From 62e9fa763bfc9b208d60b3de4ff44c569b70ce20 Mon Sep 17 00:00:00 2001 From: hferee Date: Tue, 3 Sep 2024 13:34:43 +0000 Subject: [PATCH] deploy: cae160f9d2b292c1bcac36ad0826606894ed0523 --- GL.GLS.DLW_wf_lex.html | 147 + GL.GLS.GLS_additive_cut.html | 618 + GL.GLS.GLS_calcs.html | 199 + GL.GLS.GLS_ctr.html | 1167 + GL.GLS.GLS_cut_elim.html | 88 + GL.GLS.GLS_dec.html | 318 + GL.GLS.GLS_der_dec.html | 1296 + GL.GLS.GLS_exch.html | 2278 ++ GL.GLS.GLS_export.html | 51 + GL.GLS.GLS_inv_ImpR_ImpL.html | 734 + GL.GLS.GLS_termination_measure.html | 864 + GL.GLS.GLS_wkn.html | 584 + GL.Interpolation.UIGL_And_Or_rules.html | 261 + GL.Interpolation.UIGL_Canopy.html | 534 + GL.Interpolation.UIGL_Canopy_ImpL.html | 108 + GL.Interpolation.UIGL_Canopy_ImpR.html | 241 + ...terpolation.UIGL_Canopy_nodupseq_perm.html | 405 + GL.Interpolation.UIGL_Def_measure.html | 163 + GL.Interpolation.UIGL_Diam_N_imp_UI.html | 99 + GL.Interpolation.UIGL_Diam_UI_imp_N.html | 724 + ...terpolation.UIGL_Diam_UI_imp_N_prelim.html | 319 + GL.Interpolation.UIGL_LexSeq.html | 262 + GL.Interpolation.UIGL_N_imp_UI.html | 258 + GL.Interpolation.UIGL_PermutationT.html | 195 + GL.Interpolation.UIGL_PermutationTS.html | 368 + GL.Interpolation.UIGL_UIDiam_N.html | 113 + GL.Interpolation.UIGL_UIOne.html | 233 + GL.Interpolation.UIGL_UIThree.html | 808 + GL.Interpolation.UIGL_UITwo.html | 256 + GL.Interpolation.UIGL_UI_inter.html | 631 + GL.Interpolation.UIGL_UI_prelims.html | 767 + GL.Interpolation.UIGL_basics.html | 137 + GL.Interpolation.UIGL_braga.html | 497 + GL.Interpolation.UIGL_irred_high_level.html | 144 + GL.Interpolation.UIGL_irred_short.html | 334 + GL.Interpolation.UIGL_nodupseq.html | 641 + General.List_lemmasT.html | 1328 + General.ddT.html | 915 + General.dd_fc.html | 865 + General.existsT.html | 50 + General.gen.html | 398 + General.genT.html | 688 + General.gen_seq.html | 736 + General.gen_tacs.html | 275 + General.general_export.html | 54 + General.gentree.html | 592 + General.gstep.html | 809 + General.rtcT.html | 154 + General.swappedT.html | 437 + General.univ_gen_ext.html | 624 + General.univ_gen_mod.html | 228 + ISL.Cut.html | 356 + ISL.DecisionProcedure.html | 663 + ISL.Environments.html | 874 + ISL.Formulas.html | 238 + ISL.Optimizations.html | 820 + ISL.Order.html | 497 + ISL.PropQuantifiers.html | 1209 + ISL.SequentProps.html | 1019 + ISL.Sequents.html | 303 + ISL.Simp.html | 856 + K.Interpolation.K_Craig_Interp.html | 644 + K.Interpolation.UIK_Canopy.html | 623 + K.Interpolation.UIK_Def_measure.html | 163 + K.Interpolation.UIK_UIOne.html | 166 + K.Interpolation.UIK_UIThree.html | 709 + K.Interpolation.UIK_UITwo.html | 153 + K.Interpolation.UIK_UI_prelims.html | 623 + K.Interpolation.UIK_basics.html | 293 + K.Interpolation.UIK_braga.html | 335 + K.Interpolation.UIK_irred_high_level.html | 144 + K.Interpolation.UIK_irred_short.html | 332 + K.KS.KS_additive_cut.html | 668 + K.KS.KS_calc.html | 150 + K.KS.KS_ctr.html | 955 + K.KS.KS_cut_elim.html | 87 + K.KS.KS_dec.html | 296 + K.KS.KS_exch.html | 495 + K.KS.KS_exch_ImpL.html | 589 + K.KS.KS_exch_ImpR.html | 385 + K.KS.KS_exch_KR.html | 111 + K.KS.KS_exch_prelims.html | 538 + K.KS.KS_export.html | 50 + K.KS.KS_inv_ImpR_ImpL.html | 734 + K.KS.KS_termination.html | 579 + K.KS.KS_termination_ImpL.html | 286 + K.KS.KS_termination_ImpR.html | 392 + K.KS.KS_termination_KR.html | 146 + K.KS.KS_termination_init.html | 81 + K.KS.KS_termination_measure.html | 171 + K.KS.KS_termination_prelims.html | 411 + K.KS.KS_wkn.html | 518 + Syntax.CML_Syntax.html | 277 + Syntax.Syntax_export.html | 43 + Syntax.list_lems.html | 340 + Syntax.remove_list_lems.html | 688 + UIML_extraction.UIML_extraction.html | 94 + config.js | 72 + coqdoc.css | 244 + coqdocjs.css | 249 + coqdocjs.js | 189 + demo.html | 139 + index.html | 10 + indexpage.html | 6674 ++++ toc.html | 500 + uiml_demo.bc.js | 33245 ++++++++++++++++ 106 files changed, 86421 insertions(+) create mode 100644 GL.GLS.DLW_wf_lex.html create mode 100644 GL.GLS.GLS_additive_cut.html create mode 100644 GL.GLS.GLS_calcs.html create mode 100644 GL.GLS.GLS_ctr.html create mode 100644 GL.GLS.GLS_cut_elim.html create mode 100644 GL.GLS.GLS_dec.html create mode 100644 GL.GLS.GLS_der_dec.html create mode 100644 GL.GLS.GLS_exch.html create mode 100644 GL.GLS.GLS_export.html create mode 100644 GL.GLS.GLS_inv_ImpR_ImpL.html create mode 100644 GL.GLS.GLS_termination_measure.html create mode 100644 GL.GLS.GLS_wkn.html create mode 100644 GL.Interpolation.UIGL_And_Or_rules.html create mode 100644 GL.Interpolation.UIGL_Canopy.html create mode 100644 GL.Interpolation.UIGL_Canopy_ImpL.html create mode 100644 GL.Interpolation.UIGL_Canopy_ImpR.html create mode 100644 GL.Interpolation.UIGL_Canopy_nodupseq_perm.html create mode 100644 GL.Interpolation.UIGL_Def_measure.html create mode 100644 GL.Interpolation.UIGL_Diam_N_imp_UI.html create mode 100644 GL.Interpolation.UIGL_Diam_UI_imp_N.html create mode 100644 GL.Interpolation.UIGL_Diam_UI_imp_N_prelim.html create mode 100644 GL.Interpolation.UIGL_LexSeq.html create mode 100644 GL.Interpolation.UIGL_N_imp_UI.html create mode 100644 GL.Interpolation.UIGL_PermutationT.html create mode 100644 GL.Interpolation.UIGL_PermutationTS.html create mode 100644 GL.Interpolation.UIGL_UIDiam_N.html create mode 100644 GL.Interpolation.UIGL_UIOne.html create mode 100644 GL.Interpolation.UIGL_UIThree.html create mode 100644 GL.Interpolation.UIGL_UITwo.html create mode 100644 GL.Interpolation.UIGL_UI_inter.html create mode 100644 GL.Interpolation.UIGL_UI_prelims.html create mode 100644 GL.Interpolation.UIGL_basics.html create mode 100644 GL.Interpolation.UIGL_braga.html create mode 100644 GL.Interpolation.UIGL_irred_high_level.html create mode 100644 GL.Interpolation.UIGL_irred_short.html create mode 100644 GL.Interpolation.UIGL_nodupseq.html create mode 100644 General.List_lemmasT.html create mode 100644 General.ddT.html create mode 100644 General.dd_fc.html create mode 100644 General.existsT.html create mode 100644 General.gen.html create mode 100644 General.genT.html create mode 100644 General.gen_seq.html create mode 100644 General.gen_tacs.html create mode 100644 General.general_export.html create mode 100644 General.gentree.html create mode 100644 General.gstep.html create mode 100644 General.rtcT.html create mode 100644 General.swappedT.html create mode 100644 General.univ_gen_ext.html create mode 100644 General.univ_gen_mod.html create mode 100644 ISL.Cut.html create mode 100644 ISL.DecisionProcedure.html create mode 100644 ISL.Environments.html create mode 100644 ISL.Formulas.html create mode 100644 ISL.Optimizations.html create mode 100644 ISL.Order.html create mode 100644 ISL.PropQuantifiers.html create mode 100644 ISL.SequentProps.html create mode 100644 ISL.Sequents.html create mode 100644 ISL.Simp.html create mode 100644 K.Interpolation.K_Craig_Interp.html create mode 100644 K.Interpolation.UIK_Canopy.html create mode 100644 K.Interpolation.UIK_Def_measure.html create mode 100644 K.Interpolation.UIK_UIOne.html create mode 100644 K.Interpolation.UIK_UIThree.html create mode 100644 K.Interpolation.UIK_UITwo.html create mode 100644 K.Interpolation.UIK_UI_prelims.html create mode 100644 K.Interpolation.UIK_basics.html create mode 100644 K.Interpolation.UIK_braga.html create mode 100644 K.Interpolation.UIK_irred_high_level.html create mode 100644 K.Interpolation.UIK_irred_short.html create mode 100644 K.KS.KS_additive_cut.html create mode 100644 K.KS.KS_calc.html create mode 100644 K.KS.KS_ctr.html create mode 100644 K.KS.KS_cut_elim.html create mode 100644 K.KS.KS_dec.html create mode 100644 K.KS.KS_exch.html create mode 100644 K.KS.KS_exch_ImpL.html create mode 100644 K.KS.KS_exch_ImpR.html create mode 100644 K.KS.KS_exch_KR.html create mode 100644 K.KS.KS_exch_prelims.html create mode 100644 K.KS.KS_export.html create mode 100644 K.KS.KS_inv_ImpR_ImpL.html create mode 100644 K.KS.KS_termination.html create mode 100644 K.KS.KS_termination_ImpL.html create mode 100644 K.KS.KS_termination_ImpR.html create mode 100644 K.KS.KS_termination_KR.html create mode 100644 K.KS.KS_termination_init.html create mode 100644 K.KS.KS_termination_measure.html create mode 100644 K.KS.KS_termination_prelims.html create mode 100644 K.KS.KS_wkn.html create mode 100644 Syntax.CML_Syntax.html create mode 100644 Syntax.Syntax_export.html create mode 100644 Syntax.list_lems.html create mode 100644 Syntax.remove_list_lems.html create mode 100644 UIML_extraction.UIML_extraction.html create mode 100644 config.js create mode 100644 coqdoc.css create mode 100644 coqdocjs.css create mode 100644 coqdocjs.js create mode 100644 demo.html create mode 100644 index.html create mode 100644 indexpage.html create mode 100644 toc.html create mode 100644 uiml_demo.bc.js diff --git a/GL.GLS.DLW_wf_lex.html b/GL.GLS.DLW_wf_lex.html new file mode 100644 index 0000000..0db5f88 --- /dev/null +++ b/GL.GLS.DLW_wf_lex.html @@ -0,0 +1,147 @@ + + + + + + + + + + + + + +
+
+

GL.GLS.DLW_wf_lex

+ +
+(* Modification of the file by Dominique. *)
+ +
+(**************************************************************)
+(*   Copyright Dominique Larchey-Wendling *                 *)
+(*                                                            *)
+(*                             * Affiliation LORIA -- CNRS  *)
+(**************************************************************)
+(*      This file is distributed under the terms of the       *)
+(*         CeCILL v2 FREER SOFTWARE LICENSE AGREEMENT         *)
+(**************************************************************)
+ +
+Require Import List Arith Wellfounded.
+Import ListNotations.
+ +
+Set Implicit Arguments.
+ +
+Section measure_rect.
+ +
+  Variable (X : Type) (m : X -> nat) (P : X -> Type).
+ +
+  Hypothesis F : forall x, (forall y, m y < m x -> P y) -> P x.
+ +
+  Definition measure_rect x : P x.
+  Proof.
+    cut (Acc (fun x y => m x < m y) x); [ revert x | ].
+    + refine (
+        fix loop x Dx := @F x (fun y Dy => loop y _)
+      ).
+      apply (Acc_inv Dx), Dy.
+    + apply wf_inverse_image with (f := m), lt_wf.
+  Qed.
+ +
+End measure_rect.
+ +
+Tactic Notation "induction" "on" hyp(x) "as" ident(IH) "with" "measure" uconstr(f) :=
+  pattern x; revert x; apply measure_rect with (m := fun x => f); intros x IH.
+ +
+Section lex_wf.
+ +
+  Variable (X : Type) (R : X -> X -> Prop) (Rwf : well_founded R).
+ +
+  Reserved Notation "l '<lex' m" (at level 70). (* for lexicographic product *)
+ +
+  Inductive lex : list X -> list X -> Prop :=
+    | lex_skip x l m : l <lex m -> x::l <lex x::m
+    | lex_cons x y l m : length l = length m -> R x y -> x::l <lex y::m
+  where "l <lex m" := (lex l m).
+ +
+  Fact lex_length l m : l <lex m -> length l = length m.
+  Proof. induction 1; simpl; auto. Qed.
+ +
+  Fact lex_cons_inv l m :
+          l <lex m
+       -> match m with
+            | [] => False
+            | y::m =>
+            match l with
+              | [] => False
+              | x::l => x = y /\ lex l m
+                     \/ R x y /\ length l = length m
+            end
+          end.
+  Proof. inversion 1; auto. Qed.
+ +
+  Theorem lex_wf : well_founded lex.
+  Proof.
+    intros m; induction on m as IHm with measure (length m).
+    destruct m as [ | y m ].
+    + constructor; intros l Hl; apply lex_cons_inv in Hl; easy.
+    + revert m IHm.
+      induction y as [ y IHy' ] using (well_founded_induction Rwf).
+      intros m IHm.
+      assert (Acc lex m) as Hm.
+      1: apply IHm; simpl; auto.
+      assert (forall x l, R x y -> length l = length m -> Acc lex (x::l)) as IHy.
+      1: { intros x l Hx Hl; apply IHy'; auto.
+           intros; apply IHm.
+           simpl in *; rewrite <- Hl; auto. }
+      clear IHy' IHm.
+      revert Hm IHy.
+      induction 1 as [ m Hm IHm ]; intros IHy.
+      constructor; intros l Hl; apply lex_cons_inv in Hl.
+      destruct l as [ | x l ]; try tauto.
+      destruct Hl as [ (-> & Hl) | (Hx & Hl) ].
+      * apply IHm; auto.
+        apply lex_length in Hl as ->; auto.
+      * apply IHy; auto.
+  Qed.
+ +
+End lex_wf.
+
+
+ +
+ + + diff --git a/GL.GLS.GLS_additive_cut.html b/GL.GLS.GLS_additive_cut.html new file mode 100644 index 0000000..abb2169 --- /dev/null +++ b/GL.GLS.GLS_additive_cut.html @@ -0,0 +1,618 @@ + + + + + + + + + + + + + +
+
+

GL.GLS.GLS_additive_cut

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat Arith.
+Require Import Lia.
+ +
+Require Import GLS_calcs.
+Require Import GLS_termination_measure.
+Require Import GLS_exch.
+Require Import GLS_ctr.
+Require Import GLS_wkn.
+Require Import GLS_dec.
+Require Import GLS_inv_ImpR_ImpL.
+ +
+Set Implicit Arguments.
+ +
+Theorem GLS_cut_adm_main : forall n A s Γ0 Γ1 Δ0 Δ1,
+                      (n = size A) ->
+                      (s = (Γ0 ++ Γ1, Δ0 ++ Δ1)) ->
+                      (GLS_prv (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)) ->
+                      (GLS_prv (Γ0 ++ A :: Γ1, Δ0 ++ Δ1)) ->
+                      (GLS_prv s).
+Proof.
+(* The proof is by induction on, first, size of the cut formula and on, second, the mhd
+   of the sequent-conclusion. *)

+induction n as [n PIH] using (well_founded_induction_type lt_wf).
+intros A s ; revert s A.
+refine (less_thanS_strong_inductionT _ _); intros s SIH.
+intros A Γ0 Γ1 Δ0 Δ1 size E D0 D1. inversion D0. inversion H.
+inversion D1. inversion H0.
+ +
+inversion X ; subst.
+ +
+(* Left rule is IdP *)
+- inversion H1. subst. apply list_split_form in H3. repeat destruct H3.
+  * destruct s.
+    + repeat destruct p. subst. inversion X1.
+    (* Right rule is IdP *)
+    { inversion H. subst. assert (J0 : InT (# P0) (Γ0 ++ # P :: Γ1)). rewrite <- H6. apply InT_or_app.
+      right. apply InT_eq. apply InT_app_or in J0. destruct J0.
+      - apply InT_split in i. destruct i. destruct s. subst. rewrite H2. repeat rewrite <- app_assoc.
+        assert (IdPRule [] (x ++ (# P0 :: x0) ++ Γ1, Δ2 ++ # P0 :: Δ3)). apply IdPRule_I. apply IdP in H0.
+        apply derI with (ps:=[]) ; auto.
+      - inversion i.
+        + inversion H3. subst. apply derI with (ps:=[]) ; auto. apply IdP ; apply IdPRule_I.
+        + apply InT_split in H3. destruct H3. destruct s. subst.
+          assert (J0 : InT (# P0) (Γ2 ++ # P :: Γ3)). rewrite H2. apply InT_or_app.
+          right. apply InT_or_app. right. apply InT_eq. apply InT_split in J0. destruct J0. destruct s.
+          rewrite e. apply derI with (ps:=[]) ; auto. apply IdP ; apply IdPRule_I. }
+    (* Right rule is BotL *)
+    { inversion H. subst. assert (J0 : InT () (Γ0 ++ # P :: Γ1)). rewrite <- H6. apply InT_or_app.
+      right. apply InT_eq. apply InT_app_or in J0. destruct J0.
+      - apply InT_split in i. destruct i. destruct s. subst. rewrite H2. rewrite <- app_assoc.
+        assert (BotLRule [] (x ++ ( :: x0) ++ Γ1, Δ0 ++ Δ1)). apply BotLRule_I. apply BotL in H0.
+        apply derI with (ps:=[]) ; auto.
+      - inversion i.
+        + inversion H3.
+        + apply InT_split in H3. destruct H3. destruct s. subst. rewrite H2. rewrite app_assoc.
+          assert (BotLRule [] ((Γ0 ++ x) ++ :: x0, Δ0 ++ Δ1)). apply BotLRule_I. apply BotL in H0.
+          pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ0 ++ x) ++ :: x0, Δ0 ++ Δ1) H0 X0). assumption. }
+    (* Right rule is ImpR *)
+    { inversion H. subst. assert (InT # P (Γ0 ++ Γ1)). rewrite <- H2. apply InT_or_app.
+      right. apply InT_eq. apply InT_app_or in H0. destruct H0.
+      - apply InT_split in i. destruct i.
+        destruct s. subst. repeat rewrite <- app_assoc in D1. simpl in D1.
+        assert (E0: derrec_height D1 = derrec_height D1). reflexivity.
+        assert (J0 : ctr_L # P (x ++ # P :: x0 ++ # P :: Γ1, Δ0 ++ Δ1)
+        (x ++ # P :: x0 ++ Γ1, Δ0 ++ Δ1)). apply ctr_LI.
+        pose (@GLS_hpadm_ctr_L (derrec_height D1) (x ++ # P :: x0 ++ # P :: Γ1, Δ0 ++ Δ1)
+        D1 E0 (x ++ # P :: x0 ++ Γ1, Δ0 ++ Δ1) (# P) J0). destruct s. clear l. rewrite H2.
+        rewrite <- app_assoc. rewrite H7. assumption.
+      - apply InT_split in i. destruct i. destruct s. subst.
+        assert (E0: derrec_height D1 = derrec_height D1). reflexivity.
+        assert (J0 : ctr_L # P (Γ0 ++ # P :: x ++ # P :: x0, Δ0 ++ Δ1)
+        (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1)). apply ctr_LI.
+        pose (@GLS_hpadm_ctr_L (derrec_height D1) (Γ0 ++ # P :: x ++ # P :: x0, Δ0 ++ Δ1)
+        D1 E0 (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1) (# P) J0). destruct s. clear l. rewrite H2.
+        assert (J5 : list_exch_L (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1) (Γ0 ++ x ++ # P :: x0, Δ0 ++ Δ1)).
+        assert (Γ0 ++ # P :: x ++ x0 = Γ0 ++ [# P] ++ x ++ [] ++ x0). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ x ++ # P :: x0 = Γ0 ++ [] ++ x ++ [# P] ++ x0). reflexivity. rewrite H0. clear H0.
+        apply list_exch_LI. pose (GLS_adm_list_exch_L x1 J5). rewrite H7. assumption. }
+    (* Right rule is ImpL *)
+    { inversion H. subst. assert (InT # P (Γ0 ++ Γ1)). rewrite <- H2. apply InT_or_app.
+      right. apply InT_eq. apply InT_app_or in H0. destruct H0.
+      - apply InT_split in i. destruct i.
+        destruct s. subst. repeat rewrite <- app_assoc in D1. simpl in D1.
+        assert (E0: derrec_height D1 = derrec_height D1). reflexivity.
+        assert (J0 : ctr_L # P (x ++ # P :: x0 ++ # P :: Γ1, Δ0 ++ Δ1)
+        (x ++ # P :: x0 ++ Γ1, Δ0 ++ Δ1)). apply ctr_LI.
+        pose (@GLS_hpadm_ctr_L (derrec_height D1) (x ++ # P :: x0 ++ # P :: Γ1, Δ0 ++ Δ1)
+        D1 E0 (x ++ # P :: x0 ++ Γ1, Δ0 ++ Δ1) (# P) J0). destruct s. clear l. rewrite H2.
+        rewrite <- app_assoc. rewrite H7. assumption.
+      - apply InT_split in i. destruct i. destruct s. subst.
+        assert (E0: derrec_height D1 = derrec_height D1). reflexivity.
+        assert (J0 : ctr_L # P (Γ0 ++ # P :: x ++ # P :: x0, Δ0 ++ Δ1)
+        (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1)). apply ctr_LI.
+        pose (@GLS_hpadm_ctr_L (derrec_height D1) (Γ0 ++ # P :: x ++ # P :: x0, Δ0 ++ Δ1)
+        D1 E0 (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1) (# P) J0). destruct s. clear l. rewrite H2.
+        assert (J5 : list_exch_L (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1) (Γ0 ++ x ++ # P :: x0, Δ0 ++ Δ1)).
+        assert (Γ0 ++ # P :: x ++ x0 = Γ0 ++ [# P] ++ x ++ [] ++ x0). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ x ++ # P :: x0 = Γ0 ++ [] ++ x ++ [# P] ++ x0). reflexivity. rewrite H0. clear H0.
+        apply list_exch_LI. pose (GLS_adm_list_exch_L x1 J5). rewrite H7. assumption. }
+    (* Right rule is GLR *)
+    { inversion X3. subst. assert (InT # P (Γ0 ++ Γ1)). rewrite <- H2. apply InT_or_app.
+      right. apply InT_eq. apply InT_app_or in H. destruct H.
+      - apply InT_split in i. destruct i.
+        destruct s. subst. repeat rewrite <- app_assoc in D1. simpl in D1.
+        assert (E0: derrec_height D1 = derrec_height D1). reflexivity.
+        assert (J0 : ctr_L # P (x ++ # P :: x0 ++ # P :: Γ1, Δ0 ++ Δ1)
+        (x ++ # P :: x0 ++ Γ1, Δ0 ++ Δ1)). apply ctr_LI.
+        pose (@GLS_hpadm_ctr_L (derrec_height D1) (x ++ # P :: x0 ++ # P :: Γ1, Δ0 ++ Δ1)
+        D1 E0 (x ++ # P :: x0 ++ Γ1, Δ0 ++ Δ1) (# P) J0). destruct s. clear l. rewrite H2.
+        rewrite <- app_assoc. rewrite H6. assumption.
+      - apply InT_split in i. destruct i. destruct s. subst.
+        assert (E0: derrec_height D1 = derrec_height D1). reflexivity.
+        assert (J0 : ctr_L # P (Γ0 ++ # P :: x ++ # P :: x0, Δ0 ++ Δ1)
+        (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1)). apply ctr_LI.
+        pose (@GLS_hpadm_ctr_L (derrec_height D1) (Γ0 ++ # P :: x ++ # P :: x0, Δ0 ++ Δ1)
+        D1 E0 (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1) (# P) J0). destruct s. clear l. rewrite H2.
+        assert (J5 : list_exch_L (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1) (Γ0 ++ x ++ # P :: x0, Δ0 ++ Δ1)).
+        assert (Γ0 ++ # P :: x ++ x0 = Γ0 ++ [# P] ++ x ++ [] ++ x0). reflexivity. rewrite H. clear H.
+        assert (Γ0 ++ x ++ # P :: x0 = Γ0 ++ [] ++ x ++ [# P] ++ x0). reflexivity. rewrite H. clear H.
+        apply list_exch_LI. pose (GLS_adm_list_exch_L x1 J5). rewrite H6. assumption. }
+    + repeat destruct s. repeat destruct p. subst. assert (IdPRule [] (Γ2 ++ # P :: Γ3, (Δ0 ++ x0) ++ # P :: Δ3)).
+      apply IdPRule_I. rewrite <- app_assoc in H. apply IdP in H.
+      pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[]) (Γ2 ++ # P :: Γ3, Δ0 ++ x0 ++ # P :: Δ3) H X0). assumption.
+  * repeat destruct s. repeat destruct p. subst. assert (IdPRule [] (Γ2 ++ # P :: Γ3, Δ2 ++ # P :: x ++ Δ1)).
+    apply IdPRule_I. apply IdP in H. rewrite <- app_assoc.
+    apply derI with (ps:=[]) ; auto.
+ +
+(* Left rule is BotL *)
+- inversion H1. subst. assert (BotLRule [] (Γ2 ++ :: Γ3, Δ0 ++ Δ1)).
+  apply BotLRule_I. apply BotL in H. apply derI with (ps:=[]) ; auto.
+ +
+(* Left rule is ImpR *)
+- inversion H1. subst. apply list_split_form in H3. destruct H3.
+  * destruct s.
+    + repeat destruct p. subst. inversion X1.
+      (* Right rule is IdP *)
+      { inversion H. subst. assert (J0 : InT (# P) (Γ0 ++ (A0 --> B) :: Γ1)). rewrite <- H6. apply InT_or_app.
+        right. apply InT_eq. apply InT_app_or in J0. destruct J0.
+        - apply InT_split in i. destruct i. destruct s. subst. rewrite H2. rewrite <- app_assoc.
+          assert (IdPRule [] (x ++ (# P :: x0) ++ Γ1, Δ2 ++ # P :: Δ3)). apply IdPRule_I. apply IdP in H0.
+          apply derI with (ps:=[]) ; auto.
+        - inversion i.
+          * inversion H3.
+          * apply InT_split in H3. destruct H3. destruct s. subst. rewrite H2. rewrite app_assoc.
+            assert (IdPRule [] ((Γ0 ++ x) ++ # P :: x0, Δ2 ++ # P :: Δ3)). apply IdPRule_I. apply IdP in H0.
+            apply derI with (ps:=[]) ; auto. }
+      (* Right rule is BotL *)
+      { inversion H. subst. rewrite H2. assert (J0 : InT () (Γ0 ++ (A0 --> B) :: Γ1)). rewrite <- H6. apply InT_or_app.
+        right. apply InT_eq. apply InT_app_or in J0. destruct J0.
+        - apply InT_split in i. destruct i. destruct s. subst. rewrite <- app_assoc.
+          assert (BotLRule [] (x ++ ( :: x0) ++ Γ1, Δ0 ++ Δ1)). apply BotLRule_I. apply BotL in H0.
+          apply derI with (ps:=[]) ; auto.
+        - inversion i.
+          * inversion H3.
+          * apply InT_split in H3. destruct H3. destruct s. subst. rewrite app_assoc.
+            assert (BotLRule [] ((Γ0 ++ x) ++ :: x0, Δ0 ++ Δ1)). apply BotLRule_I. apply BotL in H0.
+            apply derI with (ps:=[]) ; auto. }
+      (* Right rule is ImpR *)
+      { inversion H. subst. inversion X0. inversion X2. subst. clear X4. clear X6. rewrite <- H7 in D1.
+        assert (J1 : list_exch_L (Γ4 ++ A :: Γ5, Δ2 ++ B0 :: Δ3) (A :: Γ0 ++ A0 --> B :: Γ1, Δ2 ++ B0 :: Δ3)).
+        assert (Γ4 ++ A :: Γ5 = [] ++ [] ++ Γ4 ++ [A] ++ Γ5). reflexivity. rewrite H0. clear H0.
+        assert (A :: Γ0 ++ A0 --> B :: Γ1 = [] ++ [A] ++ Γ4 ++ [] ++ Γ5). rewrite <- H6. reflexivity.
+        rewrite H0. clear H0. apply list_exch_LI. pose (d:=GLS_adm_list_exch_L X5 J1). rewrite H2.
+        assert (ImpRRule [([] ++ A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3)] ([] ++ Γ0 ++ Γ1, Δ2 ++ A --> B0 :: Δ3)). apply ImpRRule_I.
+        simpl in H0.
+        assert (J31: GLS_rules [(A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3)] (Γ0 ++ Γ1, Δ2 ++ A --> B0 :: Δ3)).
+        apply ImpR ; try assumption.
+        assert (J21: In (A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3) [(A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3)]). apply in_eq.
+        assert (J3: (A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3) << (Γ0 ++ Γ1, Δ0 ++ Δ1)). apply ImpR_applic_reduces_measure ; rewrite <- H7 ; auto.
+        assert (J5: size (A0 --> B) = size (A0 --> B)). reflexivity.
+        assert (J7 : (A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3) = ((A :: Γ0) ++ Γ1, [] ++ Δ2 ++ B0 :: Δ3)). reflexivity.
+        pose (d0:=@SIH _ J3 (A0 --> B) (A :: Γ0) Γ1 [] (Δ2 ++ B0 :: Δ3) J5 J7). simpl in d0.
+        assert (J8 : list_exch_R (Γ0 ++ Γ1, Δ0 ++ A0 --> B :: Δ1) (Γ0 ++ Γ1, A0 --> B :: Δ2 ++ A --> B0 :: Δ3)).
+        assert (Δ0 ++ A0 --> B :: Δ1 = [] ++ [] ++ Δ0 ++ [A0 --> B] ++ Δ1). reflexivity. rewrite H3. clear H3.
+        assert (A0 --> B :: Δ2 ++ A --> B0 :: Δ3 = [] ++ [A0 --> B] ++ Δ0 ++ [] ++ Δ1). rewrite H7.
+        reflexivity. rewrite H3. clear H3. apply list_exch_RI. pose (d1:=GLS_adm_list_exch_R D0 J8).
+        assert (ImpRRule [([] ++ A :: Γ0 ++ Γ1, (A0 --> B :: Δ2) ++ B0 :: Δ3)] ([] ++ Γ0 ++ Γ1, (A0 --> B :: Δ2) ++ A --> B0 :: Δ3)).
+        apply ImpRRule_I. simpl in H3. pose (d2:=ImpR_inv d1 H3). pose (d3:=d0 d2 d).
+        apply ImpR in H0 ; try intro ; try apply f ; try rewrite <- H7 ; try auto ; try assumption.
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3)]) (Γ0 ++ Γ1, Δ2 ++ A --> B0 :: Δ3) H0). apply d4. apply dlCons ; auto. apply dlNil. }
+      (* Right rule is ImpL *)
+      { inversion H. subst. inversion X0. inversion X2. subst. clear X4. inversion X6. subst. clear X7.
+        clear X6. apply list_split_form in H6. destruct H6.
+        - destruct s.
+          * repeat destruct p. inversion e0. subst. rewrite H2.
+            assert (J1 : list_exch_L (Γ2 ++ A0 :: Γ3, Δ0 ++ B :: Δ1) (A0 :: Γ0 ++ Γ1, Δ0 ++ B :: Δ1)).
+            assert (Γ2 ++ A0 :: Γ3 = [] ++ [] ++ Γ2 ++ [A0] ++ Γ3). reflexivity. rewrite H0. clear H0.
+            assert (A0 :: Γ0 ++ Γ1 = [] ++ [A0] ++ Γ2 ++ [] ++ Γ3). rewrite <- H2. reflexivity.
+            rewrite H0. clear H0. apply list_exch_LI. pose (d:=GLS_adm_list_exch_L X3 J1).
+            assert (J2 : list_exch_R (A0 :: Γ0 ++ Γ1, Δ0 ++ B :: Δ1) (A0 :: Γ0 ++ Γ1, B :: Δ2 ++ Δ3)).
+            assert (Δ0 ++ B :: Δ1 = [] ++ [] ++ Δ0 ++ [B] ++ Δ1). reflexivity. rewrite H0. clear H0.
+            assert (B :: Δ2 ++ Δ3 = [] ++ [B] ++ Δ0 ++ [] ++ Δ1). rewrite H7. reflexivity. rewrite H0. clear H0.
+            apply list_exch_RI. pose (d0:=GLS_adm_list_exch_R d J2).
+            assert (J3: size A0 < size (A0 --> B)). simpl. lia.
+            assert (J4: size A0 = size A0). reflexivity.
+            assert (J6: (Γ2 ++ Γ3, B :: Δ2 ++ Δ3) = ([] ++ Γ2 ++ Γ3, (B :: Δ2) ++ Δ3)). reflexivity.
+            pose (d1:=PIH _ J3 A0 (Γ2 ++ Γ3, B :: Δ2 ++ Δ3) [] (Γ2 ++ Γ3) (B :: Δ2) Δ3 J4 J6). simpl in d1.
+            assert (J7 : wkn_R B (Γ2 ++ Γ3, Δ2 ++ A0 :: Δ3) (Γ2 ++ Γ3, B :: Δ2 ++ A0 :: Δ3)).
+            assert ((Γ2 ++ Γ3, Δ2 ++ A0 :: Δ3) = (Γ2 ++ Γ3, [] ++ Δ2 ++ A0 :: Δ3)). reflexivity. rewrite H0. clear H0.
+            assert ((Γ2 ++ Γ3, B :: Δ2 ++ A0 :: Δ3) = (Γ2 ++ Γ3, [] ++ B :: Δ2 ++ A0 :: Δ3)).
+            reflexivity. rewrite H0. clear H0. apply wkn_RI. rewrite <- H2 in X5.
+            assert (J8 : derrec_height X5 = derrec_height X5).
+            reflexivity. pose (GLS_wkn_R X5 J8 J7). destruct s. rewrite <- H2 in d0. pose (d2:=d1 x d0).
+            assert (J9: size B < size (A0 --> B)). simpl. lia.
+            assert (J10: size B = size B). reflexivity.
+            assert (J12: (Γ2 ++ Γ3, Δ2 ++ Δ3) = (Γ2 ++ Γ3, [] ++ Δ2 ++ Δ3)). reflexivity.
+            pose (d3:=PIH _ J9 B (Γ2 ++ Γ3, Δ2 ++ Δ3) Γ2 Γ3 [] (Δ2 ++ Δ3) J10 J12). simpl in d3.
+            assert (J30 : list_exch_L (Γ0 ++ B :: Γ1, Δ2 ++ Δ3) (B :: Γ2 ++ Γ3, Δ2 ++ Δ3)).
+            assert (Γ0 ++ B :: Γ1 = [] ++ [] ++ Γ0 ++ [B] ++ Γ1). reflexivity. rewrite H0. clear H0.
+            assert (B :: Γ2 ++ Γ3 = [] ++ [B] ++ Γ0 ++ [] ++ Γ1). rewrite H2. reflexivity.
+            rewrite H0. clear H0. apply list_exch_LI. pose (d4:=GLS_adm_list_exch_L X4 J30).
+            assert (J40 : list_exch_L (B :: Γ2 ++ Γ3, Δ2 ++ Δ3) (Γ2 ++ B :: Γ3, Δ2 ++ Δ3)).
+            assert (Γ2 ++ B :: Γ3 = [] ++ [] ++ Γ2 ++ [B] ++ Γ3). reflexivity. rewrite H0. clear H0.
+            assert (B :: Γ2 ++ Γ3 = [] ++ [B] ++ Γ2 ++ [] ++ Γ3). reflexivity. rewrite H0. clear H0.
+            apply list_exch_LI. pose (d5:=GLS_adm_list_exch_L d4 J40). pose (d3 d2 d5). rewrite <- H2. assumption.
+          * repeat destruct s. repeat destruct p. subst. rewrite H2. repeat rewrite <- app_assoc in X5. repeat rewrite <- app_assoc in X4.
+            simpl in X4. simpl in X5.
+            assert (J1 : list_exch_R (Γ0 ++ x0 ++ A --> B0 :: Γ5, Δ0 ++ A0 --> B :: Δ1) (Γ0 ++ x0 ++ A --> B0 :: Γ5, A0 --> B :: Δ2 ++ Δ3)).
+            assert (Δ0 ++ A0 --> B :: Δ1 = [] ++ [] ++ Δ0 ++ [A0 --> B] ++ Δ1). reflexivity. rewrite H0. clear H0.
+            assert (A0 --> B :: Δ2 ++ Δ3 = [] ++ [A0 --> B] ++ Δ0 ++ [] ++ Δ1). rewrite H7. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+            pose (d:=GLS_adm_list_exch_R D0 J1).
+            assert (ImpLRule [((Γ0 ++ x0) ++ Γ5, Δ2 ++ A :: Δ3); ((Γ0 ++ x0) ++ B0 :: Γ5, Δ2 ++ Δ3)] ((Γ0 ++ x0) ++ A --> B0 :: Γ5, Δ2 ++ Δ3)).
+            apply ImpLRule_I. simpl in H0. repeat rewrite <- app_assoc in H0.
+            assert (J3: (Γ0 ++ x0 ++ Γ5, Δ2 ++ A :: Δ3) << (Γ0 ++ x0 ++ A --> B0 :: Γ5, Δ2 ++ Δ3)). apply ImpL_applic_reduces_measure in H0.
+            destruct H0 ; auto.
+            assert (J5: size (A0 --> B) = size (A0 --> B)). reflexivity.
+            assert (J7 : (Γ0 ++ x0 ++ Γ5, Δ2 ++ A :: Δ3) = (Γ0 ++ x0 ++ Γ5, [] ++ Δ2 ++ A :: Δ3)). reflexivity. rewrite <- H7 in SIH.
+            pose (d0:=@SIH _ J3 (A0 --> B) Γ0 (x0 ++ Γ5) [] (Δ2 ++ A :: Δ3) J5 J7). simpl in d0.
+            assert (J3b: (Γ0 ++ x0 ++ B0 :: Γ5, Δ2 ++ Δ3) << (Γ0 ++ x0 ++ A --> B0 :: Γ5, Δ2 ++ Δ3)). apply ImpL_applic_reduces_measure in H0.
+            destruct H0 ; auto.
+            assert (J8: size (A0 --> B) = size (A0 --> B)). reflexivity.
+            assert (J10: (Γ0 ++ x0 ++ B0 :: Γ5, Δ2 ++ Δ3) = (Γ0 ++ x0 ++ B0 :: Γ5, [] ++ Δ2 ++ Δ3)). reflexivity.
+            pose (d1:=@SIH _ J3b (A0 --> B) Γ0 (x0 ++ B0 :: Γ5) [] (Δ2 ++ Δ3) J8 J10). simpl in d1.
+            assert (ImpLRule [((Γ0 ++ x0) ++ Γ5, (A0 --> B :: Δ2) ++ A :: Δ3); ((Γ0 ++ x0) ++ B0 :: Γ5, (A0 --> B :: Δ2) ++ Δ3)] ((Γ0 ++ x0) ++ A --> B0 :: Γ5, (A0 --> B :: Δ2) ++ Δ3)).
+            apply ImpLRule_I. repeat rewrite <- app_assoc in H3. pose (ImpL_inv d H3). destruct p as [d2 d3].
+            pose (d4:=d0 d2 X5). pose (d5:=d1 d3 X4). apply ImpL in H0 ; try intro ; try apply f ; try repeat rewrite <- app_assoc ; try rewrite <- H7 ;
+            try repeat rewrite app_nil_r ; try auto ; try assumption.
+            apply derI with (ps:=[(Γ0 ++ x0 ++ Γ5, Δ2 ++ A :: Δ3); (Γ0 ++ x0 ++ B0 :: Γ5, Δ2 ++ Δ3)]) ; auto.
+            apply dlCons ; auto. apply dlCons ; auto. apply dlNil.
+        - repeat destruct s. repeat destruct p. subst. rewrite H2. rewrite <- app_assoc. rewrite <- app_assoc in D0.
+          assert (J1 : list_exch_R (Γ4 ++ (A --> B0 :: x) ++ Γ1, Δ0 ++ A0 --> B :: Δ1) (Γ4 ++ (A --> B0 :: x) ++ Γ1, A0 --> B :: Δ2 ++ Δ3)).
+          assert (Δ0 ++ A0 --> B :: Δ1 = [] ++ [] ++ Δ0 ++ [A0 --> B] ++ Δ1). reflexivity. rewrite H0. clear H0.
+          assert (A0 --> B :: Δ2 ++ Δ3 = [] ++ [A0 --> B] ++ Δ0 ++ [] ++ Δ1). rewrite H7. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+          pose (d:=GLS_adm_list_exch_R D0 J1).
+          assert (ImpLRule [(Γ4 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ4 ++ (B0 :: x) ++ Γ1, Δ2 ++ Δ3)] (Γ4 ++ (A --> B0 :: x) ++ Γ1, Δ2 ++ Δ3)).
+          apply ImpLRule_I. simpl in H0.
+          assert (J3: (Γ4 ++ x ++ Γ1, Δ2 ++ A :: Δ3) << (Γ4 ++ A --> B0 :: x ++ Γ1, Δ2 ++ Δ3)). apply ImpL_applic_reduces_measure in H0.
+          destruct H0 ; auto. rewrite <- H7 in SIH. rewrite <- app_assoc in SIH.
+          assert (J5: size (A0 --> B) = size (A0 --> B)). reflexivity.
+          assert (J7 : (Γ4 ++ x ++ Γ1, Δ2 ++ A :: Δ3) = ((Γ4 ++ x) ++ Γ1, [] ++ Δ2 ++ A :: Δ3)). rewrite <- app_assoc. reflexivity.
+          pose (d0:=@SIH _ J3 (A0 --> B) (Γ4 ++ x) Γ1 [] (Δ2 ++ A :: Δ3) J5 J7). simpl in d0. repeat rewrite <- app_assoc in d0.
+          assert (J3b: (Γ4 ++ (B0 :: x) ++ Γ1, Δ2 ++ Δ3) << (Γ4 ++ A --> B0 :: x ++ Γ1, Δ2 ++ Δ3)). apply ImpL_applic_reduces_measure in H0.
+          destruct H0 ; auto.
+          assert (J8: size (A0 --> B) = size (A0 --> B)). reflexivity.
+          assert (J10: (Γ4 ++ B0 :: x ++ Γ1, Δ2 ++ Δ3) = ((Γ4 ++ B0 :: x) ++ Γ1, [] ++ Δ2 ++ Δ3)). rewrite <- app_assoc. reflexivity.
+          pose (d1:=@SIH _ J3b (A0 --> B) (Γ4 ++ B0 :: x) Γ1 [] (Δ2 ++ Δ3) J8 J10). simpl in d1.
+          assert (ImpLRule [(Γ4 ++ x ++ Γ1, (A0 --> B :: Δ2) ++ A :: Δ3); (Γ4 ++ (B0 :: x) ++ Γ1, (A0 --> B :: Δ2) ++ Δ3)] (Γ4 ++ (A --> B0 :: x) ++ Γ1, (A0 --> B :: Δ2) ++ Δ3)).
+          apply ImpLRule_I. repeat rewrite <- app_assoc in H3. pose (ImpL_inv d H3). destruct p as [d2 d3].
+          pose (d4:=d0 d2 X5). repeat rewrite <- app_assoc in d1. pose (d5:=d1 d3 X4). apply ImpL in H0 ; try intro ; try apply f ; try repeat rewrite <- app_assoc ; try rewrite <- H7 ;
+          try repeat rewrite app_nil_r ; try auto ; try assumption. apply derI with (ps:=[(Γ4 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ4 ++ B0 :: x ++ Γ1, Δ2 ++ Δ3)]) ; auto.
+          apply dlCons ; auto. apply dlCons ; auto. apply dlNil. }
+      (* Right rule is GLR *)
+      { inversion X3. subst. rewrite H2.
+        assert (GLRRule [(XBoxed_list ++ [Box A], [A])] (Γ0 ++ Γ1, Δ2 ++ Box A :: Δ3)).
+        apply GLRRule_I ; try assumption.
+        apply univ_gen_ext_splitR in X4. destruct X4. destruct s. repeat destruct p. subst.
+        apply univ_gen_ext_combine. assumption. apply univ_gen_ext_not_In_delete in u0. assumption.
+        intro. assert (In (A0 --> B) (x ++ x0)). apply in_or_app. auto. apply H5 in H0. destruct H0.
+        inversion H0. apply GLR in X5.
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(XBoxed_list ++ [Box A], [A])]) (Γ0 ++ Γ1, Δ2 ++ Box A :: Δ3) X5 X2).
+        assumption. }
+    + repeat destruct s. repeat destruct p. subst.
+      assert (J5 : list_exch_L (Γ0 ++ A :: Γ1, Δ0 ++ x0 ++ A0 --> B :: Δ3) (A :: Γ2 ++ Γ3, Δ0 ++ x0 ++ A0 --> B :: Δ3)).
+      rewrite H2. assert (Γ0 ++ A :: Γ1 = [] ++ [] ++ Γ0 ++ [A] ++ Γ1). reflexivity. rewrite H. clear H.
+      assert (A :: Γ0 ++ Γ1 = [] ++ [A] ++ Γ0 ++ [] ++ Γ1). reflexivity. rewrite H. clear H.
+      apply list_exch_LI. pose (d:=GLS_adm_list_exch_L D1 J5).
+      assert (ImpRRule [((A :: Γ2) ++ A0 :: Γ3, (Δ0 ++ x0) ++ B :: Δ3)] ((A :: Γ2) ++ Γ3, (Δ0 ++ x0) ++ A0 --> B :: Δ3)).
+      apply ImpRRule_I. repeat rewrite <- app_assoc in H. pose (d0:=ImpR_inv d H).
+      assert (ImpRRule [(Γ2 ++ A0 :: Γ3, (Δ0 ++ x0) ++ B :: Δ3)] (Γ2 ++ Γ3, (Δ0 ++ x0) ++ A0 --> B :: Δ3)).
+      apply ImpRRule_I. repeat rewrite <- app_assoc in H0.
+      assert ((Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3) << (Γ2 ++ Γ3, Δ0 ++ x0 ++ A0 --> B :: Δ3)). apply ImpR_applic_reduces_measure ; auto.
+      assert (GLS_rules [(Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3)] (Γ2 ++ Γ3, Δ0 ++ x0 ++ A0 --> B :: Δ3)).
+      apply ImpR. assumption.
+      assert (J3 : size A = size A). reflexivity.
+      assert (J4 : (Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3) = ([] ++ Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3)).
+      repeat rewrite <- app_assoc. reflexivity. rewrite <- H2 in SIH.
+      pose (d1:=@SIH _ H3 A [] (Γ2 ++ A0 :: Γ3) Δ0 (x0 ++ B :: Δ3) J3 J4). repeat rewrite <- app_assoc in d1. simpl in d1.
+      inversion X0. subst. repeat rewrite <- app_assoc in X4. pose (d2:=d1 X4 d0). pose (dlCons d2 X5).
+      pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[(Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3)]) (Γ2 ++ Γ3, Δ0 ++ x0 ++ A0 --> B :: Δ3) X3 d3). assumption.
+  * repeat destruct s. repeat destruct p. subst. repeat rewrite <- app_assoc. repeat rewrite <- app_assoc in D1.
+    assert (J5 : list_exch_L (Γ0 ++ A :: Γ1, Δ2 ++ (A0 --> B :: x) ++ Δ1) (A :: Γ2 ++ Γ3, Δ2 ++ (A0 --> B :: x) ++ Δ1)).
+    assert (Γ0 ++ A :: Γ1 = [] ++ [] ++ Γ0 ++ [A] ++ Γ1). reflexivity. rewrite H. clear H.
+    assert (A :: Γ2 ++ Γ3 = [] ++ [A] ++ Γ0 ++ [] ++ Γ1). rewrite H2. reflexivity. rewrite H. clear H.
+    apply list_exch_LI. pose (d:=GLS_adm_list_exch_L D1 J5).
+    assert (ImpRRule [((A :: Γ2) ++ A0 :: Γ3, Δ2 ++ B :: x ++ Δ1)] ((A :: Γ2) ++ Γ3, Δ2 ++ (A0 --> B :: x) ++ Δ1)).
+    apply ImpRRule_I. repeat rewrite <- app_assoc in H. pose (d0:=ImpR_inv d H).
+    assert (ImpRRule [(Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1)] (Γ2 ++ Γ3, Δ2 ++ (A0 --> B :: x) ++ Δ1)).
+    apply ImpRRule_I.
+    assert ((Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1) << (Γ2 ++ Γ3, Δ2 ++ (A0 --> B :: x) ++ Δ1)).
+    apply ImpR_applic_reduces_measure ; auto.
+    assert (GLS_rules [(Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1)] (Γ2 ++ Γ3, Δ2 ++ (A0 --> B :: x) ++ Δ1)).
+    apply ImpR ; try assumption. rewrite <- H2 in SIH.
+    assert (J3 : size A = size A). reflexivity.
+    assert (J4 : (Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1) = ([] ++ Γ2 ++ A0 :: Γ3, (Δ2 ++ B :: x) ++ Δ1)).
+    repeat rewrite <- app_assoc. reflexivity. repeat rewrite <- app_assoc in SIH.
+    pose (d1:=@SIH _ H3 A [] (Γ2 ++ A0 :: Γ3) (Δ2 ++ (B :: x)) Δ1 J3 J4). simpl in d1. repeat rewrite <- app_assoc in d1.
+    inversion X0. subst. pose (d2:=d1 X4 d0). pose (dlCons d2 X5).
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[(Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1)]) (Γ2 ++ Γ3, Δ2 ++ (A0 --> B :: x) ++ Δ1) X3 d3). assumption.
+ +
+(* Left rule is ImpL *)
+- inversion H1. subst. inversion X0. inversion X4. subst. clear X6. clear X4.
+  assert (J5 : list_exch_L (Γ0 ++ A :: Γ1, Δ0 ++ Δ1) (A :: Γ2 ++ A0 --> B :: Γ3, Δ0 ++ Δ1)).
+  rewrite H2. assert (Γ0 ++ A :: Γ1 = [] ++ [] ++ Γ0 ++ [A] ++ Γ1).
+  reflexivity. rewrite H. clear H.
+  assert (A :: Γ0 ++ Γ1 = [] ++ [A] ++ Γ0 ++ [] ++ Γ1). reflexivity. rewrite H. clear H.
+  apply list_exch_LI. pose (d:=GLS_adm_list_exch_L D1 J5). rewrite H3 in X5.
+  assert (J40 : list_exch_R (Γ2 ++ Γ3, Δ2 ++ A0 :: Δ3) (Γ2 ++ Γ3, A0 :: Δ0 ++ A :: Δ1)).
+  rewrite <- H3. assert (Δ2 ++ A0 :: Δ3 = [] ++ [] ++ Δ2 ++ [A0] ++ Δ3).
+  reflexivity. rewrite H. clear H.
+  assert (A0 :: Δ2 ++ Δ3 = [] ++ [A0] ++ Δ2 ++ [] ++ Δ3). reflexivity. rewrite H. clear H.
+  apply list_exch_RI. pose (d0:=GLS_adm_list_exch_R X3 J40).
+  assert (ImpLRule [(A :: Γ2 ++ Γ3, [] ++ A0 :: Δ0 ++ Δ1); (A :: Γ2 ++ B :: Γ3, [] ++ Δ0 ++ Δ1)] (A :: Γ2 ++ A0 --> B :: Γ3, [] ++ Δ0 ++ Δ1)).
+  assert ((A :: Γ2 ++ A0 --> B :: Γ3, [] ++ Δ0 ++ Δ1) = ((A :: Γ2) ++ A0 --> B :: Γ3, [] ++ Δ0 ++ Δ1)). reflexivity.
+  rewrite H. clear H.
+  assert ((A :: Γ2 ++ Γ3, [] ++ A0 :: Δ0 ++ Δ1) = ((A :: Γ2) ++ Γ3, [] ++ A0 :: Δ0 ++ Δ1)). reflexivity.
+  rewrite H. clear H.
+  assert ((A :: Γ2 ++ B :: Γ3, [] ++ Δ0 ++ Δ1) = ((A :: Γ2) ++ B :: Γ3, [] ++ Δ0 ++ Δ1)). reflexivity.
+  rewrite H. clear H. apply ImpLRule_I. simpl in H. pose (ImpL_inv d H). destruct p as [d1 d2].
+  assert (ImpLRule [(Γ2 ++ Γ3, [] ++ A0 :: Δ0 ++ Δ1); (Γ2 ++ B :: Γ3, [] ++ Δ0 ++ Δ1)] (Γ2 ++ A0 --> B :: Γ3, [] ++ Δ0 ++ Δ1)).
+  apply ImpLRule_I. simpl in H0.
+  assert (lt0: (Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1) << (Γ2 ++ A0 --> B :: Γ3, Δ0 ++ Δ1)).
+   apply ImpL_applic_reduces_measure in H0. destruct H0 ; auto.
+  assert (GLS_rules [(Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1); (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)] (Γ2 ++ A0 --> B :: Γ3, Δ0 ++ Δ1)).
+  apply ImpL. assumption.
+  assert (J3 : size A = size A). reflexivity.
+  assert (J4 : (Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1) = ([] ++ Γ2 ++ Γ3, (A0 :: Δ0) ++ Δ1)).
+  repeat rewrite <- app_assoc. reflexivity. rewrite <- H2 in SIH.
+  pose (d3:=@SIH _ lt0 A [] (Γ2 ++ Γ3) (A0 :: Δ0) Δ1 J3 J4). repeat rewrite <- app_assoc in d3. simpl in d3.
+  pose (d4:=d3 d0 d1).
+  assert (lt1: (Γ2 ++ B :: Γ3, Δ0 ++ Δ1) << (Γ2 ++ A0 --> B :: Γ3, Δ0 ++ Δ1)).
+   apply ImpL_applic_reduces_measure in H0. destruct H0 ; auto.
+  assert (J33 : size A = size A). reflexivity.
+  assert (J34 : (Γ2 ++ B :: Γ3, Δ0 ++ Δ1) = ([] ++ Γ2 ++ B :: Γ3, Δ0 ++ Δ1)).
+  repeat rewrite <- app_assoc. reflexivity.
+  pose (d5:=@SIH _ lt1 A [] (Γ2 ++ B :: Γ3) Δ0 Δ1 J33 J34). repeat rewrite <- app_assoc in d5. simpl in d5.
+  pose (d6:=d5 X5 d2). apply derI with (ps:=[(Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1); (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)]) ; auto.
+  apply dlCons ; auto. apply dlCons ; auto. apply dlNil.
+ +
+(* Left rule is GLR *)
+- inversion X3. subst. apply list_split_form in H2. destruct H2.
+  * destruct s.
+    + repeat destruct p. subst. inversion X1.
+      (* Right rule is IdP *)
+      { inversion H. subst. assert (J0 : InT (# P) (Γ0 ++ Box A0 :: Γ1)). rewrite <- H5. apply InT_or_app.
+        right. apply InT_eq. apply InT_app_or in J0. destruct J0.
+        - apply InT_split in i. destruct i. destruct s. subst. rewrite <- app_assoc. apply derI with (ps:=[]).
+          apply IdP. apply IdPRule_I. apply dlNil.
+        - inversion i.
+          * inversion H2.
+          * apply InT_split in H2. destruct H2. destruct s. subst. rewrite app_assoc. apply derI with (ps:=[]).
+          apply IdP. apply IdPRule_I. apply dlNil. }
+      (* Right rule is BotL *)
+      { inversion H. subst. assert (J0 : InT () (Γ0 ++ Box A0 :: Γ1)). rewrite <- H5. apply InT_or_app.
+        right. apply InT_eq. apply InT_app_or in J0. destruct J0.
+        - apply InT_split in i. destruct i. destruct s. subst. rewrite <- app_assoc. apply derI with (ps:=[]).
+          apply BotL. apply BotLRule_I. apply dlNil.
+        - inversion i.
+          * inversion H2.
+          * apply InT_split in H2. destruct H2. destruct s. subst. rewrite app_assoc. apply derI with (ps:=[]).
+          apply BotL. apply BotLRule_I. apply dlNil. }
+      (* Right rule is ImpR *)
+      { inversion H. subst. inversion X2. subst. clear X6. rewrite <- H6 in D1.
+        assert (J1 : list_exch_L (Γ2 ++ A :: Γ3, Δ2 ++ B :: Δ3) (A :: Γ0 ++ Box A0 :: Γ1, Δ2 ++ B :: Δ3)).
+        assert (Γ2 ++ A :: Γ3 = [] ++ [] ++ Γ2 ++ [A] ++ Γ3). reflexivity. rewrite H0. clear H0.
+        assert (A :: Γ0 ++ Box A0 :: Γ1 = [] ++ [A] ++ Γ2 ++ [] ++ Γ3). rewrite <- H5. reflexivity.
+        rewrite H0. clear H0. apply list_exch_LI. pose (d:=GLS_adm_list_exch_L X5 J1).
+        assert (ImpRRule [([] ++ A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3)] ([] ++ Γ0 ++ Γ1, Δ2 ++ A --> B :: Δ3)). apply ImpRRule_I.
+        simpl in H0.
+        assert (J3: (A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3) << (Γ0 ++ Γ1, Δ2 ++ A --> B :: Δ3)).
+        apply ImpR_applic_reduces_measure ; auto.
+        assert (J31: GLS_rules [(A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3)] (Γ0 ++ Γ1, Δ2 ++ A --> B :: Δ3)).
+        apply ImpR ; try assumption. rewrite <- H6 in SIH.
+        assert (J5: size (Box A0) = size (Box A0)). reflexivity.
+        assert (J7 : (A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3) = ((A :: Γ0) ++ Γ1, [] ++ Δ2 ++ B :: Δ3)). reflexivity.
+        pose (d0:=@SIH _ J3 (Box A0) (A :: Γ0) Γ1 [] (Δ2 ++ B :: Δ3) J5 J7). simpl in d0.
+        assert (J8 : list_exch_R (Γ0 ++ Γ1, Δ0 ++ Box A0 :: Δ1) (Γ0 ++ Γ1, Box A0 :: Δ2 ++ A --> B :: Δ3)).
+        assert (Δ0 ++ Box A0 :: Δ1 = [] ++ [] ++ Δ0 ++ [Box A0] ++ Δ1). reflexivity. rewrite H2. clear H2.
+        assert (Box A0 :: Δ2 ++ A --> B :: Δ3 = [] ++ [Box A0] ++ Δ0 ++ [] ++ Δ1). rewrite H6.
+        reflexivity. rewrite H2. clear H2. apply list_exch_RI. pose (d1:=GLS_adm_list_exch_R D0 J8).
+        assert (ImpRRule [([] ++ A ::Γ0 ++ Γ1, (Box A0 :: Δ2) ++ B :: Δ3)] ([] ++ Γ0 ++ Γ1, (Box A0 :: Δ2) ++ A --> B :: Δ3)).
+        apply ImpRRule_I. simpl in H2. pose (d2:=ImpR_inv d1 H2). pose (d3:=d0 d2 d). apply derI with (ps:=[(A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3)]) ; auto.
+        apply dlCons ; auto. apply dlNil. }
+      (* Right rule is ImpL *)
+      { inversion H. subst. apply list_split_form in H5. destruct H5.
+        - destruct s.
+          + repeat destruct p. inversion e0.
+          + repeat destruct s. repeat destruct p. subst. repeat rewrite <- app_assoc in H. repeat rewrite <- app_assoc in X2.
+            assert (J2: list_exch_R (Γ0 ++ x0 ++ A --> B :: Γ3, Δ0 ++ Box A0 :: Δ1) (Γ0 ++ x0 ++ A --> B :: Γ3, Box A0 :: Δ2 ++ Δ3)).
+            assert (Δ0 ++ Box A0 :: Δ1 = [] ++ [] ++ Δ0 ++ [Box A0] ++ Δ1). reflexivity. rewrite H0. clear H0.
+            assert (Box A0 :: Δ2 ++ Δ3 = [] ++ [Box A0] ++ Δ0 ++ [] ++ Δ1). rewrite H6. reflexivity. rewrite H0. clear H0.
+            apply list_exch_RI. pose (d:=GLS_adm_list_exch_R D0 J2).
+            assert (ImpLRule [((Γ0 ++ x0) ++ Γ3, (Box A0 :: Δ2) ++ A :: Δ3); ((Γ0 ++ x0) ++ B :: Γ3, (Box A0 :: Δ2) ++ Δ3)]
+            ((Γ0 ++ x0) ++ A --> B :: Γ3, (Box A0 :: Δ2) ++ Δ3)). apply ImpLRule_I. simpl in H.
+            repeat rewrite <- app_assoc in H0. pose (ImpL_inv d H0). destruct p as [d0 d1].
+            assert (ImpLRule [((Γ0 ++ x0) ++ Γ3, Δ2 ++ A :: Δ3); ((Γ0 ++ x0) ++ B :: Γ3, Δ2 ++ Δ3)]
+            ((Γ0 ++ x0) ++ A --> B :: Γ3, Δ2 ++ Δ3)). apply ImpLRule_I. repeat rewrite <- app_assoc in H0.
+            repeat rewrite <- app_assoc in H2.
+            assert (J3: (Γ0 ++ x0 ++ Γ3, Δ2 ++ A :: Δ3) << (Γ0 ++ x0 ++ A --> B :: Γ3, Δ2 ++ Δ3)).
+            apply ImpL_applic_reduces_measure in H2. destruct H2 ; auto.
+            assert (J30: GLS_rules [(Γ0 ++ x0 ++ Γ3, Δ2 ++ A :: Δ3); (Γ0 ++ x0 ++ B :: Γ3, Δ2 ++ Δ3)]
+            (Γ0 ++ x0 ++ A --> B :: Γ3, Δ2 ++ Δ3)). apply ImpL ; try assumption.
+            repeat rewrite <- app_assoc in SIH. rewrite <- H6 in SIH.
+            assert (J3b: (Γ0 ++ x0 ++ B :: Γ3, Δ2 ++ Δ3) << (Γ0 ++ x0 ++ A --> B :: Γ3, Δ2 ++ Δ3)).
+            apply ImpL_applic_reduces_measure in H2. destruct H2 ; auto.
+            assert (J6: size (Box A0) = size (Box A0)). reflexivity.
+            assert (J8: (Γ0 ++ x0 ++ Γ3, Δ2 ++ A :: Δ3) = (Γ0 ++ x0 ++ Γ3, [] ++ Δ2 ++ A :: Δ3)). reflexivity.
+            pose (d2:=@SIH _ J3 (Box A0) Γ0 (x0 ++ Γ3) [] (Δ2 ++ A :: Δ3) J6 J8). simpl in d2. inversion X2.
+            subst. inversion X6. clear X6. subst. pose (d3:=d2 d0 X5).
+            assert (J11: (Γ0 ++ x0 ++ B :: Γ3, Δ2 ++ Δ3) = (Γ0 ++ x0 ++ B :: Γ3, [] ++ Δ2 ++ Δ3)). reflexivity.
+            pose (d4:=@SIH _ J3b (Box A0) Γ0 (x0 ++ B :: Γ3) [] (Δ2 ++ Δ3) J6 J11). simpl in d4. pose (d5:=d4 d1 X7).
+            pose (dlCons d5 X8). pose (dlCons d3 d6).
+            pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[(Γ0 ++ x0 ++ Γ3, Δ2 ++ A :: Δ3); (Γ0 ++ x0 ++ B :: Γ3, Δ2 ++ Δ3)]) (Γ0 ++ x0 ++ A --> B :: Γ3, Δ2 ++ Δ3) J30 d7).
+            assumption.
+        - repeat destruct s. repeat destruct p. subst. rewrite <- app_assoc in D0.
+          assert (J2: list_exch_R (Γ2 ++ (A --> B :: x) ++ Γ1, Δ0 ++ Box A0 :: Δ1) (Γ2 ++ (A --> B :: x) ++ Γ1, Box A0 :: Δ2 ++ Δ3)).
+          assert (Δ0 ++ Box A0 :: Δ1 = [] ++ [] ++ Δ0 ++ [Box A0] ++ Δ1). reflexivity. rewrite H0. clear H0.
+          assert (Box A0 :: Δ2 ++ Δ3 = [] ++ [Box A0] ++ Δ0 ++ [] ++ Δ1). rewrite H6. reflexivity. rewrite H0. clear H0.
+          apply list_exch_RI. pose (d:=GLS_adm_list_exch_R D0 J2).
+          assert (ImpLRule [(Γ2 ++ x ++ Γ1, (Box A0 :: Δ2) ++ A :: Δ3); (Γ2 ++ B :: x ++ Γ1, (Box A0 :: Δ2) ++ Δ3)]
+          (Γ2 ++ (A --> B :: x) ++ Γ1, (Box A0 :: Δ2) ++ Δ3)). apply ImpLRule_I. repeat rewrite <- app_assoc in H0.
+          pose (ImpL_inv d H0). destruct p as [d0 d1]. rewrite <- app_assoc.
+          assert (ImpLRule [(Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3)]
+          (Γ2 ++ (A --> B :: x) ++ Γ1, Δ2 ++ Δ3)). apply ImpLRule_I.
+          assert (J3: (Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3) << (Γ2 ++ (A --> B :: x) ++ Γ1, Δ2 ++ Δ3)).
+          apply ImpL_applic_reduces_measure in H2. destruct H2 ; auto.
+          assert (J30: GLS_rules [(Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3)]
+          (Γ2 ++ (A --> B :: x) ++ Γ1, Δ2 ++ Δ3)). apply ImpL ; try assumption.
+          assert (J3b: (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3) << (Γ2 ++ (A --> B :: x) ++ Γ1, Δ2 ++ Δ3)).
+          apply ImpL_applic_reduces_measure in H2. destruct H2 ; auto.
+          repeat rewrite <- app_assoc in SIH. rewrite <- H6 in SIH.
+          assert (J6: size (Box A0) = size (Box A0)). reflexivity.
+          assert (J8: (Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3) = ((Γ2 ++ x) ++ Γ1, [] ++ Δ2 ++ A :: Δ3)). rewrite <- app_assoc. reflexivity.
+          pose (d2:=@SIH _ J3 (Box A0) (Γ2 ++ x) Γ1 [] (Δ2 ++ A :: Δ3) J6 J8). simpl in d2. inversion X2. subst. inversion X6. clear X6.
+          subst. repeat rewrite <- app_assoc in d2. pose (d3:=d2 d0 X5).
+          assert (J11: (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3) = ((Γ2 ++ B :: x) ++ Γ1, [] ++ Δ2 ++ Δ3)). rewrite <- app_assoc. reflexivity.
+          pose (d4:=@SIH _ J3b (Box A0) (Γ2 ++ B :: x) Γ1 [] (Δ2 ++ Δ3) J6 J11). simpl in d4. repeat rewrite <- app_assoc in d4.
+          pose (d5:=d4 d1 X7). pose (dlCons d5 X8). pose (dlCons d3 d6).
+          pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[(Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3)]) (Γ2 ++ (A --> B :: x) ++ Γ1, Δ2 ++ Δ3) J30 d7).
+          assumption. }
+      (* Right rule is GLR *)
+      { inversion X5. subst. inversion X0. subst. clear X8. inversion X2. subst. clear X9.
+        pose (univ_gen_ext_splitR _ _ X4). repeat destruct s. repeat destruct p.
+        pose (univ_gen_ext_splitR _ _ X6). repeat destruct s. repeat destruct p. subst. inversion u2.
+        - subst.
+          assert ((XBoxed_list (x ++ x0) ++ [Box A0], [A0]) = ((XBoxed_list (x ++ x0) ++ [Box A0]) ++ [], [] ++ [A0])).
+          repeat rewrite <- app_assoc. reflexivity.
+          assert (X7': derrec GLS_rules (fun _ : Seq => False) ((XBoxed_list (x ++ x0) ++ [Box A0]) ++ [], [] ++ [A0])).
+          rewrite <- H. assumption.
+          assert (J1: wkn_L (Box A) ((XBoxed_list (x ++ x0) ++ [Box A0]) ++ [], [] ++ [A0]) ((XBoxed_list (x ++ x0) ++ [Box A0]) ++ (Box A) :: [], [] ++ [A0])).
+          apply wkn_LI. assert (J2: derrec_height X7' = derrec_height X7'). reflexivity.
+          pose (GLS_wkn_L _ J2 J1). destruct s. clear l0. clear J2. clear X7'. clear J1.
+          assert (J3: wkn_R A ((XBoxed_list (x ++ x0) ++ [Box A0]) ++ [Box A], [] ++ [A0]) ((XBoxed_list (x ++ x0) ++ [Box A0]) ++ [Box A], [] ++ A :: [A0])).
+          apply wkn_RI. assert (J4: derrec_height x2 = derrec_height x2). reflexivity.
+          pose (GLS_wkn_R _ J4 J3). destruct s. clear l0. clear J4. clear J3. clear x2. clear H. simpl in x3.
+          rewrite XBox_app_distrib in x3. repeat rewrite <- app_assoc in x3.
+          rewrite XBox_app_distrib in X8. repeat rewrite <- app_assoc in X8. simpl in X8.
+          assert ((XBoxed_list x1 ++ A0 :: Box A0 :: XBoxed_list l ++ [Box A], [A]) =
+          (XBoxed_list x1 ++ (A0 :: [Box A0]) ++ [] ++ XBoxed_list l ++ [Box A], [A])).
+          reflexivity. rewrite H in X8. clear H.
+          assert (J5: list_exch_L (XBoxed_list x1 ++ [A0; Box A0] ++ [] ++ XBoxed_list l ++ [Box A], [A])
+          (XBoxed_list x1 ++ XBoxed_list l ++ [] ++ [A0; Box A0] ++ [Box A], [A])).
+          apply list_exch_LI.
+          pose (d:=GLS_adm_list_exch_L X8 J5). simpl in d. rewrite app_assoc in d.
+          rewrite <- XBox_app_distrib in d. assert (x1 ++ l = x ++ x0).
+          apply nobox_gen_ext_injective with (l:=(Γ0 ++ Γ1)) ; try assumption.
+          intro. intros. apply H4. apply in_or_app. apply in_app_or in H. destruct H.
+          auto. right. apply in_cons. assumption. apply univ_gen_ext_combine ; assumption.
+          rewrite H in d. clear J5. clear X8. simpl in x3. rewrite app_assoc in x3.
+          rewrite <- XBox_app_distrib in x3.
+          assert (J6: size A0 < size (Box A0)). simpl. lia.
+          assert (J7: size A0 = size A0). reflexivity.
+          assert (J9: (XBoxed_list (x ++ x0) ++ [Box A0; Box A], [A]) =
+          (XBoxed_list (x ++ x0) ++ [Box A0; Box A], [A] ++ [])). rewrite app_nil_r. reflexivity.
+          pose (d0:=@PIH (size A0) J6 A0 (XBoxed_list (x ++ x0) ++ [Box A0; Box A], [A]) (XBoxed_list (x ++ x0)) (Box A0 :: [Box A])
+          [A] [] J7 J9). rewrite app_nil_r in d0. pose (d1:=d0 x3 d).
+          assert (GLRRule [(XBoxed_list (x ++ x0) ++ [Box A0], [A0])] (x ++ x0, [Box A0])).
+          assert ((x ++ x0, [Box A0]) = (x ++ x0, [] ++ Box A0 :: [])). reflexivity. rewrite H0. clear H0.
+          apply GLRRule_I.
+          assumption. apply univ_gen_ext_refl.
+          assert (GLS_rules [(XBoxed_list (x ++ x0) ++ [Box A0], [A0])] (x ++ x0, [Box A0])).
+          apply GLR. assumption. pose (DersNilF:=dlNil GLS_rules (fun _ : Seq => False)).
+          pose (dlCons X7 DersNilF).
+          pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[(XBoxed_list (x ++ x0) ++ [Box A0], [A0])]) (x ++ x0, [Box A0]) X10 d2).
+          assert ([Box A0] = [Box A0] ++ []). reflexivity. rewrite H0 in d3.
+          assert (wkn_R A (x ++ x0, [Box A0] ++ []) (x ++ x0, [Box A0] ++ A :: [])). apply wkn_RI.
+          assert (J10: derrec_height d3 = derrec_height d3). reflexivity.
+          pose (GLS_wkn_R _ J10 H2). destruct s. clear l0. clear J10. clear H0. clear d3.
+          clear d2. clear X10. clear X8. clear J6. clear J9.
+          assert (J20: derrec_height x2 = derrec_height x2). reflexivity.
+          pose (@GLS_XBoxed_list_wkn_L (derrec_height x2) (x ++ x0) [] [] ([Box A0] ++ [A])).
+          repeat rewrite app_nil_r in s. repeat rewrite app_nil_l in s. pose (s x2 J20).
+          destruct s0. clear l0. clear J20. clear s. clear x2.
+          assert (XBoxed_list (x ++ x0) = XBoxed_list (x ++ x0) ++ []). rewrite app_nil_r. reflexivity.
+          rewrite H0 in x4. clear H0.
+          assert (wkn_L (Box A) (XBoxed_list (x ++ x0) ++ [], [Box A0] ++ [A]) (XBoxed_list (x ++ x0) ++ (Box A) :: [], [Box A0] ++ [A])).
+          apply wkn_LI.
+          assert (J10: derrec_height x4 = derrec_height x4). reflexivity.
+          pose (GLS_wkn_L _ J10 H0). destruct s. clear l0. clear J10. clear x4. clear H0.
+          assert (GLRRule [(XBoxed_list (x ++ x0) ++ [Box A], [A])] (Γ0 ++ Γ1, Δ0 ++ Δ1)).
+          rewrite <- H5. apply GLRRule_I ; try assumption.
+          destruct (dec_init_rules (Γ0 ++ Γ1, Δ2 ++ Box A :: Δ3)).
+          + repeat destruct s.
+            * apply IdP in i. pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+              (ps:=[]) (Γ0 ++ Γ1, Δ2 ++ Box A :: Δ3) i DersNilF). assumption.
+            * inversion i. apply Id_all_form.
+            * apply BotL in b. pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+              (ps:=[]) (Γ0 ++ Γ1, Δ2 ++ Box A :: Δ3) b DersNilF). assumption.
+          + assert ((XBoxed_list (x ++ x0) ++ [Box A], [A]) << (Γ0 ++ Γ1, Δ0 ++ Δ1)).
+            apply GLR_applic_reduces_measure ; try intro ; try apply f ; try rewrite H5 ; try auto ; try assumption.
+            assert (J40: GLS_rules [(XBoxed_list (x ++ x0) ++ [Box A], [A])] (Γ0 ++ Γ1, Δ0 ++ Δ1)).
+            apply GLR ; try assumption.
+            assert (J10: size (Box A0) = size (Box A0)). reflexivity.
+            assert (J12: (XBoxed_list (x ++ x0) ++ [Box A], [A]) = (XBoxed_list (x ++ x0) ++ [Box A], [] ++ [A]) ). reflexivity.
+            pose (d2:=@SIH _ H0 (Box A0) (XBoxed_list (x ++ x0)) [Box A] [] [A] J10 J12). simpl in d2. pose (d3:=d2 x2 d1). pose (dlCons d3 DersNilF).
+            pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[(XBoxed_list (x ++ x0) ++ [Box A], [A])]) (Γ0 ++ Γ1, Δ0 ++ Δ1) J40 d4).
+            rewrite H5. assumption.
+        - exfalso. apply H2. exists A0. reflexivity. }
+    + repeat destruct s. repeat destruct p. subst.
+      assert (GLRRule [(XBoxed_list ++ [Box A0], [A0])] (Γ0 ++ Γ1, (Δ0 ++ x0) ++ Box A0 :: Δ3)).
+      apply GLRRule_I ; try assumption. repeat rewrite <- app_assoc in X5.
+      assert (GLS_rules [(XBoxed_list ++ [Box A0], [A0])] (Γ0 ++ Γ1, Δ0 ++ x0 ++ Box A0 :: Δ3)).
+      apply GLR. assumption.
+      pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[(XBoxed_list ++ [Box A0], [A0])]) (Γ0 ++ Γ1, Δ0 ++ x0 ++ Box A0 :: Δ3) X6 X0). assumption.
+  * repeat destruct s. repeat destruct p. subst. rewrite <- app_assoc.
+    assert (GLRRule [(XBoxed_list ++ [Box A0], [A0])] (Γ0 ++ Γ1, Δ2 ++ (Box A0 :: x) ++ Δ1)).
+    apply GLRRule_I ; try assumption.
+    assert (GLS_rules [(XBoxed_list ++ [Box A0], [A0])] (Γ0 ++ Γ1, Δ2 ++ (Box A0 :: x) ++ Δ1)).
+    apply GLR. assumption.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[(XBoxed_list ++ [Box A0], [A0])]) (Γ0 ++ Γ1, Δ2 ++ (Box A0 :: x) ++ Δ1) X6 X0). assumption.
+Qed.
+ +
+Theorem GLS_cut_adm : forall A Γ0 Γ1 Δ0 Δ1,
+                      (GLS_prv (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)) ->
+                      (GLS_prv (Γ0 ++ A :: Γ1, Δ0 ++ Δ1)) ->
+                      (GLS_prv (Γ0 ++ Γ1, Δ0 ++ Δ1)).
+Proof.
+intros.
+assert (J1: size A = size A). reflexivity.
+assert (J3: (Γ0 ++ Γ1, Δ0 ++ Δ1) = (Γ0 ++ Γ1, Δ0 ++ Δ1)). reflexivity.
+pose (@GLS_cut_adm_main (size A) A
+(Γ0 ++ Γ1, Δ0 ++ Δ1) Γ0 Γ1 Δ0 Δ1 J1 J3). auto.
+Qed.
+ +
+
+
+ +
+ + + diff --git a/GL.GLS.GLS_calcs.html b/GL.GLS.GLS_calcs.html new file mode 100644 index 0000000..229dcf9 --- /dev/null +++ b/GL.GLS.GLS_calcs.html @@ -0,0 +1,199 @@ + + + + + + + + + + + + + +
+
+

GL.GLS.GLS_calcs

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+ +
+Require Export general_export.
+ +
+Require Export Syntax_export.
+ +
+(* In this file we define two calculi based on multisets for the propositonal modal logic
+   GL. The first one, called GLS, is the main calculus for GL. The second one, named PSGLS,
+   is essentially the calculus GLS with further restrictions on the application of the
+   rules. In other words, the calculus PSGLS is a proof-search oriented version of GLS. *)

+ +
+(* To define our rules, we will need some notions on the language. *)
+ +
+Fixpoint XBoxed_list (Γ : list MPropF) : list MPropF:=
+  match Γ with
+  | [ ] => [ ]
+  | h :: t => (unBox_formula h :: h :: XBoxed_list t)
+  end
+.
+ +
+(* Now that we have defined these, we can prove some properties about them. *)
+ +
+Lemma XBox_app_distrib :
+  forall (l1 l2: list MPropF), XBoxed_list (l1 ++ l2) = (XBoxed_list l1) ++ (XBoxed_list l2).
+Proof.
+induction l1.
+- intro l2. rewrite app_nil_l with (l:=l2). simpl. reflexivity.
+- intro l2. simpl. rewrite IHl1. reflexivity.
+Qed.
+ +
+Lemma list_preserv_XBoxed_list : forall (l : list MPropF), incl l (XBoxed_list l).
+Proof.
+induction l.
+- simpl. unfold incl. intros. inversion H.
+- simpl. unfold incl. intros. inversion H.
+  * subst. apply in_cons. apply in_eq.
+  * apply in_cons. apply in_cons. apply IHl. assumption.
+Qed.
+ +
+(* We use a macro for sequents *)
+ +
+Definition Seq := (prod (list MPropF) (list MPropF)).
+ +
+(* ---------------------------------------------------------------------------------------------------------------------------------- *)
+ +
+(* Finally, we can define the rules which constitute our calculi. We gather
+   them in cacluli in a definition appearing later. *)

+ +
+Inductive IdPRule : rlsT Seq :=
+  | IdPRule_I : forall P (Γ0 Γ1 Δ0 Δ1 : list MPropF),
+          IdPRule [] (pair (Γ0 ++ # P :: Γ1) (Δ0 ++ # P :: Δ1))
+.
+ +
+Inductive IdBRule : rlsT Seq :=
+  | IdBRule_I : forall A Γ0 Γ1 Δ0 Δ1,
+          IdBRule [] (pair (Γ0 ++ Box A :: Γ1) (Δ0 ++ Box A :: Δ1))
+.
+ +
+Inductive BotLRule : rlsT Seq :=
+  | BotLRule_I : forall Γ0 Γ1 Δ,
+          BotLRule [] (pair (Γ0 ++ (Bot) :: Γ1) Δ)
+.
+ +
+Inductive ImpRRule : rlsT Seq :=
+  | ImpRRule_I : forall A B Γ0 Γ1 Δ0 Δ1,
+          ImpRRule [(pair (Γ0 ++ A :: Γ1) (Δ0 ++ B :: Δ1))]
+                    (pair (Γ0 ++ Γ1) (Δ0 ++ (A --> B) :: Δ1))
+.
+ +
+Inductive ImpLRule : rlsT Seq :=
+  | ImpLRule_I : forall A B Γ0 Γ1 Δ0 Δ1,
+          ImpLRule ((pair (Γ0 ++ Γ1) (Δ0 ++ A :: Δ1)) ::
+                     [(pair (Γ0 ++ B :: Γ1) (Δ0 ++ Δ1))])
+                    (pair (Γ0 ++ (A --> B) :: Γ1) (Δ0 ++ Δ1))
+.
+ +
+Inductive GLRRule : rlsT Seq :=
+  | GLRRule_I : forall A Γ0 Δ0 Δ1,
+          (is_Boxed_list ) -> (* have MS of boxed formulae prem L*)
+          (nobox_gen_ext Γ0) -> (* extend BΓ in Γ0, the L of the ccl *)
+         GLRRule [(pair ((XBoxed_list ) ++ [Box A]) [A])] (pair Γ0 (Δ0 ++ Box A :: Δ1))
+.
+ +
+(* At last we can define our calculus GLS and its proof-search version PSGLS. *)
+ +
+Inductive GLS_rules : rlsT Seq :=
+  | IdP : forall ps c, IdPRule ps c -> GLS_rules ps c
+  | BotL : forall ps c, BotLRule ps c -> GLS_rules ps c
+  | ImpR : forall ps c, ImpRRule ps c -> GLS_rules ps c
+  | ImpL : forall ps c, ImpLRule ps c -> GLS_rules ps c
+  | GLR : forall ps c, GLRRule ps c -> GLS_rules ps c
+.
+ +
+(* We can show that all identities are provable in GLS. *)
+ +
+Lemma Id_all_form : forall (A : MPropF) l0 l1 l2 l3,
+          derrec GLS_rules (fun _ => False) (l0 ++ A :: l1, l2 ++ A :: l3).
+Proof.
+assert (DersNilF: dersrec GLS_rules (fun _ : rel (list MPropF) => False) []).
+apply dersrec_nil.
+ +
+induction A.
+- intros. assert (IdPRule [] (l0 ++ # s :: l1, l2 ++ # s :: l3)). apply IdPRule_I. apply IdP in H.
+  pose (derI (rules:=GLS_rules) (prems:=fun _ : rel (list MPropF) => False) (ps:=[])
+  (l0 ++ # s :: l1, l2 ++ # s :: l3) H DersNilF). assumption.
+- intros. assert (BotLRule [] (l0 ++ :: l1, l2 ++ :: l3)). apply BotLRule_I. apply BotL in H.
+  pose (derI (rules:=GLS_rules) (prems:=fun _ : rel (list MPropF) => False) (ps:=[])
+  (l0 ++ :: l1, l2 ++ :: l3) H DersNilF). assumption.
+- intros. assert (ImpRRule [(l0 ++ A1 :: A1 --> A2 :: l1, l2 ++ A2 :: l3)] (l0 ++ A1 --> A2 :: l1, l2 ++ A1 --> A2 :: l3)).
+  apply ImpRRule_I. apply ImpR in H.
+  assert (ImpLRule [((l0 ++ [A1]) ++ l1, l2 ++ A1 :: A2 :: l3); ((l0 ++ [A1]) ++ A2 :: l1, l2 ++ A2 :: l3)] ((l0 ++ [A1]) ++ A1 --> A2 :: l1, l2 ++ A2 :: l3)).
+  apply ImpLRule_I. repeat rewrite <- app_assoc in H0. simpl in H0. apply ImpL in H0.
+  pose (IHA1 l0 l1 l2 (A2 :: l3)). pose (IHA2 (l0 ++ [A1]) l1 l2 l3). repeat rewrite <- app_assoc in d0. simpl in d0.
+  pose (dlCons d0 DersNilF). pose (dlCons d d1).
+  pose (derI (rules:=GLS_rules) (prems:=fun _ : rel (list MPropF) => False) (ps:=[(l0 ++ A1 :: l1, l2 ++ A1 :: A2 :: l3); (l0 ++ A1 :: A2 :: l1, l2 ++ A2 :: l3)])
+  (l0 ++ A1 :: A1 --> A2 :: l1, l2 ++ A2 :: l3) H0 d2). pose (dlCons d3 DersNilF).
+  pose (derI (rules:=GLS_rules) (prems:=fun _ : rel (list MPropF) => False) (ps:=[(l0 ++ A1 :: A1 --> A2 :: l1, l2 ++ A2 :: l3)])
+  (l0 ++ A1 --> A2 :: l1, l2 ++ A1 --> A2 :: l3) H d4). assumption.
+- intros. assert (GLRRule [(XBoxed_list (top_boxes (l0 ++ Box A :: l1)) ++ [Box A], [A])] (l0 ++ Box A :: l1, l2 ++ Box A :: l3)).
+  apply GLRRule_I. apply is_Boxed_list_top_boxes. rewrite top_boxes_distr_app. simpl. apply univ_gen_ext_combine.
+  apply nobox_gen_ext_top_boxes. apply univ_gen_ext_cons. apply nobox_gen_ext_top_boxes.
+  rewrite top_boxes_distr_app in X. simpl in X. rewrite XBox_app_distrib in X. simpl in X.
+  repeat rewrite <- app_assoc in X. simpl in X.
+  pose (IHA (XBoxed_list (top_boxes l0)) (Box A :: XBoxed_list (top_boxes l1) ++ [Box A]) [] []).
+  simpl in d. pose (dlCons d DersNilF). apply GLR in X.
+  pose (derI (rules:=GLS_rules) (prems:=fun _ : rel (list MPropF) => False) (ps:=[(XBoxed_list (top_boxes l0) ++ A :: Box A :: XBoxed_list (top_boxes l1) ++ [Box A], [A])])
+  (l0 ++ Box A :: l1, l2 ++ Box A :: l3) X d0). assumption.
+Qed.
+ +
+Definition GLS_prv s := derrec GLS_rules (fun _ => False) s.
+Definition GLS_drv s := derrec GLS_rules (fun _ => True) s.
+ +
+
+
+ +
+ + + diff --git a/GL.GLS.GLS_ctr.html b/GL.GLS.GLS_ctr.html new file mode 100644 index 0000000..051dba8 --- /dev/null +++ b/GL.GLS.GLS_ctr.html @@ -0,0 +1,1167 @@ + + + + + + + + + + + + + +
+
+

GL.GLS.GLS_ctr

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat Arith.
+Require Import Lia.
+ +
+Require Import GLS_calcs.
+Require Import GLS_inv_ImpR_ImpL.
+ +
+Set Implicit Arguments.
+ +
+(* Next are the definitions for contraction of one formula on the left, and
+on the right. Note that while the leftmost occurrence of the formula is kept,
+if we have exchange for our calculus it amounts to the same to keep the rightmost
+formula. *)

+ +
+Inductive ctr_L (fml : MPropF) : relationT Seq :=
+  | ctr_LI Γ0 Γ1 Γ2 Δ : ctr_L fml
+        (Γ0 ++ fml :: Γ1 ++ fml :: Γ2, Δ) (Γ0 ++ fml :: Γ1 ++ Γ2, Δ).
+ +
+Inductive ctr_R (fml : MPropF) : relationT Seq :=
+  | ctr_RI Γ Δ0 Δ1 Δ2 : ctr_R fml
+        (Γ, Δ0 ++ fml :: Δ1 ++ fml :: Δ2) (Γ, Δ0 ++ fml :: Δ1 ++ Δ2).
+ +
+(* Some lemmas on the preservation of inapplicability of rules through contraction. *)
+ +
+Lemma ctr_L_IdP_notapplic : forall s se A,
+    (@ctr_L A s se) ->
+    ((IdPRule [] s) -> False) ->
+    ((IdPRule [] se) -> False).
+Proof.
+intros s se A ctr. induction ctr. intros RA RAc. apply RA.
+inversion RAc. apply app2_find_hole in H. destruct H. destruct s.
+- destruct s.
+  + destruct p. inversion e0. subst. apply IdPRule_I.
+  + destruct p. destruct x.
+    * inversion e0. subst. apply IdPRule_I.
+    * inversion e0. subst.
+      assert (E: (Γ3 ++ # P :: x) ++ A :: Γ1 ++ A :: Γ2 = Γ3 ++ # P :: x ++ A :: Γ1 ++ A :: Γ2).
+      repeat rewrite <- app_assoc. reflexivity. rewrite E. apply IdPRule_I.
+- destruct p. destruct x.
+  + inversion e0. apply IdPRule_I.
+  + inversion e0. subst. apply app2_find_hole in H2. destruct H2. destruct s.
+    * destruct s.
+      { destruct p. subst.
+        assert (E: Γ0 ++ m :: Γ1 ++ m :: # P :: Γ4 = (Γ0 ++ m :: Γ1 ++ [m]) ++ # P :: Γ4).
+        repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E.
+        apply IdPRule_I. }
+      { destruct p. subst.
+        assert (E: Γ0 ++ m :: Γ1 ++ m :: x0 ++ # P :: Γ4 = (Γ0 ++ m :: Γ1 ++ m :: x0) ++ # P :: Γ4).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+        rewrite E. apply IdPRule_I. }
+    * destruct p. destruct x0.
+      { simpl in e1. subst.
+        assert (E: Γ0 ++ m :: (x ++ []) ++ m :: # P :: Γ4 = (Γ0 ++ m :: x ++ [] ++ [m]) ++ # P :: Γ4).
+        repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity.
+        rewrite E. apply IdPRule_I. }
+      { inversion e1. subst.
+        assert (E: Γ0 ++ m :: (x ++ # P :: x0) ++ m :: Γ2 = (Γ0 ++ m :: x) ++ # P :: x0 ++ m :: Γ2).
+        repeat rewrite <- app_assoc. simpl. reflexivity. rewrite E. apply IdPRule_I. }
+Qed.
+ +
+Lemma ctr_L_IdB_notapplic : forall s se A,
+    (@ctr_L A s se) ->
+    ((IdBRule [] s) -> False) ->
+    ((IdBRule [] se) -> False).
+Proof.
+intros s se A ctr. induction ctr. intros RA RAc. apply RA.
+inversion RAc. apply app2_find_hole in H. destruct H. destruct s.
+- destruct s.
+  + destruct p. inversion e0. subst. apply IdBRule_I.
+  + destruct p. destruct x.
+    * inversion e0. subst. apply IdBRule_I.
+    * inversion e0. subst.
+      assert (E: (Γ3 ++ Box A0 :: x) ++ A :: Γ1 ++ A :: Γ2 = Γ3 ++ Box A0 :: x ++ A :: Γ1 ++ A :: Γ2).
+      repeat rewrite <- app_assoc. reflexivity. rewrite E. apply IdBRule_I.
+- destruct p. destruct x.
+  + inversion e0. apply IdBRule_I.
+  + inversion e0. subst. apply app2_find_hole in H2. destruct H2. destruct s.
+    * destruct s.
+      { destruct p. subst.
+        assert (E: Γ0 ++ m :: Γ1 ++ m :: Box A0 :: Γ4 = (Γ0 ++ m :: Γ1 ++ [m]) ++ Box A0 :: Γ4).
+        repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E.
+        apply IdBRule_I. }
+      { destruct p. subst.
+        assert (E: Γ0 ++ m :: Γ1 ++ m :: x0 ++ Box A0 :: Γ4 = (Γ0 ++ m :: Γ1 ++ m :: x0) ++ Box A0 :: Γ4).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+        rewrite E. apply IdBRule_I. }
+    * destruct p. destruct x0.
+      { simpl in e1. subst.
+        assert (E: Γ0 ++ m :: (x ++ []) ++ m :: Box A0 :: Γ4 = (Γ0 ++ m :: x ++ [] ++ [m]) ++ Box A0 :: Γ4).
+        repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity.
+        rewrite E. apply IdBRule_I. }
+      { inversion e1. subst.
+        assert (E: Γ0 ++ m :: (x ++ Box A0 :: x0) ++ m :: Γ2 = (Γ0 ++ m :: x) ++ Box A0 :: x0 ++ m :: Γ2).
+        repeat rewrite <- app_assoc. simpl. reflexivity. rewrite E. apply IdBRule_I. }
+Qed.
+ +
+Lemma ctr_L_BotL_notapplic : forall s se A,
+    (@ctr_L A s se) ->
+    ((BotLRule [] s) -> False) ->
+    ((BotLRule [] se) -> False).
+Proof.
+intros s se A ctr. induction ctr. intros RA RAc. apply RA.
+inversion RAc. apply app2_find_hole in H. destruct H. destruct s.
+- destruct s.
+  + destruct p. inversion e0. subst. apply BotLRule_I.
+  + destruct p. destruct x.
+    * inversion e0. subst. apply BotLRule_I.
+    * inversion e0. subst.
+      assert (E: (Γ3 ++ :: x) ++ A :: Γ1 ++ A :: Γ2 = Γ3 ++ :: x ++ A :: Γ1 ++ A :: Γ2).
+      repeat rewrite <- app_assoc. reflexivity. rewrite E. apply BotLRule_I.
+- destruct p. destruct x.
+  + inversion e0. apply BotLRule_I.
+  + inversion e0. subst. apply app2_find_hole in H2. destruct H2. destruct s.
+    * destruct s.
+      { destruct p. subst.
+        assert (E: Γ0 ++ m :: Γ1 ++ m :: :: Γ4 = (Γ0 ++ m :: Γ1 ++ [m]) ++ :: Γ4).
+        repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E.
+        apply BotLRule_I. }
+      { destruct p. subst.
+        assert (E: Γ0 ++ m :: Γ1 ++ m :: x0 ++ :: Γ4 = (Γ0 ++ m :: Γ1 ++ m :: x0) ++ :: Γ4).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+        rewrite E. apply BotLRule_I. }
+    * destruct p. destruct x0.
+      { simpl in e1. subst.
+        assert (E: Γ0 ++ m :: (x ++ []) ++ m :: :: Γ4 = (Γ0 ++ m :: x ++ [] ++ [m]) ++ :: Γ4).
+        repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity.
+        rewrite E. apply BotLRule_I. }
+      { inversion e1. subst.
+        assert (E: Γ0 ++ m :: (x ++ :: x0) ++ m :: Γ2 = (Γ0 ++ m :: x) ++ :: x0 ++ m :: Γ2).
+        repeat rewrite <- app_assoc. simpl. reflexivity. rewrite E. apply BotLRule_I. }
+Qed.
+ +
+Lemma ctr_R_IdP_notapplic : forall s se A,
+    (@ctr_R A s se) ->
+    ((IdPRule [] s) -> False) ->
+    ((IdPRule [] se) -> False).
+Proof.
+intros s se A ctr. induction ctr. intros RA RAc. apply RA.
+inversion RAc. apply app2_find_hole in H1. destruct H1. destruct s.
+- destruct s.
+  + destruct p. inversion e0. subst. apply IdPRule_I.
+  + destruct p. destruct x.
+    * inversion e0. subst. apply IdPRule_I.
+    * inversion e0. subst.
+      assert (E: (Δ3 ++ # P :: x) ++ A :: Δ1 ++ A :: Δ2 = Δ3 ++ # P :: x ++ A :: Δ1 ++ A :: Δ2).
+      repeat rewrite <- app_assoc. reflexivity. rewrite E. apply IdPRule_I.
+- destruct p. destruct x.
+  + inversion e0. apply IdPRule_I.
+  + inversion e0. subst. apply app2_find_hole in H2. destruct H2. destruct s.
+    * destruct s.
+      { destruct p. subst.
+        assert (E: Δ0 ++ m :: Δ1 ++ m :: # P :: Δ4 = (Δ0 ++ m :: Δ1 ++ [m]) ++ # P :: Δ4).
+        repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E.
+        apply IdPRule_I. }
+      { destruct p. subst.
+        assert (E: Δ0 ++ m :: Δ1 ++ m :: x0 ++ # P :: Δ4 = (Δ0 ++ m :: Δ1 ++ m :: x0) ++ # P :: Δ4).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+        rewrite E. apply IdPRule_I. }
+    * destruct p. destruct x0.
+      { simpl in e1. subst.
+        assert (E: Δ0 ++ m :: (x ++ []) ++ m :: # P :: Δ4 = (Δ0 ++ m :: x ++ [] ++ [m]) ++ # P :: Δ4).
+        repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity.
+        rewrite E. apply IdPRule_I. }
+      { inversion e1. subst.
+        assert (E: Δ0 ++ m :: (x ++ # P :: x0) ++ m :: Δ2 = (Δ0 ++ m :: x) ++ # P :: x0 ++ m :: Δ2).
+        repeat rewrite <- app_assoc. simpl. reflexivity. rewrite E. apply IdPRule_I. }
+Qed.
+ +
+Lemma ctr_R_IdB_notapplic : forall s se A,
+    (@ctr_R A s se) ->
+    ((IdBRule [] s) -> False) ->
+    ((IdBRule [] se) -> False).
+Proof.
+intros s se A ctr. induction ctr. intros RA RAc. apply RA.
+inversion RAc. apply app2_find_hole in H1. destruct H1. destruct s.
+- destruct s.
+  + destruct p. inversion e0. subst. apply IdBRule_I.
+  + destruct p. destruct x.
+    * inversion e0. subst. apply IdBRule_I.
+    * inversion e0. subst.
+      assert (E: (Δ3 ++ Box A0 :: x) ++ A :: Δ1 ++ A :: Δ2 = Δ3 ++ Box A0 :: x ++ A :: Δ1 ++ A :: Δ2).
+      repeat rewrite <- app_assoc. reflexivity. rewrite E. apply IdBRule_I.
+- destruct p. destruct x.
+  + inversion e0. apply IdBRule_I.
+  + inversion e0. subst. apply app2_find_hole in H2. destruct H2. destruct s.
+    * destruct s.
+      { destruct p. subst.
+        assert (E: Δ0 ++ m :: Δ1 ++ m :: Box A0 :: Δ4 = (Δ0 ++ m :: Δ1 ++ [m]) ++ Box A0 :: Δ4).
+        repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E.
+        apply IdBRule_I. }
+      { destruct p. subst.
+        assert (E: Δ0 ++ m :: Δ1 ++ m :: x0 ++ Box A0 :: Δ4 = (Δ0 ++ m :: Δ1 ++ m :: x0) ++ Box A0 :: Δ4).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+        rewrite E. apply IdBRule_I. }
+    * destruct p. destruct x0.
+      { simpl in e1. subst.
+        assert (E: Δ0 ++ m :: (x ++ []) ++ m :: Box A0 :: Δ4 = (Δ0 ++ m :: x ++ [] ++ [m]) ++ Box A0 :: Δ4).
+        repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity.
+        rewrite E. apply IdBRule_I. }
+      { inversion e1. subst.
+        assert (E: Δ0 ++ m :: (x ++ Box A0 :: x0) ++ m :: Δ2 = (Δ0 ++ m :: x) ++ Box A0 :: x0 ++ m :: Δ2).
+        repeat rewrite <- app_assoc. simpl. reflexivity. rewrite E. apply IdBRule_I. }
+Qed.
+ +
+Lemma ctr_R_BotL_notapplic : forall s se A,
+    (@ctr_R A s se) ->
+    ((BotLRule [] s) -> False) ->
+    ((BotLRule [] se) -> False).
+Proof.
+intros s se A ctr RA RAe. apply RA.
+inversion RAe. destruct s. inversion ctr. subst. inversion H3.
+subst. apply BotLRule_I.
+Qed.
+ +
+(* The following lemmas make sure that if a rule is applied on a sequent s with
+premises ps, then the same rule is applicable on a sequent sc which is a contracted
+version of s, with some premises psc that are such that they are either the same premises
+(in case the contracted formula was weakened) or contracted versions of ps. *)

+ +
+Lemma ImpR_app_ctr_L : forall s sc A ps,
+  (@ctr_L A s sc) ->
+  (ImpRRule [ps] s) ->
+  (existsT2 psc, (ImpRRule [psc] sc) * (@ctr_L A ps psc)).
+Proof.
+intros s sc A ps ctr RA. inversion RA. inversion ctr. subst.
+inversion H. subst. apply app2_find_hole in H1. destruct H1. destruct s.
+- destruct s.
+  + destruct p. subst. exists (Γ2 ++ A0 :: A :: Γ3 ++ Γ4, Δ0 ++ B :: Δ1).
+    split. apply ImpRRule_I.
+    assert (E1: Γ2 ++ A0 :: A :: Γ3 ++ A :: Γ4 = (Γ2 ++ [A0]) ++ A :: Γ3 ++ A :: Γ4).
+    repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+    assert (E2: Γ2 ++ A0 :: A :: Γ3 ++ Γ4 = (Γ2 ++ [A0]) ++ A :: Γ3 ++ Γ4).
+    repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E2.
+    apply ctr_LI.
+  + destruct p. subst. destruct x.
+    * simpl in e0. subst. repeat rewrite app_nil_r.
+      exists (Γ2 ++ A0 :: A :: Γ3 ++ Γ4, Δ0 ++ B :: Δ1). split. apply ImpRRule_I.
+      assert (E1: Γ2 ++ A0 :: A :: Γ3 ++ A :: Γ4 = (Γ2 ++ [A0]) ++ A :: Γ3 ++ A :: Γ4).
+      repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+      assert (E2: Γ2 ++ A0 :: A :: Γ3 ++ Γ4 = (Γ2 ++ [A0]) ++ A :: Γ3 ++ Γ4).
+      repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E2.
+      apply ctr_LI.
+    * inversion e0. subst. apply app2_find_hole in H2. destruct H2. destruct s.
+      { destruct s.
+        - destruct p. subst. exists ((Γ2 ++ m :: Γ3) ++ A0 :: Γ4, Δ0 ++ B :: Δ1).
+          split.
+          assert (E: Γ2 ++ m :: Γ3 ++ Γ4 = (Γ2 ++ m :: Γ3) ++ Γ4).
+          rewrite <- app_assoc. reflexivity. rewrite E. apply ImpRRule_I.
+          assert (E1: (Γ2 ++ m :: Γ3) ++ A0 :: m :: Γ4 = Γ2 ++ m :: (Γ3 ++ [A0]) ++ m :: Γ4).
+          repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+          assert (E2: (Γ2 ++ m :: Γ3) ++ A0 :: Γ4 = Γ2 ++ m :: (Γ3 ++ [A0]) ++ Γ4).
+          repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E2.
+          apply ctr_LI.
+        - destruct p. subst. destruct x0.
+          + simpl in e1. subst. repeat rewrite app_nil_r.
+            exists ((Γ2 ++ m :: Γ3) ++ A0 :: Γ4, Δ0 ++ B :: Δ1). split.
+            assert (E: Γ2 ++ m :: Γ3 ++ Γ4 = (Γ2 ++ m :: Γ3) ++ Γ4).
+            rewrite <- app_assoc. reflexivity. rewrite E.
+            apply ImpRRule_I.
+            assert (E1: (Γ2 ++ m :: Γ3) ++ A0 :: m :: Γ4 = Γ2 ++ m :: (Γ3 ++ [A0]) ++ m :: Γ4).
+            repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+            assert (E2: (Γ2 ++ m :: Γ3) ++ A0 :: Γ4 = Γ2 ++ m :: (Γ3 ++ [A0]) ++ Γ4).
+            repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E2.
+            apply ctr_LI.
+          + inversion e1. subst.
+            exists ((Γ2 ++ m0 :: Γ3 ++ x0) ++ A0 :: Γ1, Δ0 ++ B :: Δ1). split.
+            assert (E: Γ2 ++ m0 :: Γ3 ++ x0 ++ Γ1 = (Γ2 ++ m0 :: Γ3 ++ x0) ++ Γ1).
+            repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E.
+            apply ImpRRule_I.
+            repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. apply ctr_LI. }
+      { destruct p. subst. exists ((Γ2 ++ m :: x) ++ A0 :: x0 ++ Γ4,Δ0 ++ B :: Δ1).
+        split. assert (E: Γ2 ++ m :: (x ++ x0) ++ Γ4 = (Γ2 ++ m :: x) ++ x0 ++ Γ4).
+        repeat rewrite <- app_assoc. reflexivity. rewrite E. apply ImpRRule_I.
+        assert (E1: (Γ2 ++ m :: x) ++ A0 :: x0 ++ m :: Γ4 = Γ2 ++ m :: (x ++ A0 :: x0) ++ m :: Γ4).
+        repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+        assert (E2: (Γ2 ++ m :: x) ++ A0 :: x0 ++ Γ4 = Γ2 ++ m :: (x ++ A0 :: x0) ++ Γ4).
+        repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E2.
+        apply ctr_LI. }
+- destruct p. subst. exists (Γ0 ++ A0 :: x ++ A :: Γ3 ++ Γ4, Δ0 ++ B :: Δ1).
+  split. rewrite <- app_assoc. apply ImpRRule_I.
+  assert (E1: Γ0 ++ A0 :: x ++ A :: Γ3 ++ A :: Γ4 = (Γ0 ++ A0 :: x) ++ A :: Γ3 ++ A :: Γ4).
+  repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+  assert (E2: Γ0 ++ A0 :: x ++ A :: Γ3 ++ Γ4 = (Γ0 ++ A0 :: x) ++ A :: Γ3 ++ Γ4).
+  repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E2.
+  apply ctr_LI.
+Qed.
+ +
+Lemma ImpL_app_ctr_L : forall s sc A ps1 ps2,
+  (@ctr_L A s sc) ->
+  (ImpLRule [ps1;ps2] s) ->
+  ((existsT2 psc1 psc2, (ImpLRule [psc1;psc2] sc) *
+                       (@ctr_L A ps1 psc1) *
+                       (@ctr_L A ps2 psc2))
+  +
+  (existsT2 B C invps11 invps12 invps21 invps22 invpsc11 invpsc22,
+                       (A = Imp B C) *
+                       (ImpLRule [invps11;invps12] ps1) *
+                       (ImpLRule [invps21;invps22] ps2) *
+                       (@ctr_R B invps11 invpsc11) *
+                       (@ctr_L C invps22 invpsc22) *
+                       (ImpLRule [invpsc11;invpsc22] sc))).
+Proof.
+intros s sc A ps1 ps2 ctr RA. inversion RA. inversion ctr. subst. inversion H.
+subst. apply app2_find_hole in H1. destruct H1. repeat destruct s ; destruct p ; subst.
+- inversion e0. subst. right. exists A0. exists B.
+  exists (Γ2 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: A0 :: Δ1). exists (Γ2 ++ Γ3 ++ B :: Γ4, Δ0 ++ A0 :: Δ1).
+  exists (Γ2 ++ B :: Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ B :: Γ4, Δ0 ++ Δ1).
+  exists (Γ2 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ Γ4, Δ0 ++ Δ1). repeat split.
+  assert (Γ2 ++ Γ3 ++ Γ4 = (Γ2 ++ Γ3) ++ Γ4). rewrite <- app_assoc. reflexivity. rewrite H0.
+  clear H0. assert (Γ2 ++ Γ3 ++ B :: Γ4 = (Γ2 ++ Γ3) ++ B :: Γ4). rewrite <- app_assoc. reflexivity.
+  rewrite H0. clear H0. assert (Γ2 ++ Γ3 ++ A0 --> B :: Γ4 = (Γ2 ++ Γ3) ++ A0 --> B :: Γ4). rewrite <- app_assoc.
+  reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+  assert (Γ2 ++ B :: Γ3 ++ Γ4 = (Γ2 ++ B :: Γ3) ++ Γ4). rewrite <- app_assoc. reflexivity. rewrite H0.
+  clear H0. assert (Γ2 ++ B :: Γ3 ++ B :: Γ4 = (Γ2 ++ B :: Γ3) ++ B :: Γ4). rewrite <- app_assoc. reflexivity.
+  rewrite H0. clear H0. assert (Γ2 ++ B :: Γ3 ++ A0 --> B :: Γ4 = (Γ2 ++ B :: Γ3) ++ A0 --> B :: Γ4). rewrite <- app_assoc.
+  reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+  assert (Δ0 ++ A0 :: A0 :: Δ1 = Δ0 ++ A0 :: [] ++ A0 :: Δ1). reflexivity. rewrite H0. clear H0.
+  assert (Δ0 ++ A0 :: Δ1 = Δ0 ++ A0 :: [] ++ Δ1). reflexivity. rewrite H0. clear H0.
+  apply ctr_RI.
+- destruct x.
+  * simpl in e0. inversion e0. subst. right. exists A0. exists B.
+    exists (Γ2 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: A0 :: Δ1). exists (Γ2 ++ Γ3 ++ B :: Γ4, Δ0 ++ A0 :: Δ1).
+    exists (Γ2 ++ B :: Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ B :: Γ4, Δ0 ++ Δ1).
+    exists (Γ2 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ Γ4, Δ0 ++ Δ1). repeat split.
+    assert (Γ2 ++ Γ3 ++ Γ4 = (Γ2 ++ Γ3) ++ Γ4). repeat rewrite <- app_assoc. reflexivity. rewrite H0.
+    clear H0. assert (Γ2 ++ Γ3 ++ B :: Γ4 = (Γ2 ++ Γ3) ++ B :: Γ4). rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. assert ((Γ2 ++ []) ++ Γ3 ++ A0 --> B :: Γ4 = (Γ2 ++ Γ3) ++ A0 --> B :: Γ4).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+    assert (Γ2 ++ B :: Γ3 ++ Γ4 = (Γ2 ++ B :: Γ3) ++ Γ4). rewrite <- app_assoc. reflexivity. rewrite H0.
+    clear H0. assert (Γ2 ++ B :: Γ3 ++ B :: Γ4 = (Γ2 ++ B :: Γ3) ++ B :: Γ4). rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. assert ((Γ2 ++ []) ++ B :: Γ3 ++ A0 --> B :: Γ4 = (Γ2 ++ B :: Γ3) ++ A0 --> B :: Γ4).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+    assert (Δ0 ++ A0 :: A0 :: Δ1 = Δ0 ++ A0 :: [] ++ A0 :: Δ1). reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ A0 :: Δ1 = Δ0 ++ A0 :: [] ++ Δ1). reflexivity. rewrite H0. clear H0.
+    apply ctr_RI.
+  * inversion e0. subst. apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+    + inversion e1. subst. right. exists A0. exists B.
+      exists (Γ2 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1).
+      exists (Γ2 ++ Γ3 ++ B :: Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ B :: Γ4, Δ0 ++ Δ1).
+      exists (Γ2 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ Γ4, Δ0 ++ Δ1). repeat split.
+      repeat rewrite <- app_assoc. apply ImpLRule_I. repeat rewrite <- app_assoc. apply ImpLRule_I.
+      assert (Δ0 ++ A0 :: A0 :: Δ1 = Δ0 ++ A0 :: [] ++ A0 :: Δ1). reflexivity. rewrite H0. clear H0.
+      assert (Δ0 ++ A0 :: Δ1 = Δ0 ++ A0 :: [] ++ Δ1). reflexivity. rewrite H0. clear H0.
+      apply ctr_RI.
+    + destruct x0.
+      { simpl in e1. inversion e1. subst. right. exists A0. exists B.
+        exists (Γ2 ++ Γ3 ++ Γ1, Δ0 ++ A0 :: A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ Γ1, Δ0 ++ A0 :: Δ1).
+        exists (Γ2 ++ Γ3 ++ B :: Γ1, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ B :: Γ1, Δ0 ++ Δ1).
+        exists (Γ2 ++ Γ3 ++ Γ1, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ Γ1, Δ0 ++ Δ1). repeat split.
+        repeat rewrite <- app_assoc. simpl. rewrite app_nil_r. apply ImpLRule_I. repeat rewrite <- app_assoc.
+        rewrite app_nil_r. apply ImpLRule_I.
+        assert (Δ0 ++ A0 :: A0 :: Δ1 = Δ0 ++ A0 :: [] ++ A0 :: Δ1). reflexivity. rewrite H0. clear H0.
+        assert (Δ0 ++ A0 :: Δ1 = Δ0 ++ A0 :: [] ++ Δ1). reflexivity. rewrite H0. clear H0.
+        apply ctr_RI. }
+      { inversion e1. subst. left. exists (Γ2 ++ m0 :: Γ3 ++ x0 ++ Γ1, Δ0 ++ A0 :: Δ1).
+        exists (Γ2 ++ m0 :: Γ3 ++ x0 ++ B :: Γ1, Δ0 ++ Δ1). repeat split.
+        assert (Γ2 ++ m0 :: Γ3 ++ x0 ++ Γ1 = (Γ2 ++ m0 :: Γ3 ++ x0) ++ Γ1). repeat rewrite <- app_assoc.
+        simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ m0 :: Γ3 ++ x0 ++ A0 --> B :: Γ1 = (Γ2 ++ m0 :: Γ3 ++ x0) ++ A0 --> B :: Γ1). repeat rewrite <- app_assoc.
+        simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ m0 :: Γ3 ++ x0 ++ B :: Γ1 = (Γ2 ++ m0 :: Γ3 ++ x0) ++ B :: Γ1). repeat rewrite <- app_assoc.
+        simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. apply ctr_LI.
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. apply ctr_LI. }
+    + destruct x0.
+      { simpl in e1. inversion e1. subst. right. exists A0. exists B.
+        exists (Γ2 ++ x ++ Γ4, Δ0 ++ A0 :: A0 :: Δ1). exists (Γ2 ++ B :: x ++ Γ4, Δ0 ++ A0 :: Δ1).
+        exists (Γ2 ++ x ++ B :: Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: x ++ B :: Γ4, Δ0 ++ Δ1).
+        exists (Γ2 ++ x ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: x ++ Γ4, Δ0 ++ Δ1). repeat split.
+        repeat rewrite <- app_assoc. apply ImpLRule_I. repeat rewrite <- app_assoc. apply ImpLRule_I.
+        assert (Δ0 ++ A0 :: A0 :: Δ1 = Δ0 ++ A0 :: [] ++ A0 :: Δ1). reflexivity. rewrite H0. clear H0.
+        assert (Δ0 ++ A0 :: Δ1 = Δ0 ++ A0 :: [] ++ Δ1). reflexivity. rewrite H0. clear H0.
+        apply ctr_RI. rewrite <- app_assoc. simpl. apply ImpLRule_I. }
+      { inversion e1. subst. left. exists (Γ2 ++ m :: x ++ x0 ++ Γ4, Δ0 ++ A0 :: Δ1).
+        exists (Γ2 ++ m :: x ++ B :: x0 ++ Γ4, Δ0 ++ Δ1). repeat split.
+        assert (Γ2 ++ m :: x ++ x0 ++ Γ4 = (Γ2 ++ m :: x) ++ x0 ++ Γ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ m :: x ++ B :: x0 ++ Γ4 = (Γ2 ++ m :: x) ++ B :: x0 ++ Γ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ m :: (x ++ A0 --> B :: x0) ++ Γ4 = (Γ2 ++ m :: x) ++ A0 --> B :: x0 ++ Γ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        assert ((Γ2 ++ m :: x) ++ x0 ++ m :: Γ4 = Γ2 ++ m :: (x ++ x0) ++ m :: Γ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ m :: x ++ x0 ++ Γ4 = Γ2 ++ m :: (x ++ x0) ++ Γ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ctr_LI.
+        assert ((Γ2 ++ m :: x) ++ B :: x0 ++ m :: Γ4 = Γ2 ++ m :: (x ++ B :: x0) ++ m :: Γ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ m :: x ++ B :: x0 ++ Γ4 = Γ2 ++ m :: (x ++ B :: x0) ++ Γ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ctr_LI. }
+- destruct x.
+  + simpl in e0. inversion e0. subst. right. exists A0. exists B.
+    exists (Γ0 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: A0 :: Δ1). exists (Γ0 ++ Γ3 ++ B :: Γ4, Δ0 ++ A0 :: Δ1).
+    exists (Γ0 ++ B :: Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ0 ++ B :: Γ3 ++ B :: Γ4, Δ0 ++ Δ1).
+    exists (Γ0 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ0 ++ B :: Γ3 ++ Γ4, Δ0 ++ Δ1) . repeat split.
+    assert (Γ0 ++ Γ3 ++ Γ4 = (Γ0 ++ Γ3) ++ Γ4). repeat rewrite <- app_assoc. reflexivity. rewrite H0.
+    clear H0. assert (Γ0 ++ Γ3 ++ B :: Γ4 = (Γ0 ++ Γ3) ++ B :: Γ4). rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. assert (Γ0 ++ Γ3 ++ A0 --> B :: Γ4 = (Γ0 ++ Γ3) ++ A0 --> B :: Γ4).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+    assert (Γ0 ++ B :: Γ3 ++ Γ4 = (Γ0 ++ B :: Γ3) ++ Γ4). rewrite <- app_assoc. reflexivity. rewrite H0.
+    clear H0. assert (Γ0 ++ B :: Γ3 ++ B :: Γ4 = (Γ0 ++ B :: Γ3) ++ B :: Γ4). rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. assert (Γ0 ++ B :: Γ3 ++ A0 --> B :: Γ4 = (Γ0 ++ B :: Γ3) ++ A0 --> B :: Γ4).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+    assert (Δ0 ++ A0 :: A0 :: Δ1 = Δ0 ++ A0 :: [] ++ A0 :: Δ1). reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ A0 :: Δ1 = Δ0 ++ A0 :: [] ++ Δ1). reflexivity. rewrite H0. clear H0.
+    apply ctr_RI. repeat rewrite <- app_assoc. simpl. apply ImpLRule_I.
+  + inversion e0. subst. left. exists (Γ0 ++ x ++ A :: Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1).
+    exists (Γ0 ++ B :: x ++ A :: Γ3 ++ Γ4, Δ0 ++ Δ1). repeat split. repeat rewrite <- app_assoc.
+    apply ImpLRule_I.
+    assert (Γ0 ++ x ++ A :: Γ3 ++ A :: Γ4 = (Γ0 ++ x) ++ A :: Γ3 ++ A :: Γ4). repeat rewrite <- app_assoc.
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ x ++ A :: Γ3 ++ Γ4 = (Γ0 ++ x) ++ A :: Γ3 ++ Γ4). repeat rewrite <- app_assoc.
+    reflexivity. rewrite H0. clear H0. apply ctr_LI.
+    assert (Γ0 ++ B :: x ++ A :: Γ3 ++ A :: Γ4 = (Γ0 ++ B :: x) ++ A :: Γ3 ++ A :: Γ4). repeat rewrite <- app_assoc.
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ B :: x ++ A :: Γ3 ++ Γ4 = (Γ0 ++ B :: x) ++ A :: Γ3 ++ Γ4). repeat rewrite <- app_assoc.
+    reflexivity. rewrite H0. clear H0. apply ctr_LI.
+Qed.
+ +
+Lemma GLR_app_ctr_L : forall s sc A ps,
+  (@ctr_L A s sc) ->
+  (GLRRule [ps] s) ->
+    ((GLRRule [ps] sc) +
+     (existsT2 psc1 psc2, (GLRRule [psc2] sc) * (@ctr_L (unBox_formula A) ps psc1) * (@ctr_L A psc1 psc2))).
+Proof.
+intros s sc A ps ctr RA. inversion RA. inversion ctr. rewrite <- H1 in H2.
+inversion H2. subst. apply univ_gen_ext_elem_deep with (l3:=Γ1) (l4:=Γ2 ++ A :: Γ3) (a:=A) in X.
+destruct X. 3: reflexivity.
+- destruct p. apply univ_gen_ext_elem_deep with (l3:=Γ1 ++ Γ2) (l4:=Γ3) (a:=A) in u. destruct u. destruct p.
+3: rewrite <- app_assoc. 3: reflexivity.
+  * left. apply GLRRule_I.
+    assumption.
+    apply univ_gen_ext_add_elem_deep. rewrite app_assoc. assumption. assumption.
+  * exfalso. apply f. repeat destruct s. repeat destruct p. subst. apply is_box_is_in_boxed_list with (A:=A) in H0 .
+    unfold is_boxedT. destruct H0. exists x1. auto. apply in_or_app. right. apply in_eq.
+- repeat destruct s. repeat destruct p. apply univ_gen_ext_elem_deep with (l3:=Γ2) (l4:=Γ3) (a:=A) in u0.
+  destruct u0. 3: reflexivity.
+  * destruct p. exfalso. subst. apply is_box_is_in_boxed_list with (A:=A) in H0. apply f. unfold is_boxedT.
+    destruct H0. exists x1. auto. apply in_or_app. right. apply in_eq.
+  * repeat destruct s. repeat destruct p. right. subst.
+    exists ((XBoxed_list x) ++ (XBoxed_list [A]) ++ (XBoxed_list x1) ++ A :: (XBoxed_list x2) ++ [Box A0], [A0]).
+    exists (XBoxed_list (x ++ A :: x1 ++ x2) ++ [Box A0], [A0]). split.
+    + split.
+      { apply GLRRule_I.
+        intro. intros. apply H0. apply in_app_or in H. destruct H. apply in_or_app. left. assumption.
+        inversion H. subst. apply in_or_app. right. apply in_eq. apply in_app_or in H1. destruct H1.
+        apply in_or_app. right. apply in_cons. apply in_or_app. left. assumption.
+        apply in_or_app. right. apply in_cons. apply in_or_app. right. apply in_cons.
+        assumption.
+        apply univ_gen_ext_combine. assumption. apply univ_gen_ext_cons. apply univ_gen_ext_combine.
+        assumption. assumption. }
+      { repeat rewrite cons_single. repeat rewrite XBox_app_distrib. simpl.
+        assert (E1: (XBoxed_list x ++ unBox_formula A :: A :: XBoxed_list x1 ++ unBox_formula A :: A :: XBoxed_list x2) ++ [Box A0] =
+                     (XBoxed_list x ++ unBox_formula A :: (A :: XBoxed_list x1) ++ unBox_formula A :: (A :: XBoxed_list x2 ++ [Box A0]))).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+        assert (E2: XBoxed_list x ++ unBox_formula A :: A :: XBoxed_list x1 ++ A :: XBoxed_list x2 ++ [Box A0] =
+                    XBoxed_list x ++ unBox_formula A :: (A :: XBoxed_list x1) ++ (A :: XBoxed_list x2 ++ [Box A0])).
+        repeat rewrite <- app_assoc. reflexivity. rewrite E2. apply ctr_LI with (Γ2:= A :: XBoxed_list x2 ++ [Box A0]). }
+    + simpl. repeat rewrite XBox_app_distrib. simpl. repeat rewrite XBox_app_distrib.
+      assert (E1: XBoxed_list x ++ unBox_formula A :: A :: XBoxed_list x1 ++ A :: XBoxed_list x2 ++ [Box A0] =
+                  (XBoxed_list x ++ [unBox_formula A]) ++ A :: XBoxed_list x1 ++ A :: XBoxed_list x2 ++ [Box A0]).
+      repeat rewrite <- app_assoc. rewrite <- cons_single. reflexivity. rewrite E1.
+      assert (E2: (XBoxed_list x ++ unBox_formula A :: A :: XBoxed_list x1 ++ XBoxed_list x2) ++ [Box A0] =
+                  (XBoxed_list x ++ [unBox_formula A]) ++ A :: XBoxed_list x1 ++ XBoxed_list x2 ++ [Box A0]).
+      repeat rewrite <- app_assoc. rewrite <- cons_single. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E2.
+      apply ctr_LI.
+Qed.
+ +
+Lemma ImpR_app_ctr_R : forall s sc A ps,
+  (@ctr_R A s sc) ->
+  (ImpRRule [ps] s) ->
+  ((existsT2 psc, (ImpRRule [psc] sc) * (@ctr_R A ps psc))
+  +
+  (existsT2 B C invps invpsc0 invpsc, (A = Imp B C) * (ImpRRule [invps] ps) * (ImpRRule [invpsc] sc) *
+                                      (@ctr_L B invps invpsc0) * (@ctr_R C invpsc0 invpsc))).
+Proof.
+intros s sc A ps ctr RA. inversion RA. inversion ctr. subst.
+inversion H. subst. apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+- inversion e0. right. exists A0. exists B. exists (Γ0 ++ A0 :: A0 :: Γ1, Δ2 ++ B :: Δ3 ++ B :: Δ4).
+  exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3 ++ B :: Δ4). exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3 ++ Δ4).
+  repeat split. assert (Δ2 ++ B :: Δ3 ++ B :: Δ4 = (Δ2 ++ B :: Δ3) ++ B :: Δ4). rewrite <- app_assoc. reflexivity.
+  rewrite H0. clear H0. assert (Δ2 ++ B :: Δ3 ++ A0 --> B :: Δ4 = (Δ2 ++ B :: Δ3) ++ A0 --> B :: Δ4). rewrite <- app_assoc. reflexivity.
+  rewrite H0. clear H0. apply ImpRRule_I.
+  assert (Γ0 ++ A0 :: A0 :: Γ1 = Γ0 ++ A0 :: [] ++ A0 :: Γ1). reflexivity. rewrite H0. clear H0.
+  assert (Γ0 ++ A0 :: Γ1 = Γ0 ++ A0 :: [] ++ Γ1). reflexivity. rewrite H0. clear H0.
+  apply ctr_LI.
+- destruct x.
+  * simpl in e0. inversion e0. subst. right. exists A0. exists B.
+    exists (Γ0 ++ A0 :: A0 :: Γ1, (Δ2 ++ []) ++ B :: Δ3 ++ B :: Δ4).
+    exists (Γ0 ++ A0 :: Γ1, (Δ2 ++ []) ++ B :: Δ3 ++ B :: Δ4). exists (Γ0 ++ A0 :: Γ1, (Δ2 ++ []) ++ B :: Δ3 ++ Δ4).
+    repeat split. assert ((Δ2 ++ []) ++ B :: Δ3 ++ B :: Δ4 = (Δ2 ++ B :: Δ3) ++ B :: Δ4). repeat rewrite <- app_assoc.
+    reflexivity. rewrite H0. clear H0. assert ((Δ2 ++ []) ++ B :: Δ3 ++ A0 --> B :: Δ4 = (Δ2 ++ B :: Δ3) ++ A0 --> B :: Δ4).
+    rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpRRule_I. repeat rewrite <- app_assoc. simpl. apply ImpRRule_I.
+    assert (Γ0 ++ A0 :: A0 :: Γ1 = Γ0 ++ A0 :: [] ++ A0 :: Γ1). reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ A0 :: Γ1 = Γ0 ++ A0 :: [] ++ Γ1). reflexivity. rewrite H0. clear H0.
+    apply ctr_LI.
+  * inversion e0. subst. apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+    + inversion e1. subst. right. exists A0. exists B.
+      exists (Γ0 ++ A0 :: A0 :: Γ1, Δ2 ++ B :: Δ3 ++ B :: Δ4). exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3 ++ B :: Δ4).
+      exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3 ++ Δ4). repeat split.
+      repeat rewrite <- app_assoc. apply ImpRRule_I.
+      assert (Γ0 ++ A0 :: A0 :: Γ1 = Γ0 ++ A0 :: [] ++ A0 :: Γ1). reflexivity. rewrite H0. clear H0.
+      assert (Γ0 ++ A0 :: Γ1 = Γ0 ++ A0 :: [] ++ Γ1). reflexivity. rewrite H0. clear H0.
+      apply ctr_LI.
+    + destruct x0.
+      { simpl in e1. inversion e1. subst. right. exists A0. exists B.
+        exists (Γ0 ++ A0 :: A0 :: Γ1, Δ2 ++ B :: Δ3 ++ B :: Δ1). exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3 ++ B :: Δ1).
+        exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3 ++ Δ1). repeat split.
+        repeat rewrite <- app_assoc. simpl. rewrite app_nil_r. apply ImpRRule_I.
+        assert (Γ0 ++ A0 :: A0 :: Γ1 = Γ0 ++ A0 :: [] ++ A0 :: Γ1). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ A0 :: Γ1 = Γ0 ++ A0 :: [] ++ Γ1). reflexivity. rewrite H0. clear H0.
+        apply ctr_LI. }
+      { inversion e1. subst. left. exists (Γ0 ++ A0 :: Γ1, Δ2 ++ m0 :: Δ3 ++ x0 ++ B :: Δ1).
+        repeat split. assert (Δ2 ++ m0 :: Δ3 ++ x0 ++ B :: Δ1 = (Δ2 ++ m0 :: Δ3 ++ x0) ++ B :: Δ1).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ m0 :: Δ3 ++ x0 ++ A0 --> B :: Δ1 = (Δ2 ++ m0 :: Δ3 ++ x0) ++ A0 --> B :: Δ1). repeat rewrite <- app_assoc.
+        simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. apply ctr_RI. }
+    + destruct x0.
+      { simpl in e1. inversion e1. subst. right. exists A0. exists B.
+        exists (Γ0 ++ A0 :: A0 :: Γ1, Δ2 ++ B :: x ++ B :: Δ4). exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: x ++ B :: Δ4).
+        exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: x ++ Δ4). repeat split.
+        repeat rewrite <- app_assoc. apply ImpRRule_I. repeat rewrite <- app_assoc. apply ImpRRule_I.
+        assert (Γ0 ++ A0 :: A0 :: Γ1 = Γ0 ++ A0 :: [] ++ A0 :: Γ1). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ A0 :: Γ1 = Γ0 ++ A0 :: [] ++ Γ1). reflexivity. rewrite H0. clear H0.
+        apply ctr_LI. }
+      { inversion e1. subst. left. exists (Γ0 ++ A0 :: Γ1, Δ2 ++ m :: x ++ B :: x0 ++ Δ4).
+        repeat split.
+        assert (Δ2 ++ m :: x ++ B :: x0 ++ Δ4 = (Δ2 ++ m :: x) ++ B :: x0 ++ Δ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ m :: (x ++ A0 --> B :: x0) ++ Δ4 = (Δ2 ++ m :: x) ++ A0 --> B :: x0 ++ Δ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        assert ((Δ2 ++ m :: x) ++ B :: x0 ++ m :: Δ4 = Δ2 ++ m :: (x ++ B :: x0) ++ m :: Δ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ m :: x ++ B :: x0 ++ Δ4 = Δ2 ++ m :: (x ++ B :: x0) ++ Δ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ctr_RI. }
+- destruct x.
+  + simpl in e0. inversion e0. subst. right. exists A0. exists B.
+    exists (Γ0 ++ A0 :: A0 :: Γ1, Δ0 ++ B :: Δ3 ++ B :: Δ4). exists (Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ3 ++ B :: Δ4).
+    exists (Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ3 ++ Δ4). repeat split.
+    assert (Δ0 ++ B :: Δ3 ++ A0 --> B :: Δ4 = (Δ0 ++ B :: Δ3) ++ A0 --> B :: Δ4). repeat rewrite <- app_assoc. reflexivity. rewrite H0.
+    clear H0. assert (Δ0 ++ B :: Δ3 ++ B :: Δ4 = (Δ0 ++ B :: Δ3) ++ B :: Δ4). rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply ImpRRule_I. repeat rewrite <- app_assoc. simpl. apply ImpRRule_I.
+    assert (Γ0 ++ A0 :: A0 :: Γ1 = Γ0 ++ A0 :: [] ++ A0 :: Γ1). reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ A0 :: Γ1 = Γ0 ++ A0 :: [] ++ Γ1). reflexivity. rewrite H0. clear H0.
+    apply ctr_LI.
+  + inversion e0. subst. left. exists (Γ0 ++ A0 :: Γ1, Δ0 ++ B :: x ++ A :: Δ3 ++ Δ4).
+    repeat split. repeat rewrite <- app_assoc. apply ImpRRule_I.
+    assert (Δ0 ++ B :: x ++ A :: Δ3 ++ A :: Δ4 = (Δ0 ++ B :: x) ++ A :: Δ3 ++ A :: Δ4). repeat rewrite <- app_assoc.
+    reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ B :: x ++ A :: Δ3 ++ Δ4 = (Δ0 ++ B :: x) ++ A :: Δ3 ++ Δ4). repeat rewrite <- app_assoc.
+    reflexivity. rewrite H0. clear H0. apply ctr_RI.
+Qed.
+ +
+Lemma ImpL_app_ctr_R : forall s sc A ps1 ps2,
+  (@ctr_R A s sc) ->
+  (ImpLRule [ps1;ps2] s) ->
+  (existsT2 psc1 psc2, (ImpLRule [psc1;psc2] sc) * (@ctr_R A ps1 psc1) * (@ctr_R A ps2 psc2)).
+Proof.
+intros s sc A ps1 ps2 ctr RA. inversion RA. inversion ctr. subst.
+inversion H. subst. apply app2_find_hole in H2. destruct H2. destruct s.
+- destruct s.
+  + destruct p. subst. exists (Γ0 ++ Γ1, Δ2 ++ A0 :: A :: Δ3 ++ Δ4). exists (Γ0 ++ B :: Γ1, Δ2 ++ A :: Δ3 ++ Δ4).
+    split. split.
+    apply ImpLRule_I.
+    assert (E1: Δ2 ++ A0 :: A :: Δ3 ++ A :: Δ4 = (Δ2 ++ [A0]) ++ A :: Δ3 ++ A :: Δ4).
+    repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E1.
+    assert (E2: Δ2 ++ A0 :: A :: Δ3 ++ Δ4 = (Δ2 ++ [A0]) ++ A :: Δ3 ++ Δ4).
+    repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E2. apply ctr_RI.
+    apply ctr_RI.
+  + destruct p. destruct x.
+    * rewrite app_nil_r in e. rewrite app_nil_l in e0. subst.
+      exists (Γ0 ++ Γ1, Δ2 ++ A0 :: A :: Δ3 ++ Δ4). exists (Γ0 ++ B :: Γ1, Δ2 ++ A :: Δ3 ++ Δ4).
+      split. split.
+      apply ImpLRule_I.
+      assert (E1: Δ2 ++ A0 :: A :: Δ3 ++ A :: Δ4 = (Δ2 ++ [A0]) ++ A :: Δ3 ++ A :: Δ4).
+      repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E1.
+      assert (E2: Δ2 ++ A0 :: A :: Δ3 ++ Δ4 = (Δ2 ++ [A0]) ++ A :: Δ3 ++ Δ4).
+      repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E2. apply ctr_RI.
+      apply ctr_RI.
+    * inversion e0. subst. apply app2_find_hole in H2. destruct H2. destruct s.
+      { destruct s.
+        - destruct p. subst. exists (Γ0 ++ Γ1, (Δ2 ++ m :: Δ3) ++ A0 :: Δ4).
+          exists (Γ0 ++ B :: Γ1, (Δ2 ++ m :: Δ3) ++ Δ4). split. split.
+          assert (E: Δ2 ++ m :: Δ3 ++ Δ4 = (Δ2 ++ m :: Δ3) ++ Δ4).
+          rewrite <- app_assoc. reflexivity. rewrite E.
+          apply ImpLRule_I.
+          assert (E1: (Δ2 ++ m :: Δ3) ++ A0 :: m :: Δ4 = Δ2 ++ m :: (Δ3 ++ [A0]) ++ m :: Δ4).
+          repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E1.
+          assert (E2: (Δ2 ++ m :: Δ3) ++ A0 :: Δ4 = Δ2 ++ m :: (Δ3 ++ [A0]) ++ Δ4).
+          repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E2. apply ctr_RI.
+          rewrite <- app_assoc. simpl. apply ctr_RI.
+        - destruct p. subst. destruct x0.
+          + rewrite app_nil_l in e1. rewrite app_nil_r in e0. subst.
+            exists (Γ0 ++ Γ1,(Δ2 ++ m :: Δ3) ++ A0 :: Δ4). exists (Γ0 ++ B :: Γ1, (Δ2 ++ m :: Δ3) ++ Δ4).
+            split. split.
+            assert (E: Δ2 ++ m :: Δ3 ++ Δ4 = (Δ2 ++ m :: Δ3) ++ Δ4).
+            rewrite <- app_assoc. reflexivity. rewrite E.
+            apply ImpLRule_I.
+            assert (E1: (Δ2 ++ m :: Δ3 ++ []) ++ A0 :: m :: Δ4 = Δ2 ++ m :: (Δ3 ++ [A0]) ++ m :: Δ4).
+            rewrite app_nil_r. repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E1.
+            assert (E2: (Δ2 ++ m :: Δ3) ++ A0 :: Δ4 = Δ2 ++ m :: (Δ3 ++ [A0]) ++ Δ4).
+            repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E2. apply ctr_RI.
+            rewrite <- app_assoc. simpl. apply ctr_RI.
+          + inversion e1. subst. exists (Γ0 ++ Γ1,(Δ2 ++ m0 :: Δ3 ++ x0) ++ A0 :: Δ1).
+            exists (Γ0 ++ B :: Γ1,(Δ2 ++ m0 :: Δ3 ++ x0) ++ Δ1). split. split.
+            assert (E: Δ2 ++ m0 :: Δ3 ++ x0 ++ Δ1 = (Δ2 ++ m0 :: Δ3 ++ x0) ++ Δ1).
+            rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E.
+            apply ImpLRule_I.
+            assert (E1: (Δ2 ++ m0 :: Δ3 ++ m0 :: x0) ++ A0 :: Δ1 = Δ2 ++ m0 :: Δ3 ++ m0 :: x0 ++ A0 :: Δ1).
+            repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+            assert (E2: (Δ2 ++ m0 :: Δ3 ++ x0) ++ A0 :: Δ1 = Δ2 ++ m0 :: Δ3 ++ x0 ++ A0 :: Δ1).
+            repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E2. apply ctr_RI.
+            rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. apply ctr_RI. }
+      { destruct p. subst. exists (Γ0 ++ Γ1,(Δ2 ++ m :: x) ++ A0 :: x0 ++ Δ4).
+        exists (Γ0 ++ B :: Γ1, (Δ2 ++ m :: x) ++ x0 ++ Δ4). split. split.
+        assert (E: Δ2 ++ m :: (x ++ x0) ++ Δ4 = (Δ2 ++ m :: x) ++ x0 ++ Δ4).
+        rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E.
+        apply ImpLRule_I.
+        assert (E1: (Δ2 ++ m :: x) ++ A0 :: x0 ++ m :: Δ4 = Δ2 ++ m :: (x ++ A0 :: x0) ++ m :: Δ4).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+        assert (E2: (Δ2 ++ m :: x) ++ A0 :: x0 ++ Δ4 = Δ2 ++ m :: (x ++ A0 :: x0) ++ Δ4).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E2. apply ctr_RI.
+        assert (E1: (Δ2 ++ m :: x) ++ x0 ++ Δ4 = Δ2 ++ m :: (x ++ x0) ++ Δ4).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E1. apply ctr_RI. }
+- destruct p. subst. exists (Γ0 ++ Γ1, Δ0 ++ A0 :: x ++ A :: Δ3 ++ Δ4).
+  exists (Γ0 ++ B :: Γ1, Δ0 ++ x ++ A :: Δ3 ++ Δ4). split. split.
+  rewrite <- app_assoc. apply ImpLRule_I.
+  assert (E1: Δ0 ++ A0 :: x ++ A :: Δ3 ++ A :: Δ4 = (Δ0 ++ A0 :: x) ++ A :: Δ3 ++ A :: Δ4).
+  repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+  assert (E2: Δ0 ++ A0 :: x ++ A :: Δ3 ++ Δ4 = (Δ0 ++ A0 :: x) ++ A :: Δ3 ++ Δ4).
+  repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E2. apply ctr_RI.
+  rewrite app_assoc. apply ctr_RI.
+Qed.
+ +
+Lemma GLR_app_ctr_R : forall s sc A ps,
+  (@ctr_R A s sc) -> (GLRRule [ps] s) -> (GLRRule [ps] sc).
+Proof.
+intros s sc A ps ctr RA. inversion RA. inversion ctr. rewrite <- H1 in H2.
+inversion H2. apply app2_find_hole in H6. destruct H6. destruct s0.
+  + destruct s0.
+    * destruct p. inversion e0. apply GLRRule_I. assumption. assumption.
+    * destruct p. subst. destruct x.
+      { rewrite app_nil_l in e0. inversion e0. subst. apply GLRRule_I.
+        assumption. assumption. }
+      { inversion e0. subst. apply app2_find_hole in H3. destruct H3. destruct s.
+        - destruct s.
+          + destruct p. inversion e1. apply GLRRule_I. assumption. assumption.
+          + destruct p. subst. destruct x0.
+            * rewrite app_nil_l in e1. inversion e1. subst. apply GLRRule_I. assumption.
+              assumption.
+            * inversion e1. subst. assert (E: Δ2 ++ m0 :: Δ3 ++ x0 ++ Box A0 :: Δ1 = (Δ2 ++ m0 :: Δ3 ++ x0) ++ Box A0 :: Δ1).
+              repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E. apply GLRRule_I. assumption.
+              assumption.
+        - destruct p. subst. destruct x0.
+          * rewrite app_nil_l in e1. inversion e1. subst. apply GLRRule_I. assumption. assumption.
+          * inversion e1. subst. assert (E: Δ2 ++ m :: (x ++ Box A0 :: x0) ++ Δ4 = (Δ2 ++ m :: x) ++ Box A0 :: x0 ++ Δ4).
+            repeat rewrite <- app_assoc. reflexivity. rewrite E. apply GLRRule_I. assumption. assumption. }
+  + destruct p. subst. destruct x.
+    * rewrite app_nil_l in e0. rewrite app_nil_r. inversion e0. subst. apply GLRRule_I. assumption. assumption.
+    * inversion e0. rewrite <- app_assoc. simpl. apply GLRRule_I. assumption. assumption.
+Qed.
+ +
+(* Now we can prove that contractions are height-preserving admissible. *)
+ +
+Theorem GLS_hpadm_ctr_LR : forall (k : nat) s
+        (D0 : GLS_prv s),
+        k = (derrec_height D0) ->
+          (forall sc A, (((@ctr_L A s sc) + (@ctr_R A s sc)) ->
+          existsT2 (D1 : GLS_prv sc),
+          derrec_height D1 <= k)).
+Proof.
+induction k as [n IH] using (well_founded_induction_type lt_wf).
+intros s D0. remember D0 as D0'. destruct D0.
+(* D0 ip a leaf *)
+- intros hei sc A ctr. inversion f.
+(* D0 is ends with an application of rule *)
+- intros hei sc A ctr. destruct ctr as [ctr | ctr].
+{ inversion ctr. assert (DersNil: dersrec GLS_rules (fun _ : Seq => False) []).
+  apply dersrec_nil. inversion g.
+  (* IdP *)
+  * inversion H1. rewrite <- H in H5. inversion H5.
+    apply app2_find_hole in H7. destruct H7. destruct s.
+    + destruct s.
+      { destruct p. inversion e0. subst. pose (IdPRule_I P Γ3 (Γ1 ++ Γ2) Δ0 Δ1). apply IdP in i. simpl in i.
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ3 ++ # P :: Γ1 ++ Γ2, Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+        left. reflexivity. reflexivity. }
+      { destruct p. destruct x.
+        - rewrite app_nil_l in e0. inversion e0.
+          subst. pose (IdPRule_I P (Γ3 ++ []) (Γ1 ++ Γ2) Δ0 Δ1). apply IdP in i. simpl in i.
+          pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ3 ++ []) ++ # P :: Γ1 ++ Γ2,Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+          repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+        - inversion e0. subst.
+          pose (IdPRule_I P Γ3 (x ++ A :: Γ1 ++ Γ2) Δ0 Δ1). apply IdP in i. simpl in i.
+          assert (E: Γ3 ++ # P :: x ++ A :: Γ1 ++ Γ2 = (Γ3 ++ # P :: x) ++ A :: Γ1 ++ Γ2). repeat rewrite <- app_assoc. reflexivity.
+          rewrite E in i. clear E.
+          pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ3 ++ # P :: x) ++ A :: Γ1 ++ Γ2,Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+          repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+    + destruct p. destruct x.
+      { rewrite app_nil_l in e0. inversion e0. subst.
+        pose (IdPRule_I P Γ0 (Γ1 ++ Γ2) Δ0 Δ1). apply IdP in i. simpl in i.
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ0 ++ # P :: Γ1 ++ Γ2, Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+        repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+      { inversion e0. subst. apply app2_find_hole in H9. destruct H9. destruct s.
+        - destruct s.
+          + destruct p. inversion e1. subst.
+            pose (IdPRule_I P Γ0 (Γ1 ++ Γ2) Δ0 Δ1). apply IdP in i. simpl in i.
+            pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ # P :: Γ1 ++ Γ2, Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+          + destruct p. destruct x0.
+            * rewrite app_nil_l in e1. inversion e1. subst.
+              pose (IdPRule_I P Γ0 (Γ1 ++ Γ4) Δ0 Δ1). apply IdP in i. simpl in i.
+              pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+              (ps:=[]) (Γ0 ++ # P :: Γ1 ++ Γ4, Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+              repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+            * inversion e1. subst.
+              pose (IdPRule_I P (Γ0 ++ m0 :: Γ1 ++ x0) Γ4 Δ0 Δ1). apply IdP in i. simpl in i.
+              repeat rewrite <- app_assoc in i. simpl in i. repeat rewrite <- app_assoc in i.
+              pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+              (ps:=[]) (Γ0 ++ m0 :: Γ1 ++ x0 ++ # P :: Γ4,Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+              repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+        - destruct p. destruct x0.
+          + rewrite app_nil_l in e1. inversion e1. subst.
+            pose (IdPRule_I P Γ0 ((x ++ []) ++ Γ2) Δ0 Δ1). apply IdP in i. simpl in i.
+            pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ # P :: (x ++ []) ++ Γ2, Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+          + inversion e1. subst.
+            pose (IdPRule_I P (Γ0 ++ m :: x) (x0 ++ Γ2) Δ0 Δ1). apply IdP in i. simpl in i.
+            assert (E: (Γ0 ++ m :: x) ++ # P :: x0 ++ Γ2 = Γ0 ++ m :: (x ++ # P :: x0) ++ Γ2). repeat rewrite <- app_assoc. reflexivity.
+            rewrite E in i. clear E.
+            pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ m :: (x ++ # P :: x0) ++ Γ2,Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+  (* BotL *)
+  * inversion H1. rewrite <- H in H5. inversion H5.
+    apply app2_find_hole in H7. destruct H7. destruct s.
+    + destruct s.
+      { destruct p. inversion e0. subst. pose (BotLRule_I Γ3 (Γ1 ++ Γ2) Δ). apply BotL in b.
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ3 ++ :: Γ1 ++ Γ2, Δ) b DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+        left. reflexivity. reflexivity. }
+      { destruct p. destruct x.
+        - rewrite app_nil_l in e0. inversion e0.
+          subst. pose (BotLRule_I (Γ3 ++ []) (Γ1 ++ Γ2) Δ). apply BotL in b. simpl in b.
+          pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ3 ++ []) ++ :: Γ1 ++ Γ2, Δ) b DersNil). exists d0. simpl.
+          repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+        - inversion e0. subst.
+          pose (BotLRule_I Γ3 (x ++ A :: Γ1 ++ Γ2) Δ). apply BotL in b. simpl in b.
+          assert (E: Γ3 ++ :: x ++ A :: Γ1 ++ Γ2 = (Γ3 ++ :: x) ++ A :: Γ1 ++ Γ2). repeat rewrite <- app_assoc. reflexivity.
+          rewrite E in b. clear E.
+          pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ3 ++ :: x) ++ A :: Γ1 ++ Γ2, Δ) b DersNil). exists d0. simpl.
+          repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+    + destruct p. destruct x.
+      { rewrite app_nil_l in e0. inversion e0. subst.
+        pose (BotLRule_I Γ0 (Γ1 ++ Γ2) Δ). apply BotL in b. simpl in b.
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ0 ++ :: Γ1 ++ Γ2, Δ) b DersNil). exists d0. simpl.
+        repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+      { inversion e0. subst. apply app2_find_hole in H9. destruct H9. destruct s.
+        - destruct s.
+          + destruct p. inversion e1. subst.
+            pose (BotLRule_I Γ0 (Γ1 ++ Γ2) Δ). apply BotL in b. simpl in b.
+            pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ :: Γ1 ++ Γ2, Δ) b DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+          + destruct p. destruct x0.
+            * rewrite app_nil_l in e1. inversion e1. subst.
+              pose (BotLRule_I Γ0 (Γ1 ++ Γ4) Δ). apply BotL in b. simpl in b.
+              pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+              (ps:=[]) (Γ0 ++ :: Γ1 ++ Γ4, Δ) b DersNil). exists d0. simpl.
+              repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+            * inversion e1. subst.
+              pose (BotLRule_I (Γ0 ++ m0 :: Γ1 ++ x0) Γ4 Δ). apply BotL in b. simpl in b.
+              repeat rewrite <- app_assoc in b. simpl in b. repeat rewrite <- app_assoc in b.
+              pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+              (ps:=[]) (Γ0 ++ m0 :: Γ1 ++ x0 ++ :: Γ4, Δ) b DersNil). exists d0. simpl.
+              repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+        - destruct p. destruct x0.
+          + rewrite app_nil_l in e1. inversion e1. subst.
+            pose (BotLRule_I Γ0 ((x ++ []) ++ Γ2) Δ). apply BotL in b. simpl in b.
+            pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ :: (x ++ []) ++ Γ2, Δ) b DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+          + inversion e1. subst.
+            pose (BotLRule_I (Γ0 ++ m :: x) (x0 ++ Γ2) Δ). apply BotL in b. simpl in b.
+            assert (E: (Γ0 ++ m :: x) ++ :: x0 ++ Γ2 = Γ0 ++ m :: (x ++ :: x0) ++ Γ2). repeat rewrite <- app_assoc. reflexivity.
+            rewrite E in b. clear E.
+            pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ m :: (x ++ :: x0) ++ Γ2, Δ) b DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+  (* ImpR *)
+  * inversion H1. subst. inversion H5. subst. pose (ImpR_app_ctr_L ctr H1). destruct s. destruct p.
+    apply ImpR in i.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x]) (Γ0 ++ A :: Γ1 ++ Γ2, Δ0 ++ A0 --> B :: Δ1) i). subst. simpl.
+    remember [(Γ3 ++ A0 :: Γ4, Δ0 ++ B :: Δ1)] as ps'. destruct d. inversion Heqps'.
+    inversion Heqps'. subst. simpl. rewrite dersrec_height_nil. simpl in IH.
+    rewrite dersrec_height_nil in IH. rewrite Nat.max_0_r. rewrite Nat.max_0_r in IH.
+    assert (E: derrec_height d < S (derrec_height d)). auto.
+    assert (E1: derrec_height d = derrec_height d). auto.
+    assert ((ctr_L A (Γ3 ++ A0 :: Γ4, Δ0 ++ B :: Δ1) x) + (ctr_R A (Γ3 ++ A0 :: Γ4, Δ0 ++ B :: Δ1) x)).
+    left. auto.
+    pose (IH (derrec_height d) E (Γ3 ++ A0 :: Γ4, Δ0 ++ B :: Δ1) d E1 x A H).
+    destruct s.
+    pose (dlCons x0 d1). pose (d0 d2). exists d3. simpl. rewrite dersrec_height_nil.
+    rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. assumption. reflexivity. reflexivity. reflexivity.
+  (* ImpL *)
+  * inversion H1. subst. inversion H5. subst. pose (ImpL_app_ctr_L ctr H1). destruct s.
+    { repeat destruct s. repeat destruct p. apply ImpL in i.
+      pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[x;x0]) (Γ0 ++ A :: Γ1 ++ Γ2, Δ0 ++ Δ1) i). subst. simpl.
+      remember [(Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1);(Γ3 ++ B :: Γ4, Δ0 ++ Δ1)] as ps'. destruct d.
+      inversion Heqps'. inversion Heqps'. subst.
+      remember [(Γ3 ++ B :: Γ4, Δ0 ++ Δ1)] as ps''. destruct d1. inversion Heqps''.
+      inversion Heqps''. simpl. subst. rewrite dersrec_height_nil. simpl in IH.
+      rewrite dersrec_height_nil in IH. rewrite Nat.max_0_r. rewrite Nat.max_0_r in IH.
+      assert (E1: derrec_height d < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+      apply Nat.lt_succ_r. apply Nat.le_max_l.
+      assert (E2: derrec_height d = derrec_height d). auto.
+      assert ((ctr_L A (Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1) x) + (ctr_R A (Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1) x)).
+      auto.
+      pose (IH (derrec_height d) E1 (Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1) d E2 x A H).
+      destruct s.
+      assert (E3: derrec_height d1 < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+      apply Nat.lt_succ_r. apply Nat.le_max_r.
+      assert (E4: derrec_height d1 = derrec_height d1). auto.
+      assert ((ctr_L A (Γ3 ++ B :: Γ4, Δ0 ++ Δ1) x0) + (ctr_R A (Γ3 ++ B :: Γ4, Δ0 ++ Δ1) x0)).
+      auto.
+      pose (IH (derrec_height d1) E3 (Γ3 ++ B :: Γ4, Δ0 ++ Δ1) d1 E4 x0 A H2).
+      destruct s.
+      pose (dlCons x1 (dlCons x2 d2)). pose (d0 d3). exists d4. simpl. rewrite dersrec_height_nil.
+      rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. apply Nat.max_le_compat.
+      assumption. assumption. reflexivity. reflexivity. reflexivity. }
+    { simpl. repeat destruct s. repeat destruct p. subst. apply ImpL in i.
+      assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+      pose (@dersrec_derrec2_height (dersrec_height d) _ _ _ _ _ d J30). repeat destruct s.
+      assert (J1: derrec_height x7 = derrec_height x7). reflexivity.
+      pose (ImpR_ImpL_hpinv _ J1). destruct p. clear s. pose (s0 _ _ i1). repeat destruct s.
+      clear s0. destruct p. simpl in IH.
+      assert (J2: derrec_height x9 < S (dersrec_height d)). lia.
+      assert (J3: derrec_height x9 = derrec_height x9). reflexivity.
+      assert (J4: (ctr_L x x1 x5) + (ctr_R x x1 x5)). auto.
+      pose (IH _ J2 _ _ J3 _ _ J4). destruct s.
+      assert (J5: derrec_height x8 = derrec_height x8). reflexivity.
+      pose (ImpR_ImpL_hpinv _ J5). destruct p. clear s. pose (s0 _ _ i0). repeat destruct s.
+      clear s0. destruct p.
+      assert (J6: derrec_height x13 < S (dersrec_height d)). lia.
+      assert (J7: derrec_height x13 = derrec_height x13). reflexivity.
+      assert (J8: (ctr_L x0 x4 x6) + (ctr_R x0 x4 x6)). auto.
+      pose (IH _ J6 _ _ J7 _ _ J8). destruct s. pose (dlCons x14 DersNil). pose (dlCons x11 d0).
+      pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[x5;x6]) (Γ0 ++ x --> x0 :: Γ1 ++ Γ2, Δ0 ++ Δ1) i d1). exists d2. simpl.
+      rewrite dersrec_height_nil. lia. reflexivity. }
+  (* GLR *)
+  * inversion X. rewrite <- H4 in X. pose (GLR_app_ctr_L ctr X). destruct s.
+    { apply GLR in g0. pose (derI (rules:=GLS_rules)
+      (prems:=fun _ : Seq => False) (ps:=[(XBoxed_list ++ [Box A0], [A0])])
+      sc g0). subst. pose (d0 d). exists d1. simpl. reflexivity. }
+    { repeat destruct s. repeat destruct p. apply GLR in g0.
+      remember [(XBoxed_list ++ [Box A0], [A0])] as ps'. destruct d. subst. inversion H4.
+      rewrite Heqps' in H4. inversion H4. subst. simpl. simpl in IH.
+      assert (E1: derrec_height d < S (Init.Nat.max (derrec_height d) (dersrec_height d0))).
+      rewrite dersrec_height_nil. rewrite Nat.max_0_r. apply Nat.lt_succ_r. left. reflexivity.
+      assert (E2: derrec_height d = derrec_height d). auto.
+      assert ((ctr_L (unBox_formula A) (XBoxed_list ++ [Box A0], [A0]) x) +
+      (ctr_R (unBox_formula A) (XBoxed_list ++ [Box A0], [A0]) x)). auto.
+      pose (IH (derrec_height d) E1 ((XBoxed_list ++ [Box A0], [A0])) d E2 x (unBox_formula A) H).
+      destruct s.
+      assert (E3: derrec_height x1 < S (Init.Nat.max (derrec_height d) (dersrec_height d0))).
+      rewrite dersrec_height_nil. rewrite Nat.max_0_r. apply Nat.lt_succ_r. assumption. reflexivity.
+      assert (E4: derrec_height x1 = derrec_height x1). auto.
+      assert ((ctr_L A x x0) + (ctr_R A x x0)). auto.
+      pose (IH (derrec_height x1) E3 x x1 E4 x0 A H0). destruct s.
+      pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[x0]) (Γ0 ++ A :: Γ1 ++ Γ2, Δ) g0). subst. simpl.
+      pose (dlCons x2 d0). pose (d1 d2). exists d3. simpl. rewrite dersrec_height_nil.
+      repeat rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono.
+      pose (Nat.le_trans (derrec_height x2) (derrec_height x1) (derrec_height d) l0 l).
+      assumption. reflexivity. }}
+{ inversion ctr. assert (DersNil: dersrec GLS_rules (fun _ : Seq => False) []).
+  apply dersrec_nil. inversion g.
+  (* IdP *)
+  * inversion H1. rewrite <- H in H5. inversion H5.
+    apply app2_find_hole in H8. destruct H8. destruct s.
+    + destruct s.
+      { destruct p. inversion e0. subst. pose (IdPRule_I P Γ0 Γ1 Δ3 (Δ1 ++ Δ2)). apply IdP in i. simpl in i.
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ0 ++ # P :: Γ1, Δ3 ++ # P :: Δ1 ++ Δ2) i DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+        left. reflexivity. reflexivity. }
+      { destruct p. destruct x.
+        - rewrite app_nil_l in e0. inversion e0.
+          subst. pose (IdPRule_I P Γ0 Γ1 (Δ3 ++ []) (Δ1 ++ Δ2)). apply IdP in i. simpl in i.
+          pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) (Γ0 ++ # P :: Γ1, (Δ3 ++ []) ++ # P :: Δ1 ++ Δ2) i DersNil). exists d0. simpl.
+          repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+        - inversion e0. subst.
+          pose (IdPRule_I P Γ0 Γ1 Δ3 (x ++ A :: Δ1 ++ Δ2)). apply IdP in i. simpl in i.
+          assert (E: Δ3 ++ # P :: x ++ A :: Δ1 ++ Δ2 = (Δ3 ++ # P :: x) ++ A :: Δ1 ++ Δ2). repeat rewrite <- app_assoc. reflexivity.
+          rewrite E in i. clear E.
+          pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) (Γ0 ++ # P :: Γ1, (Δ3 ++ # P :: x) ++ A :: Δ1 ++ Δ2) i DersNil). exists d0. simpl.
+          repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+    + destruct p. destruct x.
+      { rewrite app_nil_l in e0. inversion e0. subst.
+        pose (IdPRule_I P Γ0 Γ1 Δ0 (Δ1 ++ Δ2)). apply IdP in i. simpl in i.
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ0 ++ # P :: Γ1, Δ0 ++ # P :: Δ1 ++ Δ2) i DersNil). exists d0. simpl.
+        repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+      { inversion e0. subst. apply app2_find_hole in H9. destruct H9. destruct s.
+        - destruct s.
+          + destruct p. inversion e1. subst.
+            pose (IdPRule_I P Γ0 Γ1 Δ0 (Δ1 ++ Δ2)). apply IdP in i. simpl in i.
+            pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ # P :: Γ1, Δ0 ++ # P :: Δ1 ++ Δ2) i DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+          + destruct p. destruct x0.
+            * rewrite app_nil_l in e1. inversion e1. subst.
+              pose (IdPRule_I P Γ0 Γ1 Δ0 (Δ1 ++ Δ4)). apply IdP in i. simpl in i.
+              pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+              (ps:=[]) (Γ0 ++ # P :: Γ1, Δ0 ++ # P :: Δ1 ++ Δ4) i DersNil). exists d0. simpl.
+              repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+            * inversion e1. subst.
+              pose (IdPRule_I P Γ0 Γ1 (Δ0 ++ m0 :: Δ1 ++ x0) Δ4). apply IdP in i. simpl in i.
+              repeat rewrite <- app_assoc in i. simpl in i. repeat rewrite <- app_assoc in i.
+              pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+              (ps:=[]) (Γ0 ++ # P :: Γ1, Δ0 ++ m0 :: Δ1 ++ x0 ++ # P :: Δ4) i DersNil). exists d0. simpl.
+              repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+        - destruct p. destruct x0.
+          + rewrite app_nil_l in e1. inversion e1. subst.
+            pose (IdPRule_I P Γ0 Γ1 Δ0 ((x ++ []) ++ Δ2)). apply IdP in i. simpl in i.
+            pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ # P :: Γ1, Δ0 ++ # P :: (x ++ []) ++ Δ2) i DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+          + inversion e1. subst.
+            pose (IdPRule_I P Γ0 Γ1 (Δ0 ++ m :: x) (x0 ++ Δ2)). apply IdP in i. simpl in i.
+            assert (E: (Δ0 ++ m :: x) ++ # P :: x0 ++ Δ2 = Δ0 ++ m :: (x ++ # P :: x0) ++ Δ2). repeat rewrite <- app_assoc. reflexivity.
+            rewrite E in i. clear E.
+            pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ # P :: Γ1, Δ0 ++ m :: (x ++ # P :: x0) ++ Δ2) i DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+  (* BotL *)
+  * inversion H1. rewrite <- H in H5. inversion H5.
+    pose (BotLRule_I Γ0 Γ1 (Δ0 ++ A :: Δ1 ++ Δ2)). apply BotL in b.
+    pose (derI (rules:=GLS_rules)
+    (prems:=fun _ : Seq => False)
+    (ps:=[]) (Γ0 ++ :: Γ1, Δ0 ++ A :: Δ1 ++ Δ2) b DersNil). subst. exists d0. simpl.
+    repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+  (* ImpR *)
+  * inversion H1. subst. inversion H5. subst. pose (ImpR_app_ctr_R ctr H1). destruct s.
+    { destruct s. destruct p. apply ImpR in i.
+      pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[x]) (Γ0 ++ Γ1, Δ0 ++ A :: Δ1 ++ Δ2) i). subst. simpl.
+      remember [(Γ0 ++ A0 :: Γ1, Δ3 ++ B :: Δ4)] as ps'. destruct d. inversion Heqps'.
+      inversion Heqps'. subst. simpl. rewrite dersrec_height_nil. simpl in IH.
+      rewrite dersrec_height_nil in IH. rewrite Nat.max_0_r. rewrite Nat.max_0_r in IH.
+      assert (E: derrec_height d < S (derrec_height d)). auto.
+      assert (E1: derrec_height d = derrec_height d). auto.
+      assert ((ctr_L A (Γ0 ++ A0 :: Γ1, Δ3 ++ B :: Δ4) x) + (ctr_R A (Γ0 ++ A0 :: Γ1, Δ3 ++ B :: Δ4) x)).
+      auto.
+      pose (IH (derrec_height d) E (Γ0 ++ A0 :: Γ1, Δ3 ++ B :: Δ4) d E1 x A H).
+      destruct s.
+      pose (dlCons x0 d1). pose (d0 d2). exists d3. simpl. rewrite dersrec_height_nil.
+      rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. assumption. reflexivity. reflexivity. reflexivity. }
+    { repeat destruct s. repeat destruct p. subst. apply ImpR in i.
+      assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+      pose (dersrec_derrec_height d J30). destruct s.
+      assert (J1: derrec_height x4 = derrec_height x4). reflexivity.
+      pose (ImpR_ImpL_hpinv _ J1). destruct p. clear s0. pose (s _ i0). repeat destruct s0.
+      clear s. simpl in IH.
+      assert (J2: derrec_height x5 < S (dersrec_height d)). lia.
+      assert (J3: derrec_height x5 = derrec_height x5). reflexivity.
+      assert (J4: (ctr_L x x1 x2) + (ctr_R x x1 x2)). auto.
+      pose (IH _ J2 _ _ J3 _ _ J4). destruct s.
+      assert (J5: derrec_height x6 = derrec_height x6). reflexivity.
+      assert (J6: derrec_height x6 < S (dersrec_height d)). lia.
+      assert (J8: (ctr_L x0 x2 x3) + (ctr_R x0 x2 x3)). auto.
+      pose (IH _ J6 _ _ J5 _ _ J8). destruct s. pose (dlCons x7 DersNil).
+      pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[x3]) (Γ0 ++ Γ1, Δ0 ++ x --> x0 :: Δ1 ++ Δ2) i d0). simpl. exists d1. simpl. rewrite dersrec_height_nil.
+      lia. reflexivity. }
+  (* ImpL *)
+  * inversion H1. subst. inversion H5. subst. pose (ImpL_app_ctr_R ctr H1). destruct s.
+    repeat destruct s. repeat destruct p. apply ImpL in i.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x;x0]) (Γ0 ++ A0 --> B :: Γ1, Δ0 ++ A :: Δ1 ++ Δ2) i). subst. simpl.
+    remember [(Γ0 ++ Γ1, Δ3 ++ A0 :: Δ4);(Γ0 ++ B :: Γ1, Δ3 ++ Δ4)] as ps'. destruct d.
+    inversion Heqps'. inversion Heqps'. subst.
+    remember [(Γ0 ++ B :: Γ1, Δ3 ++ Δ4)] as ps''. destruct d1. inversion Heqps''.
+    inversion Heqps''. simpl. subst. rewrite dersrec_height_nil. simpl in IH.
+    rewrite dersrec_height_nil in IH. rewrite Nat.max_0_r. rewrite Nat.max_0_r in IH.
+    assert (E1: derrec_height d < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+    apply Nat.lt_succ_r. apply Nat.le_max_l.
+    assert (E2: derrec_height d = derrec_height d). auto.
+    assert ((ctr_L A (Γ0 ++ Γ1, Δ3 ++ A0 :: Δ4) x) + (ctr_R A (Γ0 ++ Γ1, Δ3 ++ A0 :: Δ4) x)).
+    auto.
+    pose (IH (derrec_height d) E1 (Γ0 ++ Γ1, Δ3 ++ A0 :: Δ4) d E2 x A H).
+    destruct s.
+    assert (E3: derrec_height d1 < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+    apply Nat.lt_succ_r. apply Nat.le_max_r.
+    assert (E4: derrec_height d1 = derrec_height d1). auto.
+    assert ((ctr_L A (Γ0 ++ B :: Γ1, Δ3 ++ Δ4) x0) + (ctr_R A (Γ0 ++ B :: Γ1, Δ3 ++ Δ4) x0)).
+    auto.
+    pose (IH (derrec_height d1) E3 (Γ0 ++ B :: Γ1, Δ3 ++ Δ4) d1 E4 x0 A H0).
+    destruct s.
+    pose (dlCons x1 (dlCons x2 d2)). pose (d0 d3). exists d4. simpl. rewrite dersrec_height_nil.
+    rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. apply Nat.max_le_compat.
+    assumption. assumption. reflexivity. reflexivity. reflexivity.
+  (* GLR *)
+  * inversion X. rewrite <- H4 in X. pose (GLR_app_ctr_R ctr X).
+    apply GLR in g0.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[(XBoxed_list ++ [Box A0], [A0])]) sc g0). subst. simpl. pose (d0 d). exists d1.
+    simpl. rewrite <- Nat.succ_le_mono. left. }
+Qed.
+ +
+Theorem GLS_hpadm_ctr_L : forall (k : nat) s
+        (D0 : GLS_prv s),
+        k = (derrec_height D0) ->
+          (forall sc A, ((@ctr_L A s sc) ->
+          existsT2 (D1 : GLS_prv sc),
+          derrec_height D1 <= k)).
+Proof.
+intros. intros. assert (H1: derrec_height D0 = derrec_height D0). reflexivity.
+assert (H3 : (ctr_L A s sc) + (ctr_R A s sc)). auto.
+pose (@GLS_hpadm_ctr_LR (derrec_height D0) s
+D0 H1 sc A H3). destruct s0. exists x. lia.
+Qed.
+ +
+Theorem GLS_hpadm_ctr_R : forall (k : nat) s
+        (D0 : GLS_prv s),
+        k = (derrec_height D0) ->
+          (forall sc A, ((@ctr_R A s sc) ->
+          existsT2 (D1 : GLS_prv sc),
+          derrec_height D1 <= k)).
+Proof.
+intros. intros. assert (H1: derrec_height D0 = derrec_height D0). reflexivity.
+assert (H3 : (ctr_L A s sc) + (ctr_R A s sc)). auto.
+pose (@GLS_hpadm_ctr_LR (derrec_height D0) s
+D0 H1 sc A H3). destruct s0. exists x. lia.
+Qed.
+ +
+(* We can now prove that contraction of lists is also admissible. *)
+ +
+Theorem GLS_hpadm_list_ctr_L : forall Γ1 (k : nat) Γ0 Γ2 Γ3 Δ
+        (D0 : GLS_prv (Γ0 ++ Γ1 ++ Γ2 ++ Γ1 ++ Γ3,Δ)),
+        k = (derrec_height D0) ->
+          existsT2 (D1 : GLS_prv (Γ0 ++ Γ1 ++ Γ2 ++ Γ3,Δ)),
+          derrec_height D1 <= k.
+Proof.
+induction Γ1.
+- intros. exists D0. rewrite H. auto.
+- intros. assert (H0: derrec_height D0 = derrec_height D0). reflexivity.
+  assert (H1 : ctr_L a (Γ0 ++ (a :: Γ1) ++ Γ2 ++ (a :: Γ1) ++ Γ3, Δ) ((Γ0 ++ [a]) ++ Γ1 ++ Γ2 ++ Γ1 ++ Γ3, Δ)).
+  simpl. assert (Γ0 ++ a :: Γ1 ++ Γ2 ++ a :: Γ1 ++ Γ3 = Γ0 ++ a :: (Γ1 ++ Γ2) ++ a :: (Γ1 ++ Γ3)).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H1.
+  assert ((Γ0 ++ [a]) ++ Γ1 ++ Γ2 ++ Γ1 ++ Γ3 = Γ0 ++ a :: (Γ1 ++ Γ2) ++ Γ1 ++ Γ3). repeat rewrite <- app_assoc.
+  reflexivity. rewrite H2. apply ctr_LI.
+  assert ((ctr_L a (Γ0 ++ (a :: Γ1) ++ Γ2 ++ (a :: Γ1) ++ Γ3, Δ) ((Γ0 ++ [a]) ++ Γ1 ++ Γ2 ++ Γ1 ++ Γ3, Δ)) +
+  (ctr_R a (Γ0 ++ (a :: Γ1) ++ Γ2 ++ (a :: Γ1) ++ Γ3, Δ) ((Γ0 ++ [a]) ++ Γ1 ++ Γ2 ++ Γ1 ++ Γ3, Δ))). auto.
+  pose (@GLS_hpadm_ctr_LR (derrec_height D0) (Γ0 ++ (a :: Γ1) ++ Γ2 ++ (a :: Γ1) ++ Γ3, Δ)
+  D0 H0 ((Γ0 ++ [a]) ++ Γ1 ++ Γ2 ++ Γ1 ++ Γ3, Δ) a H2). destruct s.
+  assert (H3: derrec_height x = derrec_height x). reflexivity.
+  pose (IHΓ1 (derrec_height x) (Γ0 ++ [a]) Γ2 Γ3 Δ x H3). destruct s.
+  assert (Γ0 ++ (a :: Γ1) ++ Γ2 ++ Γ3 = (Γ0 ++ [a]) ++ Γ1 ++ Γ2 ++ Γ3). repeat rewrite <- app_assoc. auto.
+  rewrite H4. exists x0. lia.
+Qed.
+ +
+Theorem GLS_hpadm_list_ctr_R : forall Δ1 (k : nat) Γ Δ0 Δ2 Δ3
+        (D0 : GLS_prv (Γ,Δ0 ++ Δ1 ++ Δ2 ++ Δ1 ++ Δ3)),
+        k = (derrec_height D0) ->
+          existsT2 (D1 : GLS_prv (Γ,Δ0 ++ Δ1 ++ Δ2 ++ Δ3)),
+          derrec_height D1 <= k.
+Proof.
+induction Δ1.
+- intros. exists D0. rewrite H. auto.
+- intros. assert (H0: derrec_height D0 = derrec_height D0). reflexivity.
+  assert (H1 : ctr_R a (Γ, Δ0 ++ (a :: Δ1) ++ Δ2 ++ (a :: Δ1) ++ Δ3) (Γ, (Δ0 ++ [a]) ++ Δ1 ++ Δ2 ++ Δ1 ++ Δ3)).
+  simpl. assert (Δ0 ++ a :: Δ1 ++ Δ2 ++ a :: Δ1 ++ Δ3 = Δ0 ++ a :: (Δ1 ++ Δ2) ++ a :: (Δ1 ++ Δ3)).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H1.
+  assert ((Δ0 ++ [a]) ++ Δ1 ++ Δ2 ++ Δ1 ++ Δ3 = Δ0 ++ a :: (Δ1 ++ Δ2) ++ Δ1 ++ Δ3). repeat rewrite <- app_assoc.
+  reflexivity. rewrite H2. apply ctr_RI.
+  assert ((ctr_L a (Γ, Δ0 ++ (a :: Δ1) ++ Δ2 ++ (a :: Δ1) ++ Δ3) (Γ, (Δ0 ++ [a]) ++ Δ1 ++ Δ2 ++ Δ1 ++ Δ3)) +
+  (ctr_R a (Γ, Δ0 ++ (a :: Δ1) ++ Δ2 ++ (a :: Δ1) ++ Δ3) (Γ, (Δ0 ++ [a]) ++ Δ1 ++ Δ2 ++ Δ1 ++ Δ3))). auto.
+  pose (@GLS_hpadm_ctr_LR (derrec_height D0) (Γ, Δ0 ++ (a :: Δ1) ++ Δ2 ++ (a :: Δ1) ++ Δ3)
+  D0 H0 (Γ, (Δ0 ++ [a]) ++ Δ1 ++ Δ2 ++ Δ1 ++ Δ3) a H2). destruct s.
+  assert (H3: derrec_height x = derrec_height x). reflexivity.
+  pose (IHΔ1 (derrec_height x) Γ (Δ0 ++ [a]) Δ2 Δ3 x H3). destruct s.
+  assert (Δ0 ++ (a :: Δ1) ++ Δ2 ++ Δ3 = (Δ0 ++ [a]) ++ Δ1 ++ Δ2 ++ Δ3). repeat rewrite <- app_assoc. auto.
+  rewrite H4. exists x0. lia.
+Qed.
+ +
+
+
+ +
+ + + diff --git a/GL.GLS.GLS_cut_elim.html b/GL.GLS.GLS_cut_elim.html new file mode 100644 index 0000000..fd60263 --- /dev/null +++ b/GL.GLS.GLS_cut_elim.html @@ -0,0 +1,88 @@ + + + + + + + + + + + + + +
+
+

GL.GLS.GLS_cut_elim

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+ +
+Require Import GLS_calcs.
+ +
+Require Import GLS_termination_measure.
+Require Import GLS_exch.
+Require Import GLS_ctr.
+Require Import GLS_wkn.
+Require Import GLS_dec.
+Require Import GLS_inv_ImpR_ImpL.
+Require Import GLS_additive_cut.
+ +
+Inductive CutRule : rlsT Seq :=
+  | CutRule_I : forall A Γ0 Γ1 Δ0 Δ1,
+          CutRule [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1) ; (Γ0 ++ A :: Γ1, Δ0 ++ Δ1)]
+                    (Γ0 ++ Γ1, Δ0 ++ Δ1)
+.
+ +
+Inductive GLS_cut_rules : rlsT Seq :=
+  | GLS_woc : forall ps c, GLS_rules ps c -> GLS_cut_rules ps c
+  | iGLS_cut : forall ps c, CutRule ps c -> GLS_cut_rules ps c
+.
+ +
+Definition GLS_cut_prv s := derrec GLS_cut_rules (fun _ => False) s.
+Definition GLS_cut_drv s := derrec GLS_cut_rules (fun _ => True) s.
+ +
+Theorem GLS_cut_elimination : forall s, (GLS_cut_prv s) -> (GLS_prv s).
+Proof.
+intros s D.
+apply derrec_all_rect with
+(Q:= fun x => (GLS_prv x))
+in D ; auto.
+- intros. inversion H.
+- intros ps concl rule ders IH. inversion rule.
+  * subst. apply derI with (ps:=ps) ; auto. apply dersrec_forall. intros. epose (@ForallTD_forall _ _ _ IH c H) ; auto.
+  * subst. inversion H. subst. apply GLS_cut_adm with (A:=A).
+    epose (@ForallTD_forall _ _ _ IH (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)). apply g. apply InT_eq.
+    epose (@ForallTD_forall _ _ _ IH (Γ0 ++ A :: Γ1, Δ0 ++ Δ1)). apply g. apply InT_cons ; apply InT_eq.
+Defined.
+
+
+ +
+ + + diff --git a/GL.GLS.GLS_dec.html b/GL.GLS.GLS_dec.html new file mode 100644 index 0000000..b06d43a --- /dev/null +++ b/GL.GLS.GLS_dec.html @@ -0,0 +1,318 @@ + + + + + + + + + + + + + +
+
+

GL.GLS.GLS_dec

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+ +
+Require Import GLS_calcs.
+ +
+Set Implicit Arguments.
+ +
+(* In this file we show that the applicability of the rules in GLS is decidable. *)
+ +
+Definition in_top_boxes : forall l A, (In A (top_boxes l)) -> (existsT2 B l1 l2, (A = Box B) * (l = l1 ++ A :: l2)).
+Proof.
+induction l.
+- intros. simpl in H. inversion H.
+- intros. destruct a as [n | | |].
+  * simpl in H. apply IHl in H. destruct H. destruct s. destruct s. destruct p. subst.
+    exists x. exists ([# n] ++ x0). exists x1. auto.
+  * simpl in H. apply IHl in H. destruct H. destruct s. destruct s. destruct p. subst.
+    exists x. exists ([] ++ x0). exists x1. auto.
+  * simpl in H. apply IHl in H. destruct H. destruct s. destruct s. destruct p. subst.
+    exists x. exists ([a1 --> a2] ++ x0). exists x1. auto.
+  * simpl (top_boxes (Box a :: l)) in H. destruct (eq_dec_form (Box a) A).
+    + subst. exists a. exists []. exists l. auto.
+    + subst. assert (H0 : In A (top_boxes l)). inversion H. exfalso. apply n. assumption.
+      assumption. apply IHl in H0. destruct H0. destruct s. destruct s. destruct p.
+      subst. exists x. exists ([Box a] ++ x0). exists x1. auto.
+Qed.
+ +
+Lemma remove_add_rest_gen_ext : forall l (A : MPropF), rest_gen_ext [A] (remove eq_dec_form A l) l.
+Proof.
+induction l.
+- intro A. simpl. apply univ_gen_ext_nil.
+- intro A. pose (IHl A). simpl. destruct (eq_dec_form A a).
+  * subst. apply univ_gen_ext_extra. apply InT_eq.
+    assumption.
+  * apply univ_gen_ext_cons. assumption.
+Qed.
+ +
+Definition dec_prop_var_in : forall s, (existsT2 P, (In (# P) (fst s)) /\ (In (# P) (snd s))) +
+                                      ((existsT2 P, (In (# P) (fst s)) /\ (In (# P) (snd s))) -> False).
+Proof.
+intro. destruct s ; simpl.
+induction l.
+- right. intro. destruct H. destruct a. simpl in H. inversion H.
+- destruct IHl.
+  * destruct s. simpl in a0. destruct a0. left. exists x. simpl. split. auto. assumption.
+  * simpl in *. destruct a as [n | | |].
+    2-4: right ; intro H ; destruct H as (n, H0) ; destruct H0 as (H2 , H3) ; destruct H2 as [H4 | H5] ;
+    [ inversion H4 | apply f ; exists n ; auto].
+    + destruct (In_dec l0 (# n)).
+      { left. exists n ; split ; auto. }
+      { right. intro. destruct H. destruct a. destruct H ; subst.
+        - inversion H ; subst. apply n0. assumption.
+        - apply f. simpl. exists x. firstorder. }
+Defined.
+ +
+Definition dec_is_boxedT : forall (A : MPropF), (is_boxedT A) + ((is_boxedT A) -> False).
+Proof.
+induction A.
+- right. intro. inversion X. inversion H.
+- right. intro. inversion X. inversion H.
+- right. intro. inversion X. inversion H.
+- left. exists A. reflexivity.
+Defined.
+ +
+Definition dec_is_box : forall (A : MPropF), (existsT2 B, A = Box B) + ((existsT2 B, A = Box B ) -> False).
+Proof.
+destruct A.
+- right. intro. destruct H. inversion e.
+- right. intro. destruct H. inversion e.
+- right. intro. destruct H. inversion e.
+- left. exists A. reflexivity.
+Defined.
+ +
+Definition dec_box_in : forall s, (existsT2 (A : MPropF), (In (Box A) (fst s)) /\ (In (Box A) (snd s))) +
+                             ((existsT2 (A : MPropF), (In (Box A) (fst s)) /\ (In (Box A) (snd s))) -> False).
+Proof.
+intro. destruct s.
+induction l.
+- right. intro. destruct H. destruct a. simpl in H. inversion H.
+- destruct IHl.
+  * destruct s. simpl in a0. destruct a0. left. exists x. simpl. split. auto. assumption.
+  * destruct (dec_is_box a).
+    + destruct (In_dec l0 a).
+      { left. destruct s. subst. simpl. exists x. split. auto. assumption. }
+      { right. simpl. intro. destruct H. destruct a0. destruct H.
+        - subst. apply n. assumption.
+        - apply f. simpl. exists x. firstorder. }
+    + right. intro. simpl in H. destruct H. destruct a0. destruct H.
+      { subst. apply f0. exists x. reflexivity. }
+      { apply f. firstorder. }
+Defined.
+ +
+Definition dec_GLS_init_rules : forall (s :Seq) ,
+          ((IdPRule [] s) + (BotLRule [] s)) +
+          (((IdPRule [] s) + (BotLRule [] s)) -> False).
+Proof.
+intro s. destruct s. destruct (dec_prop_var_in (pair l l0)).
+- destruct s. destruct a. left. left. simpl in H. simpl in H0.
+  apply in_splitT in H. destruct H. destruct s. apply in_splitT in H0. destruct H0. destruct s.
+  subst. apply IdPRule_I.
+- destruct (In_dec l (Bot)).
+  + left. apply in_splitT in i. destruct i. destruct s. subst. right. apply BotLRule_I.
+  + right. intro. destruct H.
+    * inversion i. subst. simpl in f. apply f. exists P. split ; apply in_or_app ; right ; apply in_eq.
+    * inversion b. subst. apply n. apply in_or_app. right. apply in_eq.
+Defined.
+ +
+Definition dec_IdP_rule : forall (s :Seq) ,
+          (IdPRule [] s) +
+          ((IdPRule [] s) -> False).
+Proof.
+intro s. destruct s. destruct (dec_prop_var_in (pair l l0)).
+- destruct s. destruct a. left. simpl in H. simpl in H0.
+  apply in_splitT in H. destruct H. destruct s. apply in_splitT in H0. destruct H0. destruct s.
+  subst. apply IdPRule_I.
+- right. intro. destruct H. apply f. exists P. split ; apply in_or_app ; right ; apply in_eq.
+Defined.
+ +
+Definition dec_IdB_rule : forall (s :Seq) ,
+          (IdBRule [] s) +
+          ((IdBRule [] s) -> False).
+Proof.
+intro s. destruct s. destruct (dec_box_in (l, l0)).
+- destruct s. destruct a. left. simpl in H. simpl in H0.
+  apply in_splitT in H. destruct H. destruct s. apply in_splitT in H0. destruct H0. destruct s.
+  subst. apply IdBRule_I.
+- right. intro. destruct H. apply f. exists A. split ; apply in_or_app ; right ; apply in_eq.
+Defined.
+ +
+Definition dec_BotL_rule : forall (s :Seq) ,
+          (BotLRule [] s) +
+          ((BotLRule [] s) -> False).
+Proof.
+intro s. destruct s. destruct (In_dec l (Bot)).
+- left. apply in_splitT in i. destruct i. destruct s. subst. apply BotLRule_I.
+- right. intro. inversion H. apply n. subst. apply in_or_app. right. apply in_eq.
+Defined.
+ +
+Definition dec_init_rules : forall (s :Seq) ,
+          ((IdPRule [] s) + (IdBRule [] s) + (BotLRule [] s)) +
+          (((IdPRule [] s) + (IdBRule [] s) + (BotLRule [] s)) -> False).
+Proof.
+intro s. destruct s. destruct (dec_prop_var_in (pair l l0)).
+- destruct s. destruct a. left. left. left. simpl in H. simpl in H0.
+  apply in_splitT in H. destruct H. destruct s. apply in_splitT in H0. destruct H0. destruct s.
+  subst. apply IdPRule_I.
+- destruct (In_dec l (Bot)).
+  + left. right. apply in_splitT in i. destruct i. destruct s. subst. apply BotLRule_I.
+  + destruct (dec_box_in (l, l0)).
+    * left. left. right. destruct s. destruct a. apply in_splitT in H. destruct H. destruct s.
+      simpl in e. apply in_splitT in H0. destruct H0. destruct s. simpl in e0. subst. apply IdBRule_I.
+    * right. intro. destruct H.
+      { destruct s.
+        - inversion i. subst. simpl in f. apply f. exists P. split ; apply in_or_app ; right ; apply in_eq.
+        - inversion i. subst. apply f0. exists A. split ; apply in_or_app ; right ; apply in_eq. }
+      { inversion b. subst. apply n. apply in_or_app. right. apply in_eq. }
+Defined.
+ +
+Definition dec_is_imp : forall (A : MPropF), (existsT2 B C, A = Imp B C) + ((existsT2 B C, A = Imp B C) -> False).
+Proof.
+destruct A as [n | | |].
+- right. intro. destruct H. destruct s. inversion e.
+- right. intro. destruct H. destruct s. inversion e.
+- left. exists A1. exists A2. reflexivity.
+- right. intro. destruct H. destruct s. inversion e.
+Defined.
+ +
+Definition dec_imp_in : forall (l : list MPropF), (existsT2 A B, In (Imp A B) l) + ((existsT2 A B, In (Imp A B) l) -> False).
+Proof.
+induction l.
+- right. intro. destruct H. destruct s. inversion i.
+- destruct IHl.
+  * repeat destruct s. left. exists x. exists x0. apply in_cons. assumption.
+  * destruct (dec_is_imp a).
+    + repeat destruct s. subst. left. exists x. exists x0. apply in_eq.
+    + right. intro. destruct H. destruct s. inversion i.
+      { subst. apply f0. exists x. exists x0. reflexivity. }
+      { apply f. exists x. exists x0. assumption. }
+Defined.
+ +
+Definition dec_ImpR_rule : forall (concl :Seq),
+          (existsT2 prem, ImpRRule [prem] concl) + ((existsT2 prem, ImpRRule [prem] concl) -> False).
+Proof.
+intros concl. destruct concl. destruct (dec_imp_in l0).
+- left. repeat destruct s. apply in_splitT in i. destruct i. destruct s. subst.
+  exists ([] ++ x :: l, x1 ++ x0 :: x2). assert ((l, x1 ++ x --> x0 :: x2) = ([] ++ l, x1 ++ x --> x0 :: x2)).
+  reflexivity. apply ImpRRule_I.
+- right. intro. destruct H. inversion i. subst. apply f. exists A. exists B. apply in_or_app.
+  right. apply in_eq.
+Defined.
+ +
+Definition dec_ImpL_rule : forall (concl :Seq),
+          (existsT2 prem1 prem2, ImpLRule [prem1 ; prem2] concl) + ((existsT2 prem1 prem2, ImpLRule [prem1 ; prem2] concl) -> False).
+Proof.
+intro concl. destruct concl. destruct (dec_imp_in l).
+- left. repeat destruct s. apply in_splitT in i. destruct i. destruct s. subst.
+  exists (x1 ++ x2, [] ++ x :: l0). exists (x1 ++ x0 :: x2, [] ++ l0).
+  assert ((x1 ++ x --> x0 :: x2, l0) = (x1 ++ x --> x0 :: x2, [] ++ l0)). reflexivity.
+  rewrite H. apply ImpLRule_I.
+- right. intro. destruct H. destruct s. inversion i. subst. apply f. exists A. exists B.
+  apply in_or_app. right. apply in_eq.
+Defined.
+ +
+Definition dec_box_in_list : forall l, (existsT2 (A : MPropF), In (Box A) l) +
+                             ((existsT2 (A : MPropF), In (Box A) l) -> False).
+Proof.
+induction l.
+- simpl. right. intro. destruct H. assumption.
+- destruct (dec_is_box a).
+  * destruct s. subst. left. exists x. apply in_eq.
+  * destruct IHl.
+    + left. destruct s. exists x. apply in_cons. assumption.
+    + right. intro. destruct H. inversion i. subst. apply f. exists x. reflexivity. apply f0.
+      exists x. assumption.
+Defined.
+ +
+Definition dec_GLR_rule : forall (concl :Seq),
+          (existsT2 prem, GLRRule [prem] concl) + ((existsT2 prem, GLRRule [prem] concl) -> False).
+Proof.
+intro concl. destruct concl. destruct (dec_box_in_list l0).
+- left. destruct s. exists ((XBoxed_list (top_boxes l)) ++ [Box x], [x]).
+  apply in_splitT in i. destruct i. destruct s. subst. apply GLRRule_I.
+  + unfold is_Boxed_list. intros. apply in_top_boxes in H. destruct H. destruct s. destruct s.
+    destruct p. exists x2. assumption.
+  + induction l. simpl. apply univ_gen_ext_nil. destruct a.
+    * simpl. apply univ_gen_ext_extra. intro. destruct X. inversion H. assumption.
+    * simpl. apply univ_gen_ext_extra. intro. destruct X. inversion H. assumption.
+    * simpl. apply univ_gen_ext_extra. intro. destruct X. inversion H. assumption.
+    * simpl. apply univ_gen_ext_cons. apply IHl.
+- right. intro. destruct X. inversion g. subst. apply f. exists A. apply in_or_app. right. apply in_eq.
+Defined.
+ +
+Definition dec_GLS_rules : forall (concl :Seq) ,
+          ((existsT2 prems, GLS_rules prems concl) -> False) + (existsT2 prems, GLS_rules prems concl).
+Proof.
+intro concl. destruct (dec_GLS_init_rules concl).
+- right. repeat destruct s.
+  * exists nil. apply IdP. assumption.
+  * exists nil. apply BotL. assumption.
+- destruct (dec_ImpR_rule concl).
+  * right. destruct s. exists [x]. apply ImpR. assumption.
+  * destruct (dec_ImpL_rule concl).
+    + right. repeat destruct s. exists [x; x0]. apply ImpL. assumption.
+    + destruct (dec_GLR_rule concl).
+      { right. repeat destruct s. exists [x]. apply GLR. assumption. }
+      { left. intro. destruct X. inversion g.
+        - inversion H. subst. apply f. auto.
+        - inversion H. subst. apply f. auto.
+        - inversion H. subst. apply f0. exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1). assumption.
+        - inversion H. subst. apply f1. exists (Γ0 ++ Γ1, Δ0 ++ A :: Δ1). exists (Γ0 ++ B :: Γ1, Δ0 ++ Δ1).
+          assumption.
+        - inversion X. subst. apply f2. exists (XBoxed_list ++ [Box A], [A]). assumption. }
+Defined.
+ +
+
+
+ +
+ + + diff --git a/GL.GLS.GLS_der_dec.html b/GL.GLS.GLS_der_dec.html new file mode 100644 index 0000000..370ed20 --- /dev/null +++ b/GL.GLS.GLS_der_dec.html @@ -0,0 +1,1296 @@ + + + + + + + + + + + + + +
+
+

GL.GLS.GLS_der_dec

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+Require Import Coq.Arith.Compare_dec.
+ +
+Require Import GLS_calcs.
+Require Import GLS_termination_measure.
+Require Import GLS_exch.
+Require Import GLS_ctr.
+Require Import GLS_wkn.
+Require Import GLS_dec.
+Require Import GLS_inv_ImpR_ImpL.
+ +
+Set Implicit Arguments.
+ +
+Lemma forall_elem_list : forall {A : Type} (l : list A) (P : A -> Type),
+    (forall a, (InT a l) -> ((P a) + ((P a) -> False))) ->
+    (existsT2 a, (InT a l) * (P a)) + ((existsT2 a, (InT a l) * (P a)) -> False).
+Proof.
+induction l.
+- intros. right. intros. destruct X0. destruct p. inversion i.
+- intros. pose (X a). assert (InT a (a :: l)). apply InT_eq. apply s in X0. destruct X0.
+  * left. exists a. split. apply InT_eq. assumption.
+  * assert (forall a : A, InT a l -> P a + (P a -> False)).
+    { intros. apply X. apply InT_cons. assumption. }
+    pose (IHl P X0). destruct s0.
+    + left. destruct s0. exists x. split. apply InT_cons. firstorder. firstorder.
+    + right. intro. destruct X1. destruct p. inversion i. subst. firstorder. subst. firstorder.
+Qed.
+ +
+(* The list  premises of a sequent *)
+ +
+Definition proj1_sigT2 {A : Type} (P : A -> Type) (e:sigT P) := match e with
+                                    | existT _ a b => a
+                                    end.
+ +
+Definition proj2_sigT2 {A : Type} (P : A -> Type) (e : sigT P) :=
+  match e return (P (proj1_sigT2 e)) with
+  | existT _ a b => b
+  end.
+ +
+Lemma In_InT : forall (A : MPropF) l, In A l -> InT A l.
+Proof.
+intros. apply in_splitT in H. destruct H. destruct s. subst. apply InT_or_app. right.
+apply InT_eq.
+Qed.
+ +
+Definition In_InT_pair : forall (A : MPropF) (n : nat) l, In (A, n) l -> InT (A, n) l.
+Proof.
+induction l.
+- intro. inversion H.
+- intro. assert ({(A, n) = a} + {(A, n) <> a}). destruct a.
+  destruct (eq_dec_form A m). subst. destruct (Nat.eq_dec n n0). subst. auto.
+  right. intro. apply n1. inversion H0. auto. right. intro. inversion H0.
+  auto. destruct H0. subst. apply InT_eq. apply InT_cons. apply IHl.
+  inversion H. exfalso. auto. assumption.
+Defined.
+ +
+Definition InT_map_iff : forall {A B : Type} (f : A -> B) (l : list A) (y : B),
+       (InT y (map f l) -> (existsT2 x : A, (f x = y) * InT x l)) *
+       ((existsT2 x : A, (f x = y) * InT x l) -> InT y (map f l)).
+Proof.
+induction l.
+- intros. simpl. split. intro. inversion X. intro. destruct X. destruct p. inversion i.
+- simpl. intros. split.
+  * intro. inversion X.
+    + subst. exists a. split ; [ reflexivity | apply InT_eq].
+    + subst. pose (IHl y). destruct p. apply s in X0. destruct X0. destruct p. exists x.
+      split. assumption. apply InT_cons. assumption.
+  * intro. pose (IHl y). destruct p. clear s. pose (proj2_sigT2 X).
+    destruct p. inversion i0. subst. rewrite <- e. rewrite <- H0. apply InT_eq.
+    subst. assert (existsT2 x : A, (f x = y) * InT x l). exists (proj1_sigT2 X).
+    split ; assumption. apply i in X1. apply InT_cons. assumption.
+Defined.
+ +
+Fixpoint top_imps (l : list MPropF) : list MPropF :=
+match l with
+  | nil => nil
+  | h :: t => match h with
+                | Imp A B => (Imp A B) :: top_imps t
+                | _ => top_imps t
+              end
+end.
+ +
+Fixpoint pos_top_imps (l : list MPropF) : (list ((MPropF) * nat)) :=
+match l with
+  | nil => nil
+  | h :: t => match h with
+                | Imp A B => (Imp A B, 1) :: (map (fun y => (fst y, S (snd y))) (pos_top_imps t))
+                | _ => (map (fun y => (fst y, S (snd y))) (pos_top_imps t))
+              end
+end.
+ +
+Lemma le_False_lt : forall n m, ((n <= m) -> False) -> (m < n).
+Proof.
+induction n.
+- intros. exfalso. apply H. apply le_0_n.
+- induction m.
+  * intros. lia.
+  * intros. rewrite <- Nat.succ_lt_mono. apply IHn. intro. apply H. lia.
+Qed.
+ +
+Definition top_boxes_nobox_gen_ext : forall l, nobox_gen_ext (top_boxes l) l.
+Proof.
+induction l.
+- simpl. apply univ_gen_ext_nil.
+- destruct a ; simpl.
+  * apply univ_gen_ext_extra. intro. inversion X. inversion H. assumption.
+  * apply univ_gen_ext_extra. intro. inversion X. inversion H. assumption.
+  * apply univ_gen_ext_extra. intro. inversion X. inversion H. assumption.
+  * apply univ_gen_ext_cons. assumption.
+Defined.
+ +
+Lemma nobox_gen_ext_top_boxes_identity : forall l0 l1, nobox_gen_ext l0 l1 ->
+                                                       is_Boxed_list l0 ->
+                                                       (l0 = top_boxes l1).
+Proof.
+intros l0 l1 X. induction X.
+- intros. reflexivity.
+- intro. simpl. destruct x as [n | | | ].
+  * exfalso. pose (H (# n)). assert (In # n (# n :: l)). apply in_eq. apply e in H0.
+    destruct H0. inversion H0.
+  * exfalso. pose (H ()). assert (In () ( :: l)). apply in_eq. apply e in H0.
+    destruct H0. inversion H0.
+  * exfalso. pose (H (x1 --> x2)). assert (In (x1 --> x2) (x1 --> x2 :: l)). apply in_eq. apply e in H0.
+    destruct H0. inversion H0.
+  * assert (l = top_boxes le). apply IHX. intro. intros. apply H. apply in_cons. assumption.
+    rewrite H0. reflexivity.
+- simpl. destruct x.
+  * apply IHX.
+  * apply IHX.
+  * apply IHX.
+  * exfalso. apply p. exists x. reflexivity.
+Qed.
+ +
+Fixpoint flatten_list {A : Type} (l : list (list A)) : list A :=
+  match l with
+  | [ ] => [ ]
+  | h :: t => h ++ (flatten_list t)
+  end
+.
+ +
+Definition InT_flatten_list_InT_elem {A : Type} : forall (l : list (list A)) b,
+        InT b (flatten_list l) -> (existsT2 bs, (InT b bs) * (InT bs l)).
+Proof.
+induction l.
+- intros. simpl in X. inversion X.
+- intros. simpl in X. apply InT_app_or in X. destruct X.
+  * exists a. split ; [assumption | apply InT_eq].
+  * pose (IHl b). apply s in i. destruct i. destruct p. exists x. split ; [assumption | apply InT_cons ; assumption].
+Defined.
+ +
+Lemma redundant_flatten_list : forall ls (s : Seq), map (fun z : list MPropF * list MPropF => [z;s]) ls =
+flatten_list (map (fun y : list MPropF * list MPropF => [[y;s]]) ls).
+Proof.
+induction ls.
+- intros. simpl. reflexivity.
+- simpl. intros. rewrite IHls. reflexivity.
+Qed.
+ +
+Definition InT_trans_flatten_list {A : Type} : forall (l : list (list A)) bs b,
+        (InT b bs) -> (InT bs l) -> (InT b (flatten_list l)).
+Proof.
+induction l.
+- intros. inversion X0.
+- intros. inversion X0.
+  * subst. simpl. apply InT_or_app. auto.
+  * subst. simpl. apply InT_or_app. right. pose (IHl bs b X X1) ; assumption.
+Defined.
+ +
+(* In this file we prove that each sequent Γ |- Δ has a derivation (not proof) D in
+   GLS of maximal height: all derivations in GLS of this sequent must have an
+   inferior or equal height to that of D.
+
+   This result can be understood as claiming that the proof search defined by GLS
+   terminates. *)

+ +
+(* The next lemma claims that for each sequent s there is a derivation of that sequent. *)
+ +
+Lemma der_s_inhabited : forall s, inhabited (GLS_drv s).
+Proof.
+intros s.
+pose (@dpI Seq GLS_rules (fun _ : Seq => True) s).
+assert (H: (fun _ : Seq => True) s). apply I. apply d in H. apply inhabits. assumption.
+Qed.
+ +
+(* The next definition deals with the property of being a derivation D0 of maximal height
+   for the sequent s. *)

+ +
+Definition is_mhd (s: Seq) (D0 : GLS_drv s): Prop :=
+      forall (D1 : GLS_drv s), derrec_height D1 <= derrec_height D0.
+ +
+(* The next lemma says that given a list and an element, there are only finitely many
+   ways to insert this element in a list. *)

+ +
+Definition list_of_splits : forall (l : list MPropF), existsT2 listSplits,
+                            forall l1 l2, ((l1 ++ l2 = l) <-> In (l1, l2) listSplits).
+Proof.
+induction l.
+- exists [([],[])]. intros. destruct l1. split ; intro. simpl in H. rewrite H. apply in_eq.
+  simpl in H. destruct H. inversion H. reflexivity. inversion H. split ; intro.
+  simpl in H. inversion H. simpl. inversion H. inversion H0. inversion H0.
+- destruct IHl. exists ([([], a :: l)] ++ (map (fun y => (a :: (fst y), snd y)) x)).
+  intros. split ; intro.
+  * apply in_or_app. destruct l1. simpl. left. left. simpl in H. rewrite H.
+    reflexivity. simpl in H. inversion H. subst. right. pose (i l1 l2). destruct i0.
+    assert (l1 ++ l2 = l1 ++ l2). reflexivity. apply H0 in H2.
+    pose (in_map (fun y : list MPropF * list MPropF => (a :: fst y, snd y)) x (l1, l2) H2).
+    simpl in i. assumption.
+  * simpl in H. destruct H. inversion H. simpl. reflexivity. rewrite in_map_iff in H.
+    destruct H. destruct H. inversion H. subst. simpl. pose (i (fst x0) (snd x0)).
+    destruct i0. assert ((fst x0, snd x0) = x0). destruct x0. simpl. reflexivity.
+    rewrite H3 in H2. apply H2 in H0. rewrite H0. reflexivity.
+Defined.
+ +
+Definition listInserts l (A : MPropF) := map (fun y => (fst y) ++ A :: (snd y)) (proj1_sigT2 (list_of_splits l)).
+ +
+(* The next two lemmas make sure that the definition listInserts indeed captures the intended
+   list. *)

+ +
+Lemma listInserts_In : forall l (A: MPropF) l1 l2, ((l1 ++ l2 = l) -> In (l1 ++ A :: l2) (listInserts l A)).
+Proof.
+intros. unfold listInserts. assert (In (l1, l2) (proj1_sigT2 (list_of_splits l))). destruct (list_of_splits l).
+simpl. pose (i l1 l2). apply i0. assumption.
+pose (in_map (fun y : list MPropF * list MPropF => fst y ++ A :: snd y) (proj1_sigT2 (list_of_splits l)) (l1, l2) H0).
+simpl in i. assumption.
+Qed.
+ +
+Lemma In_listInserts : forall l (A: MPropF) l0, In l0 (listInserts l A) ->
+                            (exists l1 l2, prod (l1 ++ l2 = l) (l1 ++ A :: l2 = l0)).
+Proof.
+intros. unfold listInserts in H. destruct (list_of_splits l). simpl in H. rewrite in_map_iff in H.
+destruct H. destruct H. subst. exists (fst x0). exists (snd x0). split. apply i.
+destruct x0. simpl. assumption. reflexivity.
+Qed.
+ +
+(* The definitions below allow you to create the list of all sequents given two lists and a
+   formula to insert in one of them. *)

+ +
+Definition listInsertsR_Seqs (Γ Δ : list MPropF) (A : MPropF) := map (fun y => (y, Δ)) (listInserts Γ A).
+ +
+Definition listInsertsL_Seqs (Γ Δ : list MPropF) (A : MPropF) := map (fun y => (Γ, y)) (listInserts Δ A).
+ +
+(* The next definition allows one to create all sequents *)
+ +
+Definition listInsertsRL_Seqs (Γ Δ : list MPropF) (A B : MPropF) :=
+                  flatten_list (map (fun z => (map (fun y => (z, y)) (listInserts Δ B))) (listInserts Γ A)).
+ +
+(* Now we can prove that a sequent has only finitely many potential premises via the ImpR rules.
+
+   The next definition simply takes a list of formulae l and a sequent s. It outputs a list of sequents.
+   These sequents are generated when there is an implication (Imp A B) encountered in l. With such an
+   implication, the function will stack the list of all insertions of A on the left of s and of B on
+   the right of s (roughly: in fact you need to destroy all such implications on the right to get an ImpRRule
+   premise), and then continues computing on the rest of l. *)

+ +
+Fixpoint remove_nth (n: nat) (A : MPropF) l:=
+    match n with
+      | 0 => l
+      | 1 => match l with
+               | [] => []
+               | B::tl => if (eq_dec_form A B) then tl else B:: tl
+             end
+      | S m => match l with
+                 | [] => []
+                 | B::tl => B::(remove_nth m A tl)
+               end
+      end.
+ +
+Fixpoint nth_split (n : nat) (l : list MPropF) : (list MPropF * list MPropF) :=
+    match n with
+      | 0 => ([], l)
+      | 1 => match l with
+               | [] => ([], [])
+               | B::tl => ([B] , tl)
+             end
+      | S m => match l with
+                 | [] => ([], [])
+                 | B::tl => (B :: (fst (nth_split m tl)), snd (nth_split m tl))
+               end
+      end.
+ +
+Fixpoint prems_Imp_R (l : list ((MPropF) * nat)) (s : Seq) : list Seq :=
+match l with
+  | nil => nil
+  | (C, n) :: t => match n with
+                    | 0 => prems_Imp_R t s
+                    | S m => match C with
+                                | Imp A B => (listInsertsR_Seqs (fst s)
+                                               ((fst (nth_split m (remove_nth (S m) C (snd s)))) ++
+                                               B :: (snd (nth_split m (remove_nth (S m) C (snd s)))))
+                                               A)
+                                             ++ (prems_Imp_R t s)
+                                | _ => prems_Imp_R t s
+                                end
+                   end
+end.
+ +
+Lemma nth_split_length : forall (l0 l1 : list MPropF), (nth_split (length l0) (l0 ++ l1)) = (l0, l1).
+Proof.
+induction l0.
+- intros. simpl. reflexivity.
+- intros. pose (IHl0 l1). simpl (length (a :: l0)). simpl ((a :: l0) ++ l1).
+  simpl. destruct l0.
+  * simpl. reflexivity.
+  * assert (match length (m :: l0) with
+| 0 => ([a], (m :: l0) ++ l1)
+| S _ =>
+    (a :: fst (nth_split (length (m :: l0)) ((m :: l0) ++ l1)),
+    snd (nth_split (length (m :: l0)) ((m :: l0) ++ l1)))
+end = (a :: fst (nth_split (length (m :: l0)) ((m :: l0) ++ l1)),
+    snd (nth_split (length (m :: l0)) ((m :: l0) ++ l1)))). reflexivity. rewrite H.
+clear H. rewrite e. simpl. reflexivity.
+Qed.
+ +
+Lemma nth_split_idL : forall (l0 l1 : list MPropF), l0 = fst (nth_split (length l0) (l0 ++ l1)).
+Proof.
+induction l0.
+- intros. simpl. reflexivity.
+- intros. simpl (length (a :: l0)). pose (IHl0 l1). assert (fst (nth_split (S (length l0)) ((a :: l0) ++ l1)) =
+  a :: fst (nth_split (length l0) (l0 ++ l1))). simpl. destruct l0. simpl. reflexivity.
+  simpl. reflexivity. rewrite H. rewrite <- e. reflexivity.
+Qed.
+ +
+Lemma nth_split_idR : forall (l0 l1 : list MPropF), l1 = snd (nth_split (length l0) (l0 ++ l1)).
+Proof.
+induction l0.
+- intros. simpl. reflexivity.
+- intros. simpl (length (a :: l0)). pose (IHl0 l1). rewrite e. destruct l0.
+  * simpl. reflexivity.
+  * simpl (length (m :: l0)). simpl (S (S (length l0))).
+    simpl (length (m :: l0)) in e. rewrite <- e.
+    assert ((S (S (length l0))) = (length (a :: m :: l0))). simpl. reflexivity.
+    rewrite H. rewrite nth_split_length. simpl. reflexivity.
+Qed.
+ +
+Lemma nth_split_length_id : forall (l0 l1 : list MPropF) n, (length l0 = n) ->
+                                (fst (nth_split n (l0 ++ l1)) = l0 /\
+                                snd (nth_split n (l0 ++ l1)) = l1).
+Proof.
+induction l0.
+- intros. simpl. split. simpl in H. subst. simpl. reflexivity. simpl in H. subst. simpl. reflexivity.
+- intros. simpl in H. subst. split.
+  * assert (J1:length l0 = length l0). reflexivity. pose (@IHl0 l1 (length l0) J1).
+    destruct a0. simpl. destruct l0. simpl. reflexivity. simpl. rewrite <- H.
+    simpl. reflexivity.
+  * assert (J1:length l0 = length l0). reflexivity. pose (@IHl0 l1 (length l0) J1).
+    destruct a0. rewrite <- H0. simpl ((a :: l0) ++ snd (nth_split (length l0) (l0 ++ l1))).
+    assert ((nth_split (S (length l0)) (a :: l0 ++ snd (nth_split (length l0) (l0 ++ l1))) =
+    (a :: l0 ,snd (nth_split (length l0) (l0 ++ l1))))).
+    pose (nth_split_length (a :: l0) (snd (nth_split (length l0) (l0 ++ l1)))). apply e.
+    rewrite H1. simpl. reflexivity.
+Qed.
+ +
+Lemma In_pos_top_imps_0_False : forall l (A : MPropF), In (A, 0) (pos_top_imps l) -> False.
+Proof.
+- induction l.
+  * intros. inversion H.
+  * intros. simpl in H. destruct a.
+    + simpl in H. apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+      destruct p. destruct x. inversion e.
+    + simpl in H. apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+      destruct p. destruct x. inversion e.
+    + simpl in H. destruct H. inversion H. apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+      destruct p. destruct x. inversion e.
+    + simpl in H. apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+      destruct p. destruct x. inversion e.
+Qed.
+ +
+Lemma In_pos_top_imps_imp : forall l (A : MPropF) n, In (A, n) (pos_top_imps l) -> (existsT2 C D, A = Imp C D).
+Proof.
+induction l ; intros.
+- simpl in H. inversion H.
+- simpl in H. destruct a ; try apply IHl in H. apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+  destruct p. inversion e. destruct x. subst. apply InT_In in i. apply IHl in i. assumption.
+  apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+  destruct p. inversion e. destruct x. subst. apply InT_In in i. apply IHl in i. assumption.
+  apply In_InT_pair in H. inversion H. subst. inversion H1. exists a1. exists a2. reflexivity.
+  subst. apply InT_map_iff in H1. destruct H1. destruct p. destruct x. simpl in e. inversion e.
+  subst. apply InT_In in i. apply IHl in i. assumption.
+  apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+  destruct p. inversion e. destruct x. subst. apply InT_In in i. apply IHl in i. assumption.
+Qed.
+ +
+Lemma In_pos_top_imps_In_l : forall l (A : MPropF) n, In (A, n) (pos_top_imps l) -> In A l.
+Proof.
+induction l.
+- intros. simpl in H. destruct H.
+- intros. simpl in H. destruct a.
+  * apply in_cons. apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+    destruct p. destruct x. inversion e. subst. apply InT_In in i. apply IHl in i.
+    assumption.
+  * apply in_cons. apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+    destruct p. destruct x. inversion e. subst. apply InT_In in i. apply IHl in i.
+    assumption.
+  * inversion H.
+    + inversion H0. subst. apply in_eq.
+    + apply in_cons. apply In_InT_pair in H0. apply InT_map_iff in H0. destruct H0.
+      destruct p. destruct x. inversion e. subst. apply InT_In in i. apply IHl in i.
+      assumption.
+  * apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+    destruct p. destruct x. inversion e. subst. apply InT_In in i. apply IHl in i.
+    apply in_cons. assumption.
+Qed.
+ +
+Lemma effective_remove_nth : forall A l0 l1, ((remove_nth (S (length l0)) A (l0 ++ A :: l1)) = l0 ++ l1).
+Proof.
+induction l0.
+- intros. simpl. destruct (eq_dec_form A A). reflexivity. exfalso. auto.
+- intros. simpl (S (length (a :: l0))). repeat rewrite <- app_assoc. simpl ((a :: l0) ++ A :: l1).
+  pose (IHl0 l1). simpl ((a :: l0) ++ l1). rewrite <- e. simpl. reflexivity.
+Qed.
+ +
+Definition In_pos_top_imps_split_l : forall l (A : MPropF) n, In (A, S n) (pos_top_imps l) ->
+          existsT2 l0 l1, (l = l0 ++ A :: l1) /\
+                          (length l0 = n) /\
+                          (l0 = fst (nth_split n (remove_nth (S n) A l))) /\
+                          (l1 = snd (nth_split n (remove_nth (S n) A l))).
+Proof.
+induction l.
+- intros. simpl. exfalso. simpl in H. destruct H.
+- intros. simpl in H. destruct a as [n0 | | | ].
+  * apply In_InT_pair in H. apply InT_map_iff in H. destruct H as ([m n1] & e & i).
+    simpl in e. inversion e. subst. destruct n. exfalso.
+    apply InT_In in i. apply In_pos_top_imps_0_False in i. assumption.
+    apply InT_In in i. pose (IHl A n i). destruct s as (x & x0 & e2 & e3 & e1 & e0).
+    subst. exists (# n0 :: x). exists x0. repeat split.
+    rewrite effective_remove_nth in e1. rewrite effective_remove_nth in e0.
+    assert (fst (# n0 :: fst (nth_split (S (length x)) (x ++ x0)), snd (nth_split (S (length x)) (x ++ x0))) =
+    # n0 :: fst (nth_split (S (length x)) (x ++ x0))). simpl. reflexivity.
+    assert (S (S (length x)) = S (length (# n0 :: x))). simpl. reflexivity.
+    rewrite H0. assert ((# n0 :: x ++ A :: x0) = ((# n0 :: x) ++ A :: x0)). simpl. reflexivity.
+    rewrite H1. clear H0. clear H1. rewrite effective_remove_nth.
+    pose (nth_split_idL (# n0 :: x) x0). simpl (length (# n0 :: x)) in e2.
+    rewrite <- e2. reflexivity.
+    rewrite effective_remove_nth in e0. rewrite effective_remove_nth in e1.
+    assert (S (S (length x)) = S (length (# n0 :: x))). simpl. reflexivity.
+    rewrite H. assert ((# n0 :: x ++ A :: x0) = ((# n0 :: x) ++ A :: x0)). simpl. reflexivity.
+    rewrite H0. clear H. clear H0. rewrite effective_remove_nth.
+    pose (nth_split_idR (# n0 :: x) x0). simpl (length (# n0 :: x)) in e2.
+    rewrite <- e2. reflexivity.
+  * apply In_InT_pair in H. apply InT_map_iff in H. destruct H as ([m n1] & e & i).
+    simpl in e. inversion e. subst. destruct n.
+    -- exfalso. apply InT_In in i. apply In_pos_top_imps_0_False in i. assumption.
+      -- apply InT_In in i. pose (IHl A n i). destruct s as (x & x0 & e2 & e3 & e1 & e0).
+      subst. exists (Bot :: x). exists x0. repeat split.
+      rewrite effective_remove_nth in e1. rewrite effective_remove_nth in e0.
+      assert (fst (Bot :: fst (nth_split (S (length x)) (x ++ x0)), snd (nth_split (S (length x)) (x ++ x0))) =
+      Bot :: fst (nth_split (S (length x)) (x ++ x0))). simpl. reflexivity.
+    assert (S (S (length x)) = S (length (Bot :: x))). simpl. reflexivity.
+    rewrite H0. assert ((Bot :: x ++ A :: x0) = ((Bot :: x) ++ A :: x0)). simpl. reflexivity.
+    rewrite H1. clear H0. clear H1. rewrite effective_remove_nth.
+    pose (nth_split_idL (Bot :: x) x0). simpl (length (Bot :: x)) in e2.
+    rewrite <- e2. reflexivity.
+    rewrite effective_remove_nth in e0. rewrite effective_remove_nth in e1.
+    assert (S (S (length x)) = S (length (Bot :: x))). simpl. reflexivity.
+    rewrite H. assert ((Bot :: x ++ A :: x0) = ((Bot :: x) ++ A :: x0)). simpl. reflexivity.
+    rewrite H0. clear H. clear H0. rewrite effective_remove_nth.
+    pose (nth_split_idR (Bot :: x) x0). simpl (length (Bot :: x)) in e2.
+    rewrite <- e2. reflexivity.
+  * apply In_InT_pair in H. inversion H.
+    + inversion H1. subst. exists []. exists l. repeat split. simpl.
+      destruct (eq_dec_form (a1 --> a2) (a1 --> a2)). reflexivity. exfalso. auto.
+    + subst. apply InT_map_iff in H1. destruct H1 as ([m n1] & e & i).
+        simpl in e. inversion e. subst. destruct n. exfalso.
+        apply InT_In in i. apply In_pos_top_imps_0_False in i. assumption.
+        apply InT_In in i. pose (IHl A n i). destruct s as (x & x0 & e2 & e3 & e1 & e0).
+        subst. exists (a1 --> a2 :: x). exists x0. repeat split.
+        rewrite effective_remove_nth in e1. rewrite effective_remove_nth in e0.
+        assert (fst (a1 --> a2 :: fst (nth_split (S (length x)) (x ++ x0)), snd (nth_split (S (length x)) (x ++ x0))) =
+        a1 --> a2 :: fst (nth_split (S (length x)) (x ++ x0))). simpl. reflexivity.
+        assert (S (S (length x)) = S (length (a1 --> a2 :: x))). simpl. reflexivity.
+        rewrite H1. assert ((a1 --> a2 :: x ++ A :: x0) = ((a1 --> a2 :: x) ++ A :: x0)). simpl. reflexivity.
+        rewrite H2. clear H2. clear H1. rewrite effective_remove_nth.
+        pose (nth_split_idL (a1 --> a2 :: x) x0). simpl (length (a1 --> a2 :: x)) in e2.
+        rewrite <- e2. reflexivity.
+        rewrite effective_remove_nth in e0. rewrite effective_remove_nth in e1.
+        assert (S (S (length x)) = S (length (a1 --> a2 :: x))). simpl. reflexivity.
+        rewrite H0. assert ((a1 --> a2 :: x ++ A :: x0) = ((a1 --> a2 :: x) ++ A :: x0)). simpl. reflexivity.
+        rewrite H1. clear H0. clear H1. rewrite effective_remove_nth.
+        pose (nth_split_idR (a1 --> a2 :: x) x0). simpl (length (a1 --> a2 :: x)) in e2.
+        rewrite <- e2. reflexivity.
+        * apply In_InT_pair in H. apply InT_map_iff in H. destruct H as ([m n1] & e & i).
+         simpl in e. inversion e. subst. destruct n. exfalso.
+        apply InT_In in i. apply In_pos_top_imps_0_False in i. assumption.
+        apply InT_In in i. pose (IHl A n i). destruct s as (x & x0 & e2 & e3 & e1 & e0).
+        subst. exists (Box a :: x). exists x0. repeat split.
+        rewrite effective_remove_nth in e1. rewrite effective_remove_nth in e0.
+        assert (fst (Box a :: fst (nth_split (S (length x)) (x ++ x0)), snd (nth_split (S (length x)) (x ++ x0))) =
+        Box a :: fst (nth_split (S (length x)) (x ++ x0))). simpl. reflexivity.
+        assert (S (S (length x)) = S (length (Box a :: x))). simpl. reflexivity.
+        rewrite H0. assert ((Box a :: x ++ A :: x0) = ((Box a :: x) ++ A :: x0)). simpl. reflexivity.
+        rewrite H1. clear H0. clear H1. rewrite effective_remove_nth.
+        pose (nth_split_idL (Box a :: x) x0). simpl (length (Box a :: x)) in e2.
+        rewrite <- e2. reflexivity.
+        rewrite effective_remove_nth in e0. rewrite effective_remove_nth in e1.
+        assert (S (S (length x)) = S (length (Box a :: x))). simpl. reflexivity.
+        rewrite H. assert ((Box a :: x ++ A :: x0) = ((Box a :: x) ++ A :: x0)). simpl. reflexivity.
+        rewrite H0. clear H. clear H0. rewrite effective_remove_nth.
+        pose (nth_split_idR (Box a :: x) x0). simpl (length (Box a :: x)) in e2.
+        rewrite <- e2. reflexivity.
+Defined.
+ +
+Lemma In_l_imp_In_pos_top_imps : forall l (A B : MPropF), In (Imp A B) l ->
+                                    existsT2 n, In ((Imp A B), n) (pos_top_imps l).
+Proof.
+induction l.
+- intros. simpl in H. destruct H.
+- intros. apply In_InT in H. inversion H.
+  * subst. exists 1. simpl. left. reflexivity.
+  * destruct a.
+    + subst. apply InT_In in H1. apply IHl in H1. destruct H1. exists (S x). simpl.
+      apply InT_In. apply InT_map_iff. exists (A --> B, x). simpl. split ; auto.
+      apply In_InT_pair. assumption.
+    + subst. apply InT_In in H1. apply IHl in H1. destruct H1. exists (S x). simpl.
+      apply InT_In. apply InT_map_iff. exists (A --> B, x). simpl. split ; auto.
+      apply In_InT_pair. assumption.
+    + subst. apply InT_In in H1. apply IHl in H1. destruct H1. exists (S x). simpl.
+      right. apply InT_In. apply InT_map_iff. exists (A --> B, x). simpl. split ; auto.
+      apply In_InT_pair. assumption.
+    + subst. apply InT_In in H1. apply IHl in H1. destruct H1. exists (S x). simpl.
+      apply InT_In. apply InT_map_iff. exists (A --> B, x). simpl. split ; auto.
+      apply In_InT_pair. assumption.
+Qed.
+ +
+Lemma Good_pos_in_pos_top_imps : forall A B Δ0 Δ1,
+              In (A --> B, S (length Δ0)) (pos_top_imps (Δ0 ++ A --> B :: Δ1)).
+Proof.
+induction Δ0.
+- intros. simpl. auto.
+- intros. destruct a.
+  * simpl. apply InT_In. apply InT_map_iff. exists (A --> B, S (length Δ0)).
+    split. simpl. reflexivity. apply In_InT_pair. apply IHΔ0.
+  * simpl. apply InT_In. apply InT_map_iff. exists (A --> B, S (length Δ0)).
+    split. simpl. reflexivity. apply In_InT_pair. apply IHΔ0.
+  * simpl. right. apply InT_In. apply InT_map_iff. exists (A --> B, S (length Δ0)).
+    split. simpl. reflexivity. apply In_InT_pair. apply IHΔ0.
+  * simpl. apply InT_In. apply InT_map_iff. exists (A --> B, S (length Δ0)).
+    split. simpl. reflexivity. apply In_InT_pair. apply IHΔ0.
+Qed.
+ +
+(* From there we can show that given a specific (Imp A B) on the right of a sequent S,
+   there is only finitely many premises via ImpR applied on this implication. But we
+   need to do it for all implications on the right of this sequent. *)

+ +
+Definition ImpR_help01 : forall prem s l, InT prem (prems_Imp_R l s) ->
+                  (existsT2 n A B Γ0 Γ1 Δ0 Δ1,
+                        (In ((Imp A B), S n) l) /\
+                        (prem = (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)) /\
+                        (Γ0 ++ Γ1 = fst s) /\
+                        (Δ0 = (fst (nth_split n (remove_nth (S n) (Imp A B) (snd s))))) /\
+                        (Δ1 = (snd (nth_split n (remove_nth (S n) (Imp A B) (snd s)))))).
+Proof.
+intros prem s. destruct s. destruct prem. induction l3 ; intros X.
+- simpl in X. inversion X.
+- destruct a as [m n]. destruct m as [m | | | ].
+  * simpl in X. destruct n.
+    + pose (IHl3 X). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p).
+        decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try auto. apply in_cons. tauto.
+    + pose (IHl3 X). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p). decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try tauto. apply in_cons. tauto.
+  * simpl in X. destruct n.
+    + pose (IHl3 X). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p). decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try tauto. apply in_cons. tauto.
+    + pose (IHl3 X). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p). decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try tauto. apply in_cons. tauto.
+  * destruct n.
+    + pose (IHl3 X). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p). decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try tauto. apply in_cons. tauto.
+    + apply InT_app_or in X. destruct X.
+      { simpl (fst (l, l0)) in i. simpl (snd (l, l0)) in i.
+        unfold listInsertsR_Seqs in i. apply InT_map_iff in i. destruct i.
+        destruct p. subst. unfold listInserts in i. apply InT_map_iff in i. destruct i.
+        destruct p. destruct x0. subst. destruct (list_of_splits l). simpl in i. exists n.
+        exists m1. exists m2. exists l4. exists l5. simpl (snd (l, l0)).
+        simpl (fst (l, l0)).
+        exists (fst (nth_split n (remove_nth (S n) (m1 --> m2) l0))).
+        exists (snd (nth_split n (remove_nth (S n) (m1 --> m2) l0))).
+        repeat split ; try auto. apply in_eq. rewrite i0. apply InT_In. assumption. }
+      { pose (IHl3 i). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p). decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try tauto. apply in_cons. tauto. }
+  * simpl in X. destruct n.
+    + pose (IHl3 X). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p). decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try tauto. apply in_cons. tauto.
+    + pose (IHl3 X). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p). decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try tauto. apply in_cons. tauto.
+Defined.
+ +
+Definition ImpR_help1 : forall prem s, InT prem (prems_Imp_R (pos_top_imps (snd s)) s) -> ImpRRule [prem] s.
+Proof.
+intros prem s X. pose (ImpR_help01 _ _ X). destruct s0. destruct s.
+destruct s0. destruct s as (B & Γ0 & Γ1 & Δ0 & Δ1 & i & e2 & e3 & e4 & e5).
+subst. simpl in i, e3. subst.
+simpl (snd (_, _)) in *.
+apply In_pos_top_imps_split_l in i. destruct i. destruct s as (x2 & H1 & H2 & H3 & H4).
+subst.
+rewrite <- H4. rewrite effective_remove_nth. rewrite <- nth_split_idL.
+apply ImpRRule_I.
+Defined.
+ +
+Definition ImpR_help002 : forall Γ0 Γ1 Δ0 Δ1 A B,
+           InT (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) (listInsertsR_Seqs (Γ0 ++ Γ1) (Δ0 ++ B :: Δ1) A).
+Proof.
+intros. unfold listInsertsR_Seqs. apply InT_map_iff. exists (Γ0 ++ A :: Γ1). split.
+reflexivity. unfold listInserts. apply InT_map_iff. exists (Γ0, Γ1). simpl. split.
+reflexivity. destruct (list_of_splits (Γ0 ++ Γ1)). simpl. pose (i Γ0 Γ1).
+apply In_InT_seqs. apply i0. reflexivity.
+Defined.
+ +
+Definition ImpR_help02 : forall Γ0 Γ1 Δ0 Δ1 A B l n,
+                                ImpRRule [(Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)] (Γ0 ++ Γ1, Δ0 ++ (Imp A B) :: Δ1) ->
+                                (length Δ0 = n) ->
+                                (In ((Imp A B), S n) l) ->
+                                InT (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) (prems_Imp_R l (Γ0 ++ Γ1, Δ0 ++ (Imp A B) :: Δ1)).
+Proof.
+induction l ; intros.
+- inversion H1.
+- destruct a. destruct m.
+  * apply In_InT_pair in H1. inversion H1. subst. inversion H3. subst. apply InT_In in H3.
+    assert (J1: length Δ0 = length Δ0). reflexivity.
+    pose (IHl _ H J1 H3). simpl. destruct n0. assumption. assumption.
+  * apply In_InT_pair in H1. inversion H1. subst. inversion H3. subst. apply InT_In in H3.
+    assert (J1: length Δ0 = length Δ0). reflexivity.
+    pose (IHl _ H J1 H3). simpl. destruct n0. assumption. assumption.
+  * apply In_InT_pair in H1. inversion H1.
+    + subst. inversion H3. subst. destruct Δ0.
+      { simpl. pose (ImpR_help002 Γ0 Γ1 [] Δ1 A B). simpl in i. destruct (eq_dec_form (A --> B) (A --> B)).
+        apply InT_or_app. auto. exfalso. auto. }
+      { unfold prems_Imp_R. apply InT_or_app. left.
+        assert ((remove_nth (S (length (m :: Δ0))) (A --> B) (snd (Γ0 ++ Γ1, (m :: Δ0) ++ A --> B :: Δ1))) =
+        (m :: Δ0) ++ Δ1). simpl (snd (Γ0 ++ Γ1, (m :: Δ0) ++ A --> B :: Δ1)).
+        pose (effective_remove_nth (A --> B) (m :: Δ0) Δ1). assumption.
+        rewrite H0.
+        assert (fst (nth_split (length (m :: Δ0)) ((m :: Δ0) ++ Δ1)) = (m :: Δ0) /\
+        snd (nth_split (length (m :: Δ0)) ((m :: Δ0) ++ Δ1)) = Δ1). apply nth_split_length_id.
+        reflexivity. destruct H2. rewrite H2. rewrite H4. apply ImpR_help002. }
+    + subst. assert (J1: (length Δ0) = (length Δ0)). reflexivity. apply InT_In in H3.
+      pose (IHl (length Δ0) H J1 H3). simpl. destruct n0. assumption. apply InT_or_app. auto.
+  * apply In_InT_pair in H1. inversion H1. subst. inversion H3. subst. apply InT_In in H3.
+    assert (J1: length Δ0 = length Δ0). reflexivity.
+    pose (IHl _ H J1 H3). simpl. destruct n0. assumption. assumption.
+Defined.
+ +
+Definition ImpR_help2 : forall prem s, ImpRRule [prem] s -> InT prem (prems_Imp_R (pos_top_imps (snd s)) s).
+Proof.
+intros. inversion H. subst. simpl.
+pose (@ImpR_help02 Γ0 Γ1 Δ0 Δ1 A B (pos_top_imps (Δ0 ++ A --> B :: Δ1)) (length Δ0)). apply i ; try assumption.
+reflexivity. apply Good_pos_in_pos_top_imps.
+Defined.
+ +
+Definition finite_ImpR_premises_of_S : forall (s : Seq), existsT2 listImpRprems,
+              (forall prems, ((ImpRRule prems s) -> (InT prems listImpRprems)) *
+                             ((InT prems listImpRprems) -> (ImpRRule prems s))).
+Proof.
+intro s. destruct s.
+exists (map (fun y => [y]) (prems_Imp_R (pos_top_imps l0) (l,l0))).
+intros. split ; intro.
+- inversion H. subst. apply InT_map_iff.
+  exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1). split. reflexivity.
+  pose (@ImpR_help2 (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)). simpl in i. apply i.
+  assumption.
+- apply InT_map_iff in H. destruct H. destruct p. subst. apply ImpR_help1. simpl. assumption.
+Defined.
+ +
+(* Then, we turn to the case of the ImpL rule. *)
+ +
+Fixpoint prems_Imp_L (l : list ((MPropF) * nat)) (s : Seq) : list (list Seq) :=
+match l with
+  | nil => nil
+  | (C, n) :: t => match n with
+      | 0 => prems_Imp_L t s
+      | S m => match C with
+           | Imp A B => flatten_list
+                        (map (fun y => map (fun z => [z; y])
+                        (listInsertsL_Seqs ((fst (nth_split m (remove_nth (S m) C (fst s)))) ++
+                        (snd (nth_split m (remove_nth (S m) C (fst s))))) (snd s) A))
+                        [(((fst (nth_split m (remove_nth (S m) C (fst s)))) ++
+                        B :: (snd (nth_split m (remove_nth (S m) C (fst s))))), (snd s))])
+                        ++ (prems_Imp_L t s)
+           | _ => prems_Imp_L t s
+           end
+      end
+end.
+ +
+Definition ImpL_help002 : forall Γ0 Γ1 Δ0 Δ1 A B,
+           InT [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]
+               (flatten_list (map (fun y : list MPropF * list MPropF => map
+               (fun z : list MPropF * list MPropF => [y; z]) [(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+               (listInsertsL_Seqs (Γ0 ++ Γ1) (Δ0 ++ Δ1) A)))
+              .
+Proof.
+intros.
+pose (@InT_trans_flatten_list _ (map (fun y : list MPropF * list MPropF => map
+(fun z : list MPropF * list MPropF => [y; z]) [(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+(listInsertsL_Seqs (Γ0 ++ Γ1) (Δ0 ++ Δ1) A))
+(map (fun z : list MPropF * list MPropF => [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); z])
+[(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]) [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]).
+apply i ; clear i.
+- pose (InT_map_iff (fun z : list MPropF * list MPropF => [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); z]) [(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]
+  [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]).
+  destruct p. clear s. apply i. exists (Γ0 ++ B :: Γ1, Δ0 ++ Δ1). split. reflexivity. apply InT_eq.
+- pose (InT_map_iff (fun y : list MPropF * list MPropF =>
+  map (fun z : list MPropF * list MPropF => [y; z]) [(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+  (listInsertsL_Seqs (Γ0 ++ Γ1) (Δ0 ++ Δ1) A) (map (fun z : list MPropF * list MPropF => [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); z])
+  [(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])).
+  destruct p. apply i. clear i. clear s. exists (Γ0 ++ Γ1, Δ0 ++ A :: Δ1). split. reflexivity.
+  unfold listInsertsL_Seqs.
+  pose (InT_map_iff (fun y : list MPropF => (Γ0 ++ Γ1, y)) (listInserts (Δ0 ++ Δ1) A) (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)).
+  destruct p. apply i. clear s. clear i. exists (Δ0 ++ A :: Δ1). split. reflexivity.
+  unfold listInserts.
+  pose (InT_map_iff (fun y : list MPropF * list MPropF => fst y ++ A :: snd y)
+  (proj1_sigT2 (list_of_splits (Δ0 ++ Δ1))) (Δ0 ++ A :: Δ1)). destruct p. clear s.
+  apply i. clear i. exists (Δ0,Δ1). simpl. split. reflexivity. destruct (list_of_splits (Δ0 ++ Δ1)).
+  simpl. pose (i Δ0 Δ1). apply In_InT_seqs. rewrite <- i0. reflexivity.
+Defined.
+ +
+Definition ImpL_help02 : forall Γ0 Γ1 Δ0 Δ1 A B l n,
+            ImpLRule [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)] (Γ0 ++ (Imp A B) :: Γ1, Δ0 ++ Δ1) ->
+            (length Γ0 = n) ->
+            (In ((Imp A B), S n) l) ->
+            InT [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)] (prems_Imp_L l (Γ0 ++ (Imp A B) :: Γ1, Δ0 ++ Δ1)).
+Proof.
+induction l ; intros.
+- inversion H1.
+- destruct a. destruct m.
+  * subst. apply In_InT_pair in H1. inversion H1. subst. inversion H2. subst. apply InT_In in H2.
+    assert (J1: length Γ0 = length Γ0). reflexivity.
+    pose (IHl _ H J1 H2). simpl. destruct n0. assumption. assumption.
+  * subst. apply In_InT_pair in H1. inversion H1. subst. inversion H2. subst. apply InT_In in H2.
+    assert (J1: length Γ0 = length Γ0). reflexivity.
+    pose (IHl _ H J1 H2). simpl. destruct n0. assumption. assumption.
+  * apply In_InT_pair in H1. inversion H1.
+    + subst. inversion H3. subst.
+      pose (ImpL_help002 Γ0 Γ1 Δ0 Δ1 A B). simpl in i.
+      apply InT_or_app. left.
+      apply InT_trans_flatten_list with (bs:=(flatten_list
+      (map (fun y : list MPropF * list MPropF => [[y; (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]])
+         (listInsertsL_Seqs (Γ0 ++ Γ1) (Δ0 ++ Δ1) A)))). assumption. apply InT_map_iff.
+      exists (Γ0 ++ B :: Γ1, Δ0 ++ Δ1). split.
+      destruct (eq_dec_form (A --> B) (A --> B)).
+      apply InT_flatten_list_InT_elem in i. destruct i. destruct p.
+      assert ((listInsertsL_Seqs (fst
+      (nth_split (length Γ0) (remove_nth (S (length Γ0)) (A --> B) (fst (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)))) ++
+      snd
+      (nth_split (length Γ0) (remove_nth (S (length Γ0)) (A --> B) (fst (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)))))
+      (snd (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)) A) = (listInsertsL_Seqs (Γ0 ++ Γ1) (Δ0 ++ Δ1) A)).
+      simpl (snd (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+      simpl (fst (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)). repeat rewrite effective_remove_nth.
+      assert (length Γ0 = length Γ0). reflexivity.
+      pose (@nth_split_length_id Γ0 Γ1 (length Γ0) H0). destruct a. rewrite H2. rewrite H4.
+      reflexivity. rewrite H0.
+      apply redundant_flatten_list. exfalso. auto.
+      destruct (eq_dec_form (A --> B) (A --> B)). simpl (snd (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+      simpl (fst (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)). repeat rewrite effective_remove_nth.
+      assert (length Γ0 = length Γ0). reflexivity.
+      pose (@nth_split_length_id Γ0 Γ1 (length Γ0) H0). destruct a. rewrite H2. rewrite H4.
+      apply InT_eq. exfalso. auto.
+    + subst. assert (J1: (length Γ0) = (length Γ0)). reflexivity. apply InT_In in H3.
+      pose (IHl (length Γ0) H J1 H3). simpl. destruct n0. assumption. apply InT_or_app. auto.
+  * subst. apply In_InT_pair in H1. inversion H1. subst. inversion H2. subst. apply InT_In in H2.
+    assert (J1: length Γ0 = length Γ0). reflexivity.
+    pose (IHl _ H J1 H2). simpl. destruct n0. assumption. assumption.
+Defined.
+ +
+Definition ImpL_help2 : forall prem1 prem2 s, ImpLRule [prem1; prem2] s ->
+                      InT [prem1; prem2] (prems_Imp_L (pos_top_imps (fst s)) s).
+Proof.
+intros. inversion H. subst. simpl.
+pose (@ImpL_help02 Γ0 Γ1 Δ0 Δ1 A B (pos_top_imps (Γ0 ++ (Imp A B) :: Γ1)) (length Γ0)). apply i ; try assumption.
+reflexivity. apply Good_pos_in_pos_top_imps.
+Defined.
+ +
+Definition ImpL_help01 : forall prems s l, InT prems (prems_Imp_L l s) ->
+                  (existsT2 n prem1 prem2 A B Γ0 Γ1 Δ0 Δ1,
+                        (prems = [prem1; prem2]) /\
+                        (In ((Imp A B), S n) l) /\
+                        (prem1 = (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)) /\
+                        (prem2 = (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) /\
+                        (Δ0 ++ Δ1 = snd s) /\
+                        (Γ0 = (fst (nth_split n (remove_nth (S n) (Imp A B) (fst s))))) /\
+                        (Γ1 = (snd (nth_split n (remove_nth (S n) (Imp A B) (fst s)))))).
+Proof.
+intros prems s. destruct s. induction l1 ; intros X.
+- simpl in X. inversion X.
+- simpl (fst (l, l0)). destruct a as [m n]. destruct m as [n0 | | | ].
+  * simpl in X. destruct n.
+    + pose (s := IHl1 X). repeat destruct s. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+      repeat split ; try tauto. apply in_cons. tauto.
+    + pose (s := IHl1 X). repeat destruct s. repeat destruct p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+      repeat split ; try tauto. apply in_cons. tauto.
+  * simpl in X. destruct n.
+    + pose (s := IHl1 X). repeat destruct s. repeat destruct p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+      repeat split ; try tauto. apply in_cons. tauto.
+    + pose (s := IHl1 X). repeat destruct s. repeat destruct p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+      repeat split ; try tauto. apply in_cons. tauto.
+  * destruct n.
+    + pose (s := IHl1 X). repeat destruct s. repeat destruct p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+      repeat split ; try tauto. apply in_cons. tauto.
+    + apply InT_app_or in X. destruct X.
+      { simpl (fst (l, l0)) in i. simpl (snd (l, l0)) in i.
+        apply InT_flatten_list_InT_elem in i. destruct i. destruct p.
+        apply InT_map_iff in i0. destruct i0. destruct p.
+        inversion i0. subst. apply InT_map_iff in i. destruct i.
+        destruct p. unfold listInsertsL_Seqs in i. apply InT_map_iff in i.
+        destruct i. destruct p. subst. unfold listInserts in i. apply InT_map_iff in i. destruct i.
+        destruct p. destruct x. subst. destruct (list_of_splits l0). simpl in i. exists n.
+        simpl (fst (l2, l3)). simpl (snd (l2, l3)).
+        exists (fst (nth_split n (remove_nth (S n) (m1 --> m2) l)) ++
+        snd (nth_split n (remove_nth (S n) (m1 --> m2) l)), l2 ++ m1 :: l3).
+        exists (fst
+          (nth_split n
+             match n with
+             | 0 =>
+                 match l with
+                 | [] => []
+                 | B0 :: tl => if eq_dec_form (m1 --> m2) B0 then tl else B0 :: tl
+                 end
+             | S _ => match l with
+                      | [] => []
+                      | B0 :: tl => B0 :: remove_nth n (m1 --> m2) tl
+                      end
+             end) ++
+        m2
+        :: snd
+             (nth_split n
+                match n with
+                | 0 =>
+                    match l with
+                    | [] => []
+                    | B0 :: tl => if eq_dec_form (m1 --> m2) B0 then tl else B0 :: tl
+                    end
+                | S _ => match l with
+                         | [] => []
+                         | B0 :: tl => B0 :: remove_nth n (m1 --> m2) tl
+                         end
+                end), l0).
+        exists m1. exists m2. exists (fst (nth_split n (remove_nth (S n) (m1 --> m2) l))).
+        exists (snd (nth_split n (remove_nth (S n) (m1 --> m2) l))).
+        exists l2. exists l3. simpl (snd (l, l0)). simpl (fst (l, l0)).
+        repeat split ; try auto. apply in_eq. simpl. assert (l2 ++ l3 = l0). rewrite i1. apply InT_In.
+        assumption. rewrite <- H. reflexivity. rewrite i1. apply InT_In. assumption. subst. inversion H0. }
+      { pose (IHl1 i). repeat destruct s. repeat destruct p. exists x. exists x0. exists x1.
+        exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+        repeat split ; try tauto. apply in_cons. tauto. }
+  * simpl in X. destruct n.
+    + pose (IHl1 X). repeat destruct s. repeat destruct p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+      repeat split ; try tauto. apply in_cons. tauto.
+    + pose (IHl1 X). repeat destruct s. repeat destruct p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+      repeat split ; try tauto. apply in_cons. tauto.
+Defined.
+ +
+Definition ImpL_help1 : forall prems s, InT prems (prems_Imp_L (pos_top_imps (fst s)) s) ->
+                                         ImpLRule prems s.
+Proof.
+intros prem s X. pose (s0 := @ImpL_help01 _ _ _ X). destruct s0 as (n&Hn&A&B&Γ0&Γ1&Δ0& Δ1&e1&Heq&i&p). destruct s as (l&l0). simpl in X.
+intuition. subst.
+apply In_pos_top_imps_split_l in i.
+simpl (fst (l, l0)). simpl in H0. subst.
simpl (fst (l, Δ1 ++ e1)) in X.
+destruct i as (l0&l1&Heq1&Heq3&Heq2&Heq4).
+subst.
+simpl (fst (l, Δ1 ++ e1)) in Heq1.
+simpl (fst (l, Δ1 ++ e1)) in Heq2.
+remember (fst (nth_split (length l0) (remove_nth (S (length l0)) (B --> Γ0) l))) as Γ0'.
+remember (snd (nth_split (length l0) (remove_nth (S (length l0)) (B --> Γ0) l))) as Γ1'.
+rewrite Heq1, Heq2.
+apply ImpLRule_I.
+Defined.
+ +
+Definition finite_ImpL_premises_of_S : forall (s : Seq), existsT2 listImpLprems,
+              (forall prems, ((ImpLRule prems s) -> (InT prems listImpLprems)) *
+                             ((InT prems listImpLprems) -> (ImpLRule prems s))).
+Proof.
+intros. destruct s.
+exists (prems_Imp_L (pos_top_imps l) (l,l0)).
+intros. split ; intro.
+- inversion H. subst.
+  pose (@ImpL_help2 (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)). apply i.
+  assumption.
+- pose (@ImpL_help1 prems (l, l0)). apply i. assumption.
+Defined.
+ +
+(* Now let us tackle the GLR rule. *)
+ +
+Fixpoint prems_Box_R (l : list MPropF) (s : Seq) : list (list Seq) :=
+match l with
+  | nil => nil
+  | h :: t => match h with
+              | Box A => [((XBoxed_list (top_boxes (fst s))) ++ [Box A], [A])] :: (prems_Box_R t s)
+              | _ => prems_Box_R t s
+              end
+end.
+ +
Definition GLR_help01 : forall prems s (l : list MPropF), InT prems (prems_Box_R l s) ->
+                  (existsT2 (A : MPropF),
+                        (In (Box A) l) /\
+                        (prems = [(XBoxed_list (top_boxes (fst s)) ++ [Box A], [A])])).
+Proof.
+intros prems s. destruct s. induction l1 ; intros X.
+- simpl in X. inversion X.
+- simpl in X. destruct a.
+  * apply IHl1 in X. destruct X as (x & i & p). subst.
+     exists x. repeat split ; try auto ; try apply in_cons ; try assumption.
+  * apply IHl1 in X. destruct X as (x & i & p). subst.
+     exists x. repeat split ; try auto ; try apply in_cons ; try assumption.
+  * apply IHl1 in X. destruct X as (x & i & p). subst.
+     exists x. repeat split ; try auto ; try apply in_cons ; try assumption.
+  * inversion X.
+    + subst. eexists a. repeat split ; try auto ; try apply in_eq.
+    + apply IHl1 in H0. decompose record H0. subst.
+        exists x. repeat split ; try auto ; try apply in_cons ; try assumption.
+Defined.
+ +
+Definition GLR_help1 : forall prems s, InT prems (prems_Box_R (top_boxes (snd s)) s) ->
+                                         GLRRule prems s.
+Proof.
+intros prems s X. destruct (@GLR_help01 _ _ _ X) as (x&i&Heq). destruct s. simpl in X.
+subst. simpl in i. assert (In (Box x) l0). apply top_boxes_incl_list.
+assumption. apply in_splitT in H. destruct H. repeat destruct s.
+rewrite e. apply GLRRule_I. intro. intros. apply in_top_boxes in H.
+destruct H. repeat destruct s. repeat destruct p. exists x2. assumption.
+simpl. apply top_boxes_nobox_gen_ext.
+Defined.
+ +
+Definition GLR_help02 : forall Γ Δ0 Δ1 A l, GLRRule [(XBoxed_list ++ [Box A], [A])] (Γ, Δ0 ++ Box A :: Δ1) ->
+                                             (is_Boxed_list ) ->
+                                             (nobox_gen_ext Γ) ->
+                                             (In (Box A) l) ->
+                                             InT [(XBoxed_list ++ [Box A], [A])] (prems_Box_R l (Γ, Δ0 ++ Box A :: Δ1)).
+Proof.
+induction l ; intros.
+- inversion H0.
+- simpl. destruct a as [n | | | ].
+  * assert (InT (Box A) (# n :: l)). apply in_splitT in H0. destruct H0. destruct s. rewrite e.
+    apply InT_or_app. right. apply InT_eq. inversion H1. inversion H3. apply InT_In in H3.
+    pose (IHl X H X0 H3). assumption.
+  * assert (InT (Box A) ( :: l)). apply in_splitT in H0. destruct H0. destruct s. rewrite e.
+    apply InT_or_app. right. apply InT_eq. inversion H1. inversion H3. apply InT_In in H3.
+    pose (IHl X H X0 H3). assumption.
+  * assert (InT (Box A) (a1 --> a2 :: l)). apply in_splitT in H0. destruct H0. destruct s. rewrite e.
+    apply InT_or_app. right. apply InT_eq. inversion H1. inversion H3. apply InT_In in H3.
+    pose (IHl X H X0 H3). assumption.
+  * assert (InT (Box A) (Box a :: l)). apply in_splitT in H0. destruct H0. destruct s. rewrite e.
+    apply InT_or_app. right. apply InT_eq. inversion H1.
+    + subst. inversion H3. subst. pose (nobox_gen_ext_top_boxes_identity X0 H). rewrite e.
+      apply InT_eq.
+    + subst. apply InT_In in H3. pose (IHl X H X0 H3). apply InT_cons. assumption.
+Defined.
+ +
+Definition GLR_help2 : forall prem s, GLRRule [prem] s ->
+                      InT [prem] (prems_Box_R (top_boxes (snd s)) s).
+Proof.
+intros. inversion X. subst. simpl.
+pose (@GLR_help02 Γ0 Δ0 Δ1 A (top_boxes (Δ0 ++ Box A :: Δ1))). apply i ; try assumption.
+rewrite top_boxes_distr_app. simpl. apply in_or_app. right. apply in_eq.
+Defined.
+ +
+Definition finite_GLR_premises_of_S : forall (s : Seq), existsT2 listGLRprems,
+              (forall prems, ((GLRRule prems s) -> (InT prems listGLRprems)) *
+                             ((InT prems listGLRprems) -> (GLRRule prems s))).
+Proof.
+intros. destruct s.
+exists (prems_Box_R (top_boxes l0) (l,l0)).
+intros. split ; intro.
+- inversion X. subst.
+  pose (@GLR_help2 (XBoxed_list ++ [Box A], [A]) (l, Δ0 ++ Box A :: Δ1)). apply i.
+  assumption.
+- pose (@GLR_help1 prems (l, l0)). apply g. assumption.
+Defined.
+ +
+(* Obviously, we can obtain the same result for the initial sequents. *)
+ +
+Definition finite_IdP_premises_of_S : forall (s : Seq), existsT2 listIdPprems,
+              (forall prems, ((IdPRule prems s) -> (InT prems listIdPprems)) *
+                             ((InT prems listIdPprems) -> (IdPRule prems s))).
+Proof.
+intros s. destruct (dec_IdP_rule s).
+- exists [[]]. intros. split ; intro.
+  * inversion H. subst. apply InT_eq.
+  * inversion H. subst. assumption. inversion H1.
+- exists []. intros. split ; intro.
+  * inversion H. subst. exfalso. apply f. assumption.
+  * inversion H.
+Defined.
+ +
+Definition finite_IdB_premises_of_S : forall (s : Seq), existsT2 listIdBprems,
+              (forall prems, ((IdBRule prems s) -> (InT prems listIdBprems)) *
+                             ((InT prems listIdBprems) -> (IdBRule prems s))).
+Proof.
+intros s. destruct (dec_IdB_rule s).
+- exists [[]]. intros. split ; intro.
+  * inversion H. subst. apply InT_eq.
+  * inversion H. subst. assumption. inversion H1.
+- exists []. intros. split ; intro.
+  * inversion H. subst. exfalso. apply f. assumption.
+  * inversion H.
+Defined.
+ +
+Definition finite_BotL_premises_of_S : forall (s : Seq), existsT2 listBotLprems,
+              (forall prems, ((BotLRule prems s) -> (InT prems listBotLprems)) *
+                             ((InT prems listBotLprems) -> (BotLRule prems s))).
+Proof.
+intros. destruct (dec_BotL_rule s).
+- exists [[]]. intros. split ; intro.
+  * inversion H. subst. apply InT_eq.
+  * inversion H. subst. assumption. inversion H1.
+- exists []. intros. split ; intro.
+  * inversion H. subst. exfalso. apply f. assumption.
+  * inversion H.
+Defined.
+ +
+(* Now that we have the list of all premises of a sequent via all rules, we can combine
+   them all to obtain the list of all potential premises via the GLS calculus. *)

+ +
+Definition finite_premises_of_S : forall (s : Seq), existsT2 listprems,
+              (forall prems, ((GLS_rules prems s) -> (InT prems listprems)) *
+                             ((InT prems listprems) -> (GLS_rules prems s))).
+Proof.
+intro s.
+destruct (dec_GLS_rules s).
+- exists []. intros. split. intro. exfalso. apply f. exists prems. assumption.
+  intro. inversion H.
+- pose (finite_IdP_premises_of_S s). destruct s1.
+  pose (finite_BotL_premises_of_S s). destruct s1.
+  pose (finite_ImpR_premises_of_S s). destruct s1.
+  pose (finite_ImpL_premises_of_S s). destruct s1.
+  pose (finite_GLR_premises_of_S s). destruct s1.
+  exists (x ++ x0 ++ x1 ++ x2 ++ x3).
+  split.
+  * intro RA. inversion RA.
+    { inversion H. subst. pose (p []). destruct p4. apply InT_or_app. auto. }
+    { inversion H. subst. pose (p0 []). destruct p4. apply InT_or_app. right. apply InT_or_app. auto. }
+    { inversion H. subst. pose (p1 [(Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)]). destruct p4.
+      apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. auto. }
+    { inversion H. subst. pose (p2 [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]).
+      destruct p4. apply InT_or_app. right. apply InT_or_app. right.
+      apply InT_or_app. right. apply InT_or_app. auto. }
+    { inversion X. subst. pose (p3 [(XBoxed_list ++ [Box A], [A])]).
+      destruct p4. apply InT_or_app. right. apply InT_or_app.
+      right. apply InT_or_app. right. apply InT_or_app. right. auto. }
+  * intro. apply InT_app_or in H. destruct H.
+    { apply p in i. apply IdP ; try intro ; try apply f ; try auto ; try assumption. }
+    { apply InT_app_or in i. destruct i.
+      - apply p0 in i. apply BotL ; try intro ; try apply f ; try auto ; try assumption.
+      - apply InT_app_or in i. destruct i.
+        + apply p1 in i. apply ImpR ; try intro ; try apply f ; try auto ; try assumption.
+        + apply InT_app_or in i. destruct i.
+          * apply p2 in i. apply ImpL ; try intro ; try apply f ; try auto ; try assumption.
+          * apply p3 in i. apply GLR ; try intro ; try apply f ; try auto ; try assumption. }
+        Defined.
+ +
+(* The next definitions "flattens" a list of lists of premises to a list of premises.*)
+ +
+Definition list_of_premises (s : Seq) : list Seq :=
+         flatten_list (proj1_sigT2 (finite_premises_of_S s)).
+ +
+Lemma InT_list_of_premises_exists_prems : forall s prem, InT prem (list_of_premises s) ->
+            existsT2 prems, (InT prem prems) * (GLS_rules prems s).
+Proof.
+intros s prem X. unfold list_of_premises in X.
+apply InT_flatten_list_InT_elem in X. destruct X. destruct p.
+exists x. split. auto.
+destruct (finite_premises_of_S s). pose (p x). destruct p0. apply g. assumption.
+Qed.
+ +
+Lemma exists_prems_InT_list_of_premises : forall s prem,
+            (existsT2 prems, (InT prem prems) * (GLS_rules prems s)) ->
+            InT prem (list_of_premises s).
+Proof.
+intros. destruct X. destruct p. unfold list_of_premises. destruct (finite_premises_of_S s).
+pose (p x). destruct p0. apply InT_trans_flatten_list with (bs:=x). assumption. simpl. apply i0.
+assumption.
+Qed.
+ +
+(* Decidability *)
+ +
+Lemma derrec_composition: forall X (rules : list X -> X -> Type) (prems0 prems1 : X -> Prop) (concl : X),
+     (forall leaf : X, prems0 leaf -> (derrec rules prems1 leaf)) ->
+     (derrec rules prems0 concl) ->
+     (derrec rules prems1 concl).
+Proof.
+intros X rules prems0 prems1 concl HypLeaves der. apply derrec_all_rect with
+(Q:= fun x => (derrec rules prems1 x))
+in der.
+- exact der.
+- intros. apply HypLeaves. assumption.
+- intros ps concl0 RA ders IH. apply dersrec_all in IH. apply derI with (ps:=ps) ; assumption.
+Qed.
+ +
+Theorem derrec_leaves_thms : forall (s0 s1 : rel (list MPropF)),
+        (derrec GLS_rules (fun x => (x = s0)) s1) ->
+        (derrec GLS_rules (fun _ => False) s0) ->
+        (derrec GLS_rules (fun _ => False) s1).
+Proof.
+intros s0 s1 leaves pfs.
+pose (@derrec_composition (rel (list MPropF)) GLS_rules (fun x => (x = s0)) (fun _ => False)
+s1). apply d.
+- intros. inversion H. assumption.
+- assumption.
+Qed.
+ +
+Theorem GLS_dec_der : forall s,
+  (derrec GLS_rules (fun _ => False) s) + ((derrec GLS_rules (fun _ => False) s) -> False).
+Proof.
+apply less_thanS_strong_inductionT.
+intros s IH. pose (finite_premises_of_S s). destruct s0.
+destruct (dec_init_rules s).
+- left. destruct s0. destruct s0. 1,3: apply derI with (ps:=[]) ; auto.
+  2,4: apply dlNil. apply IdP ; auto. apply BotL ; auto.
+  inversion i ; subst. apply Id_all_form.
+- assert (forall prems, (InT prems x) -> ((dersrec GLS_rules (fun _ => False) prems) +
+  ((dersrec GLS_rules (fun _ => False) prems) -> False))).
+  { intros. pose (p prems). destruct p0. apply g in H. inversion H.
+    - inversion H0. subst. left ; apply dlNil.
+    - inversion H0. subst. left ; apply dlNil.
+    - inversion H0. subst.
+      assert (J1: (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) << (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)).
+      apply ImpR_applic_reduces_measure ; auto. destruct (IH _ J1).
+      * left ; apply dlCons ; auto ; apply dlNil.
+      * right. intro. inversion X. subst. auto.
+    - inversion H0. subst.
+      destruct (ImpL_applic_reduces_measure H0). destruct (IH _ l) ; destruct (IH _ l0).
+      * left. apply dlCons ; auto ; apply dlCons ; auto ; apply dlNil.
+      * right. intro. inversion X. subst. inversion X1. subst. auto.
+      * right. intro. inversion X. subst. auto.
+      * right. intro. inversion X. subst. auto.
+    - inversion X. subst.
+      assert (J1: (XBoxed_list ++ [Box A], [A]) << (Γ0, Δ0 ++ Box A :: Δ1)).
+      apply (GLR_applic_reduces_measure X) ; auto. destruct (IH _ J1).
+      * left. apply dlCons ; auto ; apply dlNil.
+      * right. intro. inversion X1. subst. auto. }
+  assert ((existsT2 prems, (InT prems x) * (dersrec GLS_rules (fun _ => False) prems)) +
+  (forall prems, (InT prems x) -> ((dersrec GLS_rules (fun _ => False) prems) -> False))).
+  { assert ((existsT2 prems, (InT prems x) * (dersrec GLS_rules (fun _ => False) prems)) +
+    ((existsT2 prems, (InT prems x) * (dersrec GLS_rules (fun _ => False) prems)) -> False)).
+    { pose (@forall_elem_list _ x (fun y =>
+      dersrec GLS_rules (fun _ : rel (list MPropF) => False) y) X). destruct s0.
+      - left. auto.
+      - right. auto. }
+    destruct X0.
+    - destruct s0. destruct p0. left. exists x0. auto.
+    - right. intros. firstorder. }
+  destruct X0.
+  ++ destruct s0. destruct p0. pose (p x0). destruct p0. apply g in i. left. apply derI with (ps:=x0) ; assumption.
+  ++ pose (dec_init_rules s). repeat destruct s0.
+    * left. apply derI with (ps:=[]) ; [apply IdP ; assumption | apply dlNil].
+    * left. inversion i ; subst. apply Id_all_form.
+    * left. apply derI with (ps:=[]) ; [apply BotL ; assumption | apply dlNil].
+    * right. intro der. inversion der.
+      + inversion H.
+      + subst. inversion X0.
+        { inversion H. subst. apply f. auto. }
+        { inversion H. subst. apply f. auto. }
+        { subst. pose (f0 ps). apply f2. pose (p ps). destruct p0. apply i. assumption.
+          assumption. }
+        { subst. pose (f0 ps). apply f2. pose (p ps). destruct p0. apply i. assumption.
+          assumption. }
+        { subst. pose (f0 ps). apply f2. pose (p ps). destruct p0. apply i. assumption.
+          assumption. }
+Qed.
+ +
+
+
+ +
+ + + diff --git a/GL.GLS.GLS_exch.html b/GL.GLS.GLS_exch.html new file mode 100644 index 0000000..a155d42 --- /dev/null +++ b/GL.GLS.GLS_exch.html @@ -0,0 +1,2278 @@ + + + + + + + + + + + + + +
+
+

GL.GLS.GLS_exch

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+Require Import Arith.
+ +
+Require Import GLS_calcs.
+ +
+Set Implicit Arguments.
+ +
+(* First, as we want to mimick sequents based on multisets of formulae we need to
+obtain exchange. *)

+ +
+(* Definition of exchange with lists of formulae directly. It is more general and
+makes the proofs easier to handle. *)

+ +
+Inductive list_exch_L : relationT Seq :=
+  | list_exch_LI Γ0 Γ1 Γ2 Γ3 Γ4 Δ : list_exch_L
+      (Γ0 ++ Γ1 ++ Γ2 ++ Γ3 ++ Γ4, Δ) (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4, Δ).
+ +
+Inductive list_exch_R : relationT Seq :=
+  | list_exch_RI Γ Δ0 Δ1 Δ2 Δ3 Δ4 : list_exch_R
+        (Γ, Δ0 ++ Δ1 ++ Δ2 ++ Δ3 ++ Δ4) (Γ, Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4).
+ +
+(* Some lemmas about In and exchange. *)
+ +
+Lemma InT_list_exch_R : forall l0 l1 l2,
+            (@list_exch_R (l0,l1) (l0,l2)) ->
+            (forall x, (InT x l1 -> InT x l2) * (InT x l2 -> InT x l1)).
+Proof.
+intros l0 l1 l2 exch. inversion exch.
+intro x. split.
+- intro. apply InT_app_or in H2. destruct H2. apply InT_or_app. left. assumption.
+  apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app. right.
+  apply InT_or_app. right. apply InT_or_app. left. assumption. apply InT_app_or in i.
+  destruct i. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. left.
+  assumption. apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app.
+  left. assumption. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right.
+  assumption.
+- intro. apply InT_app_or in H2. destruct H2. apply InT_or_app. left. assumption.
+  apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app. right.
+  apply InT_or_app. right. apply InT_or_app. left. assumption. apply InT_app_or in i.
+  destruct i. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. left.
+  assumption. apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app.
+  left. assumption. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right.
+  assumption.
+Qed.
+ +
+Lemma InT_list_exch_L : forall l0 l1 l2,
+            (@list_exch_L (l1,l0) (l2,l0)) ->
+            (forall x, (InT x l1 -> InT x l2) * (InT x l2 -> InT x l1)).
+Proof.
+intros l0 l1 l2 exch. inversion exch.
+intro x. split.
+- intro. apply InT_app_or in H2. destruct H2. apply InT_or_app. left. assumption.
+  apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app. right.
+  apply InT_or_app. right. apply InT_or_app. left. assumption. apply InT_app_or in i.
+  destruct i. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. left.
+  assumption. apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app.
+  left. assumption. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right.
+  assumption.
+- intro. apply InT_app_or in H2. destruct H2. apply InT_or_app. left. assumption.
+  apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app. right.
+  apply InT_or_app. right. apply InT_or_app. left. assumption. apply InT_app_or in i.
+  destruct i. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. left.
+  assumption. apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app.
+  left. assumption. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right.
+  assumption.
+Qed.
+ +
+(* Some useful lemmas about list exchange. *)
+ +
+Lemma list_exch_R_id : forall s, (@list_exch_R s s).
+Proof.
+intros s. destruct s. pose (list_exch_RI l l0
+[] [] [] []). simpl in l1. assert (H: l0 ++ [] = l0).
+apply app_nil_r. rewrite H in l1. assumption.
+Qed.
+ +
+Lemma list_exch_L_id : forall s, (@list_exch_L s s).
+Proof.
+intros s. destruct s. pose (list_exch_LI l
+[] [] [] [] l0). simpl in l1. assert (H: l ++ [] = l).
+apply app_nil_r. rewrite H in l1. assumption.
+Qed.
+ +
+Lemma list_exch_R_same_L: forall s se,
+    (@list_exch_R s se) ->
+    (forall Γ Γe Δ Δe, (s = (Γ , Δ)) ->
+    (se = (Γe , Δe)) ->
+    (Γ = Γe)).
+Proof.
+intros s se exch. induction exch. intros Γ0 Γe Δ Δe E1 E2.
+inversion E1. inversion E2. rewrite H0 in H2. assumption.
+Qed.
+ +
+Lemma list_exch_L_same_R : forall s se,
+    (@list_exch_L s se) ->
+    (forall Γ Γe Δ Δe, (s = (Γ , Δ)) ->
+    (se = (Γe , Δe)) ->
+    (Δ = Δe)).
+Proof.
+intros s se exch. induction exch. intros Γ Γe Δ0 Δe E1 E2.
+inversion E1. inversion E2. rewrite H1 in H3. assumption.
+Qed.
+ +
+Lemma list_exch_R_permL : forall s se,
+    (@list_exch_R s se) ->
+      (forall Γ0 Γ1 Δ C, s = ((Γ0 ++ C :: Γ1), Δ) ->
+      (existsT2 , se = ((Γ0 ++ C :: Γ1), ))).
+Proof.
+intros s se exch. induction exch. intros Γ0 Γ1 Δ C E.
+inversion E. exists (Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4). reflexivity.
+Qed.
+ +
+Lemma list_exch_R_permR : forall s se,
+    (@list_exch_R s se) ->
+      (forall Γ Δ0 Δ1 C, s = (Γ, (Δ0 ++ C :: Δ1)) ->
+      (existsT2 eΔ0 eΔ1, se = (Γ, (eΔ0 ++ C :: eΔ1)))).
+Proof.
+intros s se exch. induction exch. intros Γ0 Δ5 Δ6 C E.
+inversion E. apply partition_1_element in H1. destruct H1.
++ destruct s. destruct s. rewrite e. exists x. exists (x0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4).
+  simpl.
+  assert (E1: (x ++ C :: x0) ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4 = x ++ C :: x0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4).
+  { symmetry. apply app_assoc with (l:=x) (m:=C :: x0) (n:=Δ3 ++ Δ2 ++ Δ1 ++ Δ4). }
+  rewrite E1. reflexivity.
++ destruct s.
+  * destruct s. destruct s. exists (Δ0 ++ Δ3 ++ Δ2 ++ x). exists (x0 ++ Δ4).
+    rewrite e. assert (E1: Δ0 ++ Δ3 ++ Δ2 ++ (x ++ C :: x0) ++ Δ4 =
+    (Δ0 ++ Δ3 ++ Δ2 ++ x) ++ C :: x0 ++ Δ4).
+    pose (app_assoc x (C :: x0) Δ4). rewrite <- e0. simpl.
+    pose (app_assoc (Δ0 ++ Δ3 ++ Δ2) x (C :: x0 ++ Δ4)).
+    pose (app_assoc (Δ0 ++ Δ3) Δ2 x).
+    pose (app_assoc Δ0 Δ3 Δ2).
+    rewrite <- e3 in e2. rewrite <- e2 in e1.
+    pose (app_assoc Δ0 Δ3 (Δ2 ++ x)). rewrite <- e4 in e1. rewrite <- e1.
+    pose (app_assoc (Δ0 ++ Δ3) Δ2 (x ++ C :: x0 ++ Δ4)).
+    rewrite <- e3 in e5. rewrite <- e5.
+    pose (app_assoc Δ0 Δ3 (Δ2 ++ x ++ C :: x0 ++ Δ4)). rewrite e6. reflexivity.
+    rewrite E1. reflexivity.
+  * destruct s.
+    - destruct s. destruct s. exists (Δ0 ++ Δ3 ++ x). exists (x0 ++ Δ1 ++ Δ4).
+      rewrite e. assert (E1: Δ0 ++ Δ3 ++ (x ++ C :: x0) ++ Δ1 ++ Δ4 =
+      (Δ0 ++ Δ3 ++ x) ++ C :: x0 ++ Δ1 ++ Δ4).
+      pose (app_assoc x (C :: x0) (Δ1 ++ Δ4)). rewrite <- e0. simpl.
+      pose (app_assoc (Δ0 ++ Δ3) x (C :: x0 ++ Δ1 ++ Δ4)).
+      pose (app_assoc Δ0 Δ3 x). rewrite <- e2 in e1. rewrite <- e1.
+      pose (app_assoc Δ0 Δ3 (x ++ C :: x0 ++ Δ1 ++ Δ4)). rewrite <- e3.
+      reflexivity. rewrite E1. reflexivity.
+    - destruct s.
+      { destruct s. destruct s. rewrite e. exists (Δ0 ++ x). exists (x0 ++ Δ2 ++ Δ1 ++ Δ4).
+        assert (E1: Δ0 ++ (x ++ C :: x0) ++ Δ2 ++ Δ1 ++ Δ4 =
+        (Δ0 ++ x) ++ C :: x0 ++ Δ2 ++ Δ1 ++ Δ4).
+        pose (app_assoc x (C :: x0) (Δ2 ++ Δ1 ++ Δ4)). rewrite <- e0. simpl.
+        pose (app_assoc Δ0 x (C :: x0 ++ Δ2 ++ Δ1 ++ Δ4)). rewrite e1.
+        reflexivity. rewrite E1. reflexivity. }
+      { destruct s. destruct s. rewrite e. exists (Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ x).
+        exists x0. assert (E1: Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ x ++ C :: x0 =
+        (Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ x) ++ C :: x0).
+        pose (app_assoc (Δ0 ++ Δ3 ++ Δ2 ++ Δ1) x (C :: x0)).
+        pose (app_assoc (Δ0 ++ Δ3 ++ Δ2) Δ1 x).
+        pose (app_assoc (Δ0 ++ Δ3) Δ2 Δ1).
+        pose (app_assoc Δ0 Δ3 Δ2). rewrite <- e3 in e2. rewrite <- e2 in e1.
+        pose (app_assoc Δ0 Δ3 (Δ2 ++ Δ1)). rewrite <- e4 in e1. rewrite <- e1 in e0.
+        pose (app_assoc (Δ0 ++ Δ3) Δ2 (Δ1 ++ x)). rewrite <- e3 in e5.
+        rewrite <- e5 in e0.
+        pose (app_assoc Δ0 Δ3 (Δ2 ++ Δ1 ++ x)). rewrite <- e6 in e0.
+        rewrite <- e0.
+        pose (app_assoc (Δ0 ++ Δ3 ++ Δ2) Δ1 (x ++ C :: x0)).
+        rewrite <- e2 in e7. rewrite <- e4 in e7. rewrite <- e7.
+        pose (app_assoc (Δ0 ++ Δ3) Δ2 (Δ1 ++ x ++ C :: x0)).
+        rewrite <- e3 in e8. rewrite <- e8.
+        pose (app_assoc Δ0 Δ3 (Δ2 ++ Δ1 ++ x ++ C :: x0)).
+        rewrite e9. reflexivity. rewrite E1. reflexivity. }
+Qed.
+ +
+Lemma list_exch_R_permLR : forall s se,
+    (@list_exch_R s se) ->
+      (forall Γ0 Γ1 Δ0 Δ1 C D, s = ((Γ0 ++ C :: Γ1), (Δ0 ++ D :: Δ1)) ->
+      (existsT2 eΔ0 eΔ1, se = ((Γ0 ++ C :: Γ1), (eΔ0 ++ D :: eΔ1)))).
+Proof.
+intros s se exch. intros Γ0 Γ1 Δ0 Δ1 C D Eq.
+pose (list_exch_R_permL exch). pose (s0 Γ0 Γ1 (Δ0 ++ D :: Δ1) C).
+pose (s1 Eq). destruct s2.
+pose (list_exch_R_permR exch). pose (s2 (Γ0 ++ C :: Γ1) Δ0 Δ1 D).
+pose (s3 Eq). destruct s4. destruct s4. exists x0. exists x1. assumption.
+Qed.
+ +
+Lemma list_exch_L_permL : forall s se,
+    (@list_exch_L s se) ->
+      (forall Γ0 Γ1 Δ C, s = ((Γ0 ++ C :: Γ1), Δ) ->
+      (existsT2 eΓ0 eΓ1, se = ((eΓ0 ++ C :: eΓ1), Δ))).
+Proof.
+intros s se exch. induction exch. intros Γ5 Γ6 Δ0 C E.
+inversion E. apply partition_1_element in H0. destruct H0.
++ destruct s. destruct s. rewrite e. exists x. exists (x0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4).
+  simpl.
+  assert (E1: (x ++ C :: x0) ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4 = x ++ C :: x0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4).
+  { symmetry. apply app_assoc with (l:=x) (m:=C :: x0) (n:=Γ3 ++ Γ2 ++ Γ1 ++ Γ4). }
+  rewrite E1. reflexivity.
++ destruct s.
+  * destruct s. destruct s. exists (Γ0 ++ Γ3 ++ Γ2 ++ x). exists (x0 ++ Γ4).
+    rewrite e. assert (E1: Γ0 ++ Γ3 ++ Γ2 ++ (x ++ C :: x0) ++ Γ4 =
+    (Γ0 ++ Γ3 ++ Γ2 ++ x) ++ C :: x0 ++ Γ4).
+    pose (app_assoc x (C :: x0) Γ4). rewrite <- e0. simpl.
+    pose (app_assoc (Γ0 ++ Γ3 ++ Γ2) x (C :: x0 ++ Γ4)).
+    pose (app_assoc (Γ0 ++ Γ3) Γ2 x).
+    pose (app_assoc Γ0 Γ3 Γ2).
+    rewrite <- e3 in e2. rewrite <- e2 in e1.
+    pose (app_assoc Γ0 Γ3 (Γ2 ++ x)). rewrite <- e4 in e1. rewrite <- e1.
+    pose (app_assoc (Γ0 ++ Γ3) Γ2 (x ++ C :: x0 ++ Γ4)).
+    rewrite <- e3 in e5. rewrite <- e5.
+    pose (app_assoc Γ0 Γ3 (Γ2 ++ x ++ C :: x0 ++ Γ4)). rewrite e6. reflexivity.
+    rewrite E1. reflexivity.
+  * destruct s.
+    - destruct s. destruct s. exists (Γ0 ++ Γ3 ++ x). exists (x0 ++ Γ1 ++ Γ4).
+      rewrite e. assert (E1: Γ0 ++ Γ3 ++ (x ++ C :: x0) ++ Γ1 ++ Γ4 =
+      (Γ0 ++ Γ3 ++ x) ++ C :: x0 ++ Γ1 ++ Γ4).
+      pose (app_assoc x (C :: x0) (Γ1 ++ Γ4)). rewrite <- e0. simpl.
+      pose (app_assoc (Γ0 ++ Γ3) x (C :: x0 ++ Γ1 ++ Γ4)).
+      pose (app_assoc Γ0 Γ3 x). rewrite <- e2 in e1. rewrite <- e1.
+      pose (app_assoc Γ0 Γ3 (x ++ C :: x0 ++ Γ1 ++ Γ4)). rewrite <- e3.
+      reflexivity. rewrite E1. reflexivity.
+    - destruct s.
+      { destruct s. destruct s. rewrite e. exists (Γ0 ++ x). exists (x0 ++ Γ2 ++ Γ1 ++ Γ4).
+        assert (E1: Γ0 ++ (x ++ C :: x0) ++ Γ2 ++ Γ1 ++ Γ4 =
+        (Γ0 ++ x) ++ C :: x0 ++ Γ2 ++ Γ1 ++ Γ4).
+        pose (app_assoc x (C :: x0) (Γ2 ++ Γ1 ++ Γ4)). rewrite <- e0. simpl.
+        pose (app_assoc Γ0 x (C :: x0 ++ Γ2 ++ Γ1 ++ Γ4)). rewrite e1.
+        reflexivity. rewrite E1. reflexivity. }
+      { destruct s. destruct s. rewrite e. exists (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ x).
+        exists x0. assert (E1: Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ x ++ C :: x0 =
+        (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ x) ++ C :: x0).
+        pose (app_assoc (Γ0 ++ Γ3 ++ Γ2 ++ Γ1) x (C :: x0)).
+        pose (app_assoc (Γ0 ++ Γ3 ++ Γ2) Γ1 x).
+        pose (app_assoc (Γ0 ++ Γ3) Γ2 Γ1).
+        pose (app_assoc Γ0 Γ3 Γ2). rewrite <- e3 in e2. rewrite <- e2 in e1.
+        pose (app_assoc Γ0 Γ3 (Γ2 ++ Γ1)). rewrite <- e4 in e1. rewrite <- e1 in e0.
+        pose (app_assoc (Γ0 ++ Γ3) Γ2 (Γ1 ++ x)). rewrite <- e3 in e5.
+        rewrite <- e5 in e0.
+        pose (app_assoc Γ0 Γ3 (Γ2 ++ Γ1 ++ x)). rewrite <- e6 in e0.
+        rewrite <- e0.
+        pose (app_assoc (Γ0 ++ Γ3 ++ Γ2) Γ1 (x ++ C :: x0)).
+        rewrite <- e2 in e7. rewrite <- e4 in e7. rewrite <- e7.
+        pose (app_assoc (Γ0 ++ Γ3) Γ2 (Γ1 ++ x ++ C :: x0)).
+        rewrite <- e3 in e8. rewrite <- e8.
+        pose (app_assoc Γ0 Γ3 (Γ2 ++ Γ1 ++ x ++ C :: x0)).
+        rewrite e9. reflexivity. rewrite E1. reflexivity. }
+Qed.
+ +
+Lemma list_exch_L_permR : forall s se,
+    (@list_exch_L s se) ->
+      (forall Γ Δ0 Δ1 C, s = (Γ, (Δ0 ++ C :: Δ1)) ->
+      (existsT2 , se = (, (Δ0 ++ C :: Δ1)))).
+Proof.
+intros s se exch. induction exch. intros Γ Δ0 Δ1 C E.
+inversion E. exists (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4). reflexivity.
+Qed.
+ +
+Lemma list_exch_L_permLR : forall s se,
+    (@list_exch_L s se) ->
+      (forall Γ0 Γ1 Δ0 Δ1 C D, s = ((Γ0 ++ C :: Γ1), (Δ0 ++ D :: Δ1)) ->
+      (existsT2 eΓ0 eΓ1, se = ((eΓ0 ++ C :: eΓ1), (Δ0 ++ D :: Δ1)))).
+Proof.
+intros s se exch. intros Γ0 Γ1 Δ0 Δ1 C D Eq.
+pose (list_exch_L_permR exch). pose (s0 (Γ0 ++ C :: Γ1) Δ0 Δ1 D).
+pose (s1 Eq). destruct s2.
+pose (list_exch_L_permL exch). pose (s2 Γ0 Γ1 (Δ0 ++ D :: Δ1) C).
+pose (s3 Eq). destruct s4. destruct s4. exists x0. exists x1. assumption.
+Qed.
+ +
+(* Some lemmas about atomic generalized extensions of lists and exchange. *)
+ +
+Lemma nobox_gen_ext_exch_R : forall Γ Γ' l0 l1 l2,
+    (nobox_gen_ext l0 l1) -> (@list_exch_R (Γ,l1) (Γ,l2)) ->
+    existsT2 l3, (nobox_gen_ext l3 l2) * (list_exch_R (Γ',l0) (Γ',l3)).
+Proof.
+intros Γ Γ' l0. induction l0.
++ intros l1 l2 gen. remember [] as l0. destruct gen.
+  - intro exch. inversion exch. apply app_eq_nil in H1. destruct H1. apply app_eq_nil in H2. destruct H2.
+    apply app_eq_nil in H3. destruct H3. apply app_eq_nil in H4. destruct H4.
+    subst. simpl. exists []. split.
+    * apply univ_gen_ext_nil.
+    * apply list_exch_R_id.
+  - intros exch. exists []. split.
+    * inversion Heql0.
+    * inversion Heql0.
+  - intro exch. subst. exists []. split. apply all_P_univ_gen_ext_nil.
+    intros. pose (InT_list_exch_R exch). pose (p x0). destruct p0. pose (univ_gen_ext_nil_all_P gen).
+    pose (f0 x0). apply i0 in H. inversion H. subst. apply f. assumption. subst. apply f1 in H1.
+    assumption. assumption.
+    apply list_exch_R_id.
++ intros l1 l2 gen. induction gen.
+  - intro exch. inversion exch. destruct Δ0.
+    * rewrite app_nil_l in H. rewrite app_nil_l in H1. rewrite app_nil_l. destruct Δ1.
+      { rewrite app_nil_l in H1. destruct Δ2.
+        + rewrite app_nil_l in H1. destruct Δ3.
+          - rewrite app_nil_l in H1. repeat rewrite app_nil_l in H. destruct Δ4.
+            * simpl. exists []. split. apply univ_gen_ext_nil. apply list_exch_R_id.
+            * inversion H1.
+          - inversion H1.
+        + inversion H1. }
+      { inversion H1. }
+    * inversion H1.
+  - intro exch. inversion exch. destruct Δ0.
+    * rewrite app_nil_l in H. rewrite app_nil_l in H1. rewrite app_nil_l. destruct Δ1.
+      { rewrite app_nil_l in H1. destruct Δ2.
+        + rewrite app_nil_l in H1. destruct Δ3.
+          - rewrite app_nil_l in H1. repeat rewrite app_nil_l in H. destruct Δ4.
+            * inversion H1.
+            * inversion H1. simpl. subst. exists (x :: l).
+              split. apply univ_gen_ext_cons. assumption. apply list_exch_R_id.
+          - repeat rewrite app_nil_l in H. repeat rewrite app_nil_l. simpl. simpl in H. simpl in H1.
+            inversion H1. subst. exists (x :: l). split. apply univ_gen_ext_cons. assumption. apply list_exch_R_id.
+        + rewrite app_nil_l. rewrite app_nil_l in H. inversion H1. subst.
+          pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p.
+          pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p. subst.
+          exists (x2 ++ x :: x0 ++ x3). split.
+          - apply univ_gen_ext_cons with (x:=x) in u. pose (univ_gen_ext_combine u u2).
+            pose (univ_gen_ext_combine u1 u3). assumption.
+          - pose (list_exch_RI Γ' [] [] (x :: x0) x2 x3). repeat rewrite app_nil_l in l. assumption. }
+      { inversion H1. subst. pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p.
+        pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u2).
+        repeat destruct s. repeat destruct p. subst. exists (x4 ++ x2 ++ (x :: x0) ++ x5).
+        split.
+        - apply univ_gen_ext_cons with (x:=x) in u. pose (univ_gen_ext_combine u u4).
+          pose (univ_gen_ext_combine u1 u5). pose (univ_gen_ext_combine u3 u6). assumption.
+        - pose (list_exch_RI Γ' [] (x :: x0) x2 x4 x5). rewrite app_nil_l in l. assumption. }
+    * inversion H1. subst. pose (univ_gen_ext_splitR _ _ gen).
+      repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u0).
+      repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u2).
+      repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u4).
+      repeat destruct s. repeat destruct p. subst. exists (x :: x0 ++ x6 ++ x4 ++ x2 ++ x7).
+      split.
+      { apply univ_gen_ext_cons with (x:=x) in u. pose (univ_gen_ext_combine u1 u6).
+        pose (univ_gen_ext_combine u3 u7). pose (univ_gen_ext_combine u5 u8).
+        pose (univ_gen_ext_combine u u9). assumption. }
+      { assert (E1: x :: x0 ++ x2 ++ x4 ++ x6 ++ x7 = (x :: x0) ++ x2 ++ x4 ++ x6 ++ x7).
+        reflexivity. rewrite E1.
+        assert (E2: x :: x0 ++ x6 ++ x4 ++ x2 ++ x7 = (x :: x0) ++ x6 ++ x4 ++ x2 ++ x7).
+        reflexivity. rewrite E2. apply list_exch_RI. }
+  - intro exch. inversion exch. destruct Δ0.
+    * rewrite app_nil_l in H. rewrite app_nil_l in H1. rewrite app_nil_l. destruct Δ1.
+      { rewrite app_nil_l in H1. destruct Δ2.
+        + rewrite app_nil_l in H1. destruct Δ3.
+          - rewrite app_nil_l in H1. repeat rewrite app_nil_l in H. destruct Δ4.
+            * inversion H1.
+            * inversion H1. simpl. subst. exists l.
+              split. apply univ_gen_ext_extra. assumption. assumption. apply list_exch_R_id.
+          - repeat rewrite app_nil_l in H. repeat rewrite app_nil_l. simpl. simpl in H. simpl in H1.
+            inversion H1. subst. exists l. split. apply univ_gen_ext_extra. assumption. assumption. apply list_exch_R_id.
+        + rewrite app_nil_l. rewrite app_nil_l in H. inversion H1. subst.
+          pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p0.
+          pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p0. subst.
+          exists (x2 ++ x0 ++ x3). split.
+          - apply univ_gen_ext_extra with (x:=x) in u. pose (univ_gen_ext_combine u u2).
+            pose (univ_gen_ext_combine u1 u3). assumption. assumption.
+          - pose (list_exch_RI Γ' [] [] x0 x2 x3). repeat rewrite app_nil_l in l. assumption. }
+      { inversion H1. subst. pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p0.
+        pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u2).
+        repeat destruct s. repeat destruct p0. subst. exists (x4 ++ x2 ++ x0 ++ x5).
+        split.
+        - apply univ_gen_ext_extra with (x:=x) in u. pose (univ_gen_ext_combine u u4).
+          pose (univ_gen_ext_combine u1 u5). pose (univ_gen_ext_combine u3 u6). assumption. assumption.
+        - pose (list_exch_RI Γ' [] x0 x2 x4 x5). rewrite app_nil_l in l. assumption. }
+    * inversion H1. subst. pose (univ_gen_ext_splitR _ _ gen).
+      repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u0).
+      repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u2).
+      repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u4).
+      repeat destruct s. repeat destruct p0. subst. exists (x0 ++ x6 ++ x4 ++ x2 ++ x7).
+      split.
+      { apply univ_gen_ext_extra with (x:=x) in u. pose (univ_gen_ext_combine u1 u6).
+        pose (univ_gen_ext_combine u3 u7). pose (univ_gen_ext_combine u5 u8).
+        pose (univ_gen_ext_combine u u9). assumption. assumption. }
+      { apply list_exch_RI. }
+Qed.
+ +
+Lemma nobox_gen_ext_exch_L : forall Δ Δ' l0 l1 l2,
+    (nobox_gen_ext l0 l1) -> (@list_exch_L (l1,Δ) (l2,Δ)) ->
+    existsT2 l3, (nobox_gen_ext l3 l2) * (list_exch_L (l0,Δ') (l3,Δ')).
+Proof.
+intros Δ Δ' l0. induction l0.
++ intros l1 l2 gen. inversion gen.
+  - intro exch. inversion exch. apply app_eq_nil in H1. destruct H1. apply app_eq_nil in H3. destruct H3.
+    apply app_eq_nil in H4. destruct H4. apply app_eq_nil in H5. destruct H5.
+    subst. simpl. exists []. split.
+    * apply univ_gen_ext_nil.
+    * apply list_exch_L_id.
+  - intros exch. exists []. split.
+    * subst. apply all_P_univ_gen_ext_nil. intros. pose (InT_list_exch_L exch).
+      pose (p x0). destruct p0. apply i0 in H0. inversion H0. subst. apply H.
+      assumption. subst. pose (univ_gen_ext_nil_all_P gen). apply f in H0.
+      assumption. assumption.
+    * apply list_exch_L_id.
++ intros l1 l2 gen. induction gen.
+  - intro exch. inversion exch. destruct Γ0.
+    * rewrite app_nil_l in H0. rewrite app_nil_l in H. rewrite app_nil_l. destruct Γ1.
+      { rewrite app_nil_l in H0. destruct Γ2.
+        + rewrite app_nil_l in H0. destruct Γ3.
+          - rewrite app_nil_l in H0. repeat rewrite app_nil_l in H. destruct Γ4.
+            * simpl. exists []. split. apply univ_gen_ext_nil. apply list_exch_L_id.
+            * inversion H0.
+          - inversion H0.
+        + inversion H0. }
+      { inversion H0. }
+    * inversion H0.
+  - intro exch. inversion exch. destruct Γ0.
+    * rewrite app_nil_l in H. rewrite app_nil_l in H0. rewrite app_nil_l. destruct Γ1.
+      { rewrite app_nil_l in H0. destruct Γ2.
+        + rewrite app_nil_l in H0. destruct Γ3.
+          - rewrite app_nil_l in H0. repeat rewrite app_nil_l in H. destruct Γ4.
+            * inversion H0.
+            * inversion H0. simpl. subst. exists (x :: l).
+              split. apply univ_gen_ext_cons. assumption. apply list_exch_L_id.
+          - repeat rewrite app_nil_l in H. repeat rewrite app_nil_l. simpl. simpl in H. simpl in H0.
+            inversion H0. subst. exists (x :: l). split. apply univ_gen_ext_cons. assumption. apply list_exch_L_id.
+        + rewrite app_nil_l. rewrite app_nil_l in H. inversion H0. subst.
+          pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p.
+          pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p. subst.
+          exists (x2 ++ x :: x0 ++ x3). split.
+          - apply univ_gen_ext_cons with (x:=x) in u. pose (univ_gen_ext_combine u u2).
+            pose (univ_gen_ext_combine u1 u3). assumption.
+          - pose (list_exch_LI [] [] (x :: x0) x2 x3 Δ'). repeat rewrite app_nil_l in l. assumption. }
+      { inversion H0. subst. pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p.
+        pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u2).
+        repeat destruct s. repeat destruct p. subst. exists (x4 ++ x2 ++ (x :: x0) ++ x5).
+        split.
+        - apply univ_gen_ext_cons with (x:=x) in u. pose (univ_gen_ext_combine u u4).
+          pose (univ_gen_ext_combine u1 u5). pose (univ_gen_ext_combine u3 u6). assumption.
+        - pose (list_exch_LI [] (x :: x0) x2 x4 x5 Δ'). rewrite app_nil_l in l. assumption. }
+    * inversion H0. subst. pose (univ_gen_ext_splitR _ _ gen).
+      repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u0).
+      repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u2).
+      repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u4).
+      repeat destruct s. repeat destruct p. subst. exists (x :: x0 ++ x6 ++ x4 ++ x2 ++ x7).
+      split.
+      { apply univ_gen_ext_cons with (x:=x) in u. pose (univ_gen_ext_combine u1 u6).
+        pose (univ_gen_ext_combine u3 u7). pose (univ_gen_ext_combine u5 u8).
+        pose (univ_gen_ext_combine u u9). assumption. }
+      { assert (E1: x :: x0 ++ x2 ++ x4 ++ x6 ++ x7 = (x :: x0) ++ x2 ++ x4 ++ x6 ++ x7).
+        reflexivity. rewrite E1.
+        assert (E2: x :: x0 ++ x6 ++ x4 ++ x2 ++ x7 = (x :: x0) ++ x6 ++ x4 ++ x2 ++ x7).
+        reflexivity. rewrite E2. apply list_exch_LI. }
+  - intro exch. inversion exch. destruct Γ0.
+    * rewrite app_nil_l in H. rewrite app_nil_l in H0. rewrite app_nil_l. destruct Γ1.
+      { rewrite app_nil_l in H0. destruct Γ2.
+        + rewrite app_nil_l in H0. destruct Γ3.
+          - rewrite app_nil_l in H0. repeat rewrite app_nil_l in H. destruct Γ4.
+            * inversion H0.
+            * inversion H0. simpl. subst. exists l.
+              split. apply univ_gen_ext_extra. assumption. assumption. apply list_exch_L_id.
+          - repeat rewrite app_nil_l in H. repeat rewrite app_nil_l. simpl. simpl in H. simpl in H0.
+            inversion H0. subst. exists l. split. apply univ_gen_ext_extra. assumption. assumption. apply list_exch_L_id.
+        + rewrite app_nil_l. rewrite app_nil_l in H. inversion H0. subst.
+          pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p0.
+          pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p0. subst.
+          exists (x2 ++ x0 ++ x3). split.
+          - apply univ_gen_ext_extra with (x:=x) in u. pose (univ_gen_ext_combine u u2).
+            pose (univ_gen_ext_combine u1 u3). assumption. assumption.
+          - pose (list_exch_LI [] [] x0 x2 x3 Δ'). repeat rewrite app_nil_l in l. assumption. }
+      { inversion H0. subst. pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p0.
+        pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u2).
+        repeat destruct s. repeat destruct p0. subst. exists (x4 ++ x2 ++ x0 ++ x5).
+        split.
+        - apply univ_gen_ext_extra with (x:=x) in u. pose (univ_gen_ext_combine u u4).
+          pose (univ_gen_ext_combine u1 u5). pose (univ_gen_ext_combine u3 u6). assumption. assumption.
+        - pose (list_exch_LI [] x0 x2 x4 x5 Δ'). rewrite app_nil_l in l. assumption. }
+    * inversion H0. subst. pose (univ_gen_ext_splitR _ _ gen).
+      repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u0).
+      repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u2).
+      repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u4).
+      repeat destruct s. repeat destruct p0. subst. exists (x0 ++ x6 ++ x4 ++ x2 ++ x7).
+      split.
+      { apply univ_gen_ext_extra with (x:=x) in u. pose (univ_gen_ext_combine u1 u6).
+        pose (univ_gen_ext_combine u3 u7). pose (univ_gen_ext_combine u5 u8).
+        pose (univ_gen_ext_combine u u9). assumption. assumption. }
+      { apply list_exch_LI. }
+Qed.
+ +
+(* Interactions between exchange and rules. *)
+ +
+Lemma list_exch_L_IdP_notapplic : forall s se,
+    (@list_exch_L s se) ->
+    ((IdPRule [] s) -> False) ->
+    ((IdPRule [] se) -> False).
+Proof.
+intros s se exch. induction exch. intros RA RAe. apply RA.
+inversion RAe. symmetry in H. apply partition_1_element in H.
+destruct H.
+- destruct s. destruct s. rewrite e.
+  assert (E: (x ++ # P :: x0) ++ Γ1 ++ Γ2 ++ Γ3 ++ Γ4 =
+  x ++ # P :: x0 ++ Γ1 ++ Γ2 ++ Γ3 ++ Γ4).
+  pose (app_assoc x (# P :: x0) (Γ1 ++ Γ2 ++ Γ3 ++ Γ4)). rewrite <- e0.
+  auto. rewrite E. apply IdPRule_I.
+- destruct s.
+  + destruct s. destruct s. rewrite e.
+    assert (E: Γ0 ++ Γ1 ++ Γ2 ++ (x ++ # P :: x0) ++ Γ4 =
+    Γ0 ++ Γ1 ++ Γ2 ++ x ++ # P :: x0 ++ Γ4).
+    pose (app_assoc x (# P :: x0) Γ4).
+    simpl in e0. rewrite <- e0. reflexivity. rewrite E.
+    assert (E1: Γ0 ++ Γ1 ++ Γ2 ++ x ++ # P :: x0 ++ Γ4 =
+    (Γ0 ++ Γ1 ++ Γ2 ++ x) ++ # P :: x0 ++ Γ4).
+    pose (app_assoc (Γ0 ++ Γ1 ++ Γ2) x (# P :: x0 ++ Γ4)).
+    pose (app_assoc (Γ0 ++ Γ1) Γ2 x).
+    pose (app_assoc Γ0 Γ1 Γ2). rewrite <- e2 in e1. rewrite <- e1 in e0.
+    pose (app_assoc Γ0 Γ1 (Γ2 ++ x)). rewrite <- e3 in e0. rewrite <- e0.
+    pose (app_assoc (Γ0 ++ Γ1) Γ2 (x ++ # P :: x0 ++ Γ4)). rewrite <- e2 in e4.
+    rewrite <- e4.
+    pose (app_assoc Γ0 Γ1 (Γ2 ++ x ++ # P :: x0 ++ Γ4)). rewrite e5. reflexivity.
+    rewrite E1. apply IdPRule_I.
+  + destruct s.
+    * destruct s. destruct s. rewrite e.
+      assert (E: Γ0 ++ Γ1 ++ (x ++ # P :: x0) ++ Γ3 ++ Γ4 =
+      (Γ0 ++ Γ1 ++ x) ++ # P :: x0 ++ Γ3 ++ Γ4).
+      pose (app_assoc x (# P :: x0) (Γ3 ++ Γ4)). rewrite <- e0. simpl.
+      pose (app_assoc (Γ0 ++ Γ1) x (# P :: x0 ++ Γ3 ++ Γ4)).
+      pose (app_assoc Γ0 Γ1 x). rewrite <- e2 in e1. rewrite <- e1.
+      pose (app_assoc Γ0 Γ1 (x ++ # P :: x0 ++ Γ3 ++ Γ4)). rewrite <- e3.
+      reflexivity. rewrite E. apply IdPRule_I.
+    * destruct s.
+      { destruct s. destruct s. rewrite e.
+        assert (E: Γ0 ++ (x ++ # P :: x0) ++ Γ2 ++ Γ3 ++ Γ4 =
+        (Γ0 ++ x) ++ # P :: x0 ++ Γ2 ++ Γ3 ++ Γ4).
+        pose (app_assoc x (# P :: x0) (Γ2 ++ Γ3 ++ Γ4)).
+        rewrite <- e0. simpl.
+        pose (app_assoc Γ0 x (# P :: x0 ++ Γ2 ++ Γ3 ++ Γ4)).
+        rewrite <- e1. reflexivity. rewrite E. apply IdPRule_I. }
+      { destruct s. destruct s. rewrite e.
+        assert (E: Γ0 ++ Γ1 ++ Γ2 ++ Γ3 ++ x ++ # P :: x0 =
+        (Γ0 ++ Γ1 ++ Γ2 ++ Γ3 ++ x) ++ # P :: x0).
+        pose (app_assoc (Γ0 ++ Γ1 ++ Γ2 ++ Γ3) x (# P :: x0)).
+        pose (app_assoc (Γ0 ++ Γ1 ++ Γ2) Γ3 x).
+        pose (app_assoc (Γ0 ++ Γ1) Γ2 Γ3).
+        pose (app_assoc Γ0 Γ1 Γ2).
+        rewrite <- e3 in e2. rewrite <- e2 in e1.
+        pose (app_assoc Γ0 Γ1 (Γ2 ++ Γ3)).
+        rewrite <- e4 in e1. rewrite <- e1 in e0.
+        pose (app_assoc (Γ0 ++ Γ1) Γ2 (Γ3 ++ x)).
+        rewrite <- e3 in e5. rewrite <- e5 in e0.
+        pose (app_assoc Γ0 Γ1 (Γ2 ++ Γ3 ++ x)).
+        rewrite <- e6 in e0. rewrite <- e0.
+        pose (app_assoc (Γ0 ++ Γ1 ++ Γ2) Γ3 (x ++ # P :: x0)).
+        pose (app_assoc (Γ0 ++ Γ1) Γ2 Γ3).
+        rewrite <- e3 in e8. rewrite <- e8 in e7.
+        pose (app_assoc Γ0 Γ1 (Γ2 ++ Γ3)). rewrite <- e9 in e7.
+        rewrite <- e7.
+        pose (app_assoc (Γ0 ++ Γ1) Γ2 (Γ3 ++ x ++ # P :: x0)).
+        rewrite <- e3 in e10. rewrite <- e10.
+        pose (app_assoc Γ0 Γ1 (Γ2 ++ Γ3 ++ x ++ # P :: x0)).
+        rewrite <- e11. reflexivity.
+        rewrite E. apply IdPRule_I. }
+Qed.
+ +
+Lemma list_exch_L_IdB_notapplic : forall s se,
+    (@list_exch_L s se) ->
+    ((IdBRule [] s) -> False) ->
+    ((IdBRule [] se) -> False).
+Proof.
+intros s se exch. induction exch. intros RA RAe. apply RA.
+inversion RAe. symmetry in H. apply partition_1_element in H.
+destruct H.
+- destruct s. destruct s. rewrite e.
+  assert (E: (x ++ Box A :: x0) ++ Γ1 ++ Γ2 ++ Γ3 ++ Γ4 =
+  x ++ Box A :: x0 ++ Γ1 ++ Γ2 ++ Γ3 ++ Γ4).
+  pose (app_assoc x (Box A :: x0) (Γ1 ++ Γ2 ++ Γ3 ++ Γ4)). rewrite <- e0.
+  auto. rewrite E. apply IdBRule_I.
+- destruct s.
+  + destruct s. destruct s. rewrite e.
+    assert (E: Γ0 ++ Γ1 ++ Γ2 ++ (x ++ Box A :: x0) ++ Γ4 =
+    Γ0 ++ Γ1 ++ Γ2 ++ x ++ Box A :: x0 ++ Γ4).
+    pose (app_assoc x (Box A :: x0) Γ4).
+    simpl in e0. rewrite <- e0. reflexivity. rewrite E.
+    assert (E1: Γ0 ++ Γ1 ++ Γ2 ++ x ++ Box A :: x0 ++ Γ4 =
+    (Γ0 ++ Γ1 ++ Γ2 ++ x) ++ Box A :: x0 ++ Γ4).
+    pose (app_assoc (Γ0 ++ Γ1 ++ Γ2) x (Box A :: x0 ++ Γ4)).
+    pose (app_assoc (Γ0 ++ Γ1) Γ2 x).
+    pose (app_assoc Γ0 Γ1 Γ2). rewrite <- e2 in e1. rewrite <- e1 in e0.
+    pose (app_assoc Γ0 Γ1 (Γ2 ++ x)). rewrite <- e3 in e0. rewrite <- e0.
+    pose (app_assoc (Γ0 ++ Γ1) Γ2 (x ++ Box A :: x0 ++ Γ4)). rewrite <- e2 in e4.
+    rewrite <- e4.
+    pose (app_assoc Γ0 Γ1 (Γ2 ++ x ++ Box A :: x0 ++ Γ4)). rewrite e5. reflexivity.
+    rewrite E1. apply IdBRule_I.
+  + destruct s.
+    * destruct s. destruct s. rewrite e.
+      assert (E: Γ0 ++ Γ1 ++ (x ++ Box A :: x0) ++ Γ3 ++ Γ4 =
+      (Γ0 ++ Γ1 ++ x) ++ Box A :: x0 ++ Γ3 ++ Γ4).
+      pose (app_assoc x (Box A :: x0) (Γ3 ++ Γ4)). rewrite <- e0. simpl.
+      pose (app_assoc (Γ0 ++ Γ1) x (Box A :: x0 ++ Γ3 ++ Γ4)).
+      pose (app_assoc Γ0 Γ1 x). rewrite <- e2 in e1. rewrite <- e1.
+      pose (app_assoc Γ0 Γ1 (x ++ Box A :: x0 ++ Γ3 ++ Γ4)). rewrite <- e3.
+      reflexivity. rewrite E. apply IdBRule_I.
+    * destruct s.
+      { destruct s. destruct s. rewrite e.
+        assert (E: Γ0 ++ (x ++ Box A :: x0) ++ Γ2 ++ Γ3 ++ Γ4 =
+        (Γ0 ++ x) ++ Box A :: x0 ++ Γ2 ++ Γ3 ++ Γ4).
+        pose (app_assoc x (Box A :: x0) (Γ2 ++ Γ3 ++ Γ4)).
+        rewrite <- e0. simpl.
+        pose (app_assoc Γ0 x (Box A :: x0 ++ Γ2 ++ Γ3 ++ Γ4)).
+        rewrite <- e1. reflexivity. rewrite E. apply IdBRule_I. }
+      { destruct s. destruct s. rewrite e.
+        assert (E: Γ0 ++ Γ1 ++ Γ2 ++ Γ3 ++ x ++ Box A :: x0 =
+        (Γ0 ++ Γ1 ++ Γ2 ++ Γ3 ++ x) ++ Box A :: x0).
+        pose (app_assoc (Γ0 ++ Γ1 ++ Γ2 ++ Γ3) x (Box A :: x0)).
+        pose (app_assoc (Γ0 ++ Γ1 ++ Γ2) Γ3 x).
+        pose (app_assoc (Γ0 ++ Γ1) Γ2 Γ3).
+        pose (app_assoc Γ0 Γ1 Γ2).
+        rewrite <- e3 in e2. rewrite <- e2 in e1.
+        pose (app_assoc Γ0 Γ1 (Γ2 ++ Γ3)).
+        rewrite <- e4 in e1. rewrite <- e1 in e0.
+        pose (app_assoc (Γ0 ++ Γ1) Γ2 (Γ3 ++ x)).
+        rewrite <- e3 in e5. rewrite <- e5 in e0.
+        pose (app_assoc Γ0 Γ1 (Γ2 ++ Γ3 ++ x)).
+        rewrite <- e6 in e0. rewrite <- e0.
+        pose (app_assoc (Γ0 ++ Γ1 ++ Γ2) Γ3 (x ++ Box A :: x0)).
+        pose (app_assoc (Γ0 ++ Γ1) Γ2 Γ3).
+        rewrite <- e3 in e8. rewrite <- e8 in e7.
+        pose (app_assoc Γ0 Γ1 (Γ2 ++ Γ3)). rewrite <- e9 in e7.
+        rewrite <- e7.
+        pose (app_assoc (Γ0 ++ Γ1) Γ2 (Γ3 ++ x ++ Box A :: x0)).
+        rewrite <- e3 in e10. rewrite <- e10.
+        pose (app_assoc Γ0 Γ1 (Γ2 ++ Γ3 ++ x ++ Box A :: x0)).
+        rewrite <- e11. reflexivity.
+        rewrite E. apply IdBRule_I. }
+Qed.
+ +
+Lemma list_exch_L_BotL_notapplic : forall s se,
+    (@list_exch_L s se) ->
+    ((BotLRule [] s) -> False) ->
+    ((BotLRule [] se) -> False).
+Proof.
+intros s se exch. induction exch. intros RA RAe. apply RA.
+inversion RAe. symmetry in H. apply partition_1_element in H.
+destruct H.
+- destruct s. destruct s. rewrite e.
+  assert (E: (x ++ :: x0) ++ Γ1 ++ Γ2 ++ Γ3 ++ Γ4 =
+  x ++ :: x0 ++ Γ1 ++ Γ2 ++ Γ3 ++ Γ4).
+  pose (app_assoc x ( :: x0) (Γ1 ++ Γ2 ++ Γ3 ++ Γ4)). rewrite <- e0.
+  auto. rewrite E. apply BotLRule_I.
+- destruct s.
+  + destruct s. destruct s. rewrite e.
+    assert (E: Γ0 ++ Γ1 ++ Γ2 ++ (x ++ :: x0) ++ Γ4 =
+    Γ0 ++ Γ1 ++ Γ2 ++ x ++ :: x0 ++ Γ4).
+    pose (app_assoc x ( :: x0) Γ4).
+    simpl in e0. rewrite <- e0. reflexivity. rewrite E.
+    assert (E1: Γ0 ++ Γ1 ++ Γ2 ++ x ++ :: x0 ++ Γ4 =
+    (Γ0 ++ Γ1 ++ Γ2 ++ x) ++ :: x0 ++ Γ4).
+    pose (app_assoc (Γ0 ++ Γ1 ++ Γ2) x ( :: x0 ++ Γ4)).
+    pose (app_assoc (Γ0 ++ Γ1) Γ2 x).
+    pose (app_assoc Γ0 Γ1 Γ2). rewrite <- e2 in e1. rewrite <- e1 in e0.
+    pose (app_assoc Γ0 Γ1 (Γ2 ++ x)). rewrite <- e3 in e0. rewrite <- e0.
+    pose (app_assoc (Γ0 ++ Γ1) Γ2 (x ++ :: x0 ++ Γ4)). rewrite <- e2 in e4.
+    rewrite <- e4.
+    pose (app_assoc Γ0 Γ1 (Γ2 ++ x ++ :: x0 ++ Γ4)). rewrite e5. reflexivity.
+    rewrite E1. apply BotLRule_I.
+  + destruct s.
+    * destruct s. destruct s. rewrite e.
+      assert (E: Γ0 ++ Γ1 ++ (x ++ :: x0) ++ Γ3 ++ Γ4 =
+      (Γ0 ++ Γ1 ++ x) ++ :: x0 ++ Γ3 ++ Γ4).
+      pose (app_assoc x ( :: x0) (Γ3 ++ Γ4)). rewrite <- e0. simpl.
+      pose (app_assoc (Γ0 ++ Γ1) x ( :: x0 ++ Γ3 ++ Γ4)).
+      pose (app_assoc Γ0 Γ1 x). rewrite <- e2 in e1. rewrite <- e1.
+      pose (app_assoc Γ0 Γ1 (x ++ :: x0 ++ Γ3 ++ Γ4)). rewrite <- e3.
+      reflexivity. rewrite E. apply BotLRule_I.
+    * destruct s.
+      { destruct s. destruct s. rewrite e.
+        assert (E: Γ0 ++ (x ++ :: x0) ++ Γ2 ++ Γ3 ++ Γ4 =
+        (Γ0 ++ x) ++ :: x0 ++ Γ2 ++ Γ3 ++ Γ4).
+        pose (app_assoc x ( :: x0) (Γ2 ++ Γ3 ++ Γ4)).
+        rewrite <- e0. simpl.
+        pose (app_assoc Γ0 x ( :: x0 ++ Γ2 ++ Γ3 ++ Γ4)).
+        rewrite <- e1. reflexivity. rewrite E. apply BotLRule_I. }
+      { destruct s. destruct s. rewrite e.
+        assert (E: Γ0 ++ Γ1 ++ Γ2 ++ Γ3 ++ x ++ :: x0 =
+        (Γ0 ++ Γ1 ++ Γ2 ++ Γ3 ++ x) ++ :: x0).
+        pose (app_assoc (Γ0 ++ Γ1 ++ Γ2 ++ Γ3) x ( :: x0)).
+        pose (app_assoc (Γ0 ++ Γ1 ++ Γ2) Γ3 x).
+        pose (app_assoc (Γ0 ++ Γ1) Γ2 Γ3).
+        pose (app_assoc Γ0 Γ1 Γ2).
+        rewrite <- e3 in e2. rewrite <- e2 in e1.
+        pose (app_assoc Γ0 Γ1 (Γ2 ++ Γ3)).
+        rewrite <- e4 in e1. rewrite <- e1 in e0.
+        pose (app_assoc (Γ0 ++ Γ1) Γ2 (Γ3 ++ x)).
+        rewrite <- e3 in e5. rewrite <- e5 in e0.
+        pose (app_assoc Γ0 Γ1 (Γ2 ++ Γ3 ++ x)).
+        rewrite <- e6 in e0. rewrite <- e0.
+        pose (app_assoc (Γ0 ++ Γ1 ++ Γ2) Γ3 (x ++ :: x0)).
+        pose (app_assoc (Γ0 ++ Γ1) Γ2 Γ3).
+        rewrite <- e3 in e8. rewrite <- e8 in e7.
+        pose (app_assoc Γ0 Γ1 (Γ2 ++ Γ3)). rewrite <- e9 in e7.
+        rewrite <- e7.
+        pose (app_assoc (Γ0 ++ Γ1) Γ2 (Γ3 ++ x ++ :: x0)).
+        rewrite <- e3 in e10. rewrite <- e10.
+        pose (app_assoc Γ0 Γ1 (Γ2 ++ Γ3 ++ x ++ :: x0)).
+        rewrite <- e11. reflexivity.
+        rewrite E. apply BotLRule_I. }
+Qed.
+ +
+Lemma list_exch_R_IdP_notapplic : forall s se,
+    (@list_exch_R s se) ->
+    ((IdPRule [] s) -> False) ->
+    ((IdPRule [] se) -> False).
+Proof.
+intros s se exch. induction exch. intros RA RAe. apply RA.
+inversion RAe. symmetry in H1. apply partition_1_element in H1.
+destruct H1.
+- destruct s. destruct s. rewrite e.
+  assert (E: (x ++ # P :: x0) ++ Δ1 ++ Δ2 ++ Δ3 ++ Δ4 =
+  x ++ # P :: x0 ++ Δ1 ++ Δ2 ++ Δ3 ++ Δ4).
+  pose (app_assoc x (# P :: x0) (Δ1 ++ Δ2 ++ Δ3 ++ Δ4)). rewrite <- e0.
+  auto. rewrite E. apply IdPRule_I.
+- destruct s.
+  + destruct s. destruct s. rewrite e.
+    assert (E: Δ0 ++ Δ1 ++ Δ2 ++ (x ++ # P :: x0) ++ Δ4 =
+    Δ0 ++ Δ1 ++ Δ2 ++ x ++ # P :: x0 ++ Δ4).
+    pose (app_assoc x (# P :: x0) Δ4).
+    simpl in e0. rewrite <- e0. reflexivity. rewrite E.
+    assert (E1: Δ0 ++ Δ1 ++ Δ2 ++ x ++ # P :: x0 ++ Δ4 =
+    (Δ0 ++ Δ1 ++ Δ2 ++ x) ++ # P :: x0 ++ Δ4).
+    pose (app_assoc (Δ0 ++ Δ1 ++ Δ2) x (# P :: x0 ++ Δ4)).
+    pose (app_assoc (Δ0 ++ Δ1) Δ2 x).
+    pose (app_assoc Δ0 Δ1 Δ2). rewrite <- e2 in e1. rewrite <- e1 in e0.
+    pose (app_assoc Δ0 Δ1 (Δ2 ++ x)). rewrite <- e3 in e0. rewrite <- e0.
+    pose (app_assoc (Δ0 ++ Δ1) Δ2 (x ++ # P :: x0 ++ Δ4)). rewrite <- e2 in e4.
+    rewrite <- e4.
+    pose (app_assoc Δ0 Δ1 (Δ2 ++ x ++ # P :: x0 ++ Δ4)). rewrite e5. reflexivity.
+    rewrite E1. apply IdPRule_I.
+  + destruct s.
+    * destruct s. destruct s. rewrite e.
+      assert (E: Δ0 ++ Δ1 ++ (x ++ # P :: x0) ++ Δ3 ++ Δ4 =
+      (Δ0 ++ Δ1 ++ x) ++ # P :: x0 ++ Δ3 ++ Δ4).
+      pose (app_assoc x (# P :: x0) (Δ3 ++ Δ4)). rewrite <- e0. simpl.
+      pose (app_assoc (Δ0 ++ Δ1) x (# P :: x0 ++ Δ3 ++ Δ4)).
+      pose (app_assoc Δ0 Δ1 x). rewrite <- e2 in e1. rewrite <- e1.
+      pose (app_assoc Δ0 Δ1 (x ++ # P :: x0 ++ Δ3 ++ Δ4)). rewrite <- e3.
+      reflexivity. rewrite E. apply IdPRule_I.
+    * destruct s.
+      { destruct s. destruct s. rewrite e.
+        assert (E: Δ0 ++ (x ++ # P :: x0) ++ Δ2 ++ Δ3 ++ Δ4 =
+        (Δ0 ++ x) ++ # P :: x0 ++ Δ2 ++ Δ3 ++ Δ4).
+        pose (app_assoc x (# P :: x0) (Δ2 ++ Δ3 ++ Δ4)).
+        rewrite <- e0. simpl.
+        pose (app_assoc Δ0 x (# P :: x0 ++ Δ2 ++ Δ3 ++ Δ4)).
+        rewrite <- e1. reflexivity. rewrite E. apply IdPRule_I. }
+      { destruct s. destruct s. rewrite e.
+        assert (E: Δ0 ++ Δ1 ++ Δ2 ++ Δ3 ++ x ++ # P :: x0 =
+        (Δ0 ++ Δ1 ++ Δ2 ++ Δ3 ++ x) ++ # P :: x0).
+        pose (app_assoc (Δ0 ++ Δ1 ++ Δ2 ++ Δ3) x (# P :: x0)).
+        pose (app_assoc (Δ0 ++ Δ1 ++ Δ2) Δ3 x).
+        pose (app_assoc (Δ0 ++ Δ1) Δ2 Δ3).
+        pose (app_assoc Δ0 Δ1 Δ2).
+        rewrite <- e3 in e2. rewrite <- e2 in e1.
+        pose (app_assoc Δ0 Δ1 (Δ2 ++ Δ3)).
+        rewrite <- e4 in e1. rewrite <- e1 in e0.
+        pose (app_assoc (Δ0 ++ Δ1) Δ2 (Δ3 ++ x)).
+        rewrite <- e3 in e5. rewrite <- e5 in e0.
+        pose (app_assoc Δ0 Δ1 (Δ2 ++ Δ3 ++ x)).
+        rewrite <- e6 in e0. rewrite <- e0.
+        pose (app_assoc (Δ0 ++ Δ1 ++ Δ2) Δ3 (x ++ # P :: x0)).
+        pose (app_assoc (Δ0 ++ Δ1) Δ2 Δ3).
+        rewrite <- e3 in e8. rewrite <- e8 in e7.
+        pose (app_assoc Δ0 Δ1 (Δ2 ++ Δ3)). rewrite <- e9 in e7.
+        rewrite <- e7.
+        pose (app_assoc (Δ0 ++ Δ1) Δ2 (Δ3 ++ x ++ # P :: x0)).
+        rewrite <- e3 in e10. rewrite <- e10.
+        pose (app_assoc Δ0 Δ1 (Δ2 ++ Δ3 ++ x ++ # P :: x0)).
+        rewrite <- e11. reflexivity.
+        rewrite E. apply IdPRule_I. }
+Qed.
+ +
+Lemma list_exch_R_IdB_notapplic : forall s se,
+    (@list_exch_R s se) ->
+    ((IdBRule [] s) -> False) ->
+    ((IdBRule [] se) -> False).
+Proof.
+intros s se exch. induction exch. intros RA RAe. apply RA.
+inversion RAe. symmetry in H1. apply partition_1_element in H1.
+destruct H1.
+- destruct s. destruct s. rewrite e.
+  assert (E: (x ++ Box A :: x0) ++ Δ1 ++ Δ2 ++ Δ3 ++ Δ4 =
+  x ++ Box A :: x0 ++ Δ1 ++ Δ2 ++ Δ3 ++ Δ4).
+  pose (app_assoc x (Box A :: x0) (Δ1 ++ Δ2 ++ Δ3 ++ Δ4)). rewrite <- e0.
+  auto. rewrite E. apply IdBRule_I.
+- destruct s.
+  + destruct s. destruct s. rewrite e.
+    assert (E: Δ0 ++ Δ1 ++ Δ2 ++ (x ++ Box A :: x0) ++ Δ4 =
+    Δ0 ++ Δ1 ++ Δ2 ++ x ++ Box A :: x0 ++ Δ4).
+    pose (app_assoc x (Box A :: x0) Δ4).
+    simpl in e0. rewrite <- e0. reflexivity. rewrite E.
+    assert (E1: Δ0 ++ Δ1 ++ Δ2 ++ x ++ Box A :: x0 ++ Δ4 =
+    (Δ0 ++ Δ1 ++ Δ2 ++ x) ++ Box A :: x0 ++ Δ4).
+    pose (app_assoc (Δ0 ++ Δ1 ++ Δ2) x (Box A :: x0 ++ Δ4)).
+    pose (app_assoc (Δ0 ++ Δ1) Δ2 x).
+    pose (app_assoc Δ0 Δ1 Δ2). rewrite <- e2 in e1. rewrite <- e1 in e0.
+    pose (app_assoc Δ0 Δ1 (Δ2 ++ x)). rewrite <- e3 in e0. rewrite <- e0.
+    pose (app_assoc (Δ0 ++ Δ1) Δ2 (x ++ Box A :: x0 ++ Δ4)). rewrite <- e2 in e4.
+    rewrite <- e4.
+    pose (app_assoc Δ0 Δ1 (Δ2 ++ x ++ Box A :: x0 ++ Δ4)). rewrite e5. reflexivity.
+    rewrite E1. apply IdBRule_I.
+  + destruct s.
+    * destruct s. destruct s. rewrite e.
+      assert (E: Δ0 ++ Δ1 ++ (x ++ Box A :: x0) ++ Δ3 ++ Δ4 =
+      (Δ0 ++ Δ1 ++ x) ++ Box A :: x0 ++ Δ3 ++ Δ4).
+      pose (app_assoc x (Box A :: x0) (Δ3 ++ Δ4)). rewrite <- e0. simpl.
+      pose (app_assoc (Δ0 ++ Δ1) x (Box A :: x0 ++ Δ3 ++ Δ4)).
+      pose (app_assoc Δ0 Δ1 x). rewrite <- e2 in e1. rewrite <- e1.
+      pose (app_assoc Δ0 Δ1 (x ++ Box A :: x0 ++ Δ3 ++ Δ4)). rewrite <- e3.
+      reflexivity. rewrite E. apply IdBRule_I.
+    * destruct s.
+      { destruct s. destruct s. rewrite e.
+        assert (E: Δ0 ++ (x ++ Box A :: x0) ++ Δ2 ++ Δ3 ++ Δ4 =
+        (Δ0 ++ x) ++ Box A :: x0 ++ Δ2 ++ Δ3 ++ Δ4).
+        pose (app_assoc x (Box A :: x0) (Δ2 ++ Δ3 ++ Δ4)).
+        rewrite <- e0. simpl.
+        pose (app_assoc Δ0 x (Box A :: x0 ++ Δ2 ++ Δ3 ++ Δ4)).
+        rewrite <- e1. reflexivity. rewrite E. apply IdBRule_I. }
+      { destruct s. destruct s. rewrite e.
+        assert (E: Δ0 ++ Δ1 ++ Δ2 ++ Δ3 ++ x ++ Box A :: x0 =
+        (Δ0 ++ Δ1 ++ Δ2 ++ Δ3 ++ x) ++ Box A :: x0).
+        pose (app_assoc (Δ0 ++ Δ1 ++ Δ2 ++ Δ3) x (Box A :: x0)).
+        pose (app_assoc (Δ0 ++ Δ1 ++ Δ2) Δ3 x).
+        pose (app_assoc (Δ0 ++ Δ1) Δ2 Δ3).
+        pose (app_assoc Δ0 Δ1 Δ2).
+        rewrite <- e3 in e2. rewrite <- e2 in e1.
+        pose (app_assoc Δ0 Δ1 (Δ2 ++ Δ3)).
+        rewrite <- e4 in e1. rewrite <- e1 in e0.
+        pose (app_assoc (Δ0 ++ Δ1) Δ2 (Δ3 ++ x)).
+        rewrite <- e3 in e5. rewrite <- e5 in e0.
+        pose (app_assoc Δ0 Δ1 (Δ2 ++ Δ3 ++ x)).
+        rewrite <- e6 in e0. rewrite <- e0.
+        pose (app_assoc (Δ0 ++ Δ1 ++ Δ2) Δ3 (x ++ Box A :: x0)).
+        pose (app_assoc (Δ0 ++ Δ1) Δ2 Δ3).
+        rewrite <- e3 in e8. rewrite <- e8 in e7.
+        pose (app_assoc Δ0 Δ1 (Δ2 ++ Δ3)). rewrite <- e9 in e7.
+        rewrite <- e7.
+        pose (app_assoc (Δ0 ++ Δ1) Δ2 (Δ3 ++ x ++ Box A :: x0)).
+        rewrite <- e3 in e10. rewrite <- e10.
+        pose (app_assoc Δ0 Δ1 (Δ2 ++ Δ3 ++ x ++ Box A :: x0)).
+        rewrite <- e11. reflexivity.
+        rewrite E. apply IdBRule_I. }
+Qed.
+ +
+Lemma list_exch_R_BotL_notapplic : forall s se,
+    (@list_exch_R s se) ->
+    ((BotLRule [] s) -> False) ->
+    ((BotLRule [] se) -> False).
+Proof.
+intros s se exch RA RAe. apply RA.
+inversion RAe. destruct s.
+apply list_exch_R_same_L with (Γ:=l) (Γe:=Γ0 ++ :: Γ1) (Δ:=l0) (Δe:=Δ) in exch.
+subst. apply BotLRule_I. reflexivity. symmetry. assumption.
+Qed.
+ +
+(* The following lemmas make sure that if a rule is applied on a sequent s with
+premises ps, then the same rule is applicable on a sequent se which is an exchanged
+version of s, with some premises pse that are such that they are exchanged versions
+of ps. *)

+ +
+Lemma ImpR_app_list_exchL : forall s se ps,
+  (@list_exch_L s se) ->
+  (ImpRRule [ps] s) ->
+  (existsT2 pse,
+    (ImpRRule [pse] se) *
+    (@list_exch_L ps pse)).
+Proof.
+intros s se ps exch. intro RA. inversion RA. inversion exch. subst.
+inversion H. apply app2_find_hole in H1. destruct H1. repeat destruct s ; destruct p ; subst.
+- exists (Γ2 ++ A :: Γ5 ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ B :: Δ1). split.
+  apply ImpRRule_I. assert (Γ2 ++ A :: Γ3 ++ Γ4 ++ Γ5 ++ Γ6 = (Γ2 ++ [A]) ++ Γ3 ++ Γ4 ++ Γ5 ++ Γ6).
+  rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+  assert (Γ2 ++ A :: Γ5 ++ Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ [A]) ++ Γ5 ++ Γ4 ++ Γ3 ++ Γ6).
+  rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+- apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+  + exists ((Γ2 ++ Γ5) ++ A :: Γ4 ++ Γ3 ++ Γ6, Δ0 ++ B :: Δ1). split.
+    assert (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ Γ5) ++ Γ4 ++ Γ3 ++ Γ6). rewrite app_assoc.
+    reflexivity. rewrite H0. clear H0. apply ImpRRule_I. repeat rewrite <- app_assoc.
+    assert (Γ2 ++ Γ3 ++ A :: Γ4 ++ Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ (A :: Γ4) ++ Γ5 ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ Γ5 ++ A :: Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ Γ5 ++ (A :: Γ4) ++ Γ3 ++ Γ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+  + apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+    * exists ((Γ2 ++ Γ5 ++ Γ4) ++ A :: Γ3 ++ Γ6, Δ0 ++ B :: Δ1). split.
+      assert (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ Γ5 ++ Γ4) ++ Γ3 ++ Γ6). repeat rewrite app_assoc.
+      reflexivity. rewrite H0. clear H0. apply ImpRRule_I. repeat rewrite <- app_assoc.
+      assert (Γ2 ++ Γ3 ++ Γ4 ++ A :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ (Γ4 ++ [A]) ++ Γ5 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ Γ5 ++ Γ4 ++ A :: Γ3 ++ Γ6 = Γ2 ++ Γ5 ++ (Γ4 ++ [A]) ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    * apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+      { repeat rewrite <- app_assoc. exists (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ A :: Γ6, Δ0 ++ B :: Δ1).
+        split. repeat rewrite app_assoc. apply ImpRRule_I. apply list_exch_LI. }
+      { repeat rewrite <- app_assoc. exists (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ x0 ++ A :: Γ1, Δ0 ++ B :: Δ1).
+        split. repeat rewrite app_assoc. apply ImpRRule_I. apply list_exch_LI. }
+      { repeat rewrite <- app_assoc. exists (Γ2 ++ (x ++ A :: x0) ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ B :: Δ1).
+        split. assert (Γ2 ++ (x ++ A :: x0) ++ Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ x) ++ A :: x0 ++ Γ4 ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ x ++ x0 ++ Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ x) ++ x0 ++ Γ4 ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        apply ImpRRule_I.
+        assert (Γ2 ++ Γ3 ++ Γ4 ++ x ++ A :: x0 ++ Γ6 = Γ2 ++ Γ3 ++ Γ4 ++ (x ++ A :: x0) ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_LI. }
+    * repeat rewrite <- app_assoc. exists (Γ2 ++ Γ5 ++ (x0 ++ A :: x) ++ Γ3 ++ Γ6, Δ0 ++ B :: Δ1).
+      split. assert (Γ2 ++ Γ5 ++ (x0 ++ A :: x) ++ Γ3 ++ Γ6 = (Γ2 ++ Γ5 ++ x0) ++ A :: x ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ Γ5 ++ x0 ++ x ++ Γ3 ++ Γ6 = (Γ2 ++ Γ5 ++ x0) ++ x ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      apply ImpRRule_I.
+      assert (Γ2 ++ Γ3 ++ x0 ++ A :: x ++ Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ (x0 ++ A :: x) ++ Γ5 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_LI.
+  + repeat rewrite <- app_assoc. exists (Γ2 ++ Γ5 ++ Γ4 ++ (x ++ A :: x0) ++ Γ6, Δ0 ++ B :: Δ1).
+    split. assert (Γ2 ++ Γ5 ++ Γ4 ++ (x ++ A :: x0) ++ Γ6 = (Γ2 ++ Γ5 ++ Γ4 ++ x) ++ A :: x0 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ Γ5 ++ Γ4 ++ x ++ x0 ++ Γ6 = (Γ2 ++ Γ5 ++ Γ4 ++ x) ++ x0 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpRRule_I.
+    assert (Γ2 ++ x ++ A :: x0 ++ Γ4 ++ Γ5 ++ Γ6 = Γ2 ++ (x ++ A :: x0) ++ Γ4 ++ Γ5 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_LI.
+- repeat rewrite <- app_assoc. exists (Γ0 ++ A :: x ++ Γ5 ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ B :: Δ1).
+  split. apply ImpRRule_I.
+  assert (Γ0 ++ A :: x ++ Γ3 ++ Γ4 ++ Γ5 ++ Γ6 = (Γ0 ++ A :: x) ++ Γ3 ++ Γ4 ++ Γ5 ++ Γ6).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+  assert (Γ0 ++ A :: x ++ Γ5 ++ Γ4 ++ Γ3 ++ Γ6 = (Γ0 ++ A :: x) ++ Γ5 ++ Γ4 ++ Γ3 ++ Γ6).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+Qed.
+ +
+Lemma ImpL_app_list_exchL : forall s se ps1 ps2,
+  (@list_exch_L s se) ->
+  (ImpLRule [ps1;ps2] s) ->
+  (existsT2 pse1 pse2,
+    (ImpLRule [pse1;pse2] se) *
+    (@list_exch_L ps1 pse1) *
+    (@list_exch_L ps2 pse2)).
+Proof.
+intros s se ps1 ps2 exch. intro RA. inversion RA. inversion exch. subst.
+inversion H. apply app2_find_hole in H1. destruct H1. repeat destruct s ; destruct p ; subst.
+- destruct Γ3 ; destruct Γ4 ; destruct Γ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+  + exists (Γ2 ++ Γ1, Δ0 ++ A :: Δ1). exists (Γ2 ++ B :: Γ1, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  + exists (Γ2 ++ Γ5 ++ Γ6, Δ0 ++ A :: Δ1). exists (Γ2 ++ B :: Γ5 ++ Γ6, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  + exists (Γ2 ++ Γ4 ++ Γ6, Δ0 ++ A :: Δ1). exists (Γ2 ++ B :: Γ4 ++ Γ6, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  + exists (Γ2 ++ (m0 :: Γ5) ++ Γ4 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ2 ++ (m0 :: Γ5) ++ B :: Γ4 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ2 ++ (m0 :: Γ5) ++ B :: Γ4 ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ B :: Γ4 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m0 :: Γ5 ++ A --> B :: Γ4 ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ A --> B :: Γ4 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ (m0 :: Γ5) ++ Γ4 ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ Γ4 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpLRule_I.
+    assert (Γ2 ++ Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ [] ++ Γ4 ++ (m0 :: Γ5) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ (m0 :: Γ5) ++ Γ4 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ Γ4 ++ [] ++ Γ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ2 ++ B :: Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ [] ++ (B :: Γ4) ++ (m0 :: Γ5) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ (m0 :: Γ5) ++ B :: Γ4 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ (B :: Γ4) ++ [] ++ Γ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+  + exists (Γ2 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1). exists (Γ2 ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  + exists (Γ2 ++ (m0 :: Γ5) ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ2 ++ (m0 :: Γ5) ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ2 ++ m0 :: Γ5 ++ A --> B :: Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ A --> B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ (m0 :: Γ5) ++ B :: Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ (m0 :: Γ5) ++ Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpLRule_I.
+    assert (Γ2 ++ Γ3 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ (m0 :: Γ5) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ (m0 :: Γ5) ++ Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ [] ++ Γ3 ++ Γ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ2 ++ B :: Γ3 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ (B :: Γ3) ++ [] ++ (m0 :: Γ5) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ (m0 :: Γ5) ++ B :: Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ [] ++ (B :: Γ3) ++ Γ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+  + exists (Γ2 ++ m0 :: Γ4 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ2 ++ m0 :: Γ4 ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ2 ++ m0 :: Γ4 ++ A --> B :: Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ4) ++ A --> B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m0 :: Γ4 ++ B :: Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ4) ++ B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m0 :: Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ4) ++ Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+    assert (Γ2 ++ Γ3 ++ m0 :: Γ4 ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ (m0 :: Γ4) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m0 :: Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ4) ++ [] ++ Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ2 ++ B :: Γ3 ++ m0 :: Γ4 ++ Γ6 = Γ2 ++ (B :: Γ3) ++ [] ++ (m0 :: Γ4) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m0 :: Γ4 ++ B :: Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ4) ++ [] ++ (B :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+  + exists (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ A --> B :: Γ3 ++ Γ6 = (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ A --> B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ B :: Γ3 ++ Γ6 = (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpLRule_I.
+    assert (Γ2 ++ Γ3 ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ (m0 :: Γ4) ++ (m1 :: Γ5) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (m1 :: Γ5) ++ (m0 :: Γ4) ++ Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ2 ++ B :: Γ3 ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = Γ2 ++ (B :: Γ3) ++ (m0 :: Γ4) ++ (m1 :: Γ5) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ B :: Γ3 ++ Γ6 = Γ2 ++ (m1 :: Γ5) ++ (m0 :: Γ4) ++ (B :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+- apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+  + destruct Γ4 ; destruct Γ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+    * rewrite app_assoc. exists ((Γ2 ++ Γ3) ++ Γ1, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ Γ3) ++ B :: Γ1, Δ0 ++ Δ1). split. split ; try assumption. apply list_exch_L_id.
+      apply list_exch_L_id.
+    * exists (Γ2 ++ Γ5 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+      exists (Γ2 ++ B :: Γ5 ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split. apply ImpLRule_I.
+      assert ((Γ2 ++ Γ3) ++ Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ Γ5 ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ Γ5 ++ Γ3 ++ Γ6 = Γ2 ++ Γ5 ++ [] ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ Γ3) ++ B :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ (B :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ B :: Γ5 ++ Γ3 ++ Γ6 = Γ2 ++ (B :: Γ5) ++ [] ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    * exists (Γ2 ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+      exists (Γ2 ++ B :: Γ4 ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split. apply ImpLRule_I.
+      assert ((Γ2 ++ Γ3) ++ Γ4 ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ Γ4 ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ Γ4 ++ [] ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ Γ3) ++ B :: Γ4 ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ (B :: Γ4) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ B :: Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (B :: Γ4) ++ [] ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    * exists ((Γ2 ++ m0 :: Γ5) ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ m0 :: Γ5) ++ B :: Γ4 ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+      assert (Γ2 ++ m0 :: Γ5 ++ A --> B :: Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ A --> B :: Γ4 ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+      assert ((Γ2 ++ Γ3) ++ Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ Γ4 ++ (m0 :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ5) ++ Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ Γ4 ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ Γ3) ++ B :: Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ (B :: Γ4) ++ (m0 :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ5) ++ B :: Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ (B :: Γ4) ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+  + apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+    * destruct Γ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+      { exists ((Γ2 ++ Γ4 ++ Γ3) ++ Γ1, Δ0 ++ A :: Δ1).
+        exists ((Γ2 ++ Γ4 ++ Γ3) ++ B :: Γ1, Δ0 ++ Δ1). split. split.
+        assert (Γ2 ++ Γ4 ++ Γ3 ++ A --> B :: Γ1 = (Γ2 ++ Γ4 ++ Γ3) ++ A --> B :: Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+        assert ((Γ2 ++ Γ3 ++ Γ4) ++ Γ1 = Γ2 ++ Γ3 ++ [] ++ Γ4 ++ Γ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ Γ4 ++ Γ3) ++ Γ1 = Γ2 ++ Γ4 ++ [] ++ Γ3 ++ Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+        assert ((Γ2 ++ Γ3 ++ Γ4) ++ B :: Γ1 = Γ2 ++ Γ3 ++ [] ++ Γ4 ++ B :: Γ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ Γ4 ++ Γ3) ++ B :: Γ1 = Γ2 ++ Γ4 ++ [] ++ Γ3 ++ B :: Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI. }
+      { exists (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+        exists (Γ2 ++ B :: Γ5 ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split. apply ImpLRule_I.
+        repeat rewrite <- app_assoc. apply list_exch_LI.
+        assert ((Γ2 ++ Γ3 ++ Γ4) ++ B :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ Γ4 ++ (B :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ B :: Γ5 ++ Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (B :: Γ5) ++ Γ4 ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI. }
+    * apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+      { exists ((Γ2 ++ Γ5 ++ Γ4 ++ Γ3) ++ Γ1, Δ0 ++ A :: Δ1).
+        exists ((Γ2 ++ Γ5 ++ Γ4 ++ Γ3) ++ B :: Γ1, Δ0 ++ Δ1). split. split.
+        assert (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ A --> B :: Γ1 = (Γ2 ++ Γ5 ++ Γ4 ++ Γ3) ++ A --> B :: Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+        repeat rewrite <- app_assoc. apply list_exch_LI. repeat rewrite <- app_assoc. apply list_exch_LI. }
+      { exists ((Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ x0) ++ Γ1, Δ0 ++ A :: Δ1).
+        exists ((Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ x0) ++ B :: Γ1, Δ0 ++ Δ1). split. split.
+        assert (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ x0 ++ A --> B :: Γ1 = (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ x0) ++ A --> B :: Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+        repeat rewrite <- app_assoc. apply list_exch_LI. repeat rewrite <- app_assoc. apply list_exch_LI. }
+      { destruct x0.
+        - simpl in e0. subst. rewrite app_nil_r.
+          exists ((Γ2 ++ x ++ Γ4 ++ Γ3) ++ Γ1, Δ0 ++ A :: Δ1).
+          exists ((Γ2 ++ x ++ Γ4 ++ Γ3) ++ B :: Γ1, Δ0 ++ Δ1). split. split.
+          assert (Γ2 ++ x ++ Γ4 ++ Γ3 ++ A --> B :: Γ1 = (Γ2 ++ x ++ Γ4 ++ Γ3) ++ A --> B :: Γ1).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+          repeat rewrite <- app_assoc. apply list_exch_LI. repeat rewrite <- app_assoc. apply list_exch_LI.
+        - inversion e0. subst.
+          exists ((Γ2 ++ x) ++ x0 ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+          exists ((Γ2 ++ x) ++ B :: x0 ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+          assert (Γ2 ++ (x ++ A --> B :: x0) ++ Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ x) ++ A --> B :: x0 ++ Γ4 ++ Γ3 ++ Γ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+          assert ((Γ2 ++ Γ3 ++ Γ4 ++ x) ++ x0 ++ Γ6 = Γ2 ++ Γ3 ++ Γ4 ++ (x ++ x0) ++ Γ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+          assert ((Γ2 ++ x) ++ x0 ++ Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (x ++ x0) ++ Γ4 ++ Γ3 ++ Γ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+          apply list_exch_LI.
+          assert ((Γ2 ++ Γ3 ++ Γ4 ++ x) ++ B :: x0 ++ Γ6 = Γ2 ++ Γ3 ++ Γ4 ++ (x ++ B :: x0) ++ Γ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+          assert ((Γ2 ++ x) ++ B :: x0 ++ Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (x ++ B :: x0) ++ Γ4 ++ Γ3 ++ Γ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+          apply list_exch_LI. }
+    * destruct x ; destruct Γ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+      { rewrite app_nil_r. exists ((Γ2 ++ x0 ++ Γ3) ++ Γ1, Δ0 ++ A :: Δ1).
+        exists ((Γ2 ++ x0 ++ Γ3) ++ B :: Γ1, Δ0 ++ Δ1). split. split.
+        assert (Γ2 ++ x0 ++ Γ3 ++ A --> B :: Γ1 = (Γ2 ++ x0 ++ Γ3) ++ A --> B :: Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        assert ((Γ2 ++ Γ3 ++ x0) ++ Γ1 = Γ2 ++ Γ3 ++ [] ++ x0 ++ Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ x0 ++ Γ3) ++ Γ1 = Γ2 ++ x0 ++ [] ++ Γ3 ++ Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+        assert ((Γ2 ++ Γ3 ++ x0) ++ B :: Γ1 = Γ2 ++ Γ3 ++ [] ++ x0 ++ B :: Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ x0 ++ Γ3) ++ B :: Γ1 = Γ2 ++ x0 ++ [] ++ Γ3 ++ B :: Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI. }
+      { rewrite app_nil_r. exists (Γ2 ++ Γ5 ++ x0 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+        exists (Γ2 ++ B :: Γ5 ++ x0 ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+        apply ImpLRule_I. repeat rewrite <- app_assoc. apply list_exch_LI.
+        assert ((Γ2 ++ Γ3 ++ x0) ++ B :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ x0 ++ (B :: Γ5) ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ B :: Γ5 ++ x0 ++ Γ3 ++ Γ6 = Γ2 ++ (B :: Γ5) ++ x0 ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI. }
+      { exists ((Γ2 ++ x0) ++ x ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+        exists ((Γ2 ++ x0) ++ B :: x ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+        assert (Γ2 ++ (x0 ++ A --> B :: x) ++ Γ3 ++ Γ6 = (Γ2 ++ x0) ++ A --> B :: x ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        assert ((Γ2 ++ Γ3 ++ x0) ++ x ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ (x0 ++ x) ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ x0) ++ x ++ Γ3 ++ Γ6 = Γ2 ++ (x0 ++ x) ++ [] ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+        assert ((Γ2 ++ Γ3 ++ x0) ++ B :: x ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ (x0 ++ B :: x) ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ x0) ++ B :: x ++ Γ3 ++ Γ6 = Γ2 ++ (x0 ++ B :: x) ++ [] ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI. }
+      { exists ((Γ2 ++ m0 :: Γ5 ++ x0) ++ x ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+        exists ((Γ2 ++ m0 :: Γ5 ++ x0) ++ B :: x ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+        assert (Γ2 ++ m0 :: Γ5 ++ (x0 ++ A --> B :: x) ++ Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ5 ++ x0) ++ A --> B :: x ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        assert ((Γ2 ++ Γ3 ++ x0) ++ x ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ (x0 ++ x) ++ (m0 :: Γ5) ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ m0 :: Γ5 ++ x0) ++ x ++ Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ (x0 ++ x) ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        apply list_exch_LI.
+        assert ((Γ2 ++ Γ3 ++ x0) ++ B :: x ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ (x0 ++ B :: x) ++ (m0 :: Γ5) ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ m0 :: Γ5 ++ x0) ++ B :: x ++ Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ (x0 ++ B :: x) ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        apply list_exch_LI. }
+  + destruct x0 ; destruct Γ4 ; destruct Γ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+    * rewrite app_nil_r. rewrite app_assoc. exists ((Γ2 ++ x) ++ Γ1, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ x) ++ B :: Γ1, Δ0 ++ Δ1). split. split ; try assumption. apply list_exch_L_id. apply list_exch_L_id.
+    * rewrite app_nil_r. exists (Γ2 ++ Γ5 ++ x ++ Γ6, Δ0 ++ A :: Δ1).
+      exists (Γ2 ++ B :: Γ5 ++ x ++ Γ6, Δ0 ++ Δ1). split. split. apply ImpLRule_I.
+      assert ((Γ2 ++ x) ++ Γ5 ++ Γ6 = Γ2 ++ x ++ [] ++ Γ5 ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ Γ5 ++ x ++ Γ6 = Γ2 ++ Γ5 ++ [] ++ x ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ x) ++ B :: Γ5 ++ Γ6 = Γ2 ++ x ++ [] ++ (B :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ B :: Γ5 ++ x ++ Γ6 = Γ2 ++ (B :: Γ5) ++ [] ++ x ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    * rewrite app_nil_r. exists (Γ2 ++ Γ4 ++ x ++ Γ6, Δ0 ++ A :: Δ1).
+      exists (Γ2 ++ B :: Γ4 ++ x ++ Γ6, Δ0 ++ Δ1). split. split. apply ImpLRule_I.
+      assert ((Γ2 ++ x) ++ Γ4 ++ Γ6 = Γ2 ++ x ++ [] ++ Γ4 ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ Γ4 ++ x ++ Γ6 = Γ2 ++ Γ4 ++ [] ++ x ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ x) ++ B :: Γ4 ++ Γ6 = Γ2 ++ x ++ [] ++ (B :: Γ4) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ B :: Γ4 ++ x ++ Γ6 = Γ2 ++ (B :: Γ4) ++ [] ++ x ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    * rewrite app_nil_r. exists ((Γ2 ++ m0 :: Γ5) ++ Γ4 ++ x ++ Γ6, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ m0 :: Γ5) ++ B :: Γ4 ++ x ++ Γ6, Δ0 ++ Δ1). split. split.
+      assert (Γ2 ++ m0 :: Γ5 ++ A --> B :: Γ4 ++ x ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ A --> B :: Γ4 ++ x ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+      assert ((Γ2 ++ x) ++ Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ x ++ Γ4 ++ (m0 :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ5) ++ Γ4 ++ x ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ Γ4 ++ x ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ x) ++ B :: Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ x ++ (B :: Γ4) ++ (m0 :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ5) ++ B :: Γ4 ++ x ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ (B :: Γ4) ++ x ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    * exists ((Γ2 ++ x) ++ x0 ++ Γ6, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ x) ++ B :: x0 ++ Γ6, Δ0 ++ Δ1). split. split.
+      assert (Γ2 ++ (x ++ A --> B :: x0) ++ Γ6 = (Γ2 ++ x) ++ A --> B :: x0 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+      apply list_exch_L_id. apply list_exch_L_id.
+    * exists ((Γ2 ++ m0 :: Γ5 ++ x) ++ x0 ++ Γ6, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ m0 :: Γ5 ++ x) ++ B :: x0 ++ Γ6, Δ0 ++ Δ1). split. split.
+      assert (Γ2 ++ m0 :: Γ5 ++ (x ++ A --> B :: x0) ++ Γ6 = (Γ2 ++ m0 :: Γ5 ++ x) ++ A --> B :: x0 ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+      assert ((Γ2 ++ x) ++ x0 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ [] ++ (x ++ x0) ++ (m0 :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ5 ++ x) ++ x0 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ (x ++ x0) ++ [] ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ x) ++ B :: x0 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ [] ++ (x ++ B :: x0) ++ (m0 :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ5 ++ x) ++ B :: x0 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ (x ++ B :: x0) ++ [] ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_LI.
+    * exists ((Γ2 ++ m0 :: Γ4 ++ x) ++ x0 ++ Γ6, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ m0 :: Γ4 ++ x) ++ B :: x0 ++ Γ6, Δ0 ++ Δ1). split. split.
+      assert (Γ2 ++ m0 :: Γ4 ++ (x ++ A --> B :: x0) ++ Γ6 = (Γ2 ++ m0 :: Γ4 ++ x) ++ A --> B :: x0 ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+      assert ((Γ2 ++ x) ++ x0 ++ m0 :: Γ4 ++ Γ6 = Γ2 ++ [] ++ (x ++ x0) ++ (m0 :: Γ4) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ4 ++ x) ++ x0 ++ Γ6 = Γ2 ++ (m0 :: Γ4) ++ (x ++ x0) ++ [] ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ x) ++ B :: x0 ++ m0 :: Γ4 ++ Γ6 = Γ2 ++ [] ++ (x ++ B :: x0) ++ (m0 :: Γ4) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ4 ++ x) ++ B :: x0 ++ Γ6 = Γ2 ++ (m0 :: Γ4) ++ (x ++ B :: x0) ++ [] ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_LI.
+    * exists ((Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ x) ++ x0 ++ Γ6, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ x) ++ B :: x0 ++ Γ6, Δ0 ++ Δ1). split. split.
+      assert (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ (x ++ A --> B :: x0) ++ Γ6 = (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ x) ++ A --> B :: x0 ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. simpl.
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+      assert ((Γ2 ++ x) ++ x0 ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = Γ2 ++ (x ++ x0) ++ (m0 :: Γ4) ++ (m1 :: Γ5) ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ x) ++ x0 ++ Γ6 = Γ2 ++ (m1 :: Γ5) ++ (m0 :: Γ4) ++ (x ++ x0) ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ x) ++ B :: x0 ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = Γ2 ++ (x ++ B :: x0) ++ (m0 :: Γ4) ++ (m1 :: Γ5) ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ x) ++ B :: x0 ++ Γ6 = Γ2 ++ (m1 :: Γ5) ++ (m0 :: Γ4) ++ (x ++ B :: x0) ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_LI.
+- destruct x ; destruct Γ3 ; destruct Γ4 ; destruct Γ5 ; simpl ; simpl in e0 ; simpl in exch ;
+  subst ; try inversion e0 ; subst.
+  * rewrite app_nil_r. exists (Γ0 ++ Γ1, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: Γ1, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * rewrite app_nil_r. exists (Γ0 ++ Γ5 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: Γ5 ++ Γ6, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * rewrite app_nil_r. exists (Γ0 ++ Γ4 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: Γ4 ++ Γ6, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * rewrite app_nil_r. exists ((Γ0 ++ m0 :: Γ5) ++ Γ4 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists ((Γ0 ++ m0 :: Γ5) ++ B :: Γ4 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ0 ++ m0 :: Γ5 ++ A --> B :: Γ4 ++ Γ6 = (Γ0 ++ m0 :: Γ5) ++ A --> B :: Γ4 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+    assert (Γ0 ++ Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ0 ++ [] ++ Γ4 ++ (m0 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Γ0 ++ m0 :: Γ5) ++ Γ4 ++ Γ6 = Γ0 ++ (m0 :: Γ5) ++ Γ4 ++ [] ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ0 ++ B :: Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ0 ++ [] ++ (B :: Γ4) ++ (m0 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Γ0 ++ m0 :: Γ5) ++ B :: Γ4 ++ Γ6 = Γ0 ++ (m0 :: Γ5) ++ (B :: Γ4) ++ [] ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+  * rewrite app_nil_r. exists (Γ0 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * rewrite app_nil_r. exists ((Γ0 ++ m0 :: Γ5) ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists ((Γ0 ++ m0 :: Γ5) ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ0 ++ m0 :: Γ5 ++ A --> B :: Γ3 ++ Γ6 = (Γ0 ++ m0 :: Γ5) ++ A --> B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+    assert (Γ0 ++ Γ3 ++ m0 :: Γ5 ++ Γ6 = Γ0 ++ [] ++ Γ3 ++ (m0 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Γ0 ++ m0 :: Γ5) ++ Γ3 ++ Γ6 = Γ0 ++ (m0 :: Γ5) ++ Γ3 ++ [] ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ0 ++ B :: Γ3 ++ m0 :: Γ5 ++ Γ6 = Γ0 ++ [] ++ (B :: Γ3) ++ (m0 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Γ0 ++ m0 :: Γ5) ++ B :: Γ3 ++ Γ6 = Γ0 ++ (m0 :: Γ5) ++ (B :: Γ3) ++ [] ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+  * rewrite app_nil_r. exists ((Γ0 ++ m0 :: Γ4) ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists ((Γ0 ++ m0 :: Γ4) ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ0 ++ m0 :: Γ4 ++ A --> B :: Γ3 ++ Γ6 = (Γ0 ++ m0 :: Γ4) ++ A --> B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+    assert ((Γ0 ++ m0 :: Γ4) ++ Γ3 ++ Γ6 = Γ0 ++ (m0 :: Γ4) ++ Γ3 ++ [] ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ Γ3 ++ m0 :: Γ4 ++ Γ6 = Γ0 ++ [] ++ Γ3 ++ (m0 :: Γ4) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert ((Γ0 ++ m0 :: Γ4) ++ B :: Γ3 ++ Γ6 = Γ0 ++ (m0 :: Γ4) ++ (B :: Γ3) ++ [] ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ B :: Γ3 ++ m0 :: Γ4 ++ Γ6 = Γ0 ++ [] ++ (B :: Γ3) ++ (m0 :: Γ4) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+  * rewrite app_nil_r. exists ((Γ0 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists ((Γ0 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ0 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ A --> B :: Γ3 ++ Γ6 = (Γ0 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ A --> B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+    assert (Γ0 ++ Γ3 ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = Γ0 ++ Γ3 ++ (m0 :: Γ4) ++ (m1 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Γ0 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ Γ3 ++ Γ6 = Γ0 ++ (m1 :: Γ5) ++ (m0 :: Γ4) ++ Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ0 ++ B :: Γ3 ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = Γ0 ++ (B :: Γ3) ++ (m0 :: Γ4) ++ (m1 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Γ0 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ B :: Γ3 ++ Γ6 = Γ0 ++ (m1 :: Γ5) ++ (m0 :: Γ4) ++ (B :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+  * exists (Γ0 ++ x ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ Γ6, Δ0 ++ Δ1). split. split. repeat rewrite <- app_assoc. apply ImpLRule_I.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * exists (Γ0 ++ x ++ m0 :: Γ5 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ m0 :: Γ5 ++ Γ6, Δ0 ++ Δ1). split. split. repeat rewrite <- app_assoc. apply ImpLRule_I.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * exists (Γ0 ++ x ++ m0 :: Γ4 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ m0 :: Γ4 ++ Γ6, Δ0 ++ Δ1). split. split. repeat rewrite <- app_assoc. apply ImpLRule_I.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * exists (Γ0 ++ x ++ m1 :: Γ5 ++ m0 :: Γ4 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ m1 :: Γ5 ++ m0 :: Γ4 ++ Γ6, Δ0 ++ Δ1). split. split.
+    repeat rewrite <- app_assoc. apply ImpLRule_I.
+    assert (Γ0 ++ x ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = (Γ0 ++ x) ++ (m0 :: Γ4) ++ [] ++ (m1 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ x ++ m1 :: Γ5 ++ m0 :: Γ4 ++ Γ6 = (Γ0 ++ x) ++ (m1 :: Γ5) ++ [] ++ (m0 :: Γ4) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ0 ++ B :: x ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = (Γ0 ++ B :: x) ++ (m0 :: Γ4) ++ [] ++ (m1 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ B :: x ++ m1 :: Γ5 ++ m0 :: Γ4 ++ Γ6 = (Γ0 ++ B :: x) ++ (m1 :: Γ5) ++ [] ++ (m0 :: Γ4) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+  * exists (Γ0 ++ x ++ m0 :: Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ m0 :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split. repeat rewrite <- app_assoc. apply ImpLRule_I.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * exists (Γ0 ++ x ++ m1 :: Γ5 ++ m0 :: Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ m1 :: Γ5 ++ m0 :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    repeat rewrite <- app_assoc. apply ImpLRule_I.
+    assert (Γ0 ++ x ++ m0 :: Γ3 ++ m1 :: Γ5 ++ Γ6 = (Γ0 ++ x) ++ (m0 :: Γ3) ++ [] ++ (m1 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ x ++ m1 :: Γ5 ++ m0 :: Γ3 ++ Γ6 = (Γ0 ++ x) ++ (m1 :: Γ5) ++ [] ++ (m0 :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ0 ++ B :: x ++ m0 :: Γ3 ++ m1 :: Γ5 ++ Γ6 = (Γ0 ++ B :: x) ++ (m0 :: Γ3) ++ [] ++ (m1 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ B :: x ++ m1 :: Γ5 ++ m0 :: Γ3 ++ Γ6 = (Γ0 ++ B :: x) ++ (m1 :: Γ5) ++ [] ++ (m0 :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+  * exists (Γ0 ++ x ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    repeat rewrite <- app_assoc. apply ImpLRule_I.
+    assert (Γ0 ++ x ++ m0 :: Γ3 ++ m1 :: Γ4 ++ Γ6 = (Γ0 ++ x) ++ (m0 :: Γ3) ++ [] ++ (m1 :: Γ4) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ x ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6 = (Γ0 ++ x) ++ (m1 :: Γ4) ++ [] ++ (m0 :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ0 ++ B :: x ++ m0 :: Γ3 ++ m1 :: Γ4 ++ Γ6 = (Γ0 ++ B :: x) ++ (m0 :: Γ3) ++ [] ++ (m1 :: Γ4) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ B :: x ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6 = (Γ0 ++ B :: x) ++ (m1 :: Γ4) ++ [] ++ (m0 :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+  * exists (Γ0 ++ x ++ m2 :: Γ5 ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ m2 :: Γ5 ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    repeat rewrite <- app_assoc. apply ImpLRule_I.
+    assert (Γ0 ++ x ++ m0 :: Γ3 ++ m1 :: Γ4 ++ m2 :: Γ5 ++ Γ6 = (Γ0 ++ x) ++ (m0 :: Γ3) ++ (m1 :: Γ4) ++ (m2 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ x ++ m2 :: Γ5 ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6 = (Γ0 ++ x) ++ (m2 :: Γ5) ++ (m1 :: Γ4) ++ (m0 :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ0 ++ B :: x ++ m0 :: Γ3 ++ m1 :: Γ4 ++ m2 :: Γ5 ++ Γ6 = (Γ0 ++ B :: x) ++ (m0 :: Γ3) ++ (m1 :: Γ4) ++ (m2 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ B :: x ++ m2 :: Γ5 ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6 = (Γ0 ++ B :: x) ++ (m2 :: Γ5) ++ (m1 :: Γ4) ++ (m0 :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+Qed.
+ +
+Lemma GLR_app_list_exchL : forall s se ps,
+  (@list_exch_L s se) ->
+  (GLRRule [ps] s) ->
+  (existsT2 pse,
+    (GLRRule [pse] se) *
+    (@list_exch_L ps pse)).
+Proof.
+intros s se ps exch RA. inversion RA. inversion exch. rewrite <- H1 in H2.
+inversion H2. subst.
+pose (@nobox_gen_ext_exch_L (Δ0 ++ Box A :: Δ1) [A] (Γ1 ++ Γ2 ++ Γ3 ++ Γ4 ++ Γ5) (Γ1 ++ Γ4 ++ Γ3 ++ Γ2 ++ Γ5) X exch).
+destruct s. destruct p. inversion l.
+exists (XBoxed_list (Γ0 ++ Γ8 ++ Γ7 ++ Γ6 ++ Γ9) ++ [Box A], [A]). split.
+- apply GLRRule_I.
+  * unfold is_Boxed_list. intros. apply in_exch_list in H4. subst. apply H0 in H4.
+    assumption.
+  * subst. assumption.
+- repeat rewrite XBox_app_distrib. repeat rewrite <- app_assoc. apply list_exch_LI.
+Qed.
+ +
+Lemma ImpR_app_list_exchR : forall s se ps,
+  (@list_exch_R s se) ->
+  (ImpRRule [ps] s) ->
+  (existsT2 pse,
+    (ImpRRule [pse] se) *
+    (@list_exch_R ps pse)).
+Proof.
+intros s se ps exch. intro RA. inversion RA. inversion exch. subst.
+inversion H. apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+- destruct Δ3 ; destruct Δ4 ; destruct Δ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+  + exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ1). split ; try assumption. apply list_exch_R_id.
+  + exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ5 ++ Δ6). split ; try assumption. apply list_exch_R_id.
+  + exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ4 ++ Δ6). split ; try assumption. apply list_exch_R_id.
+  + exists (Γ0 ++ A :: Γ1, Δ2 ++ (m0 :: Δ5) ++ B :: Δ4 ++ Δ6). split.
+    assert (Δ2 ++ (m0 :: Δ5) ++ B :: Δ4 ++ Δ6 = (Δ2 ++ m0 :: Δ5) ++ B :: Δ4 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ2 ++ m0 :: Δ5 ++ A --> B :: Δ4 ++ Δ6 = (Δ2 ++ m0 :: Δ5) ++ A --> B :: Δ4 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpRRule_I. assert (Δ2 ++ B :: Δ4 ++ m0 :: Δ5 ++ Δ6 = Δ2 ++ [] ++ (B :: Δ4) ++ (m0 :: Δ5) ++ Δ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Δ2 ++ (m0 :: Δ5) ++ B :: Δ4 ++ Δ6 = Δ2 ++ (m0 :: Δ5) ++ (B :: Δ4) ++ [] ++ Δ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+  + exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ3 ++ Δ6). split ; try assumption. apply list_exch_R_id.
+  + exists (Γ0 ++ A :: Γ1, Δ2 ++ (m0 :: Δ5) ++ B :: Δ3 ++ Δ6). split.
+    assert (Δ2 ++ m0 :: Δ5 ++ A --> B :: Δ3 ++ Δ6 = (Δ2 ++ m0 :: Δ5) ++ A --> B :: Δ3 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ2 ++ (m0 :: Δ5) ++ B :: Δ3 ++ Δ6 = (Δ2 ++ m0 :: Δ5) ++ B :: Δ3 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpRRule_I. assert (Δ2 ++ B :: Δ3 ++ m0 :: Δ5 ++ Δ6 = Δ2 ++ (B :: Δ3) ++ [] ++ (m0 :: Δ5) ++ Δ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Δ2 ++ (m0 :: Δ5) ++ B :: Δ3 ++ Δ6 = Δ2 ++ (m0 :: Δ5) ++ [] ++ (B :: Δ3) ++ Δ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+  + exists (Γ0 ++ A :: Γ1, (Δ2 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6). split.
+    assert (Δ2 ++ m0 :: Δ4 ++ A --> B :: Δ3 ++ Δ6 = (Δ2 ++ m0 :: Δ4) ++ A --> B :: Δ3 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+    assert (Δ2 ++ B :: Δ3 ++ m0 :: Δ4 ++ Δ6 = Δ2 ++ (B :: Δ3) ++ [] ++ (m0 :: Δ4) ++ Δ6).
+    reflexivity. rewrite H0. clear H0.
+    assert ((Δ2 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6 = Δ2 ++ (m0 :: Δ4) ++ [] ++ (B :: Δ3) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+  + exists (Γ0 ++ A :: Γ1, (Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6). split.
+    assert (Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4 ++ A --> B :: Δ3 ++ Δ6 = (Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4) ++ A --> B :: Δ3 ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+    assert (Δ2 ++ B :: Δ3 ++ m0 :: Δ4 ++ m1 :: Δ5 ++ Δ6 = Δ2 ++ (B :: Δ3) ++ (m0 :: Δ4) ++ (m1 :: Δ5) ++ Δ6).
+    reflexivity. rewrite H0. clear H0.
+    assert ((Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6 = Δ2 ++ (m1 :: Δ5) ++ (m0 :: Δ4) ++ (B :: Δ3) ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+- apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+  + destruct Δ4 ; destruct Δ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+    * rewrite app_assoc. exists (Γ0 ++ A :: Γ1, (Δ2 ++ Δ3) ++ B :: Δ1). split ; try assumption. apply list_exch_R_id.
+    * exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ5 ++ Δ3 ++ Δ6). split. apply ImpRRule_I.
+      assert ((Δ2 ++ Δ3) ++ B :: Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ [] ++ (B :: Δ5) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Δ2 ++ B :: Δ5 ++ Δ3 ++ Δ6 = Δ2 ++ (B :: Δ5) ++ [] ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+    * exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ4 ++ Δ3 ++ Δ6). split. apply ImpRRule_I.
+      assert ((Δ2 ++ Δ3) ++ B :: Δ4 ++ Δ6 = Δ2 ++ Δ3 ++ [] ++ (B :: Δ4) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Δ2 ++ B :: Δ4 ++ Δ3 ++ Δ6 = Δ2 ++ (B :: Δ4) ++ [] ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+    * exists (Γ0 ++ A :: Γ1, (Δ2 ++ m0 :: Δ5) ++ B :: Δ4 ++ Δ3 ++ Δ6). split.
+      assert (Δ2 ++ m0 :: Δ5 ++ A --> B :: Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ m0 :: Δ5) ++ A --> B :: Δ4 ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+      assert ((Δ2 ++ Δ3) ++ B :: Δ4 ++ m0 :: Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ (B :: Δ4) ++ (m0 :: Δ5) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Δ2 ++ m0 :: Δ5) ++ B :: Δ4 ++ Δ3 ++ Δ6 = Δ2 ++ (m0 :: Δ5) ++ (B :: Δ4) ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+  + apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+    * destruct Δ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+      { exists (Γ0 ++ A :: Γ1, (Δ2 ++ Δ4 ++ Δ3) ++ B :: Δ1). split.
+        assert (Δ2 ++ Δ4 ++ Δ3 ++ A --> B :: Δ1 = (Δ2 ++ Δ4 ++ Δ3) ++ A --> B :: Δ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        assert ((Δ2 ++ Δ3 ++ Δ4) ++ B :: Δ1 = Δ2 ++ Δ3 ++ [] ++ Δ4 ++ B :: Δ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert ((Δ2 ++ Δ4 ++ Δ3) ++ B :: Δ1 = Δ2 ++ Δ4 ++ [] ++ Δ3 ++ B :: Δ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI. }
+      { exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ5 ++ Δ4 ++ Δ3 ++ Δ6). split. apply ImpRRule_I.
+        assert ((Δ2 ++ Δ3 ++ Δ4) ++ B :: Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ Δ4 ++ (B :: Δ5) ++ Δ6). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ B :: Δ5 ++ Δ4 ++ Δ3 ++ Δ6 = Δ2 ++ (B :: Δ5) ++ Δ4 ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI. }
+    * apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+      { exists (Γ0 ++ A :: Γ1, (Δ2 ++ Δ5 ++ Δ4 ++ Δ3) ++ B :: Δ1). split.
+        assert (Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ A --> B :: Δ1 = (Δ2 ++ Δ5 ++ Δ4 ++ Δ3) ++ A --> B :: Δ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        repeat rewrite <- app_assoc. apply list_exch_RI. }
+      { exists (Γ0 ++ A :: Γ1, (Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ x0) ++ B :: Δ1). split.
+        assert (Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ x0 ++ A --> B :: Δ1 = (Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ x0) ++ A --> B :: Δ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        repeat rewrite <- app_assoc. apply list_exch_RI. }
+      { destruct x0.
+        - simpl in e0. subst. rewrite app_nil_r.
+          exists (Γ0 ++ A :: Γ1, (Δ2 ++ x ++ Δ4 ++ Δ3) ++ B :: Δ1). split.
+          assert (Δ2 ++ x ++ Δ4 ++ Δ3 ++ A --> B :: Δ1 = (Δ2 ++ x ++ Δ4 ++ Δ3) ++ A --> B :: Δ1).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+          repeat rewrite <- app_assoc. apply list_exch_RI.
+        - inversion e0. subst.
+          exists (Γ0 ++ A :: Γ1, (Δ2 ++ x) ++ B :: x0 ++ Δ4 ++ Δ3 ++ Δ6). split.
+          assert (Δ2 ++ (x ++ A --> B :: x0) ++ Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ x) ++ A --> B :: x0 ++ Δ4 ++ Δ3 ++ Δ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+          assert ((Δ2 ++ Δ3 ++ Δ4 ++ x) ++ B :: x0 ++ Δ6 = Δ2 ++ Δ3 ++ Δ4 ++ (x ++ B :: x0) ++ Δ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+          assert ((Δ2 ++ x) ++ B :: x0 ++ Δ4 ++ Δ3 ++ Δ6 = Δ2 ++ (x ++ B :: x0) ++ Δ4 ++ Δ3 ++ Δ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+          apply list_exch_RI. }
+    * destruct x ; destruct Δ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+      { rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, (Δ2 ++ x0 ++ Δ3) ++ B :: Δ1). split.
+        assert (Δ2 ++ x0 ++ Δ3 ++ A --> B :: Δ1 = (Δ2 ++ x0 ++ Δ3) ++ A --> B :: Δ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        assert ((Δ2 ++ Δ3 ++ x0) ++ B :: Δ1 = Δ2 ++ Δ3 ++ [] ++ x0 ++ B :: Δ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Δ2 ++ x0 ++ Δ3) ++ B :: Δ1 = Δ2 ++ x0 ++ [] ++ Δ3 ++ B :: Δ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI. }
+      { rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ5 ++ x0 ++ Δ3 ++ Δ6). split.
+        apply ImpRRule_I.
+        assert ((Δ2 ++ Δ3 ++ x0) ++ B :: Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ x0 ++ (B :: Δ5) ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ B :: Δ5 ++ x0 ++ Δ3 ++ Δ6 = Δ2 ++ (B :: Δ5) ++ x0 ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI. }
+      { exists (Γ0 ++ A :: Γ1, (Δ2 ++ x0) ++ B :: x ++ Δ3 ++ Δ6). split.
+        assert (Δ2 ++ (x0 ++ A --> B :: x) ++ Δ3 ++ Δ6 = (Δ2 ++ x0) ++ A --> B :: x ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        assert ((Δ2 ++ Δ3 ++ x0) ++ B :: x ++ Δ6 = Δ2 ++ Δ3 ++ [] ++ (x0 ++ B :: x) ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Δ2 ++ x0) ++ B :: x ++ Δ3 ++ Δ6 = Δ2 ++ (x0 ++ B :: x) ++ [] ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI. }
+      { exists (Γ0 ++ A :: Γ1, (Δ2 ++ m0 :: Δ5 ++ x0) ++ B :: x ++ Δ3 ++ Δ6). split.
+        assert (Δ2 ++ m0 :: Δ5 ++ (x0 ++ A --> B :: x) ++ Δ3 ++ Δ6 = (Δ2 ++ m0 :: Δ5 ++ x0) ++ A --> B :: x ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        assert ((Δ2 ++ Δ3 ++ x0) ++ B :: x ++ m0 :: Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ (x0 ++ B :: x) ++ (m0 :: Δ5) ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Δ2 ++ m0 :: Δ5 ++ x0) ++ B :: x ++ Δ3 ++ Δ6 = Δ2 ++ (m0 :: Δ5) ++ (x0 ++ B :: x) ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        apply list_exch_RI. }
+  + destruct x0 ; destruct Δ4 ; destruct Δ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+    * rewrite app_nil_r. rewrite app_assoc. exists (Γ0 ++ A :: Γ1, (Δ2 ++ x) ++ B :: Δ1). split ; try assumption. apply list_exch_R_id.
+    * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ5 ++ x ++ Δ6). split. apply ImpRRule_I.
+      assert ((Δ2 ++ x) ++ B :: Δ5 ++ Δ6 = Δ2 ++ x ++ [] ++ (B :: Δ5) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Δ2 ++ B :: Δ5 ++ x ++ Δ6 = Δ2 ++ (B :: Δ5) ++ [] ++ x ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+    * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ4 ++ x ++ Δ6). split. apply ImpRRule_I.
+      assert ((Δ2 ++ x) ++ B :: Δ4 ++ Δ6 = Δ2 ++ x ++ [] ++ (B :: Δ4) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Δ2 ++ B :: Δ4 ++ x ++ Δ6 = Δ2 ++ (B :: Δ4) ++ [] ++ x ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+    * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, (Δ2 ++ m0 :: Δ5) ++ B :: Δ4 ++ x ++ Δ6). split.
+      assert (Δ2 ++ m0 :: Δ5 ++ A --> B :: Δ4 ++ x ++ Δ6 = (Δ2 ++ m0 :: Δ5) ++ A --> B :: Δ4 ++ x ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+      assert ((Δ2 ++ x) ++ B :: Δ4 ++ m0 :: Δ5 ++ Δ6 = Δ2 ++ x ++ (B :: Δ4) ++ (m0 :: Δ5) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Δ2 ++ m0 :: Δ5) ++ B :: Δ4 ++ x ++ Δ6 = Δ2 ++ (m0 :: Δ5) ++ (B :: Δ4) ++ x ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+    * exists (Γ0 ++ A :: Γ1, (Δ2 ++ x) ++ B :: x0 ++ Δ6). split.
+      assert (Δ2 ++ (x ++ A --> B :: x0) ++ Δ6 = (Δ2 ++ x) ++ A --> B :: x0 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+      apply list_exch_R_id.
+    * exists (Γ0 ++ A :: Γ1, (Δ2 ++ m0 :: Δ5 ++ x) ++ B :: x0 ++ Δ6). split.
+      assert (Δ2 ++ m0 :: Δ5 ++ (x ++ A --> B :: x0) ++ Δ6 = (Δ2 ++ m0 :: Δ5 ++ x) ++ A --> B :: x0 ++ Δ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+      assert ((Δ2 ++ x) ++ B :: x0 ++ m0 :: Δ5 ++ Δ6 = Δ2 ++ [] ++ (x ++ B :: x0) ++ (m0 :: Δ5) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Δ2 ++ m0 :: Δ5 ++ x) ++ B :: x0 ++ Δ6 = Δ2 ++ (m0 :: Δ5) ++ (x ++ B :: x0) ++ [] ++ Δ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_RI.
+    * exists (Γ0 ++ A :: Γ1, (Δ2 ++ m0 :: Δ4 ++ x) ++ B :: x0 ++ Δ6). split.
+      assert (Δ2 ++ m0 :: Δ4 ++ (x ++ A --> B :: x0) ++ Δ6 = (Δ2 ++ m0 :: Δ4 ++ x) ++ A --> B :: x0 ++ Δ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+      assert ((Δ2 ++ x) ++ B :: x0 ++ m0 :: Δ4 ++ Δ6 = Δ2 ++ [] ++ (x ++ B :: x0) ++ (m0 :: Δ4) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Δ2 ++ m0 :: Δ4 ++ x) ++ B :: x0 ++ Δ6 = Δ2 ++ (m0 :: Δ4) ++ (x ++ B :: x0) ++ [] ++ Δ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_RI.
+    * exists (Γ0 ++ A :: Γ1, (Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4 ++ x) ++ B :: x0 ++ Δ6). split.
+      assert (Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4 ++ (x ++ A --> B :: x0) ++ Δ6 = (Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4 ++ x) ++ A --> B :: x0 ++ Δ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. simpl.
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+      assert ((Δ2 ++ x) ++ B :: x0 ++ m0 :: Δ4 ++ m1 :: Δ5 ++ Δ6 = Δ2 ++ (x ++ B :: x0) ++ (m0 :: Δ4) ++ (m1 :: Δ5) ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert ((Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4 ++ x) ++ B :: x0 ++ Δ6 = Δ2 ++ (m1 :: Δ5) ++ (m0 :: Δ4) ++ (x ++ B :: x0) ++ Δ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_RI.
+- destruct x ; destruct Δ3 ; destruct Δ4 ; destruct Δ5 ; simpl ; simpl in e0 ; simpl in exch ;
+  subst ; try inversion e0 ; subst.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1). split ; try assumption.
+    apply list_exch_R_id.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ5 ++ Δ6). split ; try assumption.
+    apply list_exch_R_id.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ4 ++ Δ6). split ; try assumption.
+    apply list_exch_R_id.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, (Δ0 ++ m0 :: Δ5) ++ B :: Δ4 ++ Δ6). split.
+    assert (Δ0 ++ m0 :: Δ5 ++ A --> B :: Δ4 ++ Δ6 = (Δ0 ++ m0 :: Δ5) ++ A --> B :: Δ4 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+    assert (Δ0 ++ B :: Δ4 ++ m0 :: Δ5 ++ Δ6 = Δ0 ++ [] ++ (B :: Δ4) ++ (m0 :: Δ5) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Δ0 ++ m0 :: Δ5) ++ B :: Δ4 ++ Δ6 = Δ0 ++ (m0 :: Δ5) ++ (B :: Δ4) ++ [] ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ3 ++ Δ6). split ; try assumption.
+    apply list_exch_R_id.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, (Δ0 ++ m0 :: Δ5) ++ B :: Δ3 ++ Δ6). split.
+    assert (Δ0 ++ m0 :: Δ5 ++ A --> B :: Δ3 ++ Δ6 = (Δ0 ++ m0 :: Δ5) ++ A --> B :: Δ3 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+    assert (Δ0 ++ B :: Δ3 ++ m0 :: Δ5 ++ Δ6 = Δ0 ++ [] ++ (B :: Δ3) ++ (m0 :: Δ5) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Δ0 ++ m0 :: Δ5) ++ B :: Δ3 ++ Δ6 = Δ0 ++ (m0 :: Δ5) ++ (B :: Δ3) ++ [] ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, (Δ0 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6). split.
+    assert (Δ0 ++ m0 :: Δ4 ++ A --> B :: Δ3 ++ Δ6 = (Δ0 ++ m0 :: Δ4) ++ A --> B :: Δ3 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+    assert ((Δ0 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6 = Δ0 ++ (m0 :: Δ4) ++ (B :: Δ3) ++ [] ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ B :: Δ3 ++ m0 :: Δ4 ++ Δ6 = Δ0 ++ [] ++ (B :: Δ3) ++ (m0 :: Δ4) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, (Δ0 ++ m1 :: Δ5 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6). split.
+    assert (Δ0 ++ m1 :: Δ5 ++ m0 :: Δ4 ++ A --> B :: Δ3 ++ Δ6 = (Δ0 ++ m1 :: Δ5 ++ m0 :: Δ4) ++ A --> B :: Δ3 ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+    assert (Δ0 ++ B :: Δ3 ++ m0 :: Δ4 ++ m1 :: Δ5 ++ Δ6 = Δ0 ++ (B :: Δ3) ++ (m0 :: Δ4) ++ (m1 :: Δ5) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Δ0 ++ m1 :: Δ5 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6 = Δ0 ++ (m1 :: Δ5) ++ (m0 :: Δ4) ++ (B :: Δ3) ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ Δ6). split. repeat rewrite <- app_assoc. apply ImpRRule_I.
+    apply list_exch_R_id.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ m0 :: Δ5 ++ Δ6). split. repeat rewrite <- app_assoc. apply ImpRRule_I.
+    apply list_exch_R_id.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ m0 :: Δ4 ++ Δ6). split. repeat rewrite <- app_assoc. apply ImpRRule_I.
+    apply list_exch_R_id.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ m1 :: Δ5 ++ m0 :: Δ4 ++ Δ6). split.
+    repeat rewrite <- app_assoc. apply ImpRRule_I.
+    assert (Δ0 ++ B :: x ++ m0 :: Δ4 ++ m1 :: Δ5 ++ Δ6 = (Δ0 ++ B :: x) ++ (m0 :: Δ4) ++ [] ++ (m1 :: Δ5) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ B :: x ++ m1 :: Δ5 ++ m0 :: Δ4 ++ Δ6 = (Δ0 ++ B :: x) ++ (m1 :: Δ5) ++ [] ++ (m0 :: Δ4) ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ m0 :: Δ3 ++ Δ6). split. repeat rewrite <- app_assoc. apply ImpRRule_I.
+    apply list_exch_R_id.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ m1 :: Δ5 ++ m0 :: Δ3 ++ Δ6). split.
+    repeat rewrite <- app_assoc. apply ImpRRule_I.
+    assert (Δ0 ++ B :: x ++ m0 :: Δ3 ++ m1 :: Δ5 ++ Δ6 = (Δ0 ++ B :: x) ++ (m0 :: Δ3) ++ [] ++ (m1 :: Δ5) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ B :: x ++ m1 :: Δ5 ++ m0 :: Δ3 ++ Δ6 = (Δ0 ++ B :: x) ++ (m1 :: Δ5) ++ [] ++ (m0 :: Δ3) ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ m1 :: Δ4 ++ m0 :: Δ3 ++ Δ6). split.
+    repeat rewrite <- app_assoc. apply ImpRRule_I.
+    assert (Δ0 ++ B :: x ++ m0 :: Δ3 ++ m1 :: Δ4 ++ Δ6 = (Δ0 ++ B :: x) ++ (m0 :: Δ3) ++ [] ++ (m1 :: Δ4) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ B :: x ++ m1 :: Δ4 ++ m0 :: Δ3 ++ Δ6 = (Δ0 ++ B :: x) ++ (m1 :: Δ4) ++ [] ++ (m0 :: Δ3) ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ m2 :: Δ5 ++ m1 :: Δ4 ++ m0 :: Δ3 ++ Δ6). split.
+    repeat rewrite <- app_assoc. apply ImpRRule_I.
+    assert (Δ0 ++ B :: x ++ m0 :: Δ3 ++ m1 :: Δ4 ++ m2 :: Δ5 ++ Δ6 = (Δ0 ++ B :: x) ++ (m0 :: Δ3) ++ (m1 :: Δ4) ++ (m2 :: Δ5) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ B :: x ++ m2 :: Δ5 ++ m1 :: Δ4 ++ m0 :: Δ3 ++ Δ6 = (Δ0 ++ B :: x) ++ (m2 :: Δ5) ++ (m1 :: Δ4) ++ (m0 :: Δ3) ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+Qed.
+ +
+Lemma ImpL_app_list_exchR : forall s se ps1 ps2,
+  (@list_exch_R s se) ->
+  (ImpLRule [ps1;ps2] s) ->
+  (existsT2 pse1 pse2,
+    (ImpLRule [pse1;pse2] se) *
+    (@list_exch_R ps1 pse1) *
+    (@list_exch_R ps2 pse2)).
+Proof.
+intros s se ps1 ps2 exch. intro RA. inversion RA. inversion exch. subst.
+inversion H. apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+- exists (Γ0 ++ Γ1, Δ2 ++ A :: Δ5 ++ Δ4 ++ Δ3 ++ Δ6).
+  exists (Γ0 ++ B :: Γ1, Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6). split. split. apply ImpLRule_I.
+  assert (Δ2 ++ A :: Δ3 ++ Δ4 ++ Δ5 ++ Δ6 = (Δ2 ++ [A]) ++ Δ3 ++ Δ4 ++ Δ5 ++ Δ6).
+  rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+  assert (Δ2 ++ A :: Δ5 ++ Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ [A]) ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6).
+  rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+  apply list_exch_RI.
+- apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+  + exists (Γ0 ++ Γ1, (Δ2 ++ Δ5) ++ A :: Δ4 ++ Δ3 ++ Δ6).
+    exists (Γ0 ++ B :: Γ1, Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6).
+    split. split.
+    assert (Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ Δ5) ++ Δ4 ++ Δ3 ++ Δ6). rewrite app_assoc.
+    reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+    repeat rewrite <- app_assoc.
+    assert (Δ2 ++ Δ3 ++ A :: Δ4 ++ Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ (A :: Δ4) ++ Δ5 ++ Δ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Δ2 ++ Δ5 ++ A :: Δ4 ++ Δ3 ++ Δ6 = Δ2 ++ Δ5 ++ (A :: Δ4) ++ Δ3 ++ Δ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_RI. apply list_exch_RI.
+  + apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+    * exists (Γ0 ++ Γ1, (Δ2 ++ Δ5 ++ Δ4) ++ A :: Δ3 ++ Δ6).
+      exists (Γ0 ++ B :: Γ1, Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6). split. split.
+      assert (Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ Δ5 ++ Δ4) ++ Δ3 ++ Δ6). repeat rewrite app_assoc.
+      reflexivity. rewrite H0. clear H0. apply ImpLRule_I. repeat rewrite <- app_assoc.
+      assert (Δ2 ++ Δ3 ++ Δ4 ++ A :: Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ (Δ4 ++ [A]) ++ Δ5 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert (Δ2 ++ Δ5 ++ Δ4 ++ A :: Δ3 ++ Δ6 = Δ2 ++ Δ5 ++ (Δ4 ++ [A]) ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI. apply list_exch_RI.
+    * apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+      { repeat rewrite <- app_assoc. exists (Γ0 ++ Γ1, Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ A :: Δ6).
+        exists (Γ0 ++ B :: Γ1, Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6).
+        split. split. repeat rewrite app_assoc. apply ImpLRule_I. apply list_exch_RI.
+        apply list_exch_RI. }
+      { repeat rewrite <- app_assoc. exists (Γ0 ++ Γ1, Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ x0 ++ A :: Δ1).
+        exists (Γ0 ++ B :: Γ1, Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ x0 ++ Δ1). split. split. repeat rewrite app_assoc.
+        apply ImpLRule_I. apply list_exch_RI. apply list_exch_RI. }
+      { repeat rewrite <- app_assoc. exists (Γ0 ++ Γ1, Δ2 ++ (x ++ A :: x0) ++ Δ4 ++ Δ3 ++ Δ6).
+        exists (Γ0 ++ B :: Γ1, Δ2 ++ x ++ x0 ++ Δ4 ++ Δ3 ++ Δ6). split. split.
+        assert (Δ2 ++ (x ++ A :: x0) ++ Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ x) ++ A :: x0 ++ Δ4 ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ x ++ x0 ++ Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ x) ++ x0 ++ Δ4 ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        apply ImpLRule_I.
+        assert (Δ2 ++ Δ3 ++ Δ4 ++ x ++ A :: x0 ++ Δ6 = Δ2 ++ Δ3 ++ Δ4 ++ (x ++ A :: x0) ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_RI.
+        assert (Δ2 ++ Δ3 ++ Δ4 ++ x ++ x0 ++ Δ6 = Δ2 ++ Δ3 ++ Δ4 ++ (x ++ x0) ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ x ++ x0 ++ Δ4 ++ Δ3 ++ Δ6 = Δ2 ++ (x ++ x0) ++ Δ4 ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_RI. }
+    * repeat rewrite <- app_assoc. exists (Γ0 ++ Γ1, Δ2 ++ Δ5 ++ (x0 ++ A :: x) ++ Δ3 ++ Δ6).
+      exists (Γ0 ++ B :: Γ1, Δ2 ++ Δ5 ++ (x0 ++ x) ++ Δ3 ++ Δ6). split. split.
+      assert (Δ2 ++ Δ5 ++ (x0 ++ A :: x) ++ Δ3 ++ Δ6 = (Δ2 ++ Δ5 ++ x0) ++ A :: x ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert (Δ2 ++ Δ5 ++ x0 ++ x ++ Δ3 ++ Δ6 = (Δ2 ++ Δ5 ++ x0) ++ x ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert (Δ2 ++ Δ5 ++ (x0 ++ x) ++ Δ3 ++ Δ6 = (Δ2 ++ Δ5 ++ x0) ++ x ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      apply ImpLRule_I.
+      assert (Δ2 ++ Δ3 ++ x0 ++ A :: x ++ Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ (x0 ++ A :: x) ++ Δ5 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_RI.
+      assert (Δ2 ++ Δ3 ++ x0 ++ x ++ Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ (x0 ++ x) ++ Δ5 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_RI.
+  + repeat rewrite <- app_assoc. exists (Γ0 ++ Γ1, Δ2 ++ Δ5 ++ Δ4 ++ (x ++ A :: x0) ++ Δ6).
+    exists (Γ0 ++ B :: Γ1, Δ2 ++ Δ5 ++ Δ4 ++ (x ++ x0) ++ Δ6). split. split.
+    assert (Δ2 ++ Δ5 ++ Δ4 ++ (x ++ A :: x0) ++ Δ6 = (Δ2 ++ Δ5 ++ Δ4 ++ x) ++ A :: x0 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ2 ++ Δ5 ++ Δ4 ++ x ++ x0 ++ Δ6 = (Δ2 ++ Δ5 ++ Δ4 ++ x) ++ x0 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ2 ++ Δ5 ++ Δ4 ++ (x ++ x0) ++ Δ6 = (Δ2 ++ Δ5 ++ Δ4 ++ x) ++ x0 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpLRule_I.
+    assert (Δ2 ++ x ++ A :: x0 ++ Δ4 ++ Δ5 ++ Δ6 = Δ2 ++ (x ++ A :: x0) ++ Δ4 ++ Δ5 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_RI.
+    assert (Δ2 ++ x ++ x0 ++ Δ4 ++ Δ5 ++ Δ6 = Δ2 ++ (x ++ x0) ++ Δ4 ++ Δ5 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_RI.
+- repeat rewrite <- app_assoc. exists (Γ0 ++ Γ1, Δ0 ++ A :: x ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6).
+  exists (Γ0 ++ B :: Γ1, Δ0 ++ x ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6). split. split. apply ImpLRule_I.
+  assert (Δ0 ++ A :: x ++ Δ3 ++ Δ4 ++ Δ5 ++ Δ6 = (Δ0 ++ A :: x) ++ Δ3 ++ Δ4 ++ Δ5 ++ Δ6).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+  assert (Δ0 ++ A :: x ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6 = (Δ0 ++ A :: x) ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+  assert (Δ0 ++ x ++ Δ3 ++ Δ4 ++ Δ5 ++ Δ6 = (Δ0 ++ x) ++ Δ3 ++ Δ4 ++ Δ5 ++ Δ6).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+  assert (Δ0 ++ x ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6 = (Δ0 ++ x) ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+Qed.
+ +
+Lemma GLR_app_list_exchR : forall s se ps,
+  (@list_exch_R s se) ->
+  (GLRRule [ps] s) ->
+  (existsT2 pse,
+    (GLRRule [pse] se) *
+    (@list_exch_R ps pse)).
+Proof.
+intros s se ps exch RA. inversion RA. inversion exch. rewrite <- H1 in H2.
+inversion H2. exists (XBoxed_list ++ [Box A], [A]). split.
+- pose (partition_1_element2 Δ2 Δ3 Δ4 Δ5 Δ6 Δ0 Δ1 (Box A) H6). destruct s0.
+  + repeat destruct s0. repeat destruct p. subst. assert (E : (Δ0 ++ Box A :: x0) ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6 = Δ0 ++ Box A :: (x0 ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6)).
+    repeat rewrite <- app_assoc. reflexivity. rewrite E. apply GLRRule_I.
+    * assumption.
+    * assumption.
+  + destruct s0.
+    * repeat destruct s0. repeat destruct p. subst. assert (E: Δ2 ++ Δ5 ++ Δ4 ++ (x ++ Box A :: x0) ++ Δ6 = (Δ2 ++ Δ5 ++ Δ4 ++ x) ++ Box A :: x0 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite E. apply GLRRule_I.
+      { assumption. }
+      { assumption. }
+    * destruct s0.
+      { repeat destruct s0. repeat destruct p. subst. assert (E: Δ2 ++ Δ5 ++ (x ++ Box A :: x0) ++ Δ3 ++ Δ6 = (Δ2 ++ Δ5 ++ x) ++ Box A :: x0 ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite E. apply GLRRule_I.
+        - assumption.
+        - assumption. }
+      { destruct s0.
+        - repeat destruct s0. repeat destruct p. subst. assert (E: Δ2 ++ (x ++ Box A :: x0) ++ Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ x) ++ Box A :: x0 ++ Δ4 ++ Δ3 ++ Δ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite E. apply GLRRule_I.
+          + assumption.
+          + assumption.
+        - repeat destruct s0. repeat destruct p. subst. assert (E: Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ x ++ Box A :: Δ1 = (Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ x) ++ Box A :: Δ1).
+          repeat rewrite <- app_assoc. reflexivity. rewrite E. apply GLRRule_I.
+          + assumption.
+          + assumption. }
+- apply list_exch_R_id.
+Qed.
+ +
+(* We can now prove the admissibility of list_exchange on the left. *)
+ +
+Theorem GLS_adm_list_exch_L : forall s,
+        (GLS_prv s) ->
+        (forall se, (@list_exch_L s se) ->
+        (GLS_prv se)).
+Proof.
+intros s D. apply derrec_all_rect with
+(Q:= fun x => forall (se : Seq),
+list_exch_L x se ->
+derrec GLS_rules (fun _ : Seq => False)
+  se)
+in D.
+- exact D.
+- intros concl F. inversion F.
+- intros ps concl rule. induction rule.
+  (* IdP *)
+  * intros ders IH se exch. inversion i. apply derI with (ps:=[]).
+    apply IdP.
+    + assert (Permstose: existsT2 eΓ0 eΓ1, se = (eΓ0 ++ # P :: eΓ1, Δ0 ++ # P :: Δ1)).
+      { pose (list_exch_L_permLR exch). subst. destruct s0 with (Γ0:=Γ0) (Γ1:=Γ1) (Δ0:=Δ0) (Δ1:=Δ1)
+      (C:=# P) (D:=# P). auto. exists x. assumption. }
+      destruct Permstose. repeat destruct s0. subst. apply IdPRule_I.
+    + apply dersrec_all in ders. apply dersrec_all. subst. assumption.
+  (* BotL *)
+  * intros ders IH se exch. apply derI with (ps:=ps).
+    + apply BotL. inversion b. symmetry in H0.
+      assert (Permstose: existsT2 eΓ0 eΓ1, se = ((eΓ0 ++ Bot :: eΓ1), Δ)).
+      { apply list_exch_L_permL with (s:=c) (Γ0:=Γ0) (Γ1:=Γ1) (Δ:=Δ). assumption.
+        assumption. }
+      destruct Permstose. destruct s0. subst. apply BotLRule_I.
+    + apply dersrec_all in ders. apply dersrec_all. assumption.
+  (* ImpR *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpR_app_list_exchL exch i).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply ImpR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+  (* ImpL *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpL_app_list_exchL exch i).
+    destruct s0. destruct s0. destruct p. destruct p. apply derI with (ps:=[x;x0]).
+    + apply ImpL. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_cons_inv in IH. destruct IH.
+      apply ForallT_inv in f. apply ForallT_cons.
+      { apply d. subst. assumption. }
+      { apply ForallT_cons. apply f. subst. assumption. apply ForallT_nil. }
+  (* GLR *)
+  * intros ders IH se exch. inversion g. subst. pose (GLR_app_list_exchL exch g).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply GLR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion g0.
+      inversion g. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+Qed.
+ +
+Theorem GLS_adm_list_exch_R : forall s,
+        (GLS_prv s) ->
+        (forall se, (@list_exch_R s se) ->
+        (GLS_prv se)).
+Proof.
+intros s D. apply derrec_all_rect with
+(Q:= fun x => forall (se : Seq),
+list_exch_R x se ->
+derrec GLS_rules (fun _ : Seq => False)
+  se)
+in D.
+- exact D.
+- intros concl F. inversion F.
+- intros ps concl rule. induction rule.
+  (* IdP *)
+  * intros ders IH se exch. inversion i. apply derI with (ps:=[]).
+    apply IdP.
+    + assert (Permstose: existsT2 eΔ0 eΔ1, se = (Γ0 ++ # P :: Γ1, eΔ0 ++ # P :: eΔ1)).
+      { pose (list_exch_R_permLR exch). subst. destruct s0 with (Γ0:=Γ0) (Γ1:=Γ1) (Δ0:=Δ0) (Δ1:=Δ1)
+      (C:=# P) (D:=# P). auto. exists x. assumption. }
+      destruct Permstose. repeat destruct s0. subst. apply IdPRule_I.
+    + apply dersrec_all in ders. apply dersrec_all. subst. assumption.
+  (* BotL *)
+  * intros ders IH se exch. apply derI with (ps:=ps).
+    + apply BotL. inversion b. symmetry in H0.
+      assert (Permstose: existsT2 , se = ((Γ0 ++ Bot :: Γ1), )).
+      { apply list_exch_R_permL with (s:=c) (Γ0:=Γ0) (Γ1:=Γ1) (Δ:=Δ). assumption.
+        assumption. }
+      destruct Permstose. subst. apply BotLRule_I.
+    + apply dersrec_all in ders. apply dersrec_all. assumption.
+  (* ImpR *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpR_app_list_exchR exch i).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply ImpR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+  (* ImpL *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpL_app_list_exchR exch i).
+    destruct s0. destruct s0. destruct p. destruct p. apply derI with (ps:=[x;x0]).
+    + apply ImpL. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_cons_inv in IH. destruct IH.
+      apply ForallT_inv in f. apply ForallT_cons.
+      { apply d. subst. assumption. }
+      { apply ForallT_cons. apply f. subst. assumption. apply ForallT_nil. }
+  (* GLR *)
+  * intros ders IH se exch. inversion g. subst. pose (GLR_app_list_exchR exch g).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply GLR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion g0.
+      inversion g. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+Qed.
+ +
+(* Now we can turn to the derivability of list_exchange. *)
+ +
+Inductive Closure {X: Type} (F : X -> Type) (P : X -> X -> Type) : X -> Type :=
+  | InitClo : forall x, F x -> Closure F P x
+  | IndClo : forall x y, Closure F P y -> (P y x) -> Closure F P x.
+ +
+Inductive ExcClosure (hyps : Seq -> Type) : Seq -> Type :=
+  | InitLExch : forall x, Closure hyps list_exch_L x -> ExcClosure hyps x
+  | InitRExch : forall x, Closure hyps list_exch_R x -> ExcClosure hyps x
+  | IndLExch : forall x y, ExcClosure hyps x -> list_exch_L x y -> ExcClosure hyps y
+  | IndRExch : forall x y, ExcClosure hyps x -> list_exch_R x y -> ExcClosure hyps y.
+ +
+Theorem GLS_der_list_exch_L : forall hyps s,
+        (derrec GLS_rules hyps s) ->
+        (forall se, (@list_exch_L s se) ->
+        (derrec GLS_rules (ExcClosure hyps) se)).
+Proof.
+intros hyps s D. apply derrec_all_rect with
+(Q:= fun x => forall (se : Seq),
+list_exch_L x se ->
+derrec GLS_rules (ExcClosure hyps) se) in D.
+- exact D.
+- intros concl H1 se exch. apply dpI. apply InitLExch. apply IndClo with (y:=concl).
+  apply InitClo. assumption. assumption.
+- intros ps concl rule. induction rule.
+  (* IdP *)
+  * intros ders IH se exch. inversion i. apply derI with (ps:=[]).
+    apply IdP.
+    + assert (Permstose: existsT2 eΓ0 eΓ1, se = (eΓ0 ++ # P :: eΓ1, Δ0 ++ # P :: Δ1)).
+      { pose (list_exch_L_permLR exch). subst. destruct s0 with (Γ0:=Γ0) (Γ1:=Γ1) (Δ0:=Δ0) (Δ1:=Δ1)
+      (C:=# P) (D:=# P). auto. exists x. assumption. }
+      destruct Permstose. repeat destruct s0. subst. apply IdPRule_I.
+    + apply dersrec_all in ders. apply dersrec_nil.
+  (* BotL *)
+  * intros ders IH se exch. apply derI with (ps:=ps).
+    + apply BotL. inversion b. symmetry in H0.
+      assert (Permstose: existsT2 eΓ0 eΓ1, se = ((eΓ0 ++ Bot :: eΓ1), Δ)).
+      { apply list_exch_L_permL with (s:=c) (Γ0:=Γ0) (Γ1:=Γ1) (Δ:=Δ). assumption.
+        assumption. }
+      destruct Permstose. repeat destruct s0. subst. apply BotLRule_I.
+    + apply dersrec_all in ders. inversion b. apply dersrec_nil.
+  (* ImpR *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpR_app_list_exchL exch i).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply ImpR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+  (* ImpL *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpL_app_list_exchL exch i).
+    destruct s0. destruct s0. destruct p. destruct p. apply derI with (ps:=[x;x0]).
+    + apply ImpL. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_cons_inv in IH. destruct IH.
+      apply ForallT_inv in f. apply ForallT_cons.
+      { apply d. subst. assumption. }
+      { apply ForallT_cons. apply f. subst. assumption. apply ForallT_nil. }
+  (* GLR *)
+  * intros ders IH se exch. inversion g. subst. pose (GLR_app_list_exchL exch g).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply GLR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion g0.
+      inversion g. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+Qed.
+ +
+Theorem GLS_der_list_exch_R : forall hyps s,
+        (derrec GLS_rules hyps s) ->
+        (forall se, (@list_exch_R s se) ->
+        (derrec GLS_rules (ExcClosure hyps) se)).
+Proof.
+intros hyps s D. apply derrec_all_rect with
+(Q:= fun x => forall (se : Seq),
+list_exch_R x se ->
+derrec GLS_rules (ExcClosure hyps) se) in D.
+- exact D.
+- intros concl H1 se exch. apply dpI. apply InitRExch. apply IndClo with (y:=concl).
+  apply InitClo. assumption. assumption.
+- intros ps concl rule. induction rule.
+  (* IdP *)
+  * intros ders IH se exch. inversion i. apply derI with (ps:=[]).
+    apply IdP.
+    + assert (Permstose: existsT2 eΔ0 eΔ1, se = (Γ0 ++ # P :: Γ1, eΔ0 ++ # P :: eΔ1)).
+      { pose (list_exch_R_permLR exch). subst. destruct s0 with (Γ0:=Γ0) (Γ1:=Γ1) (Δ0:=Δ0) (Δ1:=Δ1)
+      (C:=# P) (D:=# P). auto. exists x. assumption. }
+      destruct Permstose. repeat destruct s0. subst. apply IdPRule_I.
+    + apply dersrec_all in ders. apply dersrec_nil.
+  (* BotL *)
+  * intros ders IH se exch. apply derI with (ps:=ps).
+    + apply BotL. inversion b. symmetry in H0.
+      assert (Permstose: existsT2 , se = ((Γ0 ++ Bot :: Γ1), )).
+      { apply list_exch_R_permL with (s:=c) (Γ0:=Γ0) (Γ1:=Γ1) (Δ:=Δ). assumption.
+        assumption. }
+      destruct Permstose. subst. apply BotLRule_I.
+    + apply dersrec_all in ders. inversion b. apply dersrec_nil.
+  (* ImpR *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpR_app_list_exchR exch i).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply ImpR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+  (* ImpL *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpL_app_list_exchR exch i).
+    destruct s0. destruct s0. destruct p. destruct p. apply derI with (ps:=[x;x0]).
+    + apply ImpL. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_cons_inv in IH. destruct IH.
+      apply ForallT_inv in f. apply ForallT_cons.
+      { apply d. subst. assumption. }
+      { apply ForallT_cons. apply f. subst. assumption. apply ForallT_nil. }
+  (* GLR *)
+  * intros ders IH se exch. inversion g. subst. pose (GLR_app_list_exchR exch g).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply GLR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion g0.
+      inversion g. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+Qed.
+ +
+(* In fact, we can prove that exchange is height-preserving admissible. *)
+ +
+Theorem GLS_hpadm_list_exch_R : forall (k : nat) s
+                                  (D0: GLS_prv s),
+        k = (derrec_height D0) ->
+        (forall se, (list_exch_R s se) ->
+        (existsT2 (D1 : GLS_prv se),
+          derrec_height D1 <=k)).
+Proof.
+induction k as [n IH] using (well_founded_induction_type lt_wf).
+intros s0 D0. remember D0 as D0'. destruct D0.
+(* D0 ip a leaf *)
+- inversion f.
+(* D0 is ends with an application of rule *)
+- intros hei se exch. inversion exch.
+  assert (DersNil: dersrec GLS_rules (fun _ : Seq => False) []).
+  apply dersrec_nil. inversion g.
+  (* IdP *)
+  * inversion H1. subst. inversion H5. subst. simpl.
+    assert (In # P (Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4)). assert (In # P (Δ0 ++ Δ1 ++ Δ2 ++ Δ3 ++ Δ4)).
+    rewrite <- H2. apply in_or_app. right. apply in_eq. apply in_app_or in H. apply in_or_app.
+    destruct H. auto. apply in_app_or in H. right. apply in_or_app. destruct H. right. apply in_or_app.
+    right. apply in_or_app. auto. apply in_app_or in H. destruct H. right. apply in_or_app. auto.
+    apply in_app_or in H. destruct H. auto. right. apply in_or_app. right. apply in_or_app. auto.
+    apply in_splitT in H. destruct H. destruct s. rewrite e.
+    assert (IdPRule [] (Γ0 ++ # P :: Γ1, x ++ # P :: x0)). apply IdPRule_I. apply IdP in H.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (Γ0 ++ # P :: Γ1, x ++ # P :: x0) H DersNil). exists d0. simpl. rewrite dersrec_height_nil.
+    lia. reflexivity.
+  (* BotL *)
+  * inversion H1. subst. inversion H5. subst. simpl.
+    assert (BotLRule [] (Γ0 ++ :: Γ1, Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4)). apply BotLRule_I. apply BotL in H.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (Γ0 ++ :: Γ1, Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4) H DersNil). exists d0. simpl. rewrite dersrec_height_nil.
+    lia. reflexivity.
+  (* ImpR *)
+  * inversion H1. subst. inversion H5. subst. simpl. simpl in IH.
+    pose (ImpR_app_list_exchR exch H1). destruct s. destruct p.
+    apply ImpR in i. assert (J0: dersrec_height d = dersrec_height d). reflexivity.
+    pose (dersrec_derrec_height d J0). destruct s.
+    assert (E: derrec_height x0 < S (dersrec_height d)). lia.
+    assert (E1: derrec_height x0 = derrec_height x0). auto.
+    pose (IH (derrec_height x0) E (Γ0 ++ A :: Γ1, Δ5 ++ B :: Δ6) x0 E1 x l).
+    destruct s. pose (dlCons x1 DersNil).
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x]) (Γ0 ++ Γ1, Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4) i d0). exists d1. simpl.
+    rewrite dersrec_height_nil. rewrite Nat.max_0_r. lia. reflexivity.
+  (* ImpL *)
+  * inversion H1. subst. inversion H5. subst. simpl. simpl in IH.
+    pose (ImpL_app_list_exchR exch H1). repeat destruct s. repeat destruct p.
+    apply ImpL in i. assert (J0: dersrec_height d = dersrec_height d). reflexivity.
+    pose (dersrec_derrec2_height d J0). repeat destruct s.
+    assert (E: derrec_height x1 < S (dersrec_height d)). lia.
+    assert (E1: derrec_height x1 = derrec_height x1). auto.
+    pose (IH (derrec_height x1) E (Γ0 ++ Γ1, Δ5 ++ A :: Δ6) x1 E1 x l0).
+    destruct s.
+    assert (E2: derrec_height x2 < S (dersrec_height d)). lia.
+    assert (E3: derrec_height x2 = derrec_height x2). auto.
+    pose (IH (derrec_height x2) E2 (Γ0 ++ B :: Γ1, Δ5 ++ Δ6) x2 E3 x0 l).
+    destruct s. pose (dlCons x4 DersNil). pose (dlCons x3 d0).
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x; x0]) (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4) i d1). exists d2. simpl.
+    rewrite dersrec_height_nil. rewrite Nat.max_0_r. lia. reflexivity.
+  (* GLR *)
+  * inversion X. subst. inversion H5. subst. simpl. simpl in IH.
+    pose (GLR_app_list_exchR exch X). destruct s. destruct p.
+    apply GLR in g0. assert (J0: dersrec_height d = dersrec_height d). reflexivity.
+    pose (dersrec_derrec_height d J0). destruct s.
+    assert (E: derrec_height x0 < S (dersrec_height d)). lia.
+    assert (E1: derrec_height x0 = derrec_height x0). auto.
+    pose (IH (derrec_height x0) E (XBoxed_list ++ [Box A], [A]) x0 E1 x l).
+    destruct s. pose (dlCons x1 DersNil).
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x]) (Γ, Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4) g0 d0). exists d1. simpl.
+    rewrite dersrec_height_nil. rewrite Nat.max_0_r. lia. reflexivity.
+Qed.
+ +
+Theorem GLS_hpadm_list_exch_L : forall (k : nat) s
+                                  (D0: GLS_prv s),
+        k = (derrec_height D0) ->
+        (forall se, (list_exch_L s se) ->
+        (existsT2 (D1 : GLS_prv se),
+          derrec_height D1 <=k)).
+Proof.
+induction k as [n IH] using (well_founded_induction_type lt_wf).
+intros s0 D0. remember D0 as D0'. destruct D0.
+(* D0 ip a leaf *)
+- inversion f.
+(* D0 is ends with an application of rule *)
+- intros hei se exch. inversion exch.
+  assert (DersNil: dersrec GLS_rules (fun _ : Seq => False) []).
+  apply dersrec_nil. inversion g.
+  (* IdP *)
+  * inversion H1. subst. inversion H5. subst. simpl.
+    assert (In # P (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4)). assert (In # P (Γ0 ++ Γ1 ++ Γ2 ++ Γ3 ++ Γ4)).
+    rewrite <- H0. apply in_or_app. right. apply in_eq. apply in_app_or in H. apply in_or_app.
+    destruct H. auto. apply in_app_or in H. right. apply in_or_app. destruct H. right. apply in_or_app.
+    right. apply in_or_app. auto. apply in_app_or in H. destruct H. right. apply in_or_app. auto.
+    apply in_app_or in H. destruct H. auto. right. apply in_or_app. right. apply in_or_app. auto.
+    apply in_splitT in H. destruct H. destruct s. rewrite e.
+    assert (IdPRule [] (x ++ # P :: x0, Δ0 ++ # P :: Δ1)). apply IdPRule_I. apply IdP in H.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x ++ # P :: x0, Δ0 ++ # P :: Δ1) H DersNil). exists d0. simpl. rewrite dersrec_height_nil.
+    lia. reflexivity.
+  (* BotL *)
+  * inversion H1. subst. inversion H5. subst. simpl.
+    assert (In () (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4)). assert (In () (Γ0 ++ Γ1 ++ Γ2 ++ Γ3 ++ Γ4)).
+    rewrite <- H0. apply in_or_app. right. apply in_eq. apply in_app_or in H. apply in_or_app.
+    destruct H. auto. apply in_app_or in H. right. apply in_or_app. destruct H. right. apply in_or_app.
+    right. apply in_or_app. auto. apply in_app_or in H. destruct H. right. apply in_or_app. auto.
+    apply in_app_or in H. destruct H. auto. right. apply in_or_app. right. apply in_or_app. auto.
+    apply in_splitT in H. destruct H. destruct s. rewrite e.
+    assert (BotLRule [] (x ++ :: x0, Δ)). apply BotLRule_I. apply BotL in H.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x ++ :: x0, Δ) H DersNil). exists d0. simpl. rewrite dersrec_height_nil.
+    lia. reflexivity.
+  (* ImpR *)
+  * inversion H1. subst. inversion H5. subst. simpl. simpl in IH.
+    pose (ImpR_app_list_exchL exch H1). destruct s. destruct p.
+    apply ImpR in i. assert (J0: dersrec_height d = dersrec_height d). reflexivity.
+    pose (dersrec_derrec_height d J0). destruct s.
+    assert (E: derrec_height x0 < S (dersrec_height d)). lia.
+    assert (E1: derrec_height x0 = derrec_height x0). auto.
+    pose (IH (derrec_height x0) E (Γ5 ++ A :: Γ6, Δ0 ++ B :: Δ1) x0 E1 x l).
+    destruct s. pose (dlCons x1 DersNil).
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x]) (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4, Δ0 ++ A --> B :: Δ1) i d0). exists d1. simpl.
+    rewrite dersrec_height_nil. rewrite Nat.max_0_r. lia. reflexivity.
+  (* ImpL *)
+  * inversion H1. subst. inversion H5. subst. simpl. simpl in IH.
+    pose (ImpL_app_list_exchL exch H1). repeat destruct s. repeat destruct p.
+    apply ImpL in i. assert (J0: dersrec_height d = dersrec_height d). reflexivity.
+    pose (dersrec_derrec2_height d J0). repeat destruct s.
+    assert (E: derrec_height x1 < S (dersrec_height d)). lia.
+    assert (E1: derrec_height x1 = derrec_height x1). auto.
+    pose (IH (derrec_height x1) E (Γ5 ++ Γ6, Δ0 ++ A :: Δ1) x1 E1 x l0).
+    destruct s.
+    assert (E2: derrec_height x2 < S (dersrec_height d)). lia.
+    assert (E3: derrec_height x2 = derrec_height x2). auto.
+    pose (IH (derrec_height x2) E2 (Γ5 ++ B :: Γ6, Δ0 ++ Δ1) x2 E3 x0 l).
+    destruct s. pose (dlCons x4 DersNil). pose (dlCons x3 d0).
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x; x0]) (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4, Δ0 ++ Δ1) i d1). exists d2. simpl.
+    rewrite dersrec_height_nil. rewrite Nat.max_0_r. lia. reflexivity.
+  (* GLR *)
+  * inversion X. subst. inversion H5. subst. simpl. simpl in IH.
+    pose (GLR_app_list_exchL exch X). destruct s. destruct p.
+    apply GLR in g0. assert (J0: dersrec_height d = dersrec_height d). reflexivity.
+    pose (dersrec_derrec_height d J0). destruct s.
+    assert (E: derrec_height x0 < S (dersrec_height d)). lia.
+    assert (E1: derrec_height x0 = derrec_height x0). auto.
+    pose (IH (derrec_height x0) E (XBoxed_list ++ [Box A], [A]) x0 E1 x l).
+    destruct s. pose (dlCons x1 DersNil).
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x]) (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4, Δ0 ++ Box A :: Δ1) g0 d0). exists d1. simpl.
+    rewrite dersrec_height_nil. rewrite Nat.max_0_r. lia. reflexivity.
+Qed.
+ +
+Theorem GLS_adm_list_exch_LR : forall s (D0: GLS_prv s),
+        (forall se, ((list_exch_L s se) -> (GLS_prv se)) *
+                        ((list_exch_R s se) -> (GLS_prv se))).
+Proof.
+intros. assert (J1: derrec_height D0 = derrec_height D0). auto. split ; intro.
+- pose (@GLS_hpadm_list_exch_L (derrec_height D0) s D0 J1 se H). destruct s0 ; auto.
+- pose (@GLS_hpadm_list_exch_R (derrec_height D0) s D0 J1 se H). destruct s0 ; auto.
+Qed.
+ +
+
+
+ +
+ + + diff --git a/GL.GLS.GLS_export.html b/GL.GLS.GLS_export.html new file mode 100644 index 0000000..76a4cc8 --- /dev/null +++ b/GL.GLS.GLS_export.html @@ -0,0 +1,51 @@ + + + + + + + + + + + + + +
+
+

GL.GLS.GLS_export

+ +
+Require Export GLS_calcs.
+Require Export GLS_dec.
+Require Export GLS_exch.
+Require Export GLS_ctr.
+Require Export GLS_wkn.
+Require Export GLS_inv_ImpR_ImpL.
+Require Export DLW_wf_lex.
+Require Export GLS_termination_measure.
+Require Export GLS_der_dec.
+Require Export GLS_additive_cut.
+Require Export GLS_cut_elim.
+
+
+ +
+ + + diff --git a/GL.GLS.GLS_inv_ImpR_ImpL.html b/GL.GLS.GLS_inv_ImpR_ImpL.html new file mode 100644 index 0000000..2ca110d --- /dev/null +++ b/GL.GLS.GLS_inv_ImpR_ImpL.html @@ -0,0 +1,734 @@ + + + + + + + + + + + + + +
+
+

GL.GLS.GLS_inv_ImpR_ImpL

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat Arith.
+Require Import Lia.
+ +
+Require Import GLS_calcs.
+Require Import GLS_exch.
+Require Import GLS_wkn.
+Require Import GLS_dec.
+ +
+Set Implicit Arguments.
+ +
+Lemma remove_rest_gen_ext : forall l A, rest_gen_ext [A] (remove eq_dec_form A l) l.
+Proof.
+induction l ; intros.
+- simpl. apply univ_gen_ext_nil.
+- simpl. destruct (eq_dec_form A a).
+  * subst. apply univ_gen_ext_extra. apply InT_eq. apply IHl.
+  * apply univ_gen_ext_cons. apply IHl.
+Qed.
+ +
+Theorem derrec_height_False_ge_1 : forall s, forall (D : GLS_prv s), 1 <= derrec_height D.
+Proof.
+intros s D.
+induction D.
+- destruct p.
+- simpl. lia.
+Qed.
+ +
+Lemma rest_nobox_gen_ext_trans : forall (A B : MPropF) l0 l1 l2, ((In (Imp A B) l0) -> False) ->
+                                                    (nobox_gen_ext l0 l1) ->
+                                                    (rest_gen_ext [Imp A B] l2 l1) ->
+                                                    (nobox_gen_ext l0 l2).
+Proof.
+intros A B l0 l1 l2 H1 H2. generalize dependent l2.
+induction H2.
+- intros. inversion X. apply univ_gen_ext_nil.
+- intros. inversion X.
+  * subst. apply univ_gen_ext_cons. apply IHuniv_gen_ext. intro. apply H1.
+    apply in_cons. assumption. assumption.
+  * subst. inversion H3. subst. exfalso. apply H1. apply in_eq.
+    inversion H0.
+- intros. inversion X.
+  * subst. apply univ_gen_ext_extra. assumption. apply IHuniv_gen_ext ; assumption.
+  * subst. apply IHuniv_gen_ext ; assumption.
+Qed.
+ +
+Theorem ImpR_ImpL_hpinv : forall (k : nat) concl
+        (D0 : GLS_prv concl),
+        k = (derrec_height D0) ->
+          ((forall prem, ((ImpRRule [prem] concl) ->
+          existsT2 (D1 : GLS_prv prem),
+          derrec_height D1 <= k))) *
+          ((forall prem1 prem2, ((ImpLRule [prem1; prem2] concl) ->
+          existsT2 (D1 : GLS_prv prem1)
+                   (D2 : GLS_prv prem2),
+          (derrec_height D1 <= k) * (derrec_height D2 <= k)))).
+Proof.
+assert (DersNilF: dersrec (GLS_rules) (fun _ : Seq => False) []).
+apply dersrec_nil.
+induction k as [n IH] using (well_founded_induction_type lt_wf).
+intros s D0. remember D0 as D0'. destruct D0.
+(* D0 is a leaf *)
+- destruct f.
+(* D0 is ends with an application of rule *)
+- intros hei. split.
+{ intros prem RA. inversion RA. subst.
+  inversion g ; subst.
+  (* IdP *)
+  * inversion H. subst. assert (InT # P (Γ0 ++ Γ1)).
+    rewrite <- H2. apply InT_or_app. right. apply InT_eq. assert (InT # P (Γ0 ++ A :: Γ1)).
+    apply InT_app_or in H0. destruct H0. apply InT_or_app. auto. apply InT_or_app. right.
+    apply InT_cons. assumption. apply InT_split in H1. destruct H1. destruct s. rewrite e.
+    assert (InT # P (Δ0 ++ B :: Δ1)). assert (InT # P (Δ2 ++ # P :: Δ3)).
+    apply InT_or_app. right. apply InT_eq. rewrite H3 in H1. apply InT_app_or in H1.
+    destruct H1. apply InT_or_app. auto. inversion i. inversion H4. apply InT_or_app. right.
+    apply InT_cons. assumption. apply InT_split in H1. destruct H1. destruct s.
+    rewrite e0. assert (IdPRule [] (x ++ # P :: x0, x1 ++ # P :: x2)).
+    apply IdPRule_I. apply IdP in H1.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x ++ # P :: x0, x1 ++ # P :: x2) H1 DersNilF). exists d0.
+    simpl. rewrite dersrec_height_nil. lia. reflexivity.
+  (* BotL *)
+  * inversion H. subst. assert (InT () (Γ0 ++ Γ1)).
+    rewrite <- H2. apply InT_or_app. right. apply InT_eq. assert (InT () (Γ0 ++ A :: Γ1)).
+    apply InT_app_or in H0. destruct H0. apply InT_or_app. auto. apply InT_or_app. right.
+    apply InT_cons. assumption. apply InT_split in H1. destruct H1. destruct s. rewrite e.
+    assert (BotLRule [] (x ++ :: x0, Δ0 ++ B :: Δ1)).
+    apply BotLRule_I. apply BotL in H1.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x ++ :: x0, Δ0 ++ B :: Δ1) H1 DersNilF). exists d0.
+    simpl. rewrite dersrec_height_nil. lia. reflexivity.
+  (* ImpR *)
+  * inversion H. subst. apply app2_find_hole in H3. destruct H3. repeat destruct s ; destruct p ; subst.
+    + inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+      pose (@dersrec_derrec_height (dersrec_height d) _ _ _ _ d J30). destruct s.
+      assert (J1: list_exch_L (Γ2 ++ A0 :: Γ3, Δ2 ++ B0 :: Δ3) (A0 :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3)).
+      assert (Γ2 ++ A0 :: Γ3 = [] ++ [] ++ Γ2 ++ [A0] ++ Γ3). reflexivity.
+      rewrite H0. clear H0.
+      assert (A0 :: Γ0 ++ Γ1 = [] ++ [A0] ++ Γ2 ++ [] ++ Γ3). simpl. rewrite H2. reflexivity.
+      rewrite H0. clear H0. apply list_exch_LI.
+      assert (J20: derrec_height x0 = derrec_height x0). reflexivity.
+      pose (GLS_hpadm_list_exch_L x0 J20 J1). destruct s.
+      assert (J2: list_exch_L (A0 :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3) (Γ0 ++ A0 :: Γ1, Δ2 ++ B0 :: Δ3)).
+      assert ((A0 :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3) = ([] ++ [A0] ++ Γ0 ++ [] ++ Γ1, Δ2 ++ B0 :: Δ3)).
+      reflexivity. assert ((Γ0 ++ A0 :: Γ1, Δ2 ++ B0 :: Δ3) = ([] ++ [] ++ Γ0 ++ [A0] ++ Γ1, Δ2 ++ B0 :: Δ3)).
+      reflexivity. rewrite H1. rewrite H0. clear H1. clear H0. apply list_exch_LI.
+      assert (J21: derrec_height x1 = derrec_height x1). reflexivity.
+      pose (GLS_hpadm_list_exch_L x1 J21 J2). destruct s. exists x2.
+      simpl. lia.
+    + destruct x.
+      { simpl in e0. inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec_height (dersrec_height d) _ _ _ _ d J30). destruct s.
+        assert (J1: list_exch_L (Γ2 ++ A :: Γ3, Δ2 ++ B :: Δ1) (A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ1)).
+        assert (Γ2 ++ A :: Γ3 = [] ++ [] ++ Γ2 ++ [A] ++ Γ3). reflexivity.
+        rewrite H0. clear H0.
+        assert (A :: Γ0 ++ Γ1 = [] ++ [A] ++ Γ2 ++ [] ++ Γ3). simpl. rewrite H2. reflexivity.
+        rewrite H0. clear H0. apply list_exch_LI.
+        assert (J20: derrec_height x = derrec_height x). reflexivity.
+        pose (GLS_hpadm_list_exch_L x J20 J1). destruct s.
+        assert (J2: list_exch_L (A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ1) (Γ0 ++ A :: Γ1, (Δ2 ++ []) ++ B :: Δ1)).
+        assert ((A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ1) = ([] ++ [A] ++ Γ0 ++ [] ++ Γ1, Δ2 ++ B :: Δ1)).
+        reflexivity. assert ((Γ0 ++ A :: Γ1, (Δ2 ++ []) ++ B :: Δ1) = ([] ++ [] ++ Γ0 ++ [A] ++ Γ1, Δ2 ++ B :: Δ1)).
+        rewrite app_nil_r. reflexivity. rewrite H1. rewrite H0. clear H1. clear H0. apply list_exch_LI.
+        assert (J21: derrec_height x0 = derrec_height x0). reflexivity.
+        pose (GLS_hpadm_list_exch_L x0 J21 J2). destruct s. exists x1.
+        simpl. lia. }
+      { inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec_height (dersrec_height d) _ _ _ _ d J30). destruct s.
+        assert (J1: list_exch_L (Γ2 ++ A0 :: Γ3, Δ2 ++ B0 :: x ++ A --> B :: Δ1) (A0 :: Γ0 ++ Γ1, Δ2 ++ B0 :: x ++ A --> B :: Δ1)).
+        assert (Γ2 ++ A0 :: Γ3 = [] ++ [] ++ Γ2 ++ [A0] ++ Γ3). reflexivity.
+        rewrite H0. clear H0.
+        assert (A0 :: Γ0 ++ Γ1 = [] ++ [A0] ++ Γ2 ++ [] ++ Γ3). simpl. rewrite H2. reflexivity.
+        rewrite H0. clear H0. apply list_exch_LI.
+        assert (J20: derrec_height x0 = derrec_height x0). reflexivity.
+        pose (GLS_hpadm_list_exch_L x0 J20 J1). destruct s. simpl in IH. simpl.
+        assert (J2: derrec_height x1 < S (dersrec_height d)). lia.
+        assert (J3: derrec_height x1 = derrec_height x1). reflexivity.
+        assert (J4: ImpRRule [(A0 :: Γ0 ++ A :: Γ1, Δ2 ++ B0 :: x ++ B :: Δ1)] (A0 :: Γ0 ++ Γ1, Δ2 ++ B0 :: x ++ A --> B :: Δ1)).
+        assert (A0 :: Γ0 ++ A :: Γ1 = (A0 :: Γ0) ++ A :: Γ1). reflexivity. rewrite H0. clear H0.
+        assert (A0 :: Γ0 ++ Γ1 = (A0 :: Γ0) ++ Γ1). reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ B0 :: x ++ B :: Δ1 = (Δ2 ++ B0 :: x) ++ B :: Δ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ B0 :: x ++ A --> B :: Δ1 = (Δ2 ++ B0 :: x) ++ A --> B :: Δ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        pose (IH _ J2 _ _ J3). destruct p. pose (s _ J4). clear s0. destruct s1. clear s.
+        assert (existsT2 (x3 : derrec GLS_rules (fun _ : Seq => False)
+        (Γ0 ++ A :: Γ1, (Δ2 ++ A0 --> B0 :: x) ++ B :: Δ1)), derrec_height x3 <= S (dersrec_height d)).
+        assert (ImpRRule [(A0 :: Γ0 ++ A :: Γ1, Δ2 ++ B0 :: x ++ B :: Δ1)] (Γ0 ++ A :: Γ1, (Δ2 ++ A0 --> B0 :: x) ++ B :: Δ1)).
+        assert (A0 :: Γ0 ++ A :: Γ1 = [] ++ A0 :: Γ0 ++ A :: Γ1). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ A :: Γ1 = [] ++ Γ0 ++ A :: Γ1). reflexivity. rewrite H0. clear H0. repeat rewrite <- app_assoc.
+        apply ImpRRule_I. apply ImpR in H0 ; try intro ; try apply f0 ; try auto ; try assumption.
+        pose (dlCons x2 DersNilF).
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(A0 :: Γ0 ++ A :: Γ1, Δ2 ++ B0 :: x ++ B :: Δ1)]) (Γ0 ++ A :: Γ1, (Δ2 ++ A0 --> B0 :: x) ++ B :: Δ1) H0 d0).
+        exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+        destruct X. exists x3. lia. }
+    + destruct x.
+      { simpl in e0. inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec_height (dersrec_height d) _ _ _ _ d J30). destruct s.
+        assert (J1: list_exch_L (Γ2 ++ A0 :: Γ3, (Δ0 ++ []) ++ B0 :: Δ3) (A0 :: Γ0 ++ Γ1, Δ0 ++ B0 :: Δ3)).
+        rewrite app_nil_r.
+        assert (Γ2 ++ A0 :: Γ3 = [] ++ [] ++ Γ2 ++ [A0] ++ Γ3). reflexivity.
+        rewrite H0. clear H0.
+        assert (A0 :: Γ0 ++ Γ1 = [] ++ [A0] ++ Γ2 ++ [] ++ Γ3). simpl. rewrite H2. reflexivity.
+        rewrite H0. clear H0. apply list_exch_LI.
+        assert (J20: derrec_height x = derrec_height x). reflexivity.
+        pose (GLS_hpadm_list_exch_L x J20 J1). destruct s.
+        assert (J2: list_exch_L (A0 :: Γ0 ++ Γ1, Δ0 ++ B0 :: Δ3) (Γ0 ++ A0 :: Γ1, Δ0 ++ B0 :: Δ3)).
+        assert ((A0 :: Γ0 ++ Γ1, Δ0 ++ B0 :: Δ3) = ([] ++ [A0] ++ Γ0 ++ [] ++ Γ1, Δ0 ++ B0 :: Δ3)).
+        reflexivity. assert ((Γ0 ++ A0 :: Γ1, Δ0 ++ B0 :: Δ3) = ([] ++ [] ++ Γ0 ++ [A0] ++ Γ1, Δ0 ++ B0 :: Δ3)).
+        reflexivity. rewrite H1. rewrite H0. clear H1. clear H0. apply list_exch_LI.
+        assert (J21: derrec_height x0 = derrec_height x0). reflexivity.
+        pose (GLS_hpadm_list_exch_L x0 J21 J2). destruct s. exists x1.
+        simpl. lia. }
+      { inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec_height (dersrec_height d) _ _ _ _ d J30). destruct s. simpl.
+        assert (J1: list_exch_L (Γ2 ++ A0 :: Γ3, (Δ0 ++ A --> B :: x) ++ B0 :: Δ3) (A0 :: Γ0 ++ Γ1, Δ0 ++ A --> B :: x ++ B0 :: Δ3)).
+        repeat rewrite <- app_assoc.
+        assert (Γ2 ++ A0 :: Γ3 = [] ++ [] ++ Γ2 ++ [A0] ++ Γ3). reflexivity.
+        rewrite H0. clear H0.
+        assert (A0 :: Γ0 ++ Γ1 = [] ++ [A0] ++ Γ2 ++ [] ++ Γ3). simpl. rewrite H2. reflexivity.
+        rewrite H0. clear H0. apply list_exch_LI.
+        assert (J20: derrec_height x0 = derrec_height x0). reflexivity.
+        pose (GLS_hpadm_list_exch_L x0 J20 J1). destruct s. simpl in IH. simpl.
+        assert (J2: derrec_height x1 < S (dersrec_height d)). lia.
+        assert (J3: derrec_height x1 = derrec_height x1). reflexivity.
+        assert (J4: ImpRRule [(A0 :: Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ B0 :: Δ3)] (A0 :: Γ0 ++ Γ1, Δ0 ++ A --> B :: x ++ B0 :: Δ3)).
+        assert (A0 :: Γ0 ++ A :: Γ1 = (A0 :: Γ0) ++ A :: Γ1). reflexivity. rewrite H0. clear H0.
+        assert (A0 :: Γ0 ++ Γ1 = (A0 :: Γ0) ++ Γ1). reflexivity. rewrite H0. clear H0.
+        apply ImpRRule_I.
+        pose (IH _ J2 _ _ J3). destruct p. pose (s _ J4). clear s0. destruct s1. clear s.
+        assert (ImpRRule [(A0 :: Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ B0 :: Δ3)] (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ A0 --> B0 :: Δ3)).
+        assert (A0 :: Γ0 ++ A :: Γ1 = [] ++ A0 :: Γ0 ++ A :: Γ1). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ A :: Γ1 = [] ++ Γ0 ++ A :: Γ1). reflexivity. rewrite H0. clear H0. repeat rewrite <- app_assoc.
+        assert (Δ0 ++ B :: x ++ B0 :: Δ3 = (Δ0 ++ B :: x) ++ B0 :: Δ3). rewrite <- app_assoc. reflexivity.
+        rewrite H0. clear H0.
+        assert (Δ0 ++ B :: x ++ A0 --> B0 :: Δ3 = (Δ0 ++ B :: x) ++ A0 --> B0 :: Δ3). rewrite <- app_assoc. reflexivity.
+        rewrite H0. clear H0.
+        apply ImpRRule_I. apply ImpR in H0 ; try intro ; try apply f0 ; try auto ; try assumption.
+        pose (dlCons x2 DersNilF).
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(A0 :: Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ B0 :: Δ3)]) (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ A0 --> B0 :: Δ3) H0 d0).
+        exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity. }
+  (* ImpL *)
+  * inversion H. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+    pose (@dersrec_derrec2_height (dersrec_height d) _ _ _ _ _ d J30). repeat destruct s. simpl.
+    assert (J1: ImpRRule [(A :: Γ2 ++ B0 :: Γ3, Δ0 ++ B :: Δ1)] (Γ2 ++ B0 :: Γ3, Δ2 ++ Δ3)).
+    rewrite H3. assert (A :: Γ2 ++ B0 :: Γ3 = [] ++ A :: Γ2 ++ B0 :: Γ3). reflexivity.
+    rewrite H0. clear H0. assert (Γ2 ++ B0 :: Γ3 = [] ++ Γ2 ++ B0 :: Γ3). reflexivity.
+    rewrite H0. clear H0. apply ImpRRule_I. simpl in IH.
+    assert (J2: derrec_height x0 < S (dersrec_height d)). lia.
+    assert (J3: derrec_height x0 = derrec_height x0). reflexivity.
+    pose (IH _ J2 _ _ J3). destruct p. clear s0. pose (s _ J1). destruct s0. clear s.
+    assert (J7: list_exch_R (Γ2 ++ Γ3, Δ2 ++ A0 :: Δ3) (Γ2 ++ Γ3, A0 :: Δ0 ++ A --> B :: Δ1)).
+    rewrite <- H3. assert (Δ2 ++ A0 :: Δ3 = [] ++ [] ++ Δ2 ++ [A0] ++ Δ3). reflexivity.
+    rewrite H0. clear H0. assert (A0 :: Δ2 ++ Δ3 = [] ++ [A0] ++ Δ2 ++ [] ++ Δ3). reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+    assert (J8: derrec_height x = derrec_height x). reflexivity.
+    pose (GLS_hpadm_list_exch_R x J8 J7). destruct s.
+    assert (J4: ImpRRule [(A :: Γ2 ++ Γ3, A0 :: Δ0 ++ B :: Δ1)] (Γ2 ++ Γ3, A0 :: Δ0 ++ A --> B :: Δ1)).
+    assert (A :: Γ2 ++ Γ3 = [] ++ A :: Γ2 ++ Γ3). reflexivity.
+    rewrite H0. clear H0. assert ((Γ2 ++ Γ3, A0 :: Δ0 ++ A --> B :: Δ1) = ([] ++ Γ2 ++ Γ3, A0 :: Δ0 ++ A --> B :: Δ1)). reflexivity.
+    rewrite H0. clear H0. assert (A0 :: Δ0 ++ B :: Δ1 = (A0 :: Δ0) ++ B :: Δ1). reflexivity.
+    rewrite H0. clear H0. assert (A0 :: Δ0 ++ A --> B :: Δ1 = (A0 :: Δ0) ++ A --> B :: Δ1). reflexivity.
+    rewrite H0. clear H0. apply ImpRRule_I. simpl in IH.
+    assert (J5: derrec_height x2 < S (dersrec_height d)). lia.
+    assert (J6: derrec_height x2 = derrec_height x2). reflexivity.
+    pose (IH _ J5 _ _ J6). destruct p. clear s0. pose (s _ J4). destruct s0. clear s.
+    assert (ImpLRule [(A :: Γ2 ++ Γ3, A0 :: Δ0 ++ B :: Δ1); (A :: Γ2 ++ B0 :: Γ3, Δ0 ++ B :: Δ1)]
+    (A :: Γ2 ++ A0 --> B0 :: Γ3, Δ0 ++ B :: Δ1)).
+    assert (A :: Γ2 ++ Γ3 = (A :: Γ2) ++ Γ3). reflexivity. rewrite H0. clear H0.
+    assert (A :: Γ2 ++ B0 :: Γ3 = (A :: Γ2) ++ B0 :: Γ3). reflexivity. rewrite H0. clear H0.
+    assert (A :: Γ2 ++ A0 --> B0 :: Γ3 = (A :: Γ2) ++ A0 --> B0 :: Γ3). reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ B :: Δ1 = [] ++ Δ0 ++ B :: Δ1). reflexivity. rewrite H0. clear H0.
+    assert (A0 :: [] ++ Δ0 ++ B :: Δ1 = [] ++ A0 :: Δ0 ++ B :: Δ1). reflexivity. rewrite H0. clear H0.
+    apply ImpLRule_I. pose (dlCons x1 DersNilF). pose (dlCons x3 d0).
+    apply ImpL in H0.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[(A :: Γ2 ++ Γ3, A0 :: Δ0 ++ B :: Δ1); (A :: Γ2 ++ B0 :: Γ3, Δ0 ++ B :: Δ1)])
+    (A :: Γ2 ++ A0 --> B0 :: Γ3, Δ0 ++ B :: Δ1) H0 d1).
+    assert (J40: list_exch_L (A :: Γ2 ++ A0 --> B0 :: Γ3, Δ0 ++ B :: Δ1) (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)).
+    rewrite H2. assert (A :: Γ0 ++ Γ1 = [] ++ [A] ++ Γ0 ++ [] ++ Γ1). reflexivity. rewrite H1. clear H1.
+    assert (Γ0 ++ A :: Γ1 = [] ++ [] ++ Γ0 ++ [A] ++ Γ1). reflexivity. rewrite H1. clear H1.
+    apply list_exch_LI.
+    assert (J41: derrec_height d2 = derrec_height d2). reflexivity.
+    pose (GLS_hpadm_list_exch_L d2 J41 J40). destruct s. exists x4. simpl in J41.
+    simpl in l2. rewrite dersrec_height_nil in l2. lia. reflexivity.
+  (* GLR *)
+  * inversion X. subst.
+    assert (GLRRule [(XBoxed_list ++ [Box A0], [A0])] (Γ0 ++ Γ1, Δ0 ++ Δ1)).
+    assert (In (Box A0) (Δ0 ++ Δ1)).
+    assert (InT (Box A0) (Δ2 ++ Box A0 :: Δ3)). apply InT_or_app. right. apply InT_eq.
+    rewrite H2 in H. apply InT_app_or in H. apply in_or_app. destruct H. apply InT_In in i. auto.
+    inversion i. inversion H0. apply InT_In in H0. auto.
+    apply in_splitT in H. destruct H. destruct s. rewrite e. apply GLRRule_I ; try assumption.
+    simpl. simpl in IH.
+    apply GLR in X1.
+    assert (dersrec_height d = dersrec_height d). reflexivity.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[(XBoxed_list ++ [Box A0], [A0])]) (Γ0 ++ Γ1, Δ0 ++ Δ1) X1 d).
+    assert (J1: wkn_L A (Γ0 ++ Γ1, Δ0 ++ Δ1) (Γ0 ++ A :: Γ1, Δ0 ++ Δ1)).
+    apply wkn_LI.
+    assert (J2: derrec_height d0 = derrec_height d0). reflexivity.
+    pose (GLS_wkn_L d0 J2 J1). destruct s.
+    assert (J3: wkn_R B (Γ0 ++ A :: Γ1, Δ0 ++ Δ1) (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)).
+    apply wkn_RI.
+    assert (J4: derrec_height x = derrec_height x). reflexivity.
+    pose (GLS_wkn_R x J4 J3). destruct s. exists x0.
+    pose (Nat.le_trans _ _ _ l0 l). simpl in l1. assumption. }
+{ intros prem1 prem2 RA. inversion RA. subst.
+  inversion g ; subst.
+  (* IdP *)
+  * inversion H. subst. assert (InT # P (Γ0 ++ Γ1)). assert (InT # P (Γ2 ++ # P :: Γ3)).
+    apply InT_or_app. right. apply InT_eq. rewrite H2 in H0. apply InT_or_app.
+    apply InT_app_or in H0. destruct H0. auto. inversion i. inversion H1.
+    auto. assert (InT # P (Γ0 ++ B :: Γ1)).
+    apply InT_app_or in H0. apply InT_or_app. destruct H0. auto. right. apply InT_cons.
+    assumption. apply InT_split in H1. destruct H1. destruct s. apply InT_split in H0. destruct H0.
+    destruct s. rewrite e0. rewrite e. assert (In # P (Δ0 ++ A :: Δ1)). assert (In # P (Δ0 ++ Δ1)).
+    rewrite <- H3. apply in_or_app. right. apply in_eq. apply in_app_or in H0. apply in_or_app.
+    destruct H0. auto. right. apply in_cons. assumption. apply in_splitT in H0. destruct H0.
+    destruct s. rewrite e1.
+    assert (IdPRule [] (x1 ++ # P :: x2, x3 ++ # P :: x4)).
+    apply IdPRule_I. apply IdP in H0.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x1 ++ # P :: x2, x3 ++ # P :: x4) H0 DersNilF). exists d0.
+    assert (IdPRule [] (x ++ # P :: x0, Δ0 ++ Δ1)). rewrite <- H3.
+    apply IdPRule_I. apply IdP in H1.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x ++ # P :: x0, Δ0 ++ Δ1) H1 DersNilF). exists d1.
+    simpl. rewrite dersrec_height_nil. split ; lia. reflexivity.
+  (* BotL *)
+  * inversion H. subst. assert (InT () (Γ0 ++ Γ1)). assert (InT () (Γ2 ++ () :: Γ3)).
+    apply InT_or_app. right. apply InT_eq. rewrite H2 in H0. apply InT_app_or in H0.
+    apply InT_or_app. destruct H0. auto. inversion i. inversion H1. auto. assert (InT () (Γ0 ++ B :: Γ1)).
+    apply InT_app_or in H0. apply InT_or_app. destruct H0. auto. right. apply InT_cons.
+    assumption. apply InT_split in H0. destruct H0. destruct s. apply InT_split in H1. destruct H1.
+    destruct s. rewrite e0. rewrite e.
+    assert (BotLRule [] (x ++ :: x0, Δ0 ++ A :: Δ1)).
+    apply BotLRule_I. apply BotL in H0.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x ++ :: x0, Δ0 ++ A :: Δ1) H0 DersNilF). exists d0.
+    assert (BotLRule [] (x1 ++ :: x2, Δ0 ++ Δ1)).
+    apply BotLRule_I. apply BotL in H1.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x1 ++ :: x2, Δ0 ++ Δ1) H1 DersNilF). exists d1.
+    simpl. rewrite dersrec_height_nil. split ; lia. reflexivity.
+  (* ImpR *)
+  * inversion H. subst. simpl in IH.
+    assert (J0: (dersrec_height d) = (dersrec_height d)). reflexivity.
+    pose (dersrec_derrec_height d J0). destruct s.
+    apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+    + assert (ImpLRule [(Γ2 ++ A0 :: Γ1, A :: Δ2 ++ B0 :: Δ3) ; (Γ2 ++ A0 :: B :: Γ1, Δ2 ++ B0 :: Δ3)]
+      (Γ2 ++ A0 :: A --> B :: Γ1, Δ2 ++ B0 :: Δ3)). assert (Γ2 ++ A0 :: Γ1 = (Γ2 ++ [A0]) ++ Γ1).
+      rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ A0 :: B :: Γ1 = (Γ2 ++ [A0]) ++ B :: Γ1). rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. assert (Γ2 ++ A0 :: A --> B :: Γ1 = (Γ2 ++ [A0]) ++ A --> B :: Γ1). rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. assert (Δ2 ++ B0 :: Δ3 = [] ++ Δ2 ++ B0 :: Δ3).
+      reflexivity. rewrite H0. clear H0. assert (A :: [] ++ Δ2 ++ B0 :: Δ3 = [] ++ A :: Δ2 ++ B0 :: Δ3).
+      reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+      assert (J1: derrec_height x < S (dersrec_height d)). lia.
+      assert (J2: derrec_height x = derrec_height x). reflexivity.
+      pose (IH (derrec_height x) J1 _ x J2). destruct p. clear s.
+      pose (s0 _ _ H0). repeat destruct s. clear s0. destruct p.
+      assert (ImpRRule [(Γ2 ++ A0 :: Γ1, A :: Δ2 ++ B0 :: Δ3)] (Γ2 ++ Γ1, A :: Δ0 ++ Δ1)).
+      rewrite <- H3. assert (A :: Δ2 ++ B0 :: Δ3 = (A :: Δ2) ++ B0 :: Δ3). reflexivity.
+      rewrite H1. clear H1. assert (A :: Δ2 ++ A0 --> B0 :: Δ3 = (A :: Δ2) ++ A0 --> B0 :: Δ3). reflexivity.
+      rewrite H1. clear H1. apply ImpRRule_I.
+      assert (existsT2 (x3: derrec GLS_rules (fun _ : Seq => False)
+      (Γ2 ++ Γ1, A :: Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+      apply ImpR in H1.
+      pose (dlCons x1 DersNilF). pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[(Γ2 ++ A0 :: Γ1, A :: Δ2 ++ B0 :: Δ3)]) (Γ2 ++ Γ1, A :: Δ0 ++ Δ1) H1 d0).
+      exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+      destruct X.
+      assert (J3: derrec_height x3 = derrec_height x3). reflexivity.
+      assert (J4: list_exch_R (Γ2 ++ Γ1, A :: Δ0 ++ Δ1) (Γ2 ++ Γ1, Δ0 ++ A :: Δ1)).
+      assert (A :: Δ0 ++ Δ1 = [] ++ [A] ++ Δ0 ++ [] ++ Δ1). reflexivity. rewrite H2. clear H2.
+      assert (Δ0 ++ A :: Δ1 = [] ++ [] ++ Δ0 ++ [A] ++ Δ1). reflexivity. rewrite H2. clear H2.
+      apply list_exch_RI. pose (GLS_hpadm_list_exch_R x3 J3 J4). destruct s. exists x4.
+      assert (ImpRRule [(Γ2 ++ A0 :: B :: Γ1, Δ2 ++ B0 :: Δ3)] (Γ2 ++ B :: Γ1, Δ0 ++ Δ1)).
+      rewrite <- H3. apply ImpRRule_I.
+      assert (existsT2 (x3: derrec GLS_rules (fun _ : Seq => False)
+      (Γ2 ++ B :: Γ1, Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+      apply ImpR in H2.
+      pose (dlCons x2 DersNilF). pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[(Γ2 ++ A0 :: B :: Γ1, Δ2 ++ B0 :: Δ3)]) (Γ2 ++ B :: Γ1, Δ0 ++ Δ1) H2 d0).
+      exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+      destruct X. exists x5. simpl. split. lia. lia.
+    + assert (ImpLRule [(Γ2 ++ A0 :: x0 ++ Γ1, A :: Δ2 ++ B0 :: Δ3) ; (Γ2 ++ A0 :: x0 ++ B :: Γ1, Δ2 ++ B0 :: Δ3)]
+      (Γ2 ++ A0 :: x0 ++ A --> B :: Γ1, Δ2 ++ B0 :: Δ3)). assert (Γ2 ++ A0 :: x0 ++ Γ1 = (Γ2 ++ A0 :: x0) ++ Γ1).
+      rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ A0 :: x0 ++ B :: Γ1 = (Γ2 ++ A0 :: x0) ++ B :: Γ1). rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. assert (Γ2 ++ A0 :: x0 ++ A --> B :: Γ1 = (Γ2 ++ A0 :: x0) ++ A --> B :: Γ1). rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. assert (Δ2 ++ B0 :: Δ3 = [] ++ Δ2 ++ B0 :: Δ3).
+      reflexivity. rewrite H0. clear H0. assert (A :: [] ++ Δ2 ++ B0 :: Δ3 = [] ++ A :: Δ2 ++ B0 :: Δ3).
+      reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+      assert (J1: derrec_height x < S (dersrec_height d)). lia.
+      assert (J2: derrec_height x = derrec_height x). reflexivity.
+      pose (IH (derrec_height x) J1 _ x J2). destruct p. clear s.
+      pose (s0 _ _ H0). repeat destruct s. clear s0. destruct p.
+      assert (ImpRRule [(Γ2 ++ A0 :: x0 ++ Γ1, A :: Δ2 ++ B0 :: Δ3)] ((Γ2 ++ x0) ++ Γ1, A :: Δ0 ++ Δ1)).
+      rewrite <- H3. assert (A :: Δ2 ++ B0 :: Δ3 = (A :: Δ2) ++ B0 :: Δ3). reflexivity.
+      rewrite H1. clear H1. assert (A :: Δ2 ++ A0 --> B0 :: Δ3 = (A :: Δ2) ++ A0 --> B0 :: Δ3). reflexivity.
+      rewrite H1. clear H1. rewrite <- app_assoc. apply ImpRRule_I.
+      assert (existsT2 (x3: derrec GLS_rules (fun _ : Seq => False)
+      ((Γ2 ++ x0) ++ Γ1, A :: Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+      apply ImpR in H1.
+      pose (dlCons x1 DersNilF). pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[(Γ2 ++ A0 :: x0 ++ Γ1, A :: Δ2 ++ B0 :: Δ3)]) ((Γ2 ++ x0) ++ Γ1, A :: Δ0 ++ Δ1) H1 d0).
+      exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+      destruct X.
+      assert (J3: derrec_height x3 = derrec_height x3). reflexivity.
+      assert (J4: list_exch_R ((Γ2 ++ x0) ++ Γ1, A :: Δ0 ++ Δ1) ((Γ2 ++ x0) ++ Γ1, Δ0 ++ A :: Δ1)).
+      assert (A :: Δ0 ++ Δ1 = [] ++ [A] ++ Δ0 ++ [] ++ Δ1). reflexivity. rewrite H2. clear H2.
+      assert (Δ0 ++ A :: Δ1 = [] ++ [] ++ Δ0 ++ [A] ++ Δ1). reflexivity. rewrite H2. clear H2.
+      apply list_exch_RI. pose (GLS_hpadm_list_exch_R x3 J3 J4). destruct s. exists x4.
+      assert (ImpRRule [(Γ2 ++ A0 :: x0 ++ B :: Γ1, Δ2 ++ B0 :: Δ3)] ((Γ2 ++ x0) ++ B :: Γ1, Δ0 ++ Δ1)).
+      rewrite <- H3. rewrite <- app_assoc. apply ImpRRule_I.
+      assert (existsT2 (x3: derrec GLS_rules (fun _ : Seq => False)
+      ((Γ2 ++ x0) ++ B :: Γ1, Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+      apply ImpR in H2.
+      pose (dlCons x2 DersNilF). pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[(Γ2 ++ A0 :: x0 ++ B :: Γ1, Δ2 ++ B0 :: Δ3)]) ((Γ2 ++ x0) ++ B :: Γ1, Δ0 ++ Δ1) H2 d0).
+      exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+      destruct X. exists x5. simpl. split. lia. lia.
+    + destruct x0.
+      { simpl in e1. subst. assert (ImpLRule [(Γ0 ++ A0 :: Γ1, A :: Δ2 ++ B0 :: Δ3) ; (Γ0 ++ A0 :: B :: Γ1, Δ2 ++ B0 :: Δ3)]
+        ((Γ0 ++ []) ++ A0 :: A --> B :: Γ1, Δ2 ++ B0 :: Δ3)). rewrite app_nil_r. assert (Γ0 ++ A0 :: Γ1 = (Γ0 ++ [A0]) ++ Γ1).
+        rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ A0 :: B :: Γ1 = (Γ0 ++ [A0]) ++ B :: Γ1). rewrite <- app_assoc. reflexivity.
+        rewrite H0. clear H0. assert (Γ0 ++ A0 :: A --> B :: Γ1 = (Γ0 ++ [A0]) ++ A --> B :: Γ1). rewrite <- app_assoc. reflexivity.
+        rewrite H0. clear H0. assert (Δ2 ++ B0 :: Δ3 = [] ++ Δ2 ++ B0 :: Δ3).
+        reflexivity. rewrite H0. clear H0. assert (A :: [] ++ Δ2 ++ B0 :: Δ3 = [] ++ A :: Δ2 ++ B0 :: Δ3).
+        reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        assert (J1: derrec_height x < S (dersrec_height d)). lia.
+        assert (J2: derrec_height x = derrec_height x). reflexivity.
+        pose (IH (derrec_height x) J1 _ x J2). destruct p. clear s.
+        pose (s0 _ _ H0). repeat destruct s. clear s0. destruct p.
+        assert (ImpRRule [(Γ0 ++ A0 :: Γ1, A :: Δ2 ++ B0 :: Δ3)] (Γ0 ++ Γ1, A :: Δ0 ++ Δ1)).
+        rewrite <- H3. assert (A :: Δ2 ++ B0 :: Δ3 = (A :: Δ2) ++ B0 :: Δ3). reflexivity.
+        rewrite H1. clear H1. assert (A :: Δ2 ++ A0 --> B0 :: Δ3 = (A :: Δ2) ++ A0 --> B0 :: Δ3). reflexivity.
+        rewrite H1. clear H1. apply ImpRRule_I.
+        assert (existsT2 (x3: derrec GLS_rules (fun _ : Seq => False)
+        (Γ0 ++ Γ1, A :: Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+        apply ImpR in H1.
+        pose (dlCons x0 DersNilF). pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(Γ0 ++ A0 :: Γ1, A :: Δ2 ++ B0 :: Δ3)]) (Γ0 ++ Γ1, A :: Δ0 ++ Δ1) H1 d0).
+        exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+        destruct X.
+        assert (J3: derrec_height x2 = derrec_height x2). reflexivity.
+        assert (J4: list_exch_R (Γ0 ++ Γ1, A :: Δ0 ++ Δ1) (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)).
+        assert (A :: Δ0 ++ Δ1 = [] ++ [A] ++ Δ0 ++ [] ++ Δ1). reflexivity. rewrite H2. clear H2.
+        assert (Δ0 ++ A :: Δ1 = [] ++ [] ++ Δ0 ++ [A] ++ Δ1). reflexivity. rewrite H2. clear H2.
+        apply list_exch_RI. pose (GLS_hpadm_list_exch_R x2 J3 J4). destruct s. exists x3.
+        assert (ImpRRule [(Γ0 ++ A0 :: B :: Γ1, Δ2 ++ B0 :: Δ3)] (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)).
+        rewrite <- H3. apply ImpRRule_I.
+        assert (existsT2 (x3: derrec GLS_rules (fun _ : Seq => False)
+        (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+        apply ImpR in H2.
+        pose (dlCons x1 DersNilF). pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(Γ0 ++ A0 :: B :: Γ1, Δ2 ++ B0 :: Δ3)]) (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) H2 d0).
+        exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+        destruct X. exists x4. simpl. split. lia. lia. }
+        { inversion e1. subst. assert (ImpLRule [(Γ0 ++ x0 ++ A0 :: Γ3, A :: Δ2 ++ B0 :: Δ3) ; (Γ0 ++ B :: x0 ++ A0 :: Γ3, Δ2 ++ B0 :: Δ3)]
+          ((Γ0 ++ A --> B :: x0) ++ A0 :: Γ3, Δ2 ++ B0 :: Δ3)). rewrite <- app_assoc.
+          assert (Δ2 ++ B0 :: Δ3 = [] ++ Δ2 ++ B0 :: Δ3). reflexivity. rewrite H0. clear H0.
+          assert (A :: [] ++ Δ2 ++ B0 :: Δ3 = [] ++ A :: Δ2 ++ B0 :: Δ3). reflexivity. rewrite H0.
+          clear H0. apply ImpLRule_I.
+          assert (J1: derrec_height x < S (dersrec_height d)). lia.
+          assert (J2: derrec_height x = derrec_height x). reflexivity.
+          pose (IH (derrec_height x) J1 _ x J2). destruct p. clear s.
+          pose (s0 _ _ H0). repeat destruct s. clear s0. destruct p.
+          assert (ImpRRule [(Γ0 ++ x0 ++ A0 :: Γ3, A :: Δ2 ++ B0 :: Δ3)] (Γ0 ++ x0 ++ Γ3, A :: Δ0 ++ Δ1)).
+          rewrite <- H3. assert (A :: Δ2 ++ B0 :: Δ3 = (A :: Δ2) ++ B0 :: Δ3). reflexivity.
+          rewrite H1. clear H1. assert (A :: Δ2 ++ A0 --> B0 :: Δ3 = (A :: Δ2) ++ A0 --> B0 :: Δ3). reflexivity.
+          rewrite H1. clear H1. assert (Γ0 ++ x0 ++ A0 :: Γ3 = (Γ0 ++ x0) ++ A0 :: Γ3). rewrite <- app_assoc.
+          reflexivity. rewrite H1. clear H1. assert (Γ0 ++ x0 ++ Γ3 = (Γ0 ++ x0) ++ Γ3). rewrite <- app_assoc.
+          reflexivity. rewrite H1. clear H1. apply ImpRRule_I.
+          assert (existsT2 (x3: derrec GLS_rules (fun _ : Seq => False)
+          (Γ0 ++ x0 ++ Γ3, A :: Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+          apply ImpR in H1.
+          pose (dlCons x1 DersNilF). pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[(Γ0 ++ x0 ++ A0 :: Γ3, A :: Δ2 ++ B0 :: Δ3)]) (Γ0 ++ x0 ++ Γ3, A :: Δ0 ++ Δ1) H1 d0).
+          exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+          destruct X.
+          assert (J3: derrec_height x3 = derrec_height x3). reflexivity.
+          assert (J4: list_exch_R (Γ0 ++ x0 ++ Γ3, A :: Δ0 ++ Δ1) (Γ0 ++ x0 ++ Γ3, Δ0 ++ A :: Δ1)).
+          assert (A :: Δ0 ++ Δ1 = [] ++ [A] ++ Δ0 ++ [] ++ Δ1). reflexivity. rewrite H2. clear H2.
+          assert (Δ0 ++ A :: Δ1 = [] ++ [] ++ Δ0 ++ [A] ++ Δ1). reflexivity. rewrite H2. clear H2.
+          apply list_exch_RI. pose (GLS_hpadm_list_exch_R x3 J3 J4). destruct s. exists x4.
+          assert (ImpRRule [(Γ0 ++ B :: x0 ++ A0 :: Γ3, Δ2 ++ B0 :: Δ3)] (Γ0 ++ B :: x0 ++ Γ3, Δ0 ++ Δ1)).
+          rewrite <- H3. assert (Γ0 ++ B :: x0 ++ A0 :: Γ3 = (Γ0 ++ B :: x0) ++ A0 :: Γ3). rewrite <- app_assoc.
+          reflexivity. rewrite H2. clear H2. assert (Γ0 ++ B :: x0 ++ Γ3 = (Γ0 ++ B :: x0) ++ Γ3). rewrite <- app_assoc.
+          reflexivity. rewrite H2. clear H2. apply ImpRRule_I.
+          assert (existsT2 (x3: derrec GLS_rules (fun _ : Seq => False)
+          (Γ0 ++ B :: x0 ++ Γ3, Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+          apply ImpR in H2.
+          pose (dlCons x2 DersNilF). pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[(Γ0 ++ B :: x0 ++ A0 :: Γ3, Δ2 ++ B0 :: Δ3)]) (Γ0 ++ B :: x0 ++ Γ3, Δ0 ++ Δ1) H2 d0).
+          exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+          destruct X. exists x5. simpl. split. lia. lia. }
+  (* ImpL *)
+  * inversion H. subst.
+    apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+    + inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+      pose (@dersrec_derrec2_height (dersrec_height d) _ _ _ _ _ d J30). repeat destruct s.
+      assert (J1: list_exch_R (Γ2 ++ Γ3, Δ2 ++ A0 :: Δ3) (Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1)).
+      assert (Δ2 ++ A0 :: Δ3 = [] ++ [] ++ Δ2 ++ [A0] ++ Δ3). reflexivity.
+      rewrite H0. clear H0.
+      assert (A0 :: Δ0 ++ Δ1 = [] ++ [A0] ++ Δ2 ++ [] ++ Δ3). simpl. rewrite H3. reflexivity.
+      rewrite H0. clear H0. apply list_exch_RI.
+      assert (J20: derrec_height x0 = derrec_height x0). reflexivity.
+      pose (GLS_hpadm_list_exch_R x0 J20 J1). destruct s.
+      assert (J2: list_exch_R (Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1) (Γ2 ++ Γ3, Δ0 ++ A0 :: Δ1)).
+      assert (A0 :: Δ0 ++ Δ1 = [] ++ [A0] ++ Δ0 ++ [] ++ Δ1).
+      reflexivity. assert (Δ0 ++ A0 :: Δ1 = [] ++ [] ++ Δ0 ++ [A0] ++ Δ1).
+      reflexivity. rewrite H1. rewrite H0. clear H1. clear H0. apply list_exch_RI.
+      assert (J21: derrec_height x2 = derrec_height x2). reflexivity.
+      pose (GLS_hpadm_list_exch_R x2 J21 J2). destruct s. exists x3.
+      assert (existsT2 (x4: derrec GLS_rules (fun _ : Seq => False) (Γ2 ++ B0 :: Γ3, Δ0 ++ Δ1)),
+      derrec_height x4 = derrec_height x1). rewrite <- H3. exists x1. reflexivity. destruct X. exists x4. split.
+       simpl. lia. simpl. lia.
+    + destruct x.
+      { simpl in e0. inversion e0. simpl. rewrite app_nil_r. subst.
+        assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec2_height (dersrec_height d) _ _ _ _ _ d J30). repeat destruct s.
+        assert (J1: list_exch_R (Γ2 ++ Γ1, Δ2 ++ A :: Δ3) (Γ2 ++ Γ1, A :: Δ0 ++ Δ1)).
+        assert (Δ2 ++ A :: Δ3 = [] ++ [] ++ Δ2 ++ [A] ++ Δ3). reflexivity.
+        rewrite H0. clear H0.
+        assert (A :: Δ0 ++ Δ1 = [] ++ [A] ++ Δ2 ++ [] ++ Δ3). simpl. rewrite H3. reflexivity.
+        rewrite H0. clear H0. apply list_exch_RI.
+        assert (J20: derrec_height x = derrec_height x). reflexivity.
+        pose (GLS_hpadm_list_exch_R x J20 J1). destruct s.
+        assert (J2: list_exch_R (Γ2 ++ Γ1, A :: Δ0 ++ Δ1) (Γ2 ++ Γ1, Δ0 ++ A :: Δ1)).
+        assert (A :: Δ0 ++ Δ1 = [] ++ [A] ++ Δ0 ++ [] ++ Δ1).
+        reflexivity. assert (Δ0 ++ A :: Δ1 = [] ++ [] ++ Δ0 ++ [A] ++ Δ1).
+        reflexivity. rewrite H1. rewrite H0. clear H1. clear H0. apply list_exch_RI.
+        assert (J21: derrec_height x1 = derrec_height x1). reflexivity.
+        pose (GLS_hpadm_list_exch_R x1 J21 J2). destruct s. exists x2.
+        assert (existsT2 (x3: derrec GLS_rules (fun _ : Seq => False) (Γ2 ++ B :: Γ1, Δ0 ++ Δ1)),
+        derrec_height x3 = derrec_height x0). rewrite <- H3. exists x0. reflexivity. destruct X. exists x3. split.
+        simpl. lia. simpl. lia. }
+      { inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec2_height (dersrec_height d) _ _ _ _ _ d J30). repeat destruct s.
+        assert (J1: list_exch_R (Γ2 ++ x ++ A --> B :: Γ1, Δ2 ++ A0 :: Δ3) (Γ2 ++ x ++ A --> B :: Γ1, A0 :: Δ0 ++ Δ1)).
+        assert (Δ2 ++ A0 :: Δ3 = [] ++ [] ++ Δ2 ++ [A0] ++ Δ3). reflexivity.
+        rewrite H0. clear H0.
+        assert (A0 :: Δ0 ++ Δ1 = [] ++ [A0] ++ Δ2 ++ [] ++ Δ3). simpl. rewrite H3. reflexivity.
+        rewrite H0. clear H0. apply list_exch_RI.
+        assert (J20: derrec_height x0 = derrec_height x0). reflexivity.
+        pose (GLS_hpadm_list_exch_R x0 J20 J1). destruct s. simpl in IH. simpl.
+        assert (J2: derrec_height x2 < S (dersrec_height d)). lia.
+        assert (J3: derrec_height x2 = derrec_height x2). reflexivity.
+        assert (J4: ImpLRule [(Γ2 ++ x ++ Γ1, A0 :: Δ0 ++ A :: Δ1); (Γ2 ++ x ++ B :: Γ1, A0 :: Δ0 ++ Δ1)]
+        (Γ2 ++ x ++ A --> B :: Γ1, A0 :: Δ0 ++ Δ1)).
+        assert (A0 :: Δ0 ++ A :: Δ1 = (A0 :: Δ0) ++ A :: Δ1). reflexivity. rewrite H0. clear H0.
+        assert (A0 :: Δ0 ++ Δ1 = (A0 :: Δ0) ++ Δ1). reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ x ++ B :: Γ1 = (Γ2 ++ x) ++ B :: Γ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ x ++ A --> B :: Γ1 = (Γ2 ++ x) ++ A --> B :: Γ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ x ++ Γ1 = (Γ2 ++ x) ++ Γ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        pose (IH _ J2 _ _ J3). destruct p. pose (s0 _ _ J4). clear s. destruct s1. clear s0. destruct s.
+        destruct p.
+        assert (J5: derrec_height x1 < S (dersrec_height d)). lia.
+        assert (J6: derrec_height x1 = derrec_height x1). reflexivity.
+        assert (J7: ImpLRule [(Γ2 ++ B0 :: x ++ Γ1, Δ0 ++ A :: Δ1); (Γ2 ++ B0 :: x ++ B :: Γ1, Δ0 ++ Δ1)]
+        (Γ2 ++ B0 :: x ++ A --> B :: Γ1, Δ2 ++ Δ3)). rewrite H3.
+        assert (Γ2 ++ B0 :: x ++ Γ1 = (Γ2 ++ B0 :: x) ++ Γ1). rewrite <- app_assoc. reflexivity.
+        rewrite H0. clear H0.
+        assert (Γ2 ++ B0 :: x ++ B :: Γ1 = (Γ2 ++ B0 :: x) ++ B :: Γ1). rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ B0 :: x ++ A --> B :: Γ1 = (Γ2 ++ B0 :: x) ++ A --> B :: Γ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        pose (IH _ J5 _ _ J6). destruct p. pose (s0 _ _ J7). clear s. destruct s1. clear s0. destruct s.
+        destruct p.
+        assert (existsT2 (x7 : derrec GLS_rules (fun _ : Seq => False)
+        ((Γ2 ++ A0 --> B0 :: x) ++ Γ1, Δ0 ++ A :: Δ1)), derrec_height x7 <= S (dersrec_height d)).
+        assert (ImpLRule [(Γ2 ++ x ++ Γ1, A0 :: Δ0 ++ A :: Δ1); (Γ2 ++ B0 :: x ++ Γ1, Δ0 ++ A :: Δ1)]
+        ((Γ2 ++ A0 --> B0 :: x) ++ Γ1, Δ0 ++ A :: Δ1)). rewrite <- app_assoc.
+        assert (A0 :: Δ0 ++ A :: Δ1 = [] ++ A0 :: Δ0 ++ A :: Δ1). reflexivity. rewrite H0. clear H0.
+        assert (Δ0 ++ A :: Δ1 = [] ++ Δ0 ++ A :: Δ1). reflexivity. rewrite H0. clear H0. repeat rewrite <- app_assoc.
+        apply ImpLRule_I. apply ImpL in H0.
+        pose (dlCons x5 DersNilF). pose (dlCons x3 d0).
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(Γ2 ++ x ++ Γ1, A0 :: Δ0 ++ A :: Δ1); (Γ2 ++ B0 :: x ++ Γ1, Δ0 ++ A :: Δ1)])
+        ((Γ2 ++ A0 --> B0 :: x) ++ Γ1, Δ0 ++ A :: Δ1) H0 d1).
+        exists d2. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+        destruct X. exists x7.
+        assert (existsT2 (x8 : derrec GLS_rules (fun _ : Seq => False)
+        ((Γ2 ++ A0 --> B0 :: x) ++ B :: Γ1, Δ0 ++ Δ1)), derrec_height x8 <= S (dersrec_height d)).
+        assert (ImpLRule [(Γ2 ++ x ++ B :: Γ1, A0 :: Δ0 ++ Δ1); (Γ2 ++ B0 :: x ++ B :: Γ1, Δ0 ++ Δ1)]
+        ((Γ2 ++ A0 --> B0 :: x) ++ B :: Γ1, Δ0 ++ Δ1)). rewrite <- app_assoc.
+        assert (Δ0 ++ Δ1 = [] ++ Δ0 ++ Δ1). reflexivity. rewrite H0. clear H0.
+        assert (A0 :: [] ++ Δ0 ++ Δ1 = [] ++ A0 :: Δ0 ++ Δ1). reflexivity. rewrite H0. clear H0.
+        apply ImpLRule_I. apply ImpL in H0.
+        pose (dlCons x6 DersNilF). pose (dlCons x4 d0).
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(Γ2 ++ x ++ B :: Γ1, A0 :: Δ0 ++ Δ1); (Γ2 ++ B0 :: x ++ B :: Γ1, Δ0 ++ Δ1)])
+        ((Γ2 ++ A0 --> B0 :: x) ++ B :: Γ1, Δ0 ++ Δ1) H0 d1).
+        exists d2. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+        destruct X. exists x8. split. lia. lia. }
+    + destruct x.
+      { simpl in e0. inversion e0. simpl. subst.
+        assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec2_height (dersrec_height d) _ _ _ _ _ d J30). repeat destruct s.
+        assert (J1: list_exch_R ((Γ0 ++ []) ++ Γ3, Δ2 ++ A0 :: Δ3) (Γ0 ++ Γ3, A0 :: Δ0 ++ Δ1)).
+        rewrite app_nil_r.
+        assert (Δ2 ++ A0 :: Δ3 = [] ++ [] ++ Δ2 ++ [A0] ++ Δ3). reflexivity.
+        rewrite H0. clear H0.
+        assert (A0 :: Δ0 ++ Δ1 = [] ++ [A0] ++ Δ2 ++ [] ++ Δ3). simpl. rewrite H3. reflexivity.
+        rewrite H0. clear H0. apply list_exch_RI.
+        assert (J20: derrec_height x = derrec_height x). reflexivity.
+        pose (GLS_hpadm_list_exch_R x J20 J1). destruct s.
+        assert (J2: list_exch_R (Γ0 ++ Γ3, A0 :: Δ0 ++ Δ1) (Γ0 ++ Γ3, Δ0 ++ A0 :: Δ1)).
+        assert (A0 :: Δ0 ++ Δ1 = [] ++ [A0] ++ Δ0 ++ [] ++ Δ1).
+        reflexivity. assert (Δ0 ++ A0 :: Δ1 = [] ++ [] ++ Δ0 ++ [A0] ++ Δ1).
+        reflexivity. rewrite H1. rewrite H0. clear H1. clear H0. apply list_exch_RI.
+        assert (J21: derrec_height x1 = derrec_height x1). reflexivity.
+        pose (GLS_hpadm_list_exch_R x1 J21 J2). destruct s. exists x2.
+        assert (existsT2 (x3: derrec GLS_rules (fun _ : Seq => False) (Γ0 ++ B0 :: Γ3, Δ0 ++ Δ1)),
+        derrec_height x3 = derrec_height x0). rewrite <- H3.
+        assert (Γ0 ++ B0 :: Γ3 = (Γ0 ++ []) ++ B0 :: Γ3). rewrite app_nil_r. reflexivity.
+        rewrite H0. exists x0. reflexivity. destruct X. exists x3. split.
+        simpl. lia. simpl. lia. }
+      { inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec2_height (dersrec_height d) _ _ _ _ _ d J30). repeat destruct s.
+        assert (J1: list_exch_R ((Γ0 ++ A --> B :: x) ++ Γ3, Δ2 ++ A0 :: Δ3) (Γ0 ++ A --> B :: x ++ Γ3, A0 :: Δ0 ++ Δ1)).
+        assert (Δ2 ++ A0 :: Δ3 = [] ++ [] ++ Δ2 ++ [A0] ++ Δ3). reflexivity.
+        rewrite H0. clear H0. rewrite <- app_assoc.
+        assert (A0 :: Δ0 ++ Δ1 = [] ++ [A0] ++ Δ2 ++ [] ++ Δ3). simpl. rewrite H3. reflexivity.
+        rewrite H0. clear H0. apply list_exch_RI.
+        assert (J20: derrec_height x0 = derrec_height x0). reflexivity.
+        pose (GLS_hpadm_list_exch_R x0 J20 J1). destruct s. simpl in IH. simpl.
+        assert (J2: derrec_height x2 < S (dersrec_height d)). lia.
+        assert (J3: derrec_height x2 = derrec_height x2). reflexivity.
+        assert (J4: ImpLRule [(Γ0 ++ x ++ Γ3, A0 :: Δ0 ++ A :: Δ1); (Γ0 ++ B :: x ++ Γ3, A0 :: Δ0 ++ Δ1)]
+        (Γ0 ++ A --> B :: x ++ Γ3, A0 :: Δ0 ++ Δ1)).
+        assert (A0 :: Δ0 ++ A :: Δ1 = (A0 :: Δ0) ++ A :: Δ1). reflexivity. rewrite H0. clear H0.
+        assert (A0 :: Δ0 ++ Δ1 = (A0 :: Δ0) ++ Δ1). reflexivity. rewrite H0. clear H0.
+        apply ImpLRule_I.
+        pose (IH _ J2 _ _ J3). destruct p. pose (s0 _ _ J4). clear s. destruct s1. clear s0. destruct s.
+        destruct p.
+        assert (J5: derrec_height x1 < S (dersrec_height d)). lia.
+        assert (J6: derrec_height x1 = derrec_height x1). reflexivity.
+        assert (J7: ImpLRule [(Γ0 ++ x ++ B0 :: Γ3, Δ0 ++ A :: Δ1); (Γ0 ++ B :: x ++ B0 :: Γ3, Δ0 ++ Δ1)]
+        ((Γ0 ++ A --> B :: x) ++ B0 :: Γ3, Δ2 ++ Δ3)). rewrite H3. rewrite <- app_assoc.
+        apply ImpLRule_I. pose (IH _ J5 _ _ J6). destruct p. pose (s0 _ _ J7). clear s.
+        destruct s1. clear s0. destruct s. destruct p.
+        assert (existsT2 (x7 : derrec GLS_rules (fun _ : Seq => False)
+        (Γ0 ++ x ++ A0 --> B0 :: Γ3, Δ0 ++ A :: Δ1)), derrec_height x7 <= S (dersrec_height d)).
+        assert (ImpLRule [(Γ0 ++ x ++ Γ3, A0 :: Δ0 ++ A :: Δ1); (Γ0 ++ x ++ B0 :: Γ3, Δ0 ++ A :: Δ1)]
+        (Γ0 ++ x ++ A0 --> B0 :: Γ3, Δ0 ++ A :: Δ1)).
+        assert (A0 :: Δ0 ++ A :: Δ1 = [] ++ A0 :: Δ0 ++ A :: Δ1). reflexivity. rewrite H0. clear H0.
+        assert (Δ0 ++ A :: Δ1 = [] ++ Δ0 ++ A :: Δ1). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ x ++ Γ3 = (Γ0 ++ x) ++ Γ3). rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ x ++ B0 :: Γ3 = (Γ0 ++ x) ++ B0 :: Γ3). rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ x ++ A0 --> B0 :: Γ3 = (Γ0 ++ x) ++ A0 --> B0 :: Γ3). rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        apply ImpLRule_I. apply ImpL in H0.
+        pose (dlCons x5 DersNilF). pose (dlCons x3 d0).
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(Γ0 ++ x ++ Γ3, A0 :: Δ0 ++ A :: Δ1); (Γ0 ++ x ++ B0 :: Γ3, Δ0 ++ A :: Δ1)])
+        (Γ0 ++ x ++ A0 --> B0 :: Γ3, Δ0 ++ A :: Δ1) H0 d1).
+        exists d2. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+        destruct X. exists x7.
+        assert (existsT2 (x8 : derrec GLS_rules (fun _ : Seq => False)
+        (Γ0 ++ B :: x ++ A0 --> B0 :: Γ3, Δ0 ++ Δ1)), derrec_height x8 <= S (dersrec_height d)).
+        assert (ImpLRule [(Γ0 ++ B :: x ++ Γ3, A0 :: Δ0 ++ Δ1); (Γ0 ++ B :: x ++ B0 :: Γ3, Δ0 ++ Δ1)]
+        (Γ0 ++ B :: x ++ A0 --> B0 :: Γ3, Δ0 ++ Δ1)).
+        assert (Δ0 ++ Δ1 = [] ++ Δ0 ++ Δ1). reflexivity. rewrite H0. clear H0.
+        assert (A0 :: [] ++ Δ0 ++ Δ1 = [] ++ A0 :: Δ0 ++ Δ1). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ B :: x ++ Γ3 = (Γ0 ++ B :: x) ++ Γ3). rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ B :: x ++ B0 :: Γ3 = (Γ0 ++ B :: x) ++ B0 :: Γ3). rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ B :: x ++ A0 --> B0 :: Γ3 = (Γ0 ++ B :: x) ++ A0 --> B0 :: Γ3). rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        apply ImpLRule_I. apply ImpL in H0.
+        pose (dlCons x6 DersNilF). pose (dlCons x4 d0).
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(Γ0 ++ B :: x ++ Γ3, A0 :: Δ0 ++ Δ1); (Γ0 ++ B :: x ++ B0 :: Γ3, Δ0 ++ Δ1)])
+        (Γ0 ++ B :: x ++ A0 --> B0 :: Γ3, Δ0 ++ Δ1) H0 d1).
+        exists d2. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+        destruct X. exists x8. split. lia. lia. }
+  (* GLR *)
+  * inversion X. subst. pose (univ_gen_ext_splitR _ _ X0). repeat destruct s. repeat destruct p. subst.
+    assert (J0: dersrec_height d = dersrec_height d). reflexivity.
+    pose (dersrec_derrec_height d J0). destruct s.
+    assert (GLRRule [(XBoxed_list (x ++ x0) ++ [Box A0], [A0])] (Γ0 ++ Γ1, Δ0 ++ Δ1)).
+    rewrite <- H2. apply GLRRule_I ; try assumption. apply univ_gen_ext_combine.
+    assumption. apply univ_gen_ext_not_In_delete with (a:=A --> B). intro.
+    assert (In (A --> B) (x ++ x0)). apply in_or_app. auto. apply H1 in H0. destruct H0.
+    inversion H0. assumption.
+    assert (existsT2 (D : derrec GLS_rules (fun _ : Seq => False) (Γ0 ++ Γ1, Δ0 ++ Δ1)),
+    derrec_height D <= S (dersrec_height d)).
+    apply GLR in X1.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[(XBoxed_list (x ++ x0) ++ [Box A0], [A0])]) (Γ0 ++ Γ1, Δ0 ++ Δ1) X1 d).
+    exists d0. simpl. lia.
+    destruct X2.
+    assert (J1: derrec_height x2 = derrec_height x2). reflexivity.
+    assert (J2: wkn_L B (Γ0 ++ Γ1, Δ0 ++ Δ1) (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)). apply wkn_LI.
+    pose (GLS_wkn_L x2 J1 J2). destruct s.
+    assert (J3: wkn_R A (Γ0 ++ Γ1, Δ0 ++ Δ1) (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)). apply wkn_RI.
+    pose (GLS_wkn_R x2 J1 J3). destruct s. exists x4. exists x3. simpl.
+    split ; lia. }
+Qed.
+ +
+Theorem ImpR_inv : forall concl prem, (GLS_prv concl) ->
+                                      (ImpRRule [prem] concl) ->
+                                      (GLS_prv prem).
+Proof.
+intros.
+assert (J1: derrec_height X = derrec_height X). reflexivity.
+pose (ImpR_ImpL_hpinv X J1). destruct p. pose (s _ H). destruct s1. assumption.
+Qed.
+ +
+Theorem ImpL_inv : forall concl prem1 prem2, (GLS_prv concl) ->
+                                      (ImpLRule [prem1;prem2] concl) ->
+                                      (GLS_prv prem1) *
+                                      (GLS_prv prem2).
+Proof.
+intros.
+assert (J1: derrec_height X = derrec_height X). reflexivity.
+pose (ImpR_ImpL_hpinv X J1). destruct p. pose (s0 _ _ H). repeat destruct s1. auto.
+Qed.
+
+
+ +
+ + + diff --git a/GL.GLS.GLS_termination_measure.html b/GL.GLS.GLS_termination_measure.html new file mode 100644 index 0000000..2201662 --- /dev/null +++ b/GL.GLS.GLS_termination_measure.html @@ -0,0 +1,864 @@ + + + + + + + + + + + + + +
+
+

GL.GLS.GLS_termination_measure

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+Require Import Wellfounded.
+ +
+Require Import GLS_calcs.
+Require Import DLW_wf_lex.
+ +
+Set Implicit Arguments.
+ +
+Lemma NoDup_incl_lengthT : forall (l l' : list MPropF), NoDup l -> incl l l' ->
+          {length l < length l'} + {length l = length l'}.
+Proof. intros. apply Compare_dec.le_lt_eq_dec, NoDup_incl_length; assumption. Qed.
+ +
+(* First, let us define a the second part of our measure. This number is simply
+   the number of implication symbols in a sequent.
+
+   To define it, we need to define the number of implications in a formula. *)

+ +
+Fixpoint n_imp_subformF (A : MPropF) : nat :=
+match A with
+ | # P => 0
+ | => 0
+ | Imp B C => 1 + (n_imp_subformF B) + (n_imp_subformF C)
+ | Box B => (n_imp_subformF B)
+end.
+ +
+(* With this definition in hand, we can then straightforwardly define the number
+   of implications in a list of formulae. *)

+ +
+Fixpoint n_imp_subformLF (l : list MPropF) : nat :=
+match l with
+  | [] => 0
+  | h :: t => (n_imp_subformF h) + (n_imp_subformLF t)
+end.
+ +
+(* The the definition we were initially looking for can be reached: *)
+ +
+Definition n_imp_subformS (s : Seq) : nat :=
+    (n_imp_subformLF (fst s)) + (n_imp_subformLF (snd s)).
+ +
+(* It is clear that n_imp_subformS counts the occurrences of implications in a
+   sequent s. As a consequence, if that number is 0 we know for sure that the
+   rules for implication on the left or right cannot be applied upwards on s.
+   This is the meaning of the lemma n_imp_subformS_is_0. 
+
+   But first we need a preliminary lemma which claims that if an implication is
+   in a list, then n_imp_subformLF of that list is higher than one.*)

+ +
+Lemma In_n_imp_subformLF_is_non_0 (l : list MPropF) :
+    forall A B, (In (Imp A B) l) -> (le 1 (n_imp_subformLF l)).
+Proof.
+intros A B Hin. induction l.
+- inversion Hin.
+- inversion Hin.
+  * subst. simpl. rewrite <- Nat.succ_le_mono. apply le_0_n.
+  * pose (IHl H). simpl. destruct l0.
+    + rewrite Nat.add_1_r. rewrite <- Nat.succ_le_mono. apply le_0_n.
+    + rewrite <- plus_n_Sm. rewrite <- Nat.succ_le_mono. apply le_0_n.
+Qed.
+ +
+Theorem n_imp_subformS_is_0 (s : Seq) :
+    (n_imp_subformS s) = 0 -> (existsT2 ps, (ImpRRule ps s) + (ImpLRule ps s)) -> False.
+Proof.
+intros is0 RA. destruct RA. destruct s0.
+- inversion i. subst. unfold n_imp_subformS in is0. simpl in is0.
+  assert (n_imp_subformLF (Δ0 ++ A --> B :: Δ1) = 0). lia.
+  assert (In (A --> B) (Δ0 ++ A --> B :: Δ1)). apply in_or_app. right. apply in_eq.
+  pose (In_n_imp_subformLF_is_non_0 (Δ0 ++ A --> B :: Δ1) A B H0). lia.
+- inversion i. subst.
+  assert (In (A --> B) (Γ0 ++ A --> B :: Γ1)). apply in_or_app. right. apply in_eq.
+  pose (In_n_imp_subformLF_is_non_0 (Γ0 ++ A --> B :: Γ1) A B H). unfold n_imp_subformS in is0.
+  simpl in is0. assert (n_imp_subformLF (Δ0 ++ Δ1) = 0). lia. lia.
+Qed.
+ +
+Lemma n_imp_subformLF_dist_app : forall l1 l2, n_imp_subformLF (l1 ++ l2) =
+                                               plus (n_imp_subformLF l1) (n_imp_subformLF l2).
+Proof.
+induction l1.
+- intros. auto.
+- intros. simpl. rewrite IHl1. lia.
+Qed.
+ +
+(* Second, we intend to define the notion of usable boxed formulae in a sequent. We also
+   prove that if this measure is 0 then no GLR rule can be applied to this sequent.
+
+   In the next definitions our aim is to define the list of all boxed subformulae (not
+   occurrences) of all the formulae in a sequent. *)

+ +
+Fixpoint subform_boxesF (A : MPropF) : list MPropF :=
+match A with
+ | # P => nil
+ | => nil
+ | Imp B C => (subform_boxesF B) ++ (remove_list (subform_boxesF B) (subform_boxesF C))
+ | Box B => (Box B) :: (subform_boxesF B)
+end.
+ +
+Fixpoint subform_boxesLF (l : list MPropF) : list MPropF :=
+match l with
+  | nil => nil
+  | h :: t => (subform_boxesF h) ++ (remove_list (subform_boxesF h) (subform_boxesLF t))
+end.
+ +
+Definition subform_boxesS (s : Seq) : list MPropF :=
+  (subform_boxesLF (fst s)) ++ (remove_list (subform_boxesLF (fst s)) (subform_boxesLF (snd s))).
+ +
+Lemma In_subform_boxesF_box : forall (A B : MPropF), In A (subform_boxesF B) -> is_boxedT A.
+Proof.
+unfold is_boxedT. intros A B. generalize dependent A. induction B ; intros.
+- simpl in H. destruct H.
+- simpl in H. destruct H.
+- simpl in H. apply in_app_or in H. destruct H.
+  * apply IHB1 in H. assumption.
+  * assert (In A (subform_boxesF B2)). apply In_remove_list_In_list in H. assumption.
+    apply IHB2 in H0. assumption.
+- simpl in H. destruct H. exists B. auto. apply IHB in H. assumption.
+Qed.
+ +
+Lemma In_subform_boxesLF_box : forall (A : MPropF) l, In A (subform_boxesLF l) -> is_boxedT A.
+Proof.
+unfold is_boxedT. intros A l. generalize dependent A. induction l ; intros.
+- simpl in H. destruct H.
+- simpl in H. apply in_app_or in H. destruct H. apply In_subform_boxesF_box in H. assumption.
+  apply In_remove_list_In_list in H. apply IHl. assumption.
+Qed.
+ +
+(* Then next lemmas help us reach our goal. *)
+ +
+Fixpoint length_form (a: MPropF) : nat :=
+match a with
+  | # n => 1
+  | => 1
+  | Imp a0 a1 => S (length_form a0 + length_form a1)
+  | Box a0 => S (length_form a0)
+end.
+ +
+Lemma S_le_False : forall (n : nat), S n <= n -> False.
+Proof.
+induction n.
+- intro. inversion H.
+- intro. apply Nat.succ_le_mono in H. apply IHn. assumption.
+Qed.
+ +
+Lemma in_subform_boxesF_smaller_length_form : forall (A B : MPropF), In A (subform_boxesF B) ->
+                (length_form A <= length_form B).
+Proof.
+intros A B. generalize dependent A. induction B; intros .
+- simpl. inversion H.
+- simpl. inversion H.
+- simpl. simpl in H. apply in_app_or in H. destruct H.
+  * apply IHB1 in H. lia.
+  * assert (In A (subform_boxesF B2)). apply In_remove_list_In_list in H. assumption.
+    apply IHB2 in H0. lia.
+- simpl in H. destruct H. subst. auto. apply IHB in H. simpl. apply le_S. assumption.
+Qed.
+ +
+Lemma contradic_subform_boxesF: forall A l, (l = (subform_boxesF A)) -> (In (Box A) l) -> False.
+Proof.
+intros. subst. pose (in_subform_boxesF_smaller_length_form (Box A) A H0).
+inversion l.
+- apply eq_S_F in H1. assumption.
+- simpl in l. apply S_le_False in l. assumption.
+Qed.
+ +
+Lemma NoDup_subform_boxesF : forall A, NoDup (subform_boxesF A).
+Proof.
+induction A.
+- simpl. apply NoDup_nil.
+- simpl. apply NoDup_nil.
+- simpl. apply add_remove_list_preserve_NoDup. apply IHA1. apply IHA2.
+- simpl. apply NoDup_cons. intro. apply contradic_subform_boxesF in H. assumption.
+  reflexivity. apply IHA.
+Qed.
+ +
+Lemma subform_boxesLF_dist_app : forall l1 l2,
+        (subform_boxesLF (l1 ++ l2)) =
+        (subform_boxesLF l1) ++ (remove_list (subform_boxesLF l1) (subform_boxesLF l2)).
+Proof.
+induction l1.
+- intros l2. simpl. reflexivity.
+- intros l2. simpl. rewrite IHl1. repeat rewrite <- app_assoc.
+  assert (E: remove_list (subform_boxesF a) (subform_boxesLF l1 ++
+             remove_list (subform_boxesLF l1) (subform_boxesLF l2)) =
+             remove_list (subform_boxesF a) (subform_boxesLF l1) ++
+             remove_list (subform_boxesF a ++ remove_list (subform_boxesF a)
+             (subform_boxesLF l1)) (subform_boxesLF l2)).
+  { rewrite app_remove_list. rewrite redund_remove_list. rewrite <- remove_list_dist_app. reflexivity. }
+  rewrite E. reflexivity.
+Qed.
+ +
+Lemma NoDup_subform_boxesLF : forall l, NoDup (subform_boxesLF l).
+Proof.
+induction l.
+- intros. simpl. apply NoDup_nil.
+- intros. simpl. apply add_remove_list_preserve_NoDup. apply NoDup_subform_boxesF.
+  apply IHl.
+Qed.
+ +
+Lemma NoDup_subform_boxesS : forall s, NoDup (subform_boxesS s).
+Proof.
+intro s. unfold subform_boxesS. apply add_remove_list_preserve_NoDup ;
+apply NoDup_subform_boxesLF.
+Qed.
+ +
+Lemma univ_gen_ext_incl_subform_boxes : forall l1 l2 P, (univ_gen_ext P l1 l2) ->
+                                          incl (subform_boxesLF l1) (subform_boxesLF l2).
+Proof.
+intros. induction X.
+- unfold incl. intros. auto.
+- unfold incl. intros. simpl in H. simpl. apply in_app_or in H. destruct H.
+  * apply in_or_app. left. assumption.
+  * apply In_remove_list_In_list_not_In_remove_list in H. destruct H.
+    apply in_or_app. right. apply not_removed_remove_list. apply IHX. assumption.
+    assumption.
+- unfold incl. intros. simpl. destruct (In_dec (subform_boxesF x) a).
+  * apply in_or_app. left. assumption.
+  * apply in_or_app. right. apply not_removed_remove_list. apply IHX. assumption.
+    assumption.
+Qed.
+ +
+Lemma XBoxed_list_same_subform_boxes : forall l,
+          incl (subform_boxesLF (XBoxed_list l)) (subform_boxesLF l) /\
+          incl (subform_boxesLF l) (subform_boxesLF (XBoxed_list l)).
+Proof.
+induction l.
+- split.
+  * unfold incl. intros. simpl in H. inversion H.
+  * unfold incl. intros. simpl in H. inversion H.
+- split.
+  * unfold incl. intros. simpl. simpl in H. apply in_app_or in H. destruct H.
+    apply in_or_app. left. destruct a ; simpl in H ; try contradiction.
+    simpl. assumption. simpl. right. assumption. apply In_remove_list_In_list in H.
+    apply in_app_or in H. destruct H. apply in_or_app. left. assumption. apply in_or_app.
+    right. apply In_remove_list_In_list_not_In_remove_list in H. destruct H. destruct IHl.
+    apply H1 in H. apply not_removed_remove_list ; assumption.
+  * destruct IHl. unfold incl. intros. simpl in H1. apply in_app_or in H1. destruct H1.
+    destruct a ; simpl in H1 ; try contradiction. apply in_app_or in H1. destruct H1.
+    simpl. apply in_or_app. left. apply in_or_app. left. assumption. apply
+    In_remove_list_In_list_not_In_remove_list in H1. destruct H1. simpl. apply in_or_app.
+    left. apply in_or_app. right. apply not_removed_remove_list ; assumption. destruct H1.
+    subst. simpl. apply in_or_app. right. apply not_removed_remove_list. apply in_eq.
+    intros. apply contradic_subform_boxesF in H1. assumption. auto. simpl. apply in_or_app.
+    left. assumption. simpl. apply in_or_app. right. rewrite remove_list_dist_app.
+    apply in_or_app. right. apply not_removed_remove_list. apply
+    In_remove_list_In_list_not_In_remove_list in H1. destruct H1. apply H0 in H1.
+    apply not_removed_remove_list ; assumption. intro. apply
+    In_remove_list_In_list_not_In_remove_list in H1. destruct H1. destruct a ; simpl ; try assumption.
+    simpl (unBox_formula (a1 --> a2)) in H2. firstorder. simpl (unBox_formula (Box a)) in H2.
+    apply H3. simpl. right. assumption.
+Qed.
+ +
+Lemma In_incl_subform_boxes : forall l A, In A l ->
+                  (forall B, In B (subform_boxesF A) -> In B (subform_boxesLF l)).
+Proof.
+induction l.
+- intros. inversion H.
+- intros. simpl. inversion H.
+  * subst. apply in_or_app. left. assumption.
+  * pose (IHl A H1). destruct (In_dec (subform_boxesF a) B).
+    + apply in_or_app. left. assumption.
+    + apply in_or_app. right. apply not_removed_remove_list. apply i. assumption.
+      assumption.
+Qed.
+ +
+(* Now we can define the notion of usable boxed formulae: it is a one such that
+   it does not appear as a top formula in the LHS of the sequent. To do so, we need to
+   define the list of such formulae: *)

+ +
+Lemma top_boxes_incl_list : forall l, incl (top_boxes l) l.
+Proof.
+induction l.
+- simpl. unfold incl. intros. inversion H.
+- unfold incl. intros. destruct a.
+  * simpl in H. apply in_cons. apply IHl. assumption.
+  * simpl in H. apply in_cons. apply IHl. assumption.
+  * simpl in H. apply in_cons. apply IHl. assumption.
+  * simpl in H. destruct H.
+    + subst. apply in_eq.
+    + apply in_cons. apply IHl. assumption.
+Qed.
+ +
+Lemma in_top_boxes : forall l A, (In A (top_boxes l)) -> (existsT2 B l1 l2, (A = Box B) * (l = l1 ++ A :: l2)).
+Proof.
+induction l.
+- intros. simpl in H. inversion H.
+- intros. destruct a as [n | | |].
+  * simpl in H. apply IHl in H. destruct H. destruct s. destruct s. destruct p. subst.
+    exists x. exists ([# n] ++ x0). exists x1. auto.
+  * simpl in H. apply IHl in H. destruct H. destruct s. destruct s. destruct p. subst.
+    exists x. exists ([] ++ x0). exists x1. auto.
+  * simpl in H. apply IHl in H. destruct H. destruct s. destruct s. destruct p. subst.
+    exists x. exists ([a1 --> a2] ++ x0). exists x1. auto.
+  * simpl (top_boxes (Box a :: l)) in H. destruct (eq_dec_form (Box a) A).
+    + subst. exists a. exists []. exists l. auto.
+    + subst. assert (H0 : In A (top_boxes l)). inversion H. exfalso. apply n. assumption.
+      assumption. apply IHl in H0. destruct H0. destruct s. destruct s. destruct p.
+      subst. exists x. exists ([Box a] ++ x0). exists x1. auto.
+Qed.
+ +
+Lemma box_preserv_top_boxes : forall l1 l2 l3 A, top_boxes l1 = l2 ++ Box A :: l3 ->
+                                existsT2 l4 l5, l1 = l4 ++ Box A :: l5.
+Proof.
+induction l1.
+- intros. simpl in H. destruct l2 ; inversion H.
+- induction l2.
+  * intros. rewrite app_nil_l in H. destruct a as [n | | |].
+    + pose (IHl1 [] l3 A). simpl in s. apply s in H. destruct H. destruct s0. exists ([# n] ++ x).
+      exists x0. subst. auto.
+    + pose (IHl1 [] l3 A). simpl in s. apply s in H. destruct H. destruct s0. exists ([] ++ x).
+      exists x0. subst. auto.
+    + pose (IHl1 [] l3 A). simpl in s. apply s in H. destruct H. destruct s0. exists ([a1 --> a2] ++ x).
+      exists x0. subst. auto.
+    + inversion H. exists []. exists l1. auto.
+  * intros. destruct a as [n | | |].
+    + simpl in H. pose (IHl1 (a0 :: l2) l3 A). simpl in s. apply s in H. destruct H. destruct s0. exists ([# n] ++ x).
+      exists x0. subst. auto.
+    + simpl in H. pose (IHl1 (a0 :: l2) l3 A). simpl in s. apply s in H. destruct H. destruct s0. exists ([] ++ x).
+      exists x0. subst. auto.
+    + simpl in H. pose (IHl1 (a0 :: l2) l3 A). simpl in s. apply s in H. destruct H. destruct s0. exists ([a1 --> a2] ++ x).
+      exists x0. subst. auto.
+    + inversion H. apply IHl1 in H2. destruct H2. destruct s. subst. exists (Box a :: x). exists x0. auto.
+Qed.
+ +
+Lemma removed_box_exists : forall l1 l2 l3 A,
+    (remove_list (top_boxes l1) (top_boxes (l2 ++ Box A :: l3))) = nil ->
+    (existsT2 l4 l5, l1 = l4 ++ Box A :: l5).
+Proof.
+intros. pose (box_in_top_boxes l2 l3 A). repeat destruct s. rewrite e in H.
+remember (top_boxes l1) as l. apply remove_list_in_nil in H. destruct H.
+destruct s. subst. apply box_preserv_top_boxes in e0. assumption.
+Qed.
+ +
+Lemma is_box_in_top_boxes : forall l A, In A l -> is_boxedT A -> In A (top_boxes l).
+Proof.
+induction l.
+- intros. inversion H.
+- intros. inversion H.
+  * subst. inversion X. subst. simpl. left. reflexivity.
+  * pose (IHl A H0 X). destruct a ; simpl ; try assumption.
+    right. assumption.
+Qed.
+ +
+(* Some more 'macro' lemmas dealing with subform_boxes and top_boxes. *)
+ +
+Lemma RHS_top_box_is_subformLF : forall (s : Seq) (A : MPropF),
+        (In A (top_boxes (snd s))) -> (In A (subform_boxesLF (snd s))).
+Proof.
+intros s A H. apply in_top_boxes in H. destruct H. repeat destruct s0. destruct p. subst. rewrite e0.
+rewrite subform_boxesLF_dist_app. apply in_or_app. pose (In_dec (subform_boxesLF x0) (Box x)).
+destruct s0.
+- left. assumption.
+- right. apply not_removed_remove_list.
+  * simpl. left. reflexivity.
+  * assumption.
+Qed.
+ +
+Lemma RHS_top_box_is_subform : forall s A, (In A (top_boxes (snd s))) -> (In A (subform_boxesS s)).
+Proof.
+intros s A H. unfold subform_boxesS. apply RHS_top_box_is_subformLF in H.
+apply remove_list_is_in with (l2:=subform_boxesLF (fst s)) in H. assumption.
+Qed.
+ +
+(* Finally, we can define the list of usable boxed formulae. The length of that list is
+   the first component of our measure. *)

+ +
+Definition usable_boxes (s : Seq) : list MPropF :=
+   remove_list (top_boxes (fst s)) (subform_boxesS s).
+ +
+(* We can show that our notion of usable box effectively captures what it is intended to:
+   an upper bound on how many GLR rules can be applied to a sequent. To check this, we can
+   show that if the number of usable boxes is effectively 0 then no GLR is applicable. This
+   is the content of the lemma length_usable_boxes_is_0. *)

+ +
+Lemma no_RHS_box_no_GLR (s : Seq) :
+    (top_boxes (snd s)) = nil -> (existsT2 ps, GLRRule ps s) -> False.
+Proof.
+intros isnil RA. destruct RA. inversion g. subst. simpl in isnil.
+rewrite top_boxes_distr_app in isnil. apply app_eq_nil in isnil. destruct isnil.
+simpl in H1. inversion H1.
+Qed.
+ +
+Lemma all_RHS_boxes_are_LHS_boxes_no_GLR (s : Seq) :
+    (IdBRule [] s -> False) -> (* This line makes sure that we do PS: no IdB can happen. *)
+    (remove_list (top_boxes (fst s)) (top_boxes (snd s))) = nil ->
+    (existsT2 ps, GLRRule ps s) -> False.
+Proof.
+intros noId isnil RA. destruct RA. inversion g. subst. simpl in isnil.
+apply noId. apply removed_box_exists in isnil. destruct isnil. destruct s.
+subst. apply IdBRule_I.
+Qed.
+ +
+Lemma no_usable_boxes_all_RHS_are_LHS (s : Seq) :
+    length (usable_boxes s) = 0 -> (remove_list (top_boxes (fst s)) (top_boxes (snd s))) = nil.
+Proof.
+intro is0. remember (usable_boxes s) as l. destruct l.
+- unfold usable_boxes in Heql. symmetry in Heql. rewrite remove_list_is_nil in Heql.
+  rewrite remove_list_is_nil. intros. apply RHS_top_box_is_subform in H. apply Heql. assumption.
+- inversion is0.
+Qed.
+ +
+Theorem length_usable_boxes_is_0 (s : Seq) :
+    length (usable_boxes s) = 0 ->
+    (IdBRule [] s -> False) ->
+    (existsT2 ps, GLRRule ps s) -> False.
+Proof.
+intros H0 H1. pose (no_usable_boxes_all_RHS_are_LHS s H0).
+pose (all_RHS_boxes_are_LHS_boxes_no_GLR H1 e). assumption.
+Qed.
+ +
+Lemma NoDup_usable_boxes : forall s, NoDup (usable_boxes s).
+Proof.
+intro s. unfold usable_boxes. destruct s. simpl. unfold subform_boxesS.
+simpl. pose (NoDup_subform_boxesLF l0). pose (NoDup_subform_boxesLF l).
+pose (add_remove_list_preserve_NoDup _ _ n0 n). apply remove_list_preserv_NoDup.
+assumption.
+Qed.
+ +
+(* We can consequently define our measure on sequents: *)
+ +
+Definition measure (s : Seq) : list nat :=
+  [length (usable_boxes s) ; (n_imp_subformS s)].
+ +
+(* Fourth, we show that the number of usable boxes decreases upwards in the application
+   of a GLR rule. To do so we need to prove some lemmas beforehand. *)

+ +
+Lemma GLR_applic_more_top_boxes : forall prem concl, GLRRule [prem] concl ->
+                                                     (IdBRule [] concl -> False) ->
+                                    incl (top_boxes (fst concl)) (top_boxes (fst prem)).
+Proof.
+intros prem concl RA noIdB. inversion RA. subst. simpl. rewrite top_boxes_distr_app.
+simpl. unfold incl. intros. apply in_or_app. left. assert (In a Γ0). apply in_top_boxes in H.
+destruct H. repeat destruct s. destruct p. subst. apply in_or_app. right. apply in_eq.
+assert (InT a Γ0). apply in_splitT in H1. destruct H1. destruct s. rewrite e.
+apply InT_or_app. right. apply InT_eq. pose (InT_univ_gen_ext H2 X). destruct s.
+exfalso. apply f. apply in_top_boxes in H. destruct H. repeat destruct s.
+destruct p. exists x. assumption. apply top_boxes_incl_list in H.
+pose (list_preserv_XBoxed_list ). pose (InT_In i). apply i0 in i1.
+apply is_box_in_top_boxes. apply i0. apply InT_In. assumption.
+apply H0. apply InT_In. assumption.
+Qed.
+ +
+Lemma GLR_applic_le_subform_boxes : forall prem concl, GLRRule [prem] concl ->
+                                                        (IdBRule [] concl -> False) ->
+                        (length (subform_boxesS prem) <= length (subform_boxesS concl) /\
+                         forall B, (In B (subform_boxesS prem)) -> (In B (subform_boxesS concl))).
+Proof.
+intros prem concl RA noIdB. inversion RA. subst. split.
+- apply NoDup_incl_length.
+  * apply NoDup_subform_boxesS.
+  * intro. intros. unfold subform_boxesS in H. unfold subform_boxesS. simpl. simpl in H.
+    repeat rewrite app_length. repeat rewrite app_length in H. repeat rewrite remove_list_of_nil.
+    repeat rewrite remove_list_of_nil in H. rewrite app_nil_r in H. apply in_app_or in H.
+    destruct H. rewrite subform_boxesLF_dist_app in H. apply in_app_or in H. destruct H.
+    apply in_or_app. left. apply univ_gen_ext_incl_subform_boxes in X. apply X. pose (XBoxed_list_same_subform_boxes ).
+    destruct a0. apply H1. assumption. apply In_remove_list_In_list in H.
+    apply remove_list_is_in. rewrite subform_boxesLF_dist_app. apply remove_list_is_in.
+    simpl. simpl in H. destruct H. left. assumption. right. repeat rewrite remove_list_of_nil in H.
+    apply in_app_or in H. destruct H. apply in_or_app. auto. simpl in H. destruct H.
+    apply remove_list_is_in. apply In_remove_list_In_list in H. rewrite subform_boxesLF_dist_app.
+    apply remove_list_is_in. simpl. right. apply in_or_app. auto.
+- intro. intros. unfold subform_boxesS in H. unfold subform_boxesS. simpl. simpl in H.
+  repeat rewrite app_length. repeat rewrite app_length in H. repeat rewrite remove_list_of_nil.
+  repeat rewrite remove_list_of_nil in H. rewrite app_nil_r in H. apply in_app_or in H.
+  destruct H. rewrite subform_boxesLF_dist_app in H. apply in_app_or in H. destruct H.
+  apply in_or_app. left. apply univ_gen_ext_incl_subform_boxes in X. apply X. pose (XBoxed_list_same_subform_boxes ).
+  destruct a. apply H1. assumption. apply In_remove_list_In_list in H.
+  apply remove_list_is_in. rewrite subform_boxesLF_dist_app. apply remove_list_is_in.
+  simpl. simpl in H. destruct H. left. assumption. right. repeat rewrite remove_list_of_nil in H.
+  apply in_app_or in H. destruct H. apply in_or_app. auto. simpl in H. destruct H.
+  apply remove_list_is_in. apply In_remove_list_In_list in H. rewrite subform_boxesLF_dist_app.
+  apply remove_list_is_in. simpl. right. apply in_or_app. auto.
+Qed.
+ +
+Theorem GLR_applic_less_usable_boxes : forall prem concl, GLRRule [prem] concl ->
+                                                          (IdBRule [] concl -> False) ->
+                                         length (usable_boxes prem) < length (usable_boxes concl).
+Proof.
+intros prem concl RA noIdB. inversion RA. unfold usable_boxes. simpl.
+apply remove_list_incr_decr.
+- apply NoDup_subform_boxesS.
+- apply NoDup_subform_boxesS.
+- exists (Box A). repeat split. simpl. rewrite top_boxes_distr_app. apply in_or_app. right. simpl.
+  left. reflexivity. unfold subform_boxesS. simpl.
+  destruct (In_dec (subform_boxesLF Γ0) (Box A)). apply in_or_app. left. assumption.
+  apply in_or_app. right. apply not_removed_remove_list. rewrite subform_boxesLF_dist_app.
+  destruct (In_dec (subform_boxesLF Δ0) (Box A)). apply in_or_app. left. assumption.
+  apply in_or_app. right. apply not_removed_remove_list. simpl. auto. assumption. assumption.
+  intro. simpl in H2. apply noIdB. subst. pose (in_top_boxes Γ0 (Box A) H2). repeat destruct s.
+  destruct p. subst. apply IdBRule_I.
+- intro A0. pose (@GLR_applic_more_top_boxes prem concl). subst. pose (i RA). pose (i0 noIdB).
+  apply i1.
+- intro A0. subst. pose (GLR_applic_le_subform_boxes RA noIdB). destruct a. apply H1.
+Qed.
+ +
+Theorem ImpR_applic_less_Imp_same_usable_boxes : forall prem concl, ImpRRule [prem] concl ->
+                   prod (sumbool (length (usable_boxes prem) < length(usable_boxes concl))
+                    (length (usable_boxes prem) = length(usable_boxes concl)))
+                   (n_imp_subformS (prem) < n_imp_subformS (concl)).
+Proof.
+intros prem concl RA. inversion RA. subst. split.
+- pose (NoDup_usable_boxes (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)).
+  pose (NoDup_usable_boxes (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)).
+  apply NoDup_incl_lengthT. assumption. unfold incl. intros. unfold usable_boxes in H. simpl in H.
+  unfold usable_boxes. simpl. apply In_remove_list_In_list_not_In_remove_list in H.
+  destruct H. apply not_removed_remove_list. unfold subform_boxesS. unfold subform_boxesS in H.
+  simpl. simpl in H. apply in_app_or in H. destruct H. rewrite subform_boxesLF_dist_app in H.
+  apply in_app_or in H. destruct H. apply in_or_app. left. rewrite subform_boxesLF_dist_app.
+  apply in_or_app. left. assumption. apply In_remove_list_In_list_not_In_remove_list in H.
+  destruct H. simpl in H. apply in_app_or in H. destruct H. destruct (In_dec (subform_boxesLF (Γ0 ++ Γ1)) a).
+  apply in_or_app. left. assumption. apply in_or_app. right. apply not_removed_remove_list.
+  2: assumption. apply In_incl_subform_boxes with (A:=A --> B). apply in_or_app. right. apply in_eq.
+  simpl. apply in_or_app. left.
+  assumption. apply In_remove_list_In_list_not_In_remove_list in H. destruct H. apply in_or_app. left.
+  rewrite subform_boxesLF_dist_app. apply in_or_app. right. apply not_removed_remove_list. assumption.
+  assumption. apply In_remove_list_In_list_not_In_remove_list in H. destruct H. rewrite subform_boxesLF_dist_app in H.
+  apply in_app_or in H. destruct H. apply in_or_app. right. apply not_removed_remove_list.
+  rewrite subform_boxesLF_dist_app. apply in_or_app. left. assumption. intro.
+  apply H1. rewrite subform_boxesLF_dist_app. apply in_or_app.
+  rewrite subform_boxesLF_dist_app in H2. apply in_app_or in H2.
+  destruct H2. auto. apply In_remove_list_In_list_not_In_remove_list in H2. destruct H2.
+  right. apply not_removed_remove_list. simpl. apply in_or_app. right. apply not_removed_remove_list.
+  assumption. intro. apply H1. rewrite subform_boxesLF_dist_app. apply in_or_app. right.
+  apply not_removed_remove_list. simpl. apply in_or_app. left. assumption. assumption. assumption.
+  apply in_or_app. right. apply not_removed_remove_list. apply In_remove_list_In_list_not_In_remove_list in H.
+  destruct H. simpl in H. apply in_app_or in H. destruct H. apply In_incl_subform_boxes with (A:=A --> B).
+  apply in_or_app. right. apply in_eq. simpl. apply in_or_app. right. apply not_removed_remove_list. assumption.
+  intro. apply H1. rewrite subform_boxesLF_dist_app. apply in_or_app. right. apply not_removed_remove_list.
+  simpl. apply in_or_app. left. assumption. intro. apply H1. rewrite subform_boxesLF_dist_app. apply in_or_app.
+  auto. apply In_remove_list_In_list_not_In_remove_list in H. destruct H.
+  rewrite subform_boxesLF_dist_app.
+  apply in_or_app. right. apply not_removed_remove_list. simpl. apply in_or_app. right.
+  apply not_removed_remove_list. assumption. intro. apply in_app_or in H4. destruct H4.
+  apply H1. rewrite subform_boxesLF_dist_app. apply in_or_app. right. apply not_removed_remove_list.
+  simpl. apply in_or_app. left. assumption. intro. apply H1. rewrite subform_boxesLF_dist_app.
+  apply in_or_app. auto. apply H3. apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+  assumption. assumption. intro. apply H1. rewrite subform_boxesLF_dist_app.
+  apply in_or_app. rewrite subform_boxesLF_dist_app in H2. apply in_app_or in H2.
+  destruct H2. auto. apply In_remove_list_In_list_not_In_remove_list in H2.
+  destruct H2. right. apply not_removed_remove_list. simpl. apply in_or_app. right.
+  apply not_removed_remove_list. assumption. intro. apply H1. rewrite subform_boxesLF_dist_app.
+  apply in_or_app. right. apply not_removed_remove_list. simpl. apply in_or_app. auto.
+  assumption. assumption. intro. apply H0. rewrite top_boxes_distr_app. rewrite top_boxes_distr_app in H1.
+  apply in_app_or in H1. destruct H1. apply in_or_app. auto. apply in_or_app. right.
+  assert (A :: Γ1 = [A] ++ Γ1). auto. rewrite H2. rewrite top_boxes_distr_app. apply in_or_app. right.
+  auto.
+- unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl. lia.
+Qed.
+ +
+Theorem ImpL_applic_less_Imp_same_usable_boxes : forall prem1 prem2 concl, ImpLRule [prem1 ; prem2] concl ->
+                   prod (prod (sumbool (length (usable_boxes prem1) < length(usable_boxes concl))
+                    (length (usable_boxes prem1) = length(usable_boxes concl)))
+                   (n_imp_subformS (prem1) < n_imp_subformS (concl)))
+                   (prod (sumbool (length (usable_boxes prem2) < length(usable_boxes concl))
+                    (length (usable_boxes prem2) = length(usable_boxes concl)))
+                   (n_imp_subformS (prem2) < n_imp_subformS (concl))).
+Proof.
+intros prem1 prem2 concl RA. inversion RA. subst. split.
+- split.
+  * pose (NoDup_usable_boxes (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)).
+    pose (NoDup_usable_boxes (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+    apply NoDup_incl_lengthT. assumption. unfold incl. intros. unfold usable_boxes in H. simpl in H.
+    unfold usable_boxes. simpl. apply In_remove_list_In_list_not_In_remove_list in H.
+    destruct H. apply not_removed_remove_list. unfold subform_boxesS. unfold subform_boxesS in H.
+    simpl. simpl in H. apply in_app_or in H. destruct H. rewrite subform_boxesLF_dist_app in H.
+    apply in_app_or in H. destruct H. apply in_or_app. left. rewrite subform_boxesLF_dist_app.
+    apply in_or_app. auto. apply in_or_app.
+    apply In_remove_list_In_list_not_In_remove_list in H. destruct H. left.
+    rewrite subform_boxesLF_dist_app. apply in_or_app. right.
+    apply not_removed_remove_list. simpl. apply in_or_app.
+    destruct (In_dec (subform_boxesF A ++ remove_list (subform_boxesF A) (subform_boxesF B)) a).
+    auto. right. apply not_removed_remove_list.
+    assumption. assumption. assumption. apply In_remove_list_In_list_not_In_remove_list in H.
+    destruct H. rewrite subform_boxesLF_dist_app in H. apply in_app_or in H. destruct H. apply in_or_app.
+    destruct (In_dec (subform_boxesLF (Γ0 ++ A --> B :: Γ1)) a). auto. right. apply not_removed_remove_list.
+    2: assumption. rewrite subform_boxesLF_dist_app. apply in_or_app. auto.
+    apply in_or_app. apply In_remove_list_In_list_not_In_remove_list in H. destruct H. simpl in H. apply in_app_or in H.
+    destruct H. left. assert (In a (subform_boxesF (A --> B))). simpl. apply in_or_app. auto.
+    apply In_incl_subform_boxes with (A:=A --> B). apply in_or_app. right. apply in_eq. assumption.
+    apply In_remove_list_In_list_not_In_remove_list in H. destruct H.
+    destruct (In_dec (subform_boxesLF (Γ0 ++ A --> B :: Γ1)) a). auto. right.
+    apply not_removed_remove_list. rewrite subform_boxesLF_dist_app. apply in_or_app. right. apply not_removed_remove_list.
+    assumption. assumption. assumption. intro. apply H0. rewrite top_boxes_distr_app in H1. rewrite top_boxes_distr_app.
+    apply in_or_app. apply in_app_or in H1. destruct H1. auto. simpl in H1. auto.
+  * unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl. lia.
+- split.
+  * pose (NoDup_usable_boxes (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)).
+    pose (NoDup_usable_boxes (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+    apply NoDup_incl_lengthT. assumption. unfold incl. intros. unfold usable_boxes in H. simpl in H.
+    unfold usable_boxes. simpl. apply In_remove_list_In_list_not_In_remove_list in H.
+    destruct H. apply not_removed_remove_list. unfold subform_boxesS. unfold subform_boxesS in H.
+    simpl. simpl in H. apply in_app_or in H. destruct H.
+    apply in_or_app. left. rewrite subform_boxesLF_dist_app in H.
+    apply in_app_or in H. destruct H. rewrite subform_boxesLF_dist_app. apply in_or_app. auto.
+    apply In_remove_list_In_list_not_In_remove_list in H. destruct H. simpl in H. apply in_app_or in H.
+    destruct H. simpl. rewrite subform_boxesLF_dist_app. apply in_or_app. right.
+    apply not_removed_remove_list. simpl. apply in_or_app. destruct (In_dec (subform_boxesF A) a).
+    left. apply in_or_app. auto. left.
+    apply in_or_app. right. apply not_removed_remove_list. assumption. assumption. assumption.
+    apply In_remove_list_In_list_not_In_remove_list in H. destruct H. rewrite subform_boxesLF_dist_app.
+    apply in_or_app. right. apply not_removed_remove_list. simpl. destruct (In_dec (subform_boxesF A) a).
+    apply in_or_app. left. apply in_or_app. auto. apply in_or_app. right.
+    apply not_removed_remove_list. assumption. intro. apply in_app_or in H3. destruct H3.
+    apply n1. auto. apply In_remove_list_In_list_not_In_remove_list in H3. destruct H3. auto.
+    assumption. apply In_remove_list_In_list_not_In_remove_list in H. destruct H.
+    destruct (In_dec (subform_boxesLF (Γ0 ++ A --> B :: Γ1)) a). apply in_or_app. auto.
+    apply in_or_app. right. apply not_removed_remove_list. assumption. assumption.
+    intro. apply H0. rewrite top_boxes_distr_app. rewrite top_boxes_distr_app in H1.
+    apply in_app_or in H1. destruct H1. apply in_or_app. auto. simpl in H1.
+    apply in_or_app. right. assert (B :: Γ1 = [B] ++ Γ1). reflexivity. rewrite H2.
+    rewrite top_boxes_distr_app. apply in_or_app. auto.
+  * unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl. lia.
+Qed.
+ +
+(* Now we show that the measure decreases upwards in the rule applications we considered. *)
+ +
+Definition less_thanS (s0 s1 : Seq) : Prop := lex lt (measure s0) (measure s1).
+ +
+Notation "s0 '<<' s1" := (less_thanS s0 s1) (at level 70).
+ +
+Fact less_thanS_inv l m : l << m -> (lex lt (measure l) (measure m)).
+Proof.
+inversion 1; subst ; auto.
+Qed.
+ +
+Theorem less_thanS_wf : well_founded less_thanS.
+Proof.
+unfold less_thanS.
+apply wf_inverse_image. apply lex_wf.
+auto. apply Wf_nat.lt_wf.
+Qed.
+ +
+Fact lex_trans : forall l m n, (lex lt l m) -> (lex lt m n) -> (lex lt l n).
+Proof.
+intros l m n H. revert n. induction H.
+- intros. inversion H0 ; subst. apply lex_skip ; auto. apply lex_cons ; auto. apply lex_length in H ; lia.
+- intros. inversion H1 ; subst. apply lex_cons ; auto. apply lex_length in H5 ; lia.
+  apply lex_cons ; lia.
+Qed.
+ +
+Fact less_thanS_trans l m n : l << m -> m << n -> l << n.
+Proof.
+unfold less_thanS. apply lex_trans.
+Qed.
+ +
+(* Corollary less_thanS_rect (P : (list MPropF * (MPropF)) -> Type)
+(HP : forall s, (forall s1, (less_than lt (measure s1) (seq_list_occ_weight s)) -> P s1) -> P s) s : P s.
+Proof.
+  induction s as  s IHs  using (well_founded_induction_type less_thanS_wf).
+  apply HP; intros; apply IHs. unfold less_thanS ; auto.
+Qed. *)

+ +
+Lemma decT_lt : forall m n, (m < n) + ((m < n) -> False).
+Proof.
+induction m.
+- destruct n. right. intro. inversion H. left. lia.
+- destruct n. right. intro. inversion H. pose (IHm n). destruct s. left. lia. right. intro. apply f. lia.
+Qed.
+ +
+Lemma decT_lex_lt : forall l0 l1, (lex lt l0 l1) + ((lex lt l0 l1) -> False).
+Proof.
+induction l0 ; intros.
+- destruct l1. right ; intro. inversion H ; auto. right ; intro. inversion H ; auto.
+- destruct l1. right ; intro. inversion H ; auto.
+  destruct (IHl0 l1).
+  + pose (lex_length l). destruct (decT_lt a n).
+      * left. apply lex_cons ; auto.
+      * destruct (Nat.eq_dec a n) ; subst.
+        left. apply lex_skip ; auto.
+        right. intro. inversion H ; subst ; auto.
+  + destruct (decT_lt a n).
+      * destruct (Nat.eq_dec (length l0) (length l1)). left. apply lex_cons ; auto.
+        right. intro. inversion H ; auto.
+      * right. intro. inversion H ; auto.
+Qed.
+ +
+Lemma decT_less_than_lt : forall l0 l1, (less_thanS l0 l1) + ((less_thanS l0 l1) -> False).
+Proof.
+intros. destruct l0, l1. unfold less_thanS.
+apply decT_lex_lt.
+Qed.
+ +
+Theorem less_thanS_strong_inductionT:
+forall P : Seq -> Type,
+(forall s0 : Seq, (forall s1 : Seq, ((s1 << s0) -> P s1)) -> P s0) ->
+forall s : Seq, P s.
+Proof.
+  induction s as [ s IHs ] using (well_founded_induction_type less_thanS_wf).
+  apply X; intros; apply IHs. unfold less_thanS ; auto.
+Qed.
+ +
+Theorem GLR_applic_reduces_measure : forall prem concl,
+                GLRRule [prem] concl ->
+                (IdBRule [] concl -> False) ->
+                prem << concl.
+Proof.
+intros. apply lex_cons ; auto.
+apply GLR_applic_less_usable_boxes ; auto.
+Qed.
+ +
+Theorem ImpR_applic_reduces_ub_or_imp : forall prem concl,
+                ImpRRule [prem] concl ->
+                ((length (usable_boxes prem) < length (usable_boxes concl)) +
+                ((length (usable_boxes prem) = length (usable_boxes concl)) *
+                (n_imp_subformS prem < n_imp_subformS concl))).
+Proof.
+intros.
+pose (ImpR_applic_less_Imp_same_usable_boxes H). destruct p ; auto.
+destruct s ; auto.
+Qed.
+ +
+Theorem ImpR_applic_reduces_measure : forall prem concl,
+                ImpRRule [prem] concl ->
+                prem << concl.
+Proof.
+intros. destruct (ImpR_applic_less_Imp_same_usable_boxes H).
+destruct s.
+- apply lex_cons ; auto.
+- unfold less_thanS ; unfold measure ; rewrite e ; apply lex_skip ; auto.
+  apply lex_cons ; auto.
+Qed.
+ +
+Theorem ImpL_applic_reduces_ub_or_imp : forall prem1 prem2 concl,
+                ImpLRule [prem1; prem2] concl ->
+                ((length (usable_boxes prem1) < length (usable_boxes concl)) +
+                ((length (usable_boxes prem1) = length (usable_boxes concl)) *
+                (n_imp_subformS prem1 < n_imp_subformS concl))) *
+                ((length (usable_boxes prem2) < length (usable_boxes concl)) +
+                ((length (usable_boxes prem2) = length (usable_boxes concl)) *
+                (n_imp_subformS prem2 < n_imp_subformS concl))).
+Proof.
+intros.
+pose (ImpL_applic_less_Imp_same_usable_boxes H). destruct p ; auto. destruct p ; auto.
+destruct p0 ; auto. destruct s ; auto. destruct s0 ; auto. destruct s0 ; auto.
+Qed.
+ +
+Theorem ImpL_applic_reduces_measure : forall prem1 prem2 concl,
+                ImpLRule [prem1; prem2] concl ->
+                (prem1 << concl) * (prem2 << concl).
+Proof.
+intros. destruct (ImpL_applic_less_Imp_same_usable_boxes H).
+destruct p, p0. split.
+- destruct s.
+  + apply lex_cons ; auto.
+  + unfold less_thanS ; unfold measure ; rewrite e ; apply lex_skip ; auto.
+    apply lex_cons ; auto.
+- destruct s0.
+  + apply lex_cons ; auto.
+  + unfold less_thanS ; unfold measure ; rewrite e ; apply lex_skip ; auto.
+    apply lex_cons ; auto.
+Qed.
+
+
+ +
+ + + diff --git a/GL.GLS.GLS_wkn.html b/GL.GLS.GLS_wkn.html new file mode 100644 index 0000000..fbacc75 --- /dev/null +++ b/GL.GLS.GLS_wkn.html @@ -0,0 +1,584 @@ + + + + + + + + + + + + + +
+
+

GL.GLS.GLS_wkn

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+Require Import Arith.
+ +
+Require Import GLS_calcs.
+Require Import GLS_dec.
+ +
+Set Implicit Arguments.
+ +
+(* We define the relations which take care of the notion of weakening. *)
+ +
+Inductive wkn_L (fml : MPropF) : relationT Seq :=
+  | wkn_LI Γ0 Γ1 Δ : wkn_L fml
+        (Γ0 ++ Γ1, Δ) (Γ0 ++ fml :: Γ1, Δ).
+ +
+Inductive wkn_R (fml : MPropF) : relationT Seq :=
+  | wkn_RI Γ Δ0 Δ1 : wkn_R fml
+        (Γ, Δ0 ++ Δ1) (Γ, Δ0 ++ fml :: Δ1).
+ +
+(* Some lemmas on the preservation of inapplicability of BotL through weakening. *)
+ +
+Lemma wkn_R_BotL_notapplic : forall s sw A,
+    (@wkn_R A s sw) ->
+    ((BotLRule [] s) -> False) ->
+    ((BotLRule [] sw) -> False).
+Proof.
+intros s sw A wkn RA RAw. apply RA.
+inversion RAw. destruct s. inversion wkn. subst. inversion H3.
+subst. apply BotLRule_I.
+Qed.
+ +
+(* The following lemmas make sure that if a rule is applied on a sequent s with
+premises ps, then the same rule is applicable on a sequent sw which is a weakened
+version of s, with some premises psw that are such that they are either the same premises
+(in case the weakened formula is weakened in the rule) or weakened versions of ps. *)

+ +
+Lemma ImpR_app_wkn_L : forall s sw A ps,
+  (@wkn_L A s sw) ->
+  (ImpRRule [ps] s) ->
+  (existsT2 psw, (ImpRRule [psw] sw) * (@wkn_L A ps psw)).
+Proof.
+intros s sw A ps wkn RA. inversion RA. inversion wkn. subst.
+inversion H. subst. apply app2_find_hole in H1. destruct H1.
+repeat destruct s ; destruct p ; subst.
+- exists (Γ2 ++ A0 :: A :: Γ3, Δ0 ++ B :: Δ1). repeat split ; try assumption.
+  rewrite cons_single. rewrite cons_single with (v:=A0). rewrite app_assoc. rewrite app_assoc with (l:=Γ2).
+  apply wkn_LI.
+- exists ((Γ2 ++ A :: x) ++ A0 :: Γ1, Δ0 ++ B :: Δ1). split.
+  * assert (Γ2 ++ A :: x ++ Γ1 = (Γ2 ++ A :: x) ++ Γ1). rewrite <- app_assoc. reflexivity.
+    rewrite H0. apply ImpRRule_I ; assumption.
+  * repeat rewrite <- app_assoc. apply wkn_LI.
+- exists (Γ0 ++ A0 :: x ++ A :: Γ3, Δ0 ++ B :: Δ1). split.
+  * repeat rewrite <- app_assoc. apply ImpRRule_I ; assumption.
+  * rewrite cons_single. rewrite cons_single with (v:=A0). rewrite app_assoc. rewrite app_assoc with (l:=Γ0).
+    rewrite app_assoc. rewrite app_assoc with (l:=(Γ0 ++ [A0])). apply wkn_LI.
+Qed.
+ +
+Lemma ImpL_app_wkn_L : forall s sw A ps1 ps2,
+  (@wkn_L A s sw) ->
+  (ImpLRule [ps1;ps2] s) ->
+  (existsT2 psw1 psw2, (ImpLRule [psw1;psw2] sw) *
+                                                  (@wkn_L A ps1 psw1) *
+                                                  (@wkn_L A ps2 psw2)).
+Proof.
+intros s sw A ps1 ps2 wkn RA. inversion RA. inversion wkn. subst.
+inversion H. subst. apply app2_find_hole in H1. destruct H1. repeat destruct s ; destruct p ; subst.
+  - exists (Γ2 ++ A :: Γ1, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ A :: B :: Γ1, Δ0 ++ Δ1).
+    split. split. assert (E1: Γ2 ++ A :: Γ1 = (Γ2 ++ [A]) ++ Γ1). rewrite <- app_assoc.
+    simpl. auto. rewrite E1. assert (E2 : Γ2 ++ A :: B :: Γ1 = (Γ2 ++ [A]) ++ B :: Γ1).
+    rewrite <- app_assoc. simpl. auto. rewrite E2. assert (E3 : Γ2 ++ A :: A0 --> B :: Γ1 = (Γ2 ++ [A]) ++ A0 --> B :: Γ1).
+    rewrite <- app_assoc. simpl. auto. rewrite E3. apply ImpLRule_I.
+    apply wkn_LI. apply wkn_LI.
+  - exists (Γ2 ++ A :: x ++ Γ1, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ A :: x ++ B :: Γ1, Δ0 ++ Δ1).
+    split. split. assert (E1: Γ2 ++ A :: x ++ Γ1 = (Γ2 ++ [A] ++ x) ++ Γ1). rewrite <- app_assoc.
+    simpl. auto. rewrite E1. assert (E2 : Γ2 ++ A :: x ++ B :: Γ1 = (Γ2 ++ [A] ++ x) ++ B :: Γ1).
+    rewrite <- app_assoc. simpl. auto. rewrite E2.
+    assert (E3 : Γ2 ++ A :: x ++ A0 --> B :: Γ1 = (Γ2 ++ [A] ++ x) ++ A0 --> B :: Γ1).
+    rewrite <- app_assoc. simpl. auto. rewrite E3. apply ImpLRule_I.
+    repeat rewrite <- app_assoc. apply wkn_LI. repeat rewrite <- app_assoc. apply wkn_LI.
+  - destruct x ; subst ; repeat rewrite app_nil_r.
+    + simpl in e0. subst. exists (Γ0 ++ A :: Γ1, Δ0 ++ A0 :: Δ1). exists (Γ0 ++ A :: B :: Γ1, Δ0 ++ Δ1) .
+      split. split. assert (E1: Γ0 ++ A :: Γ1 = (Γ0 ++ [A]) ++ Γ1). rewrite <- app_assoc.
+      simpl. auto. rewrite E1. assert (E2 : Γ0 ++ A :: B :: Γ1 = (Γ0 ++ [A]) ++ B :: Γ1).
+      rewrite <- app_assoc. simpl. auto. rewrite E2.
+      assert (E3 : Γ0 ++ A :: A0 --> B :: Γ1 = (Γ0 ++ [A]) ++ A0 --> B :: Γ1).
+      rewrite <- app_assoc. simpl. auto. rewrite E3. apply ImpLRule_I.
+      repeat rewrite <- app_assoc. apply wkn_LI. repeat rewrite <- app_assoc. apply wkn_LI.
+    + inversion e0. subst. exists (Γ0 ++ x ++ A :: Γ3, Δ0 ++ A0 :: Δ1).
+      exists (Γ0 ++ B :: x ++ A :: Γ3, Δ0 ++ Δ1). split. split.
+      repeat rewrite <- app_assoc. apply ImpLRule_I.
+      assert (Γ0 ++ x ++ Γ3 = (Γ0 ++ x) ++ Γ3). rewrite <- app_assoc. reflexivity.
+      rewrite H0. assert (Γ0 ++ x ++ A :: Γ3 = (Γ0 ++ x) ++ A :: Γ3). rewrite <- app_assoc. reflexivity.
+      rewrite H1. apply wkn_LI.
+      assert (Γ0 ++ B :: x ++ Γ3 = (Γ0 ++ B :: x) ++ Γ3). rewrite <- app_assoc. reflexivity.
+      rewrite H0. assert (Γ0 ++ B :: x ++ A :: Γ3 = (Γ0 ++ B :: x) ++ A :: Γ3). rewrite <- app_assoc. reflexivity.
+      rewrite H1. apply wkn_LI.
+Qed.
+ +
+Lemma GLR_app_wkn_L : forall s sw A ps,
+  (@wkn_L A s sw) ->
+  (GLRRule [ps] s) ->
+  ((GLRRule [ps] sw) +
+   (existsT2 psw1 psw2, (GLRRule [psw2] sw) * (@wkn_L (unBox_formula A) ps psw1) * (@wkn_L A psw1 psw2))).
+Proof.
+intros s sw A ps wkn RA. inversion RA. inversion wkn. rewrite <- H1 in H2.
+inversion H2. subst. destruct (dec_is_boxedT A).
+  * right. apply univ_gen_ext_splitR in X. destruct X. destruct s. repeat destruct p.
+    subst. exists (((XBoxed_list x) ++ (unBox_formula A) :: (XBoxed_list x0)) ++ [Box A0], [A0]).
+    exists (XBoxed_list (x ++ A :: x0) ++ [Box A0], [A0]). split. split.
+    + apply GLRRule_I. intro. intros. apply in_app_or in H. destruct H. apply H0. apply in_or_app. auto.
+      inversion H. subst. assumption. apply H0. apply in_or_app. auto. apply univ_gen_ext_combine.
+      assumption. apply univ_gen_ext_cons. assumption.
+    + rewrite XBox_app_distrib. repeat rewrite <- app_assoc. apply wkn_LI.
+    + rewrite XBox_app_distrib. simpl.
+      assert (E1: (XBoxed_list x ++ unBox_formula A :: XBoxed_list x0) ++ [Box A0] =
+      (XBoxed_list x ++ [unBox_formula A]) ++ XBoxed_list x0 ++ [Box A0]). repeat rewrite <- app_assoc.
+      simpl. reflexivity. rewrite E1.
+      assert (E2: (XBoxed_list x ++ unBox_formula A :: A :: XBoxed_list x0) ++ [Box A0] =
+      (XBoxed_list x ++ [unBox_formula A]) ++ A :: XBoxed_list x0 ++ [Box A0]). repeat rewrite <- app_assoc.
+      simpl. reflexivity. rewrite E2.
+      apply wkn_LI.
+  * left. apply GLRRule_I.
+    + assumption.
+    + apply univ_gen_ext_splitR in X. destruct X. destruct s. repeat destruct p.
+      subst. apply univ_gen_ext_combine. assumption. apply univ_gen_ext_extra. assumption.
+      assumption.
+Qed.
+ +
+Lemma ImpR_app_wkn_R : forall s sw A ps,
+  (@wkn_R A s sw) ->
+  (ImpRRule [ps] s) ->
+  ((existsT2 psw, (ImpRRule [psw] sw) * (@wkn_R A ps psw))).
+Proof.
+intros s sw A ps wkn RA. inversion RA. inversion wkn. subst. inversion H.
+subst. apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+  - exists (Γ0 ++ A0 :: Γ1, Δ2 ++ A :: B :: Δ1). split.
+    assert (E1: Δ2 ++ A :: B :: Δ1 = (Δ2 ++ [A]) ++ B :: Δ1). rewrite <- app_assoc.
+    simpl. auto. rewrite E1. assert (E3 : Δ2 ++ A :: A0 --> B :: Δ1 = (Δ2 ++ [A]) ++ A0 --> B :: Δ1).
+    rewrite <- app_assoc. simpl. auto. rewrite E3. apply ImpRRule_I.
+    apply wkn_RI.
+  - exists (Γ0 ++ A0 :: Γ1, Δ2 ++ A :: x ++ B :: Δ1).
+    split. assert (E1: Δ2 ++ A :: x ++ B :: Δ1 = (Δ2 ++ [A] ++ x) ++ B :: Δ1). rewrite <- app_assoc.
+    simpl. auto. rewrite E1. assert (E2 : Δ2 ++ A :: x ++ A0 --> B :: Δ1 = (Δ2 ++ [A] ++ x) ++ A0 --> B :: Δ1).
+    rewrite <- app_assoc. simpl. auto. rewrite E2. apply ImpRRule_I.
+    repeat rewrite <- app_assoc. apply wkn_RI.
+  - destruct x ; subst ; repeat rewrite app_nil_r.
+    + simpl in e0. subst. exists (Γ0 ++ A0 :: Γ1, Δ0 ++ A :: B :: Δ1).
+      split. assert (E1: Δ0 ++ A :: B :: Δ1 = (Δ0 ++ [A]) ++ B :: Δ1). rewrite <- app_assoc.
+      simpl. auto. rewrite E1.
+      assert (E3 : Δ0 ++ A :: A0 --> B :: Δ1 = (Δ0 ++ [A]) ++ A0 --> B :: Δ1).
+      rewrite <- app_assoc. simpl. auto. rewrite E3. apply ImpRRule_I.
+      repeat rewrite <- app_assoc. apply wkn_RI.
+    + inversion e0. subst. exists (Γ0 ++ A0 :: Γ1, Δ0 ++ B :: x ++ A :: Δ3).
+      split. repeat rewrite <- app_assoc. apply ImpRRule_I.
+      assert (Δ0 ++ B :: x ++ Δ3 = (Δ0 ++ B :: x) ++ Δ3). rewrite <- app_assoc. reflexivity.
+      rewrite H0. assert (Δ0 ++ B :: x ++ A :: Δ3 = (Δ0 ++ B :: x) ++ A :: Δ3). rewrite <- app_assoc. reflexivity.
+      rewrite H1. apply wkn_RI.
+Qed.
+ +
+Lemma ImpL_app_wkn_R : forall s sw A ps1 ps2,
+  (@wkn_R A s sw) ->
+  (ImpLRule [ps1;ps2] s) ->
+  (existsT2 psw1 psw2, (ImpLRule [psw1;psw2] sw) * (@wkn_R A ps1 psw1) *
+                                                   (@wkn_R A ps2 psw2)).
+Proof.
+intros s sw A ps1 ps2 wkn RA. inversion RA. inversion wkn. subst.
+inversion H. subst. apply app2_find_hole in H2. destruct H2. repeat destruct s.
+- destruct p. subst. exists (Γ0 ++ Γ1, Δ2 ++ A0 :: A :: Δ3).
+  exists (Γ0 ++ B :: Γ1, Δ2 ++ A :: Δ3). repeat split.
+  assert (E1: Δ2 ++ A0 :: A :: Δ3 = (Δ2 ++ [A0]) ++ A :: Δ3).
+  repeat rewrite <- app_assoc. simpl. reflexivity. rewrite E1.
+  assert (E2: Δ2 ++ A0 :: Δ3 = (Δ2 ++ [A0]) ++ Δ3).
+  repeat rewrite <- app_assoc. simpl. reflexivity. rewrite E2. apply wkn_RI.
+- destruct p. subst. exists (Γ0 ++ Γ1, (Δ2 ++ A :: x) ++ A0 :: Δ1). exists (Γ0 ++ B :: Γ1, (Δ2 ++ A :: x) ++ Δ1).
+  split. split.
+  * assert (E: Δ2 ++ A :: x ++ Δ1 = (Δ2 ++ A :: x) ++ Δ1). rewrite <- app_assoc. simpl. reflexivity.
+    rewrite E. apply ImpLRule_I ; assumption.
+  * repeat rewrite <- app_assoc. simpl. apply wkn_RI.
+  * repeat rewrite <- app_assoc. simpl. apply wkn_RI.
+- destruct p. subst. exists (Γ0 ++ Γ1, Δ0 ++ A0 :: x ++ A :: Δ3).
+  exists (Γ0 ++ B :: Γ1, Δ0 ++ x ++ A :: Δ3). repeat split.
+  * rewrite <- app_assoc. apply ImpLRule_I ; assumption.
+  * assert (E1: Δ0 ++ A0 :: x ++ Δ3 = (Δ0 ++ A0 :: x) ++ Δ3). rewrite <- app_assoc. simpl. reflexivity.
+    rewrite E1.
+    assert (E2: Δ0 ++ A0 :: x ++ A :: Δ3 = (Δ0 ++ A0 :: x) ++ A :: Δ3). rewrite <- app_assoc. simpl. reflexivity.
+    rewrite E2. apply wkn_RI.
+  * rewrite app_assoc with (l:=Δ0). apply wkn_RI.
+Qed.
+ +
+Lemma GLR_app_wkn_R : forall s sw A ps,
+  (@wkn_R A s sw) ->
+  (GLRRule [ps] s) ->
+  (GLRRule [ps] sw).
+Proof.
+intros s sw A ps wkn RA. inversion RA. inversion wkn. rewrite <- H1 in H2.
+inversion H2. apply app2_find_hole in H6. destruct H6. repeat destruct s0.
+- destruct p. subst. assert (Δ2 ++ A :: Box A0 :: Δ1 = (Δ2 ++ [A]) ++ Box A0 :: Δ1).
+  rewrite <- app_assoc. simpl. reflexivity. rewrite H. apply GLRRule_I ; assumption.
+- destruct p. subst. assert (E: Δ2 ++ A :: x ++ Box A0 :: Δ1 = (Δ2 ++ A :: x) ++ Box A0 :: Δ1).
+  repeat rewrite <- app_assoc. simpl. reflexivity. rewrite E.
+  apply GLRRule_I ; assumption.
+- destruct p. subst. destruct x.
+  + rewrite app_nil_r. rewrite app_nil_l in e0. subst. assert (Δ0 ++ A :: Box A0 :: Δ1 = (Δ0 ++ [A]) ++ Box A0 :: Δ1).
+    rewrite <- app_assoc. reflexivity. rewrite H. apply GLRRule_I ; assumption.
+  + inversion e0. subst. rewrite <- app_assoc. simpl. apply GLRRule_I ; assumption.
+Qed.
+ +
+(* Now we can prove that weakening is height-preserving admissible. *)
+ +
+Theorem GLS_wkn_L : forall (k : nat) s
+        (D0 : GLS_prv s),
+        k = (derrec_height D0) ->
+          (forall sw A, ((@wkn_L A s sw) ->
+          existsT2 (D1 : GLS_prv sw),
+          derrec_height D1 <= k)).
+Proof.
+induction k as [n IH] using (well_founded_induction_type lt_wf).
+intros s0 D0. remember D0 as D0'. destruct D0.
+(* D0 is a leaf *)
+- intros hei sw A wkn. inversion f.
+(* D0 ends with an application of rule *)
+- intros hei sw A wkn. inversion wkn. inversion g.
+  (* IdP *)
+  * inversion H1. rewrite <- H in H5. inversion H5. apply app2_find_hole in H7.
+    destruct H7. assert (DersNil: dersrec GLS_rules (fun _ : Seq => False) []).
+    apply dersrec_nil.
+    destruct s.
+    + destruct s.
+      { destruct p. inversion e0. subst. pose (IdPRule_I P (Γ2 ++ [A]) Γ3 Δ0 Δ1). apply IdP in i. rewrite <- app_assoc in i.
+        simpl in i. pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ2 ++ A :: # P :: Γ3, Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+        left. reflexivity. reflexivity. }
+      { destruct p. destruct x.
+        - rewrite app_nil_l in e0. inversion e0. subst.
+          pose (IdPRule_I P ((Γ2 ++ []) ++ [A]) Γ3 Δ0 Δ1). apply IdP in i. rewrite <- app_assoc in i. simpl in i.
+          pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ2 ++ []) ++ A :: # P :: Γ3, Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+          left. reflexivity. reflexivity.
+        - inversion e0. subst.
+          pose (IdPRule_I P Γ2 (x ++ A :: Γ1) Δ0 Δ1). apply IdP in i.
+          assert (E0 : Γ2 ++ # P :: x ++ A :: Γ1 = (Γ2 ++ # P :: x) ++ A :: Γ1). rewrite <- app_assoc. reflexivity.
+          rewrite E0 in i.
+          pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ2 ++ # P :: x) ++ A :: Γ1, Δ0 ++ # P :: Δ1) i DersNil).
+          exists d0. simpl. repeat rewrite dersrec_height_nil.
+          left. reflexivity. reflexivity. }
+    + destruct p. subst. pose (IdPRule_I P (Γ0 ++ A :: x) Γ3 Δ0 Δ1). apply IdP in i. rewrite <- app_assoc in i. simpl in i.
+      pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[]) (Γ0 ++ A :: x ++ # P :: Γ3, Δ0 ++ # P :: Δ1) i DersNil).
+      exists d0. simpl. repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+  (* BotL *)
+  * inversion H1. rewrite <- H in H5. inversion H5.
+    assert (DersNil: dersrec GLS_rules (fun _ : Seq => False) []).
+    apply dersrec_nil.
+    apply app2_find_hole in H7. destruct H7. destruct s.
+    + destruct s.
+      { destruct p. inversion e0. subst.
+        pose (BotLRule_I (Γ2 ++ [A]) Γ3 Δ). apply BotL in b. rewrite <- app_assoc in b. simpl in b.
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ2 ++ A :: :: Γ3, Δ) b DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+        left. reflexivity. reflexivity. }
+      { destruct p. destruct x.
+        - rewrite app_nil_l in e0. inversion e0. subst.
+          pose (BotLRule_I ((Γ2 ++ []) ++ [A]) Γ3 Δ). apply BotL in b. rewrite <- app_assoc in b. simpl in b.
+          pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ2 ++ []) ++ A :: :: Γ3, Δ) b DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+          left. reflexivity. reflexivity.
+        - inversion e0. subst.
+          pose (BotLRule_I Γ2 (x ++ A :: Γ1) Δ). apply BotL in b.
+          assert (E0: Γ2 ++ :: x ++ A :: Γ1 = (Γ2 ++ :: x) ++ A :: Γ1). rewrite <- app_assoc. reflexivity.
+          rewrite E0 in b.
+          pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ2 ++ :: x) ++ A :: Γ1, Δ) b DersNil).
+          exists d0. simpl. repeat rewrite dersrec_height_nil.
+          left. reflexivity. reflexivity. }
+    + destruct p. subst. pose (BotLRule_I (Γ0 ++ A :: x) Γ3 Δ). apply BotL in b.
+      assert (E0 : (Γ0 ++ A :: x) ++ :: Γ3 = Γ0 ++ A :: x ++ :: Γ3).
+      rewrite <- app_assoc. reflexivity. rewrite E0 in b.
+      pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[]) (Γ0 ++ A :: x ++ :: Γ3, Δ) b DersNil). exists d0. simpl.
+      repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+  (* ImpR *)
+  * assert (DersNil: dersrec GLS_rules (fun _ : Seq => False) []).
+    apply dersrec_nil.
+    inversion H1. subst. inversion H5. subst. pose (ImpR_app_wkn_L wkn H1). destruct s.
+    repeat destruct p. remember [(Γ2 ++ A0 :: Γ3, Δ0 ++ B :: Δ1)] as ps'. destruct d.
+    inversion Heqps'. inversion Heqps'. subst.
+    assert (E: derrec_height d < S (derrec_height d)). auto.
+    assert (E1: derrec_height d = derrec_height d). auto. simpl in IH.
+    rewrite dersrec_height_nil in IH. 2: reflexivity. rewrite Nat.max_0_r in IH.
+    pose (IH (derrec_height d) E (Γ2 ++ A0 :: Γ3, Δ0 ++ B :: Δ1) d
+    E1 x A w).
+    destruct s. pose (dlCons x0 d0). apply ImpR in i.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x]) (Γ0 ++ A :: Γ1, Δ0 ++ A0 --> B :: Δ1) i).
+    pose (d2 d1). exists d3.
+    simpl. repeat rewrite dersrec_height_nil. repeat rewrite Nat.max_0_r.
+    rewrite <- Nat.succ_le_mono. assumption. reflexivity.
+  (* ImpL *)
+  * inversion H1. subst. inversion H5. subst. pose (ImpL_app_wkn_L wkn H1). repeat destruct s.
+    repeat destruct p. apply ImpL in i.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x;x0]) (Γ0 ++ A :: Γ1, Δ0 ++ Δ1) i). subst. simpl.
+    remember [(Γ2 ++ Γ3, Δ0 ++ A0 :: Δ1); (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)] as ps'. destruct d.
+    inversion Heqps'. inversion Heqps'. subst.
+    remember [(Γ2 ++ B :: Γ3, Δ0 ++ Δ1)] as ps''. destruct d1. inversion Heqps''.
+    inversion Heqps''. simpl. subst. rewrite dersrec_height_nil. simpl in IH.
+    rewrite dersrec_height_nil in IH. rewrite Nat.max_0_r. rewrite Nat.max_0_r in IH.
+    assert (E1: derrec_height d < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+    apply Nat.lt_succ_r. apply Nat.le_max_l.
+    assert (E2: derrec_height d = derrec_height d). auto.
+    pose (IH (derrec_height d) E1 (Γ2 ++ Γ3, Δ0 ++ A0 :: Δ1) d E2 x A w0).
+    destruct s.
+    assert (E3: derrec_height d1 < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+    apply Nat.lt_succ_r. apply Nat.le_max_r.
+    assert (E4: derrec_height d1 = derrec_height d1). auto.
+    pose (IH (derrec_height d1) E3 (Γ2 ++ B :: Γ3, Δ0 ++ Δ1) d1 E4 x0 A w).
+    destruct s.
+    pose (dlCons x1 (dlCons x2 d2)). subst. pose (d0 d3). exists d4. simpl. rewrite dersrec_height_nil.
+    rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. apply Nat.max_le_compat.
+    assumption. assumption. reflexivity. reflexivity. reflexivity.
+  (* GLR *)
+  * inversion X. rewrite <- H4 in X. subst. pose (GLR_app_wkn_L wkn X). destruct s.
+    { apply GLR in g0. subst. pose (derI (rules:=GLS_rules)
+      (prems:=fun _ : Seq => False) (ps:=[(XBoxed_list ++ [Box A0], [A0])])
+      (Γ0 ++ A :: Γ1, Δ) g0). subst. pose (d0 d). exists d1. simpl. reflexivity. }
+    { repeat destruct s. repeat destruct p. apply GLR in g0.
+      remember [(XBoxed_list ++ [Box A0], [A0])] as ps'. destruct d. inversion Heqps'. subst.
+      inversion Heqps'. subst. simpl. simpl in IH.
+      assert (E1: derrec_height d < S (Init.Nat.max (derrec_height d) (dersrec_height d0))).
+      rewrite dersrec_height_nil. rewrite Nat.max_0_r. apply Nat.lt_succ_r. left. reflexivity.
+      assert (E2: derrec_height d = derrec_height d). auto.
+      pose (IH (derrec_height d) E1 ((XBoxed_list ++ [Box A0], [A0])) d E2 x (unBox_formula A) w0).
+      destruct s.
+      assert (E3: derrec_height x1 < S (Init.Nat.max (derrec_height d) (dersrec_height d0))).
+      rewrite dersrec_height_nil. rewrite Nat.max_0_r. apply Nat.lt_succ_r. assumption. reflexivity.
+      assert (E4: derrec_height x1 = derrec_height x1). auto.
+      pose (IH (derrec_height x1) E3 x x1 E4 x0 A w). destruct s.
+      pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[x0]) (Γ0 ++ A :: Γ1, Δ) g0). subst. simpl.
+      pose (dlCons x2 d0). pose (d1 d2). exists d3. simpl. rewrite dersrec_height_nil.
+      repeat rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono.
+      pose (Nat.le_trans (derrec_height x2) (derrec_height x1) (derrec_height d) l0 l).
+      assumption. reflexivity. }
+Qed.
+ +
+Theorem GLS_prv_wkn_L : forall s, GLS_prv s ->
+          (forall sw A, (@wkn_L A s sw) -> GLS_prv sw).
+Proof.
+intros.
+assert (J0: derrec_height X = derrec_height X). auto.
+pose (GLS_wkn_L _ J0 H). destruct s0. auto.
+Qed.
+ +
+Theorem GLS_wkn_R : forall (k : nat) s
+        (D0 : GLS_prv s),
+        k = (derrec_height D0) ->
+          (forall sw A, ((@wkn_R A s sw) ->
+          existsT2 (D1 : GLS_prv sw),
+          derrec_height D1 <= k)).
+Proof.
+induction k as [n IH] using (well_founded_induction_type lt_wf).
+intros s0 D0. remember D0 as D0'. destruct D0.
+(* D0 is a leaf *)
+- intros hei sw A wkn. inversion f.
+(* D0 ends with an application of rule *)
+- intros hei sw A wkn. inversion wkn. inversion g.
+  (* IdP *)
+  * inversion H1. rewrite <- H in H5. inversion H5. apply app2_find_hole in H8.
+    destruct H8. assert (DersNil: dersrec GLS_rules (fun _ : Seq => False) []).
+    apply dersrec_nil.
+    repeat destruct s.
+    + destruct p. inversion e0. subst. pose (IdPRule_I P Γ0 Γ1 (Δ2 ++ [A]) Δ3). apply IdP in i. rewrite <- app_assoc in i. simpl in i.
+      pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[]) (Γ0 ++ # P :: Γ1, Δ2 ++ A :: # P :: Δ3) i DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+      left. reflexivity. reflexivity.
+    + destruct p. destruct x.
+      { rewrite app_nil_l in e0. inversion e0. subst.
+        pose (IdPRule_I P Γ0 Γ1 ((Δ2 ++ []) ++ [A]) Δ3). apply IdP in i. rewrite <- app_assoc in i. simpl in i.
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ0 ++ # P :: Γ1, (Δ2 ++ []) ++ A :: # P :: Δ3) i DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+        left. reflexivity. reflexivity. }
+      { inversion e0. subst.
+        pose (IdPRule_I P Γ0 Γ1 Δ2 (x ++ A :: Δ1)). apply IdP in i.
+        assert (E0: Δ2 ++ # P :: x ++ A :: Δ1 = (Δ2 ++ # P :: x) ++ A :: Δ1). rewrite <- app_assoc. reflexivity.
+        rewrite E0 in i.
+        pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ0 ++ # P :: Γ1, (Δ2 ++ # P :: x) ++ A :: Δ1) i DersNil).
+        exists d0. simpl. repeat rewrite dersrec_height_nil.
+        left. reflexivity. reflexivity. }
+    + destruct p. subst. pose (IdPRule_I P Γ0 Γ1 (Δ0 ++ A :: x) Δ3). apply IdP in i. rewrite <- app_assoc in i. simpl in i.
+      pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[]) (Γ0 ++ # P :: Γ1, Δ0 ++ A :: x ++ # P :: Δ3) i DersNil).
+      exists d0. simpl. repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+  (* BotL *)
+  * inversion H1. rewrite <- H in H5. inversion H5.
+    assert (DersNil: dersrec GLS_rules (fun _ : Seq => False) []).
+    apply dersrec_nil.
+    pose (BotLRule_I Γ0 Γ1 (Δ0 ++ A :: Δ1)). apply BotL in b.
+    pose (derI (rules:=GLS_rules)
+    (prems:=fun _ : Seq => False)
+    (ps:=[]) (Γ0 ++ :: Γ1, Δ0 ++ A :: Δ1) b DersNil). subst. exists d0. simpl.
+    repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+  (* ImpR *)
+  * inversion H1. subst. inversion H5. subst. pose (ImpR_app_wkn_R wkn H1). destruct s.
+    destruct p. apply ImpR in i.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x]) (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) i). subst. simpl.
+    remember [(Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3)] as ps'. destruct d. inversion Heqps'.
+    inversion Heqps'. subst. simpl. rewrite dersrec_height_nil. simpl in IH.
+    rewrite dersrec_height_nil in IH. rewrite Nat.max_0_r. rewrite Nat.max_0_r in IH.
+    assert (E: derrec_height d < S (derrec_height d)). auto.
+    assert (E1: derrec_height d = derrec_height d). auto.
+    pose (IH (derrec_height d) E (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3) d E1 x A w).
+    destruct s.
+    pose (dlCons x0 d1). pose (d0 d2). exists d3. simpl. rewrite dersrec_height_nil.
+    rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. assumption. reflexivity. reflexivity. reflexivity.
+  (* ImpL *)
+  * inversion H1. subst. inversion H5. subst. pose (ImpL_app_wkn_R wkn H1). repeat destruct s.
+    repeat destruct p. apply ImpL in i.
+    pose (derI (rules:=GLS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x;x0]) (Γ0 ++ A0 --> B :: Γ1, Δ0 ++ A :: Δ1) i). subst. simpl.
+    remember [(Γ0 ++ Γ1, Δ2 ++ A0 :: Δ3); (Γ0 ++ B :: Γ1, Δ2 ++ Δ3)] as ps'. destruct d.
+    inversion Heqps'. inversion Heqps'. subst.
+    remember [(Γ0 ++ B :: Γ1, Δ2 ++ Δ3)] as ps''. destruct d1. inversion Heqps''.
+    inversion Heqps''. simpl. subst. rewrite dersrec_height_nil. simpl in IH.
+    rewrite dersrec_height_nil in IH. rewrite Nat.max_0_r. rewrite Nat.max_0_r in IH.
+    assert (E1: derrec_height d < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+    apply Nat.lt_succ_r. apply Nat.le_max_l.
+    assert (E2: derrec_height d = derrec_height d). auto.
+    pose (IH (derrec_height d) E1 (Γ0 ++ Γ1, Δ2 ++ A0 :: Δ3) d E2 x A w0).
+    destruct s.
+    assert (E3: derrec_height d1 < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+    apply Nat.lt_succ_r. apply Nat.le_max_r.
+    assert (E4: derrec_height d1 = derrec_height d1). auto.
+    pose (IH (derrec_height d1) E3 (Γ0 ++ B :: Γ1, Δ2 ++ Δ3) d1 E4 x0 A w).
+    destruct s.
+    pose (dlCons x1 (dlCons x2 d2)). subst. pose (d0 d3). exists d4. simpl. rewrite dersrec_height_nil.
+    rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. apply Nat.max_le_compat.
+    assumption. assumption. reflexivity. reflexivity. reflexivity.
+  (* GLR *)
+  * inversion X. rewrite <- H4 in X. pose (GLR_app_wkn_R wkn X).
+    apply GLR in g0. pose (derI (rules:=GLS_rules)
+    (prems:=fun _ : Seq => False) (ps:=[(XBoxed_list ++ [Box A0], [A0])])
+    sw g0). subst. pose (d0 d). exists d1. simpl. reflexivity.
+Qed.
+ +
+Theorem GLS_prv_wkn_R : forall s, GLS_prv s ->
+          (forall sw A, (@wkn_R A s sw) -> GLS_prv sw).
+Proof.
+intros.
+assert (J0: derrec_height X = derrec_height X). auto.
+pose (GLS_wkn_R _ J0 H). destruct s0. auto.
+Qed.
+ +
+Theorem GLS_list_wkn_R : forall (k : nat) Γ Δ0 Δ1
+        (D0 : GLS_prv (Γ,Δ0 ++ Δ1)),
+        k = (derrec_height D0) ->
+          (forall l, existsT2 (D1 : GLS_prv (Γ,Δ0 ++ l ++ Δ1)),
+           derrec_height D1 <= k).
+Proof.
+intros. induction l.
+- simpl. exists D0. lia.
+- simpl. destruct IHl.
+  assert (E: derrec_height x = derrec_height x). reflexivity.
+  assert (H0: wkn_R a (Γ, Δ0 ++ l ++ Δ1) (Γ, Δ0 ++ a :: l ++ Δ1)). apply wkn_RI.
+  pose (@GLS_wkn_R (derrec_height x) (Γ, Δ0 ++ l ++ Δ1) x E (Γ, Δ0 ++ a :: l ++ Δ1) a H0).
+  destruct s. exists x0. lia.
+Qed.
+ +
+Theorem GLS_prv_list_wkn_R : forall Γ Δ0 Δ1,
+        GLS_prv (Γ,Δ0 ++ Δ1) -> forall l, GLS_prv (Γ,Δ0 ++ l ++ Δ1).
+Proof.
+intros.
+assert (J0: derrec_height X = derrec_height X). auto.
+pose (@GLS_list_wkn_R _ _ _ _ X J0 l). destruct s. auto.
+Qed.
+ +
+Theorem GLS_list_wkn_L : forall (k : nat) Γ0 Γ1 Δ
+        (D0 : GLS_prv (Γ0 ++ Γ1,Δ)),
+        k = (derrec_height D0) ->
+          (forall l, existsT2 (D1 : GLS_prv (Γ0 ++ l ++ Γ1,Δ)),
+          derrec_height D1 <= k).
+Proof.
+intros. induction l.
+- simpl. exists D0. lia.
+- simpl. destruct IHl.
+  assert (E: derrec_height x = derrec_height x). reflexivity.
+  assert (H0: wkn_L a (Γ0 ++ l ++ Γ1, Δ) (Γ0 ++ a :: l ++ Γ1, Δ)). apply wkn_LI.
+  pose (@GLS_wkn_L (derrec_height x) (Γ0 ++ l ++ Γ1, Δ) x E (Γ0 ++ a :: l ++ Γ1, Δ) a H0).
+  destruct s. exists x0. lia.
+Qed.
+ +
+Theorem GLS_prv_list_wkn_L : forall Γ0 Γ1 Δ,
+        GLS_prv (Γ0 ++ Γ1,Δ) -> forall l, GLS_prv (Γ0 ++ l ++ Γ1,Δ).
+Proof.
+intros.
+assert (J0: derrec_height X = derrec_height X). auto.
+pose (@GLS_list_wkn_L _ _ _ _ X J0 l). destruct s. auto.
+Qed.
+ +
+Theorem GLS_XBoxed_list_wkn_L : forall (k : nat) Γ1 Γ0 Γ2 Δ
+        (D0 : GLS_prv (Γ0 ++ Γ1 ++ Γ2,Δ)),
+        k = (derrec_height D0) ->
+          (existsT2 (D1 : GLS_prv (Γ0 ++ (XBoxed_list Γ1) ++ Γ2,Δ)),
+           derrec_height D1 <= k).
+Proof.
+induction Γ1.
+- intros. simpl. simpl in D0. exists D0. rewrite H. left.
+- intros. simpl. assert (Γ0 ++ (a :: Γ1) ++ Γ2 = (Γ0 ++ [a]) ++ Γ1 ++ Γ2). rewrite <- app_assoc. reflexivity.
+  pose (@IHΓ1 (Γ0 ++ [a]) Γ2 Δ). repeat rewrite <- H0 in s.
+  pose (s D0 H). destruct s0. clear s.
+  assert (wkn_L (unBox_formula a) ((Γ0 ++ [a]) ++ XBoxed_list Γ1 ++ Γ2, Δ) (Γ0 ++ unBox_formula a :: a :: XBoxed_list Γ1 ++ Γ2, Δ)).
+  assert ((Γ0 ++ [a]) ++ XBoxed_list Γ1 ++ Γ2 = Γ0 ++ a :: XBoxed_list Γ1 ++ Γ2). rewrite <- app_assoc. reflexivity. rewrite H1.
+  apply wkn_LI.
+  assert (derrec_height x = derrec_height x). reflexivity.
+  pose (GLS_wkn_L x H2 H1). destruct s. exists x0. lia.
+Qed.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_And_Or_rules.html b/GL.Interpolation.UIGL_And_Or_rules.html new file mode 100644 index 0000000..d79d96c --- /dev/null +++ b/GL.Interpolation.UIGL_And_Or_rules.html @@ -0,0 +1,261 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_And_Or_rules

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+ +
+Require Import general_export.
+ +
+Require Import GLS_export.
+ +
+Require Import UIGL_Def_measure.
+Require Import UIGL_Canopy.
+Require Import UIGL_irred_short.
+Require Import UIGL_braga.
+Require Import UIGL_LexSeq.
+Require Import UIGL_nodupseq.
+ +
+  Section list_conj_disj_properties.
+ +
+  Lemma TopR : forall X Y0 Y1, GLS_prv (X, Y0 ++ Top :: Y1).
+  Proof.
+  intros. unfold Top. apply derI with (ps:=[([] ++ :: X, Y0 ++ :: Y1)]).
+  apply ImpR. assert ((X, Y0 ++ --> :: Y1) = ([] ++ X, Y0 ++ --> :: Y1)). auto.
+  rewrite H. apply ImpRRule_I. apply dlCons. 2: apply dlNil. apply derI with (ps:=[]).
+  apply BotL. apply BotLRule_I. apply dlNil.
+  Qed.
+ +
+  Lemma TopL_remove : forall Y X0 X1, GLS_prv (X0 ++ Top :: X1, Y) -> GLS_prv (X0 ++ X1, Y).
+  Proof.
+  intros. assert (Y= [] ++ Y). auto. rewrite H. rewrite H in X. apply GLS_cut_adm with (A:=Top) ; auto.
+  apply TopR.
+  Qed.
+ +
+  Lemma BotR_remove : forall X Y0 Y1, GLS_prv (X, Y0 ++ Bot :: Y1) -> GLS_prv (X, Y0 ++ Y1).
+  Proof.
+  intros. assert (X= [] ++ X). auto. rewrite H. rewrite H in X0. apply GLS_cut_adm with (A:=Bot) ; auto.
+  apply derI with (ps:=[]). 2: apply dlNil. apply BotL. apply BotLRule_I.
+  Qed.
+ +
+  Lemma AndL : forall s A B, GLS_prv (A :: B :: fst s, snd s) -> GLS_prv (And A B :: fst s, snd s).
+  Proof.
+  intros. unfold And. unfold Neg.
+  apply derI with (ps:=[([] ++ fst s, [] ++ (A --> B --> Bot) :: snd s); ([] ++ Bot :: fst s, [] ++ snd s)]).
+  apply ImpL. assert (((A --> B --> Bot) --> Bot :: fst s, snd s) = ([] ++ (A --> B --> Bot) --> Bot :: fst s, snd s)). auto.
+  rewrite H. apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+  apply derI with (ps:=[([] ++ A :: fst s, [] ++ B --> Bot :: snd s)]). apply ImpR. apply ImpRRule_I.
+  apply dlCons. 2: apply dlNil. apply derI with (ps:=[([A] ++ B :: fst s, [] ++ Bot :: snd s)]).
+  assert (([] ++ A :: fst s, [] ++ B --> Bot :: snd s) = ([A] ++ fst s, [] ++ B --> Bot :: snd s)). auto. rewrite H.
+  apply ImpR. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+  assert (J0: derrec_height X = derrec_height X). auto.
+  assert (J1: wkn_R Bot ([A] ++ B :: fst s, [] ++ snd s) ([A] ++ B :: fst s, [] ++ Bot :: snd s)). apply wkn_RI.
+  pose (GLS_wkn_R X J0 J1). destruct s0. auto. apply derI with (ps:=[]). apply BotL. apply BotLRule_I.
+  apply dlNil.
+  Qed.
+ +
+  Lemma AndR : forall s A B, GLS_prv (fst s, A :: snd s) -> GLS_prv (fst s, B :: snd s) -> GLS_prv (fst s, And A B :: snd s).
+  Proof.
+  intros. unfold And. unfold Neg.
+  apply derI with (ps:=[([] ++ A --> B --> :: fst s, [] ++ :: snd s)]).
+  apply ImpR. assert ((fst s, (A --> B --> ) --> :: snd s) = ([] ++ fst s, [] ++ (A --> B --> ) --> :: snd s)). auto.
+  rewrite H. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+  apply derI with (ps:=[([] ++ fst s, [] ++ A :: :: snd s);([] ++ B --> :: fst s, [] ++ :: snd s)]). apply ImpL.
+  apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+  assert (J0: derrec_height X = derrec_height X). auto.
+  assert (J1: wkn_R Bot ([] ++ fst s, [A] ++ snd s) ([] ++ fst s, [A] ++ :: snd s)). apply wkn_RI.
+  pose (GLS_wkn_R X J0 J1). destruct s0. auto.
+  apply derI with (ps:=[([] ++ fst s, [] ++ B :: :: snd s);([] ++ :: fst s, [] ++ :: snd s)]). apply ImpL.
+  apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+  assert (J0: derrec_height X0 = derrec_height X0). auto.
+  assert (J1: wkn_R Bot ([] ++ fst s, [B] ++ snd s) ([] ++ fst s, [B] ++ :: snd s)). apply wkn_RI.
+  pose (GLS_wkn_R X0 J0 J1). destruct s0. auto. apply derI with (ps:=[]). apply BotL. apply BotLRule_I.
+  apply dlNil.
+  Qed.
+ +
+  Lemma list_conj_wkn_L : forall l s A, InT A l -> GLS_prv (A :: fst s, snd s) -> GLS_prv (list_conj l :: fst s, snd s).
+  Proof.
+  induction l.
+  - intros. inversion H.
+  - intros. inversion H ; subst.
+    * simpl. apply AndL.
+      assert (J0: derrec_height X = derrec_height X). auto.
+      assert (J1: wkn_L (list_conj l) (A :: fst s, snd s) (A :: list_conj l :: fst s, snd s)).
+      assert (A :: fst s = [A] ++ fst s). auto. rewrite H0.
+      assert (A :: list_conj l :: fst s = [A] ++ list_conj l :: fst s). auto. rewrite H1. apply wkn_LI.
+      pose (GLS_wkn_L X J0 J1). destruct s0. auto.
+    * simpl. apply IHl in X ; auto.
+      assert (J0: derrec_height X = derrec_height X). auto.
+      assert (J1: wkn_L a (list_conj l :: fst s, snd s) (a :: list_conj l :: fst s, snd s)).
+      assert (a :: list_conj l :: fst s = [] ++ a :: list_conj l :: fst s). auto. rewrite H0.
+      assert ((list_conj l :: fst s,snd s) = ([] ++ list_conj l :: fst s,snd s)). auto. rewrite H2. apply wkn_LI.
+      pose (GLS_wkn_L X J0 J1). destruct s0. apply AndL ; auto.
+  Qed.
+ +
+  Lemma list_conj_R : forall l s, (forall A, InT A l -> GLS_prv (fst s, A :: snd s)) -> GLS_prv (fst s, list_conj l :: snd s).
+  Proof.
+  induction l.
+  - intros. simpl. unfold Top.
+    apply derI with (ps:=[([] ++ :: fst s, [] ++ :: snd s)]).
+    apply ImpR. assert ((fst s, --> :: snd s) = ([] ++ fst s, [] ++ --> :: snd s)). auto.
+    rewrite H. apply ImpRRule_I. apply dlCons. 2: apply dlNil. apply derI with (ps:=[]). apply BotL.
+    apply BotLRule_I. apply dlNil.
+  - intros. simpl. apply AndR.
+    * apply X. apply InT_eq.
+    * simpl. apply IHl. intros. apply X. apply InT_cons ; auto.
+  Qed.
+ +
+  Lemma OrL : forall s A B, GLS_prv (A :: fst s, snd s) -> GLS_prv (B :: fst s, snd s) -> GLS_prv (Or A B :: fst s, snd s).
+  Proof.
+  intros. unfold Or. unfold Neg.
+  apply derI with (ps:=[([] ++ fst s, [] ++ (A --> ) :: snd s); ([] ++ B :: fst s, [] ++ snd s)]).
+  apply ImpL. assert (((A --> ) --> B :: fst s, snd s) = ([] ++ (A --> ) --> B :: fst s, snd s)). auto.
+  rewrite H. apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+  apply derI with (ps:=[([] ++ A :: fst s, [] ++ Bot :: snd s)]). apply ImpR. apply ImpRRule_I.
+  apply dlCons. 2: apply dlNil.
+  assert (J0: derrec_height X = derrec_height X). auto.
+  assert (J1: wkn_R Bot (A :: fst s, [] ++ snd s) (A :: fst s, [] ++ Bot :: snd s)). apply wkn_RI.
+  pose (GLS_wkn_R X J0 J1). destruct s0. auto. auto.
+  Qed.
+ +
+  Lemma OrR : forall s A B, GLS_prv (fst s, A :: B :: snd s) -> GLS_prv (fst s, Or A B :: snd s).
+  Proof.
+  intros. unfold Or. unfold Neg.
+  apply derI with (ps:=[([] ++ (A --> Bot) :: fst s, [] ++ B :: snd s)]).
+  apply ImpR. assert ((fst s, (A --> Bot) --> B :: snd s) = (fst s, [] ++ (A --> Bot) --> B :: snd s)). auto.
+  rewrite H. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+  apply derI with (ps:=[([] ++ fst s, [] ++ A :: B :: snd s);([] ++ :: fst s, [] ++ B :: snd s)]).
+  apply ImpL. apply ImpLRule_I.
+  apply dlCons. 2: apply dlCons. 3: apply dlNil. simpl ; auto.
+  apply derI with (ps:=[]). apply BotL. apply BotLRule_I. apply dlNil.
+  Qed.
+ +
+  Lemma list_disj_L : forall l s, (forall A, InT A l -> GLS_prv (A :: fst s, snd s)) -> GLS_prv (list_disj l :: fst s, snd s).
+  Proof.
+  induction l.
+  - intros. simpl. apply derI with (ps:=[]). apply BotL. assert (( :: fst s, snd s) = ([] ++ :: fst s, snd s)). auto.
+    rewrite H. apply BotLRule_I. apply dlNil.
+  - intros. simpl. apply OrL.
+    * apply X. apply InT_eq.
+    * simpl. apply IHl. intros. apply X. apply InT_cons ; auto.
+  Qed.
+ +
+  Lemma list_disj_wkn_R : forall l s A, InT A l -> GLS_prv (fst s, A :: snd s) -> GLS_prv (fst s, list_disj l :: snd s).
+  Proof.
+  induction l.
+  - intros. inversion H.
+  - intros. inversion H ; subst.
+    * simpl. apply OrR.
+      assert (J0: derrec_height X = derrec_height X). auto.
+      assert (J1: wkn_R (list_disj l) (fst s, A :: snd s) (fst s, A :: list_disj l :: snd s)).
+      assert (A :: snd s = [A] ++ snd s). auto. rewrite H0.
+      assert (A :: list_disj l :: snd s = [A] ++ list_disj l :: snd s). auto. rewrite H1. apply wkn_RI.
+      pose (GLS_wkn_R X J0 J1). destruct s0. auto.
+    * simpl. apply IHl in X ; auto.
+      assert (J0: derrec_height X = derrec_height X). auto.
+      assert (J1: wkn_R a (fst s, list_disj l :: snd s) (fst s, a :: list_disj l :: snd s)).
+      assert (a :: list_disj l :: snd s = [] ++ a :: list_disj l :: snd s). auto. rewrite H0.
+      assert ((fst s, list_disj l :: snd s) = (fst s, [] ++ list_disj l :: snd s)). auto. rewrite H2. apply wkn_RI.
+      pose (GLS_wkn_R X J0 J1). destruct s0. apply OrR ; auto.
+  Qed.
+ +
+  Lemma AndR_inv : forall s A B, GLS_prv (fst s, And A B :: snd s) -> (GLS_prv (fst s, A :: snd s) * GLS_prv (fst s, B :: snd s)).
+  Proof.
+  intros. unfold And in X. unfold Neg in X. apply ImpR_inv with (prem:=((A --> B --> ) :: fst s, :: snd s)) in X.
+  apply ImpL_inv with (prem1:=(fst s, A :: :: snd s)) (prem2:=(B --> :: fst s, :: snd s)) in X. destruct X.
+  apply ImpL_inv with (prem1:=(fst s, B :: :: snd s)) (prem2:=( :: fst s, :: snd s)) in g0. destruct g0.
+  pose (BotR_remove (fst s) [A] (snd s) g). pose (BotR_remove (fst s) [B] (snd s) g0). auto.
+  1-2: epose (ImpLRule_I _ _ [] _ [] _) ; simpl in i ; apply i.
+  epose (ImpRRule_I _ _ [] _ [] _) ; simpl in i ; apply i.
+  Qed.
+ +
+  Lemma AndL_inv : forall s A B, GLS_prv (And A B :: fst s, snd s) -> GLS_prv (A :: B :: fst s, snd s).
+  Proof.
+  intros. unfold And in X. unfold Neg in X.
+  apply ImpL_inv with (prem1:=(fst s, A --> B --> :: snd s)) (prem2:=( :: fst s, snd s)) in X. destruct X.
+  apply ImpR_inv with (prem:=(A :: fst s, B --> :: snd s)) in g.
+  apply ImpR_inv with (prem:=(A :: B :: fst s, :: snd s)) in g.
+  pose (BotR_remove (A :: B :: fst s) [] (snd s) g). simpl in g1. auto.
+  epose (ImpRRule_I _ _ [A] _ [] _) ; simpl in i ; apply i.
+  epose (ImpRRule_I _ _ [] _ [] _) ; simpl in i ; apply i.
+  epose (ImpLRule_I _ _ [] _ [] _) ; simpl in i ; apply i.
+  Qed.
+ +
+  Lemma OrR_inv : forall s A B, GLS_prv (fst s, Or A B :: snd s) -> GLS_prv (fst s, A :: B :: snd s).
+  Proof.
+  intros. unfold Or in X. unfold Neg in X.
+  apply ImpR_inv with (prem:=(A --> :: fst s, B :: snd s)) in X.
+  apply ImpL_inv with (prem1:=(fst s, A :: B :: snd s)) (prem2:=( :: fst s, B :: snd s)) in X. destruct X. auto.
+  epose (ImpLRule_I _ _ [] _ [] _) ; simpl in i ; apply i.
+  epose (ImpRRule_I _ _ [] _ [] _) ; simpl in i ; apply i.
+  Qed.
+ +
+  Lemma OrL_inv : forall s A B, GLS_prv (Or A B :: fst s, snd s) -> (GLS_prv (A :: fst s, snd s) * GLS_prv (B :: fst s, snd s)).
+  Proof.
+  intros. unfold Or in X. unfold Neg in X.
+  apply ImpL_inv with (prem1:=(fst s, A --> :: snd s)) (prem2:=(B :: fst s, snd s)) in X. destruct X. split ; auto.
+  apply ImpR_inv with (prem:=(A :: fst s, :: snd s)) in g.
+  pose (BotR_remove (A :: fst s) [] (snd s) g). simpl in g1 ; auto.
+  epose (ImpRRule_I _ _ [] _ [] _) ; simpl in i ; apply i.
+  epose (ImpLRule_I _ _ [] _ [] _) ; simpl in i ; apply i.
+  Qed.
+ +
+  End list_conj_disj_properties.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_Canopy.html b/GL.Interpolation.UIGL_Canopy.html new file mode 100644 index 0000000..555d02d --- /dev/null +++ b/GL.Interpolation.UIGL_Canopy.html @@ -0,0 +1,534 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_Canopy

+ +
+  (* Closure of sequents *)
+ +
+  Require Import List.
+  Export ListNotations.
+  Require Import Lia.
+ +
+  Require Import Coq.Init.Wf.
+ +
+  Require Import GLS_export.
+  Require Import UIGL_Def_measure.
+ +
+  Require Import UIGL_irred_short UIGL_irred_high_level.
+ +
+  Require Import general_export.
+ +
+  (* Defining the premises of a sequent via Imp rules. *)
+ +
+  Lemma finite_ImpRules_premises_of_S : forall (s : Seq), existsT2 listImpRulesprems,
+                (forall prems, (((ImpRRule prems s) + (ImpLRule prems s)) -> (InT prems listImpRulesprems)) *
+                               ((InT prems listImpRulesprems) -> ((ImpRRule prems s) + (ImpLRule prems s)))).
+  Proof.
+  intros.
+  pose (finite_ImpR_premises_of_S s). destruct s0.
+  pose (finite_ImpL_premises_of_S s). destruct s0.
+  exists (x ++ x0). intros. split ; intro.
+  - destruct H.
+    + inversion i. subst. apply InT_or_app. left. apply p. apply ImpRRule_I.
+    + inversion i. subst. apply InT_or_app. right. apply p0. apply ImpLRule_I.
+  - apply InT_app_or in H. destruct H.
+    + left. apply p ; auto.
+    + right. apply p0 ; auto.
+  Defined.
+ +
+  Definition inv_prems (s : Seq) := flatten_list (proj1_sigT2 (finite_ImpRules_premises_of_S s)).
+ +
+  (* The number of implication symbols in a sequent gives a measure
+      which has a well-founded order.*)

+ +
+  Definition less_imp (s0 s1 : Seq) := (n_imp_subformS s0) < (n_imp_subformS s1).
+ +
+  Lemma Acc_less_imp : well_founded less_imp.
+  Proof.
+  intros s ; induction on s as IHm with measure (n_imp_subformS s).
+  apply Acc_intro. auto.
+  Defined.
+ +
+  Definition invprem (s0 s1 : Seq) := In s0 (inv_prems s1).
+ +
+  Lemma InT_In_inv_prems : forall s0 s1, (InT s0 (inv_prems s1) -> In s0 (inv_prems s1)) *
+                                                                   (In s0 (inv_prems s1) -> InT s0 (inv_prems s1)).
+  Proof.
+  intros. split ; intros.
+  - apply InT_In ; auto.
+  - unfold inv_prems. unfold inv_prems in H. destruct (finite_ImpRules_premises_of_S s1).
+    simpl. simpl in H. apply In_InT_seqs. auto.
+Qed.
+ +
+  Lemma Acc_invprem : well_founded invprem.
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  apply Acc_intro. intros. apply IHs. unfold invprem in H.
+  apply InT_In_inv_prems in H. unfold inv_prems in H.
+  destruct (finite_ImpRules_premises_of_S s) in H. simpl in H.
+  apply InT_flatten_list_InT_elem in H. destruct H. destruct p0.
+  apply p in i0. destruct i0.
+  inversion i0. subst. inversion i. subst.
+  unfold n_imp_subformS ; simpl. repeat rewrite n_imp_subformLF_dist_app.
+  simpl. lia. subst. inversion H0.
+  inversion i0. subst. inversion i. subst.
+  unfold n_imp_subformS ; simpl. repeat rewrite n_imp_subformLF_dist_app.
+  simpl. lia. subst.
+  inversion H0. subst.
+  unfold n_imp_subformS ; simpl. repeat rewrite n_imp_subformLF_dist_app.
+  simpl. lia. subst. inversion H1.
+  Defined.
+ +
+  (* The closure of a sequent is the list of all sequents which can be
+      reach via chains of backward applications of invertible rules. *)

+ +
+  Definition Canopy := irred Acc_invprem.
+ +
+  (* Critical sequents are sequents on which no invertible (Imp)
+      rule is backward applicable. *)

+ +
+  Definition critical_Seq (s : Seq) := is_Prime ((fst s) ++ (snd s)).
+ +
+  Definition is_Prime_dec : forall l, (is_Prime l) + (is_Prime l -> False).
+  Proof.
+  unfold is_Prime. induction l ; simpl ; auto.
+  left. intros. inversion H. destruct IHl. destruct a as [n | | |].
+  1,2,4: left ; intros ; destruct H ; auto. right. left ; exists n ; auto.
+  left ; exists a ; auto. right. intro.
+  assert (a1 --> a2 = a1 --> a2 \/ In (a1 --> a2) l). left ; auto. apply H in H0.
+  destruct H0. destruct H0. inversion H0. destruct H0. destruct H0 ; inversion H0.
+  inversion H0. right. intros. apply f. intros. apply H. auto.
+  Defined.
+ +
+  Definition critical_Seq_dec (s : Seq) : (critical_Seq s) + (critical_Seq s -> False).
+  Proof.
+  unfold critical_Seq. destruct s ; simpl. apply is_Prime_dec.
+  Defined.
+ +
+  (* We show that all sequents in Canopy are critical. *)
+ +
+  Lemma inv_prems_id_critical : forall s, inv_prems s = [] -> critical_Seq s.
+  Proof.
+  intros. destruct s. unfold critical_Seq. intros A H0. destruct A as [n | | |].
+  right ; left ; exists n ; auto. right ; auto.
+  2: left ; exists A ; auto. exfalso. simpl in H0.
+  apply in_app_or in H0 ; destruct H0.
+  apply in_split in H0. destruct H0. destruct H0. subst.
+  assert (In (x ++ A2 :: x0, l0) (inv_prems (x ++ A1 --> A2 :: x0, l0))).
+  unfold inv_prems. apply InT_In.
+  apply InT_trans_flatten_list with (bs:=[(x ++ x0, [] ++ A1 :: l0);(x ++ A2 :: x0, [] ++ l0)]).
+  apply InT_cons ; apply InT_eq.
+  destruct (finite_ImpRules_premises_of_S (x ++ A1 --> A2 :: x0, l0)).
+  apply p. right. assert ((x ++ A1 --> A2 :: x0, l0) = (x ++ A1 --> A2 :: x0, [] ++ l0)). auto.
+  rewrite H0. apply ImpLRule_I.
+  rewrite H in H0. inversion H0.
+  apply in_split in H0. destruct H0. destruct H0. subst.
+  assert (In (l ++ A1 :: [], x ++ A2 :: x0) (inv_prems (l ++ [] , x ++ A1 --> A2 :: x0))).
+  unfold inv_prems. apply InT_In.
+  apply InT_trans_flatten_list with (bs:=[(l ++ [A1], x ++ A2 :: x0)]). apply InT_eq.
+  destruct (finite_ImpRules_premises_of_S (l ++ [], x ++ A1 --> A2 :: x0)).
+  apply p. left. apply ImpRRule_I. rewrite app_nil_r in H0.
+  rewrite H in H0. inversion H0.
+  Qed.
+ +
+  Lemma Canopy_critical : forall s leaf, InT leaf (Canopy s) -> (critical_Seq leaf).
+  Proof.
+  unfold Canopy.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros. remember (inv_prems s) as prems. destruct prems.
+  - symmetry in Heqprems ; pose (irred_nil _ _ Acc_invprem s Heqprems).
+    rewrite e in H. pose (inv_prems_id_critical _ Heqprems). inversion H ; subst ; auto.
+    inversion H1.
+  - assert (J1: inv_prems s <> []%list). rewrite <- Heqprems. intro.
+    inversion H0. pose (irred_not _ _ Acc_invprem s J1). rewrite e in H.
+    pose (InT_In H). apply in_flat_map in i. destruct i. destruct H0.
+    apply In_InT_seqs in H1. apply IHs with (y:=x) ; auto.
+    apply InT_In_inv_prems in H0. unfold inv_prems in H0.
+    destruct (finite_ImpRules_premises_of_S s) in H0. simpl in H0.
+    apply InT_flatten_list_InT_elem in H0. destruct H0. destruct p0.
+    apply p in i0. destruct i0.
+    inversion i0. subst. inversion i. subst.
+    unfold n_imp_subformS ; simpl. repeat rewrite n_imp_subformLF_dist_app.
+    simpl. lia. subst. inversion H2.
+    inversion i0. subst. inversion i. subst.
+    unfold n_imp_subformS ; simpl. repeat rewrite n_imp_subformLF_dist_app.
+    simpl. lia. subst.
+    inversion H2. subst.
+    unfold n_imp_subformS ; simpl. repeat rewrite n_imp_subformLF_dist_app.
+    simpl. lia. subst. inversion H3.
+  Qed.
+ +
+  (* We show the equiprovability between a sequent and its Canopy. *)
+ +
+  Lemma ImpRule_Canopy : forall s prems, ((ImpRRule prems s) + (ImpLRule prems s)) ->
+                (forall prem, InT prem prems -> (forall leaf, InT leaf (Canopy prem) -> InT leaf (Canopy s))).
+  Proof.
+  intros. unfold Canopy. rewrite irred_not. apply In_InT_seqs.
+  apply in_flat_map. exists prem ; split ; auto. 2: apply InT_In ; auto.
+  unfold inv_prems. apply InT_In. apply InT_trans_flatten_list with (bs:=prems) ; auto.
+  destruct (finite_ImpRules_premises_of_S s) ; simpl. apply p ; auto.
+  intro. unfold inv_prems in H2. destruct (finite_ImpRules_premises_of_S s) ; simpl.
+  simpl in H2. apply p in H. assert (InT prem (flatten_list x)).
+  apply InT_trans_flatten_list with (bs:=prems) ; auto. rewrite H2 in H3. inversion H3.
+  Qed.
+ +
+  (* Move the lemma below to a more general location. *)
+ +
+  Lemma InT_flat_map: forall (f : Seq -> list Seq) (l : list Seq) (y : Seq), (InT y (flat_map f l) -> (existsT2 x : Seq, InT x l * InT y (f x))) *
+                                                                                                                ( (existsT2 x : Seq, InT x l * InT y (f x)) -> InT y (flat_map f l)).
+  Proof.
+  intros f. induction l.
+  - intros ; split ; intros. simpl in H. inversion H. simpl. destruct H. destruct p. inversion i.
+  - intros ; simpl ; split ; intros. apply InT_app_or in H. destruct H. exists a ; split ; auto. apply InT_eq.
+    apply IHl in i. destruct i. destruct p. exists x ; split ; auto. apply InT_cons ; auto.
+    apply InT_or_app. destruct H. destruct p. inversion i ; subst ; auto. right.
+    apply IHl. exists x ; split ; auto.
+  Qed.
+ +
+  Lemma fold_Canopy : forall s leaf, InT leaf (Canopy s) ->
+                  (leaf = s) + (existsT2 prem, InT prem (inv_prems s) * InT leaf (Canopy prem)).
+  Proof.
+  intros. remember (finite_ImpRules_premises_of_S s) as J.
+  destruct J. destruct x.
+  - assert (Canopy s = [s]). apply irred_nil. unfold inv_prems. rewrite <- HeqJ.
+    simpl. auto. rewrite H0 in H. inversion H ; subst ; auto. inversion H2.
+  - right. unfold Canopy in H. rewrite irred_not in H. apply InT_flat_map in H. destruct H.
+    destruct p0. exists x0 ; split ; auto. intro. unfold inv_prems in H0. rewrite <- HeqJ in H0.
+    assert (InT l (l :: x)). apply InT_eq. apply p in H1. destruct H1 ; inversion i ; subst ;
+    simpl in H0 ; inversion H0.
+  Qed.
+ +
+  Lemma Canopy_equiprv : forall s,
+    ((forall leaf, InT leaf (Canopy s) -> GLS_prv leaf) -> (GLS_prv s)) *
+    ((GLS_prv s) -> (forall leaf, InT leaf (Canopy s) -> GLS_prv leaf)).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros ; split ; intros.
+  - remember (finite_ImpRules_premises_of_S s) as H.
+    destruct H. destruct x.
+    + assert (Canopy s = [s]). apply irred_nil. unfold inv_prems. rewrite <- HeqH.
+       simpl. auto. rewrite H in X. apply X. apply InT_eq.
+    + assert (J1: InT l (l :: x)). apply InT_eq. apply p in J1. destruct J1 ; unfold GLS_prv ; apply derI with (ps:=l).
+       apply ImpR ; auto. 2: apply ImpL ; auto. all: inversion i ; subst ; apply dlCons. 4: apply dlCons. 2,5: apply dlNil.
+       all: apply IHs. 1,3,5: unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       all: intros ; apply X. apply ImpRule_Canopy with (prems:=[(Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)]) (prem:=(Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)) ; auto.
+       apply InT_eq. apply ImpRule_Canopy with (prems:=[(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+       (prem:=(Γ0 ++ Γ1, Δ0 ++ A :: Δ1)) ; auto. apply InT_eq.
+        apply ImpRule_Canopy with (prems:=[(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+       (prem:=(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto. apply InT_cons ; apply InT_eq.
+  - apply fold_Canopy in H. destruct H ; subst ; auto. destruct s0. destruct p.
+    unfold inv_prems in i ; apply InT_flatten_list_InT_elem in i ; destruct i ; destruct p ; destruct (finite_ImpRules_premises_of_S s) ;
+    simpl in i1. apply p in i1. destruct i1 ; inversion i1 ; subst.
+    + inversion i ; subst. 2: inversion H0. apply IHs with (y:=(Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpR_inv with (concl:=(Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)) ; auto.
+    + inversion i ; subst. apply IHs with (y:=(Γ0 ++ Γ1, Δ0 ++ A :: Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpL_inv with (concl:=(Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)) (prem2:= (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto.
+       inversion H0 ; subst. 2: inversion H1. apply IHs with (y:=(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpL_inv with (concl:=(Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)) (prem1:= (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)) ; auto.
+  Qed.
+ +
+  Lemma Canopy_equiprv_genL : forall s A,
+    ((forall leaf, InT leaf (Canopy s) -> GLS_prv (A :: fst leaf, snd leaf)) -> (GLS_prv (A :: fst s, snd s))) *
+    ((GLS_prv (A :: fst s, snd s)) -> (forall leaf, InT leaf (Canopy s) -> GLS_prv (A :: fst leaf, snd leaf))).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros ; split ; intros.
+  - remember (finite_ImpRules_premises_of_S s) as H0.
+    destruct H0. destruct x.
+    + assert (Canopy s = [s]). apply irred_nil. unfold inv_prems. rewrite <- HeqH0.
+       simpl. auto. rewrite H in X. apply X. apply InT_eq.
+    + assert (J1: InT l (l :: x)). apply InT_eq. apply p in J1. destruct J1 ; unfold GLS_prv ; inversion i ; subst ; simpl.
+       apply derI with (ps:=[(A :: Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1)]).
+       apply ImpR ; auto. assert ((A :: Γ0 ++ A0 :: Γ1) = ((A :: Γ0) ++ A0 :: Γ1)). auto. rewrite H.
+       assert (A :: Γ0 ++ Γ1 = (A :: Γ0) ++ Γ1). auto. rewrite H0. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+       2: apply derI with (ps:=[(A :: Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1);(A :: Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]).
+       2: apply ImpL ; auto. 2: assert (A :: Γ0 ++ Γ1 = ((A :: Γ0) ++ Γ1)) ; auto ; rewrite H.
+       2: assert (A :: Γ0 ++ B :: Γ1 = (A :: Γ0) ++ B :: Γ1) ; auto ; rewrite H0. 2: apply ImpLRule_I. 2: apply dlCons.
+       3: apply dlCons. 4: apply dlNil.
+       assert (J2: n_imp_subformS (Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1) < n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A0 --> B :: Δ1)).
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply IHs with (A:=A) in J2. simpl in J2. destruct J2. apply g. intros. apply X.
+       apply ImpRule_Canopy with (prems:=[(Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1)]) (prem:=(Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1)) ; auto.
+       apply InT_eq.
+       assert (J2: n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1) < n_imp_subformS (Γ0 ++ A0 --> B :: Γ1, Δ0 ++ Δ1)).
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply IHs with (A:=A) in J2. simpl in J2. destruct J2. apply g. intros. apply X.
+       apply ImpRule_Canopy with (prems:=[(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+       (prem:=(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1)) ; auto. apply InT_eq.
+       assert (J2: n_imp_subformS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) < n_imp_subformS (Γ0 ++ A0 --> B :: Γ1, Δ0 ++ Δ1)).
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply IHs with (A:=A) in J2. simpl in J2. destruct J2. apply g. intros. apply X.
+       apply ImpRule_Canopy with (prems:=[(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+       (prem:=(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto. apply InT_cons. apply InT_eq.
+  - apply fold_Canopy in H. destruct H ; subst ; auto. destruct s0. destruct p.
+    unfold inv_prems in i ; apply InT_flatten_list_InT_elem in i ; destruct i ; destruct p ; destruct (finite_ImpRules_premises_of_S s) ;
+    simpl in i1. apply p in i1. destruct i1 ; inversion i1 ; subst.
+    + inversion i ; subst. 2: inversion H0. apply IHs with (y:=(Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpR_inv with (concl:=(A :: Γ0 ++ Γ1, Δ0 ++ A0 --> B :: Δ1)) ; auto. simpl.
+       assert (A :: Γ0 ++ A0 :: Γ1 = (A :: Γ0) ++ A0 :: Γ1). auto. rewrite H.
+       assert (A :: Γ0 ++ Γ1 = (A :: Γ0) ++ Γ1). auto. rewrite H0. apply ImpRRule_I.
+    + inversion i ; subst. apply IHs with (y:=(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpL_inv with (concl:=(A :: Γ0 ++ A0 --> B :: Γ1, Δ0 ++ Δ1)) (prem2:= (A :: Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto. simpl.
+       assert (A :: Γ0 ++ B :: Γ1 = (A :: Γ0) ++ B :: Γ1). auto. rewrite H.
+       assert (A :: Γ0 ++ Γ1 = (A :: Γ0) ++ Γ1). auto. rewrite H0. apply ImpLRule_I.
+       inversion H0 ; subst. 2: inversion H1. apply IHs with (y:=(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpL_inv with (concl:=(A :: Γ0 ++ A0 --> B :: Γ1, Δ0 ++ Δ1)) (prem1:= (A :: Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1)) ; auto. simpl.
+       assert (A :: Γ0 ++ B :: Γ1 = (A :: Γ0) ++ B :: Γ1). auto. rewrite H.
+       assert (A :: Γ0 ++ Γ1 = (A :: Γ0) ++ Γ1). auto. rewrite H1. apply ImpLRule_I.
+  Qed.
+ +
+  Lemma Canopy_equiprv_genR : forall s A,
+    ((forall leaf, InT leaf (Canopy s) -> GLS_prv (fst leaf, A :: snd leaf)) -> (GLS_prv (fst s, A :: snd s))) *
+    ((GLS_prv (fst s, A :: snd s)) -> (forall leaf, InT leaf (Canopy s) -> GLS_prv (fst leaf, A :: snd leaf))).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros ; split ; intros.
+  - remember (finite_ImpRules_premises_of_S s) as H0.
+    destruct H0. destruct x.
+    + assert (Canopy s = [s]). apply irred_nil. unfold inv_prems. rewrite <- HeqH0.
+       simpl. auto. rewrite H in X. apply X. apply InT_eq.
+    + assert (J1: InT l (l :: x)). apply InT_eq. apply p in J1. destruct J1 ; unfold GLS_prv ; inversion i ; subst ; simpl.
+       apply derI with (ps:=[(Γ0 ++ A0 :: Γ1, A :: Δ0 ++ B :: Δ1)]).
+       apply ImpR ; auto. assert ((A :: Δ0 ++ B :: Δ1) = ((A :: Δ0) ++ B :: Δ1)). auto. rewrite H.
+       assert (A :: Δ0 ++ A0 --> B :: Δ1 = (A :: Δ0) ++ A0 --> B :: Δ1). auto. rewrite H0. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+       2: apply derI with (ps:=[(Γ0 ++ Γ1, A :: Δ0 ++ A0 :: Δ1);(Γ0 ++ B :: Γ1, A :: Δ0 ++ Δ1)]).
+       2: apply ImpL ; auto. 2: assert (A :: Δ0 ++ Δ1 = ((A :: Δ0) ++ Δ1)) ; auto ; rewrite H.
+       2: assert (A :: Δ0 ++ A0 :: Δ1 = (A :: Δ0) ++ A0 :: Δ1) ; auto ; rewrite H0. 2: apply ImpLRule_I. 2: apply dlCons.
+       3: apply dlCons. 4: apply dlNil.
+       assert (J2: n_imp_subformS (Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1) < n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A0 --> B :: Δ1)).
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply IHs with (A:=A) in J2. simpl in J2. destruct J2. apply g. intros. apply X.
+       apply ImpRule_Canopy with (prems:=[(Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1)]) (prem:=(Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1)) ; auto.
+       apply InT_eq.
+       assert (J2: n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1) < n_imp_subformS (Γ0 ++ A0 --> B :: Γ1, Δ0 ++ Δ1)).
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply IHs with (A:=A) in J2. simpl in J2. destruct J2. apply g. intros. apply X.
+       apply ImpRule_Canopy with (prems:=[(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+       (prem:=(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1)) ; auto. apply InT_eq.
+       assert (J2: n_imp_subformS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) < n_imp_subformS (Γ0 ++ A0 --> B :: Γ1, Δ0 ++ Δ1)).
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply IHs with (A:=A) in J2. simpl in J2. destruct J2. apply g. intros. apply X.
+       apply ImpRule_Canopy with (prems:=[(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+       (prem:=(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto. apply InT_cons. apply InT_eq.
+  - apply fold_Canopy in H. destruct H ; subst ; auto. destruct s0. destruct p.
+    unfold inv_prems in i ; apply InT_flatten_list_InT_elem in i ; destruct i ; destruct p ; destruct (finite_ImpRules_premises_of_S s) ;
+    simpl in i1. apply p in i1. destruct i1 ; inversion i1 ; subst.
+    + inversion i ; subst. 2: inversion H0. apply IHs with (y:=(Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpR_inv with (concl:=(Γ0 ++ Γ1, A :: Δ0 ++ A0 --> B :: Δ1)) ; auto. simpl.
+       assert (A :: Δ0 ++ B :: Δ1 = (A :: Δ0) ++ B :: Δ1). auto. rewrite H.
+       assert (A :: Δ0 ++ A0 --> B :: Δ1 = (A :: Δ0) ++ A0 --> B :: Δ1). auto. rewrite H0. apply ImpRRule_I.
+    + inversion i ; subst. apply IHs with (y:=(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpL_inv with (concl:=(Γ0 ++ A0 --> B :: Γ1, A :: Δ0 ++ Δ1)) (prem2:= (Γ0 ++ B :: Γ1, A :: Δ0 ++ Δ1)) ; auto. simpl.
+       assert (A :: Δ0 ++ A0 :: Δ1 = (A :: Δ0) ++ A0 :: Δ1). auto. rewrite H.
+       assert (A :: Δ0 ++ Δ1 = (A :: Δ0) ++ Δ1). auto. rewrite H0. apply ImpLRule_I.
+       inversion H0 ; subst. 2: inversion H1. apply IHs with (y:=(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpL_inv with (concl:=(Γ0 ++ A0 --> B :: Γ1, A :: Δ0 ++ Δ1)) (prem1:= (Γ0 ++ Γ1, A :: Δ0 ++ A0 :: Δ1)) ; auto. simpl.
+       assert (A :: Δ0 ++ A0 :: Δ1 = (A :: Δ0) ++ A0 :: Δ1). auto. rewrite H.
+       assert (A :: Δ0 ++ Δ1 = (A :: Δ0) ++ Δ1). auto. rewrite H1. apply ImpLRule_I.
+  Qed.
+ +
+  Lemma Canopy_hp_inv_ctx : forall s k scomp (D0 : GLS_prv scomp) X0 Y0,
+        k = (derrec_height D0) ->
+        scomp = (fst s ++ X0, snd s ++ Y0) ->
+        (forall leaf, InT leaf (Canopy s) -> existsT2 (D1: GLS_prv (fst leaf ++ X0, snd leaf ++ Y0)),
+                                                                                derrec_height D1 <= k).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros. apply fold_Canopy in H1. destruct H1.
+  - subst. exists D0 ; auto.
+  - destruct s0 ; destruct p. unfold inv_prems in i. apply InT_flatten_list_InT_elem in i. destruct i.
+    destruct p. destruct (finite_ImpRules_premises_of_S s). simpl in i1. subst.
+    assert (J0: derrec_height D0 = derrec_height D0). auto.
+    pose (ImpR_ImpL_hpinv D0 J0). destruct p0. apply p in i1. destruct i1.
+    + inversion i1 ; subst. simpl in s0.
+       assert (J1: ImpRRule [(Γ0 ++ A :: (Γ1 ++ X0), Δ0 ++ B :: (Δ1 ++ Y0))] ((Γ0 ++ Γ1) ++ X0, (Δ0 ++ A --> B :: Δ1) ++ Y0)).
+       repeat rewrite <- app_assoc ; apply ImpRRule_I. apply s0 in J1. destruct J1. inversion i ; subst.
+       assert (J2: n_imp_subformS (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) < n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)).
+       unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+       lia.
+       assert (J3: derrec_height x0 = derrec_height x0). auto.
+       assert (J4: (Γ0 ++ A :: Γ1 ++ X0, Δ0 ++ B :: Δ1 ++ Y0) = (fst (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) ++ X0, snd (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) ++ Y0)).
+       simpl ; repeat rewrite <- app_assoc ; auto.
+       pose (IHs _ J2 _ _ x0 X0 Y0 J3 J4 _ i0). destruct s. exists x. apply PeanoNat.Nat.le_trans with (m:=derrec_height x0) ; auto.
+       inversion H0.
+    + inversion i1 ; subst. simpl in s1. clear s0.
+       assert (J1: ImpLRule [(Γ0 ++ Γ1 ++ X0, Δ0 ++ A :: Δ1 ++ Y0); (Γ0 ++ B :: Γ1 ++ X0, Δ0 ++ Δ1 ++ Y0)] ((Γ0 ++ A --> B :: Γ1) ++ X0, (Δ0 ++ Δ1) ++ Y0)).
+       repeat rewrite <- app_assoc ; apply ImpLRule_I. apply s1 in J1. destruct J1. destruct s. destruct p0. inversion i ; subst.
+       assert (J2: n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+       unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+       lia.
+       assert (J3: derrec_height x0 = derrec_height x0). auto.
+       assert (J4: (Γ0 ++ Γ1 ++ X0, Δ0 ++ A :: Δ1 ++ Y0) = (fst (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) ++ X0, snd (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) ++ Y0)).
+       simpl ; repeat rewrite <- app_assoc ; auto.
+       pose (IHs _ J2 _ _ x0 X0 Y0 J3 J4 _ i0). destruct s. exists x. apply PeanoNat.Nat.le_trans with (m:=derrec_height x0) ; auto.
+       inversion H0 ; subst.
+       assert (J2: n_imp_subformS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+       unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+       lia.
+       assert (J3: derrec_height x2 = derrec_height x2). auto.
+       assert (J4: (Γ0 ++ B :: Γ1 ++ X0, Δ0 ++ Δ1 ++ Y0) = (fst (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) ++ X0, snd (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) ++ Y0)).
+       simpl ; repeat rewrite <- app_assoc ; auto.
+       pose (IHs _ J2 _ _ x2 X0 Y0 J3 J4 _ i0). destruct s. exists x. apply PeanoNat.Nat.le_trans with (m:=derrec_height x2) ; auto.
+       inversion H1.
+  Qed.
+ +
+  Lemma Canopy_neg_var : forall s q, InT (# q) (fst s) -> (forall leaf, InT leaf (Canopy s) -> InT (# q) (fst leaf)).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros. apply fold_Canopy in H0. destruct H0 ; subst ; auto.
+  destruct s0 ; destruct p. unfold inv_prems in i. apply InT_flatten_list_InT_elem in i. destruct i.
+  destruct p. destruct (finite_ImpRules_premises_of_S s). simpl in i1. subst.
+  apply p in i1. destruct i1.
+  - inversion i1 ; subst. inversion i ; subst. 2: inversion H1.
+    assert (J0: n_imp_subformS (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) < n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)).
+     unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+     lia.
+    apply IHs with (q:= q) (leaf:=leaf) in J0 ; auto. simpl. apply InT_or_app. simpl in H. apply InT_app_or in H ; destruct H ; auto.
+    right ; apply InT_cons ; auto.
+  - inversion i1 ; subst. inversion i ; subst. 2: inversion H1. 3: inversion H2.
+    assert (J0: n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+     unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+     lia.
+    apply IHs with (q:= q) (leaf:=leaf) in J0 ; auto. simpl. apply InT_or_app. simpl in H. apply InT_app_or in H ; destruct H ; auto.
+    inversion i2 ; subst. inversion H0. auto. subst.
+    assert (J0: n_imp_subformS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+     unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+     lia.
+    apply IHs with (q:= q) (leaf:=leaf) in J0 ; auto. simpl. apply InT_or_app. simpl in H. apply InT_app_or in H ; destruct H ; auto.
+    inversion i2 ; subst. inversion H0. right ; apply InT_cons ; auto.
+  Qed.
+ +
+  Lemma Canopy_pos_var : forall s q, InT (# q) (snd s) -> (forall leaf, InT leaf (Canopy s) -> InT (# q) (snd leaf)).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros. apply fold_Canopy in H0. destruct H0 ; subst ; auto.
+  destruct s0 ; destruct p. unfold inv_prems in i. apply InT_flatten_list_InT_elem in i. destruct i.
+  destruct p. destruct (finite_ImpRules_premises_of_S s). simpl in i1. subst.
+  apply p in i1. destruct i1.
+  - inversion i1 ; subst. inversion i ; subst. 2: inversion H1.
+    assert (J0: n_imp_subformS (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) < n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)).
+     unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+     lia.
+    apply IHs with (q:= q) (leaf:=leaf) in J0 ; auto. simpl. apply InT_or_app. simpl in H. apply InT_app_or in H ; destruct H ; auto.
+    inversion i2 ; subst. inversion H0. right ; apply InT_cons ; auto.
+  - inversion i1 ; subst. inversion i ; subst. 2: inversion H1. 3: inversion H2.
+    assert (J0: n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+     unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+     lia.
+    apply IHs with (q:= q) (leaf:=leaf) in J0 ; auto. simpl. apply InT_or_app. simpl in H. apply InT_app_or in H ; destruct H ; auto.
+    right ; apply InT_cons ; auto. subst.
+    assert (J0: n_imp_subformS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+     unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+     lia.
+    apply IHs with (q:= q) (leaf:=leaf) in J0 ; auto.
+  Qed.
+ +
+  Definition Id_InT_Canopy : forall s, InT s (Canopy s) -> Canopy s = [s].
+  Proof.
+  intros. destruct (critical_Seq_dec s).
+  - remember (finite_ImpRules_premises_of_S s) as J.
+    destruct J. destruct x.
+    + apply irred_nil. unfold inv_prems. rewrite <- HeqJ.
+       simpl. auto.
+    + exfalso. assert (J1: InT l (l :: x)). apply InT_eq. apply p in J1. unfold critical_Seq in c.
+       destruct J1 ; inversion i ; subst ; simpl in c.
+       assert (In (A --> B) ((Γ0 ++ Γ1) ++ Δ0 ++ A --> B :: Δ1)). apply in_or_app ; right ; apply in_or_app ; right ; apply in_eq.
+       apply c in H0. destruct H0. destruct H0. inversion H0. destruct H0. destruct H0 ; inversion H0. inversion H0.
+       assert (In (A --> B) ((Γ0 ++ A --> B :: Γ1) ++ Δ0 ++ Δ1)). apply in_or_app ; left ; apply in_or_app ; right ; apply in_eq.
+       apply c in H0. destruct H0. destruct H0. inversion H0. destruct H0. destruct H0 ; inversion H0. inversion H0.
+  - exfalso. apply Canopy_critical in H. auto.
+  Defined.
+ +
+  Lemma critical_Seq_InT_Canopy : forall s, critical_Seq s -> InT s (Canopy s).
+  Proof.
+  intros. remember (finite_ImpRules_premises_of_S s) as J.
+  destruct J. destruct x.
+  + pose irred_nil. unfold Canopy. rewrite e. apply InT_eq. unfold inv_prems. rewrite <- HeqJ.
+     simpl. auto.
+  + exfalso. assert (J1: InT l (l :: x)). apply InT_eq. apply p in J1. unfold critical_Seq in H.
+     destruct J1 ; inversion i ; subst ; simpl in H.
+     assert (In (A --> B) ((Γ0 ++ Γ1) ++ Δ0 ++ A --> B :: Δ1)). apply in_or_app ; right ; apply in_or_app ; right ; apply in_eq.
+     apply H in H0. destruct H0. destruct H0. inversion H0. destruct H0. destruct H0 ; inversion H0. inversion H0.
+     assert (In (A --> B) ((Γ0 ++ A --> B :: Γ1) ++ Δ0 ++ Δ1)). apply in_or_app ; left ; apply in_or_app ; right ; apply in_eq.
+     apply H in H0. destruct H0. destruct H0. inversion H0. destruct H0. destruct H0 ; inversion H0. inversion H0.
+  Qed.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_Canopy_ImpL.html b/GL.Interpolation.UIGL_Canopy_ImpL.html new file mode 100644 index 0000000..0a48f6b --- /dev/null +++ b/GL.Interpolation.UIGL_Canopy_ImpL.html @@ -0,0 +1,108 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_Canopy_ImpL

+ +
+  Require Import List.
+  Export ListNotations.
+  Require Import PeanoNat.
+  Require Import Lia.
+ +
+  Require Import general_export.
+ +
+  Require Import GLS_export.
+ +
+  Require Import UIGL_Def_measure.
+  Require Import UIGL_Canopy.
+  Require Import UIGL_irred_short.
+  Require Import UIGL_braga.
+  Require Import UIGL_Canopy_ImpR.
+ +
+  Lemma repeat_more_than_one : forall n (A : MPropF), 0 < n -> In A (repeat A n).
+  Proof.
+  induction n ; simpl ; intros ; auto. inversion H.
+  Qed.
+ +
+  (* These two lemmas are crucial. *)
+ +
+  Lemma mult_ImpL_R : forall s0 s1 A B,
+          InT s1 (Canopy (replace (A --> B) B (fst s0), snd s0))->
+          InT s1 (Canopy s0).
+  Proof.
+  intros s0 s1 A B. remember (count_occ eq_dec_form (fst s0) (A --> B)) as n. revert Heqn. generalize dependent B.
+  generalize dependent A. generalize dependent s1. generalize dependent s0. induction n ; simpl ; intros.
+  - symmetry in Heqn. rewrite <- count_occ_not_In in Heqn. rewrite notin_replace in H ; auto. destruct s0 ; auto.
+  - assert (count_occ eq_dec_form (fst s0) (A --> B) > 0). lia. apply count_occ_In in H0. destruct s0. simpl in H0.
+    simpl in H. simpl in Heqn. apply In_InT in H0. apply InT_split in H0. destruct H0. destruct s ; subst.
+    repeat rewrite count_occ_app in Heqn. simpl in Heqn. repeat rewrite replace_app in H.
+    simpl in H. destruct (eq_dec_form (A --> B) (A --> B)). 2: exfalso ; auto.
+    assert (n = count_occ eq_dec_form (x ++ x0) (A --> B)). repeat rewrite count_occ_app ; lia.
+    pose (IHn (x ++ B :: x0, l0) s1 A B). simpl in i.
+    repeat rewrite count_occ_app in i. simpl in i. repeat rewrite replace_app in i.
+    simpl in i. destruct (eq_dec_form B (A --> B)). exfalso. assert (length_form (A --> B) = length_form B). rewrite <- e0 ; auto.
+    simpl in H1 ; lia. destruct (eq_dec_form (A --> B) B). exfalso ; auto. repeat rewrite count_occ_app in H0. pose (i H0 H).
+    apply ImpRule_Canopy with (prems:=[(x ++ x0, A :: l0);(x ++ B :: x0, l0)]) (prem:=(x ++ B :: x0, l0)) ; auto.
+     right. epose (ImpLRule_I _ _ _ _ []). simpl in i1 ; apply i1. apply InT_cons ; apply InT_eq.
+  Qed.
+ +
+  Lemma mult_ImpL_L : forall s0 s1 A B,
+          InT s1 (Canopy (remove eq_dec_form (A --> B) (fst s0), repeat A (count_occ eq_dec_form (fst s0) (A --> B)) ++ (snd s0)))->
+          InT s1 (Canopy s0).
+  Proof.
+  intros s0 s1 A B. remember (count_occ eq_dec_form (fst s0) (A --> B)) as n. revert Heqn. generalize dependent B.
+  generalize dependent A. generalize dependent s1. generalize dependent s0. induction n ; simpl ; intros.
+  - symmetry in Heqn. rewrite <- count_occ_not_In in Heqn. rewrite notin_remove in H ; auto. destruct s0 ; auto.
+  - assert (count_occ eq_dec_form (fst s0) (A --> B) > 0). lia. apply count_occ_In in H0. destruct s0. simpl in H0.
+    simpl in H. simpl in Heqn. apply In_InT in H0. apply InT_split in H0. destruct H0. destruct s ; subst.
+    repeat rewrite count_occ_app in Heqn. simpl in Heqn. repeat rewrite remove_app in H.
+    simpl in H. destruct (eq_dec_form (A --> B) (A --> B)). 2: exfalso ; auto.
+    assert (n = count_occ eq_dec_form (x ++ x0) (A --> B)). repeat rewrite count_occ_app ; lia.
+    pose (IHn (x ++ x0, A :: l0) s1 A B). simpl in i. repeat rewrite count_occ_app in i. repeat rewrite remove_app in i.
+    repeat rewrite count_occ_app in H0. pose (i H0).
+    assert (repeat A n ++ A :: l0 = A :: repeat A n ++ l0). assert (repeat A n ++ A :: l0 = (repeat A n ++ [A]) ++ l0).
+    rewrite <- app_assoc. auto. rewrite H1. rewrite <- repeat_cons. simpl ; auto. rewrite H1 in i0. apply i0 in H.
+    apply ImpRule_Canopy with (prems:=[(x ++ x0, A :: l0);(x ++ B :: x0, l0)]) (prem:=(x ++ x0, A :: l0)) ; auto.
+    right. epose (ImpLRule_I _ _ _ _ []). simpl in i1 ; apply i1. apply InT_eq.
+  Qed.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_Canopy_ImpR.html b/GL.Interpolation.UIGL_Canopy_ImpR.html new file mode 100644 index 0000000..8909d88 --- /dev/null +++ b/GL.Interpolation.UIGL_Canopy_ImpR.html @@ -0,0 +1,241 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_Canopy_ImpR

+ +
+  Require Import List.
+  Export ListNotations.
+  Require Import PeanoNat.
+  Require Import Lia.
+ +
+  Require Import general_export.
+ +
+  Require Import GLS_export.
+ +
+  Require Import UIGL_Def_measure.
+  Require Import UIGL_Canopy.
+  Require Import UIGL_irred_short.
+  Require Import UIGL_braga.
+ +
+  (* Operation to remove and replace an element in a list. *)
+ +
+  Definition replace (A B : MPropF) (l : list MPropF) : list MPropF :=
+  let subst_form A B C := if (eq_dec_form A C) then B else C in
+  map (subst_form A B) l.
+ +
+  Lemma replace_app : forall l0 l1 A B, replace A B (l0 ++ l1) = replace A B l0 ++ replace A B l1.
+  Proof. intros. apply map_app. Qed.
+ +
+  Lemma in_not_touched_replace : forall (l : list MPropF) [A B C : MPropF], In C l -> C <> A ->
+              In C (replace A B l).
+  Proof.
+  intros. apply in_map_iff. exists C. destruct (eq_dec_form A C) ; subst; tauto.
+  Qed.
+ +
+  Lemma in_replace : forall l A B C, A <> B -> In C (replace A B l) -> (In C l \/ C = B) /\ A <> C.
+  Proof.
+  induction l ; simpl ; intros ; auto. destruct (eq_dec_form A a) ; subst.
+  inversion H0 ; subst. split ; auto. pose (IHl _ _ _ H H1). destruct a0. split ; auto. destruct H2 ; auto.
+  inversion H0 ; subst. split ; auto. pose (IHl _ _ _ H H1). destruct a0 ; split ; auto. destruct H2 ; auto.
+  Qed.
+ +
+  Lemma notin_replace : forall l (A B : MPropF), (In A l -> False) -> replace A B l = l.
+  Proof.
+  induction l ; simpl ; intros ; auto. destruct (eq_dec_form A a) ; subst. destruct H ; auto. rewrite IHl ; auto.
+  Qed.
+ +
+  Lemma univ_gen_ext_count_occ : forall l0 l1 A, univ_gen_ext (fun x : MPropF => x = A) l0 l1 ->
+                count_occ eq_dec_form l0 A <= count_occ eq_dec_form l1 A.
+  Proof.
+  intros. induction X ; simpl ; try lia. all: destruct (eq_dec_form x A) ; try lia.
+  Qed.
+ +
+  Lemma univ_gen_ext_S_count_occ : forall l0 l1 A, (count_occ eq_dec_form l0 A < count_occ eq_dec_form l1 A) ->
+                (univ_gen_ext (fun x : MPropF => x = A) l0 l1) ->
+                existsT2 l2 l3 l4 l5, (l0 = l2 ++ l3) * (l1 = l4 ++ A :: l5) * (univ_gen_ext (fun x : MPropF => x = A) l2 l4) *
+                                              (univ_gen_ext (fun x : MPropF => x = A) l3 l5).
+  Proof.
+  intros. revert H. induction X ; simpl ; intros ; auto ; try lia.
+  - destruct (eq_dec_form x A) ; subst.
+    * assert ((count_occ eq_dec_form l A) < (count_occ eq_dec_form le A)). lia. apply IHX in H0.
+      destruct H0. destruct s. destruct s. destruct s. destruct p. destruct p. destruct p ; subst.
+      exists (A :: x). exists x0. exists (A :: x1). exists x2. simpl. repeat split ; auto.
+      apply univ_gen_ext_cons ; auto.
+    * apply IHX in H. destruct H. destruct s. destruct s. destruct s. destruct p. destruct p. destruct p ; subst.
+      exists (x :: x0). exists x1. exists (x :: x2). exists x3. simpl. repeat split ; auto.
+      apply univ_gen_ext_cons ; auto.
+  - destruct (eq_dec_form x A) ; subst.
+    * exists []. exists l. exists []. exists le. simpl. repeat split ; auto. apply univ_gen_ext_nil.
+    * apply IHX in H. destruct H. destruct s. destruct s. destruct s. destruct p. destruct p. destruct p ; subst.
+      exists x. exists x0. exists (A :: x1). exists x2. simpl. repeat split ; auto.
+      apply univ_gen_ext_extra ; auto.
+  Qed.
+ +
+  Lemma count_occ_n_imp_subformLF : forall l A B, count_occ eq_dec_form l (A --> B) * S (n_imp_subformF A) <= n_imp_subformLF l.
+  Proof.
+  induction l ; simpl ; intros ; auto. destruct (eq_dec_form a (A --> B)) ; subst ; auto.
+  - pose (IHl A B). assert (n_imp_subformF A < n_imp_subformF (A --> B)). simpl. lia. lia.
+  - pose (IHl A B). lia.
+  Qed.
+ +
+  Lemma count_le_n_imp : forall l A B, count_occ eq_dec_form l (A --> B) <= n_imp_subformLF l.
+  Proof.
+  intros. pose (count_occ_n_imp_subformLF l A B). lia.
+  Qed.
+ +
+  Global Opaque eq_dec_form.
+ +
+  Lemma n_imp_subformLF_replace : forall l A B, n_imp_subformLF (replace (A --> B) B l) =
+        (n_imp_subformLF l - ((count_occ eq_dec_form l (A --> B)) * S (n_imp_subformF A))).
+  Proof.
+  intros. remember (count_occ eq_dec_form l (A --> B)) as n. revert Heqn. generalize dependent B.
+  generalize dependent A. generalize dependent l. induction n ; simpl ; intros.
+  - rewrite notin_replace ; try lia. symmetry in Heqn. rewrite <- count_occ_not_In in Heqn ; auto.
+  - assert (count_occ eq_dec_form l (A --> B) > 0). lia. apply count_occ_In in H. apply in_split in H. destruct H.
+    destruct H ; subst. repeat rewrite n_imp_subformLF_dist_app. simpl. repeat rewrite count_occ_app in Heqn.
+    repeat rewrite replace_app. simpl. simpl in Heqn. destruct (eq_dec_form (A --> B) (A --> B)). 2: exfalso ; auto.
+    assert (n = count_occ eq_dec_form (x ++ x0) (A --> B)). repeat rewrite count_occ_app ; lia.
+    apply IHn in H. repeat rewrite replace_app in H. simpl in H. repeat rewrite n_imp_subformLF_dist_app.
+    simpl. repeat rewrite n_imp_subformLF_dist_app in H. simpl in H.
+    assert ((n_imp_subformLF (replace (A --> B) B x) + (n_imp_subformF B + n_imp_subformLF (replace (A --> B) B x0)))%nat =
+    (n_imp_subformF B + ((n_imp_subformLF (replace (A --> B) B x) + n_imp_subformLF (replace (A --> B) B x0))))%nat). lia.
+    rewrite H0. clear H0. rewrite H. simpl.
+    assert ((n_imp_subformLF x + S (n_imp_subformF A + n_imp_subformF B + n_imp_subformLF x0) - S (n_imp_subformF A + n * S (n_imp_subformF A)))%nat =
+    ((n_imp_subformLF x + n_imp_subformF A + n_imp_subformF B + n_imp_subformLF x0) - (n_imp_subformF A + n * S (n_imp_subformF A)))%nat).
+    lia. rewrite H0. clear H0. rewrite Nat.sub_add_distr.
+    assert ((n * S (n_imp_subformF A))%nat <= (n_imp_subformLF x + n_imp_subformLF x0)%nat).
+    assert (n = (count_occ eq_dec_form x (A --> B) + (count_occ eq_dec_form x0 (A --> B)))%nat). lia.
+    rewrite H0. pose (count_occ_n_imp_subformLF (x ++ x0) A B). rewrite n_imp_subformLF_dist_app in l.
+    rewrite count_occ_app in l. lia. lia.
+  Qed.
+ +
+  Lemma univ_gen_ext_more_occ : forall l0 l1 A, univ_gen_ext (fun x : MPropF => x = A) l0 l1 ->
+          (count_occ eq_dec_form l0 A) <= (count_occ eq_dec_form l1 A).
+  Proof.
+  intros. induction X ; simpl ; auto ; subst.
+  - destruct (eq_dec_form x A) ; subst ; lia.
+  - destruct (eq_dec_form A A) ; auto.
+  Qed.
+ +
+  Lemma univ_gen_ext_n_imp_subform : forall l0 l1 A, univ_gen_ext (fun x : MPropF => x = A) l0 l1->
+                 (n_imp_subformLF l1 = (n_imp_subformLF l0 + (n_imp_subformF A * ((count_occ eq_dec_form l1 A) - (count_occ eq_dec_form l0 A))))%nat).
+  Proof.
+  intros. induction X ; simpl ; auto ; subst.
+  - destruct (eq_dec_form x A) ; subst ; lia.
+  - destruct (eq_dec_form A A). 2: exfalso ; auto. rewrite IHX. apply univ_gen_ext_more_occ in X.
+    assert ((S (count_occ eq_dec_form le A) - count_occ eq_dec_form l A)%nat = S ((count_occ eq_dec_form le A) - count_occ eq_dec_form l A)).
+    lia. rewrite H. lia.
+  Qed.
+ +
+  Lemma n_imp_subformS_ImpR_mult : forall x Γ0 Γ1 Δ0 Δ1 A B,
+                              (univ_gen_ext (fun x : MPropF => x = A) (Γ0 ++ A :: Γ1) x) ->
+          ((count_occ eq_dec_form (Δ0 ++ B :: Δ1) (A --> B) + count_occ eq_dec_form (Γ0 ++ A :: Γ1) A)%nat = count_occ eq_dec_form x A) ->
+          (n_imp_subformS (x, replace (A --> B) B (Δ0 ++ B :: Δ1)) < n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)).
+  Proof.
+  intros. remember (count_occ eq_dec_form (Δ0 ++ B :: Δ1) (A --> B)) as n. revert H. revert Heqn. revert X.
+  generalize dependent B. generalize dependent A. generalize dependent Δ1. generalize dependent Δ0.
+  generalize dependent Γ1. generalize dependent Γ0. generalize dependent x. induction n.
+  - simpl. intros. symmetry in Heqn. rewrite <- count_occ_not_In in Heqn. rewrite notin_replace ; auto.
+    repeat rewrite count_occ_app in H. simpl in H. destruct (eq_dec_form A A). 2: exfalso ; auto.
+    unfold n_imp_subformS ; simpl. repeat rewrite n_imp_subformLF_dist_app ; simpl.
+    assert (n_imp_subformLF x = (n_imp_subformLF Γ0 + n_imp_subformLF Γ1 + n_imp_subformF A)%nat).
+    pose (univ_gen_ext_n_imp_subform _ _ _ X). rewrite e0. repeat rewrite count_occ_app. simpl.
+    destruct (eq_dec_form A A). 2: exfalso ; auto. repeat rewrite n_imp_subformLF_dist_app ; simpl. lia.
+    lia.
+  - intros. repeat rewrite replace_app. simpl. repeat rewrite count_occ_app in H. simpl in H. destruct (eq_dec_form A A). 2: exfalso ; auto.
+    destruct (eq_dec_form (A --> B) B). exfalso. assert (length_form (A --> B) = length_form B).
+    rewrite e0 ; auto. simpl in H0 ; lia. repeat rewrite count_occ_app in Heqn. simpl in Heqn.
+    destruct (eq_dec_form B (A --> B)). exfalso. assert (length_form (A --> B) = length_form B).
+    rewrite <- e0 ; auto. simpl in H0 ; lia.
+    unfold n_imp_subformS ; simpl. repeat rewrite n_imp_subformLF_dist_app ; simpl.
+    assert (n_imp_subformLF x = (n_imp_subformLF Γ0 + n_imp_subformLF Γ1 + (n_imp_subformF A * S (S n)))%nat).
+    pose (univ_gen_ext_n_imp_subform _ _ _ X). rewrite e0. repeat rewrite count_occ_app. simpl.
+    destruct (eq_dec_form A A). 2: exfalso ; auto. repeat rewrite n_imp_subformLF_dist_app ; simpl. lia.
+    rewrite H0.
+    pose (n_imp_subformLF_replace Δ0 A B). rewrite e0. clear e0.
+    pose (n_imp_subformLF_replace Δ1 A B). rewrite e0. clear e0.
+    pose (count_occ_n_imp_subformLF Δ0 A B).
+    pose (count_occ_n_imp_subformLF Δ1 A B). lia.
+Qed.
+ +
+  (* This lemma is crucial. *)
+ +
+  Lemma mult_ImpR : forall s0 s1 A B,
+          InT s1 (Canopy (repeat A (count_occ eq_dec_form (snd s0) (A --> B)) ++ (fst s0), replace (A --> B) B (snd s0))) ->
+          InT s1 (Canopy s0).
+  Proof.
+  intros s0 s1 A B. remember (count_occ eq_dec_form (snd s0) (A --> B)) as n. revert Heqn. generalize dependent B.
+  generalize dependent A. generalize dependent s1. generalize dependent s0. induction n ; simpl ; intros.
+  - symmetry in Heqn. rewrite <- count_occ_not_In in Heqn. rewrite notin_replace in H ; auto. destruct s0 ; auto.
+  - assert (count_occ eq_dec_form (snd s0) (A --> B) > 0). lia. apply count_occ_In in H0. destruct s0. simpl in H0.
+    simpl in H. simpl in Heqn. apply In_InT in H0. apply InT_split in H0. destruct H0. destruct s ; subst.
+    repeat rewrite count_occ_app in Heqn. simpl in Heqn. repeat rewrite replace_app in H.
+    simpl in H. destruct (eq_dec_form (A --> B) (A --> B)). 2: exfalso ; auto.
+    assert (n = count_occ eq_dec_form (x ++ x0) (A --> B)). repeat rewrite count_occ_app ; lia.
+    pose (IHn (A :: l, x ++ B :: x0) s1 A B). simpl in i.
+    repeat rewrite count_occ_app in i. simpl in i. repeat rewrite replace_app in i.
+    simpl in i. destruct (eq_dec_form B (A --> B)). exfalso. assert (length_form (A --> B) = length_form B). rewrite <- e0 ; auto.
+    simpl in H1 ; lia. destruct (eq_dec_form (A --> B) B). exfalso. assert (length_form (A --> B) = length_form B). rewrite e0 ; auto.
+    simpl in H1 ; lia. repeat rewrite count_occ_app in H0. pose (i H0).
+    assert (repeat A n ++ A :: l = A :: repeat A n ++ l). assert (repeat A n ++ A :: l = (repeat A n ++ [A]) ++ l).
+    rewrite <- app_assoc. auto. rewrite H1. rewrite <- repeat_cons. simpl ; auto. rewrite H1 in i0. apply i0 in H.
+    apply ImpRule_Canopy with (prems:=[(A :: l, x ++ B :: x0)]) (prem:=(A :: l, x ++ B :: x0)) ; auto.
+     left. epose (ImpRRule_I _ _ []). simpl in i1 ; apply i1. apply InT_eq.
+  Qed.
+ +
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_Canopy_nodupseq_perm.html b/GL.Interpolation.UIGL_Canopy_nodupseq_perm.html new file mode 100644 index 0000000..2c5c1e3 --- /dev/null +++ b/GL.Interpolation.UIGL_Canopy_nodupseq_perm.html @@ -0,0 +1,405 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_Canopy_nodupseq_perm

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+ +
+Require Import general_export.
+ +
+Require Import GLS_export.
+ +
+Require Import UIGL_Def_measure.
+Require Import UIGL_Canopy.
+Require Import UIGL_irred_short.
+Require Import UIGL_braga.
+Require Import UIGL_LexSeq.
+Require Import UIGL_PermutationT.
+Require Import UIGL_PermutationTS.
+Require Import UIGL_nodupseq.
+Require Import UIGL_Canopy_ImpR.
+Require Import UIGL_Canopy_ImpL.
+ +
+Lemma nodup_length : forall l0 l1, length (nodup eq_dec_form l0) <= length (nodup eq_dec_form (l1 ++ l0)).
+Proof.
+intros l0 l1. revert l0. induction l1 ; intros ; simpl ; auto.
+destruct (in_dec eq_dec_form a (l1 ++ l0)).
+- apply in_app_or in i. destruct i ; auto.
+- simpl. pose (IHl1 l0). lia.
+Qed.
+ +
+Lemma repeat_n_imp_subformLF: forall (n : nat) A, n_imp_subformLF (repeat A n) = (mult n (n_imp_subformF A)).
+Proof.
+induction n ; simpl ; intros ; auto.
+Qed.
+ +
+Lemma replace_n_imp_subformLF: forall l A B,
+    plus (mult (S (n_imp_subformF A)) (count_occ eq_dec_form l (A --> B))) (n_imp_subformLF (replace (A --> B) B l)) = n_imp_subformLF l.
+Proof.
+induction l ; simpl ; intros ; auto. lia.
+destruct (eq_dec_form a (A --> B)) ; subst ; simpl. destruct (eq_dec_form (A --> B) (A --> B)) ; simpl. pose (IHl A B). lia.
+exfalso ; apply n ; auto. destruct (eq_dec_form (A --> B) a) ; simpl. subst. exfalso ; apply n ; auto.
+pose (IHl A B). lia.
+Qed.
+ +
+Lemma repeat_S : forall n (A: MPropF)A, 0 < n -> (A :: (@repeat MPropF A (Init.Nat.pred n))) = repeat A n.
+Proof.
+induction n ; simpl ; intros ; auto. inversion H.
+Qed.
+ +
+Lemma Permutation_replace_repeat : forall l A B, Permutation (replace A B l) ((repeat B (count_occ eq_dec_form l A)) ++ remove eq_dec_form A l).
+Proof.
+induction l ; intros ; simpl ; auto. destruct (eq_dec_form A a) ; subst. destruct (eq_dec_form a a) ; subst.
+pose (IHl a B). simpl. apply perm_skip ; auto. exfalso ; apply n ; auto.
+destruct (eq_dec_form a A) ; subst ; simpl. exfalso ; apply n ; auto.
+pose (IHl a B). apply Permutation_cons_app ; auto.
+Qed.
+ +
+Lemma Permutation_repeat_extract : forall n l0 l1 l2 A B,
+  (0 < n) ->
+  ((count_occ eq_dec_form l0 A) = n) ->
+  (In A (l1 ++ B :: l2) -> False) ->
+  Permutation (remove eq_dec_form A l0) (l1 ++ l2) ->
+  Permutation (repeat B n ++ remove eq_dec_form A l0) ((repeat B (Init.Nat.pred n)) ++ l1 ++ B :: l2).
+Proof.
+induction n ; simpl ; auto.
+- intros. inversion H.
+- induction l0 ; simpl ; intros ; auto. exfalso ; lia.
+  destruct (eq_dec_form a A) ; subst.
+  + destruct (eq_dec_form A A) ; subst. inversion H0 ; subst.
+     apply perm_trans with (l':=(B :: repeat B (count_occ eq_dec_form l0 A) ++ l1 ++ l2)). apply perm_skip.
+     apply Permutation_app ; auto. pose (@Permutation_middle _ (repeat B (count_occ eq_dec_form l0 A) ++ l1) l2 B).
+     repeat rewrite <- app_assoc in p ; simpl in p. auto.
+     apply perm_trans with (l':=(B :: repeat B n ++ l1 ++ l2)). apply perm_skip.
+     apply Permutation_app ; auto. pose (@Permutation_middle _ (repeat B n ++ l1) l2 B).
+     repeat rewrite <- app_assoc in p ; simpl in p. auto.
+  + destruct (eq_dec_form A a) ; subst. exfalso ; apply n0 ; auto.
+     apply perm_trans with (l':=(B :: repeat B n ++ l1 ++ l2)). apply perm_skip.
+     apply Permutation_app ; auto. pose (@Permutation_middle _ (repeat B n ++ l1) l2 B).
+     repeat rewrite <- app_assoc in p ; simpl in p. auto.
+Qed.
+ +
+Lemma Permutation_remove : forall l0 l1 A, Permutation l0 l1 -> Permutation (remove eq_dec_form A l0) (remove eq_dec_form A l1).
+Proof.
+induction 1 ; simpl ; auto.
+- destruct (eq_dec_form A x) ; subst ; auto.
+- destruct (eq_dec_form A y) ; subst ; auto. destruct (eq_dec_form A x) ; subst ; auto.
+  apply perm_swap.
+- apply (perm_trans IHPermutation1 IHPermutation2).
+Qed.
+ +
+Lemma count_occ_n_imp_subformLF : forall l A, count_occ eq_dec_form l A * n_imp_subformF A <= n_imp_subformLF l.
+Proof.
+induction l ; simpl ; auto.
+intros. destruct (eq_dec_form a A) ; subst ; auto. pose (IHl A). lia.
+pose (IHl A) ; lia.
+Qed.
+ +
+Lemma remove_n_imp_subformLF : forall l A,
+        n_imp_subformLF (remove eq_dec_form A l) = minus (n_imp_subformLF l) (mult (count_occ eq_dec_form l A) (n_imp_subformF A)).
+Proof.
+induction l ; simpl ; auto ; intros.
+destruct (eq_dec_form A a) ; subst ; auto. destruct (eq_dec_form a a) ; subst ; auto.
+assert (n_imp_subformLF (remove eq_dec_form a l) = n_imp_subformLF l - count_occ eq_dec_form l a * n_imp_subformF a).
+apply IHl. destruct (count_occ eq_dec_form l a) ; lia. exfalso ; auto.
+destruct (eq_dec_form a A). exfalso ; auto.
+pose (IHl A). simpl. rewrite e.
+assert (count_occ eq_dec_form l A * n_imp_subformF A <= n_imp_subformLF l). apply count_occ_n_imp_subformLF.
+lia.
+Qed.
+ +
+Lemma remove_n_imp_subformLF_decomp : forall l A,
+        n_imp_subformLF l = plus (n_imp_subformLF (remove eq_dec_form A l)) (mult (count_occ eq_dec_form l A) (n_imp_subformF A)).
+Proof.
+induction l ; simpl ; intros ; auto.
+destruct (eq_dec_form A a) ; subst ; auto. destruct (eq_dec_form a a) ; subst ; auto. pose (IHl a).
+lia. exfalso ; auto. simpl. destruct (eq_dec_form a A). exfalso ; auto. simpl. pose (IHl A). lia.
+Qed.
+ +
+Lemma Permutation_replace : forall l0 l1 A B, Permutation l0 l1 -> Permutation (replace A B l0) (replace A B l1).
+Proof. intros. apply Permutation_map. assumption. Qed.
+ +
+Lemma Canopy_nodupseq_perm_gen : forall s0 s1 leaf1,
+        (existsT2 l0 l1, (PermutationTS s0 (l0 ++ fst s1, l1 ++ snd s1)) * (incl l0 (fst s1)) * (incl l1 (snd s1))) ->
+        (InT leaf1 (Canopy s1)) ->
+        (existsT2 leaf0, InT leaf0 (Canopy s0) * (PermutationTS (nodupseq leaf0) (nodupseq leaf1))).
+Proof.
+  intros s ; induction on s as IH with measure (n_imp_subformS s).
+  intros s1 leaf1 perm InClos. destruct perm. destruct s0. destruct p. destruct p.
+  pose (fold_Canopy _ _ InClos). destruct s0 ; subst ; auto.
+  - exists s. split ; auto. apply Canopy_critical in InClos. apply critical_Seq_InT_Canopy.
+    apply PermutationTS_sym in p. apply (PermutationTS_critic _ _ p). intros A HA ; simpl in HA.
+    apply InClos. apply in_or_app. apply in_app_or in HA ; destruct HA. 1-2: apply in_app_or in H ; destruct H ; auto.
+    split ; apply Permutation_PermutationT ; destruct p ; apply Permutation_PermutationT in p,p0 ; simpl in p,p0 ; unfold nodupseq ; simpl.
+    apply perm_trans with (l':=(nodup eq_dec_form (x ++ fst s1))).
+    apply Permutation_PermutationT ; apply PermutationT_nodupseq ; apply Permutation_PermutationT ; auto.
+    apply (@NoDup_Permutation_bis _ (nodup eq_dec_form (x ++ fst s1)) (nodup eq_dec_form (fst s1))). apply NoDup_nodup.
+    apply nodup_length. intros A HA. apply nodup_In. apply (nodup_In) in HA. apply in_app_or in HA ; destruct HA ; auto.
+    apply perm_trans with (l':=(nodup eq_dec_form (x0 ++ snd s1))).
+    apply Permutation_PermutationT ; apply PermutationT_nodupseq ; apply Permutation_PermutationT ; auto.
+    apply (@NoDup_Permutation_bis _ (nodup eq_dec_form (x0 ++ snd s1)) (nodup eq_dec_form (snd s1))). apply NoDup_nodup.
+    apply nodup_length. intros A HA. apply nodup_In. apply (nodup_In) in HA. apply in_app_or in HA ; destruct HA ; auto.
+  - destruct s0. destruct p0. unfold inv_prems in i1. apply InT_flatten_list_InT_elem in i1. destruct i1.
+    destruct p0. destruct (finite_ImpRules_premises_of_S s1). simpl in i3.
+    apply p0 in i3. destruct i3 ; inversion i3 ; subst.
+    (* x0 is obtained via ImpR. *)
+    + inversion i1 ; subst. 2: inversion H0. simpl in *.
+       assert (InT (A --> B) (snd s)). apply In_InT. destruct p. apply Permutation_PermutationT in p1 ; simpl in p1.
+       apply Permutation_in with (l:=(x0 ++ Δ0 ++ A --> B :: Δ1)). apply Permutation_sym ; auto.
+       apply in_or_app ; right ; apply in_or_app ; right ; simpl ; auto. apply InT_split in H. destruct H. destruct s0.
+       destruct s ; simpl in * ; rewrite e in * ; clear e. inversion p ; simpl in *.
+       destruct (In_dec x0 (A --> B)).
+       * destruct (In_dec (Δ0 ++ Δ1) (A --> B)).
+         -- assert (J1: n_imp_subformS (A :: l, x1 ++ B :: x2) < n_imp_subformS (l, x1 ++ A --> B :: x2)).
+            unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl. lia.
+            pose (IH _ J1 (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) leaf1). simpl in s. destruct s ; simpl ; auto.
+            exists x. clear p0. exists x0. repeat split ; auto ; simpl. apply Permutation_PermutationT.
+            apply perm_trans with (l':=(A :: x ++ Γ0 ++ Γ1)). apply perm_skip. apply Permutation_PermutationT ; auto.
+            pose (Permutation_middle (x ++ Γ0) Γ1 A). repeat rewrite <- app_assoc in p0 ; simpl in p0 ; auto. apply Permutation_PermutationT.
+            apply perm_trans with (l':=(B :: x0 ++ Δ0 ++ Δ1)). apply perm_trans with (l':=(B :: x1 ++ x2)) ; auto.
+            2: apply perm_skip. apply Permutation_sym ; apply Permutation_cons_app ; apply Permutation_refl. apply Permutation_PermutationT in H0.
+            epose (@Permutation_cons_app_inv _ _ (x0 ++ Δ0) Δ1 (A --> B)). repeat rewrite <- app_assoc in p0 ; simpl in p0. apply p0.
+            apply perm_trans with (l':=(x1 ++ A --> B :: x2)) ; auto. apply Permutation_cons_app ; apply Permutation_refl.
+            epose (@Permutation_cons_app _ _ (x0 ++ Δ0) Δ1 B). repeat rewrite <- app_assoc in p0 ; simpl in p0. apply p0 ; apply Permutation_refl.
+            intros C HC. apply in_or_app. apply i0 in HC. simpl. apply in_app_or in HC ; destruct HC ; auto.
+            intros C HC. apply in_or_app ; simpl. pose (i _ HC). apply in_app_or in i6 ; destruct i6 ; auto. inversion H1 ; subst ; auto.
+            apply in_app_or in i5 ; destruct i5 ; auto.
+            destruct p1. exists x4 ; split ; auto. eapply ImpRule_Canopy. left. apply (ImpRRule_I A B [] l x1 x2).
+            simpl. apply InT_eq. auto.
+         -- assert (J1: n_imp_subformS (repeat A (count_occ eq_dec_form (x1 ++ A --> B :: x2) (A --> B)) ++ l, replace (A --> B) B (x1 ++ A --> B :: x2)) < n_imp_subformS (l, x1 ++ A --> B :: x2)).
+            unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl. rewrite repeat_n_imp_subformLF.
+            pose (replace_n_imp_subformLF (x1 ++ A --> B :: x2) A B). repeat rewrite n_imp_subformLF_dist_app in e ; simpl in e. rewrite <- e.
+            assert (0 < count_occ eq_dec_form (x1 ++ A --> B :: x2) (A --> B)). apply count_occ_In. apply in_or_app ; right ; simpl ; auto. lia.
+            pose (IH _ J1 (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) leaf1). simpl in s. destruct s ; simpl ; auto.
+            exists (repeat A (pred (count_occ eq_dec_form (x1 ++ A --> B :: x2) (A --> B))) ++ x). clear p0.
+            exists (repeat B (pred (count_occ eq_dec_form (x1 ++ A --> B :: x2) (A --> B))) ++ (remove eq_dec_form (A --> B) x0)).
+            repeat split ; auto ; simpl. apply Permutation_PermutationT. repeat rewrite <- app_assoc.
+            apply perm_trans with (l':=(repeat A (count_occ eq_dec_form (x1 ++ A --> B :: x2) (A --> B)) ++ x ++ Γ0 ++ Γ1)).
+            apply Permutation_app_head. apply Permutation_PermutationT ; auto.
+            apply perm_trans with (l':=(A :: repeat A (Init.Nat.pred (count_occ eq_dec_form (x1 ++ A --> B :: x2) (A --> B))) ++ x ++ Γ0 ++ Γ1)).
+            assert (A :: repeat A (Init.Nat.pred (count_occ eq_dec_form (x1 ++ A --> B :: x2) (A --> B))) = repeat A (count_occ eq_dec_form (x1 ++ A --> B :: x2) (A --> B))).
+            apply repeat_S ; auto. apply count_occ_In. apply in_or_app ; right ; simpl ; auto.
+            rewrite <- H1. simpl. apply perm_skip. apply Permutation_app_head. apply Permutation_refl.
+            epose (@Permutation_cons_app _ _ (repeat A (Init.Nat.pred (count_occ eq_dec_form (x1 ++ A --> B :: x2) (A --> B))) ++ x ++ Γ0) Γ1 A).
+            repeat rewrite <- app_assoc in p0 ; apply p0 ; clear p0. apply Permutation_refl.
+            apply Permutation_PermutationT. pose (Permutation_replace_repeat (x1 ++ A --> B :: x2) (A --> B) B).
+            apply perm_trans with (l':=(repeat B (count_occ eq_dec_form (x1 ++ A --> B :: x2) (A --> B)) ++ remove eq_dec_form (A --> B) (x1 ++ A --> B :: x2))) ; auto.
+            assert (J20: 0 < count_occ eq_dec_form (x1 ++ A --> B :: x2) (A --> B)). apply count_occ_In. apply in_or_app ; right ; simpl ; auto.
+            assert (J21: (In (A --> B) ((remove eq_dec_form (A --> B) x0 ++ Δ0) ++ B :: Δ1) -> False)).
+            intros. apply in_app_or in H1 ; destruct H1. apply in_app_or in H1 ; destruct H1. apply remove_not_in_anymore in H1 ; auto.
+            apply n ; apply in_or_app ; auto. inversion H1. assert (size B = size (A --> B)). rewrite <- H2 ; auto. simpl in H3 ; lia.
+            apply n ; apply in_or_app ; auto. assert (J43: count_occ eq_dec_form (x1 ++ A --> B :: x2) (A --> B) = count_occ eq_dec_form (x1 ++ A --> B :: x2) (A --> B)) ; auto.
+            pose (Permutation_repeat_extract _ (x1 ++ A --> B :: x2) _ _ (A --> B) B J20 J43 J21).
+            repeat rewrite <- app_assoc ; simpl. repeat rewrite <- app_assoc in p1 ; simpl in p1. apply p1 ; clear p1.
+            assert ((remove eq_dec_form (A --> B) x0 ++ Δ0 ++ Δ1) = (remove eq_dec_form (A --> B) (x0 ++ Δ0 ++ A --> B :: Δ1))).
+            repeat rewrite remove_app. simpl. destruct (eq_dec_form (A --> B) (A --> B)). pose (notin_remove eq_dec_form Δ0).
+            pose (notin_remove eq_dec_form Δ1). rewrite e0. rewrite e1 ; auto. 1-2: intro ; apply n ; apply in_or_app ; auto.
+            exfalso ; apply n0 ; auto. rewrite H1. apply Permutation_remove ; apply Permutation_PermutationT in H0 ; auto.
+            intros C HC. apply in_or_app. apply in_app_or in HC ; destruct HC. right. simpl. apply repeat_spec in H1 ; auto.
+            apply i0 in H1. simpl. apply in_app_or in H1 ; destruct H1 ; auto.
+            intros C HC. apply in_or_app ; simpl. apply in_app_or in HC ; destruct HC. right. apply repeat_spec in H1 ; auto.
+            apply in_remove in H1. destruct H1. pose (i _ H1). apply in_app_or in i5 ; destruct i5 ; auto. inversion H3 ; subst ; auto.
+            exfalso ; auto.
+            destruct p1. exists x4 ; split ; auto. apply (mult_ImpR _ _ A B) ; auto.
+       * assert (J1: n_imp_subformS (A :: l, x1 ++ B :: x2) < n_imp_subformS (l, x1 ++ A --> B :: x2)).
+         unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl. lia.
+         pose (IH _ J1 (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) leaf1). simpl in s. destruct s ; simpl ; auto.
+         exists x. clear p0. exists x0. repeat split ; auto ; simpl. apply Permutation_PermutationT.
+         apply perm_trans with (l':=(A :: x ++ Γ0 ++ Γ1)). apply perm_skip. apply Permutation_PermutationT ; auto.
+         pose (Permutation_middle (x ++ Γ0) Γ1 A). repeat rewrite <- app_assoc in p0 ; simpl in p0 ; auto. apply Permutation_PermutationT.
+         apply perm_trans with (l':=(B :: x0 ++ Δ0 ++ Δ1)). apply perm_trans with (l':=(B :: x1 ++ x2)) ; auto.
+         2: apply perm_skip. apply Permutation_sym ; apply Permutation_cons_app ; apply Permutation_refl. apply Permutation_PermutationT in H0.
+         epose (@Permutation_cons_app_inv _ _ (x0 ++ Δ0) Δ1 (A --> B)). repeat rewrite <- app_assoc in p0 ; simpl in p0. apply p0.
+         apply perm_trans with (l':=(x1 ++ A --> B :: x2)) ; auto. apply Permutation_cons_app ; apply Permutation_refl.
+         epose (@Permutation_cons_app _ _ (x0 ++ Δ0) Δ1 B). repeat rewrite <- app_assoc in p0 ; simpl in p0. apply p0 ; apply Permutation_refl.
+         intros C HC. apply in_or_app. apply i0 in HC. simpl. apply in_app_or in HC ; destruct HC ; auto.
+         intros C HC. apply in_or_app ; simpl. pose (i _ HC). apply in_app_or in i4 ; destruct i4 ; auto. inversion H1 ; subst ; auto.
+         exfalso ; auto.
+         destruct p1. exists x4 ; split ; auto. eapply ImpRule_Canopy. left. apply (ImpRRule_I A B [] l x1 x2).
+         simpl. apply InT_eq. auto.
+    (* x0 is obtained via ImpL. *)
+    + subst. inversion p. simpl in *.
+       assert (InT (A --> B) (fst s)). apply In_InT. apply Permutation_PermutationT in H.
+       apply Permutation_in with (l:=(x ++ Γ0 ++ A --> B :: Γ1)). apply Permutation_sym ; auto.
+       apply in_or_app ; right ; apply in_or_app ; right ; simpl ; auto. apply InT_split in H1. destruct H1. destruct s0.
+       destruct s ; simpl in * ; rewrite e in * ; clear e. inversion i1 ; subst. 2: inversion H2 ; subst ; simpl in *. 3: inversion H3.
+     (* Left premise. *)
+     { destruct (In_dec x (A --> B)).
+       * destruct (In_dec (Γ0 ++ Γ1) (A --> B)).
+         -- assert (J1: n_imp_subformS (x2 ++ x4, A :: l0) < n_imp_subformS (x2 ++ A --> B :: x4, l0)).
+            unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+            pose (IH _ J1 (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) leaf1). simpl in s. destruct s ; simpl ; auto.
+            exists x. clear p0. exists x0. repeat split ; auto ; simpl. 1-2: apply Permutation_PermutationT.
+            pose (@Permutation_app_inv _ x2 x4 (x ++ Γ0) Γ1 (A --> B)). repeat rewrite <- app_assoc in p0.
+            apply p0 ; apply Permutation_PermutationT ; auto.
+            apply perm_trans with (l':=(A :: x0 ++ Δ0 ++ Δ1)). apply perm_skip. apply Permutation_PermutationT ; auto.
+            pose (Permutation_middle (x0 ++ Δ0) Δ1 A). repeat rewrite <- app_assoc in p0 ; simpl in p0 ; auto.
+            intros C HC. apply in_or_app ; simpl. pose (i0 _ HC). apply in_app_or in i6 ; destruct i6 ; auto. inversion H1 ; subst ; auto.
+            apply in_app_or in i5 ; destruct i5 ; auto.
+            intros C HC. apply in_or_app. apply i in HC. simpl. apply in_app_or in HC ; destruct HC ; auto.
+            destruct p1. exists x1 ; split ; auto. eapply ImpRule_Canopy. right. apply (ImpLRule_I A B x2 x4 [] l0).
+            simpl. apply InT_eq. auto.
+         -- assert (J1: n_imp_subformS (remove eq_dec_form (A --> B) (x2 ++ x4), repeat A (count_occ eq_dec_form (x2 ++ A --> B :: x4) (A --> B)) ++ l0) < n_imp_subformS (x2 ++ A --> B :: x4, l0)).
+            unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl. rewrite repeat_n_imp_subformLF.
+            assert (0 < count_occ eq_dec_form (x2 ++ A --> B :: x4) (A --> B)). apply count_occ_In. apply in_or_app ; right ; simpl ; auto.
+            pose (remove_n_imp_subformLF_decomp (x2 ++ A --> B :: x4) (A --> B)). rewrite n_imp_subformLF_dist_app in e ; simpl in e.
+            assert (n_imp_subformLF (remove eq_dec_form (A --> B) (x2 ++ x4)) + (count_occ eq_dec_form (x2 ++ A --> B :: x4) (A --> B) * n_imp_subformF A + n_imp_subformLF l0) <
+            n_imp_subformLF l0 + (n_imp_subformLF x2 + S (n_imp_subformF A + n_imp_subformF B + n_imp_subformLF x4))).
+            rewrite e. repeat rewrite remove_app. simpl. destruct (eq_dec_form (A --> B) (A --> B)). lia. exfalso ; apply n0 ; auto. lia.
+            pose (IH _ J1 (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) leaf1). simpl in s. destruct s ; simpl ; auto.
+            exists (remove eq_dec_form (A --> B) x). clear p0.
+            exists (repeat A (pred (count_occ eq_dec_form (x2 ++ A --> B :: x4) (A --> B))) ++ x0).
+            repeat split ; auto ; simpl. 1-2: apply Permutation_PermutationT.
+            pose (Permutation_remove (x2 ++ x4) (x ++ Γ0 ++ Γ1) (A --> B)).
+            assert (remove eq_dec_form (A --> B) x ++ Γ0 ++ Γ1 = remove eq_dec_form (A --> B) (x ++ Γ0 ++ Γ1)).
+            repeat rewrite remove_app. pose (notin_remove eq_dec_form Γ0). pose (notin_remove eq_dec_form Γ1).
+            rewrite e. rewrite e0 ; auto. 1-2: intro ; apply n ; apply in_or_app ; auto. rewrite H1. apply p0.
+            epose (Permutation_app_inv x2 x4 (x ++ Γ0) Γ1 (A --> B)). repeat rewrite <- app_assoc in p1. apply p1 ; apply Permutation_PermutationT ; auto.
+            apply perm_trans with (l':=((A :: repeat A (Init.Nat.pred (count_occ eq_dec_form (x2 ++ A --> B :: x4) (A --> B))) ++ x0) ++ Δ0 ++ Δ1)).
+            assert (A :: repeat A (Init.Nat.pred (count_occ eq_dec_form (x2 ++ A --> B :: x4) (A --> B))) = repeat A (count_occ eq_dec_form (x2 ++ A --> B :: x4) (A --> B))).
+            remember (count_occ eq_dec_form (x2 ++ A --> B :: x4) (A --> B)) as n' ; destruct n' ; auto ; simpl. exfalso. symmetry in Heqn' ; apply count_occ_not_In in Heqn'.
+            apply Heqn'. apply in_or_app ; simpl ; auto. rewrite <- H1. simpl. apply perm_skip. repeat rewrite <- app_assoc ; simpl.
+            apply Permutation_app_head ; apply Permutation_PermutationT ; auto.
+            epose (@Permutation_cons_app _ ((repeat A (Init.Nat.pred (count_occ eq_dec_form (x2 ++ A --> B :: x4) (A --> B))) ++ x0) ++ Δ0 ++ Δ1)
+            (repeat A (Init.Nat.pred (count_occ eq_dec_form (x2 ++ A --> B :: x4) (A --> B))) ++ x0 ++ Δ0) Δ1 A).
+            simpl ; repeat rewrite <- app_assoc ; simpl in p0 ; repeat rewrite <- app_assoc in p0. apply p0 ; clear p0. apply Permutation_refl.
+            intros C HC. apply in_or_app. apply in_remove in HC. destruct HC. apply i0 in H1. apply in_app_or in H1 ; destruct H1 ; auto.
+            inversion H1 ; [ exfalso ; subst ; apply H2 ; auto | auto].
+            intros C HC. apply in_or_app ; simpl. apply in_app_or in HC ; destruct HC. right. apply repeat_spec in H1 ; auto.
+            pose (i _ H1). apply in_app_or in i5 ; destruct i5 ; auto.
+            destruct p1. exists x1 ; split ; auto. apply (mult_ImpL_L _ _ A B) ; simpl ; auto.
+            assert (remove eq_dec_form (A --> B) (x2 ++ A --> B :: x4) = remove eq_dec_form (A --> B) (x2 ++ x4)).
+            repeat rewrite remove_app. simpl. destruct (eq_dec_form (A --> B) (A --> B)) ; auto. exfalso ; auto. rewrite H1 ; auto.
+       * assert (J1: n_imp_subformS (x2 ++ x4, A :: l0) < n_imp_subformS (x2 ++ A --> B :: x4, l0)).
+         unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl. lia.
+         pose (IH _ J1 (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) leaf1). simpl in s. destruct s ; simpl ; auto.
+        exists x. clear p0. exists x0. repeat split ; auto ; simpl. 1-2: apply Permutation_PermutationT.
+        pose (@Permutation_app_inv _ x2 x4 (x ++ Γ0) Γ1 (A --> B)). repeat rewrite <- app_assoc in p0.
+        apply p0 ; apply Permutation_PermutationT ; auto.
+        apply perm_trans with (l':=(A :: x0 ++ Δ0 ++ Δ1)). apply perm_skip. apply Permutation_PermutationT ; auto.
+        pose (Permutation_middle (x0 ++ Δ0) Δ1 A). repeat rewrite <- app_assoc in p0 ; simpl in p0 ; auto.
+        intros C HC. apply in_or_app ; simpl. pose (i0 _ HC). apply in_app_or in i4 ; destruct i4 ; auto. inversion H1 ; subst ; auto.
+        exfalso ; auto.
+        intros C HC. apply in_or_app. apply i in HC. simpl. apply in_app_or in HC ; destruct HC ; auto.
+        destruct p1. exists x1 ; split ; auto. eapply ImpRule_Canopy. right. apply (ImpLRule_I A B x2 x4 [] l0).
+        simpl. apply InT_eq. auto. }
+     (* Right premise. *)
+     { destruct (In_dec x (A --> B)).
+       * destruct (In_dec (Γ0 ++ Γ1) (A --> B)).
+         -- assert (J1: n_imp_subformS (x2 ++ B :: x4, l0) < n_imp_subformS (x2 ++ A --> B :: x4, l0)).
+            unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+            pose (IH _ J1 (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) leaf1). simpl in s. destruct s ; simpl ; auto.
+            exists x. clear p0. exists x0. repeat split ; auto ; simpl. apply Permutation_PermutationT.
+            pose (@Permutation_app_inv _ x2 x4 (x ++ Γ0) Γ1 (A --> B)). repeat rewrite <- app_assoc in p0.
+            pose (Permutation_elt x2 x4 (x ++ Γ0) Γ1 B). repeat rewrite <- app_assoc in p1. apply p1.
+            apply p0. apply Permutation_PermutationT ; auto.
+            intros C HC. apply in_or_app ; simpl. pose (i0 _ HC). apply in_app_or in i6 ; destruct i6 ; auto. inversion H1 ; subst ; auto.
+            apply in_app_or in i5 ; destruct i5 ; auto.
+            destruct p1. exists x1 ; split ; auto. eapply ImpRule_Canopy. right. apply (ImpLRule_I A B x2 x4 [] l0).
+            simpl. apply InT_cons ; apply InT_eq. auto.
+         -- assert (J1: n_imp_subformS (replace (A --> B) B (x2 ++ A --> B :: x4), l0) < n_imp_subformS (x2 ++ A --> B :: x4, l0)).
+            unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl.
+            pose (replace_n_imp_subformLF (x2 ++ A --> B :: x4) A B). repeat rewrite n_imp_subformLF_dist_app in e. simpl in e.
+            repeat rewrite replace_app. simpl. repeat rewrite replace_app in e. simpl in e. destruct (eq_dec_form (A --> B) (A --> B)).
+            2: exfalso ; auto.
+            assert (0 < count_occ eq_dec_form (x2 ++ A --> B :: x4) (A --> B)). apply count_occ_In. apply in_or_app ; right ; simpl ; auto.
+            lia.
+            pose (IH _ J1 (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) leaf1). simpl in s. destruct s ; simpl ; auto.
+            exists (replace (A --> B) B x). clear p0.
+            exists x0.
+            repeat split ; auto ; simpl. apply Permutation_PermutationT.
+            pose (Permutation_replace (x2 ++ A --> B :: x4) (x ++ Γ0 ++ A --> B :: Γ1) (A --> B) B).
+            assert (replace (A --> B) B x ++ Γ0 ++ B :: Γ1 = replace (A --> B) B (x ++ Γ0 ++ A --> B :: Γ1)).
+            repeat rewrite replace_app. simpl. destruct (eq_dec_form (A --> B) (A --> B)) ; auto. 2: exfalso ; auto.
+            pose (notin_replace Γ0). pose (notin_replace Γ1). rewrite e0. rewrite e1. auto.
+            1-2: intro ; apply n ; apply in_or_app ; auto. rewrite H1. apply p0 ; apply Permutation_PermutationT ; auto.
+            intros C HC. apply in_or_app. apply in_replace in HC. destruct HC. simpl ; destruct H1 ; auto.
+            apply i0 in H1. apply in_app_or in H1 ; destruct H1 ; auto.
+            inversion H1 ; [ exfalso ; subst ; auto | auto]. intro. assert (size (A --> B) = size B). rewrite H1 ; auto. simpl in H3 ; lia.
+            destruct p1. exists x1 ; split ; auto. apply (mult_ImpL_R _ _ A B) ; simpl ; auto.
+       * assert (J1: n_imp_subformS (x2 ++ B :: x4, l0) < n_imp_subformS (x2 ++ A --> B :: x4, l0)).
+         unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl. lia.
+         pose (IH _ J1 (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) leaf1). simpl in s. destruct s ; simpl ; auto.
+        exists x. clear p0. exists x0. repeat split ; auto ; simpl. apply Permutation_PermutationT.
+        pose (@Permutation_app_inv _ x2 x4 (x ++ Γ0) Γ1 (A --> B)). repeat rewrite <- app_assoc in p0.
+        pose (Permutation_elt x2 x4 (x ++ Γ0) Γ1 B). repeat rewrite <- app_assoc in p1. apply p1.
+        apply p0. apply Permutation_PermutationT ; auto.
+        intros C HC. apply in_or_app ; simpl. pose (i0 _ HC). apply in_app_or in i4 ; destruct i4 ; auto. inversion H1 ; subst ; auto.
+        exfalso ; auto.
+        destruct p1. exists x1 ; split ; auto. eapply ImpRule_Canopy. right. apply (ImpLRule_I A B x2 x4 [] l0).
+        simpl. apply InT_cons ; apply InT_eq. auto. }
+Qed.
+ +
+Lemma Canopy_nodupseq_perm : forall s leaf, InT leaf (Canopy (nodupseq s)) ->
+        (existsT2 s0, InT s0 (Canopy s) * (PermutationTS (nodupseq s0) (nodupseq leaf))).
+Proof.
+intros. pose (Canopy_nodupseq_perm_gen s (nodupseq s) leaf). apply s0 ; auto.
+destruct (nodupseq_id s). destruct p. destruct s1. destruct s1. destruct p0. destruct p0.
+exists x0 ; exists x1 ; repeat split ; auto ; simpl.
+- destruct p. destruct p0. apply Permutation_PermutationT in p,p0. simpl in p0.
+  apply Permutation_PermutationT. apply perm_trans with (l':=(x0 ++ fst x)) ; auto.
+  apply Permutation_app_head ; auto.
+- destruct p. destruct p0. apply Permutation_PermutationT in p2,p1. simpl in p2.
+  apply Permutation_PermutationT. apply perm_trans with (l':=(x1 ++ snd x)) ; auto.
+  apply Permutation_app_head ; auto.
+- intros A HA. destruct s ; simpl in *. destruct p. apply i0 in HA. apply Permutation_PermutationT in p.
+  simpl in p. apply Permutation_in with (l:= fst x) ; auto.
+- intros A HA. destruct s ; simpl in *. destruct p. apply i in HA. apply Permutation_PermutationT in p1.
+  simpl in p1. apply Permutation_in with (l:= snd x) ; auto.
+Qed.
+ +
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_Def_measure.html b/GL.Interpolation.UIGL_Def_measure.html new file mode 100644 index 0000000..9e26c6b --- /dev/null +++ b/GL.Interpolation.UIGL_Def_measure.html @@ -0,0 +1,163 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_Def_measure

+ +
+(* Modification of the following file. *)
+ +
+(**************************************************************)
+(*   Copyright Dominique Larchey-Wendling *                 *)
+(*                                                            *)
+(*                             * Affiliation LORIA -- CNRS  *)
+(**************************************************************)
+(*      This file is distributed under the terms of the       *)
+(*         CeCILL v2 FREER SOFTWARE LICENSE AGREEMENT         *)
+(**************************************************************)
+ +
+Require Import List Arith Wellfounded.
+Import ListNotations.
+ +
+Set Implicit Arguments.
+ +
+Section measure_rect.
+ +
+  Variable (X : Type) (m : X -> nat) (P : X -> Type).
+ +
+  Hypothesis F : forall x, (forall y, m y < m x -> P y) -> P x.
+ +
+  Definition measure_rect x : P x.
+  Proof.
+    cut (Acc (fun x y => m x < m y) x); [ revert x | ].
+    + refine (
+        fix loop x Dx := @F x (fun y Dy => loop y _)
+      ).
+      apply (Acc_inv Dx), Dy.
+    + apply wf_inverse_image with (f := m), lt_wf.
+  Qed.
+ +
+End measure_rect.
+ +
+Tactic Notation "induction" "on" hyp(x) "as" ident(IH) "with" "measure" uconstr(f) :=
+  pattern x; revert x; apply measure_rect with (m := fun x => f); intros x IH.
+ +
+Section lex_wf.
+ +
+  Variable (X : Type) (R : X -> X -> Prop) (Rwf : well_founded R).
+ +
+  Reserved Notation "l '<lex' m" (at level 70). (* for lexicographic product *)
+ +
+  Inductive lex : list X -> list X -> Prop :=
+    | lex_skip x l m : l <lex m -> x::l <lex x::m
+    | lex_cons x y l m : length l = length m -> R x y -> x::l <lex y::m
+  where "l <lex m" := (lex l m).
+ +
+  Fact lex_length l m : l <lex m -> length l = length m.
+  Proof. induction 1; simpl; auto. Qed.
+ +
+  Fact lex_cons_inv l m :
+          l <lex m
+       -> match m with
+            | [] => False
+            | y::m =>
+            match l with
+              | [] => False
+              | x::l => x = y /\ lex l m
+                     \/ R x y /\ length l = length m
+            end
+          end.
+  Proof. inversion 1; auto. Qed.
+ +
+  Theorem lex_wf : well_founded lex.
+  Proof.
+    intros m; induction on m as IHm with measure (length m).
+    destruct m as [ | y m ].
+    + constructor; intros l Hl; apply lex_cons_inv in Hl; easy.
+    + revert m IHm.
+      induction y as [ y IHy' ] using (well_founded_induction Rwf).
+      intros m IHm.
+      assert (Acc lex m) as Hm.
+      1: apply IHm; simpl; auto.
+      assert (forall x l, R x y -> length l = length m -> Acc lex (x::l)) as IHy.
+      1: { intros x l Hx Hl; apply IHy'; auto.
+           intros; apply IHm.
+           simpl in *; rewrite <- Hl; auto. }
+      clear IHy' IHm.
+      revert Hm IHy.
+      induction 1 as [ m Hm IHm ]; intros IHy.
+      constructor; intros l Hl; apply lex_cons_inv in Hl.
+      destruct l as [ | x l ]; try tauto.
+      destruct Hl as [ (-> & Hl) | (Hx & Hl) ].
+      * apply IHm; auto.
+        apply lex_length in Hl as ->; auto.
+      * apply IHy; auto.
+  Qed.
+ +
+  Section lex_rect.
+ +
+    Variable (P : list X -> Type) (HP : forall m, (forall l, lex l m -> P l) -> P m).
+ +
+    Corollary lex_rect m : P m.
+    Proof.
+      induction m as [ m IHm ] using (well_founded_induction_type lex_wf).
+      apply HP; intros; apply IHm. auto.
+    Qed.
+ +
+  End lex_rect.
+ +
+End lex_wf.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_Diam_N_imp_UI.html b/GL.Interpolation.UIGL_Diam_N_imp_UI.html new file mode 100644 index 0000000..175bf6a --- /dev/null +++ b/GL.Interpolation.UIGL_Diam_N_imp_UI.html @@ -0,0 +1,99 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_Diam_N_imp_UI

+ +
+  Require Import List.
+  Export ListNotations.
+  Require Import PeanoNat.
+  Require Import Lia.
+ +
+  Require Import general_export.
+ +
+  Require Import GLS_export.
+ +
+  Require Import UIGL_Def_measure.
+  Require Import UIGL_Canopy.
+  Require Import UIGL_LexSeq.
+  Require Import UIGL_nodupseq.
+  Require Import UIGL_irred_short.
+  Require Import UIGL_braga.
+  Require Import UIGL_UI_prelims.
+  Require Import UIGL_UI_inter.
+  Require Import UIGL_N_imp_UI.
+ +
+  Theorem Diam_rec_UI_imp : forall s p X Y, (is_init s -> False) -> (critical_Seq s) ->
+              GLS_prv (X,
+        Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) -->
+        Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list)) :: Y).
+  Proof.
+  intros.
+  remember (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) as conj1.
+  remember (UI p (XBoxed_list (top_boxes (fst s)), []%list)) as conj2.
+  unfold Diam. unfold Neg.
+  apply derI with (ps:=[((Box (conj1 --> ) --> ) :: X, Box (conj2 --> ) --> :: Y)]).
+  apply ImpR. epose (ImpRRule_I _ _ [] X [] Y). simpl in i. apply i. apply dlCons. 2: apply dlNil.
+  apply derI with (ps:=[(Box (conj2 --> ) :: (Box (conj1 --> ) --> ) :: X, :: Y)]).
+  apply ImpR. epose (ImpRRule_I _ _ [] (Box (conj1 --> ) --> :: X) [] Y). simpl in i. apply i. apply dlCons. 2: apply dlNil.
+  apply derI with (ps:=[([Box (conj2 --> )] ++ X, Box (conj1 --> ) :: :: Y);(Box (conj2 --> ) :: :: X, :: Y)]).
+  apply ImpL. epose (ImpLRule_I _ _ [Box (conj2 --> )] X [] (Bot :: Y)). simpl in i. apply i. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+  2: apply derI with (ps:=[]) ; [apply BotL ; epose (BotLRule_I [Box (conj2 --> )] X _) ; simpl in b ; apply b | apply dlNil].
+  apply derI with (ps:=[(XBoxed_list (Box (conj2 --> ) :: top_boxes X) ++ [Box (conj1 --> )], [conj1 --> ])]).
+  apply GLR. epose (@GLRRule_I _ _ _ []). simpl in g. apply g. 3: apply dlCons. 4: apply dlNil.
+  intro. intros. inversion H1. exists (conj2 --> ) ; rewrite <- H2 ; auto. apply in_top_boxes in H2. destruct H2.
+  destruct s0 ; auto. destruct s0. destruct p0. exists x ; rewrite <- e ; auto.
+  simpl. apply univ_gen_ext_cons. apply top_boxes_nobox_gen_ext. simpl.
+  apply derI with (ps:=[([] ++ conj1 :: conj2 --> :: Box (conj2 --> ) :: XBoxed_list (top_boxes X) ++ [Box (conj1 --> )], [] ++ :: [])]).
+  apply ImpR. apply ImpRRule_I. apply dlCons. 2: apply dlNil. simpl.
+  apply derI with (ps:=[(conj1 :: Box (conj2 --> ) :: XBoxed_list (top_boxes X) ++ [Box (conj1 --> )], [conj2 ; ]);
+  (conj1 :: :: Box (conj2 --> ) :: XBoxed_list (top_boxes X) ++ [Box (conj1 --> )], [])]).
+  apply ImpL. epose (ImpLRule_I _ _ [conj1] _ [] _). simpl in i. apply i. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+  2: apply derI with (ps:=[]) ; [apply BotL ; epose (BotLRule_I [conj1] _ _) ; simpl in b ; apply b | apply dlNil].
+  pose (@GLS_prv_list_wkn_L [conj1] [] [conj2]). simpl in g.
+  pose (@GLS_prv_list_wkn_R (conj1 :: Box (conj2 --> ) :: XBoxed_list (top_boxes X) ++ [Box (conj1 --> )]) [conj2] []). simpl in g0.
+  epose (g0 _ [Bot]). rewrite app_nil_r in g1. apply g1. Unshelve. clear g0.
+  epose (g _ (Box (conj2 --> ) :: XBoxed_list (top_boxes X) ++ [Box (conj1 --> )])).
+  rewrite app_nil_r in g0. apply g0. Unshelve. clear g.
+  apply ImpR_inv with (concl:=([], [conj1 --> conj2])). subst.
+  apply rec_UI_imp ; auto.
+  epose (ImpRRule_I _ _ [] [] [] []). simpl in i. apply i.
+  Qed.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_Diam_UI_imp_N.html b/GL.Interpolation.UIGL_Diam_UI_imp_N.html new file mode 100644 index 0000000..5945d9c --- /dev/null +++ b/GL.Interpolation.UIGL_Diam_UI_imp_N.html @@ -0,0 +1,724 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_Diam_UI_imp_N

+ +
+  Require Import List.
+  Export ListNotations.
+  Require Import PeanoNat.
+  Require Import Lia.
+ +
+  Require Import general_export.
+ +
+  Require Import GLS_export.
+ +
+  Require Import UIGL_Def_measure.
+  Require Import UIGL_Canopy.
+  Require Import UIGL_irred_short.
+  Require Import UIGL_PermutationT.
+  Require Import UIGL_braga.
+  Require Import UIGL_LexSeq.
+  Require Import UIGL_nodupseq.
+  Require Import UIGL_PermutationTS.
+  Require Import UIGL_And_Or_rules.
+  Require Import UIGL_UI_prelims.
+  Require Import UIGL_UI_inter.
+  Require Import UIGL_Diam_UI_imp_N_prelim.
+ +
+  (* Diam UI implies Diam N.  *)
+ +
+  Theorem UI_Diam_rec_imp : forall s p X Y, (is_init s -> False) -> (critical_Seq s) ->
+              GLS_prv (X,
+        Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list)) -->
+        Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) :: Y).
+  Proof.
+  pose (d:=LexSeq_ind (fun (s:Seq) => forall p X Y, (is_init s -> False) -> (critical_Seq s) ->
+              GLS_prv (X, Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list)) -->
+        Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) :: Y))).
+  apply d. clear d. intros s IH.
+  intros.
+  destruct (empty_seq_dec (XBoxed_list (top_boxes (fst s)), []%list)) as [EE | DE].
+  (* (XBoxed_list (top_boxes (fst s)), *)
+  { inversion EE ; subst ; simpl in *. rewrite H2 in *. assert (GUI p ([],[]) Bot). apply GUI_empty_seq ; auto. apply UI_GUI in H1.
+    rewrite H1 in *. eapply derI with [(Diam :: X , _ :: Y)]. apply ImpR. apply (ImpRRule_I _ _ [] _ []).
+    apply dlCons. 2: apply dlNil. apply DiamL_lim with (top_boxes X).
+    apply is_Boxed_list_top_boxes. apply nobox_gen_ext_top_boxes.
+    apply derI with []. apply BotL ; apply (BotLRule_I []). apply dlNil. }
+  (* (XBoxed_list (top_boxes (fst s)), *)
+  { destruct (critical_Seq_dec (XBoxed_list (top_boxes (fst s)), []%list)).
+  (* The sequent (XBoxed_list (top_boxes (fst s)), *)
+  - assert ((Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))) = [nodupseq (XBoxed_list (top_boxes (fst s)), []%list)]).
+    apply critical_nodupseq in c. apply critical_Seq_InT_Canopy in c. apply Id_InT_Canopy in c ; auto.
+    assert (J50: (Canopy (XBoxed_list (top_boxes (fst s)), []%list)) = [(XBoxed_list (top_boxes (fst s)), []%list)]).
+    apply critical_Seq_InT_Canopy in c. apply Id_InT_Canopy in c ; auto.
+    rewrite H1 ; simpl.
+    destruct (dec_init_rules (XBoxed_list (top_boxes (fst s)), []%list)).
+    (* The sequent (XBoxed_list (top_boxes (fst s)), *)
+    * assert (is_init (XBoxed_list (top_boxes (fst s)), []%list)). auto.
+      assert (is_init (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))). pose (is_init_nodupseq (XBoxed_list (top_boxes (fst s)), []%list)) ; destruct p0 ; auto.
+      assert (J0: GUI p (XBoxed_list (top_boxes (fst s)), []%list) (UI p (XBoxed_list (top_boxes (fst s)), []%list))). apply UI_GUI ; auto.
+      pose (@GUI_inv_critic_init p (XBoxed_list (top_boxes (fst s)), []%list) (UI p (XBoxed_list (top_boxes (fst s)), []%list)) J0 c X0). rewrite <- e.
+      unfold N.
+      destruct (N_pwc p s (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))).
+      simpl. pose (GN_inv_init _ g). rewrite e0. unfold Diam. unfold Neg.
+      apply derI with (ps:=[([] ++ Box (x --> ) --> :: X, [] ++ (Box (And x x --> ) --> ) :: Y)]).
+      assert ((X, (Box (x --> ) --> ) --> (Box (And x x --> ) --> ) :: Y) = ([] ++ X, [] ++ (Box (x --> ) --> ) --> (Box (And x x --> ) --> ) :: Y)).
+      auto. rewrite H2. apply ImpR. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+      apply derI with (ps:=[([] ++ Box (And x x --> ) :: Box (x --> ) --> :: X, [] ++ :: Y)]).
+      apply ImpR. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+      apply derI with (ps:=[([Box (And x x --> )] ++ X, [] ++ Box (x --> ) :: :: Y);([Box (And x x --> )] ++ :: X, [] ++ :: Y)]).
+      apply ImpL. apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+      2: apply derI with (ps:=[]) ; [apply BotL ; apply BotLRule_I | apply dlNil].
+      apply derI with (ps:=[(XBoxed_list (Box (And x x --> ) :: top_boxes X) ++ [Box (x --> )], [x --> ])]).
+      apply GLR. apply GLRRule_I. 3: apply dlCons. 4: apply dlNil.
+      intro. intros. inversion H2. exists (And x x --> ) ; rewrite <- H3 ; auto. apply in_top_boxes in H3. destruct H3.
+      destruct s1 ; auto. destruct s1. destruct p0. exists x0 ; rewrite <- e1 ; auto.
+      simpl. apply univ_gen_ext_cons. apply top_boxes_nobox_gen_ext. simpl.
+      apply derI with (ps:=[([] ++ x :: And x x --> :: Box (And x x --> ) :: XBoxed_list (top_boxes X) ++ [Box (x --> )], [] ++ :: [])]).
+      apply ImpR. apply ImpRRule_I. apply dlCons. 2: apply dlNil. simpl.
+      apply derI with (ps:=[([x] ++ Box (And x x --> ) :: XBoxed_list (top_boxes X) ++ [Box (x --> )], [] ++ And x x :: []);
+      ([x] ++ :: Box (And x x --> ) :: XBoxed_list (top_boxes X) ++ [Box (x --> )], [] ++ [])]).
+      apply ImpL. assert ((x :: And x x --> :: Box (And x x --> ) :: XBoxed_list (top_boxes X) ++ [Box (x --> )], []) =
+      ([x] ++ And x x --> :: Box (And x x --> ) :: XBoxed_list (top_boxes X) ++ [Box (x --> )], [] ++ [])).
+      repeat rewrite <- app_assoc ; auto. rewrite H2. apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+      2: apply derI with (ps:=[]) ; [apply BotL ; apply BotLRule_I | apply dlNil].
+      pose (AndR ([x] ++ Box (And x x --> ) :: XBoxed_list (top_boxes X) ++ [Box (x --> )], []) x x). simpl in g0.
+      simpl. apply g0. clear g0.
+      all: assert ((x :: Box (And x x --> ) :: XBoxed_list (top_boxes X) ++ [Box (x --> )], [x; ]) =
+      ([] ++ x :: Box (And x x --> ) :: XBoxed_list (top_boxes X) ++ [Box (x --> )], [] ++ [x; ])) ;
+      auto ; rewrite H2 ; apply Id_all_form.
+  (* The sequent (XBoxed_list (top_boxes (fst s)), *)
+    * (* Massaging UI. *)
+      assert (J: is_init (XBoxed_list (top_boxes (fst s)), []%list) -> False). auto.
+      assert (J40: is_init (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)) -> False). intro ; apply J ; apply is_init_nodupseq ; auto.
+      assert (J0: GUI p (XBoxed_list (top_boxes (fst s)), []%list) (UI p (XBoxed_list (top_boxes (fst s)), []%list))). apply UI_GUI ; auto.
+      assert (J1: Gimap (GUI p) (GLR_prems (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))) (map (UI p) (GLR_prems (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))). apply Gimap_map. intros.
+      apply UI_GUI ; auto.
+      assert (J2: Gimap (GN p (GUI p) (XBoxed_list (top_boxes (fst s)), []%list))
+      (Canopy (nodupseq (XBoxed_list (top_boxes (fst (XBoxed_list (top_boxes (fst s)), @nil MPropF))), []%list)))
+      (map (N p (XBoxed_list (top_boxes (fst s)), []%list)) (Canopy (nodupseq (XBoxed_list (top_boxes (fst (XBoxed_list (top_boxes (fst s)), @nil MPropF))), []%list))))).
+      simpl. apply Gimap_map. intros. apply (N_spec p (XBoxed_list (top_boxes (fst s)), []%list) x).
+ +
+      pose (@GUI_inv_critic_not_init p (XBoxed_list (top_boxes (fst s)), []%list) _ _ _ J0 c DE J J1 J2). rewrite <- e. clear e. simpl.
+      (*
+      assert (H2 : (GLR_prems (nodupseq (XBoxed_list (top_boxes (fst s)), list))). simpl.
+      destruct x ; auto. assert (InT l (l::x)) by apply InT_eq. apply p0 in H2.
+      inversion H2 ; subst. destruct Δ0 ; inversion H6.
+      }
+      rewrite H2. simpl. *)

+ +
+      (* Naming formulas for brevity. *)
+      remember (And (N p s (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))) Top) as conj.
+      remember (Or (Or (list_disj (map Neg (restr_list_prop p (XBoxed_list (top_boxes (fst s)))))) (Or (Diam (list_conj (map (N p (XBoxed_list (top_boxes (fst s)), []%list)) (Canopy (nodupseq (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list))))))))) as disj.
+ +
+       (* Proof-theoretic work. *)
+       apply derI with (ps:=[([] ++ Diam disj :: X, [] ++ Diam conj :: Y)]). apply ImpR.
+       apply ImpRRule_I.
+       apply dlCons. 2: apply dlNil. unfold Diam.
+       apply derI with (ps:=[([] ++ Box (Neg conj) :: Neg (Box (Neg disj)) :: X, [] ++ Bot :: Y)]).
+       apply ImpR. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+       apply derI with (ps:=[([Box (Neg conj)] ++ X, [] ++ Box (Neg disj) :: :: Y);
+       ([Box (Neg conj)] ++ Bot :: X, [] ++ :: Y)]).
+       apply ImpL. apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+       2: apply derI with (ps:=[]) ; [apply BotL ; apply BotLRule_I | apply dlNil].
+       apply derI with (ps:=[(XBoxed_list (Box (Neg conj) :: top_boxes X) ++ [Box (Neg disj)], [Neg disj])]).
+       apply GLR. apply GLRRule_I.
+       intro A. intros H3. inversion H3 as [H4 | H4]. exists (Neg conj) ; rewrite <- H4 ; auto. apply in_top_boxes in H4. destruct H4.
+       destruct s0 ; auto. destruct s0. destruct p0. exists x ; rewrite <- e ; auto.
+       simpl. apply univ_gen_ext_cons. apply top_boxes_nobox_gen_ext. simpl. apply dlCons. 2: apply dlNil.
+       apply derI with (ps:=[([] ++ disj :: Neg conj :: Box (Neg conj) :: XBoxed_list (top_boxes X) ++ [Box (Neg disj)], [] ++ Bot :: [])]).
+       apply ImpR. assert ((Neg conj :: Box (Neg conj) :: XBoxed_list (top_boxes X) ++ [Box (Neg disj)], [Neg disj]) =
+       ([] ++ Neg conj :: Box (Neg conj) :: XBoxed_list (top_boxes X) ++ [Box (Neg disj)], [] ++ [Neg disj])). auto. rewrite H2.
+       apply ImpRRule_I. apply dlCons. 2: apply dlNil. simpl.
+       apply derI with (ps:=[([disj] ++ Box (Neg conj) :: XBoxed_list (top_boxes X) ++ [Box (Neg disj)], [] ++ conj :: []);
+       ([disj] ++ Bot:: Box (Neg conj) :: XBoxed_list (top_boxes X) ++ [Box (Neg disj)], [] ++ [])]).
+       apply ImpL. assert ((disj :: Neg conj :: Box (Neg conj) :: XBoxed_list (top_boxes X) ++ [Box (Neg disj)], []) =
+       ([disj] ++ Neg conj :: Box (Neg conj) :: XBoxed_list (top_boxes X) ++ [Box (Neg disj)], [] ++ [])).
+       repeat rewrite <- app_asoc ; auto. rewrite H2. apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+       2: apply derI with (ps:=[]) ; [apply BotL ; apply BotLRule_I | apply dlNil]. simpl. rewrite Heqconj.
+       pose (AndR (disj :: Box (Neg (And (N p s (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))) Top)) :: XBoxed_list (top_boxes X) ++ [Box (Neg disj)], []) (N p s (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))) Top).
+       simpl in g. apply g. clear g.
+       2: pose (TopR (disj :: Box (Neg (And (N p s (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))) Top)) :: XBoxed_list (top_boxes X) ++ [Box (Neg disj)]) [] [Bot]) ; simpl in g0 ; auto.
+       pose (@GLS_prv_wkn_R (disj :: Box (Neg (And (N p s (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))) Top)) :: XBoxed_list (top_boxes X) ++ [Box (Neg disj)], [N p s (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))])).
+       apply g with (A:=Bot). clear g. subst.
+      2: epose (wkn_RI Bot _ [N p s (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))] []) ; simpl in w ; apply w.
+ +
+       (* Naming LHS. *)
+       remember (Box (Neg (And (N p s (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))) Top)) :: XBoxed_list (top_boxes X) ++ [Box (Neg (Or (Or (list_disj (map Neg (restr_list_prop p (XBoxed_list (top_boxes (fst s))))))
+       (Or (Diam (list_conj (map (N p (XBoxed_list (top_boxes (fst s)), []%list)) (Canopy (nodupseq (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list))))))))))]) as LHS.
+ +
+      destruct (Compare_dec.lt_dec (length (usable_boxes (nodupseq (XBoxed_list (top_boxes (fst s)), [])))) (length (usable_boxes s))).
+      (* The sequent (XBoxed_list (top_boxes (fst s)), *)
+      + remember (N p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))) as N_func.
+         (* Massage N on the right. *)
+         unfold N. unfold N in HeqLHS.
+         destruct (N_pwc p s (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))).
+         simpl. simpl in HeqLHS.
+         assert ((forall (x : Seq) (l m : MPropF), (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x l -> (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x m -> l = m)).
+         intros. subst. auto.
+         assert (J11: Gimap (GUI p) (GLR_prems (XBoxed_list (top_boxes (fst s)), []%list)) (map (UI p) (GLR_prems (XBoxed_list (top_boxes (fst s)), []%list)))).
+         apply Gimap_map. intros. apply UI_GUI ; auto.
+         assert (J12: GUI p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)) (UI p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))). apply UI_GUI ; auto.
+         apply UI_GUI in J12.
+         pose (GN_inv_noinit_lessub p g J40 l (UI_spec p _)). rewrite <- e. rewrite <- e in HeqLHS. clear e.
+         assert (J00: GUI p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)) (UI p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))). apply UI_GUI ; auto.
+         assert (J01: critical_Seq (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))). apply critical_nodupseq in c ; auto.
+         assert (J43: (nodupseq (XBoxed_list (top_boxes (fst s)), @nil MPropF)) <> ([],[])). simpl ; intro. inversion H3.
+         apply nodup_nil in H5. rewrite H5 in DE ; auto.
+         assert (J44: is_init (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)) -> False). intro. apply J. apply is_init_nodupseq ; auto.
+         assert (J45: Gimap (GUI p) (GLR_prems (nodupseq (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))) (map (UI p) (GLR_prems (nodupseq (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))).
+         apply Gimap_map. intros. apply UI_GUI ; auto.
+         assert (J46: Gimap (GN p (GUI p) (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))
+         (Canopy (nodupseq (XBoxed_list (top_boxes (fst (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))), []%list)))
+         (map (N p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))) (Canopy (nodupseq (XBoxed_list (top_boxes (fst (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))), []%list))))).
+         simpl. apply Gimap_map. intros. apply (N_spec p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)) x0).
+         pose (@GUI_inv_critic_not_init p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)) _ _ _ J00 J01 J43 J44 J45 J46). rewrite <- e. clear e. simpl.
+         (* Deal with the first disjuncts. *)
+         epose (OrL (_,_)). apply g0 ; simpl ; clear g0.
+         apply derI with (ps:=[]) ; [ apply BotL ; apply (BotLRule_I []) | apply dlNil].
+         epose (OrL (_,_)). apply g0 ; simpl ; clear g0.
+         epose (OrR (_,_)). apply g0 ; simpl ; clear g0.
+         epose (@GLS_prv_wkn_R (list_disj (map Neg (restr_list_prop p (XBoxed_list (top_boxes (fst s))))) :: LHS,[Or (list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))))) (Or
+         (Diam (list_conj (map (N p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))
+         (Canopy (nodupseq (XBoxed_list (top_boxes (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))), []%list)))))))])).
+         apply g0 with (A:=Bot) ; simpl ; clear g0. 2: eapply (wkn_RI Bot _ []).
+         eapply (list_disj_L _ (_,_)) ; simpl. intros. apply InT_map_iff in H3. destruct H3. destruct p0. rewrite <- e.
+         epose (OrR (_,_)). apply g0 ; simpl ; clear g0.
+         eapply (list_disj_wkn_R _ (_,_) (Neg x0)) ; simpl. apply InT_map_iff. exists x0 ; split ; auto.
+         apply restr_list_prop_nodup in i ; auto.
+         epose (Id_all_form _ [] _ [] _). simpl in d. apply d.
+         epose (OrL (_,_)). apply g0 ; simpl ; clear g0.
+         apply derI with (ps:=[]) ; [ apply BotL ; apply (BotLRule_I []) | apply dlNil].
+         epose (OrR (_,_)). apply g0 ; simpl ; clear g0.
+         epose (@GLS_prv_wkn_R (Diam (list_conj (map (fun s0 : Seq => proj1_sig
+         (N_pwc p (XBoxed_list (top_boxes (fst s)), []%list) s0))
+         (Canopy (nodupseq (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list))))) :: LHS,[Or (list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))))) (Or
+         (Diam (list_conj (map (N p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))
+         (Canopy (nodupseq (XBoxed_list (top_boxes (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))), []%list)))))))])).
+         apply g0 with (A:=Bot) ; simpl ; clear g0. 2: eapply (wkn_RI Bot _ []).
+         epose (OrR (_,_)). apply g0 ; simpl ; clear g0.
+         epose (@GLS_prv_wkn_R (Diam (list_conj (map (fun s0 : Seq => proj1_sig
+         (N_pwc p (XBoxed_list (top_boxes (fst s)), []%list) s0))
+         (Canopy (nodupseq (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list))))) :: LHS,[(Or
+         (Diam (list_conj (map (N p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))
+         (Canopy (nodupseq (XBoxed_list (top_boxes (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))), []%list)))))))])).
+         apply g0 with (A:=list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))))) ; simpl ; clear g0.
+          2: eapply (wkn_RI (list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))))) _ []).
+         epose (OrR (_,_)). apply g0 ; simpl ; clear g0.
+         epose (@GLS_prv_wkn_R (Diam (list_conj (map (fun s0 : Seq => proj1_sig
+         (N_pwc p (XBoxed_list (top_boxes (fst s)), []%list) s0))
+         (Canopy (nodupseq (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list))))) :: LHS,[Diam (list_conj (map (N p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))
+         (Canopy (nodupseq (XBoxed_list (top_boxes (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))), []%list)))))])).
+         apply g0 with (A:=Bot) ; simpl ; clear g0. 2: eapply (wkn_RI Bot _ []).
+ +
+        (* Naming formulas for brevity. *)
+        remember ((list_conj (map (fun s0 : Seq => proj1_sig (N_pwc p(XBoxed_list (top_boxes (fst s)), []%list) s0))
+        (Canopy (nodupseq (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list)))))) as conj1.
+        remember (list_conj
+         (map (N p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))
+            (Canopy (nodupseq (XBoxed_list (top_boxes (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))), []%list))))) as conj2.
+ +
+         (* Proof-theoretic work. *)
+         unfold Diam.
+         apply derI with (ps:=[([] ++ Box (Neg conj2) :: Neg (Box (Neg conj1)) :: LHS, [] ++ Bot :: [])]).
+         apply ImpR. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+         apply derI with (ps:=[([Box (Neg conj2)] ++ LHS, [] ++ Box (Neg conj1) :: :: []);
+         ([Box (Neg conj2)] ++ Bot :: LHS, [] ++ :: [])]).
+         apply ImpL. apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+         2: apply derI with (ps:=[]) ; [apply BotL ; apply BotLRule_I | apply dlNil].
+         apply derI with (ps:=[(XBoxed_list (Box (Neg conj2) :: top_boxes LHS) ++ [Box (Neg conj1)], [Neg conj1])]).
+         apply GLR. apply GLRRule_I.
+         intro. intros. inversion H3. exists (Neg conj2) ; rewrite <- H4 ; auto. apply in_top_boxes in H4. destruct H4.
+         destruct s0 ; auto. destruct s0. destruct p0. exists x0 ; rewrite <- e ; auto.
+         simpl. apply univ_gen_ext_cons. apply top_boxes_nobox_gen_ext. simpl. apply dlCons. 2: apply dlNil.
+         remember (Box (Neg conj2) :: XBoxed_list (top_boxes LHS) ++ [Box (Neg conj1)]) as LHS0.
+         apply derI with (ps:=[([] ++ conj1 :: Neg conj2 :: LHS0, [] ++ Bot :: [])]).
+         apply ImpR. eapply (ImpRRule_I _ _ [] _ []). apply dlCons. 2: apply dlNil. simpl.
+         apply derI with (ps:=[(conj1 :: LHS0, [conj2;]);(conj1 :: Bot :: LHS0, [])]).
+         apply ImpL. eapply (ImpLRule_I _ _ [_] _ []). apply dlCons. 2: apply dlCons. 3: apply dlNil.
+         2: apply derI with (ps:=[]) ; [apply BotL ; eapply (BotLRule_I [_]) | apply dlNil].
+ +
+         (* Deal with the Ns. *)
+         rewrite Heqconj1. rewrite Heqconj2.
+         eapply (list_conj_R _ (_,_)) ; simpl. intros. apply InT_map_iff in H3. destruct H3. destruct p0. rewrite <- e.
+         rewrite <- nodup_top_boxes in i. unfold nodupseq in i ; simpl in i. rewrite nodup_XBoxed_list in i.
+         eapply (list_conj_wkn_L _ (_,_) (N p (XBoxed_list (top_boxes (fst s)), []%list) x0)). apply InT_map_iff. exists x0.
+         destruct ((N_pwc p (XBoxed_list (top_boxes (fst s)), []%list) x0)) ; simpl.
+         split ; auto. subst. pose (@N_spec p (XBoxed_list (top_boxes (fst s)), []%list) x0).
+         eapply (GN_fun0 p _ _ _ _ _ _ g0 g1). simpl.
+ +
+        (* Massage the Ns. *)
+        destruct (dec_init_rules x0).
+        (* The sequents x1 and x0 is initial. *)
+         assert (is_init x0) ; auto.
+         pose (N_spec p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)) x0).
+         pose (GN_inv_init _ g0). rewrite <- e0 ; auto.
+         epose (TopR _ [] [Bot]). simpl in g1 ; apply g1.
+        (* The sequent x is not initial. *)
+         assert (is_init x0 -> False) ; auto.
+         assert (J20: GUI p x0 (UI p x0)). apply UI_GUI ; auto.
+         pose (Canopy_critical _ _ i).
+         destruct (Compare_dec.lt_dec (length (usable_boxes x0)) (length (usable_boxes (XBoxed_list (top_boxes (fst s)), []%list)))).
+         (* The sequent x has less usable boxes than s. *)
+         pose (N_spec p (XBoxed_list (top_boxes (fst s)), []%list) x0).
+         epose (@GN_inv_noinit_lessub _ _ _ _ _ g0 H3 l0 (UI_spec p _)). rewrite <- e0 ; auto.
+         assert (J60: length (usable_boxes x0) < length (usable_boxes (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))).
+         rewrite <- ub_nodupseq ; auto.
+         pose (N_spec p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)) x0).
+         epose (@GN_inv_noinit_lessub _ _ _ _ _ g1 H3). rewrite <- e1 ; auto.
+         epose (Id_all_form _ [] _ [] _). simpl in d. apply d. apply UI_GUI ; auto.
+         (* The sequent x does not have less usable boxes than s. *)
+         pose (N_spec p (XBoxed_list (top_boxes (fst s)), []%list) x0).
+         assert (J61: Gimap (GUI p) (GLR_prems (nodupseq x0)) (map (UI p) (GLR_prems (nodupseq x0)))).
+         apply Gimap_map ; auto. intros ; apply UI_GUI ; auto.
+         epose (@GN_inv_noinit_nolessub _ _ _ _ _ g0 H3 n J61). rewrite <- e0 ; auto.
+         assert (J62: (length (usable_boxes x0) < length (usable_boxes (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))) -> False).
+         rewrite <- ub_nodupseq ; auto.
+         pose (N_spec p (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)) x0).
+         epose (@GN_inv_noinit_nolessub _ _ _ _ _ g1 H3 J62 J61). rewrite <- e1 ; auto.
+         epose (Id_all_form _ [] _ [] _). simpl in d. apply d.
+ +
+      (* The sequent (XBoxed_list (top_boxes (fst s)), *)
+      + remember (N p (XBoxed_list (top_boxes (fst s)), []%list)) as N_func.
+         (* Massage N on the right. *)
+         unfold N. unfold N in HeqLHS. destruct (N_pwc p s (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))).
+         simpl. simpl in HeqLHS.
+         assert ((forall (x : Seq) (l m : MPropF), (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x l -> (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x m -> l = m)).
+         intros. subst. auto.
+         assert (J11: Gimap (GUI p) (GLR_prems (nodupseq (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))) (map (UI p) (GLR_prems (nodupseq (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))).
+         apply Gimap_map. intros. apply UI_GUI ; auto.
+         pose (GN_inv_noinit_nolessub _ g J40 n J11). rewrite <- e. rewrite <- e in HeqLHS. clear e. simpl.
+ +
+        (* (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), *)
+        assert (critical_Seq (nodupseq (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list))).
+        intros A HA ; simpl ; simpl in HA. rewrite app_nil_r in HA. apply nodup_In in HA.
+        pose (In_XBoxed_list _ _ HA). destruct o. left.
+        apply in_top_boxes in H3. destruct H3. destruct s0. destruct s0. destruct p0. exists x0 ; auto.
+        destruct H3. destruct H3. subst. apply c. simpl. rewrite app_nil_r. apply XBoxed_list_In.
+        apply nolessub_In. intro. apply n. rewrite <- ub_nodupseq. auto. auto.
+        pose (i := critical_Seq_InT_Canopy _ H3). apply Id_InT_Canopy in i. rewrite i ; simpl.
+ +
+        (* Treating the disjunction on the right. *)
+        epose (OrR (_,_)). simpl in g0. apply g0 ; clear g0.
+        epose (@GLS_prv_wkn_R (Or (Or (list_disj (map Neg (restr_list_prop p (XBoxed_list (top_boxes (fst s))))))
+        (Or (Diam (And (N_func (nodupseq (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list))) Top)))) :: LHS, [Or (list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))))) ])).
+        apply g0 with (A:=). clear g0.
+        2: eapply (wkn_RI Bot _ []).
+        epose (OrR (_,_)). simpl in g0. apply g0 ; clear g0.
+        pose (@GLS_prv_wkn_R (Or (Or (list_disj (map Neg (restr_list_prop p (XBoxed_list (top_boxes (fst s))))))
+        (Or (Diam (And (N_func (nodupseq (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list))) Top)))) :: LHS, [list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))))])).
+        apply g0 with (A:=). clear g0.
+        2: eapply (wkn_RI Bot _ [list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))))] []).
+ +
+        (* Treating the disjunction on the left. *)
+        epose (OrL (_,_)). simpl in g0. apply g0 ; clear g0.
+        apply derI with (ps:=[]). apply BotL. eapply (BotLRule_I []). apply dlNil.
+        epose (OrL (_,_)). simpl in g0. apply g0 ; clear g0.
+        eapply (list_disj_L _ (_,_)) ; simpl. intros. apply InT_map_iff in H4. destruct H4. destruct p0. rewrite <- e.
+        eapply (list_disj_wkn_R _ (_,_) (Neg x0)) ; simpl. apply InT_map_iff. exists x0 ; split ; auto.
+        apply restr_list_prop_nodup in i0 ; auto.
+        epose (Id_all_form _ [] _ [] _). simpl in d. apply d.
+        epose (OrL (_,_)). apply g0 ; simpl ; clear g0.
+        apply derI with (ps:=[]) ; [ apply BotL ; apply (BotLRule_I []) | apply dlNil].
+ +
+        (* Critical case. *)
+        subst ; simpl. rewrite i. simpl.
+        remember (And (N p (XBoxed_list (top_boxes (fst s)), []%list) (nodupseq (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list))) Top) as conjN.
+        remember [list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))))] as RHS.
+        remember (Box (Neg (And (Or (Or (list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))))) )) Top)) :: XBoxed_list (top_boxes X) ++
+        [Box (Neg (Or (Or (list_disj (map Neg (restr_list_prop p (XBoxed_list (top_boxes (fst s)))))) (Or (Diam conjN)))))]) as LHS.
+        unfold Diam.
+        apply derI with (ps:=[([] ++ LHS, [] ++ (Box (Neg conjN)) :: RHS);([] ++ Bot :: LHS, [] ++ RHS)]).
+        apply ImpL. apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+        2: apply derI with (ps:=[]) ; [apply BotL ; apply BotLRule_I | apply dlNil].
+        apply derI with (ps:=[(XBoxed_list (top_boxes LHS) ++ [Box (Neg conjN)], [Neg conjN])]).
+        apply GLR. apply GLRRule_I.
+        intros A HA. rewrite HeqLHS in HA. inversion HA. symmetry in H4. eexists ; rewrite H4 ; auto. apply in_top_boxes in H4. destruct H4.
+        destruct s0 ; auto. destruct s0. destruct p0. exists x0 ; rewrite <- e ; auto.
+        simpl. apply top_boxes_nobox_gen_ext. apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[([] ++ conjN :: XBoxed_list (top_boxes LHS) ++ [Box (Neg conjN)], [] ++ Bot :: [])]).
+        apply ImpR. assert ((XBoxed_list (top_boxes LHS) ++ [Box (Neg conjN)], [Neg conjN]) =
+        ([] ++ XBoxed_list (top_boxes LHS) ++ [Box (Neg conjN)], [] ++ [Neg conjN])). auto. rewrite H4.
+        apply ImpRRule_I. apply dlCons. 2: apply dlNil. simpl. subst.
+        epose (AndL (_, _)). simpl in g0. apply g0. simpl. clear g0. repeat rewrite top_boxes_distr_app. simpl.
+        repeat rewrite XBox_app_distrib. simpl. repeat rewrite <- app_assoc. simpl.
+        eapply derI with (ps:=[_ ; _]). apply ImpL. epose (ImpLRule_I _ Bot [_ ; _] _ [] [Bot]).
+        simpl in i0. apply i0. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+        2: apply derI with (ps:=[]) ; [apply BotL ; epose (BotLRule_I [_ ; _] _ _) ; simpl in b ; apply b | apply dlNil]. simpl.
+        epose (AndR (_,_)). simpl in g0. apply g0. clear g0. 2: epose (TopR _ [] [Bot]) ; apply g1 ; auto.
+        epose (OrR (_,_)). simpl in g0. apply g0. clear g0.
+ +
+         (* Massaging N on the left. *)
+         unfold N. destruct (N_pwc p (XBoxed_list (top_boxes (fst s)), []%list)
+         (nodupseq (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list))). simpl.
+         assert (J12: Gimap (GUI p) (GLR_prems (nodupseq (nodupseq (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list))))
+         (map (UI p) (GLR_prems (nodupseq (nodupseq (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list)))))).
+         apply Gimap_map. intros. apply UI_GUI ; auto.
+ +
+         assert (J13: length (usable_boxes (nodupseq (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list))) < length (usable_boxes (XBoxed_list (top_boxes (fst s)), []%list)) -> False).
+         subst. intro. apply n. rewrite <- ub_nodupseq. apply ub_stable ; auto. rewrite <- ub_nodupseq in H4 ; auto.
+ +
+         assert (J14: is_init (nodupseq (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list)) -> False).
+         intros. apply J. unfold is_init. right. destruct X0. destruct s0. inversion i0. exfalso. destruct Δ0 ; inversion H6.
+         inversion i0. destruct Δ0 ; inversion H6. inversion b. subst.
+         assert (InT Bot (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))))).
+         apply In_InT. rewrite <- nodup_In. rewrite <- H4. apply in_or_app ; right ; apply in_eq.
+         assert (In Bot (XBoxed_list (top_boxes (fst s)))).
+         apply InT_In in H5. apply In_XBoxed_list in H5. destruct H5. exfalso. apply in_top_boxes in H5.
+         destruct H5. destruct s0. destruct s0. destruct p0 ; subst. inversion e. destruct H5.
+         destruct H5. subst. apply nolessub_In in H5 ; auto. apply XBoxed_list_In ; auto.
+         rewrite <- ub_nodupseq in n ; auto. apply In_InT in H6. apply InT_split in H6.
+         destruct H6. destruct s0. rewrite e. apply BotLRule_I.
+ +
+         pose (GN_inv_noinit_nolessub _ g0 J14 J13 J12). rewrite <- e. simpl.
+ +
+         (* Final proof-theoretic work. *)
+         epose (OrL (_,_)). simpl in g1. apply g1 ; clear g1.
+         apply derI with (ps:=[]). apply BotL. epose (BotLRule_I []). simpl in b ; auto. apply dlNil.
+         epose (OrL (_,_)). simpl in g1. apply g1 ; clear g1.
+         epose (@GLS_prv_wkn_R (list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))))))) :: Top
+         :: Box (Neg (And (Or (Or (list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))))) )) Top)) :: XBoxed_list (top_boxes (XBoxed_list (top_boxes X))) ++
+         [Neg (Or (Or (list_disj (map Neg (restr_list_prop p (XBoxed_list (top_boxes (fst s)))))) (Or (Diam (And (Or (Or (list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s))))))))) )) Top)))));
+         Box (Neg (Or (Or (list_disj (map Neg (restr_list_prop p (XBoxed_list (top_boxes (fst s)))))) (Or (Diam (And (Or (Or (list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s))))))))) )) Top))))));
+         Box (Neg (And (Or (Or (list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s))))))))) )) Top))], [Or (list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (XBoxed_list (top_boxes (fst s))))))) ; ])).
+         apply g1 with (A:=Bot). clear g1. clear e.
+         epose (OrR (_,[Bot])). simpl in g1. apply g1. clear g1.
+         epose (list_disj_L _ (_,_)). simpl in g1. apply g1. clear g1. intros.
+         epose (list_disj_wkn_R _ (_,_) A). apply g1. clear g1. apply InT_map_iff. apply InT_map_iff in H4. destruct H4.
+         destruct p0. subst. exists x1 ; split ; auto. apply restr_list_prop_nodup.
+         pose (restr_list_prop_nodup (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s))))) x1 p). destruct p0. apply i1 in i0.
+         unfold restr_list_prop. unfold restr_list_prop in i0. apply In_InT. apply InT_In in i0.
+         apply in_remove in i0. destruct i0. apply in_in_remove ; auto. apply In_list_prop_LF in H4.
+         destruct H4. destruct s0. subst. apply In_list_In_list_prop_LF ; auto. apply In_XBoxed_list in i0.
+         destruct i0. exfalso. apply in_top_boxes in H4. destruct H4. destruct s0. destruct s0. destruct p0. inversion e.
+         destruct H4. destruct H4. subst. apply nolessub_In in H4 ; auto. apply XBoxed_list_In ; auto.
+         rewrite <- ub_nodupseq in n ; auto.
+         simpl. clear g1. epose (Id_all_form A [] _ []). simpl in d. apply d.
+         epose (wkn_RI Bot _ []). simpl in w. apply w.
+         apply derI with (ps:=[]). apply BotL. epose (BotLRule_I []). simpl in b. auto. apply dlNil.
+  (* The sequent (XBoxed_list (top_boxes (fst s)), *)
+  - (* First, we massage UI. *)
+    assert ((GLR_prems (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))) = nil).
+    unfold GLR_prems. destruct (finite_GLR_premises_of_S (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))). simpl.
+    destruct x ; auto. assert (InT l (l::x)). apply InT_eq. apply p0 in H1.
+    inversion H1 ; subst. destruct Δ0 ; inversion H5.
+    assert (J0: GUI p (XBoxed_list (top_boxes (fst s)), []%list) (UI p (XBoxed_list (top_boxes (fst s)), []%list))). apply UI_GUI ; auto.
+    assert (J1: Gimap (GUI p) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))) (map (UI p) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))). apply Gimap_map. intros.
+    apply UI_GUI ; auto.
+    pose (@GUI_inv_not_critic p (XBoxed_list (top_boxes (fst s)), []%list) (UI p (XBoxed_list (top_boxes (fst s)), []%list)) _ J0 f J1). rewrite <- e. clear e.
+ +
+    (* Proof theoretic work on the implication and diamonds. *)
+    remember (list_conj (map (UI p) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) as conj1.
+    remember (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) as conj2.
+    apply derI with (ps:=[([] ++ Diam conj1 :: X, [] ++ Diam conj2 :: Y)]). apply ImpR. apply ImpRRule_I.
+    apply dlCons. 2: apply dlNil. unfold Diam.
+    apply derI with (ps:=[([] ++ Box (Neg conj2) :: Neg (Box (Neg conj1)) :: X, [] ++ Bot :: Y)]).
+    apply ImpR. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+    apply derI with (ps:=[([Box (Neg conj2)] ++ X, [] ++ Box (Neg conj1) :: :: Y);
+    ([Box (Neg conj2)] ++ Bot :: X, [] ++ :: Y)]).
+    apply ImpL. apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+    2: apply derI with (ps:=[]) ; [apply BotL ; apply BotLRule_I | apply dlNil].
+    apply derI with (ps:=[(XBoxed_list (Box (Neg conj2) :: top_boxes X) ++ [Box (Neg conj1)], [Neg conj1])]).
+    apply GLR. apply GLRRule_I.
+    intro. intros. inversion H2. exists (Neg conj2) ; rewrite <- H3 ; auto. apply in_top_boxes in H3. destruct H3.
+    destruct s0 ; auto. destruct s0. destruct p0. exists x ; rewrite <- e ; auto.
+    simpl. apply univ_gen_ext_cons. apply top_boxes_nobox_gen_ext. simpl. apply dlCons. 2: apply dlNil.
+    apply derI with (ps:=[([] ++ conj1 :: Neg conj2 :: Box (Neg conj2) :: XBoxed_list (top_boxes X) ++ [Box (Neg conj1)], [] ++ Bot :: [])]).
+    apply ImpR. eapply (ImpRRule_I _ _ [] _ []). apply dlCons. 2: apply dlNil. simpl.
+    apply derI with (ps:=[([conj1] ++ Box (Neg conj2) :: XBoxed_list (top_boxes X) ++ [Box (Neg conj1)], [] ++ conj2 :: []);
+    ([conj1] ++ Bot :: Box (Neg conj2) :: XBoxed_list (top_boxes X) ++ [Box (Neg conj1)], [] ++ [])]).
+    apply ImpL. eapply (ImpLRule_I _ _ [_] _ [] [_]). apply dlCons. 2: apply dlCons. 3: apply dlNil.
+    2: apply derI with (ps:=[]) ; [apply BotL ; apply BotLRule_I | apply dlNil]. simpl.
+ +
+    (* Getting rid of bottom on the right. *)
+    pose (@GLS_prv_wkn_R (conj1 :: Box (Neg conj2) :: XBoxed_list (top_boxes X) ++ [Box (Neg conj1)], [conj2])).
+    apply g with (A:=Bot). subst. clear g.
+    2: assert ([conj2; ] = [conj2] ++ :: []) ; auto. 2: rewrite H2.
+    2: assert ([conj2] = [conj2] ++ []) ; auto. 2: rewrite H3 ; apply wkn_RI.
+ +
+    (* Naming context on the left. *)
+    remember (Box (Neg (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))))
+    :: XBoxed_list (top_boxes X) ++ [Box (Neg (list_conj (map (UI p) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))))]) as LHS.
+ +
+    (* We treat the list of conjunction on the right. *)
+    epose (list_conj_R _ (_,[])). simpl in g. apply g. clear g. intros. apply InT_map_iff in H2. destruct H2. destruct p0. rewrite <- e.
+ +
+    (* We treat the list of conjunction on the left. *)
+    epose (list_conj_wkn_L _ (LHS,_)). simpl in g. apply g with (A:=UI p x). clear g. subst. apply InT_map_iff. exists x ; auto. clear g.
+ +
+    destruct (dec_init_rules x).
+    (* The sequent x is initial. *)
+     assert (is_init x) ; auto.
+     pose (N_spec p s x).
+     pose (GN_inv_init _ g). rewrite <- e0 ; auto.
+     epose (TopR _ [] []). simpl in g0 ; apply g0.
+    (* The sequent x is not initial. *)
+     assert (is_init x -> False) ; auto.
+     assert (J2: GUI p x (UI p x)). apply UI_GUI ; auto.
+     pose (Canopy_critical _ _ i).
+     assert (J3: Gimap (GUI p) (GLR_prems (nodupseq x)) (map (UI p) (GLR_prems (nodupseq x)))).
+     apply Gimap_map. intros. apply UI_GUI ; auto.
+     assert (J4: Gimap (GN p (GUI p) x) (Canopy (nodupseq (XBoxed_list (top_boxes (fst x)), @nil MPropF)))
+     (map (N p x) (Canopy (nodupseq (XBoxed_list (top_boxes (fst x)), @nil MPropF))))).
+     simpl. apply Gimap_map. intros. apply (N_spec p x x0).
+     destruct (empty_seq_dec x) as [EEx | DEx].
+     { subst. assert (GUI p ([],[]) Bot). apply GUI_empty_seq ; auto. apply UI_GUI in H3.
+       rewrite H3 in *. apply derI with []. apply BotL ; apply (BotLRule_I []). apply dlNil. }
+
+      { epose (GUI_inv_critic_not_init _ J2 c DEx H2 J3 J4). rewrite <- e0.
+      destruct (Compare_dec.lt_dec (length (usable_boxes x)) (length (usable_boxes s))).
+      (* The sequent x has less usable boxes than s. *)
+      assert ((forall (x : Seq) (l m : MPropF), (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x l -> (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x m -> l = m)).
+      intros. subst. auto.
+      pose (N_spec p s x).
+      epose (@GN_inv_noinit_lessub _ _ _ _ _ g H2 l (UI_spec p _)). rewrite <- e1 ; auto. rewrite <- e0.
+      epose (Id_all_form _ [] _ [] []). simpl in d ; apply d.
+      (* The sequent x does not have less usable boxes than s. *)
+      assert ((forall (x : Seq) (l m : MPropF), (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x l -> (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x m -> l = m)).
+      intros. subst. auto.
+      pose (N_spec p s x).
+      assert (J5: Gimap (GUI p) (GLR_prems (nodupseq x)) (map (UI p) (GLR_prems (nodupseq x)))).
+      apply Gimap_map ; auto. intros ; apply UI_GUI ; auto.
+      epose (@GN_inv_noinit_nolessub _ _ _ _ _ g H2 n J5). rewrite <- e1 ; auto.
+ +
+       (* Proof-theoretic work. *)
+       epose (OrL (LHS,_)). simpl in g0. apply g0. clear g0.
+       epose (OrR (_,[])). simpl in g0. apply g0. epose (Id_all_form _ [] _ [] _). simpl in d ; apply d.
+       apply g0. clear g0. epose (OrR (_,[])). simpl in g0. apply g0.
+       pose (@GLS_prv_wkn_R (list_disj (map Neg (restr_list_prop p (fst x))) :: LHS, [Or (list_disj (map Neg (restr_list_prop p (fst x)))) (list_disj (map Box (map (UI p) (GLR_prems (nodupseq x)))))])).
+       apply g1 with (A:=list_disj (restr_list_prop p (snd x))). clear g1. apply g0. epose (Id_all_form _ [] _ [] _). simpl in d ; apply d.
+       epose (wkn_RI _ _ []). simpl in w. apply w.
+       apply g0. clear g0. epose (OrR (_,[])). simpl in g0. apply g0.
+       pose (@GLS_prv_wkn_R (list_disj (map Box (map (UI p) (GLR_prems (nodupseq x)))) :: LHS, [Or (list_disj (map Neg (restr_list_prop p (fst x)))) (list_disj (map Box (map (UI p) (GLR_prems (nodupseq x)))))])).
+       apply g1 with (A:=list_disj (restr_list_prop p (snd x))). clear g1. apply g0.
+       pose (@GLS_prv_wkn_R (list_disj (map Box (map (UI p) (GLR_prems (nodupseq x)))) :: LHS, [(list_disj (map Box (map (UI p) (GLR_prems (nodupseq x)))))])).
+       apply g1 with (A:=list_disj (map Neg (restr_list_prop p (fst x)))). clear g1. clear g0.
+       epose (Id_all_form _ [] _ [] _). simpl in d ; apply d.
+       epose (wkn_RI _ _ []). simpl in w. apply w. epose (wkn_RI _ _ []). simpl in w. apply w.
+       clear g0. epose (OrR (_,[])). simpl in g0. apply g0.
+       pose (@GLS_prv_wkn_R (Diam (list_conj (map (N p x) (Canopy (nodupseq (XBoxed_list (top_boxes (fst x)), []%list))))) :: LHS, [Or (list_disj (map Neg (restr_list_prop p (fst x)))) (list_disj (map Box (map (UI p) (GLR_prems (nodupseq x)))))])).
+       apply g1 with (A:=list_disj (restr_list_prop p (snd x))). clear g1. apply g0.
+       pose (@GLS_prv_wkn_R (Diam (list_conj (map (N p x) (Canopy (nodupseq (XBoxed_list (top_boxes (fst x)), []%list))))) :: LHS, [(list_disj (map Box (map (UI p) (GLR_prems (nodupseq x)))))])).
+       apply g1 with (A:=list_disj (map Neg (restr_list_prop p (fst x)))). clear g1. clear g0.
+       2-3: epose (wkn_RI _ _ []) ; simpl in w ; apply w.
+      remember [list_disj (map Box (map (UI p) (GLR_prems (nodupseq x))))] as RHS. unfold Diam.
+      apply derI with (ps:=[([] ++ LHS, [] ++ Box (Neg (list_conj (map (N p x) (Canopy (nodupseq (XBoxed_list (top_boxes (fst x)), []%list)))))) :: RHS);
+      ([] ++ Bot :: LHS, [] ++ RHS)]).
+      apply ImpL. apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+      2: apply derI with (ps:=[]) ; [apply BotL ; apply BotLRule_I | apply dlNil].
+      apply derI with (ps:=[(XBoxed_list (top_boxes LHS) ++ [Box (Neg (list_conj (map (N p x) (Canopy (nodupseq (XBoxed_list (top_boxes (fst x)), []%list))))))], [(Neg (list_conj (map (N p x) (Canopy (nodupseq (XBoxed_list (top_boxes (fst x)), []%list))))))])]).
+      apply GLR. apply GLRRule_I.
+      intro. intros. subst. simpl in H4. repeat rewrite top_boxes_distr_app in H4. simpl in H4.
+      inversion H4. symmetry in H5 ; eexists ; apply H5. apply in_app_or in H5. destruct H5.
+      apply in_top_boxes in H5. destruct H5. destruct s0 ; auto. destruct s0. destruct p0. exists x0 ; rewrite <- e ; auto.
+      simpl in H5. destruct H5. symmetry in H5 ; eexists ; apply H5. inversion H5.
+      simpl. apply top_boxes_nobox_gen_ext. apply dlCons. 2: apply dlNil. subst. simpl.
+      pose (@GLS_prv_list_wkn_L [Neg (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))] []
+      [Neg (list_conj (map (N p x) (Canopy (nodupseq (XBoxed_list (top_boxes (fst x)), []%list)))))]).
+      simpl in g0.
+ +
+      assert (J20: GLS_prv ([Neg (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))],
+      [Neg (list_conj (map (N p x) (Canopy (nodupseq (XBoxed_list (top_boxes (fst x)), []%list)))))])).
+      remember (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) as conj1. clear e0.
+      remember (list_conj (map (N p x) (Canopy (nodupseq (XBoxed_list (top_boxes (fst x)), []%list))))) as conj2.
+      apply derI with (ps:=[([conj2;Neg conj1], [Bot])]). apply ImpR. epose (ImpRRule_I _ _ [] _ [] []). simpl in i0. apply i0.
+      apply dlCons. 2: apply dlNil.
+      apply derI with (ps:=[([conj2] , [conj1; ]);([conj2;Bot], [])]). apply ImpL. epose (ImpLRule_I _ _[conj2] [] [] [Bot]). simpl in i0.
+      apply i0. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+      2: apply derI with (ps:=[]) ; [apply BotL ; eapply (BotLRule_I [conj2] [] _) | apply dlNil]. simpl. subst.
+      pose (@GLS_prv_wkn_R ([list_conj (map (N p x) (Canopy (nodupseq (XBoxed_list (top_boxes (fst x)), []%list))))], [list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))])).
+      apply g1 with (A:=Bot). clear g1.
+      2: epose (wkn_RI Bot _ [list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))] []) ; simpl in w ; apply w.
+      epose (list_conj_R _ (_,_)). apply g1 ; clear g1 ; simpl.
+      intros A HA. apply InT_map_iff in HA. destruct HA. destruct p0 ; subst.
+ +
+      assert (PermutationTS (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)) (nodupseq (XBoxed_list (top_boxes (fst x)), []%list))).
+      unfold PermutationTS. split ; simpl. 2: apply permT_nil. apply Permutation_PermutationT.
+      apply NoDup_Permutation. 1-2: apply NoDup_nodup.
+      assert (length (usable_boxes x) < length (usable_boxes (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))) -> False).
+      intro. rewrite <- ub_nodupseq in H4. pose (leq_ub_unif s). lia.
+      assert (forall A, In A (top_boxes (fst s)) <-> In A (top_boxes (fst x))).
+      intros ; split ; intros. apply top_boxes_diam_jump in H5 ; auto.
+      pose (top_boxes_Canopy_noless_ub _ _ i H4). simpl in p0 ; destruct p0. destruct p0.
+      destruct p0. apply i4. rewrite <- nodup_top_boxes. apply nodup_In. auto.
+      pose (leq_ub_unif s). inversion l ; auto ; subst. exfalso. rewrite <- ub_nodupseq in H4.
+      pose (leq_ub_Canopy _ _ i). rewrite <- ub_nodupseq in l0. lia.
+      apply top_boxes_diam_jump ; auto. pose (leq_ub_unif s). inversion l ; auto ; subst. exfalso. rewrite <- ub_nodupseq in H4.
+      pose (leq_ub_Canopy _ _ i). rewrite <- ub_nodupseq in l0. lia.
+      pose (top_boxes_Canopy_noless_ub _ _ i H4). simpl in p0 ; destruct p0. destruct p0.
+      destruct p0. apply i3 in H5. rewrite <- nodup_top_boxes in H5. apply nodup_In in H5. auto.
+      intros. split ; intro ; apply nodup_In ; apply nodup_In in H6.
+      apply In_XBoxed_list in H6. destruct H6. apply list_preserv_XBoxed_list ; apply H5 ; auto.
+      destruct H6. destruct H6 ; subst. apply XBoxed_list_In. apply H5 ; auto.
+      apply In_XBoxed_list in H6. destruct H6. apply list_preserv_XBoxed_list ; apply H5 ; auto.
+      destruct H6. destruct H6 ; subst. apply XBoxed_list_In. apply H5 ; auto.
+      pose (PermutationTS_Canopy _ _ H4 _ i0). destruct s0. destruct p0.
+      epose (list_conj_wkn_L _ (_,_) (N p x x1)). apply g1 ; clear g1 ; simpl.
+      apply InT_map_iff. exists x1 ; split ; auto.
+ +
+      assert (J80: length (usable_boxes s) = length (usable_boxes x)).
+      pose (leq_ub_unif s). pose (leq_ub_Canopy _ _ i). rewrite <- ub_nodupseq in l0. lia.
+ +
+    (* Massage the Ns. *)
+    destruct (dec_init_rules x0).
+    (* The sequents x1 and x0 is initial. *)
+     assert (is_init x0) ; auto.
+     pose (N_spec p s x0).
+     pose (GN_inv_init _ g1). rewrite <- e ; auto.
+     epose (TopR _ [] []). simpl in g2 ; apply g2.
+    (* The sequent x is not initial. *)
+     assert (is_init x0 -> False) ; auto.
+     assert (is_init x1 -> False). intro. apply H5. apply (PermutationTS_is_init _ _ (PermutationTS_sym _ _ p0) X0).
+     assert (J20: GUI p x0 (UI p x0)). apply UI_GUI ; auto.
+     assert (J30: GUI p x1 (UI p x1)). apply UI_GUI ; auto.
+     pose (Canopy_critical _ _ i0).
+     pose (Canopy_critical _ _ i1).
+     destruct (Compare_dec.lt_dec (length (usable_boxes x0)) (length (usable_boxes s))).
+     (* The sequent x has less usable boxes than s. *)
+     pose (N_spec p s x0).
+     epose (@GN_inv_noinit_lessub _ _ _ _ _ g1 H5 l (UI_spec p _)). rewrite <- e ; auto.
+     assert (J40: length (usable_boxes x1) < length (usable_boxes x)). rewrite <- J80 ; auto.
+     assert (incl (usable_boxes x1) (usable_boxes x0)). intros A HA.
+     apply InT_In ; apply In_InT in HA. apply (PermutationTS_usable_boxes _ _ (PermutationTS_sym _ _ p0)) ; auto.
+     pose (NoDup_incl_length (NoDup_usable_boxes x1) H7).
+     assert (incl (usable_boxes x0) (usable_boxes x1)). intros A HA.
+     apply InT_In ; apply In_InT in HA. apply (PermutationTS_usable_boxes _ _ p0) ; auto.
+     pose (NoDup_incl_length (NoDup_usable_boxes x0) H8). lia.
+     pose (N_spec p x x1).
+     epose (@GN_inv_noinit_lessub _ _ _ _ _ g2 H6 J40 (UI_spec p _)). rewrite <- e0 ; auto.
+     apply PermutationTS_UI ; apply PermutationTS_sym ; auto.
+     (* The sequent x does not have less usable boxes than s. *)
+     pose (N_spec p s x0).
+     assert (J41: Gimap (GUI p) (GLR_prems (nodupseq x0)) (map (UI p) (GLR_prems (nodupseq x0)))).
+     apply Gimap_map ; auto. intros ; apply UI_GUI ; auto.
+     epose (@GN_inv_noinit_nolessub _ _ _ _ _ g1 H5 n0 J41). rewrite <- e ; auto.
+     assert (J42: (length (usable_boxes x1) < length (usable_boxes x)) -> False). rewrite <- J80.
+     assert (incl (usable_boxes x1) (usable_boxes x0)). intros A HA.
+     apply InT_In ; apply In_InT in HA. apply (PermutationTS_usable_boxes _ _ (PermutationTS_sym _ _ p0)) ; auto.
+     pose (NoDup_incl_length (NoDup_usable_boxes x1) H7).
+     assert (incl (usable_boxes x0) (usable_boxes x1)). intros A HA.
+     apply InT_In ; apply In_InT in HA. apply (PermutationTS_usable_boxes _ _ p0) ; auto.
+     pose (NoDup_incl_length (NoDup_usable_boxes x0) H8). lia.
+     pose (N_spec p x x1).
+     assert (J43: Gimap (GUI p) (GLR_prems (nodupseq x1)) (map (UI p) (GLR_prems (nodupseq x1)))).
+     apply Gimap_map ; auto. intro ; apply UI_GUI ; auto.
+     epose (@GN_inv_noinit_nolessub _ _ _ _ _ g2 H6 J42 J43). rewrite <- e0 ; auto.
+ +
+       (* Proof-theoretic work. *)
+       epose (OrL (_,_)). simpl in g3. apply g3 ; clear g3.
+       epose (OrR (_,[])). simpl in g3. apply g3 ; clear g3.
+       epose (list_disj_L _ (_,_)). simpl in g3. apply g3 ; clear g3. intros.
+       epose (list_disj_wkn_R _ (_,_) A). apply g3 ; clear g3.
+       apply PermutationTS_restr_list_prop_snd with (s:=x1) ; auto. apply PermutationTS_sym ; auto.
+       simpl. epose (Id_all_form _ [] _ [] _). simpl in d ; apply d.
+       epose (OrL (_,_)). simpl in g3. apply g3 ; clear g3.
+       epose (OrR (_,[])). simpl in g3. apply g3 ; clear g3.
+       pose (@GLS_prv_wkn_R ([list_disj (map Neg (restr_list_prop p (fst x1)))],[Or (list_disj (map Neg (restr_list_prop p (fst x0)))) (list_disj (map Box (map (UI p) (GLR_prems (nodupseq x0)))))])).
+       apply g3 with (A:=list_disj (restr_list_prop p (snd x0))). clear g3.
+       2: epose (wkn_RI _ _ []) ; simpl in w ; apply w.
+       epose (OrR (_,[])). simpl in g3. apply g3 ; clear g3.
+       epose (list_disj_L _ (_,_)). simpl in g3. apply g3 ; clear g3. intros.
+       epose (list_disj_wkn_R _ (_,_) A). apply g3 ; clear g3.
+       apply InT_map_iff. apply InT_map_iff in H7. destruct H7. destruct p1 ; subst.
+       exists x2 ; split ; auto.
+       apply PermutationTS_restr_list_prop_fst with (s:=x1) ; auto. apply PermutationTS_sym ; auto.
+       simpl. epose (Id_all_form _ [] _ [] _). simpl in d ; apply d.
+       epose (OrR (_,[])). simpl in g3. apply g3 ; clear g3.
+       pose (@GLS_prv_wkn_R ([list_disj (map Box (map (UI p) (GLR_prems (nodupseq x1))))],[Or (list_disj (map Neg (restr_list_prop p (fst x0)))) (list_disj (map Box (map (UI p) (GLR_prems (nodupseq x0)))))])).
+       apply g3 with (A:=list_disj (restr_list_prop p (snd x0))). clear g3.
+       2: epose (wkn_RI _ _ []) ; simpl in w ; apply w.
+       epose (OrR (_,[])). simpl in g3. apply g3 ; clear g3.
+       pose (@GLS_prv_wkn_R ([list_disj (map Box (map (UI p) (GLR_prems (nodupseq x1))))],[(list_disj (map Box (map (UI p) (GLR_prems (nodupseq x0)))))])).
+       apply g3 with (A:=list_disj (map Neg (restr_list_prop p (fst x0)))). clear g3.
+       2: epose (wkn_RI _ _ []) ; simpl in w ; apply w.
+       epose (list_disj_L _ (_,_)). simpl in g3. apply g3 ; clear g3. intros.
+       apply InT_map_iff in H7. destruct H7. destruct p1 ; subst.
+       apply InT_map_iff in i2. destruct i2. destruct p1 ; subst.
+       pose (PermutationTS_GLR_prems _ _ (PermutationTS_nodupseq _ _ (PermutationTS_sym _ _ p0)) _ i2).
+       destruct s0. destruct p1.
+       epose (list_disj_wkn_R _ (_,_) (Box (UI p x2))). apply g3 ; clear g3.
+       apply InT_map_iff. exists (UI p x2) ; split ; auto.
+       apply InT_map_iff. exists x2 ; split ; auto. simpl.
+       apply derI with (ps:=[([UI p x3 ; Box (UI p x3) ; Box (UI p x2)], [UI p x2])]).
+       apply GLR. epose (@GLRRule_I _ [Box (UI p x3)] _ [] []). simpl in g3. apply g3 ; clear g3.
+       intros A HA. inversion HA ; subst. eexists ; auto. inversion H7. apply univ_gen_ext_refl.
+       apply dlCons. 2: apply dlNil.
+       pose (PermutationTS_UI _ _ p p1).
+       pose (@GLS_prv_list_wkn_L [UI p x3] [] [UI p x2] g3 [Box (UI p x3); Box (UI p x2)]). simpl in g4.
+       auto.
+ +
+      epose (GLS_prv_list_wkn_L [_] [] _ _). rewrite app_nil_r in g1 ; simpl in g1. apply g1.
+      Unshelve. apply GUI_fun. rewrite app_nil_r ; auto. } }
+  Qed.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_Diam_UI_imp_N_prelim.html b/GL.Interpolation.UIGL_Diam_UI_imp_N_prelim.html new file mode 100644 index 0000000..4c2908e --- /dev/null +++ b/GL.Interpolation.UIGL_Diam_UI_imp_N_prelim.html @@ -0,0 +1,319 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_Diam_UI_imp_N_prelim

+ +
+  Require Import List.
+  Export ListNotations.
+  Require Import PeanoNat.
+  Require Import Lia.
+ +
+  Require Import general_export.
+ +
+  Require Import GLS_export.
+ +
+  Require Import UIGL_Def_measure.
+  Require Import UIGL_Canopy.
+  Require Import UIGL_irred_short.
+  Require Import UIGL_braga.
+  Require Import UIGL_LexSeq.
+  Require Import UIGL_nodupseq.
+  Require Import UIGL_And_Or_rules.
+  Require Import UIGL_UI_prelims.
+  Require Import UIGL_UI_inter.
+ +
+  (* Preliminary lemmas. *)
+ +
+  Lemma top_boxes_Canopy_noless_ub : forall s0 s1, InT s1 (Canopy s0) ->
+                        (length (usable_boxes s1) < length (usable_boxes s0) -> False) ->
+                        (incl (top_boxes (fst s1)) (top_boxes (fst s0))) * (incl (top_boxes (fst s0)) (top_boxes (fst s1))) *
+                        (incl (subform_boxesS s1) (subform_boxesS s0)) * (incl (subform_boxesS s0) (subform_boxesS s1)).
+  Proof.
+  intro s0. induction on s0 as IH with measure (n_imp_subformS s0).
+  intros. pose (fold_Canopy _ _ H). destruct s ; subst.
+  - assert (Canopy s0 = [s0]). apply Id_InT_Canopy ; auto. rewrite H1 in H. inversion H ; subst.
+    repeat split ; intros a K ; auto. inversion H3.
+  - destruct s. destruct p.
+    assert (n_imp_subformS x < n_imp_subformS s0).
+    unfold inv_prems in i. apply InT_flatten_list_InT_elem in i. destruct i. destruct p.
+    destruct (finite_ImpRules_premises_of_S s0). simpl in i1. apply p in i1. destruct i1.
+    inversion i1 ; subst. inversion i ; subst. 2: inversion H2.
+    unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+    inversion i1 ; subst. inversion i ; subst.
+    unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+    inversion H2 ; subst. 2: inversion H3.
+    unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+    assert ((length (usable_boxes s1) < length (usable_boxes x) -> False)).
+    intro. apply H0. unfold inv_prems in i. apply InT_flatten_list_InT_elem in i. destruct i. destruct p.
+    destruct (finite_ImpRules_premises_of_S s0). simpl in i1. apply p in i1. destruct i1.
+    inversion i1 ; subst. inversion i ; subst. apply ImpR_applic_reduces_ub_or_imp in i1. destruct i1.
+    lia. destruct p0 ; lia. inversion H4.
+    inversion i1 ; subst. inversion i ; subst. apply ImpL_applic_reduces_ub_or_imp in i1. destruct i1. destruct s.
+    lia. destruct p0 ; lia. inversion H4 ; subst. 2: inversion H5. apply ImpL_applic_reduces_ub_or_imp in i1. destruct i1.
+    destruct s0. lia. destruct p0 ; lia.
+    pose (IH _ H1 _ i0 H2).
+    assert ( length (usable_boxes x) < length (usable_boxes s0) -> False).
+    intro. apply H0. destruct p. apply leq_ub_Canopy in i0 ; lia.
+    unfold inv_prems in i. apply InT_flatten_list_InT_elem in i. destruct i. destruct p0.
+    destruct (finite_ImpRules_premises_of_S s0). simpl in i1. apply p0 in i1. destruct i1.
+    + inversion i1 ; subst ; simpl. inversion i ; subst. 2: inversion H5. simpl in p. repeat split.
+       * intros C G. apply p in G. rewrite top_boxes_distr_app ; rewrite top_boxes_distr_app in G.
+         apply in_or_app. apply in_app_or in G ; destruct G ; auto. destruct A ; simpl in H4 ; auto.
+         destruct H4 ; auto. subst. destruct (In_dec (top_boxes (Γ0 ++ Γ1)) (Box A)).
+         rewrite top_boxes_distr_app in i2 ; apply in_app_or in i2 ; auto. exfalso. apply H3.
+         unfold usable_boxes ; simpl. apply remove_list_incr_decr ; auto. 1-2: apply NoDup_subform_boxesS.
+         exists (Box A). repeat split ; auto. rewrite top_boxes_distr_app ; apply in_or_app ; simpl ; auto.
+         unfold subform_boxesS. simpl. apply remove_list_is_in. apply In_incl_subform_boxes with (A:=(Box A --> B)).
+         apply in_or_app ; right ; simpl ; auto. simpl ; auto.
+         intros a G. rewrite top_boxes_distr_app ; rewrite top_boxes_distr_app in G.
+         apply in_or_app. apply in_app_or in G ; destruct G ; auto. right. simpl ; auto.
+         unfold subform_boxesS ; simpl. intros a G. apply in_app_or in G ; destruct G.
+         rewrite subform_boxesLF_dist_app in H4. apply in_app_or in H4 ; destruct H4. apply in_or_app.
+         left ; rewrite subform_boxesLF_dist_app ; apply in_or_app ; auto. apply In_remove_list_In_list_not_In_remove_list in H4.
+         destruct H4. simpl in H4. destruct H4 ; subst. apply remove_list_is_in.
+         rewrite subform_boxesLF_dist_app. apply remove_list_is_in. simpl ; auto.
+         apply in_app_or in H4. destruct H4. apply remove_list_is_in. rewrite subform_boxesLF_dist_app.
+         apply remove_list_is_in. simpl ; right ; apply in_or_app ; left ; apply in_or_app ; auto.
+         apply in_remove in H4. destruct H4. apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+         apply in_or_app ; left ; rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. apply remove_list_is_in.
+         rewrite subform_boxesLF_dist_app in H4. apply in_app_or in H4 ; destruct H4.
+         rewrite subform_boxesLF_dist_app ; apply in_or_app ; auto. apply In_remove_list_In_list_not_In_remove_list in H4.
+         destruct H4. simpl in H4. apply in_app_or in H4 ; destruct H4.
+         rewrite subform_boxesLF_dist_app. apply remove_list_is_in ; simpl. right. apply in_or_app ; left.
+         apply in_or_app ; right ; apply in_not_touched_remove. apply not_removed_remove_list ; auto.
+         intros. apply H5. rewrite subform_boxesLF_dist_app. apply remove_list_is_in ; simpl. right. apply in_or_app ; auto.
+         intro. subst. apply H5. rewrite subform_boxesLF_dist_app. apply remove_list_is_in ; simpl ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+         rewrite subform_boxesLF_dist_app. apply remove_list_is_in. assert (Box A --> B :: Δ1 = [Box A --> B] ++ Δ1).
+         auto. rewrite H8. rewrite subform_boxesLF_dist_app. apply remove_list_is_in ; auto.
+       * intros C G. apply p. rewrite top_boxes_distr_app ; rewrite top_boxes_distr_app in G.
+         apply in_or_app. apply in_app_or in G ; destruct G ; auto. right. destruct A ; simpl ; auto.
+       * intros C G. apply p in G. unfold subform_boxesS ; unfold subform_boxesS in G ; simpl ; simpl in G.
+         apply in_app_or in G ; destruct G. rewrite subform_boxesLF_dist_app in H4. apply in_app_or in H4 ; destruct H4.
+         apply in_or_app ; left ; rewrite subform_boxesLF_dist_app ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. simpl in H4. apply in_app_or in H4 ; destruct H4.
+         apply remove_list_is_in. rewrite subform_boxesLF_dist_app ; apply remove_list_is_in. simpl. apply in_or_app ; left ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+         apply in_or_app ; left ; rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. apply remove_list_is_in.
+         rewrite subform_boxesLF_dist_app in H4. apply in_app_or in H4. destruct H4.
+         rewrite subform_boxesLF_dist_app ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in. simpl in H4. apply in_app_or in H4.
+         destruct H4. simpl. apply in_or_app ; left. apply remove_list_is_in ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. simpl. apply remove_list_is_in ; auto.
+       * intros C G. apply p. unfold subform_boxesS ; unfold subform_boxesS in G ; simpl ; simpl in G.
+         apply in_app_or in G ; destruct G. apply in_or_app ; left. rewrite subform_boxesLF_dist_app in H4.
+         apply in_app_or in H4 ; destruct H4. rewrite subform_boxesLF_dist_app. apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; simpl ; apply remove_list_is_in ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+         rewrite subform_boxesLF_dist_app in H4. apply in_app_or in H4. destruct H4.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; rewrite subform_boxesLF_dist_app ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. simpl in H4. apply in_app_or in H4.
+         destruct H4. apply in_app_or in H4. destruct H4. apply in_or_app ; left.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. apply remove_list_is_in.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. apply remove_list_is_in.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; simpl ; apply remove_list_is_in ; auto.
+    + inversion i1 ; subst ; simpl ; simpl in p. inversion i ; subst ; simpl in p.
+       ++ repeat split.
+       * intros C G. apply p in G. rewrite top_boxes_distr_app ; rewrite top_boxes_distr_app in G.
+         apply in_or_app. apply in_app_or in G ; destruct G ; auto.
+       * intros C G. apply p. rewrite top_boxes_distr_app ; rewrite top_boxes_distr_app in G.
+         apply in_or_app. apply in_app_or in G ; destruct G ; auto.
+       * intros C G. apply p in G. unfold subform_boxesS ; unfold subform_boxesS in G ; simpl ; simpl in G.
+         apply in_app_or in G ; destruct G. rewrite subform_boxesLF_dist_app in H4. apply in_app_or in H4 ; destruct H4.
+         apply in_or_app ; left ; rewrite subform_boxesLF_dist_app ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+         apply in_or_app ; left ; rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; simpl ; apply remove_list_is_in ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+         rewrite subform_boxesLF_dist_app in H4. apply in_app_or in H4. destruct H4.
+         apply remove_list_is_in ; rewrite subform_boxesLF_dist_app ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. simpl in H4. apply in_app_or in H4 ; destruct H4.
+         apply in_or_app ; left ; rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; simpl ; apply in_or_app ; left ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; auto.
+       * intros C G. apply p. unfold subform_boxesS ; unfold subform_boxesS in G ; simpl ; simpl in G.
+         apply in_app_or in G ; destruct G. rewrite subform_boxesLF_dist_app in H4.
+         apply in_app_or in H4 ; destruct H4. apply in_or_app ; left. rewrite subform_boxesLF_dist_app. apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. simpl in H4. apply in_app_or in H4.
+         destruct H4. apply in_app_or in H4. destruct H4.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ;
+         apply in_or_app ; auto. apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+         destruct (In_dec (subform_boxesLF (Γ0 ++ Γ1) ++ remove_list (subform_boxesLF (Γ0 ++ Γ1)) (subform_boxesLF (Δ0 ++ A :: Δ1))) C) ; auto.
+         exfalso. apply H3. unfold usable_boxes ; simpl. repeat rewrite top_boxes_distr_app ; simpl.
+         apply remove_list_incr_decr4 ; auto. 1-2: apply NoDup_subform_boxesS. unfold subform_boxesS ; simpl.
+         intros a G. apply in_app_or in G ; destruct G. rewrite subform_boxesLF_dist_app in H7. apply in_app_or in H7 ; destruct H7.
+         apply in_or_app ; left ; rewrite subform_boxesLF_dist_app ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H7. destruct H7. apply in_or_app ; left.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; apply remove_list_is_in ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H7. destruct H7. rewrite subform_boxesLF_dist_app in H7.
+         apply in_app_or in H7. destruct H7. apply remove_list_is_in ; rewrite subform_boxesLF_dist_app ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H7. destruct H7. simpl in H7.
+         apply in_app_or in H7. destruct H7. apply in_or_app ; left ; rewrite subform_boxesLF_dist_app ; apply remove_list_is_in.
+         simpl. apply in_or_app ; left ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H7. destruct H7.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; auto.
+         intro. assert (In C (subform_boxesS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1))). unfold subform_boxesS ; simpl. apply in_or_app ; left.
+         apply In_incl_subform_boxes with (A:=A --> B). apply in_or_app ; simpl ; auto. simpl. apply remove_list_is_in ; auto.
+         apply H7 in H8. unfold subform_boxesS in H8 ; simpl in H8. auto.
+         exists C. repeat split. unfold subform_boxesS ; simpl. apply in_or_app ; left.
+         apply In_incl_subform_boxes with (A:=A --> B). apply in_or_app ; simpl ; auto. simpl. apply remove_list_is_in ; auto.
+         intro. apply n. apply in_or_app ; left. apply in_app_or in H7. destruct H7. rewrite subform_boxesLF_dist_app ; apply in_or_app ; left.
+         apply subform_boxesLF_top_boxes. pose (in_top_boxes _ _ H7). destruct s ; destruct s ; destruct s ; destruct p1 ; subst.
+         repeat rewrite top_boxes_distr_app ; simpl. rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; simpl ; auto.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in.
+         apply subform_boxesLF_top_boxes. pose (in_top_boxes _ _ H7). destruct s ; destruct s ; destruct s ; destruct p1 ; subst.
+         repeat rewrite top_boxes_distr_app ; simpl. rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; simpl ; auto.
+         unfold subform_boxesS ; simpl ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+         apply in_or_app ; left. rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; rewrite subform_boxesLF_dist_app.
+         rewrite subform_boxesLF_dist_app in H4. apply in_app_or in H4. destruct H4. apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. apply remove_list_is_in ; apply remove_list_is_in ; auto.
+       ++ inversion H5 ; subst ; simpl in p. 2: inversion H6. repeat split.
+       * intros C G. apply p in G. rewrite top_boxes_distr_app ; rewrite top_boxes_distr_app in G.
+         apply in_or_app. apply in_app_or in G ; destruct G ; auto. simpl. destruct B ; simpl in H4 ; auto.
+         destruct H4 ; subst ; auto. destruct (In_dec (top_boxes (Γ0 ++ Γ1)) (Box B)). rewrite top_boxes_distr_app in i2 ; apply in_app_or in i2 ; auto.
+         exfalso. apply H3. unfold usable_boxes ; simpl. repeat rewrite top_boxes_distr_app ; simpl.
+         apply remove_list_incr_decr ; auto. 1-2: apply NoDup_subform_boxesS.
+         exists (Box B). repeat split. apply in_or_app ; simpl ; auto. unfold subform_boxesS ; simpl.
+         rewrite subform_boxesLF_dist_app ; apply in_or_app ; left ; apply remove_list_is_in ; simpl ; apply in_or_app ; left ; apply remove_list_is_in ; apply in_eq.
+         rewrite top_boxes_distr_app in n ; auto.
+         intros a G. apply in_app_or in G ; apply in_or_app ; simpl ; destruct G ; auto.
+         unfold subform_boxesS ; simpl.
+         intros a G. apply in_app_or in G ; destruct G. rewrite subform_boxesLF_dist_app in H4. apply in_app_or in H4 ; destruct H4.
+         apply in_or_app ; left ; rewrite subform_boxesLF_dist_app ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. simpl in H4 ; destruct H4 ; subst. apply in_or_app ; left.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; simpl ; apply in_or_app ; left ; apply remove_list_is_in ; apply in_eq.
+         apply in_app_or in H4 ; destruct H4. apply in_or_app ; left.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; simpl ; apply in_or_app ; left ; apply remove_list_is_in ; apply in_cons ; auto.
+         apply in_remove in H4. destruct H4.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. apply in_or_app ; left.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; apply remove_list_is_in ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. apply remove_list_is_in ; auto.
+       * intros C G. apply p. rewrite top_boxes_distr_app ; rewrite top_boxes_distr_app in G ; simpl in G.
+         apply in_or_app. apply in_app_or in G ; destruct G ; auto. simpl. destruct B ; auto. right ; apply in_cons ; auto.
+       * intros C G. apply p in G. unfold subform_boxesS ; unfold subform_boxesS in G ; simpl ; simpl in G.
+         apply in_app_or in G ; destruct G. rewrite subform_boxesLF_dist_app in H4. apply in_app_or in H4 ; destruct H4.
+         apply in_or_app ; left ; rewrite subform_boxesLF_dist_app ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. apply in_or_app ; left. simpl in H4 ; apply in_app_or in H4 ; destruct H4.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; simpl ; apply in_or_app ; left ; apply remove_list_is_in ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; simpl ; apply remove_list_is_in ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. apply remove_list_is_in ; auto.
+       * intros C G. apply p. unfold subform_boxesS ; unfold subform_boxesS in G ; simpl ; simpl in G.
+         apply in_app_or in G ; destruct G. rewrite subform_boxesLF_dist_app in H4. apply in_app_or in H4 ; destruct H4.
+         apply in_or_app ; left ; rewrite subform_boxesLF_dist_app ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. simpl in H4 ; apply in_app_or in H4 ; destruct H4.
+         apply in_app_or in H4 ; destruct H4. destruct (In_dec (subform_boxesLF (Γ0 ++ B :: Γ1) ++ remove_list (subform_boxesLF (Γ0 ++ B :: Γ1)) (subform_boxesLF (Δ0 ++ Δ1))) C) ; auto.
+ +
+         exfalso. apply H3. unfold usable_boxes ; simpl. repeat rewrite top_boxes_distr_app. simpl (top_boxes (A --> B :: Γ1)).
+         assert (length (remove_list (top_boxes Γ0 ++ top_boxes (B :: Γ1)) (subform_boxesS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1))) <=
+         length (remove_list (top_boxes Γ0 ++ top_boxes Γ1) (subform_boxesS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)))).
+         destruct B ; simpl ; auto. apply remove_list_incr_decr3 ; auto. intros a G. apply in_or_app ; simpl ; apply in_app_or in G ; destruct G ; auto.
+         assert (length (remove_list (top_boxes Γ0 ++ top_boxes Γ1) (subform_boxesS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1))) <
+         length (remove_list (top_boxes Γ0 ++ top_boxes Γ1) (subform_boxesS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)))).
+         apply remove_list_incr_decr4 ; auto. 1-2: apply NoDup_subform_boxesS.
+         intros a G. unfold subform_boxesS ; simpl ; unfold subform_boxesS in G ; simpl in G. apply in_app_or in G ; destruct G.
+         apply in_or_app ; left. rewrite subform_boxesLF_dist_app in H8 ; apply in_app_or in H8 ; destruct H8.
+         rewrite subform_boxesLF_dist_app ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H8. destruct H8. simpl in H8 ; apply in_app_or in H8 ; destruct H8.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; simpl ; apply in_or_app ; left ; apply remove_list_is_in ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H8. destruct H8.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; apply remove_list_is_in ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H8. destruct H8. apply remove_list_is_in ; auto.
+         intro. apply n. apply H8. unfold subform_boxesS ; simpl. apply in_or_app ; left.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; simpl ; apply in_or_app ; left ; apply in_or_app ; auto.
+         exists (C). repeat split. unfold subform_boxesS ; simpl. apply in_or_app ; left.
+         rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; simpl ; apply in_or_app ; left ; apply in_or_app ; auto.
+         intro. apply n. apply in_or_app ; left. apply subform_boxesLF_top_boxes. assert (In C (top_boxes (Γ0 ++ B :: Γ1))).
+         repeat rewrite top_boxes_distr_app. apply in_or_app ; apply in_app_or in H8 ; destruct H8 ; auto. right. destruct B ; simpl ; auto.
+         pose (in_top_boxes _ _ H9). destruct s ; destruct s ; destruct s ; destruct p1 ; subst. rewrite e0.
+         repeat rewrite top_boxes_distr_app ; simpl. rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; simpl ; auto. auto.
+         lia.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+         apply in_or_app ; left ; rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; apply in_or_app ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4.
+         apply in_or_app ; left ; rewrite subform_boxesLF_dist_app ; apply remove_list_is_in ; apply remove_list_is_in ; auto.
+         apply In_remove_list_In_list_not_In_remove_list in H4. destruct H4. apply remove_list_is_in ; auto.
+  Qed.
+ +
+  Lemma noless_ub_incl_subform_boxesS : forall s,
+              (length (usable_boxes (XBoxed_list (top_boxes (fst s)), []%list)) < length (usable_boxes s) -> False) ->
+              incl (subform_boxesS s) (subform_boxesS (XBoxed_list (top_boxes (fst s)), []%list)).
+  Proof.
+  intros s H. unfold subform_boxesS ; simpl. intros A H0. rewrite remove_list_of_nil. rewrite app_nil_r.
+  apply InT_In. pose (InT_dec (subform_boxesLF (XBoxed_list (top_boxes (fst s)))) A).
+  destruct s0 ; auto. exfalso. apply H. destruct s.
+  simpl. simpl in f. simpl in H0. simpl in H. unfold usable_boxes. simpl. unfold subform_boxesS. simpl.
+  rewrite remove_list_of_nil. rewrite app_nil_r.
+ +
+  assert (length (remove_list (top_boxes l) (subform_boxesLF (XBoxed_list (top_boxes l)))) <
+  length (remove_list (top_boxes l) (subform_boxesLF l ++ remove_list (subform_boxesLF l) (subform_boxesLF l0)))).
+  apply remove_list_incr_decr4 ; simpl. apply NoDup_subform_boxesLF. apply add_remove_list_preserve_NoDup.
+  1-2: apply NoDup_subform_boxesLF.
+  intro. intros. apply in_or_app ; left.
+  pose (XBoxed_list_same_subform_boxes (top_boxes l)). apply a0 in H1. apply In_subform_boxes in H1. destruct H1.
+  destruct H1. apply In_incl_subform_boxes with (A:=x). apply top_boxes_incl_list ; auto. auto.
+  intro. apply f. apply In_InT ; auto.
+  exists A. repeat split ; auto. intro. apply f. apply In_InT. apply In_incl_subform_boxes with (A:=A).
+  apply list_preserv_XBoxed_list ; auto. apply in_top_boxes in H1. destruct H1. destruct s. destruct s.
+  destruct p. subst ; simpl ; auto. intro ; apply f ; apply In_InT ; auto.
+ +
+  assert (length (remove_list (top_boxes (XBoxed_list (top_boxes l))) (subform_boxesLF (XBoxed_list (top_boxes l)))) <=
+  length (remove_list (top_boxes l) (subform_boxesLF (XBoxed_list (top_boxes l))))).
+  apply remove_list_incr_decr3 ; simpl.
+  intro. intros. pose (XBoxed_list_same_subform_boxes (top_boxes l)). apply is_box_in_top_boxes.
+  apply list_preserv_XBoxed_list ; auto. apply in_top_boxes in H2. destruct H2. destruct s. destruct s.
+  destruct p ; subst ; eexists ; auto.
+  lia.
+  Qed.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_LexSeq.html b/GL.Interpolation.UIGL_LexSeq.html new file mode 100644 index 0000000..ecab28d --- /dev/null +++ b/GL.Interpolation.UIGL_LexSeq.html @@ -0,0 +1,262 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_LexSeq

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+ +
+Require Import general_export.
+ +
+Require Import GLS_export.
+ +
+Require Import UIGL_Def_measure.
+Require Import UIGL_Canopy.
+Require Import UIGL_irred_short.
+ +
+  Section LogDefinition.
+ +
+  (* Below is the measure which can be used to prove termination of
+      the Fixpoint UI (order used: lexicographic on pairs of natural numbers). *)

+ +
+  Definition measure (s : Seq) := [(length (usable_boxes s)) ; (n_imp_subformS s)].
+ +
+  (* List of all premises through the GLR rule for a sequent s.
+      Note that GLR is not invertible. *)

+ +
+  Definition GLR_prems (s : Seq) := flatten_list (proj1_sigT2 (finite_GLR_premises_of_S s)).
+ +
+  (* Property of being an initial sequent. *)
+ +
+  Definition is_init s : Type := (IdPRule [] s) + (IdBRule [] s) + (BotLRule [] s).
+ +
+  End LogDefinition.
+ +
+  Section LexSeq_ind.
+ +
+  Definition LexSeq := fun s0 s1 => (less_thanS s0 s1).
+ +
+  Lemma wf_LexSeq : well_founded LexSeq.
+  Proof.
+  unfold LexSeq. apply less_thanS_wf.
+  Qed.
+ +
+  Variable (P : Seq -> Type).
+ +
+  Definition LexSeq_ind : (forall s0, (forall s1, LexSeq s1 s0 -> P s1) -> P s0) -> (forall s, P s).
+  Proof.
+  intros. induction s as [ s0 IHs0 ] using (well_founded_induction_type wf_LexSeq).
+  apply X; intros; apply IHs0 ; auto.
+  Defined.
+ +
+  End LexSeq_ind.
+ +
+  Section LexSeq_properties.
+ +
+  Theorem LexSeq_trans : forall x y z, LexSeq x y -> LexSeq y z -> LexSeq x z.
+  Proof.
+  unfold LexSeq. apply less_thanS_trans.
+  Qed.
+ +
+  Lemma inv_prems_LexSeq : forall s0 s1, InT s1 (inv_prems s0) -> LexSeq s1 s0.
+  Proof.
+  intros. unfold inv_prems in H. apply InT_flatten_list_InT_elem in H.
+  destruct H. destruct p. destruct (finite_ImpRules_premises_of_S s0). simpl in i0.
+  apply p in i0. destruct i0 ; inversion i0 ; subst. inversion i ; subst. unfold LexSeq.
+  apply ImpR_applic_reduces_measure ; auto. inversion H0.
+  unfold LexSeq. destruct (ImpL_applic_reduces_measure i0).
+  inversion i ; subst ; auto. inversion H0 ; subst ; auto. inversion H1.
+  Qed.
+ +
+  Lemma GLR_prems_LexSeq : forall s0 s1, (IdBRule [] s0 -> False) ->
+            InT s1 (GLR_prems s0) -> LexSeq s1 s0.
+  Proof.
+  intros s0 s1 H0 H. unfold GLR_prems in H. apply InT_flatten_list_InT_elem in H.
+  destruct H. destruct p. destruct (finite_GLR_premises_of_S s0). simpl in i0.
+  apply p in i0. inversion i0 ; subst. unfold LexSeq. apply GLR_applic_reduces_measure ; auto.
+  inversion i ; subst ; auto. inversion H2.
+  Qed.
+ +
+  Lemma GLR_prems_less_ub : forall s0 s1, (IdBRule [] s0 -> False) ->
+            InT s1 (GLR_prems s0) -> (length (usable_boxes s1) < length (usable_boxes s0)).
+  Proof.
+  intros s0 s1 H0 H. unfold GLR_prems in H. apply InT_flatten_list_InT_elem in H.
+  destruct H. destruct p. destruct (finite_GLR_premises_of_S s0). simpl in i0.
+  apply p in i0. inversion i0 ; subst. apply GLR_applic_less_usable_boxes in i0 ; auto.
+  inversion i ; subst ; auto. inversion H2.
+  Qed.
+ +
+  Lemma top_boxes_XBoxed_list : forall l, incl (top_boxes l) (top_boxes (XBoxed_list (top_boxes l))).
+  Proof.
+  induction l ; intro ; intros ; auto. destruct a ; simpl ; simpl in H ; auto. destruct H. subst.
+  destruct a ; auto. 1-3: apply in_eq. apply in_cons ; apply in_eq. destruct a ; auto. all: apply in_cons ; auto.
+  apply in_cons ; auto.
+  Qed.
+ +
+  Lemma subform_boxesLF_top_boxes : forall l a, In a (subform_boxesLF (top_boxes l)) -> In a (subform_boxesLF l).
+  Proof.
+  induction l ; simpl ; intros ; auto. destruct a ; simpl ; auto. apply remove_list_is_in. auto.
+  simpl in H. destruct H ; auto. right. apply in_app_or in H. apply in_or_app. destruct H ; auto.
+  right. apply in_not_touched_remove. 2: apply In_remove_diff in H ; auto.
+  apply In_remove_In_list in H. apply not_removed_remove_list.
+  apply In_remove_list_In_list in H ; auto. intro. apply remove_list_cont in H ; auto.
+  Qed.
+ +
+  Lemma leq_ub_unif : forall s, (length (usable_boxes (XBoxed_list (top_boxes (fst s)), []))) <= (length (usable_boxes s)).
+  Proof.
+  intros. destruct s. simpl. unfold usable_boxes. simpl.
+  assert (J0: incl (top_boxes l) (top_boxes (XBoxed_list (top_boxes l)))). apply top_boxes_XBoxed_list.
+  pose (remove_list_incr_decr3 (subform_boxesS (XBoxed_list (top_boxes l), []%list)) _ _ J0).
+  assert (J1: NoDup (subform_boxesS (XBoxed_list (top_boxes l), []%list))). apply NoDup_subform_boxesS.
+  assert (J2: NoDup (subform_boxesS (l, l0))). apply NoDup_subform_boxesS.
+  assert (J3: incl (subform_boxesS (XBoxed_list (top_boxes l), []%list)) (subform_boxesS (l, l0))).
+  intro ; intros. unfold subform_boxesS. simpl. unfold subform_boxesS in H. simpl in H.
+  rewrite remove_list_of_nil in H. rewrite app_nil_r in H. apply in_or_app ; left.
+  apply XBoxed_list_same_subform_boxes with (l:=(top_boxes l)) in H.
+  apply subform_boxesLF_top_boxes ; auto.
+  pose (remove_list_incr_decr2 _ _ (top_boxes l) J1 J2 J3). lia.
+  Qed.
+ +
+  Lemma Canopy_nil : forall s0, (inv_prems s0 = []) -> (forall s1, InT s1 (Canopy s0) -> s1 = s0).
+  Proof.
+  intros. assert (Canopy s0 = [s0]). apply irred_nil. unfold inv_prems. unfold inv_prems in H. auto.
+  rewrite H1 in H0. inversion H0. subst. auto. inversion H3.
+  Qed.
+ +
+  Lemma Canopy_LexSeq: forall s0 s1, InT s1 (Canopy s0) -> ((s0 = s1) + (LexSeq s1 s0)).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros. remember (finite_ImpRules_premises_of_S s) as H0. destruct H0. destruct x.
+  - left. assert (Canopy s = [s]). apply irred_nil. unfold inv_prems ; rewrite <- HeqH0 ; auto.
+    rewrite H0 in H. inversion H ; subst ; auto. inversion H2.
+  - apply fold_Canopy in H. destruct H ; auto. right. destruct s0. destruct p0. apply IHs in i0.
+    destruct i0 ; subst ; auto. apply inv_prems_LexSeq in i ; auto. apply inv_prems_LexSeq in i.
+    apply (LexSeq_trans _ _ _ l0 i). unfold inv_prems in i. apply InT_flatten_list_InT_elem in i.
+    destruct i. destruct p0. rewrite <- HeqH0 in i1. simpl in i1. apply p in i1. destruct i1 ; inversion i1 ; subst.
+    inversion i. subst. unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+    inversion H0. inversion i ; subst. unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+    inversion H0 ; subst. unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+    inversion H1.
+  Qed.
+ +
+  Lemma leq_ub_Canopy : forall s0 s1, InT s1 (Canopy s0) ->
+                  (length (usable_boxes s1)) <= (length (usable_boxes s0)).
+  Proof.
+  intros s0 ; induction on s0 as IHs0 with measure (n_imp_subformS s0).
+  intros. remember (finite_ImpRules_premises_of_S s0) as H0.
+  destruct H0. destruct x.
+  - assert (Canopy s0 = [s0]). apply irred_nil. unfold inv_prems. rewrite <- HeqH0.
+    simpl. auto. rewrite H0 in H. inversion H. subst. auto. inversion H2.
+  - apply fold_Canopy in H. destruct H ; auto. subst. auto.
+    destruct s. destruct p0. unfold inv_prems in i. destruct (finite_ImpRules_premises_of_S s0).
+    simpl in i. apply InT_flatten_list_InT_elem in i. destruct i. destruct p1.
+    apply p0 in i1.
+    assert ((length (usable_boxes x0) <= length (usable_boxes s0)) * ((n_imp_subformS x0) < (n_imp_subformS s0))).
+    destruct i1. inversion i1 ; subst. apply ImpR_applic_reduces_ub_or_imp in i1. destruct i1.
+    inversion i ; subst. split ; try lia. unfold n_imp_subformS ; simpl.
+    repeat rewrite n_imp_subformLF_dist_app ; simpl ; repeat rewrite n_imp_subformLF_dist_app. lia.
+    inversion H0. destruct p1. inversion i ; subst. split ; try lia. inversion H0.
+    inversion i1 ; subst. inversion i ; subst. apply ImpL_applic_reduces_ub_or_imp in i1. destruct i1.
+    destruct s. split ; try lia. unfold n_imp_subformS ; simpl.
+    repeat rewrite n_imp_subformLF_dist_app ; simpl ; repeat rewrite n_imp_subformLF_dist_app. lia.
+    destruct p1 ; split ; try lia. inversion H0 ; subst. 2: inversion H1.
+    apply ImpL_applic_reduces_ub_or_imp in i1. destruct i1.
+    destruct s0. split ; try lia. unfold n_imp_subformS ; simpl.
+    repeat rewrite n_imp_subformLF_dist_app ; simpl ; repeat rewrite n_imp_subformLF_dist_app. lia.
+    destruct p1. split ; try lia.
+    destruct H. apply IHs0 in i0 ; lia.
+  Qed.
+ +
+  End LexSeq_properties.
+ +
+  Section empty_seq.
+ +
+  Definition empty_seq_dec : forall (s: Seq), (s = ([],[])) + (s <> ([],[])).
+  Proof.
+  intros. destruct s. destruct l ; destruct l0 ; auto.
+  all: right ; intro H ; inversion H.
+  Defined.
+ +
+  Lemma not_init_empty_seq : is_init ([],[]) -> False.
+  Proof.
+  intro. destruct X. destruct s. 1-2: inversion i ; destruct Γ0 ; inversion H.
+  inversion b ; subst. destruct Γ0 ; inversion H.
+  Qed.
+ +
+  Lemma critical_empty_seq : critical_Seq ([],[]).
+  Proof.
+  intros A HA ; simpl in *. inversion HA.
+  Qed.
+ +
+  End empty_seq.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_N_imp_UI.html b/GL.Interpolation.UIGL_N_imp_UI.html new file mode 100644 index 0000000..6868c7f --- /dev/null +++ b/GL.Interpolation.UIGL_N_imp_UI.html @@ -0,0 +1,258 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_N_imp_UI

+ +
+  Require Import List.
+  Export ListNotations.
+  Require Import PeanoNat.
+  Require Import Lia.
+ +
+  Require Import general_export.
+ +
+  Require Import GLS_export.
+ +
+  Require Import UIGL_Def_measure.
+  Require Import UIGL_Canopy.
+  Require Import UIGL_irred_short.
+  Require Import UIGL_braga.
+  Require Import UIGL_LexSeq.
+  Require Import UIGL_nodupseq.
+  Require Import UIGL_And_Or_rules.
+  Require Import UIGL_UI_prelims.
+  Require Import UIGL_UI_inter.
+ +
+Theorem gen_rec_UI_imp : forall s sr p X Y,
+              GLS_prv (X, (list_conj (map (N p sr) (Canopy (nodupseq s)))) --> (UI p s) :: Y).
+  Proof.
+  pose (d:=LexSeq_ind (fun (s:Seq) => forall sr p X Y,
+              GLS_prv (X, (list_conj (map (N p sr) (Canopy (nodupseq s)))) --> (UI p s) :: Y))).
+  apply d. clear d. intros s IH.
+  intros.
+  destruct (empty_seq_dec s) as [EE | DE].
+  (* s is the empty sequent. *)
+  { subst ; simpl in *. unfold nodupseq ; simpl.
+    assert ((Canopy ([], [])) = [([], [])]). apply Id_InT_Canopy ; auto.
+    apply critical_Seq_InT_Canopy ; auto. apply critical_empty_seq. rewrite H ; simpl.
+    assert (GUI p ([],[]) Bot). apply GUI_empty_seq ; auto. apply UI_GUI in H0.
+    rewrite H0 in *. pose critical_empty_seq. pose not_init_empty_seq.
+    unfold N. destruct (N_pwc p sr ([], [])). simpl.
+    assert ((forall (x : Seq) (l m : MPropF), (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x l -> (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x m -> l = m)).
+    intros. subst. auto.
+    assert (J11: Gimap (GUI p) (GLR_prems (nodupseq ([],[]))) (map (UI p) (GLR_prems (nodupseq ([],[]))))).
+    apply Gimap_map. intros. apply UI_GUI ; auto.
+    assert (J41: Gimap (GUI p) (GLR_prems (nodupseq (nodupseq ([],[])))) (map (UI p) (GLR_prems (nodupseq (nodupseq ([],[])))))).
+    apply Gimap_map. intros. apply UI_GUI ; auto.
+    destruct (Compare_dec.lt_dec (length (usable_boxes ([],[]))) (length (usable_boxes sr))).
+    + assert (J0: GUI p (nodupseq ([],[])) (UI p (nodupseq ([],[])))). apply UI_GUI ; auto. apply UI_GUI in J0.
+       rewrite ub_nodupseq in l.
+       epose (GN_inv_noinit_lessub p g f l (UI_spec p _)). rewrite <- e. rewrite H0.
+       apply derI with (ps:=[([] ++ (And Bot Top) :: X, [] ++ Bot :: Y)]). apply ImpR. apply ImpRRule_I.
+       apply dlCons. 2: apply dlNil. simpl.
+       pose (AndL (X, Bot :: Y) Bot Top). simpl in g0. apply g0. clear g0.
+       apply derI with []. 2: apply dlNil. apply BotL ; apply (BotLRule_I []).
+    + rewrite ub_nodupseq in n. pose (GN_inv_noinit_nolessub _ g f n J41). rewrite <- e. clear e. simpl.
+        unfold nodupseq in * ; simpl in *. destruct (GLR_prems ([], [])) eqn:E; simpl.
+        { apply derI with (ps:=[([] ++ (And (Or (Or )) Top) :: X, [] ++ Bot :: Y)]). apply ImpR. apply ImpRRule_I.
+          apply dlCons. 2: apply dlNil. simpl.
+          pose (AndL (X, Bot :: Y) (Or (Or )) Top). simpl in g0. apply g0. clear g0.
+          pose (OrL (Top :: X, :: Y)). simpl in g0. apply g0 ; clear g0.
+          apply derI with []. 2: apply dlNil. apply BotL ; apply (BotLRule_I []).
+          pose (OrL (Top :: X, :: Y)). simpl in g0. apply g0 ; clear g0.
+          all: apply derI with [] ; [apply BotL ; apply (BotLRule_I []) | apply dlNil]. }
+        { exfalso. unfold GLR_prems in E. destruct (finite_GLR_premises_of_S ([], [])).
+           simpl in *. destruct x0. simpl in E. inversion E. simpl in E. pose (p0 l0).
+           destruct p1. assert (InT l0 (l0 :: x0)). apply InT_eq. apply g0 in H2. inversion H2.
+           destruct Δ0 ; subst ; inversion H6. } }
+  (* s is not the empty sequent. *)
+  { destruct (critical_Seq_dec s).
+  (* If s is critical. *)
+  - assert ((Canopy (nodupseq s)) = [nodupseq s]). apply Id_InT_Canopy ; auto.
+    apply critical_Seq_InT_Canopy ; auto. apply critical_nodupseq in c ; auto.
+    destruct (dec_init_rules s).
+    (* If s is initial. *)
+    * assert (is_init s). auto.
+      assert (J0: GUI p s (UI p s)). apply UI_GUI ; auto.
+      pose (@GUI_inv_critic_init p s (UI p s) J0 c X0). rewrite <- e. rewrite H. simpl. unfold N.
+      destruct (N_pwc p sr (nodupseq s)).
+      simpl. assert (is_init (nodupseq s)). pose (is_init_nodupseq s) ; destruct p0 ; auto. pose (GN_inv_init _ g).
+      apply derI with (ps:=[([] ++ And x Top :: X, [] ++ Top :: Y)]).
+      apply ImpR. apply ImpRRule_I. apply dlCons. 2: apply dlNil. simpl.
+      epose (TopR _ []). simpl in g0 ; apply g0.
+    (* If s is not initial. *)
+    * rewrite H. simpl. unfold N.
+      destruct (N_pwc p sr (nodupseq s)). simpl.
+      assert (is_init s -> False). auto.
+      assert (J40: is_init (nodupseq s) -> False). intro. apply H0. pose (is_init_nodupseq s) ; destruct p0 ; auto.
+      assert ((forall (x : Seq) (l m : MPropF), (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x l -> (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x m -> l = m)).
+      intros. subst. auto.
+      assert (J11: Gimap (GUI p) (GLR_prems (nodupseq s)) (map (UI p) (GLR_prems (nodupseq s)))).
+      apply Gimap_map. intros. apply UI_GUI ; auto.
+      assert (J41: Gimap (GUI p) (GLR_prems (nodupseq (nodupseq s))) (map (UI p) (GLR_prems (nodupseq (nodupseq s))))).
+      apply Gimap_map. intros. apply UI_GUI ; auto.
+      destruct (Compare_dec.lt_dec (length (usable_boxes s)) (length (usable_boxes sr))).
+      (* If s has less usable boxes than sr. *)
+      + assert (J0: GUI p (nodupseq s) (UI p (nodupseq s))). apply UI_GUI ; auto. apply UI_GUI in J0.
+         rewrite ub_nodupseq in l.
+         epose (GN_inv_noinit_lessub p g J40 l (UI_spec p _)). rewrite <- e.
+         apply derI with (ps:=[([] ++ (And (UI p (nodupseq s)) Top) :: X, [] ++ UI p s :: Y)]). apply ImpR. apply ImpRRule_I.
+         apply dlCons. 2: apply dlNil. simpl.
+         pose (AndL (X, UI p s :: Y) (UI p (nodupseq s)) Top). simpl in g0. apply g0. clear g0.
+         apply UI_nodupseq.
+      (* If s does not have less usable boxes than sr. *)
+      + rewrite ub_nodupseq in n. pose (GN_inv_noinit_nolessub _ g J40 n J41). rewrite <- e. clear e.
+          assert (J0: GUI p s (UI p s)). apply UI_GUI ; auto.
+          assert (J1: Gimap (GUI p) (GLR_prems (nodupseq s)) (map (UI p) (GLR_prems (nodupseq s)))). apply Gimap_map. intros.
+          apply UI_GUI ; auto.
+          assert (J2: Gimap (GN p (GUI p) s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))
+          (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))).
+          simpl. apply Gimap_map. intros. apply (N_spec p s x0).
+          assert (J42: Gimap (GN p (GUI p) s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))
+          (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))).
+          simpl. apply Gimap_map. intros. apply (N_spec p s x0).
+          pose (@GUI_inv_critic_not_init p s _ _ _ J0 c DE H0 J1 J42). rewrite <- e. clear e. simpl.
+          remember (Or (list_disj (restr_list_prop p (nodup eq_dec_form (snd s)))) (Or (list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (fst s))))) (list_disj (map Box (map (UI p) (GLR_prems (nodupseq (nodupseq s)))))))) as disj1.
+          remember (Or (list_disj (restr_list_prop p (snd s))) (Or (list_disj (map Neg (restr_list_prop p (fst s))))
+          (Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s))))) (Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))))))
+          as disj2.
+          apply derI with (ps:=[([] ++ (And disj1 Top) :: X, [] ++ disj2 :: Y)]). apply ImpR. apply ImpRRule_I.
+          apply dlCons. 2: apply dlNil. simpl.
+          pose (AndL (X, disj2 :: Y) disj1 Top). simpl in g0. apply g0. clear g0.
+          pose (@GLS_prv_list_wkn_L [disj1] [] [disj2]).
+          pose (@GLS_prv_list_wkn_R (disj1 :: Top :: X) [disj2] []). simpl in g1. simpl in g0.
+          assert (GLS_prv (disj1 :: Top :: X, [disj2])).
+          assert (GLS_prv ([disj1], [disj2])).
+          rewrite Heqdisj2.
+          pose (OrR ([disj1],[])). simpl in g2. apply g2 ; clear g2. subst.
+          epose (OrL (_,_)). simpl in g2. apply g2 ; clear g2.
+          eapply (list_disj_L) with (s:=([],_)). intros. simpl.
+          epose (list_disj_wkn_R _ ([A], _) A). simpl in g2. apply g2 ; clear g2. subst.
+          apply restr_list_prop_nodup ; auto.
+          epose (Id_all_form A [] [] []). simpl in d. apply d.
+          epose (OrL (_,_)). simpl in g2. apply g2 ; clear g2.
+          apply GLS_prv_wkn_R with
+          (s:= ([list_disj (map Neg (restr_list_prop p (nodup eq_dec_form (fst s))))], [Or (list_disj (map Neg (restr_list_prop p (fst s))))
+          (Or (list_disj (map Box (map (UI p) (GLR_prems ( nodupseq s)))))
+          (Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))))]))
+          (A:=list_disj (restr_list_prop p (snd s))).
+          2: epose (wkn_RI (list_disj (restr_list_prop p (snd s))) _ [] _) ; simpl in w ; apply w.
+          epose (OrR (_,_)). simpl in g2. apply g2 ; clear g2.
+          eapply (list_disj_L) with (s:=([],_)). intros. simpl.
+          epose (list_disj_wkn_R _ ([A], _) A). simpl in g2. apply g2 ; clear g2. subst.
+          apply InT_map_iff. apply InT_map_iff in H2. destruct H2. exists x0.
+          destruct p0 ; split ; auto. apply restr_list_prop_nodup ; auto.
+          epose (Id_all_form A [] [] []). simpl in d. apply d. clear g0. clear g1.
+          apply GLS_prv_wkn_R with
+          (s:= ([list_disj (map Box (map (UI p) (GLR_prems (nodupseq (nodupseq s)))))], [Or (list_disj (map Neg (restr_list_prop p (fst s))))
+          (Or (list_disj (map Box (map (UI p) (GLR_prems ( nodupseq s)))))
+          (Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))))]))
+          (A:=list_disj (restr_list_prop p (snd s))).
+          2: epose (wkn_RI (list_disj (restr_list_prop p (snd s))) _ [] _) ; simpl in w ; apply w.
+          epose (OrR (_,_)). simpl in g0. apply g0 ; clear g0.
+          apply GLS_prv_wkn_R with
+          (s:= ([list_disj (map Box (map (UI p) (GLR_prems (nodupseq (nodupseq s)))))], [(Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s)))))
+          (Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))))]))
+          (A:=list_disj (map Neg (restr_list_prop p (fst s)))).
+          2: epose (wkn_RI (list_disj (map Neg (restr_list_prop p (fst s)))) _ [] _) ; simpl in w ; apply w.
+          epose (OrR (_,_)). simpl in g0. apply g0 ; clear g0.
+          eapply (list_disj_L) with (s:=([],_)). intros. simpl.
+          apply InT_map_iff in H2. destruct H2. destruct p0 ; subst. apply InT_map_iff in i.
+          destruct i. destruct p0 ; subst.
+          apply nodupseq_GLR_prems in i. destruct i. destruct p0. destruct p0. subst.
+          epose (list_disj_wkn_R _ (_,[_]) (Box (UI p x0))). apply g0 ; clear g0. apply InT_map_iff.
+          exists (UI p x0). split ; auto. apply InT_map_iff. exists x0 ; auto.
+          simpl. apply derI with (ps:=[([UI p x1;Box (UI p x1);Box (UI p x0)], [UI p x0])]).
+          apply GLR. epose (@GLRRule_I _ [Box (UI p x1)] _ [] [_]). simpl in g0. apply g0.
+          intros A H3. inversion H3 ; subst. eexists ; auto. inversion H2. apply univ_gen_ext_refl.
+          apply dlCons. 2: apply dlNil. eapply (UI_nodupseq_gen x1 x0 p _ []).
+          unfold nodupseq ; simpl. rewrite e. rewrite e0 ; auto.
+          epose (g0 X0 (Top :: X)). rewrite app_nil_r in g2. apply g2.
+          epose (g1 X0 Y). rewrite app_nil_r in g2. apply g2.
+  (* If s is not critical. *)
+  - assert (J0: GUI p s (UI p s)). apply UI_GUI ; auto.
+    assert (J1: Gimap (GUI p) (Canopy (nodupseq s)) (map (UI p) (Canopy (nodupseq s)))). apply Gimap_map. intros.
+    apply UI_GUI ; auto.
+    pose (@GUI_inv_not_critic p s (UI p s) _ J0 f J1). rewrite <- e.
+    apply derI with (ps:=[(list_conj (map (N p sr) (Canopy (nodupseq s))) :: X, list_conj (map (UI p) (Canopy (nodupseq s))) :: Y)]).
+    apply ImpR. epose (ImpRRule_I _ _ [] _ []). simpl in i. apply i. apply dlCons. 2: apply dlNil.
+    epose (list_conj_R _ (_,_)). simpl in g. apply g. clear g. intros. apply InT_map_iff in H. destruct H.
+    destruct p0 ; subst.
+    epose (list_conj_wkn_L _ (_,_) (N p sr x)). simpl in g. apply g ; clear g.
+    apply InT_map_iff. exists x ; split ; auto.
+    pose (Canopy_LexSeq _ _ i). destruct s0.
+    exfalso. subst. apply Canopy_critical in i. apply critical_nodupseq in i ; auto.
+    assert (J20: LexSeq x s). pose (LexSeq_nodupseq_case s). destruct s0. apply LexSeq_trans with (y:=nodupseq s) ; auto.
+    destruct p0. unfold LexSeq ; unfold less_thanS ; unfold GLS_termination_measure.measure ; inversion l ; subst.
+    rewrite <- e1 in H2. rewrite H2. apply DLW_wf_lex.lex_skip ; auto. rewrite <- e0 ; auto.
+    apply DLW_wf_lex.lex_cons ; auto. rewrite e1 ; auto.
+    pose (IH _ J20 sr p X Y). pose (Canopy_critical _ _ i).
+    assert (Canopy (nodupseq x) = [nodupseq x]). apply Id_InT_Canopy ; auto.
+    apply critical_Seq_InT_Canopy ; auto. rewrite <- critical_nodupseq ; auto.
+    rewrite H in g. simpl in g.
+    epose (ImpRRule_I _ _ [] _ [] _). simpl in i0.
+    pose (@ImpR_inv _ (And (N p sr (nodupseq x)) Top :: X, UI p x :: Y) g i0).
+    epose (TopL_remove _ [] (N p sr x :: X)). simpl in g1. apply g1. clear g1.
+    epose (GLS_cut_adm (And (N p sr x) Top) [] (Top :: N p sr x :: X) [] (UI p x :: Y)).
+    simpl in g1. apply g1 ; clear g1.
+    epose (AndR (_,_)). simpl in g1. apply g1 ; clear g1.
+    epose (Id_all_form (N p sr x) [Top] X []). simpl in d. apply d.
+    epose (TopR _ []). simpl in g1 ; apply g1.
+    pose (@GLS_prv_list_wkn_L [And (N p sr x) Top] X (UI p x :: Y)).
+    simpl in g1. apply g1 with (l:=(Top :: [N p sr x])) ; clear g1.
+    eapply AndL with (s:=(X,_)) ; simpl.
+    eapply AndL_inv with (s:=(_,_)) in g0. simpl in g0.
+    pose (N_nodupseq sr x p (Top :: X) (UI p x :: Y)).
+    epose (GLS_cut_adm (N p sr (nodupseq x)) [] (N p sr x :: Top :: X) [] (UI p x :: Y)).
+    simpl in g2. apply g2 ; clear g2 ; auto.
+    apply GLS_prv_wkn_L with (s:= (N p sr (nodupseq x) :: Top :: X, UI p x :: Y))
+    (A:=N p sr x) ; auto.
+    epose (wkn_LI (N p sr x) [_] _ _) ; simpl in w ; apply w. }
+  Qed.
+ +
+  Theorem rec_UI_imp : forall s p X Y, (is_init s -> False) -> (critical_Seq s) ->
+              GLS_prv (X,
+        (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) -->
+        (UI p (XBoxed_list (top_boxes (fst s)), []%list)) :: Y).
+  Proof.
+  intros. apply gen_rec_UI_imp.
+  Qed.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_PermutationT.html b/GL.Interpolation.UIGL_PermutationT.html new file mode 100644 index 0000000..2e78d08 --- /dev/null +++ b/GL.Interpolation.UIGL_PermutationT.html @@ -0,0 +1,195 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_PermutationT

+ +
+Require Import List.
+Export ListNotations.
+Require Export Permutation.
+ +
+Require Import GLS_export.
+ +
+Section PermutationT.
+ +
+    Inductive PermutationT : list MPropF -> list MPropF -> Type :=
+      | permT_nil: PermutationT nil nil
+      | permT_skip: forall (x: MPropF) (l l':list MPropF), PermutationT l l' -> PermutationT (cons x l) (cons x l')
+      | permT_swap: forall (x y: MPropF) (l:list MPropF), PermutationT (cons y (cons x l)) (cons x (cons y l))
+      | permT_trans: forall (l l' l'':list MPropF), PermutationT l l' -> PermutationT l' l'' -> PermutationT l l''.
+ +
+Local Hint Constructors PermutationT : core.
+ +
+Theorem PermutationT_refl : forall l, PermutationT l l.
+Proof.
+  induction l; constructor. exact IHl.
+Qed.
+ +
+Theorem PermutationT_sym : forall l l',
PermutationT l l' -> PermutationT l' l.
+Proof.
+  intros l l' Hperm; induction Hperm; auto.
+  apply permT_trans with (l':=l'); assumption.
+Qed.
+ +
+Lemma PermutationT_app_tail : forall l l' tl,
PermutationT l l' -> PermutationT (l++tl) (l'++tl).
+Proof.
+  intros l l' tl Hperm; induction Hperm as [|x l l'|x y l|l l' l'']; simpl; auto.
+  apply PermutationT_refl.
+  eapply permT_trans with (l':=l'++tl); trivial.
+Qed.
+ +
+Lemma PermutationT_app_head : forall l tl tl',
PermutationT tl tl' -> PermutationT (l++tl) (l++tl').
+Proof.
+  intros l tl tl' Hperm; induction l;
+   [trivial | repeat rewrite <- app_comm_cons; constructor; assumption].
+Qed.
+ +
+Theorem PermutationT_app : forall l m l' m',
PermutationT l l' -> PermutationT m m' -> PermutationT (l++m) (l'++m').
+Proof.
+  intros l m l' m' Hpermll' Hpermmm';
+   induction Hpermll' as [|x l l'|x y l|l l' l''];
+    repeat rewrite <- app_comm_cons; auto.
+  - apply permT_trans with (l' := (x :: y :: l ++ m));
+      [idtac | repeat rewrite app_comm_cons; apply PermutationT_app_head]; trivial.
+  - apply permT_trans with (l' := (l' ++ m')); try assumption.
+    apply PermutationT_app_tail; assumption.
+Qed.
+ +
+Lemma PermutationT_cons_append : forall l x,
+  PermutationT (x :: l) (l ++ x :: nil).
+Proof.
+induction l; intros; auto. simpl. apply permT_skip ; apply permT_nil. simpl.
+apply permT_trans with (l':=(a :: x :: l)). apply permT_swap. apply permT_skip ; auto.
+Qed.
+ +
+Theorem PermutationT_app_comm : forall l l',
+  PermutationT (l ++ l') (l' ++ l).
+Proof.
+  induction l as [|x l]; simpl; intro l'.
+  - rewrite app_nil_r; trivial. apply PermutationT_refl.
+  - rewrite app_comm_cons. pose (IHl l').
+    apply permT_trans with (l':= (l' ++ l ++ [x])).
+    simpl. apply permT_trans with (l':= (x :: l' ++ l)).
+    apply permT_skip ; auto. pose (PermutationT_cons_append (l' ++ l) x).
+    rewrite <- app_assoc in p0 ; auto.
+    apply (PermutationT_app l'). apply PermutationT_refl.
+    apply PermutationT_sym , PermutationT_cons_append.
+Qed.
+Local Hint Resolve PermutationT_app_comm : core.
+ +
+Theorem PermutationT_cons_app : forall l l1 l2 a,
+  PermutationT l (l1 ++ l2) -> PermutationT (a :: l) (l1 ++ a :: l2).
+Proof.
+  intros l l1 l2 a H. apply permT_trans with (l':=(a :: (l1 ++ l2))).
+  apply permT_skip ; auto.
+  rewrite app_comm_cons. apply permT_trans with (l':=(a :: (l2 ++ l1))).
+  simpl. apply permT_skip ; auto. pose (PermutationT_app_comm (a :: l2) l1).
+  simpl in p ; auto.
+Qed.
+ +
+Lemma Permutation_vs_elt_invT : forall l l1 l2 (a : MPropF),
Permutation l (l1 ++ a :: l2) -> existsT2 l' l'', l = l' ++ a :: l''.
+Proof.
+  intros l l1 l2 a HP. apply Permutation_sym in HP.
+  assert (In a (l1 ++ a :: l2)). apply in_or_app ; right ; apply in_eq.
+  epose (Permutation_in a HP H). apply In_InT in i. apply InT_split in i.
+  auto.
+Qed.
+ +
+Lemma Permutation_vs_cons_invT : forall l l1 (a : MPropF),
+  Permutation l (a :: l1) -> existsT2 l' l'', l = l' ++ a :: l''.
+Proof.
+  intros l l1 a HP.
+  rewrite <- (app_nil_l (a :: l1)) in HP. apply Permutation_vs_elt_invT in HP. auto.
+Qed.
+ +
+    Theorem Permutation_PermutationT : forall l l', (Permutation l l' -> PermutationT l l') * (PermutationT l l' -> Permutation l l').
+    Proof.
+    intros l l'. split ; intros.
+    - revert H. revert l'. induction l.
+      + intros. destruct l'. apply permT_nil. apply Permutation_nil in H ; inversion H.
+      + intros. pose (Permutation_sym H). apply Permutation_vs_cons_invT in p. destruct p. destruct s. subst.
+         apply Permutation_cons_app_inv in H. apply IHl in H. apply PermutationT_cons_app ; auto.
+    - induction H.
+      + apply perm_nil.
+      + apply perm_skip ; auto.
+      + apply perm_swap ; auto.
+      + apply perm_trans with (l':=l') ; auto.
+    Qed.
+ +
+Theorem PermutationT_ind_T :
forall P : list MPropF -> list MPropF -> Type,
+   P [] [] ->
+   (forall x l l', PermutationT l l' -> P l l' -> P (x :: l) (x :: l')) ->
+   (forall x y l l', PermutationT l l' -> P l l' -> P (y :: x :: l) (x :: y :: l')) ->
+   (forall l l' l'', PermutationT l l' -> P l l' -> PermutationT l' l'' -> P l' l'' -> P l l'') ->
+   forall l l', PermutationT l l' -> P l l'.
+Proof.
+  intros P Hnil Hskip Hswap Htrans.
+  intros l l' ; induction 1 ; auto.
+  - apply Htrans with (x::y::l); auto.
+    + apply Hswap; auto. apply Permutation_PermutationT ; apply Permutation_refl.
+      induction l; auto. apply Hskip ; auto. apply Permutation_PermutationT ; apply Permutation_refl.
+    + apply Permutation_PermutationT ; apply Permutation_refl.
+    + apply Hskip; auto. apply Permutation_PermutationT ; apply Permutation_refl.
+      apply Hskip; auto. apply Permutation_PermutationT ; apply Permutation_refl.
+      induction l; auto. apply Hskip ; auto. apply Permutation_PermutationT ; apply Permutation_refl.
+  - eauto.
+Qed.
+ +
+  End PermutationT.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_PermutationTS.html b/GL.Interpolation.UIGL_PermutationTS.html new file mode 100644 index 0000000..e7b7281 --- /dev/null +++ b/GL.Interpolation.UIGL_PermutationTS.html @@ -0,0 +1,368 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_PermutationTS

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat Arith.
+Require Import Lia.
+ +
+Require Import general_export.
+ +
+Require Import GLS_export.
+ +
+Require Import UIGL_Def_measure.
+Require Import UIGL_Canopy.
+Require Import UIGL_irred_short.
+Require Import UIGL_PermutationT.
+Require Import UIGL_LexSeq.
+Require Import UIGL_basics.
+ +
+Definition PermutationTS (s sp : Seq) := (PermutationT (fst s) (fst sp)) * (PermutationT (snd s) (snd sp)).
+ +
+Theorem PermutationTS_sym : forall s sp, PermutationTS s sp -> PermutationTS sp s.
+Proof.
+unfold PermutationTS. intros. destruct H. apply Permutation_PermutationT in p.
+apply Permutation_PermutationT in p0. split.
+1-2: apply Permutation_PermutationT ; apply Permutation_sym ; auto.
+Qed.
+ +
+Theorem PermutationT_XBoxed_list : forall l0 l1, PermutationT l0 l1 -> PermutationT (XBoxed_list l0) (XBoxed_list l1).
+Proof.
+induction 1 ; simpl ; intuition.
+- apply Permutation_PermutationT ; apply Permutation_refl.
+- apply Permutation_PermutationT ; repeat apply perm_skip ; apply Permutation_PermutationT ; auto.
+- apply Permutation_PermutationT. epose (Permutation_app_swap_app (_ :: [_]) (_ :: [_])). simpl in p. apply p.
+- apply permT_trans with (l':=(XBoxed_list l')) ; auto.
+Qed.
+ +
+Theorem PermutationT_top_boxes : forall l0 l1, PermutationT l0 l1 -> PermutationT (top_boxes l0) (top_boxes l1).
+Proof.
+induction 1.
+- apply Permutation_PermutationT ; apply Permutation_refl.
+- destruct x ; simpl ; auto. apply Permutation_PermutationT ; repeat apply perm_skip ; apply Permutation_PermutationT ; auto.
+- destruct x ; destruct y ; simpl ; apply Permutation_PermutationT ; try apply Permutation_refl. apply perm_swap.
+- apply permT_trans with (l':=(top_boxes l')) ; auto.
+Qed.
+ +
+Theorem PermutationTS_prv_hpadm : forall s (D: GLS_prv s),
+          forall sp, PermutationTS s sp -> existsT2 (D0: GLS_prv sp), derrec_height D0 <= derrec_height D.
+Proof.
+intros s D. remember (derrec_height D) as n. revert Heqn. revert D. revert s. revert n.
+induction n as [n IH] using (well_founded_induction_type lt_wf).
+intros s0 D0. destruct D0.
+- intros. inversion f.
+- intros hei sp Perm. simpl in hei.
+  inversion g ; subst.
+  + inversion H ; subst.
+     assert (GLS_rules [] sp). apply IdP. destruct sp. destruct Perm. simpl in *. apply Permutation_PermutationT in p, p0.
+     assert (InT (# P) l0). apply In_InT. apply (Permutation_in _ p0). apply in_or_app ; right ; apply in_eq.
+     assert (InT (# P) l). apply In_InT. apply (Permutation_in _ p). apply in_or_app ; right ; apply in_eq.
+     apply InT_split in H0. apply InT_split in H1. destruct H0. destruct s. destruct H1. destruct s. subst ; apply IdPRule_I.
+     pose (dlNil GLS_rules (fun _ : Seq => False)).
+     epose (@derI _ _ (fun _ : Seq => False) _ _ X d0). exists d1. simpl. lia.
+  + inversion H ; subst.
+     assert (GLS_rules [] sp). apply BotL. destruct sp. destruct Perm. simpl in *. apply Permutation_PermutationT in p.
+     assert (InT Bot l). apply In_InT. apply (Permutation_in _ p). apply in_or_app ; right ; apply in_eq.
+     apply InT_split in H0. destruct H0. destruct s. subst ; apply BotLRule_I.
+     pose (dlNil GLS_rules (fun _ : Seq => False)).
+     epose (@derI _ _ (fun _ : Seq => False) _ _ X d0). exists d1. simpl. lia.
+  + inversion H ; subst. destruct sp. destruct Perm. simpl in *. apply Permutation_PermutationT in p0.
+     assert (InT (A --> B) l0). apply In_InT. apply (Permutation_in _ p0). apply in_or_app ; right ; apply in_eq.
+     apply InT_split in H0. destruct H0. destruct s. subst.
+     assert (GLS_rules [(A :: l, x ++ B :: x0)] (l, x ++ A --> B :: x0)). apply ImpR. eapply (ImpRRule_I _ _ []).
+     assert (dersrec_height d = dersrec_height d). auto. pose (dersrec_derrec_height d H0). destruct s ; subst.
+     assert (J0: derrec_height x1 < S (dersrec_height d)). lia.
+     assert (J1: derrec_height x1 = derrec_height x1). auto.
+     assert (J2: PermutationTS (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) (A :: l, x ++ B :: x0)).
+     split ; simpl ; apply Permutation_PermutationT ; apply Permutation_PermutationT in p.
+     apply Permutation_sym. apply Permutation_cons_app ; auto. apply Permutation_sym ; auto.
+     apply Permutation_elt. apply Permutation_app_inv in p0 ; auto.
+     pose (IH _ J0 _ _ J1 _ J2). destruct s. pose (dlCons x2 (dlNil _ _)).
+     epose (@derI _ _ (fun _ : Seq => False) _ _ X d0). exists d1. simpl. lia.
+  + inversion H ; subst. destruct sp. destruct Perm. simpl in *. apply Permutation_PermutationT in p0 , p.
+     assert (InT (A --> B) l). apply In_InT. apply (Permutation_in _ p). apply in_or_app ; right ; apply in_eq.
+     apply InT_split in H0. destruct H0. destruct s. subst.
+     assert (GLS_rules [(x ++ x0, A :: l0);(x ++ B :: x0, l0)] (x ++ A --> B :: x0, l0)). apply ImpL. eapply (ImpLRule_I _ _ x x0 []).
+     assert (dersrec_height d = dersrec_height d). auto. pose (dersrec_derrec2_height d H0). destruct s ; subst. destruct s.
+     assert (J0: derrec_height x1 < S (dersrec_height d)). lia.
+     assert (J1: derrec_height x1 = derrec_height x1). auto.
+     assert (J2: PermutationTS (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) (x ++ x0, A :: l0)).
+     split ; simpl ; apply Permutation_PermutationT.
+     apply Permutation_app_inv in p ; auto.
+     apply Permutation_sym. apply Permutation_cons_app ; auto. apply Permutation_sym ; auto.
+     pose (IH _ J0 _ _ J1 _ J2). destruct s.
+     assert (J3: derrec_height x2 < S (dersrec_height d)). lia.
+     assert (J4: derrec_height x2 = derrec_height x2). auto.
+     assert (J5: PermutationTS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) (x ++ B :: x0, l0)).
+     split ; simpl ; apply Permutation_PermutationT ; auto.
+     apply Permutation_elt. apply Permutation_app_inv in p ; auto.
+     pose (IH _ J3 _ _ J4 _ J5). destruct s. pose (dlCons x4 (dlNil _ _)). pose (dlCons x3 d0).
+     epose (@derI _ _ (fun _ : Seq => False) _ _ X d1). exists d2. simpl. lia.
+  + inversion X ; subst. destruct sp. destruct Perm. simpl in *. apply Permutation_PermutationT in p0 , p.
+     assert (InT (Box A) l0). apply In_InT. apply (Permutation_in _ p0). apply in_or_app ; right ; apply in_eq.
+     apply InT_split in H0. destruct H0. destruct s. subst.
+     assert (GLS_rules [(XBoxed_list (top_boxes l) ++ [Box A], [A])] (l, x ++ Box A :: x0)). apply GLR. apply GLRRule_I.
+     apply is_Boxed_list_top_boxes. apply nobox_gen_ext_top_boxes.
+     assert (dersrec_height d = dersrec_height d). auto. pose (dersrec_derrec_height d H0). destruct s ; subst.
+     assert (J0: derrec_height x1 < S (dersrec_height d)). lia.
+     assert (J1: derrec_height x1 = derrec_height x1). auto.
+     assert (J2: PermutationTS (XBoxed_list ++ [Box A], [A]) (XBoxed_list (top_boxes l) ++ [Box A], [A])).
+     split ; simpl ; apply Permutation_PermutationT. 2: apply Permutation_refl.
+     apply Permutation_app. 2: apply Permutation_refl.
+     pose (nobox_gen_ext_top_boxes_identity X0 H). rewrite e0. apply Permutation_PermutationT.
+     apply PermutationT_XBoxed_list. apply PermutationT_top_boxes ; apply Permutation_PermutationT ; auto.
+     pose (IH _ J0 _ _ J1 _ J2). destruct s. pose (dlCons x2 (dlNil _ _)).
+     epose (@derI _ _ (fun _ : Seq => False) _ _ X1 d0). exists d1. simpl. lia.
+Qed.
+ +
+Theorem PermutationTS_prv : forall s sp, PermutationTS s sp -> GLS_prv s -> GLS_prv sp.
+Proof.
+intros. destruct (PermutationTS_prv_hpadm _ X _ H) ; auto.
+Qed.
+ +
+Theorem PermutationTS_restr_list_prop_snd : forall s sp p A, PermutationTS s sp -> InT A (restr_list_prop p (snd s)) -> InT A (restr_list_prop p (snd sp)).
+Proof.
+unfold PermutationTS. intros. destruct H. apply Permutation_PermutationT in p0, p1.
+apply InT_In in H0. apply In_InT. unfold restr_list_prop in *. apply in_remove in H0 ; destruct H0.
+apply in_in_remove ; auto. apply In_list_prop_LF_bis in H. destruct H. apply list_prop_LF_In ; auto.
+apply (Permutation_in _ p1 i).
+Qed.
+ +
+Theorem PermutationTS_restr_list_prop_fst : forall s sp p A, PermutationTS s sp -> InT A (restr_list_prop p (fst s)) -> InT A (restr_list_prop p (fst sp)).
+Proof.
+unfold PermutationTS. intros. destruct H. apply Permutation_PermutationT in p0, p1.
+apply InT_In in H0. apply In_InT. unfold restr_list_prop in *. apply in_remove in H0 ; destruct H0.
+apply in_in_remove ; auto. apply In_list_prop_LF_bis in H. destruct H. apply list_prop_LF_In ; auto.
+apply (Permutation_in _ p0 i).
+Qed.
+ +
+Theorem PermutationTS_GLR_prems : forall s sp, PermutationTS s sp ->
+            (forall ps, InT ps (GLR_prems s) -> (existsT2 psp, PermutationTS ps psp * InT psp (GLR_prems sp))).
+Proof.
+intros. unfold GLR_prems in H0. destruct (finite_GLR_premises_of_S s). simpl in H0.
+apply InT_flatten_list_InT_elem in H0. destruct H0. destruct p0. apply p in i0. inversion i0 ; subst.
+destruct sp. destruct H. simpl in *. apply Permutation_PermutationT in p0, p1.
+assert (InT (Box A) l0). apply In_InT. apply (Permutation_in _ p1). apply in_or_app ; right ; apply in_eq.
+apply InT_split in H. destruct H. destruct s. subst.
+exists (XBoxed_list (top_boxes l) ++ [Box A], [A]). inversion i ; subst. 2: inversion H1. split.
+split ; simpl ; apply Permutation_PermutationT. 2: apply Permutation_refl.
+apply Permutation_app. 2: apply Permutation_refl.
+pose (nobox_gen_ext_top_boxes_identity X H0). rewrite e. apply Permutation_PermutationT.
+apply PermutationT_XBoxed_list. apply PermutationT_top_boxes ; apply Permutation_PermutationT ; auto.
+unfold GLR_prems. destruct (finite_GLR_premises_of_S (l, x0 ++ Box A :: x1)). simpl.
+apply InT_trans_flatten_list with (bs:=[(XBoxed_list (top_boxes l) ++ [Box A], [A])]).
+apply InT_eq. apply p2. apply GLRRule_I.
+apply is_Boxed_list_top_boxes. apply nobox_gen_ext_top_boxes.
+Qed.
+ +
+Theorem PermutationTS_is_init : forall s sp, PermutationTS s sp -> (is_init s -> is_init sp).
+Proof.
+unfold PermutationTS. intros. destruct H. apply Permutation_PermutationT in p, p0. destruct s. destruct sp.
+simpl in *. inversion X. inversion H.
+- inversion H0 ; subst.
+  assert (InT (# P) l2). apply In_InT. apply (Permutation_in _ p0). apply in_or_app ; right ; apply in_eq.
+  apply InT_split in H1. destruct H1. destruct s. subst.
+  assert (InT (# P) l1). apply In_InT. apply (Permutation_in _ p). apply in_or_app ; right ; apply in_eq.
+  apply InT_split in H1. destruct H1. destruct s. subst. left. left. apply IdPRule_I.
+- inversion H0 ; subst.
+  assert (InT (Box A) l2). apply In_InT. apply (Permutation_in _ p0). apply in_or_app ; right ; apply in_eq.
+  apply InT_split in H1. destruct H1. destruct s. subst.
+  assert (InT (Box A) l1). apply In_InT. apply (Permutation_in _ p). apply in_or_app ; right ; apply in_eq.
+  apply InT_split in H1. destruct H1. destruct s. subst. left. right. apply IdBRule_I.
+- inversion H ; subst.
+  assert (InT (Bot) l1). apply In_InT. apply (Permutation_in _ p). apply in_or_app ; right ; apply in_eq.
+  apply InT_split in H0. destruct H0. destruct s. subst. right. apply BotLRule_I.
+Qed.
+ +
+Theorem PermutationTS_critic : forall s sp, PermutationTS s sp -> (critical_Seq s -> critical_Seq sp).
+Proof.
+unfold PermutationTS. intros. destruct H. apply Permutation_PermutationT in p, p0. destruct s. destruct sp.
+simpl in *. unfold critical_Seq in * ; simpl in *. intros A HA. apply in_app_or in HA ; destruct HA.
+- assert (InT A l). apply In_InT. apply (Permutation_in _ (Permutation_sym p)) ; auto.
+  apply H0. apply in_or_app ; left ; apply InT_In ; auto.
+- assert (InT A l0). apply In_InT. apply (Permutation_in _ (Permutation_sym p0)) ; auto.
+  apply H0. apply in_or_app ; right ; apply InT_In ; auto.
+Qed.
+ +
+Theorem Permutation_subform_boxesLF : forall l0 l1, Permutation l0 l1 ->
+    (forall A, In A (subform_boxesLF l0) -> In A (subform_boxesLF l1)).
+Proof.
+induction 1 ; simpl ; intuition.
+- apply in_app_or in H0. apply in_or_app. destruct H0 ; auto. right.
+  apply In_remove_list_In_list_not_In_remove_list in H0. destruct H0.
+  apply not_removed_remove_list ; auto.
+- apply in_app_or in H. destruct H ; auto. apply remove_list_is_in. apply in_or_app ; auto.
+  apply In_remove_list_In_list_not_In_remove_list in H. destruct H.
+  apply in_app_or in H. destruct H ; auto. apply in_or_app ; auto.
+  apply In_remove_list_In_list_not_In_remove_list in H. destruct H.
+  apply remove_list_is_in. apply remove_list_is_in ; auto.
+Qed.
+ +
+Theorem PermutationTS_usable_boxes : forall s sp, PermutationTS s sp ->
+    (forall A, InT A (usable_boxes s) -> InT A (usable_boxes sp)).
+Proof.
+unfold PermutationTS. intros. destruct H. apply Permutation_PermutationT in p, p0. destruct s. destruct sp.
+simpl in *. unfold usable_boxes in *. simpl in *. apply InT_In in H0. apply In_InT.
+apply In_remove_list_In_list_not_In_remove_list in H0. destruct H0.
+apply not_removed_remove_list ; auto.
+unfold subform_boxesS in * ; simpl in *. apply in_or_app.
+apply in_app_or in H. destruct H. left.
+apply Permutation_subform_boxesLF with (l0:=l) ; auto.
+right. apply In_remove_list_In_list_not_In_remove_list in H. destruct H.
+apply not_removed_remove_list.
+apply Permutation_subform_boxesLF with (l0:=l0) ; auto.
+intro. apply H1.
+apply Permutation_subform_boxesLF with (l0:=l1) ; auto. apply Permutation_sym ; auto.
+intro. apply H0. pose (in_top_boxes _ _ H1). repeat destruct s.
+destruct p1. clear e0 ; subst. apply is_box_in_top_boxes. 2: eexists ; auto.
+apply top_boxes_incl_list in H1. apply (Permutation_in _ (Permutation_sym p) H1).
+Qed.
+ +
+Theorem PermutationTS_Canopy : forall s sp, PermutationTS s sp ->
+      (forall sc, InT sc (Canopy s) -> existsT2 spc, InT spc (Canopy sp) * PermutationTS sc spc).
+Proof.
+  intros s0 ; induction on s0 as IH with measure (n_imp_subformS s0).
+  intros s1 perm sp InClos.
+  pose (fold_Canopy _ _ InClos). destruct s ; subst ; auto.
+  - exists s1. split ; auto. apply Canopy_critical in InClos. apply critical_Seq_InT_Canopy.
+    apply (PermutationTS_critic _ _ perm) ; auto.
+  - destruct s. destruct p. unfold inv_prems in i. apply InT_flatten_list_InT_elem in i. destruct i.
+    destruct p. destruct (finite_ImpRules_premises_of_S s0). simpl in i1.
+    apply p in i1. destruct i1. inversion i1 ; subst.
+    (* x0 is obtained via ImpR. *)
+    + inversion i ; subst. 2: inversion H0. assert (InT (A --> B) (snd s1)).
+       apply In_InT. apply Permutation_in with (l:=Δ0 ++ A --> B :: Δ1). destruct perm ; simpl in * ; auto.
+       apply Permutation_PermutationT in p1 ; auto. apply in_or_app ; right ; apply in_eq.
+       apply InT_split in H. destruct H. destruct s. subst.
+       assert (J1: n_imp_subformS (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) < n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)).
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       assert (J2: PermutationTS (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) (A :: fst s1, x ++ B :: x0)).
+       unfold PermutationTS. destruct perm ; simpl in * ; split. apply Permutation_PermutationT. apply Permutation_sym.
+       apply Permutation_cons_app ; apply Permutation_sym ; auto. apply Permutation_PermutationT in p0 ; auto.
+       apply Permutation_PermutationT. apply Permutation_PermutationT in p1. rewrite e in p1.
+       apply Permutation_app_inv in p1. apply Permutation_elt ; auto.
+       pose (IH _ J1 _ J2 _ i0). destruct s. destruct p0. exists x2 ; split ; auto.
+       assert (ImpRRule [(A :: fst s1, x ++ B :: x0)] s1 + ImpLRule [(A :: fst s1, x ++ B :: x0)] s1).
+       left. destruct s1. epose (ImpRRule_I _ _ [] _ _ _). simpl in * ; subst ; simpl in *. apply i3.
+       assert (InT (A :: fst s1, x ++ B :: x0) [(A :: fst s1, x ++ B :: x0)]). apply InT_eq.
+       pose (ImpRule_Canopy _ _ H _ H0). apply i3 ; auto.
+    + inversion i1 ; subst. assert (InT (A --> B) (fst s1)). apply In_InT. apply Permutation_in with (l:=Γ0 ++ A --> B :: Γ1). destruct perm ; simpl in * ; auto.
+       apply Permutation_PermutationT in p0 ; auto. apply in_or_app ; right ; apply in_eq.
+       apply InT_split in H. destruct H. destruct s. inversion i ; subst.
+       (* x is the left premise via ImpL. *)
+       * assert (J1: n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+         unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+         assert (J2: PermutationTS (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) (x0 ++ x2, A :: snd s1)).
+         unfold PermutationTS. destruct perm ; simpl in * ; split.
+         apply Permutation_PermutationT. apply Permutation_PermutationT in p0. rewrite e in p0.
+         apply Permutation_app_inv in p0 ; auto.
+         apply Permutation_PermutationT. apply Permutation_sym.
+         apply Permutation_cons_app ; apply Permutation_sym ; auto. apply Permutation_PermutationT in p1 ; auto.
+         pose (IH _ J1 _ J2 _ i0). destruct s. destruct p0. exists x ; split ; auto.
+         assert (ImpRRule [(x0 ++ x2, A :: snd s1);(x0 ++ B :: x2, snd s1)] s1 + ImpLRule [(x0 ++ x2, A :: snd s1);(x0 ++ B :: x2, snd s1)] s1).
+         right. destruct s1. epose (ImpLRule_I _ _ _ _ [] _). simpl in * ; subst ; simpl in *. apply i3.
+         assert (InT (x0 ++ x2, A :: snd s1) [(x0 ++ x2, A :: snd s1); (x0 ++ B :: x2, snd s1)]). apply InT_eq.
+         pose (ImpRule_Canopy _ _ H _ H0). apply i3 ; auto.
+       (* x is the right premise via ImpL. *)
+       * inversion H0 ; subst. 2: inversion H1.
+         assert (J1: n_imp_subformS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+         unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+         assert (J2: PermutationTS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) (x0 ++ B :: x2, snd s1)).
+         unfold PermutationTS. destruct perm ; simpl in * ; split.
+         apply Permutation_PermutationT. apply Permutation_PermutationT in p0. rewrite e in p0.
+         apply Permutation_app_inv in p0 ; auto. apply Permutation_elt ; auto.
+         apply Permutation_PermutationT ; apply Permutation_PermutationT in p1 ; auto.
+         pose (IH _ J1 _ J2 _ i0). destruct s. destruct p0. exists x ; split ; auto.
+         assert (ImpRRule [(x0 ++ x2, A :: snd s1);(x0 ++ B :: x2, snd s1)] s1 + ImpLRule [(x0 ++ x2, A :: snd s1);(x0 ++ B :: x2, snd s1)] s1).
+         right. destruct s1. epose (ImpLRule_I _ _ _ _ [] _). simpl in * ; subst ; simpl in *. apply i3.
+         assert (InT (x0 ++ B :: x2, snd s1) [(x0 ++ x2, A :: snd s1); (x0 ++ B :: x2, snd s1)]). apply InT_cons ; apply InT_eq.
+         pose (ImpRule_Canopy _ _ H _ H1). apply i3 ; auto.
+Qed.
+ +
+Lemma PermutationT_nodupseq : forall l0 l1, PermutationT l0 l1 -> PermutationT (nodup eq_dec_form l0) (nodup eq_dec_form l1).
+Proof.
+intros. apply Permutation_PermutationT. apply Permutation_PermutationT in H.
+revert H. revert l1. revert l0.
+epose (@Permutation_ind_bis _ (fun l0 l1 => Permutation (nodup eq_dec_form l0) (nodup eq_dec_form l1))).
+apply p ; clear p ; intros.
+- simpl. apply perm_nil.
+- simpl. destruct (in_dec eq_dec_form x l). destruct (in_dec eq_dec_form x l') ; auto.
+  exfalso. apply n. apply (Permutation_in _ H) ; auto. destruct (in_dec eq_dec_form x l') ; auto.
+  exfalso. apply n. apply Permutation_sym in H. apply (Permutation_in _ H) ; auto.
+- simpl. destruct (eq_dec_form x y) ; subst ; simpl. destruct (eq_dec_form y y). 2: exfalso ; auto.
+  destruct (in_dec eq_dec_form y l) ; auto. destruct (in_dec eq_dec_form y l') ; auto.
+  exfalso. apply n. apply (Permutation_in _ H) ; auto. destruct (in_dec eq_dec_form y l') ; auto.
+  exfalso. apply n. apply Permutation_sym in H. apply (Permutation_in _ H) ; auto.
+  destruct (in_dec eq_dec_form y l). destruct (in_dec eq_dec_form x l). destruct (eq_dec_form y x).
+  exfalso ; auto. destruct (in_dec eq_dec_form x l'). destruct (in_dec eq_dec_form y l') ; auto.
+  exfalso. apply n1. apply (Permutation_in _ H) ; auto. exfalso. apply n1. apply (Permutation_in _ H) ; auto.
+  destruct (eq_dec_form y x). exfalso ; auto. destruct (in_dec eq_dec_form x l').
+  exfalso. apply n0. apply Permutation_sym in H. apply (Permutation_in _ H) ; auto.
+  destruct (in_dec eq_dec_form y l'). apply perm_skip ; auto. exfalso.
+  apply n3. apply (Permutation_in _ H) ; auto. destruct (in_dec eq_dec_form x l).
+  destruct (eq_dec_form y x). exfalso ; auto. destruct (in_dec eq_dec_form x l').
+  destruct (in_dec eq_dec_form y l') ; auto. exfalso. apply n0. apply Permutation_sym in H. apply (Permutation_in _ H) ; auto.
+  exfalso. apply n2. apply (Permutation_in _ H) ; auto. destruct (eq_dec_form y x).
+  exfalso ; auto. destruct (in_dec eq_dec_form x l'). exfalso. apply n1. apply Permutation_sym in H. apply (Permutation_in _ H) ; auto.
+  destruct (in_dec eq_dec_form y l'). exfalso. apply n0. apply Permutation_sym in H. apply (Permutation_in _ H) ; auto.
+  pose (@Permutation_cons_app _ (x :: nodup eq_dec_form l) [x] (nodup eq_dec_form l') y). simpl in p. apply p.
+  clear p. apply perm_skip ; auto.
+- apply (perm_trans H0 H2) ; auto.
+Qed.
+ +
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_UIDiam_N.html b/GL.Interpolation.UIGL_UIDiam_N.html new file mode 100644 index 0000000..b8d2ec8 --- /dev/null +++ b/GL.Interpolation.UIGL_UIDiam_N.html @@ -0,0 +1,113 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_UIDiam_N

+ +
+  Require Import List.
+  Export ListNotations.
+  Require Import PeanoNat.
+  Require Import Lia.
+ +
+  Require Import general_export.
+ +
+  Require Import GLS_export.
+ +
+  Require Import UIGL_Def_measure.
+  Require Import UIGL_Canopy.
+  Require Import UIGL_irred_short.
+  Require Import UIGL_braga.
+  Require Import UIGL_LexSeq.
+  Require Import UIGL_nodupseq.
+  Require Import UIGL_UI_prelims.
+  Require Import UIGL_UI_inter.
+  Require Import UIGL_Diam_N_imp_UI.
+  Require Import UIGL_Diam_UI_imp_N.
+ +
+    Section UIPDiam.
+ +
+  Theorem Diam_rec_UI : forall s p X Y, (is_init s -> False) -> (critical_Seq s) ->
+              (GLS_prv (X, Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) :: Y) ->
+               GLS_prv (X, Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list)) :: Y) ) *
+
+              (GLS_prv (X, Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list)) :: Y) ->
+               GLS_prv (X, Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) :: Y)).
+  Proof.
+  intros. split ; intros.
+ +
+  pose (Diam_rec_UI_imp _ p X Y H H0).
+  apply ImpR_inv with (prem:=([] ++ Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) :: X,
+  [] ++ Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list)) :: Y)) in g.
+  pose (GLS_cut_adm (Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))))
+  [] X [] (Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list)) :: Y)). simpl in g0. apply g0. clear g0.
+  clear g.
+  assert (wkn_R (Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list))) (X, [Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))] ++ Y)
+  (X, [Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))] ++ Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list)) :: Y)).
+  apply wkn_RI.
+  pose (@GLS_prv_wkn_R (X, [Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))] ++ Y)
+  X0 _ _ H1). auto.
+  simpl in g ; auto.
+  assert ((X, Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) --> Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list)) :: Y) =
+  ([] ++ X, [] ++ Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) --> Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list)) :: Y)).
+  auto. rewrite H1. apply ImpRRule_I.
+ +
+  pose (UI_Diam_rec_imp _ p X Y H H0).
+  apply ImpR_inv with (prem:=([] ++ Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list)) :: X,
+  [] ++ Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) :: Y)) in g.
+  pose (GLS_cut_adm (Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list)))
+  [] X [] (Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) :: Y)). simpl in g0. apply g0. clear g0.
+  clear g.
+  assert (wkn_R (Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))) (X, [Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list))] ++ Y)
+  (X, [Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list))] ++ Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) :: Y)).
+  apply wkn_RI.
+  pose (@GLS_prv_wkn_R (X, [Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list))] ++ Y)
+  X0 _ _ H1). auto.
+  simpl in g ; auto.
+  assert ((X, Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list)) --> Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) :: Y) =
+  ([] ++ X, [] ++ Diam (UI p (XBoxed_list (top_boxes (fst s)), []%list)) --> Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) :: Y)).
+  auto. rewrite H1. apply ImpRRule_I.
+  Qed.
+ +
+    End UIPDiam.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_UIOne.html b/GL.Interpolation.UIGL_UIOne.html new file mode 100644 index 0000000..e54ee5d --- /dev/null +++ b/GL.Interpolation.UIGL_UIOne.html @@ -0,0 +1,233 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_UIOne

+ +
+(* First property of uniform interpolation *)
+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+Require Import String.
+Require Import general_export.
+ +
+Require Import GLS_export.
+ +
+Require Import UIGL_Def_measure.
+Require Import UIGL_Canopy.
+Require Import UIGL_irred_short.
+Require Import UIGL_braga.
+Require Import UIGL_LexSeq.
+Require Import UIGL_nodupseq.
+Require Import UIGL_And_Or_rules.
+Require Import UIGL_UI_prelims.
+ +
+  Section UIPOne.
+ +
+  (* The formula defined by the function UI satisfies all the properties of
+      uniform interpolation. *)

+ +
+  Theorem UI_One : forall s p q, In (Var q) (propvar_subform (UI p (fst s, snd s))) ->
+                                                      ((q <> p) * (In (Var q) (propvar_subform_list (fst s ++ snd s)))).
+  Proof.
+  pose (LexSeq_ind (fun s => forall p q, In (Var q) (propvar_subform (UI p (fst s, snd s))) ->
+                                                      ((q <> p) * (In (Var q) (propvar_subform_list (fst s ++ snd s)))))).
+  apply p. clear p.
+  intros s0 H p q H0. rewrite propvar_subform_list_app.
+  destruct (empty_seq_dec s0).
+  (* s is the empty sequent. *)
+  { subst ; simpl in *. assert (GUI p ([],[]) Bot). apply GUI_empty_seq ; auto. apply UI_GUI in H1.
+    rewrite H1 in *. simpl in H0. inversion H0. }
+  { destruct (critical_Seq_dec s0).
+  (* s0 is a critical sequent *)
+  - destruct (dec_init_rules s0).
+    (* s0 is an initial sequent *)
+    + assert (is_init s0) ; auto.
+       assert (GUI p s0 Top). apply GUI_critic_init ; auto. apply UI_GUI in H1.
+       destruct s0. simpl in H0. rewrite H1 in H0. simpl in H0. inversion H0.
+    (* s0 is not an initial sequent *)
+    + remember (fst s0) as LHS.
+       assert (GUI p s0
+       (Or (list_disj (restr_list_prop p (snd s0)))
+       (Or (list_disj (map Neg (restr_list_prop p (fst s0))))
+       (Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s0)))))
+       (Diam (list_conj (map (N p s0) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s0)), []%list)))))))))).
+       apply GUI_critic_not_init ; auto. 1-2: apply Gimap_map ; intros. apply UI_GUI ; auto.
+       apply (@N_spec p s0 x). apply UI_GUI in H1. destruct s0. rewrite HeqLHS in H0 ; simpl in H0. rewrite H1 in H0. simpl in H0.
+       repeat rewrite app_nil_r in H0. clear H1. rewrite HeqLHS ; simpl.
+       apply in_app_or in H0. destruct H0.
+ +
+       apply propvar_subform_list_disj in H0.
+       apply propvar_subform_list_restr_list_prop in H0. destruct H0 ; split ; auto. apply in_or_app ; auto.
+ +
+       apply in_app_or in H0 ; destruct H0. apply propvar_subform_list_disj in H0. apply propvar_subform_list_witness in H0.
+       destruct H0. destruct H0. apply in_map_iff in H0. destruct H0. destruct H0 ; subst. simpl in H1.
+       rewrite app_nil_r in H1. unfold restr_list_prop in H2. apply in_remove in H2. destruct H2.
+       pose (In_list_prop_LF _ _ H0). destruct p0. destruct s. subst. simpl in H1. destruct H1. inversion H1. subst.
+       destruct (string_dec q p). exfalso ; apply H2 ; subst ; auto. split ; auto. apply in_or_app ; left.
+       apply list_prop_LF_propvar_subform_list in H0 ; auto. inversion H1.
+ +
+       apply in_app_or in H0 ; destruct H0. apply propvar_subform_list_disj in H0. apply propvar_subform_list_witness in H0.
+       destruct H0. destruct H0. apply in_map_iff in H0. destruct H0. destruct H0 ; subst. simpl in H1.
+       apply in_map_iff in H2. destruct H2. destruct H0 ; subst. assert (In # q (propvar_subform (UI p (fst x, snd x)))).
+       destruct x ; auto. apply H in H0. destruct H0 ; split ; auto.
+       unfold GLR_prems in H2. destruct (finite_GLR_premises_of_S (nodupseq (l, l0))). simpl in H2.
+       apply In_InT_seqs in H2. apply InT_flatten_list_InT_elem in H2. destruct H2. destruct p1.
+       apply p0 in i1. inversion i1 ; subst. inversion i0 ; subst. 2: inversion X0. simpl in i. repeat rewrite propvar_subform_list_app.
+       simpl ; repeat rewrite propvar_subform_list_app.
+       repeat rewrite propvar_subform_list_app in i. apply in_app_or in i ; destruct i. apply in_app_or in H0 ; destruct H0.
+       apply in_or_app ; left. apply propvar_subform_list_XBoxed_list in H0.
+       pose (propvar_subform_list_nobox_gen_ext _ _ X _ H0). apply propvar_subform_list_nodup ; auto.
+       simpl in H0. rewrite app_nil_r in H0.
+       apply in_or_app ; right. apply propvar_subform_list_nodup ; rewrite <- H4 ; repeat rewrite propvar_subform_list_app ;
+       apply in_or_app ; right ; apply in_or_app ; auto. simpl in H0. rewrite app_nil_r in H0.
+       apply in_or_app ; right. apply propvar_subform_list_nodup ; rewrite <- H4 ; repeat rewrite propvar_subform_list_app ;
+       apply in_or_app ; right ; apply in_or_app ; auto.
+       unfold GLR_prems in H2. destruct (finite_GLR_premises_of_S (nodupseq (l, l0))). simpl in H2.
+       apply In_InT_seqs in H2. apply InT_flatten_list_InT_elem in H2. destruct H2. destruct p1.
+       apply p0 in i0. inversion i0 ; subst. inversion i ; subst. 2: inversion X0. apply DLW_wf_lex.lex_cons ; auto.
+       pose (GLR_applic_less_usable_boxes i0). rewrite <- ub_nodupseq in l1. apply l1 ; auto.
+       assert (is_init (l,l0) -> False) ; auto. pose (is_init_nodupseq (l,l0)). destruct p1. intro.
+       assert (is_init (nodupseq (l, l0))) ; auto. unfold is_init ; auto.
+ +
+       apply propvar_subform_list_conj in H0. apply propvar_subform_list_witness in H0.
+       destruct H0. destruct H0. apply in_map_iff in H0. destruct H0. destruct H0 ; subst.
+ +
+       pose (@N_spec p (l,l0) x0). destruct (dec_init_rules x0).
+       (* If x0 is initial. *)
+       assert (is_init x0) ; unfold is_init ; auto. pose (GN_inv_init _ g). rewrite <- e in H1 ; auto. simpl in H1. inversion H1.
+       (* If x0 is not initial. *)
+       destruct (Compare_dec.lt_dec (length (usable_boxes x0)) (length (usable_boxes (l, l0)))).
+       (* If x0 has less usable boxes than (XBoxed_list (top_boxes l), ). *)
+       assert ((forall (x : Seq) (l m : MPropF), (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x l -> (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x m -> l = m)).
+       intros. subst. auto. assert ((is_init x0 -> False)) ; auto.
+       epose (@GN_inv_noinit_lessub _ _ _ _ _ g H3 l1 (UI_spec p x0)). rewrite <- e in H1 ; auto. clear e.
+       assert (In # q (propvar_subform (UI p (fst x0, snd x0)))). destruct x0 ; simpl ; auto.
+       apply H in H4. destruct H4 ; split ; auto.
+       apply propvar_subform_list_Canopy with (A:=# q) in H2 ; auto. simpl in H2. rewrite app_nil_r in H2.
+       apply in_or_app ; left.
+       assert (J30: In # q (propvar_subform_list (XBoxed_list (top_boxes l)))). apply propvar_subform_list_nodup ; auto.
+       apply propvar_subform_list_XBoxed_list in J30. apply propvar_subform_list_top_boxes ; auto.
+       apply DLW_wf_lex.lex_cons ; auto.
+       (* If x0 does not have less usable boxes than (XBoxed_list (top_boxes l), ). *)
+       assert ((forall (x : Seq) (l m : MPropF), (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x l -> (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x m -> l = m)).
+       intros. subst. auto.
+       assert (J1: Gimap (GUI p) (GLR_prems (nodupseq x0)) (map (UI p) (GLR_prems (nodupseq x0)))).
+       apply Gimap_map ; auto. intros ; apply UI_GUI ; auto. assert ((is_init x0 -> False)) ; auto.
+       pose (@GN_inv_noinit_nolessub p _ _ _ _ g H3 n0 J1).
+       rewrite <- e in H1. clear e. clear J1. clear H0. simpl in H1. repeat rewrite app_nil_r in H1. apply in_app_or in H1.
+       destruct H1. apply propvar_subform_list_disj in H0. apply propvar_subform_list_restr_list_prop in H0. destruct H0 ; split ; auto.
+       apply propvar_subform_list_Canopy with (A:=# q) in H2 ; auto. simpl in H2. rewrite app_nil_r in H2.
+       apply in_or_app ; left.
+       assert (J30: In # q (propvar_subform_list (XBoxed_list (top_boxes l)))). apply propvar_subform_list_nodup ; auto.
+       apply propvar_subform_list_XBoxed_list in J30. apply propvar_subform_list_top_boxes ; auto.
+       rewrite propvar_subform_list_app. apply in_or_app ;auto.
+       apply in_app_or in H0. destruct H0. apply propvar_subform_list_disj in H0. apply propvar_subform_list_witness in H0.
+       destruct H0. destruct H0. apply In_InT in H0. apply InT_map_iff in H0. destruct H0. destruct p0 ; subst. simpl in H1.
+       rewrite app_nil_r in H1. unfold restr_list_prop in i. apply InT_In in i. apply in_remove in i. destruct i.
+       pose (In_list_prop_LF _ _ H0). destruct p0. destruct s. subst. simpl in H1. destruct H1. inversion H1. subst.
+       destruct (string_dec q p). exfalso ; apply H4 ; subst ; auto. split ; auto. apply in_or_app ; left.
+       apply list_prop_LF_propvar_subform_list in H0 ; auto. apply propvar_subform_list_Canopy with (A:=# q) in H2 ; auto.
+       simpl in H2. rewrite app_nil_r in H2.
+       assert (J30: In # q (propvar_subform_list (XBoxed_list (top_boxes l)))). apply propvar_subform_list_nodup ; auto.
+       apply propvar_subform_list_XBoxed_list in J30. apply propvar_subform_list_top_boxes ; auto.
+       rewrite propvar_subform_list_app. apply in_or_app ;auto. inversion H1.
+       apply propvar_subform_list_disj in H0. apply propvar_subform_list_witness in H0.
+       destruct H0. destruct H0. apply In_InT in H0. apply InT_map_iff in H0. destruct H0. destruct p0 ; subst. simpl in H1.
+       apply InT_map_iff in i. destruct i. destruct p0 ; subst. assert (In # q (propvar_subform (UI p (fst x, snd x)))).
+       destruct x ; simpl ; auto. apply H in H0. destruct H0 ; split ; auto.
+       unfold GLR_prems in i. destruct (finite_GLR_premises_of_S (nodupseq x0)). simpl in i.
+       apply InT_flatten_list_InT_elem in i. destruct i. destruct p1.
+       apply p0 in i1. inversion i1 ; subst. inversion i ; subst. 2: inversion H4. simpl in i0.
+       repeat rewrite propvar_subform_list_app in i0. simpl in i0. repeat rewrite app_nil_r in i0.
+       apply in_app_or in i0 ; destruct i0. apply in_app_or in H0 ; destruct H0.
+       apply in_or_app ; left. apply propvar_subform_list_XBoxed_list in H0.
+       pose (propvar_subform_list_nobox_gen_ext _ _ X _ H0). rewrite propvar_subform_list_nodup in i0 ; auto.
+       apply propvar_subform_list_Canopy with (A:=# q) in H2 ; auto. simpl in H2. rewrite app_nil_r in H2.
+       assert (J30: In # q (propvar_subform_list (XBoxed_list (top_boxes l)))). apply propvar_subform_list_nodup ; auto.
+       apply propvar_subform_list_XBoxed_list in J30. apply propvar_subform_list_top_boxes ; auto.
+       rewrite propvar_subform_list_app. apply in_or_app ;auto.
+       apply propvar_subform_list_Canopy with (A:=# q) in H2 ; auto. simpl in H2. rewrite app_nil_r in H2.
+       assert (J30: In # q (propvar_subform_list (XBoxed_list (top_boxes l)))). apply propvar_subform_list_nodup ; auto.
+       apply propvar_subform_list_XBoxed_list in J30. apply in_or_app ; left. apply propvar_subform_list_top_boxes ; auto.
+       simpl. repeat rewrite propvar_subform_list_app ; simpl. apply in_or_app ; right. apply propvar_subform_list_nodup ; auto.
+       rewrite <- H6. repeat rewrite propvar_subform_list_app ; simpl. apply in_or_app ; right ; apply in_or_app ; auto.
+       apply propvar_subform_list_Canopy with (A:=# q) in H2 ; auto. simpl in H2. rewrite app_nil_r in H2.
+       assert (J30: In # q (propvar_subform_list (XBoxed_list (top_boxes l)))). apply propvar_subform_list_nodup ; auto.
+       apply propvar_subform_list_XBoxed_list in J30. apply in_or_app ; left. apply propvar_subform_list_top_boxes ; auto.
+       simpl. repeat rewrite propvar_subform_list_app ; simpl. apply in_or_app ; right. apply propvar_subform_list_nodup ; auto.
+       rewrite <- H6. repeat rewrite propvar_subform_list_app ; simpl. apply in_or_app ; right ; apply in_or_app ; auto.
+       apply DLW_wf_lex.lex_cons ; auto. unfold GLR_prems in i. destruct (finite_GLR_premises_of_S (nodupseq x0)). simpl in i.
+       apply InT_flatten_list_InT_elem in i. destruct i. destruct p1.
+       apply p0 in i0. inversion i0 ; subst. inversion i ; subst. 2: inversion H5.
+       pose (GLR_applic_less_usable_boxes i0). rewrite <- ub_nodupseq in l1.
+       apply In_InT_seqs in H2 ; apply leq_ub_Canopy in H2. pose (set_leq_ub_unif (l, l0)). simpl in l1. simpl in l2.
+       assert (length (usable_boxes (XBoxed_list ++ [Box A], [A])) < length (usable_boxes x0)). apply l1 ; auto.
+       pose (is_init_nodupseq x0). destruct p1. intro. assert (is_init (nodupseq x0)) ; auto. unfold is_init ; auto.
+       lia.
+  (* s0 is not a critical sequent *)
+  - assert (GUI p s0 (list_conj (map (UI p) (Canopy (nodupseq s0))))). apply GUI_not_critic ; auto.
+    apply Gimap_map ; intros ; apply UI_GUI ; auto. apply UI_GUI in H1. destruct s0.
+    simpl in H0. rewrite H1 in H0. apply propvar_subform_list_conj in H0.
+    apply propvar_subform_list_witness in H0. destruct H0. destruct H0. apply in_map_iff in H0.
+    destruct H0. destruct H0 ; subst. simpl. assert (In # q (propvar_subform (UI p (fst x0, snd x0)))).
+    destruct x0 ; auto. pose (In_InT_seqs _ _ H3). apply Canopy_LexSeq in i. destruct i ; subst.
+    simpl in H0. exfalso. apply f. apply In_InT_seqs in H3 ; apply Canopy_critical in H3 ; auto.
+    apply critical_nodupseq ; auto.
+    apply H in H0 ; auto. destruct H0 ; split ; auto.
+    apply propvar_subform_list_Canopy with (A:=# q) in H3 ; auto.
+    simpl in H3 ; rewrite propvar_subform_list_app in H3 ; auto.
+    apply in_app_or in H3 ; destruct H3. apply in_or_app ; left. apply propvar_subform_list_nodup ; auto.
+    apply in_or_app ; right. apply propvar_subform_list_nodup ; auto.
+    apply LexSeq_nodupseq ; auto. }
+  Qed.
+ +
+  End UIPOne.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_UIThree.html b/GL.Interpolation.UIGL_UIThree.html new file mode 100644 index 0000000..5db3be7 --- /dev/null +++ b/GL.Interpolation.UIGL_UIThree.html @@ -0,0 +1,808 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_UIThree

+ +
+(* Uniform interpolation *)
+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat Arith.
+Require Import Lia.
+ +
+Require Import general_export.
+ +
+Require Import GLS_export.
+ +
+Require Import UIGL_Def_measure.
+Require Import UIGL_Canopy.
+Require Import UIGL_irred_short.
+Require Import UIGL_braga.
+Require Import UIGL_LexSeq.
+Require Import UIGL_nodupseq.
+Require Import UIGL_PermutationT.
+Require Import UIGL_PermutationTS.
+Require Import UIGL_And_Or_rules.
+Require Import UIGL_UI_prelims.
+Require Import UIGL_UI_inter.
+Require Import UIGL_UIDiam_N.
+ +
+  Section UIPThree.
+ +
+  Theorem UI_Three : forall s p X0 Y0,
+                                    (In (Var p) (propvar_subform_list (X0 ++ Y0)) -> False) ->
+                                    GLS_prv (fst s ++ X0, snd s ++ Y0) ->
+                                    GLS_prv (X0, (UI p s) :: Y0).
+  Proof.
+  (* Setting up the strong induction on the height of the derivation (PIH) and
+      on the measure of the sequent using LexSeq (SIH). *)

+  intros s p X0 Y0 NotVar D. generalize dependent NotVar. remember (fst s ++ X0, snd s ++ Y0) as scomp.
+  generalize dependent Heqscomp. remember (derrec_height D) as n. generalize dependent Heqn.
+  generalize dependent Y0. generalize dependent X0. generalize dependent D.
+  generalize dependent scomp. generalize dependent s. generalize dependent n.
+  induction n as [n PIH] using (well_founded_induction_type lt_wf).
+  pose (d:=LexSeq_ind (fun (s:Seq) => forall (scomp : list MPropF * list MPropF) (D : GLS_prv scomp) (X0 Y0 : list MPropF),
+                n = derrec_height D ->
+                scomp = (fst s ++ X0, snd s ++ Y0) -> (In # p (propvar_subform_list (X0 ++ Y0)) -> False) -> GLS_prv (X0, UI p s :: Y0))).
+  apply d. clear d. intros k SIH.
+ +
+  (* Now we do the actual proof-theoretical work. *)
+  intros s0 D0. remember D0 as D0'. destruct D0.
+  (* D0 is a leaf *)
+  - inversion f.
+  (* D0 ends with an application of rule *)
+  - intros X0 Y0 hei idseq propvar. destruct (empty_seq_dec k) as [ EE | NE].
+    { subst ; simpl in *.
+       assert (J1: GLS_prv (X0, Y0)). apply derI with ps ; auto. apply GLS_prv_wkn_R with (X0, Y0) (UI p ([], [])) ; auto.
+       apply (wkn_RI _ _ []). }
+    { inversion g ; subst.
+    (* IdP *)
+    * inversion H ; subst.
+      assert (InT (# P) (fst k ++ X0)). rewrite <- H2. apply InT_or_app ; right ; apply InT_eq.
+      apply InT_app_or in H0.
+      assert (InT (# P) (snd k ++ Y0)). rewrite <- H3. apply InT_or_app ; right ; apply InT_eq.
+      apply InT_app_or in H1. destruct H0 ; destruct H1.
+      + assert ((X0, UI p k :: Y0) = (X0, [] ++ UI p k :: Y0)). auto. rewrite H0. apply is_init_UI.
+         left ; left. destruct k. simpl in i ; simpl in i0. apply InT_split in i. destruct i. destruct s ; subst.
+         apply InT_split in i0. destruct i0. destruct s ; subst. apply IdPRule_I.
+      + destruct (critical_Seq_dec k).
+         -- destruct (dec_init_rules k).
+            ** assert (is_init k) ; auto. assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+                pose (@GUI_inv_critic_init p k _ J0 c X). rewrite <- e.
+                assert ((X0, Top :: Y0) = (X0, [] ++ Top :: Y0)). auto. rewrite H0. apply TopR.
+            ** assert ((is_init k) -> False) ; auto. assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+                assert (J1: Gimap (GUI p) (GLR_prems (nodupseq k)) (map (UI p) (GLR_prems (nodupseq k)))). apply Gimap_map. intros.
+                apply UI_GUI ; auto.
+                assert (J2: (Gimap (GN p (GUI p) k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), [])))
+                (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), [])))))). apply Gimap_map. intros.
+                apply (N_spec p k x).
+                assert (J40: fst k <> []). intro. rewrite H1 in i ; inversion i.
+                pose (@GUI_inv_critic_not_init p k _ _ _ J0 c NE H0 J1 J2). rewrite <- e.
+                pose (OrR (X0,Y0)). simpl in g0. apply g0.
+                apply (@GLS_adm_list_exch_R (X0,
+                Or (list_disj (map Neg (restr_list_prop p (fst k))))
+                   (Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq k)))))
+                      (Diam
+                         (list_conj
+                            (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list)))))))
+                 :: list_disj (restr_list_prop p (snd k)) :: Y0)).
+                2: epose (list_exch_RI _ [] [Or (list_disj (map Neg (restr_list_prop p (fst k)))) (Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq k)))))
+                (Diam (list_conj (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list)))))))] [] [list_disj (restr_list_prop p (snd k))] Y0) ; simpl in l ; apply l.
+                pose (OrR (X0,list_disj (restr_list_prop p (snd k)) :: Y0)). simpl in g1. apply g1.
+                assert (J3: InT (Neg # P) (map Neg (restr_list_prop p (fst k)))). unfold restr_list_prop. apply InT_map_iff.
+                exists (# P) ; split ; auto. apply In_InT. apply in_not_touched_remove. apply In_list_In_list_prop_LF ; apply InT_In ; auto.
+                intro. apply propvar. rewrite <- H1. rewrite propvar_subform_list_app. apply in_or_app ; right.
+                apply In_list_In_propvar_subform_list ; apply InT_In ; auto.
+                remember (Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) (Diam (list_conj
+                       (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list))))))
+                 :: list_disj (restr_list_prop p (snd k)) :: Y0) as Y.
+                pose (list_disj_wkn_R (map Neg (restr_list_prop p (fst k))) (X0, Y) (Neg # P) J3). apply g2. simpl.
+                unfold Neg. apply derI with (ps:=[([] ++ # P :: X0, [] ++ :: Y)]). apply ImpR. assert ((X0, # P --> :: Y) = ([] ++ X0, [] ++ # P --> :: Y)).
+                auto. rewrite H1. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+                assert (InT (# P) ([] ++ :: Y)). simpl. apply InT_cons. rewrite HeqY. repeat apply InT_cons ; auto.
+                apply InT_split in H1. destruct H1. destruct s. rewrite e0. apply derI with (ps:=[]). apply IdP. apply IdPRule_I.
+                apply dlNil.
+         -- assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+            assert (J1: Gimap (GUI p) (Canopy (nodupseq k)) (map (UI p) (Canopy (nodupseq k)))). apply Gimap_map. intros.
+            apply UI_GUI ; auto.
+            pose (@GUI_inv_not_critic p k _ _ J0 f J1). rewrite <- e.
+            pose (list_conj_R (map (UI p) (Canopy (nodupseq k))) (X0,Y0)). simpl in g0. apply g0. intros.
+            apply InT_map_iff in H0. destruct H0. destruct p0. subst.
+            assert (LexSeq x k). pose (Canopy_LexSeq _ _ i1). destruct s ; subst ; auto. exfalso.
+            apply f ; apply Canopy_critical in i1 ; auto. apply critical_nodupseq ; auto. apply LexSeq_nodupseq in l ; auto.
+            simpl in SIH.
+            assert (J2: GLS_rules [] (fst x ++ X0, snd x ++ Y0)).
+            apply IdP. assert (InT (# P) (snd x ++ Y0)). apply InT_or_app ; auto. apply InT_split in H1.
+            destruct H1. destruct s. rewrite e0. assert (InT (# P) (fst x ++ X0)). apply InT_or_app ; left.
+            apply Canopy_neg_var with (q:=P) in i1 ; auto. apply In_InT. destruct k ; simpl. apply nodup_In ; simpl in i ; apply InT_In in i ; auto.
+            apply InT_split in H1. destruct H1. destruct s. rewrite e1.
+            apply IdPRule_I. pose (derI _ J2 d).
+            assert (J3: S (dersrec_height d) = derrec_height d0). simpl. lia.
+            assert (J4: (fst x ++ X0, snd x ++ Y0) = (fst x ++ X0, snd x ++ Y0)). auto.
+            pose (SIH _ H0 _ _ _ _ J3 J4 propvar). auto.
+      + destruct (critical_Seq_dec k).
+         -- destruct (dec_init_rules k).
+            ** assert (is_init k) ; auto. assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+                pose (@GUI_inv_critic_init p k _ J0 c X). rewrite <- e.
+                assert ((X0, Top :: Y0) = (X0, [] ++ Top :: Y0)). auto. rewrite H0. apply TopR.
+            ** assert ((is_init k) -> False) ; auto. assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+                assert (J1: Gimap (GUI p) (GLR_prems (nodupseq k)) (map (UI p) (GLR_prems (nodupseq k)))). apply Gimap_map. intros.
+                apply UI_GUI ; auto.
+                assert (J2: (Gimap (GN p (GUI p) k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), [])))
+                (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), [])))))). apply Gimap_map. intros.
+                apply (N_spec p k x).
+                pose (@GUI_inv_critic_not_init p k _ _ _ J0 c NE H0 J1 J2). rewrite <- e.
+                pose (OrR (X0,Y0)). simpl in g0. apply g0.
+                assert (J3: InT (# P) (restr_list_prop p (snd k))). unfold restr_list_prop. apply In_InT.
+                apply in_not_touched_remove. apply In_list_In_list_prop_LF ; apply InT_In ; auto.
+                intro. apply propvar. rewrite <- H1. rewrite propvar_subform_list_app. apply in_or_app ; left.
+                apply In_list_In_propvar_subform_list ; apply InT_In ; auto.
+                remember (Or (list_disj (map Neg (restr_list_prop p (fst k)))) (Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) (Diam
+                (list_conj (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list))))))) :: Y0) as Y.
+                pose (list_disj_wkn_R (restr_list_prop p (snd k)) (X0, Y) (# P) J3). apply g1. simpl.
+                apply InT_split in i. destruct i. destruct s. rewrite e0. apply derI with (ps:=[]). apply IdP. 2: apply dlNil.
+                assert ((x ++ # P :: x0, # P :: Y) = (x ++ # P :: x0, [] ++ # P :: Y)). auto. rewrite H1 ; apply IdPRule_I.
+         -- assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+            assert (J1: Gimap (GUI p) (Canopy (nodupseq k)) (map (UI p) (Canopy (nodupseq k)))). apply Gimap_map. intros.
+            apply UI_GUI ; auto.
+            pose (@GUI_inv_not_critic p k _ _ J0 f J1). rewrite <- e.
+            pose (list_conj_R (map (UI p) (Canopy (nodupseq k))) (X0,Y0)). simpl in g0. apply g0. intros.
+            apply InT_map_iff in H0. destruct H0. destruct p0. subst.
+            assert (LexSeq x k). pose (Canopy_LexSeq _ _ i1). destruct s ; subst ; auto. exfalso.
+            apply f ; apply Canopy_critical in i1 ; auto. apply critical_nodupseq ; auto. apply LexSeq_nodupseq in l ; auto. simpl in SIH.
+            assert (J2: GLS_rules [] (fst x ++ X0, snd x ++ Y0)).
+            apply IdP. assert (InT (# P) (fst x ++ X0)). apply InT_or_app ; auto. apply InT_split in H1.
+            destruct H1. destruct s. rewrite e0. assert (InT (# P) (snd x ++ Y0)). apply InT_or_app ; left.
+            apply Canopy_pos_var with (q:=P) in i1 ; auto. auto. apply In_InT. destruct k ; simpl. apply nodup_In ; simpl in i0 ; apply InT_In in i0 ; auto.
+            apply InT_split in H1. destruct H1. destruct s. rewrite e1.
+            apply IdPRule_I. pose (derI _ J2 d).
+            assert (J3: S (dersrec_height d) = derrec_height d0). simpl. lia.
+            assert (J4: (fst x ++ X0, snd x ++ Y0) = (fst x ++ X0, snd x ++ Y0)). auto.
+            pose (SIH _ H0 _ _ _ _ J3 J4 propvar). auto.
+      + apply derI with (ps:=[]). 2: apply dlNil. apply IdP. apply InT_split in i. destruct i. destruct s ; subst.
+         apply InT_split in i0. destruct i0. destruct s ; subst. assert (UI p k :: x1 ++ # P :: x2 = (UI p k :: x1) ++ # P :: x2).
+         auto. rewrite H0. apply IdPRule_I.
+ +
+    (* BotL *)
+    * inversion H ; subst.
+      assert (InT (fst k ++ X0)). rewrite <- H2. apply InT_or_app ; right ; apply InT_eq.
+      apply InT_app_or in H0. destruct H0.
+      + assert ((X0, UI p k :: Y0) = (X0, [] ++ UI p k :: Y0)). auto. rewrite H0. apply is_init_UI.
+         right. destruct k. simpl in i. apply InT_split in i. destruct i. destruct s ; subst. apply BotLRule_I.
+      + apply derI with (ps:=[]). 2: apply dlNil. apply BotL. apply InT_split in i. destruct i. destruct s ; subst.
+         apply BotLRule_I.
+ +
+    (* ImpR *)
+    * destruct (critical_Seq_dec k).
+      (* If critical, then the rule ImpR was applied on a formula in X0 or Y0.
+          So, apply PIH omn the premise and then the rule. *)

+      + inversion H ; subst. assert (J0: dersrec_height d = dersrec_height d) ; auto.
+         apply dersrec_derrec_height in J0. destruct J0.
+         assert (J1: derrec_height x = derrec_height x). auto.
+         assert (J2: list_exch_L (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) (A :: fst k ++ X0, Δ0 ++ B :: Δ1)).
+         assert ((Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) = ([] ++ [] ++ Γ0 ++ [A] ++ Γ1, Δ0 ++ B :: Δ1)). auto.
+         rewrite H0.
+         assert ((A :: fst k ++ X0, Δ0 ++ B :: Δ1) = ([] ++ [A] ++ Γ0 ++ [] ++ Γ1, Δ0 ++ B :: Δ1)).
+         simpl. rewrite H2. auto. rewrite H1. apply list_exch_LI.
+         pose (GLS_hpadm_list_exch_L x J1 J2). destruct s.
+         assert (J3: derrec_height x0 = derrec_height x0). auto.
+         assert (J4: list_exch_L (A :: fst k ++ X0, Δ0 ++ B :: Δ1) (fst k ++ A :: X0, Δ0 ++ B :: Δ1)).
+         assert ((fst k ++ A :: X0, Δ0 ++ B :: Δ1) = ([] ++ [] ++ fst k ++ [A] ++ X0, Δ0 ++ B :: Δ1)). auto.
+         rewrite H0.
+         assert ((A :: fst k ++ X0, Δ0 ++ B :: Δ1) = ([] ++ [A] ++ fst k ++ [] ++ X0, Δ0 ++ B :: Δ1)).
+         auto. rewrite H1. apply list_exch_LI.
+         pose (GLS_hpadm_list_exch_L x0 J3 J4). destruct s. simpl in PIH.
+         apply app2_find_hole in H3. destruct H3.
+         repeat destruct s ; destruct p0 ; subst.
+         assert (J5: derrec_height x1 < S (dersrec_height d)). lia.
+         assert (J6: derrec_height x1 = derrec_height x1). auto.
+         assert (J7: (fst k ++ A :: X0, snd k ++ B :: Δ1) = (fst k ++ A:: X0, snd k ++ B :: Δ1)). auto.
+         assert (J8: (In # p (propvar_subform_list ((A :: X0) ++ B :: Δ1)) -> False)).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc in H0.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         left ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         left ; apply in_or_app ; auto. apply in_or_app ; right ; apply in_or_app ; auto.
+         pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+         apply derI with (ps:=[([] ++ A :: X0, [UI p k] ++ B :: Δ1)]). apply ImpR.
+         assert ((X0, UI p k :: A --> B :: Δ1) = ([] ++ X0, [UI p k] ++ A --> B :: Δ1)). auto. rewrite H0.
+         apply ImpRRule_I. apply dlCons ; [ simpl ; auto | apply dlNil].
+         destruct x2 ; simpl in e1 ; subst. rewrite app_nil_r in e0 ; subst.
+         assert (J5: derrec_height x1 < S (dersrec_height d)). lia.
+         assert (J6: derrec_height x1 = derrec_height x1). auto.
+         assert (J7: (fst k ++ A :: X0, snd k ++ B :: Δ1) = (fst k ++ A:: X0, snd k ++ B :: Δ1)). auto.
+         assert (J8: (In # p (propvar_subform_list ((A :: X0) ++ B :: Δ1)) -> False)).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc in H0.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         left ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         left ; apply in_or_app ; auto. apply in_or_app ; right ; apply in_or_app ; auto.
+         pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+         apply derI with (ps:=[([] ++ A :: X0, [UI p k] ++ B :: Δ1)]). apply ImpR.
+         assert ((X0, UI p k :: A --> B :: Δ1) = ([] ++ X0, [UI p k] ++ A --> B :: Δ1)). auto. rewrite H0.
+         apply ImpRRule_I. apply dlCons ; [ simpl ; auto | apply dlNil].
+         exfalso. destruct k ; simpl in e0 ; subst. unfold critical_Seq in c ; unfold is_Prime in c ; simpl in c.
+         assert (In m (l1 ++ Δ0 ++ m :: x2)). apply in_or_app ; right ; apply in_or_app ; right ; apply in_eq.
+         apply c in H0. inversion e1 ; subst. destruct H0 ; destruct H0 ; inversion H0 ; inversion H1.
+         assert (J5: derrec_height x1 < S (dersrec_height d)). lia.
+         assert (J6: derrec_height x1 = derrec_height x1). auto.
+         assert (J7: (fst k ++ A :: X0, (snd k ++ x2) ++ B :: Δ1) = (fst k ++ A:: X0, snd k ++ x2 ++ B :: Δ1)).
+         repeat rewrite <- app_assoc. auto.
+         assert (J8: (In # p (propvar_subform_list ((A :: X0) ++ (x2 ++ B :: Δ1))) -> False)).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc in H0.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; left ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; left ; apply in_or_app ; auto.
+         apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+         pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+         apply derI with (ps:=[([] ++ A :: X0, (UI p k :: x2) ++ B :: Δ1)]). apply ImpR.
+         assert ((X0, UI p k :: x2 ++ A --> B :: Δ1) = ([] ++ X0, (UI p k :: x2) ++ A --> B :: Δ1)). auto. rewrite H0.
+         apply ImpRRule_I. apply dlCons ; [ simpl ; auto | apply dlNil].
+      (*  If not critical, consider the conjunction that UI p k is. *)
+      + assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+         assert (J1: Gimap (GUI p) (Canopy (nodupseq k)) (map (UI p) (Canopy (nodupseq k)))). apply Gimap_map. intros.
+         apply UI_GUI ; auto.
+         pose (@GUI_inv_not_critic p k (UI p k) (map (UI p) (Canopy (nodupseq k))) J0 f J1). rewrite <- e.
+ +
+         assert (J2: forall s1, InT s1 (Canopy (nodupseq k)) -> GLS_prv (X0, UI p s1 :: Y0)).
+         intros. pose (fold_Canopy _ _ H0). destruct s ; subst.
+         exfalso. apply f. apply Canopy_critical in H0 ; auto. apply critical_nodupseq in H0 ; auto.
+         destruct s. destruct p0. unfold inv_prems in i.
+         apply InT_flatten_list_InT_elem in i. destruct i. destruct p0. simpl in PIH. simpl in SIH.
+         pose (derI _ g d).
+         assert (existsT2 (d1: GLS_prv (fst (nodupseq k) ++ X0, snd (nodupseq k) ++ Y0)), derrec_height d1 <= derrec_height d0).
+         destruct (nodupseq_id k). destruct p0. destruct s. destruct s. destruct p1. destruct p1.
+         pose (PermutationTS_prv_hpadm _ d0 (x2 ++ fst x1 ++ X0, x3 ++ snd x1 ++ Y0)). destruct s.
+         split ; simpl ; apply Permutation_PermutationT. destruct p1.
+         pose (@Permutation_app _ (fst k) X0 (x2 ++ fst x1) X0). rewrite <- app_assoc in p3 ; apply p3 ; auto.
+         apply Permutation_PermutationT ; auto. destruct p1.
+         pose (@Permutation_app _ (snd k) Y0 (x3 ++ snd x1) Y0). rewrite <- app_assoc in p3 ; apply p3 ; auto.
+         apply Permutation_PermutationT ; auto.
+         epose (incl_ctr_R_hpadm _ x3 _ x4). destruct s. intros A HA ; apply in_or_app ; left ; auto.
+         epose (incl_ctr_L_hpadm x2 _ _ x5). destruct s. intros A HA ; apply in_or_app ; left ; auto.
+         pose (PermutationTS_prv_hpadm _ x6 (fst (nodupseq k) ++ X0, snd (nodupseq k) ++ Y0)). destruct s.
+         split ; simpl ; apply Permutation_PermutationT. destruct p0. apply Permutation_app ; auto.
+         unfold nodupseq in p0. apply Permutation_PermutationT ; auto. destruct p0.
+         apply Permutation_app ; auto. unfold nodupseq in p2. apply Permutation_PermutationT ; auto.
+         exists x7. lia. destruct X.
+         assert (J2: derrec_height x1 = derrec_height x1). auto.
+         assert (J3: (fst (nodupseq k) ++ X0, snd (nodupseq k) ++ Y0) = (fst (nodupseq k) ++ X0, snd (nodupseq k) ++ Y0)). auto.
+         pose (Canopy_hp_inv_ctx (nodupseq k) _ _ x1 X0 Y0 J2 J3 _ H0). destruct s.
+         destruct (Compare_dec.lt_dec (derrec_height x2) (S (dersrec_height d))).
+         (* Use PIH. *)
+         pose (fold_Canopy _ _ H0). destruct s ; subst.
+         exfalso. apply f. apply Canopy_critical in H0 ; auto. apply critical_nodupseq in H0 ; auto.
+         destruct s. destruct p0. unfold inv_prems in i2.
+         apply InT_flatten_list_InT_elem in i2. destruct i2. destruct p0.
+         assert (J4: derrec_height x2 = derrec_height x2). auto.
+         assert (J5: (fst s1 ++ X0, snd s1 ++ Y0) = (fst s1 ++ X0, snd s1 ++ Y0)). auto.
+         pose (PIH _ l1 s1 _ x2 X0 Y0 J4 J5). apply g0 ; auto.
+         (* Use SIH. *)
+         assert (derrec_height x2 = S (dersrec_height d)). assert (derrec_height d0 = S (dersrec_height d)). simpl. auto. lia.
+         assert (J4: LexSeq s1 k). pose (Canopy_LexSeq _ _ H0).
+         destruct s ; subst ; auto. exfalso. apply f. apply Canopy_critical in H0 ; apply critical_nodupseq in H0 ; auto.
+         apply LexSeq_nodupseq in l1 ; auto. symmetry in H1.
+         assert (J5: (fst s1 ++ X0, snd s1 ++ Y0) = (fst s1 ++ X0, snd s1 ++ Y0)). auto.
+         pose (SIH _ J4 _ _ _ _ H1 J5 propvar). auto.
+ +
+         assert (J3: (forall A : MPropF, InT A (map (UI p) (Canopy (nodupseq k))) -> GLS_prv (fst (X0, Y0), A :: snd (X0, Y0)))).
+         intros. simpl. apply InT_map_iff in H0. destruct H0. destruct p0 ; subst. apply J2 in i ; auto.
+         pose (list_conj_R _ _ J3). simpl in g0. auto.
+ +
+    (* ImpL *)
+    * destruct (critical_Seq_dec k).
+      (* If critical, then the rule ImpL was applied on a formula in X0 or Y0.
+          So, apply PIH on the premises and then the rule. *)

+      + inversion H ; subst. assert (J0: dersrec_height d = dersrec_height d) ; auto.
+         apply dersrec_derrec2_height in J0. destruct J0. destruct s. simpl in PIH.
+         assert (J1: derrec_height x = derrec_height x). auto.
+         assert (J2: list_exch_R (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) (Γ0 ++ Γ1, A :: snd k ++ Y0)).
+         assert ((Γ0 ++ Γ1, Δ0 ++ A :: Δ1) = (Γ0 ++ Γ1, [] ++ [] ++ Δ0 ++ [A] ++ Δ1)). auto.
+         rewrite H0.
+         assert ((Γ0 ++ Γ1, A :: snd k ++ Y0) = (Γ0 ++ Γ1, [] ++ [A] ++ Δ0 ++ [] ++ Δ1)).
+         simpl. rewrite H3. auto. rewrite H1. apply list_exch_RI.
+         pose (GLS_hpadm_list_exch_R x J1 J2). destruct s.
+         assert (J3: derrec_height x1 = derrec_height x1). auto.
+         assert (J4: list_exch_R (Γ0 ++ Γ1, A :: snd k ++ Y0) (Γ0 ++ Γ1, snd k ++ A :: Y0)).
+         assert ((Γ0 ++ Γ1, snd k ++ A :: Y0) = (Γ0 ++ Γ1, [] ++ [] ++ snd k ++ [A] ++ Y0)). auto.
+         rewrite H0.
+         assert ((Γ0 ++ Γ1, A :: snd k ++ Y0) = (Γ0 ++ Γ1, [] ++ [A] ++ snd k ++ [] ++ Y0)).
+         auto. rewrite H1. apply list_exch_RI.
+         pose (GLS_hpadm_list_exch_R x1 J3 J4). destruct s.
+         apply app2_find_hole in H2. destruct H2.
+         repeat destruct s ; destruct p0 ; subst.
+         assert (J5: derrec_height x2 < S (dersrec_height d)). lia.
+         assert (J6: derrec_height x2 = derrec_height x2). auto.
+         assert (J7: (fst k ++ Γ1, snd k ++ A :: Y0) = (fst k ++ Γ1, snd k ++ A :: Y0)). auto.
+         assert (J8: In # p (propvar_subform_list (Γ1 ++ A :: Y0)) -> False).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; auto. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto.
+         pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+         assert (J9: derrec_height x0 < S (dersrec_height d)). lia.
+         assert (J10: derrec_height x0 = derrec_height x0). auto.
+         assert (J11: (fst k ++ B :: Γ1, Δ0 ++ Δ1) = (fst k ++ B :: Γ1, snd k ++ Y0)). rewrite H3 ; auto.
+         assert (J12: In # p (propvar_subform_list ((B :: Γ1) ++ Y0)) -> False).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc. repeat rewrite <- app_assoc in H0.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto.
+         pose (PIH _ J9 _ _ _ _ _ J10 J11 J12).
+         apply derI with (ps:=[([] ++ Γ1, [UI p k] ++ A :: Y0);([] ++ B :: Γ1, [UI p k] ++ Y0)]). apply ImpL.
+         assert ((A --> B :: Γ1, UI p k :: Y0) = ([] ++ A --> B :: Γ1, [UI p k] ++ Y0)). auto. rewrite H0.
+         apply ImpLRule_I. apply dlCons. auto. apply dlCons. auto. apply dlNil.
+         destruct x3 ; simpl in e1 ; subst. rewrite app_nil_r in e0 ; subst.
+         assert (J5: derrec_height x2 < S (dersrec_height d)). lia.
+         assert (J6: derrec_height x2 = derrec_height x2). auto.
+         assert (J7: (fst k ++ Γ1, snd k ++ A :: Y0) = (fst k ++ Γ1, snd k ++ A :: Y0)). auto.
+         assert (J8: In # p (propvar_subform_list (Γ1 ++ A :: Y0)) -> False).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; auto. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto.
+         pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+         assert (J9: derrec_height x0 < S (dersrec_height d)). lia.
+         assert (J10: derrec_height x0 = derrec_height x0). auto.
+         assert (J11: (fst k ++ B :: Γ1, Δ0 ++ Δ1) = (fst k ++ B :: Γ1, snd k ++ Y0)). rewrite H3 ; auto.
+         assert (J12: In # p (propvar_subform_list ((B :: Γ1) ++ Y0)) -> False).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc. repeat rewrite <- app_assoc in H0.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto.
+         pose (PIH _ J9 _ _ _ _ _ J10 J11 J12).
+         apply derI with (ps:=[([] ++ Γ1, [UI p k] ++ A :: Y0);([] ++ B :: Γ1, [UI p k] ++ Y0)]). apply ImpL.
+         assert ((A --> B :: Γ1, UI p k :: Y0) = ([] ++ A --> B :: Γ1, [UI p k] ++ Y0)). auto. rewrite H0.
+         apply ImpLRule_I. apply dlCons. auto. apply dlCons. auto. apply dlNil.
+         exfalso. destruct k ; simpl in e0 ; subst. unfold critical_Seq in c ; unfold is_Prime in c ; simpl in c.
+         assert (In m ((Γ0 ++ m :: x3) ++ l2)). repeat rewrite <- app_assoc. apply in_or_app ; right ; apply in_or_app ; left ; apply in_eq.
+         apply c in H0. inversion e1 ; subst. destruct H0 ; destruct H0 ; inversion H0 ; inversion H1.
+         assert (J5: derrec_height x2 < S (dersrec_height d)). lia.
+         assert (J6: derrec_height x2 = derrec_height x2). auto.
+         assert (J7: ((fst k ++ x3) ++ Γ1, snd k ++ A :: Y0) = (fst k ++ x3 ++ Γ1, snd k ++ A :: Y0)).
+         rewrite <- app_assoc ; auto.
+         assert (J8: In # p (propvar_subform_list ((x3 ++ Γ1) ++ A :: Y0)) -> False).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc. repeat rewrite <- app_assoc in H0.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; auto. apply in_app_or in H0 ; destruct H0.
+         apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ; auto.
+         apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+         pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+         assert (J9: derrec_height x0 < S (dersrec_height d)). lia.
+         assert (J10: derrec_height x0 = derrec_height x0). auto.
+         assert (J11: ((fst k ++ x3) ++ B :: Γ1, Δ0 ++ Δ1) = (fst k ++ x3 ++ B :: Γ1, snd k ++ Y0)).
+         rewrite H3 ; rewrite <- app_assoc ; auto.
+         assert (J12: In # p (propvar_subform_list ((x3 ++ B :: Γ1) ++ Y0)) -> False).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc. repeat rewrite <- app_assoc in H0.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; auto. apply in_or_app ; right ; apply in_or_app ; auto.
+         pose (PIH _ J9 _ _ _ _ _ J10 J11 J12).
+         apply derI with (ps:=[(x3 ++ Γ1, [UI p k] ++ A :: Y0);(x3 ++ B :: Γ1, [UI p k] ++ Y0)]). apply ImpL.
+         assert ((x3 ++ A --> B :: Γ1, UI p k :: Y0) = (x3 ++ A --> B :: Γ1, [UI p k] ++ Y0)). auto. rewrite H0.
+         apply ImpLRule_I. apply dlCons. auto. apply dlCons. auto. apply dlNil.
+      (*  If not critical, consider the conjunction that UI p k is. *)
+      + assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+         assert (J1: Gimap (GUI p) (Canopy (nodupseq k)) (map (UI p) (Canopy (nodupseq k)))). apply Gimap_map. intros.
+         apply UI_GUI ; auto.
+         pose (@GUI_inv_not_critic p k (UI p k) (map (UI p) (Canopy (nodupseq k))) J0 f J1). rewrite <- e.
+ +
+         assert (J2: forall s1, InT s1 (Canopy (nodupseq k)) -> GLS_prv (X0, UI p s1 :: Y0)).
+         intros. pose (fold_Canopy _ _ H0). destruct s ; subst.
+         exfalso. apply f. apply Canopy_critical in H0 ; auto. apply critical_nodupseq in H0 ; auto.
+         destruct s. destruct p0. unfold inv_prems in i.
+         apply InT_flatten_list_InT_elem in i. destruct i. destruct p0. simpl in PIH. simpl in SIH.
+         pose (derI _ g d).
+ +
+         assert (existsT2 (d1: GLS_prv (fst (nodupseq k) ++ X0, snd (nodupseq k) ++ Y0)), derrec_height d1 <= derrec_height d0).
+         destruct (nodupseq_id k). destruct p0. destruct s. destruct s. destruct p1. destruct p1.
+         pose (PermutationTS_prv_hpadm _ d0 (x2 ++ fst x1 ++ X0, x3 ++ snd x1 ++ Y0)). destruct s.
+         split ; simpl ; apply Permutation_PermutationT. destruct p1.
+         pose (@Permutation_app _ (fst k) X0 (x2 ++ fst x1) X0). rewrite <- app_assoc in p3 ; apply p3 ; auto.
+         apply Permutation_PermutationT ; auto. destruct p1.
+         pose (@Permutation_app _ (snd k) Y0 (x3 ++ snd x1) Y0). rewrite <- app_assoc in p3 ; apply p3 ; auto.
+         apply Permutation_PermutationT ; auto.
+         epose (incl_ctr_R_hpadm _ x3 _ x4). destruct s. intros A HA ; apply in_or_app ; left ; auto.
+         epose (incl_ctr_L_hpadm x2 _ _ x5). destruct s. intros A HA ; apply in_or_app ; left ; auto.
+         pose (PermutationTS_prv_hpadm _ x6 (fst (nodupseq k) ++ X0, snd (nodupseq k) ++ Y0)). destruct s.
+         split ; simpl ; apply Permutation_PermutationT. destruct p0. apply Permutation_app ; auto.
+         unfold nodupseq in p0. apply Permutation_PermutationT ; auto. destruct p0.
+         apply Permutation_app ; auto. unfold nodupseq in p2. apply Permutation_PermutationT ; auto.
+         exists x7. lia. destruct X.
+         assert (J2: derrec_height x1 = derrec_height x1). auto.
+         assert (J3: (fst (nodupseq k) ++ X0, snd (nodupseq k) ++ Y0) = (fst (nodupseq k) ++ X0, snd (nodupseq k) ++ Y0)). auto.
+         pose (Canopy_hp_inv_ctx (nodupseq k) _ _ x1 X0 Y0 J2 J3 _ H0). destruct s.
+         destruct (Compare_dec.lt_dec (derrec_height x2) (S (dersrec_height d))).
+         (* Use PIH. *)
+         pose (fold_Canopy _ _ H0). destruct s ; subst.
+         exfalso. apply f. apply Canopy_critical in H0 ; auto. apply critical_nodupseq in H0 ; auto.
+         destruct s. destruct p0. unfold inv_prems in i2.
+         apply InT_flatten_list_InT_elem in i2. destruct i2. destruct p0.
+         assert (J4: derrec_height x2 = derrec_height x2). auto.
+         assert (J5: (fst s1 ++ X0, snd s1 ++ Y0) = (fst s1 ++ X0, snd s1 ++ Y0)). auto.
+         pose (PIH _ l1 s1 _ x2 X0 Y0 J4 J5). apply g0 ; auto.
+         (* Use SIH. *)
+         assert (derrec_height x2 = S (dersrec_height d)). assert (derrec_height d0 = S (dersrec_height d)). simpl. auto. lia.
+         assert (J4: LexSeq s1 k). pose (Canopy_LexSeq _ _ H0).
+         destruct s ; subst ; auto. exfalso. apply f. apply Canopy_critical in H0 ; apply critical_nodupseq in H0 ; auto.
+         apply LexSeq_nodupseq in l1 ; auto. symmetry in H1.
+         assert (J5: (fst s1 ++ X0, snd s1 ++ Y0) = (fst s1 ++ X0, snd s1 ++ Y0)). auto.
+         pose (SIH _ J4 _ _ _ _ H1 J5 propvar). auto.
+ +
+         assert (J3: (forall A : MPropF, InT A (map (UI p) (Canopy (nodupseq k))) -> GLS_prv (fst (X0, Y0), A :: snd (X0, Y0)))).
+         intros. simpl. apply InT_map_iff in H0. destruct H0. destruct p0 ; subst. apply J2 in i ; auto.
+         pose (list_conj_R _ _ J3). simpl in g0. auto.
+ +
+    (* GLR *)
+    * destruct (critical_Seq_dec k).
+      (* If critical. *)
+      + inversion X ; subst. (* Not sure the two lines below are useful. *)
+         assert (J0: dersrec_height d = dersrec_height d) ; auto.
+         apply dersrec_derrec_height in J0. destruct J0. simpl in PIH. simpl in SIH.
+         destruct (dec_init_rules k).
+         (* If initial. *)
+        ** assert (is_init k) ; auto. assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+         pose (@GUI_inv_critic_init p k _ J0 c X2). rewrite <- e0.
+         assert ((X0, Top :: Y0) = (X0, [] ++ Top :: Y0)). auto. rewrite H. apply TopR.
+         (* If not initial. *)
+        ** apply univ_gen_ext_splitR in X1. destruct X1. destruct s. destruct p0. destruct p0.
+         apply app2_find_hole in H2. destruct H2.
+         assert ((is_init k) -> False) ; auto.
+         assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+         assert (J1: Gimap (GUI p) (GLR_prems (nodupseq k)) (map (UI p) (GLR_prems (nodupseq k)))). apply Gimap_map. intros.
+         apply UI_GUI ; auto.
+         assert (J2: (Gimap (GN p (GUI p) k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), [])))
+         (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), [])))))). apply Gimap_map. intros.
+         apply (N_spec p k x3).
+         pose (@GUI_inv_critic_not_init p k _ _ _ J0 c NE H J1 J2). rewrite <- e1. clear e1.
+         repeat destruct s ; destruct p0 ; subst.
+         (* If Box A is in Y0. *)
+         -- pose (OrR (X0,Box A :: Δ1)). simpl in g0. apply g0. clear g0.
+            apply GLS_prv_wkn_R with (A:=list_disj (restr_list_prop p (snd k))) (s:=(X0,
+            Or (list_disj (map Neg (restr_list_prop p (fst k))))(Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) (Diam
+            (list_conj (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list)))))))
+            :: Box A :: Δ1)).
+            2: epose (wkn_RI (list_disj (restr_list_prop p (snd k))) _ [] _) ; simpl in w ; apply w.
+            pose (OrR (X0,Box A :: Δ1)). simpl in g0. apply g0. clear g0.
+            apply GLS_prv_wkn_R with (A:=list_disj (map Neg (restr_list_prop p (fst k)))) (s:=(X0,
+            Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) (Diam
+            (list_conj (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list))))))
+            :: Box A :: Δ1)).
+            2: epose (wkn_RI (list_disj (map Neg (restr_list_prop p (fst k)))) _ [] _) ; simpl in w ; apply w.
+            pose (OrR (X0,Box A :: Δ1)). simpl in g0. apply g0. clear g0.
+            apply GLS_prv_wkn_R with (A:=list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) (s:=(X0,
+            (Diam (list_conj (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list))))))
+            :: Box A :: Δ1)).
+            2: epose (wkn_RI (list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) _ [] _) ; simpl in w ; apply w.
+            apply Diam_rec_UI ; auto.
+            assert (J5: derrec_height x < S (dersrec_height d)). lia.
+            assert (J6: derrec_height x = derrec_height x). auto.
+            assert (J7: (XBoxed_list (x0 ++ x1) ++ [Box A], [A]) = (fst (XBoxed_list x0, @nil MPropF) ++ XBoxed_list x1 ++ [Box A], snd (XBoxed_list x0, []) ++ [A])).
+            simpl ; rewrite XBox_app_distrib. repeat rewrite <- app_assoc ; auto.
+            assert (J8: (In # p (propvar_subform_list ((XBoxed_list x1 ++ [Box A]) ++ [A])) -> False)).
+            intro. apply propvar. repeat rewrite propvar_subform_list_app.
+            repeat rewrite propvar_subform_list_app in H0. simpl in H0. repeat rewrite app_nil_r in H0. simpl.
+            repeat rewrite <- app_assoc in H0. apply in_app_or in H0 ; destruct H0.
+            apply in_or_app ; left. apply propvar_subform_list_XBoxed_list in H0.
+            apply propvar_subform_list_nobox_gen_ext with (l0:=x1); auto.
+            apply in_or_app ; right ; apply in_or_app ; left. apply in_app_or in H0 ; destruct H0 ; auto.
+            pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+            apply derI with (ps:=[(X0 ++ Box (Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list))) :: [], [] ++ Bot :: Box A :: Δ1)]).
+            apply ImpR. assert ((X0, Diam (UI p (XBoxed_list (top_boxes (fst k)), []%list)) :: Box A :: Δ1) =
+            (X0 ++ [], [] ++ Diam (UI p (XBoxed_list (top_boxes (fst k)), []%list)) :: Box A :: Δ1)). rewrite app_nil_r. auto. rewrite H0.
+            apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+            apply derI with (ps:=[(XBoxed_list (x1 ++ [Box (Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list)))]) ++ [Box A], [A])]).
+            apply GLR. assert (([] ++ :: Box A :: Δ1) = [] ++ Box A :: Δ1). auto. rewrite H0. apply GLRRule_I ; auto.
+            intro. intros. apply in_app_or in H2 ; destruct H2. apply H1 ; apply in_or_app ; auto. exists (Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list))).
+            inversion H2 ; subst ; auto. inversion H3. apply univ_gen_ext_combine ; auto. apply univ_gen_ext_cons. apply univ_gen_ext_nil.
+            apply dlCons. 2: apply dlNil. rewrite XBox_app_distrib. simpl. repeat rewrite <- app_assoc. simpl.
+            apply GLS_prv_wkn_L with (A:=Box (Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list)))) (s:=(XBoxed_list x1 ++
+            [Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list)); Box A], [A])).
+            2: epose (wkn_LI (Box (Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list)))) (XBoxed_list x1 ++ [Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list))]) [Box A] _) ;
+            simpl in w ; repeat rewrite <- app_assoc in w ; simpl in w ; apply w.
+            apply derI with (ps:=[(XBoxed_list x1 ++ [Box A], [] ++ (UI p (XBoxed_list (top_boxes (fst k)), []%list)) :: [A]);
+            (XBoxed_list x1 ++ Bot :: [Box A], [] ++ [A])]). apply ImpL. apply ImpLRule_I. apply dlCons. 2: apply dlCons.
+            3: apply dlNil. 2: apply derI with (ps:=[]) ; [apply BotL ; apply BotLRule_I | apply dlNil].
+            simpl. assert ((top_boxes (fst k)) = x0). symmetry. apply nobox_gen_ext_top_boxes_identity ; auto.
+            intro. intros. apply H1 ; apply in_or_app ; auto. rewrite H0. auto.
+        -- destruct x2 ; simpl in e2 ; subst.
+            (* If Box A is in Y0 (bis). *)
+            +++ rewrite app_nil_r in e1 ; subst.
+                pose (OrR (X0,Box A :: Δ1)). simpl in g0. apply g0. clear g0.
+                apply GLS_prv_wkn_R with (A:=list_disj (restr_list_prop p (snd k))) (s:=(X0,
+                Or (list_disj (map Neg (restr_list_prop p (fst k))))(Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) (Diam
+                (list_conj (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list)))))))
+                :: Box A :: Δ1)).
+                2: epose (wkn_RI (list_disj (restr_list_prop p (snd k))) _ [] _) ; simpl in w ; apply w.
+                pose (OrR (X0,Box A :: Δ1)). simpl in g0. apply g0. clear g0.
+                apply GLS_prv_wkn_R with (A:=list_disj (map Neg (restr_list_prop p (fst k)))) (s:=(X0,
+                Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) (Diam
+                (list_conj (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list))))))
+                :: Box A :: Δ1)).
+                2: epose (wkn_RI (list_disj (map Neg (restr_list_prop p (fst k)))) _ [] _) ; simpl in w ; apply w.
+                pose (OrR (X0,Box A :: Δ1)). simpl in g0. apply g0. clear g0.
+                apply GLS_prv_wkn_R with (A:=list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) (s:=(X0,
+                (Diam (list_conj (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list))))))
+                :: Box A :: Δ1)).
+                2: epose (wkn_RI (list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) _ [] _) ; simpl in w ; apply w.
+                apply Diam_rec_UI ; auto.
+                assert (J5: derrec_height x < S (dersrec_height d)). lia.
+                assert (J6: derrec_height x = derrec_height x). auto.
+                assert (J7: (XBoxed_list (x0 ++ x1) ++ [Box A], [A]) = (fst (XBoxed_list x0, @nil MPropF) ++ XBoxed_list x1 ++ [Box A], snd (XBoxed_list x0, []) ++ [A])).
+                simpl ; rewrite XBox_app_distrib. repeat rewrite <- app_assoc ; auto.
+                assert (J8: (In # p (propvar_subform_list ((XBoxed_list x1 ++ [Box A]) ++ [A])) -> False)).
+                intro. apply propvar. repeat rewrite propvar_subform_list_app.
+                repeat rewrite propvar_subform_list_app in H0. simpl in H0. repeat rewrite app_nil_r in H0. simpl.
+                repeat rewrite <- app_assoc in H0. apply in_app_or in H0 ; destruct H0.
+                apply in_or_app ; left. apply propvar_subform_list_XBoxed_list in H0.
+                apply propvar_subform_list_nobox_gen_ext with (l0:=x1); auto.
+                apply in_or_app ; right ; apply in_or_app ; left. apply in_app_or in H0 ; destruct H0 ; auto.
+                pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+                apply derI with (ps:=[(X0 ++ Box (Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list))) :: [], [] ++ Bot :: Box A :: Δ1)]).
+                apply ImpR. assert ((X0, Diam (UI p (XBoxed_list (top_boxes (fst k)), []%list)) :: Box A :: Δ1) =
+                (X0 ++ [], [] ++ Diam (UI p (XBoxed_list (top_boxes (fst k)), []%list)) :: Box A :: Δ1)). rewrite app_nil_r. auto. rewrite H0.
+                apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+                apply derI with (ps:=[(XBoxed_list (x1 ++ [Box (Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list)))]) ++ [Box A], [A])]).
+                apply GLR. assert (([] ++ :: Box A :: Δ1) = [] ++ Box A :: Δ1). auto. rewrite H0. apply GLRRule_I ; auto.
+                intro. intros. apply in_app_or in H2 ; destruct H2. apply H1 ; apply in_or_app ; auto. exists (Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list))).
+                inversion H2 ; subst ; auto. inversion H3. apply univ_gen_ext_combine ; auto. apply univ_gen_ext_cons. apply univ_gen_ext_nil.
+                apply dlCons. 2: apply dlNil. rewrite XBox_app_distrib. simpl. repeat rewrite <- app_assoc. simpl.
+                apply GLS_prv_wkn_L with (A:=Box (Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list)))) (s:=(XBoxed_list x1 ++
+                [Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list)); Box A], [A])).
+                2: epose (wkn_LI (Box (Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list)))) (XBoxed_list x1 ++ [Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list))]) [Box A] _) ;
+                simpl in w ; repeat rewrite <- app_assoc in w ; simpl in w ; apply w.
+                apply derI with (ps:=[(XBoxed_list x1 ++ [Box A], [] ++ (UI p (XBoxed_list (top_boxes (fst k)), []%list)) :: [A]);
+                (XBoxed_list x1 ++ Bot :: [Box A], [] ++ [A])]). apply ImpL. apply ImpLRule_I. apply dlCons. 2: apply dlCons.
+                3: apply dlNil. 2: apply derI with (ps:=[]) ; [apply BotL ; apply BotLRule_I | apply dlNil].
+                simpl. assert ((top_boxes (fst k)) = x0). symmetry. apply nobox_gen_ext_top_boxes_identity ; auto.
+                intro. intros. apply H1 ; apply in_or_app ; auto. rewrite H0. auto.
+           (* If Box A is in (snd k). *)
+           +++ inversion e2 ; subst.
+                assert (J10:derrec_height x = derrec_height x) ; auto.
+                assert (J11: list_exch_L (XBoxed_list (x0 ++ x1) ++ [Box A], [A]) ((XBoxed_list x0 ++ [Box A]) ++ XBoxed_list x1, [A])).
+                assert (XBoxed_list (x0 ++ x1) ++ [Box A] = XBoxed_list x0 ++ [] ++ XBoxed_list x1 ++ [Box A] ++ []). rewrite XBox_app_distrib.
+                repeat rewrite <- app_assoc. auto. rewrite H0.
+                assert ((XBoxed_list x0 ++ [Box A]) ++ XBoxed_list x1 = XBoxed_list x0 ++ [Box A] ++ XBoxed_list x1 ++ [] ++ []).
+                repeat rewrite <- app_assoc. auto. repeat rewrite app_nil_r. auto. rewrite H2. apply list_exch_LI.
+                pose (GLS_hpadm_list_exch_L _ J10 J11). destruct s.
+                pose (incl_hpadm_prv _ ((XBoxed_list (top_boxes (fst (nodupseq k))) ++ [Box A]) ++ XBoxed_list x1, [A]) x3). simpl in s. destruct s.
+                intros B HB. apply in_app_or in HB ; destruct HB. apply in_app_or in H0 ; destruct H0.
+                apply in_or_app ; left. apply in_or_app ; left. destruct (In_XBoxed_list_gen _ _ H0).
+                apply list_preserv_XBoxed_list. apply is_box_in_top_boxes. apply nodup_In.
+                apply (univ_gen_ext_In _ u) ; auto. apply H1. apply in_or_app ; auto. destruct H2. destruct H2 ; subst.
+                apply XBoxed_list_In. apply is_box_in_top_boxes. apply nodup_In. apply (univ_gen_ext_In _ u) ; auto.
+                apply H1. apply in_or_app ; auto. inversion H0 ; subst. apply in_or_app ; left ; apply in_or_app ; auto. inversion H2.
+                apply in_or_app ; auto. intros B HB ; auto.
+                assert (J5: derrec_height x4 < S (dersrec_height d)). lia.
+                assert (J6: derrec_height x4 = derrec_height x4). auto.
+                assert (J7: ((XBoxed_list (top_boxes (nodup eq_dec_form (fst k))) ++ [Box A]) ++ XBoxed_list x1, [A]) = (fst (XBoxed_list (top_boxes (nodup eq_dec_form (fst k))) ++[Box A], [A]) ++ XBoxed_list x1, snd (XBoxed_list x0 ++[Box A], [A]) ++ [])).
+                simpl. repeat rewrite <- app_assoc ; auto.
+                assert (J8: (In # p (propvar_subform_list ((XBoxed_list x1 ++ [])))) -> False).
+                intro. apply propvar. repeat rewrite propvar_subform_list_app.
+                repeat rewrite propvar_subform_list_app in H0. simpl in H0. repeat rewrite app_nil_r in H0. simpl.
+                repeat rewrite <- app_assoc in H0. apply in_or_app ; left. apply propvar_subform_list_XBoxed_list in H0.
+                apply propvar_subform_list_nobox_gen_ext with (l0:=x1); auto.
+                pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+                apply GLS_prv_wkn_L with (A:=Box (UI p (XBoxed_list (top_boxes (nodup eq_dec_form (fst k))) ++ [Box A], [A])))
+                (sw:=(XBoxed_list x1 ++ [Box (UI p (XBoxed_list (top_boxes (nodup eq_dec_form (fst k))) ++ [Box A], [A]))] , [UI p (XBoxed_list (top_boxes (nodup eq_dec_form (fst k))) ++ [Box A], [A])])) in g0.
+                2: epose (wkn_LI (Box (UI p (XBoxed_list (top_boxes (nodup eq_dec_form (fst k))) ++ [Box A], [A]))) _ [] _) ; rewrite app_nil_r in w ; simpl in w ; apply w.
+                assert (J20: GLS_rules [(XBoxed_list x1 ++ [Box (UI p (XBoxed_list (top_boxes (nodup eq_dec_form (fst k))) ++ [Box A], [A]))], [UI p (XBoxed_list (top_boxes (nodup eq_dec_form (fst k))) ++ [Box A], [A])])]
+                (X0, Box (UI p (XBoxed_list (top_boxes (nodup eq_dec_form (fst k))) ++ [Box A], [A])) :: Y0)). apply GLR.
+                assert (Box (UI p (XBoxed_list (top_boxes (nodup eq_dec_form (fst k))) ++ [Box A], [A])) :: Y0 = [] ++ Box (UI p (XBoxed_list (top_boxes (nodup eq_dec_form (fst k))) ++ [Box A], [A])) :: Y0).
+                auto. rewrite H0. apply GLRRule_I ;auto. intro. intros. apply H1. apply in_or_app ;auto.
+                pose (dlNil GLS_rules (fun _ : Seq => False)).
+                pose (dlCons g0 d0). pose (derI _ J20 d1).
+                pose (OrR (X0,Y0)). simpl in g1. apply g1. clear g1.
+                apply GLS_prv_wkn_R with (A:=list_disj (restr_list_prop p (snd k))) (s:=(X0,
+                Or (list_disj (map Neg (restr_list_prop p (fst k))))(Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) (Diam
+                (list_conj (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list)))))))
+                :: Y0)).
+                2: epose (wkn_RI (list_disj (restr_list_prop p (snd k))) _ [] _) ; simpl in w ; apply w.
+                pose (OrR (X0,Y0)). simpl in g1. apply g1. clear g1.
+                apply GLS_prv_wkn_R with (A:=list_disj (map Neg (restr_list_prop p (fst k)))) (s:=(X0,
+                Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) (Diam
+                (list_conj (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list))))))
+                :: Y0)).
+                2: epose (wkn_RI (list_disj (map Neg (restr_list_prop p (fst k)))) _ [] _) ; simpl in w ; apply w.
+                pose (OrR (X0,Y0)). simpl in g1. apply g1. clear g1.
+                pose (list_disj_wkn_R (map Box (map (UI p) (GLR_prems (nodupseq k)))) (X0, Diam
+                 (list_conj (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list))))) :: Y0)).
+                (* The next UI does not have the correct LHS, which we expect to use x0, to link up with d1. *)
+                apply g1 with (A:=Box (UI p (XBoxed_list (top_boxes (fst (nodupseq k))) ++ [Box A], [A]))) ; clear g1 ; simpl ; auto.
+                apply InT_map_iff.
+                exists (UI p (XBoxed_list (top_boxes (fst (nodupseq k))) ++ [Box A], [A])) ; split ; auto. apply InT_map_iff.
+                exists (XBoxed_list (top_boxes (fst (nodupseq k))) ++ [Box A], [A]) ; split ; auto. unfold GLR_prems.
+                apply InT_trans_flatten_list with (bs:=[(XBoxed_list (top_boxes (fst (nodupseq k))) ++ [Box A], [A])]) ; auto. apply InT_eq.
+                destruct (finite_GLR_premises_of_S (nodupseq k)) ; subst. simpl. apply p0. assert (k = (fst k,Δ0 ++ Box A :: x2)).
+                rewrite <- e1. destruct k ; auto. rewrite H0. unfold nodupseq ; simpl.
+                assert (InT (Box A) (nodup eq_dec_form (Δ0 ++ Box A :: x2))). apply In_InT ; apply nodup_In ; apply in_or_app ; right ; simpl ; auto.
+                apply InT_split in H2 ; destruct H2. destruct s. rewrite e0.
+                apply GLRRule_I ; auto. intro. intros. apply in_top_boxes in H2 ; destruct H2. destruct s ; destruct s. destruct p1.
+                eexists ; subst ; auto. apply nobox_top_boxes.
+                apply GLS_prv_wkn_R with (A:=Diam (list_conj (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list))))))
+                (s:=(X0, Box (UI p (XBoxed_list (top_boxes (nodup eq_dec_form (fst k))) ++ [Box A], [A])) :: Y0)) ; auto.
+                assert ((X0, Box (UI p (XBoxed_list (top_boxes (nodup eq_dec_form (fst k))) ++ [Box A], [A])) :: Y0) = (X0, [Box (UI p (XBoxed_list (top_boxes (nodup eq_dec_form (fst k))) ++ [Box A], [A]))] ++ Y0)).
+                repeat rewrite <- app_assoc ; auto. rewrite H0. apply wkn_RI.
+         (* If Box A is in Y0 (ter). *)
+         -- pose (OrR (X0,x2 ++ Box A :: Δ1)). simpl in g0. apply g0. clear g0.
+            apply GLS_prv_wkn_R with (A:=list_disj (restr_list_prop p (snd k))) (s:=(X0,
+            Or (list_disj (map Neg (restr_list_prop p (fst k))))(Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) (Diam
+            (list_conj (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list)))))))
+            :: x2 ++ Box A :: Δ1)).
+            2: epose (wkn_RI (list_disj (restr_list_prop p (snd k))) _ [] _) ; simpl in w ; apply w.
+            pose (OrR (X0,x2 ++ Box A :: Δ1)). simpl in g0. apply g0. clear g0.
+            apply GLS_prv_wkn_R with (A:=list_disj (map Neg (restr_list_prop p (fst k)))) (s:=(X0,
+            Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) (Diam
+            (list_conj (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list))))))
+            :: x2 ++ Box A :: Δ1)).
+            2: epose (wkn_RI (list_disj (map Neg (restr_list_prop p (fst k)))) _ [] _) ; simpl in w ; apply w.
+            pose (OrR (X0,x2 ++ Box A :: Δ1)). simpl in g0. apply g0. clear g0.
+            apply GLS_prv_wkn_R with (A:=list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) (s:=(X0,
+            (Diam (list_conj (map (N p k) (Canopy (nodupseq (XBoxed_list (top_boxes (fst k)), []%list))))))
+            :: x2 ++ Box A :: Δ1)).
+            2: epose (wkn_RI (list_disj (map Box (map (UI p) (GLR_prems (nodupseq k))))) _ [] _) ; simpl in w ; apply w.
+            apply Diam_rec_UI ; auto.
+            assert (J5: derrec_height x < S (dersrec_height d)). lia.
+            assert (J6: derrec_height x = derrec_height x). auto.
+            assert (J7: (XBoxed_list (x0 ++ x1) ++ [Box A], [A]) = (fst (XBoxed_list x0, @nil MPropF) ++ XBoxed_list x1 ++ [Box A], snd (XBoxed_list x0, []) ++ [A])).
+            simpl ; rewrite XBox_app_distrib. repeat rewrite <- app_assoc ; auto.
+            assert (J8: (In # p (propvar_subform_list ((XBoxed_list x1 ++ [Box A]) ++ [A])) -> False)).
+            intro. apply propvar. repeat rewrite propvar_subform_list_app.
+            repeat rewrite propvar_subform_list_app in H0. simpl in H0. repeat rewrite app_nil_r in H0. simpl.
+            repeat rewrite <- app_assoc in H0. apply in_app_or in H0 ; destruct H0.
+            apply in_or_app ; left. apply propvar_subform_list_XBoxed_list in H0.
+            apply propvar_subform_list_nobox_gen_ext with (l0:=x1); auto.
+            apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; left. apply in_app_or in H0 ; destruct H0 ; auto.
+            pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+            apply derI with (ps:=[(X0 ++ Box (Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list))) :: [], [] ++ Bot :: x2 ++ Box A :: Δ1)]).
+            apply ImpR. assert ((X0, Diam (UI p (XBoxed_list (top_boxes (fst k)), []%list)) :: x2 ++ Box A :: Δ1) =
+            (X0 ++ [], [] ++ Diam (UI p (XBoxed_list (top_boxes (fst k)), []%list)) :: x2 ++ Box A :: Δ1)). rewrite app_nil_r. auto. rewrite H0.
+            apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+            apply derI with (ps:=[(XBoxed_list (x1 ++ [Box (Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list)))]) ++ [Box A], [A])]).
+            apply GLR. assert (([] ++ :: x2 ++ Box A :: Δ1) = ( :: x2) ++ Box A :: Δ1). auto. rewrite H0. apply GLRRule_I ; auto.
+            intro. intros. apply in_app_or in H2 ; destruct H2. apply H1 ; apply in_or_app ; auto. exists (Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list))).
+            inversion H2 ; subst ; auto. inversion H3. apply univ_gen_ext_combine ; auto. apply univ_gen_ext_cons. apply univ_gen_ext_nil.
+            apply dlCons. 2: apply dlNil. rewrite XBox_app_distrib. simpl. repeat rewrite <- app_assoc. simpl.
+            apply GLS_prv_wkn_L with (A:=Box (Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list)))) (s:=(XBoxed_list x1 ++
+            [Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list)); Box A], [A])).
+            2: epose (wkn_LI (Box (Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list)))) (XBoxed_list x1 ++ [Neg (UI p (XBoxed_list (top_boxes (fst k)), []%list))]) [Box A] _) ;
+            simpl in w ; repeat rewrite <- app_assoc in w ; simpl in w ; apply w.
+            apply derI with (ps:=[(XBoxed_list x1 ++ [Box A], [] ++ (UI p (XBoxed_list (top_boxes (fst k)), []%list)) :: [A]);
+            (XBoxed_list x1 ++ Bot :: [Box A], [] ++ [A])]). apply ImpL. apply ImpLRule_I. apply dlCons. 2: apply dlCons.
+            3: apply dlNil. 2: apply derI with (ps:=[]) ; [apply BotL ; apply BotLRule_I | apply dlNil].
+            simpl. assert ((top_boxes (fst k)) = x0). symmetry. apply nobox_gen_ext_top_boxes_identity ; auto.
+            intro. intros. apply H1 ; apply in_or_app ; auto. rewrite H0. auto.
+      (*  If not critical, consider the conjunction that UI p k is. *)
+      + assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+         assert (J1: Gimap (GUI p) (Canopy (nodupseq k)) (map (UI p) (Canopy (nodupseq k)))). apply Gimap_map. intros.
+         apply UI_GUI ; auto.
+         pose (@GUI_inv_not_critic p k (UI p k) (map (UI p) (Canopy (nodupseq k))) J0 f J1). rewrite <- e.
+ +
+         assert (J2: forall s1, InT s1 (Canopy (nodupseq k)) -> GLS_prv (X0, UI p s1 :: Y0)).
+         intros. pose (fold_Canopy _ _ H). destruct s ; subst.
+         exfalso. apply f. apply Canopy_critical in H ; auto. apply critical_nodupseq in H ; auto.
+         destruct s. destruct p0. unfold inv_prems in i.
+         apply InT_flatten_list_InT_elem in i. destruct i. destruct p0. simpl in PIH. simpl in SIH.
+         pose (derI _ g d).
+ +
+         assert (existsT2 (d1: GLS_prv (fst (nodupseq k) ++ X0, snd (nodupseq k) ++ Y0)), derrec_height d1 <= derrec_height d0).
+         destruct (nodupseq_id k). destruct p0. destruct s. destruct s. destruct p1. destruct p1.
+         pose (PermutationTS_prv_hpadm _ d0 (x2 ++ fst x1 ++ X0, x3 ++ snd x1 ++ Y0)). destruct s.
+         split ; simpl ; apply Permutation_PermutationT. destruct p1.
+         pose (@Permutation_app _ (fst k) X0 (x2 ++ fst x1) X0). rewrite <- app_assoc in p3 ; apply p3 ; auto.
+         apply Permutation_PermutationT ; auto. destruct p1.
+         pose (@Permutation_app _ (snd k) Y0 (x3 ++ snd x1) Y0). rewrite <- app_assoc in p3 ; apply p3 ; auto.
+         apply Permutation_PermutationT ; auto.
+         epose (incl_ctr_R_hpadm _ x3 _ x4). destruct s. intros A HA ; apply in_or_app ; left ; auto.
+         epose (incl_ctr_L_hpadm x2 _ _ x5). destruct s. intros A HA ; apply in_or_app ; left ; auto.
+         pose (PermutationTS_prv_hpadm _ x6 (fst (nodupseq k) ++ X0, snd (nodupseq k) ++ Y0)). destruct s.
+         split ; simpl ; apply Permutation_PermutationT. destruct p0. apply Permutation_app ; auto.
+         unfold nodupseq in p0. apply Permutation_PermutationT ; auto. destruct p0.
+         apply Permutation_app ; auto. unfold nodupseq in p2. apply Permutation_PermutationT ; auto.
+         exists x7. lia. destruct X1.
+         assert (J2: derrec_height x1 = derrec_height x1). auto.
+         assert (J3: (fst (nodupseq k) ++ X0, snd (nodupseq k) ++ Y0) = (fst (nodupseq k) ++ X0, snd (nodupseq k) ++ Y0)). auto.
+         pose (Canopy_hp_inv_ctx (nodupseq k) _ _ x1 X0 Y0 J2 J3 _ H). destruct s.
+         destruct (Compare_dec.lt_dec (derrec_height x2) (S (dersrec_height d))).
+         (* Use PIH. *)
+         pose (fold_Canopy _ _ H). destruct s ; subst.
+         exfalso. apply f. apply Canopy_critical in H ; auto. apply critical_nodupseq in H ; auto.
+         destruct s. destruct p0. unfold inv_prems in i2.
+         apply InT_flatten_list_InT_elem in i2. destruct i2. destruct p0.
+         assert (J4: derrec_height x2 = derrec_height x2). auto.
+         assert (J5: (fst s1 ++ X0, snd s1 ++ Y0) = (fst s1 ++ X0, snd s1 ++ Y0)). auto.
+         pose (PIH _ l1 s1 _ x2 X0 Y0 J4 J5). apply g0 ; auto.
+         (* Use SIH. *)
+         assert (derrec_height x2 = S (dersrec_height d)). assert (derrec_height d0 = S (dersrec_height d)). simpl. auto. lia.
+         assert (J4: LexSeq s1 k). pose (Canopy_LexSeq _ _ H).
+         destruct s ; subst ; auto. exfalso. apply f. apply Canopy_critical in H ; apply critical_nodupseq in H ; auto.
+         apply LexSeq_nodupseq in l1 ; auto. symmetry in H0.
+         assert (J5: (fst s1 ++ X0, snd s1 ++ Y0) = (fst s1 ++ X0, snd s1 ++ Y0)). auto.
+         pose (SIH _ J4 _ _ _ _ H0 J5 propvar). auto.
+ +
+         assert (J3: (forall A : MPropF, InT A (map (UI p) (Canopy (nodupseq k))) -> GLS_prv (fst (X0, Y0), A :: snd (X0, Y0)))).
+         intros. simpl. apply InT_map_iff in H. destruct H. destruct p0 ; subst. apply J2 in i ; auto.
+         pose (list_conj_R _ _ J3). simpl in g0. auto. }
+  Qed.
+ +
+  End UIPThree.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_UITwo.html b/GL.Interpolation.UIGL_UITwo.html new file mode 100644 index 0000000..f47ec38 --- /dev/null +++ b/GL.Interpolation.UIGL_UITwo.html @@ -0,0 +1,256 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_UITwo

+ +
+(* Uniform interpolation *)
+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+ +
+Require Import general_export.
+ +
+Require Import GLS_export.
+ +
+Require Import UIGL_Def_measure.
+Require Import UIGL_Canopy.
+Require Import UIGL_irred_short.
+Require Import UIGL_braga.
+Require Import UIGL_LexSeq.
+Require Import UIGL_nodupseq.
+Require Import UIGL_And_Or_rules.
+Require Import UIGL_UI_prelims.
+Require Import UIGL_UI_inter.
+ +
+  Section UIPTwo.
+ +
+  Theorem UI_Two : forall (s : Seq), forall p, GLS_prv ((UI p s) :: fst s, snd s).
+  Proof.
+  pose (LexSeq_ind (fun s => forall p, GLS_prv (UI p s :: fst s, snd s))).
+  apply g. clear g. intros.
+  destruct (empty_seq_dec s0).
+  (* s is the empty sequent. *)
+  { subst ; simpl in *. assert (GUI p ([],[]) Bot). apply GUI_empty_seq ; auto. apply UI_GUI in H.
+    rewrite H in *. apply derI with []. apply BotL ; apply (BotLRule_I [] []). apply dlNil. }
+  (* s is not the empty sequent. *)
+  { destruct (critical_Seq_dec s0).
+  (* s0 is a critical sequent *)
+  - destruct (dec_init_rules s0).
+    (* s0 is an initial sequent *)
+    + assert (GLS_prv (fst s0, snd s0)). destruct s0 ; destruct s. destruct s.
+      1,3: apply derI with (ps:=[]) ; try apply dlNil.
+      apply IdP ; auto. apply BotL ; auto. inversion i ; subst. apply Id_all_form.
+      destruct s0. simpl. simpl in X0.
+      assert (J0: derrec_height X0 = derrec_height X0). auto.
+      assert (J1: wkn_L (UI p (l, l0)) (l, l0) (UI p (l, l0) :: l, l0)).
+      assert ((l, l0) = ([] ++ l, l0)). auto. rewrite H.
+      assert ((UI p ([] ++ l, l0) :: l, l0) = ([] ++ UI p ([] ++ l, l0) :: l, l0)). auto. rewrite H0. apply wkn_LI.
+      pose (GLS_wkn_L X0 J0 J1). destruct s0. auto.
+    (* s0 is not an initial sequent *)
+   + assert (P1: GLS_prv (list_disj (map Neg (restr_list_prop p (fst s0))) :: fst s0, snd s0)).
+      apply list_disj_L. intros. apply InT_map_iff in H. destruct H. destruct p0. subst. unfold Neg.
+      apply derI with (ps:=[([] ++ fst s0, [] ++ x :: snd s0);([] ++ :: fst s0, [] ++ snd s0)]).
+      assert ((x --> :: fst s0, snd s0) = ([] ++ x --> :: fst s0, [] ++ snd s0)). auto. rewrite H. apply ImpL. apply ImpLRule_I.
+      apply dlCons. 2: apply dlCons. 3: apply dlNil. unfold restr_list_prop in i.
+      apply InT_In in i. apply In_remove_In_list in i. apply In_list_prop_LF in i. destruct i. apply In_InT in i.
+      apply InT_split in i. destruct i. destruct s1. destruct s. rewrite e. assert ([] ++ x0 ++ x :: x1 = x0 ++ x :: x1). auto.
+      rewrite H. apply Id_all_form. apply derI with (ps:=[]). apply BotL. apply BotLRule_I. apply dlNil.
+ +
+      assert (P2: GLS_prv (list_disj (restr_list_prop p (snd s0)) :: fst s0, snd s0)).
+      apply list_disj_L. intros. unfold restr_list_prop in H. apply InT_In in H. apply In_remove_In_list in H.
+      apply In_list_prop_LF in H. destruct H. apply In_InT in i. apply InT_split in i. destruct i. destruct s1.
+      rewrite e. assert (A :: fst s0 = [] ++ A :: fst s0). auto. rewrite H. apply Id_all_form.
+ +
+      assert (P3: GLS_prv (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s0)))) :: fst s0, snd s0)).
+      apply list_disj_L. intros. apply InT_map_iff in H. destruct H. destruct p0. subst. apply InT_map_iff in i.
+      destruct i. destruct p0 ; subst. unfold GLR_prems in i. destruct (finite_GLR_premises_of_S (nodupseq s0)).
+      simpl in i. apply InT_flatten_list_InT_elem in i. destruct i. destruct p1. apply p0 in i0.
+      inversion i0 ; subst. inversion i ; subst. simpl. remember (UI p (XBoxed_list ++ [Box A], [A])) as Interp.
+      apply derI with (ps:=[(XBoxed_list (Box Interp :: top_boxes (fst s0)) ++ [Box A], [A])]). apply GLR.
+      assert (InT (Box A) (snd s0)).
+      apply In_InT ; apply (nodup_In eq_dec_form) ; rewrite <- H2 ; apply in_or_app ; right ; simpl ; auto.
+      apply InT_split in H. destruct H. destruct s. rewrite e. apply GLRRule_I.
+      intro. intros. inversion H ; simpl. exists Interp ; auto. apply in_top_boxes in H0. destruct H0.
+      destruct s. destruct s. destruct p1 ; subst. eexists ; auto. apply univ_gen_ext_cons.
+      apply nobox_top_boxes. apply dlCons. 2: apply dlNil. simpl.
+      pose (incl_prv (Interp :: Box Interp :: XBoxed_list ++ [Box A], [A])). apply g ; clear g ; simpl ; auto. 1-2: intros B HB ; auto.
+      inversion HB ; simpl ; subst ; auto. inversion HB ; simpl ; subst ; auto. inversion H0 ; simpl ; subst ; auto.
+      apply in_app_or in H3 ; destruct H3. right. right. apply in_or_app ; left. apply In_XBoxed_list_gen in H3.
+      destruct H3. apply list_preserv_XBoxed_list. destruct (is_box_is_in_boxed_list _ H3 H1) ; subst.
+      apply is_box_in_top_boxes ; auto. 2: eexists ; auto. apply (nodup_In eq_dec_form).
+      apply (univ_gen_ext_In _ X0 H3). destruct H3. destruct H3 ; subst. apply XBoxed_list_In.
+      apply is_box_in_top_boxes ; auto. 2: eexists ; auto. apply (nodup_In eq_dec_form).
+      apply (univ_gen_ext_In _ X0 H3). right. right. apply in_or_app ; auto.
+      assert (J2: length (usable_boxes (XBoxed_list ++ [Box A], [A])) < length (usable_boxes s0)).
+      assert (J300: length (usable_boxes (XBoxed_list ++ [Box A], [A])) < length (usable_boxes (nodupseq s0))).
+      apply (GLR_applic_less_usable_boxes i0) ; auto. intro. assert (is_init s0).
+      apply is_init_nodupseq ; unfold is_init ; auto. apply f ; auto.
+      pose (ub_nodupseq s0). lia.
+      assert (J3: LexSeq (XBoxed_list ++ [Box A], [A]) s0).
+      apply DLW_wf_lex.lex_cons ; auto.
+      pose (X (XBoxed_list ++ [Box A], [A]) J3 p). simpl in g. rewrite <- HeqInterp in g.
+      assert (J4: derrec_height g = derrec_height g). auto.
+      assert (J5: wkn_L (Box Interp) (Interp :: XBoxed_list ++ [Box A], [A]) (Interp :: Box Interp :: XBoxed_list ++ [Box A], [A])).
+      assert (Interp :: XBoxed_list ++ [Box A] = [Interp] ++ XBoxed_list ++ [Box A]) ; auto. rewrite H.
+      assert (Interp :: Box Interp :: XBoxed_list ++ [Box A] = [Interp] ++ Box Interp :: XBoxed_list ++ [Box A]) ; auto. rewrite H0.
+      apply wkn_LI. pose (GLS_wkn_L g J4 J5). destruct s. auto. inversion H0.
+ +
+      assert (P4: GLS_prv (Diam (list_conj (map (N p s0) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s0)), []))))) :: fst s0, snd s0)).
+      apply DiamL_lim with (:=top_boxes (fst s0)). apply is_Boxed_list_top_boxes. apply nobox_top_boxes.
+      apply incl_prv with (s0:=(list_conj (map (N p s0) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s0)), []%list))))
+      :: fst ((nodupseq (XBoxed_list (top_boxes (fst s0)), []%list))), []%list)) ; simpl ; auto.
+      intros A HIn ; simpl. destruct HIn ; auto. right. apply nodup_In in H ; auto. intros A HA ; inversion HA.
+      pose (Canopy_nodupseq_equiprv_genL (nodupseq (XBoxed_list (top_boxes (fst s0)), []%list))
+      (list_conj (map (N p s0) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s0)), []%list)))))).
+      apply p0. clear p0. intros.
+      apply list_conj_wkn_L with (A:=N p s0 leaf).
+      apply InT_map_iff. exists leaf ; split ; auto. rewrite <- fixpoint_nodupseq in H ; auto.
+      destruct (dec_init_rules leaf).
+      (* If leaf is initial. *)
+      assert (GLS_prv leaf). destruct leaf. repeat destruct s. 1,3: apply derI with (ps:=[]) ; try apply dlNil.
+      apply IdP ; auto. apply BotL ; auto. inversion i. subst. apply Id_all_form.
+      rewrite <- fixpoint_nodupseq in H ; auto.
+      assert (J0: derrec_height X0 = derrec_height X0). auto.
+      assert (J1:wkn_L (N p s0 leaf) leaf (N p s0 leaf :: fst leaf, snd leaf)).
+      epose (wkn_LI _ [] (fst leaf) (snd leaf)). destruct leaf ; simpl ; simpl in w. apply w.
+      pose (GLS_wkn_L X0 J0 J1). destruct s1. auto.
+      (* If leaf is not initial. *)
+      destruct (Compare_dec.lt_dec (length (usable_boxes leaf)) (length (usable_boxes s0))).
+      (* If leaf has less usable boxes than (XBoxed_list (top_boxes (fst s0)), ). *)
+      unfold N. destruct (N_pwc p s0 leaf).
+      simpl. assert (J0: is_init leaf -> False). auto.
+      assert ((forall (x : Seq) (l m : MPropF), (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x l -> (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x m -> l = m)).
+      intros. subst. auto.
+      epose (@GN_inv_noinit_lessub p _ _ _ _ g J0 l (UI_spec p leaf)). rewrite <- e ; auto. clear e.
+      clear H0. apply X. apply DLW_wf_lex.lex_cons ; auto.
+      (* If leaf does not have less usable boxes than (XBoxed_list (top_boxes (fst s0)), ). *)
+      unfold N. destruct (N_pwc p s0 leaf).
+      simpl. assert (J0: is_init leaf -> False). auto.
+      assert ((forall (x : Seq) (l m : MPropF), (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x l -> (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x m -> l = m)).
+      intros. subst. auto.
+      assert (J1: Gimap (GUI p) (GLR_prems (nodupseq leaf)) (map (UI p) (GLR_prems (nodupseq leaf)))).
+      apply Gimap_map ; auto. intros ; apply UI_GUI ; auto.
+      pose (@GN_inv_noinit_nolessub p _ _ _ _ g J0 n0 J1).
+      rewrite <- e ; auto. clear e. clear J1. clear H0. apply OrL. 2: apply OrL.
+      1-3: apply list_disj_L ; intros. 1-2: unfold restr_list_prop in H0.
+      apply InT_In in H0. apply In_remove_In_list in H0.
+      apply In_list_prop_LF in H0. destruct H0. apply In_InT in i. apply InT_split in i. destruct i. destruct s1.
+      rewrite e. assert (A :: fst leaf = [] ++ A :: fst leaf). auto. rewrite H0. apply Id_all_form.
+      apply InT_map_iff in H0. destruct H0. destruct p0. subst. unfold Neg.
+      apply derI with (ps:=[([] ++ fst leaf, [] ++ x0 :: snd leaf);([] ++ :: fst leaf, [] ++ snd leaf)]).
+      assert ((x0 --> :: fst leaf, snd leaf) = ([] ++ x0 --> :: fst leaf, [] ++ snd leaf)). auto. rewrite H0. apply ImpL. apply ImpLRule_I.
+      apply dlCons. 2: apply dlCons. 3: apply dlNil.
+      apply InT_In in i. apply In_remove_In_list in i. apply In_list_prop_LF in i. destruct i. apply In_InT in i.
+      apply InT_split in i. destruct i. destruct s1. rewrite e. assert ([] ++ x1 ++ x0 :: x2 = x1 ++ x0 :: x2). auto.
+      rewrite H0. apply Id_all_form. apply derI with (ps:=[]). apply BotL. apply BotLRule_I. apply dlNil.
+      apply InT_map_iff in H0. destruct H0. destruct p0. subst. apply InT_map_iff in i. destruct i. destruct p0.
+      subst. unfold GLR_prems in i. destruct (finite_GLR_premises_of_S (nodupseq leaf)).
+      simpl in i. apply InT_flatten_list_InT_elem in i. destruct i. destruct p1. apply p0 in i0.
+      inversion i0 ; subst. inversion i ; subst. simpl. remember (UI p (XBoxed_list ++ [Box A], [A])) as Interp.
+      apply derI with (ps:=[(XBoxed_list (Box Interp :: (top_boxes (fst leaf))) ++ [Box A], [A])]). apply GLR.
+      assert (InT (Box A) (snd leaf)).
+      apply In_InT ; apply (nodup_In eq_dec_form) ; rewrite <- H3 ; apply in_or_app ; right ; simpl ; auto.
+      apply InT_split in H0. destruct H0. destruct s. rewrite e. apply GLRRule_I.
+      intro. intros. inversion H0 ; simpl. exists Interp ; auto. apply in_top_boxes in H1. destruct H1.
+      destruct s. destruct s. destruct p1 ; subst. eexists ; auto. apply univ_gen_ext_cons.
+      apply nobox_top_boxes. apply dlCons. 2: apply dlNil. simpl.
+      pose (incl_prv (Interp :: Box Interp :: XBoxed_list ++ [Box A], [A])). apply g0 ; clear g0 ; simpl ; auto. 1-2: intros B HB ; auto.
+      inversion HB ; simpl ; subst ; auto. inversion HB ; simpl ; subst ; auto. inversion H1 ; simpl ; subst ; auto.
+      apply in_app_or in H4 ; destruct H4. right. right. apply in_or_app ; left. apply In_XBoxed_list_gen in H4.
+      destruct H4. apply list_preserv_XBoxed_list. destruct (is_box_is_in_boxed_list _ H4 H2) ; subst.
+      apply is_box_in_top_boxes ; auto. 2: eexists ; auto. apply (nodup_In eq_dec_form).
+      apply (univ_gen_ext_In _ X0 H4). destruct H4. destruct H4 ; subst. apply XBoxed_list_In.
+      apply is_box_in_top_boxes ; auto. 2: eexists ; auto. apply (nodup_In eq_dec_form).
+      apply (univ_gen_ext_In _ X0 H4). right. right. apply in_or_app ; auto.
+      assert (J2: length (usable_boxes (XBoxed_list ++ [Box A], [A])) < length (usable_boxes leaf)).
+      assert (J300: length (usable_boxes (XBoxed_list ++ [Box A], [A])) < length (usable_boxes (nodupseq leaf))).
+      apply (GLR_applic_less_usable_boxes i0) ; auto. intro. apply J0. apply is_init_nodupseq ; unfold is_init ; auto.
+      pose (ub_nodupseq leaf). lia.
+      assert (J3: LexSeq (XBoxed_list ++ [Box A], [A]) s0).
+      apply DLW_wf_lex.lex_cons ; auto. pose (leq_ub_unif s0). apply leq_ub_Canopy in H.
+      rewrite <- fixpoint_nodupseq in H.
+      assert (J30:length (usable_boxes (XBoxed_list (top_boxes (fst s0)), []%list)) = length (usable_boxes (nodupseq (XBoxed_list (top_boxes (fst s0)), []%list)))).
+      apply ub_nodupseq. lia.
+      pose (X (XBoxed_list ++ [Box A], [A]) J3 p). simpl in g0. rewrite <- HeqInterp in g0.
+      assert (J4: derrec_height g0 = derrec_height g0). auto.
+      assert (J5: wkn_L (Box Interp) (Interp :: XBoxed_list ++ [Box A], [A]) (Interp :: Box Interp :: XBoxed_list ++ [Box A], [A])).
+      assert (Interp :: XBoxed_list ++ [Box A] = [Interp] ++ XBoxed_list ++ [Box A]) ; auto. rewrite H0.
+      assert (Interp :: Box Interp :: XBoxed_list ++ [Box A] = [Interp] ++ Box Interp :: XBoxed_list ++ [Box A]) ; auto. rewrite H1.
+      apply wkn_LI. pose (GLS_wkn_L g0 J4 J5). destruct s. auto. inversion H1.
+      remember (fst s0) as LHS.
+      assert (GUI p s0
+      (Or (list_disj (restr_list_prop p (snd s0)))
+      (Or (list_disj (map Neg (restr_list_prop p (fst s0))))
+      (Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s0)))))
+      (Diam (list_conj (map (N p s0) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s0)), []%list)))))))))).
+      apply GUI_critic_not_init ; auto. 1-2: apply Gimap_map ; intros. apply UI_GUI ; auto.
+      apply (@N_spec p s0 x). apply (UI_GUI p s0) in H. rewrite H. rewrite HeqLHS in *. repeat apply OrL ; auto.
+  (* s0 is not a critical sequent *)
+  - assert (J0: GUI p s0 (UI p s0)). apply UI_GUI ; auto.
+    assert (J1: Gimap (GUI p) (Canopy (nodupseq s0)) (map (UI p) (Canopy (nodupseq s0)))). apply Gimap_map. intros.
+    apply UI_GUI ; auto.
+    pose (@GUI_inv_not_critic p s0 (UI p s0) (map (UI p) (Canopy (nodupseq s0))) J0 f J1). rewrite <- e.
+    destruct (LexSeq_nodupseq_case s0).
+    + assert (J2: forall s1, InT s1 (Canopy (nodupseq s0)) -> GLS_prv (UI p s1 :: fst s1, snd s1)).
+       intros. apply X. pose (Canopy_LexSeq _ _ H). destruct s ; subst ; auto. apply LexSeq_trans with (y:=nodupseq s0) ; auto.
+       assert (J3 : forall s1 : Seq, InT s1 (Canopy (nodupseq s0)) -> GLS_prv (list_conj (map (UI p) (Canopy (nodupseq s0))) :: fst s1, snd s1)).
+       intros. apply list_conj_wkn_L with (A:=UI p s1) ; auto. apply InT_mapI. exists s1 ; auto.
+       apply Canopy_nodupseq_equiprv_genL ; auto.
+    + destruct p0. assert (J2: forall s1, InT s1 (Canopy (nodupseq s0)) -> GLS_prv (UI p s1 :: fst s1, snd s1)).
+       intros. apply X. pose (Canopy_LexSeq _ _ H). destruct s ; subst ; auto. exfalso.
+       apply f. apply critical_nodupseq. apply Canopy_critical in H ; auto. unfold LexSeq in *.
+       inversion l ; subst. unfold less_thanS. unfold GLS_termination_measure.measure. rewrite <- e1 in *. rewrite H3. apply DLW_wf_lex.lex_skip ; auto.
+       rewrite e0 in *. apply DLW_wf_lex.lex_cons ; auto. inversion H1 ; subst ; auto. inversion H2. apply DLW_wf_lex.lex_cons ; auto. lia.
+       assert (J3 : forall s1 : Seq, InT s1 (Canopy (nodupseq s0)) -> GLS_prv (list_conj (map (UI p) (Canopy (nodupseq s0))) :: fst s1, snd s1)).
+       intros. apply list_conj_wkn_L with (A:=UI p s1) ; auto. apply InT_mapI. exists s1 ; auto.
+       apply Canopy_nodupseq_equiprv_genL ; auto. }
+  Qed.
+ +
+  End UIPTwo.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_UI_inter.html b/GL.Interpolation.UIGL_UI_inter.html new file mode 100644 index 0000000..f5ff5ba --- /dev/null +++ b/GL.Interpolation.UIGL_UI_inter.html @@ -0,0 +1,631 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_UI_inter

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+ +
+Require Import general_export.
+ +
+Require Import GLS_export.
+ +
+Require Import UIGL_Def_measure.
+Require Import UIGL_Canopy.
+Require Import UIGL_irred_short.
+Require Import UIGL_braga.
+Require Import UIGL_LexSeq.
+Require Import UIGL_nodupseq.
+Require Import UIGL_PermutationT.
+Require Import UIGL_PermutationTS.
+Require Import UIGL_And_Or_rules.
+Require Import UIGL_UI_prelims.
+ +
+  Theorem PermutationTS_UI : forall s sp p, PermutationTS s sp -> GLS_prv ([UI p s], [UI p sp]).
+  Proof.
+  pose (d:=LexSeq_ind (fun (s:Seq) => forall sp p, PermutationTS s sp -> GLS_prv ([UI p s], [UI p sp]))).
+  apply d. clear d. intros s IH sp p perm.
+  destruct (empty_seq_dec s) as [EE | DE].
+  { subst. assert (J0: GUI p ([],[]) Bot). apply GUI_empty_seq ; auto. apply UI_GUI in J0.
+     rewrite J0 in *. apply derI with []. apply BotL ; apply (BotLRule_I [] []). apply dlNil. }
+  { destruct (critical_Seq_dec s).
+  (* Sequents are critical. *)
+  - pose (PermutationTS_critic _ _ perm c).
+    destruct (dec_init_rules s).
+    (* Sequents are initial. *)
+    * assert (is_init s) ; auto. pose (PermutationTS_is_init _ _ perm X).
+      assert (J0: GUI p sp (UI p sp)). apply UI_GUI ; auto.
+      pose (@GUI_inv_critic_init p sp _ J0 c0 i). rewrite <- e. epose (TopR _ [] []). simpl in g ; apply g.
+    (* Sequents are not initial. *)
+    * assert ((is_init s) -> False) ; auto. assert ((is_init sp) -> False). intro. apply H.
+      pose (PermutationTS_sym _ _ perm). apply (PermutationTS_is_init _ _ p0) ; auto.
+      assert (J0: GUI p s (UI p s)). apply UI_GUI ; auto.
+      assert (J00: GUI p sp (UI p sp)). apply UI_GUI ; auto.
+      assert (J1: Gimap (GUI p) (GLR_prems (nodupseq s)) (map (UI p) (GLR_prems (nodupseq s)))). apply Gimap_map. intros.
+      apply UI_GUI ; auto.
+      assert (J10: Gimap (GUI p) (GLR_prems (nodupseq sp)) (map (UI p) (GLR_prems (nodupseq sp)))). apply Gimap_map. intros.
+      apply UI_GUI ; auto.
+      assert (J2: (Gimap (GN p (GUI p) s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), [])))
+      (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), [])))))). apply Gimap_map. intros.
+      pose (N_spec p s x) ; auto.
+      assert (J20: (Gimap (GN p (GUI p) sp) (Canopy (nodupseq (XBoxed_list (top_boxes (fst sp)), [])))
+      (map (N p sp) (Canopy (nodupseq (XBoxed_list (top_boxes (fst sp)), [])))))). apply Gimap_map. intros.
+      apply (N_spec p sp x).
+      assert (J41: sp <> ([], [])). intro. destruct sp ; destruct s ; inversion H1 ; subst. apply DE. destruct perm. simpl in *.
+      destruct (Permutation_PermutationT l1 []). pose (p3 p0). apply Permutation_sym in p4 ; apply Permutation_nil in p4.
+      destruct (Permutation_PermutationT l2 []). pose (p6 p1). apply Permutation_sym in p7 ; apply Permutation_nil in p7 ; subst ; auto.
+       pose (@GUI_inv_critic_not_init p s _ _ _ J0 c DE H J1 J2). rewrite <- e ; clear e.
+       pose (@GUI_inv_critic_not_init p sp _ _ _ J00 c0 J41 H0 J10 J20). rewrite <- e ; clear e.
+        epose (OrR (_,[])). simpl in g. apply g ; clear g.
+        epose (OrL ([],_)). simpl in g. apply g ; clear g.
+        epose (list_disj_L _ (_,_)). apply g ; clear g. simpl ; intros.
+        pose (PermutationTS_restr_list_prop_snd _ _ _ _ perm H1).
+        epose (list_disj_wkn_R _ ([_],[_]) _ i). simpl in g. apply g ; clear g.
+        epose (Id_all_form _ [] _ []). simpl in d ; apply d.
+        eapply GLS_prv_wkn_R with (s:=([Or (list_disj (map Neg (restr_list_prop p (fst s)))) (Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s)))))
+       (Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))))], [Or (list_disj (map Neg (restr_list_prop p (fst sp)))) (Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq sp)))))
+        (Diam (list_conj (map (N p sp) (Canopy (nodupseq (XBoxed_list (top_boxes (fst sp)), []%list)))))))])) (A:=list_disj (restr_list_prop p (snd sp))).
+        2: epose (wkn_RI (list_disj (restr_list_prop p (snd sp))) _ [] _) ; simpl in w ; apply w.
+        epose (OrR (_,[])). simpl in g. apply g ; clear g.
+        epose (OrL ([],_)). simpl in g. apply g ; clear g.
+        epose (list_disj_L _ (_,_)). apply g ; clear g. simpl ; intros.
+        apply InT_map_iff in H1. destruct H1. destruct p0 ; subst.
+        pose (@PermutationTS_restr_list_prop_fst _ _ p x perm i).
+        epose (list_disj_wkn_R _ ([_],[_]) _). simpl in g. apply g ; clear g. apply InT_map_iff. exists x ; split ; auto.
+        epose (Id_all_form _ [] _ []). simpl in d ; apply d.
+        eapply GLS_prv_wkn_R with (s:=([Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s))))) (Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))))],
+        [(Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq sp)))))
+        (Diam (list_conj (map (N p sp) (Canopy (nodupseq (XBoxed_list (top_boxes (fst sp)), []%list)))))))])) (A:=list_disj (map Neg (restr_list_prop p (fst sp)))).
+        2: epose (wkn_RI (list_disj (map Neg (restr_list_prop p (fst sp)))) _ [] _) ; simpl in w ; apply w.
+        epose (OrR (_,[])). simpl in g. apply g ; clear g.
+        epose (OrL ([],_)). simpl in g. apply g ; clear g.
+        epose (list_disj_L _ (_,_)). apply g ; clear g. simpl ; intros. apply InT_map_iff in H1.
+        destruct H1. destruct p0 ; subst. apply InT_map_iff in i. destruct i. destruct p0 ; subst.
+        destruct (PermutationTS_GLR_prems _ _ (PermutationTS_nodupseq _ _ perm) _ i). destruct p0.
+        epose (list_disj_wkn_R _ ([_],_) (Box (UI p x))). simpl in g. apply g ; clear g.
+        apply InT_map_iff. exists (UI p x). split ; auto. apply InT_map_iff. exists x ; split ; auto.
+        apply derI with (ps:=[([(UI p x0);Box (UI p x0);Box (UI p x)], [UI p x])]). apply GLR.
+        epose (@GLRRule_I _ [Box (UI p x0)] _ []). simpl in g. apply g. intros A HA. inversion HA ; subst.
+        eexists ; auto. inversion H1. apply univ_gen_ext_refl. apply dlCons. 2: apply dlNil.
+        assert (J50: GLS_prv ([UI p x0], [UI p x])).
+        apply IH ; auto. apply GLR_prems_LexSeq in i ; auto. apply LexSeq_nodupseq in i ; auto.
+        intro. assert (is_init (nodupseq s)) ; auto. unfold is_init ; auto. apply H. apply is_init_nodupseq ; auto.
+        epose (GLS_prv_list_wkn_L [UI p x0] [] J50 _). simpl in g ; rewrite app_nil_r in g. apply g.
+        eapply GLS_prv_wkn_R with (s:=([Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))],
+        [Diam (list_conj (map (N p sp) (Canopy (nodupseq (XBoxed_list (top_boxes (fst sp)), []%list)))))])) (A:=list_disj (map Box (map (UI p) (GLR_prems (nodupseq sp))))).
+        2: epose (wkn_RI (list_disj (map Box (map (UI p) (GLR_prems (nodupseq sp))))) _ [] _) ; simpl in w ; apply w.
+        remember (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) as conjL.
+        remember (list_conj (map (N p sp) (Canopy (nodupseq (XBoxed_list (top_boxes (fst sp)), []%list))))) as conjR.
+        apply derI with (ps:=[([Box (Neg conjR) ; Diam conjL], [Bot])]). apply ImpR. epose (ImpRRule_I _ _ [] [_] [] []). simpl in i ; apply i.
+        apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[([Box (Neg conjR)], [Box (Neg conjL);]);([Box (Neg conjR); ], [])]).
+        apply ImpL. epose (ImpLRule_I _ _ [_] [] [] [_]). simpl in i. apply i. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+        2: apply derI with (ps:=[]) ; [ apply BotL ; epose (BotLRule_I [_] []) ; simpl in b ; auto | apply dlNil].
+        apply derI with (ps:=[([Neg conjR;Box (Neg conjR);Box (Neg conjL)], [Neg conjL])]). apply GLR.
+        epose (@GLRRule_I _ [Box (Neg conjR)] _ [] [_]). simpl in g ; apply g ; clear g ; auto. intros A HA. inversion HA ; subst.
+        eexists ; auto. inversion H1. apply univ_gen_ext_refl. apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[([conjL;Neg conjR; Box (Neg conjR); Box (Neg conjL)], [Bot])]). apply ImpR. epose (ImpRRule_I _ _ [] _ [] []). simpl in i ; apply i.
+        apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[([conjL; Box (Neg conjR); Box (Neg conjL)], [conjR;]);([conjL; Bot; Box (Neg conjR); Box (Neg conjL)], [])]).
+        apply ImpL. epose (ImpLRule_I _ _ [_] _ [] [_]). simpl in i. apply i. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+        2: apply derI with (ps:=[]) ; [ apply BotL ; epose (BotLRule_I [_] _) ; simpl in b ; auto | apply dlNil].
+        remember ([Box (Neg conjR); Box (Neg conjL)]) as LHS0. rewrite HeqconjL. rewrite HeqconjR.
+        epose (list_conj_R _ (_,_)). apply g ; clear g. simpl ; intros. apply InT_map_iff in H1.
+        destruct H1. destruct p0 ; subst.
+        assert (PermutationTS (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)) (nodupseq (XBoxed_list (top_boxes (fst sp)), []%list))).
+        apply PermutationTS_nodupseq. split ; simpl ; auto. apply PermutationT_XBoxed_list. apply PermutationT_top_boxes. destruct perm ; auto.
+        apply PermutationT_refl. apply PermutationTS_sym in H1.
+        pose (PermutationTS_Canopy _ _ H1 _ i). destruct s0. destruct p0.
+        epose (list_conj_wkn_L _ (_,_) (N p s x0)). simpl in g. apply g ; clear g.
+        apply InT_map_iff. exists x0 ; split ; auto.
+ +
+        assert (J100: GLS_prv ([N p s x0], [N p sp x])).
+        { (* Massage the Ns. *)
+          assert ((forall (x : Seq) (l m : MPropF), (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x l -> (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x m -> l = m)).
+          intros. subst. auto.
+          destruct (dec_init_rules x0).
+          (* The sequents x0 and x are initial. *)
+           assert (is_init x0) ; auto. pose (PermutationTS_is_init _ _ (PermutationTS_sym _ _ p0) X).
+           pose (N_spec p sp x).
+           pose (GN_inv_init _ g i1). rewrite <- e.
+           epose (TopR _ [] []). simpl in g0 ; apply g0.
+          (* The sequent x0 and x are not initial. *)
+           assert (is_init x0 -> False) ; auto.
+           assert (is_init x -> False). intro. apply H3. apply (PermutationTS_is_init _ _ p0 X).
+           assert (J200: GUI p x0 (UI p x0)). apply UI_GUI ; auto.
+           assert (J300: GUI p x (UI p x)). apply UI_GUI ; auto.
+           pose (Canopy_critical _ _ i0).
+           pose (Canopy_critical _ _ i).
+           assert (J80: length (usable_boxes s) = length (usable_boxes sp)).
+           assert (incl (usable_boxes s) (usable_boxes sp)). intros A HA. apply InT_In. apply In_InT in HA.
+           apply (PermutationTS_usable_boxes _ _ perm) ; auto.
+           epose (NoDup_incl_length (NoDup_usable_boxes s) H5).
+           assert (incl (usable_boxes sp) (usable_boxes s)). intros A HA. apply InT_In. apply In_InT in HA.
+           apply (PermutationTS_usable_boxes _ _ (PermutationTS_sym _ _ perm)) ; auto.
+           epose (NoDup_incl_length (NoDup_usable_boxes sp) H6). lia.
+           assert (J81: length (usable_boxes x) = length (usable_boxes x0)).
+           assert (incl (usable_boxes x) (usable_boxes x0)). intros A HA. apply InT_In. apply In_InT in HA.
+           apply (PermutationTS_usable_boxes _ _ p0) ; auto.
+           epose (NoDup_incl_length (NoDup_usable_boxes x) H5).
+           assert (incl (usable_boxes x0) (usable_boxes x)). intros A HA. apply InT_In. apply In_InT in HA.
+           apply (PermutationTS_usable_boxes _ _ (PermutationTS_sym _ _ p0)) ; auto.
+           epose (NoDup_incl_length (NoDup_usable_boxes x0) H6). lia.
+           destruct (Compare_dec.lt_dec (length (usable_boxes x0)) (length (usable_boxes s))).
+           (* The sequent x0 has less usable boxes than s. *)
+           pose (N_spec p s x0).
+           epose (@GN_inv_noinit_lessub _ _ _ _ _ g H3 l J200). rewrite <- e ; auto.
+           assert (J500: length (usable_boxes x) < length (usable_boxes sp)). lia.
+           pose (N_spec p sp x).
+           epose (@GN_inv_noinit_lessub _ _ _ _ _ g0 H4 J500 J300). rewrite <- e0 ; auto.
+           apply IH. apply DLW_wf_lex.lex_cons ; auto. apply PermutationTS_sym ; auto.
+           (* The sequent x0 does not have less usable boxes than s. *)
+           pose (N_spec p s x0).
+           assert (J410: Gimap (GUI p) (GLR_prems (nodupseq x0)) (map (UI p) (GLR_prems (nodupseq x0)))).
+           apply Gimap_map ; auto. intros. apply UI_GUI ; auto.
+           epose (@GN_inv_noinit_nolessub _ _ _ _ _ g H3 n J410). rewrite <- e ; auto.
+           assert (J42: (length (usable_boxes x) < length (usable_boxes sp)) -> False). lia.
+           pose (N_spec p sp x).
+           assert (J43: Gimap (GUI p) (GLR_prems (nodupseq x)) (map (UI p) (GLR_prems (nodupseq x)))).
+           apply Gimap_map ; auto. intros. apply UI_GUI ; auto.
+           epose (@GN_inv_noinit_nolessub _ _ _ _ _ g0 H4 J42 J43). rewrite <- e0 ; auto.
+           epose (OrR (_,[])). simpl in g1. apply g1 ; clear g1.
+           epose (OrL ([],_)). simpl in g1. apply g1 ; clear g1.
+           epose (list_disj_L _ (_,_)). apply g1 ; clear g1. simpl ; intros.
+           pose (PermutationTS_restr_list_prop_snd _ _ _ _ (PermutationTS_sym _ _ p0) H5).
+           epose (list_disj_wkn_R _ ([_],[_]) _ i1). simpl in g1. apply g1 ; clear g1.
+           epose (Id_all_form _ [] _ []). simpl in d ; apply d.
+           eapply GLS_prv_wkn_R with (s:=([Or (list_disj (map Neg (restr_list_prop p (fst x0)))) (list_disj (map Box (map (UI p) (GLR_prems (nodupseq x0)))))],
+           [Or (list_disj (map Neg (restr_list_prop p (fst x)))) (list_disj (map Box (map (UI p) (GLR_prems (nodupseq x)))))])) (A:=list_disj (restr_list_prop p (snd x))).
+           2: epose (wkn_RI (list_disj (restr_list_prop p (snd x))) _ [] _) ; simpl in w ; apply w.
+           epose (OrR (_,[])). simpl in g1. apply g1 ; clear g1.
+           epose (OrL ([],_)). simpl in g1. apply g1 ; clear g1.
+           epose (list_disj_L _ (_,_)). apply g1 ; clear g1. simpl ; intros.
+           apply InT_map_iff in H5. destruct H5. destruct p1 ; subst.
+           pose (@PermutationTS_restr_list_prop_fst _ _ p x1 (PermutationTS_sym _ _ p0) i1).
+           epose (list_disj_wkn_R _ ([_],[_]) _). simpl in g1. apply g1 ; clear g1. apply InT_map_iff. exists x1 ; split ; auto.
+           epose (Id_all_form _ [] _ []). simpl in d ; apply d.
+           eapply GLS_prv_wkn_R with (s:=([list_disj (map Box (map (UI p) (GLR_prems (nodupseq x0))))],
+           [list_disj (map Box (map (UI p) (GLR_prems (nodupseq x))))])) (A:=list_disj (map Neg (restr_list_prop p (fst x)))).
+           2: epose (wkn_RI (list_disj (map Neg (restr_list_prop p (fst x)))) _ [] _) ; simpl in w ; apply w.
+            epose (list_disj_L _ (_,_)). apply g1 ; clear g1. simpl ; intros. apply InT_map_iff in H5.
+            destruct H5. destruct p1 ; subst. apply InT_map_iff in i1. destruct i1. destruct p1 ; subst.
+            destruct (PermutationTS_GLR_prems _ _ (PermutationTS_nodupseq _ _ (PermutationTS_sym _ _ p0)) _ i1). destruct p1.
+            epose (list_disj_wkn_R _ ([_],_) (Box (UI p x1))). simpl in g1. apply g1 ; clear g1.
+            apply InT_map_iff. exists (UI p x1). split ; auto. apply InT_map_iff. exists x1 ; split ; auto.
+            apply derI with (ps:=[([(UI p x2);Box (UI p x2);Box (UI p x1)], [UI p x1])]). apply GLR.
+            epose (@GLRRule_I _ [Box (UI p x2)] _ []). simpl in g1. apply g1 ; clear g1. intros A HA. inversion HA ; subst.
+            eexists ; auto. inversion H5. apply univ_gen_ext_refl. apply dlCons. 2: apply dlNil.
+            assert (J50: GLS_prv ([UI p x2], [UI p x1])). apply IH ; auto.
+            pose (leq_ub_unif s). pose (leq_ub_Canopy _ _ i0). apply DLW_wf_lex.lex_cons ; auto.
+            unfold GLR_prems in i1. destruct (finite_GLR_premises_of_S (nodupseq x0)). simpl in i1. apply InT_flatten_list_InT_elem in i1.
+            destruct i1. destruct p3. apply p2 in i3. inversion i3 ; subst. inversion i1 ; subst.
+            assert ((IdBRule []%list (nodupseq x0)) -> False). intro. assert (is_init (nodupseq x0)).
+            destruct x0 ; simpl in H5 ; simpl in H8 ; unfold nodupseq ; simpl ; unfold is_init ; subst ; auto.
+            apply is_init_nodupseq in X0 ; auto. pose (GLR_applic_less_usable_boxes i3 H5).
+            assert (J30:length (usable_boxes (XBoxed_list (top_boxes (fst s)), []%list)) = length (usable_boxes (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))).
+            apply ub_nodupseq. rewrite <- J30 in l0. pose (ub_nodupseq x0). lia. inversion H6.
+            epose (@GLS_prv_list_wkn_L [_] [] _). rewrite app_nil_r in g1 ; simpl in g1. epose (g1 J50 [_;_]). simpl in g2. apply g2. }
+
+        epose (@GLS_prv_list_wkn_R _ _ []). rewrite app_nil_r in g ; simpl in g. pose (g J100 [Bot]). simpl in g0.
+        epose (@GLS_prv_list_wkn_L [_] [] _). rewrite app_nil_r in g1 ; simpl in g1. epose (g1 g0 [_;_]). simpl in g2. apply g2.
+  (* Sequents are not critical. *)
+  - assert (J0: GUI p s (UI p s)). apply UI_GUI ; auto. assert (J00: GUI p sp (UI p sp)). apply UI_GUI ; auto.
+    assert (J1: Gimap (GUI p) (Canopy (nodupseq s)) (map (UI p) (Canopy (nodupseq s)))). apply Gimap_map. intros.
+    apply UI_GUI ; auto.
+    assert (J10: Gimap (GUI p) (Canopy (nodupseq sp)) (map (UI p) (Canopy (nodupseq sp)))). apply Gimap_map. intros.
+    apply UI_GUI ; auto.
+    pose (@GUI_inv_not_critic p s _ _ J0 f J1). rewrite <- e ; clear e.
+    assert (critical_Seq sp -> False). intro. apply f. apply (PermutationTS_critic _ _ (PermutationTS_sym _ _ perm) H).
+    pose (@GUI_inv_not_critic p sp _ _ J00 H J10). rewrite <- e ; clear e.
+    epose (list_conj_R _ (_,_)). simpl in g. apply g ; clear g. intros.
+    apply InT_map_iff in H0. destruct H0. destruct p0. subst.
+    pose (PermutationTS_nodupseq _ _ perm). apply PermutationTS_sym in p0.
+    pose (PermutationTS_Canopy _ _ p0 _ i). destruct s0. destruct p1.
+    epose (list_conj_wkn_L _ (_,_) (UI p x0)). simpl in g. apply g ; clear g.
+    apply InT_map_iff. exists x0 ; split ; auto.
+    assert (LexSeq x0 s). pose (Canopy_LexSeq _ _ i0). destruct s0 ; subst ; auto. exfalso.
+    apply f ; apply Canopy_critical in i0 ; auto. apply critical_nodupseq ; auto. apply LexSeq_nodupseq in l ; auto.
+    apply (IH _ H0 _ p (PermutationTS_sym _ _ p1)). }
+  Qed.
+ +
+  Lemma UI_nodupseq : forall s p X Y, GLS_prv (UI p (nodupseq s) :: X, UI p s :: Y).
+  Proof.
+  pose (d:=LexSeq_ind (fun (s:Seq) => forall p X Y, GLS_prv (UI p (nodupseq s) :: X, UI p s :: Y))).
+  apply d. clear d. intros s IH p X Y.
+  destruct (empty_seq_dec s) as [EE | DE].
+  { subst. unfold nodupseq. simpl. assert (J0: GUI p ([],[]) Bot). apply GUI_empty_seq ; auto. apply UI_GUI in J0.
+     rewrite J0 in *. apply derI with []. apply BotL ; apply (BotLRule_I []). apply dlNil. }
+  { destruct (critical_Seq_dec s).
+  (* Sequents are critical. *)
+  - assert (critical_Seq (nodupseq s)). apply (critical_nodupseq s) ; auto.
+    destruct (dec_init_rules s).
+    (* Sequents are initial. *)
+    * assert (is_init s) ; auto. assert (is_init (nodupseq s)). apply (is_init_nodupseq s) ; auto.
+      assert (J0: GUI p s (UI p s)). apply UI_GUI ; auto.
+      pose (@GUI_inv_critic_init p s _ J0 c X0). rewrite <- e. epose (TopR _ [] _). simpl in g ; apply g.
+    (* Sequents are not initial. *)
+    * assert ((is_init s) -> False) ; auto. assert ((is_init (nodupseq s)) -> False). intro. apply H0.
+      apply (is_init_nodupseq s) ; auto.
+      assert (J0: GUI p s (UI p s)). apply UI_GUI ; auto.
+      assert (J00: GUI p (nodupseq s) (UI p (nodupseq s))). apply UI_GUI ; auto.
+      assert (J1: Gimap (GUI p) (GLR_prems (nodupseq s)) (map (UI p) (GLR_prems (nodupseq s)))). apply Gimap_map. intros.
+      apply UI_GUI ; auto.
+      assert (J10: Gimap (GUI p) (GLR_prems (nodupseq (nodupseq s))) (map (UI p) (GLR_prems (nodupseq (nodupseq s))))). apply Gimap_map. intros.
+      apply UI_GUI ; auto.
+      assert (J2: (Gimap (GN p (GUI p) s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), [])))
+      (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), [])))))). apply Gimap_map. intros.
+      apply (N_spec p s x).
+      assert (J20: (Gimap (GN p (GUI p) (nodupseq s)) (Canopy (nodupseq (XBoxed_list (top_boxes (fst (nodupseq s))), [])))
+      (map (N p (nodupseq s)) (Canopy (nodupseq (XBoxed_list (top_boxes (fst (nodupseq s))), [])))))). apply Gimap_map. intros.
+      apply (N_spec p (nodupseq s) x).
+      assert (J41: (nodupseq s) <> ([],[])). intro. apply DE. destruct s. simpl in *. unfold nodupseq in *. simpl in H2. inversion H2 ; subst.
+      apply nodup_nil in H4 ; rewrite H4 in H5 ; apply nodup_nil in H5 ; subst ; auto.
+       pose (@GUI_inv_critic_not_init p s _ _ _ J0 c DE H0 J1 J2). rewrite <- e ; clear e.
+       pose (@GUI_inv_critic_not_init p (nodupseq s) _ _ _ J00 H J41 H1 J10 J20). rewrite <- e ; clear e.
+       repeat rewrite <- fixpoint_nodupseq.
+        epose (OrR (_,_)). simpl in g. apply g ; clear g.
+        epose (OrL (_,_)). simpl in g. apply g ; clear g.
+        epose (list_disj_L _ (_,_)). apply g ; clear g. simpl ; intros.
+        epose (restr_list_prop_nodup (snd s) A p). apply p0 in H2.
+        epose (list_disj_wkn_R _ (_,_) _ H2). simpl in g. apply g ; clear g.
+        epose (Id_all_form _ [] _ []). simpl in d ; apply d.
+        eapply GLS_prv_wkn_R with (s:=((Or (list_disj (map Neg (restr_list_prop p (fst (nodupseq s))))) (Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s)))))
+        (Diam (list_conj (map (N p (nodupseq s)) (Canopy (nodupseq (XBoxed_list (top_boxes (fst (nodupseq s))), []%list)))))))) :: X, Or (list_disj (map Neg (restr_list_prop p (fst s))))
+        (Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s))))) (Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))))) :: Y)) (A:=list_disj (restr_list_prop p (snd s))).
+        2: epose (wkn_RI (list_disj (restr_list_prop p (snd s))) _ [] _) ; simpl in w ; apply w.
+        epose (OrR (_,_)). simpl in g. apply g ; clear g.
+        epose (OrL (_,_)). simpl in g. apply g ; clear g.
+        epose (list_disj_L _ (_,_)). apply g ; clear g. simpl ; intros.
+        apply InT_map_iff in H2. destruct H2. destruct p0 ; subst.
+        epose (restr_list_prop_nodup (fst s) x p). apply p0 in i.
+        epose (list_disj_wkn_R _ (_,_) _). simpl in g. apply g ; clear g. apply InT_map_iff. exists x ; split ; auto.
+        epose (Id_all_form _ [] _ []). simpl in d ; apply d.
+        eapply GLS_prv_wkn_R with (s:=((Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s))))) (Diam (list_conj (map (N p (nodupseq s)) (Canopy (nodupseq (XBoxed_list (top_boxes (fst (nodupseq s))), []%list))))))) :: X,
+        (Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s)))))
+        (Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))))) :: Y)) (A:=list_disj (map Neg (restr_list_prop p (fst s)))).
+        2: epose (wkn_RI (list_disj (map Neg (restr_list_prop p (fst s)))) _ [] _) ; simpl in w ; apply w.
+        epose (OrR (_,_)). simpl in g. apply g ; clear g.
+        epose (OrL (_,_)). simpl in g. apply g ; clear g.
+        epose (list_disj_L _ (_,_)). apply g ; clear g. simpl ; intros. apply InT_map_iff in H2.
+        destruct H2. destruct p0 ; subst. apply InT_map_iff in i. destruct i. destruct p0 ; subst.
+        epose (list_disj_wkn_R _ (_,_) (Box (UI p x0))). simpl in g. apply g ; clear g.
+        apply InT_map_iff. exists (UI p x0). split ; auto. apply InT_map_iff. exists x0 ; split ; auto.
+        epose (Id_all_form _ [] _ []). simpl in d ; apply d.
+        eapply GLS_prv_wkn_R with (s:=((Diam (list_conj (map (N p (nodupseq s)) (Canopy (nodupseq (XBoxed_list (top_boxes (fst (nodupseq s))), []%list)))))) :: X,
+        Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) :: Y)) (A:=list_disj (map Box (map (UI p) (GLR_prems (nodupseq s))))).
+        2: epose (wkn_RI (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s))))) _ [] _) ; simpl in w ; apply w.
+        remember (list_conj (map (N p (nodupseq s)) (Canopy (nodupseq (XBoxed_list (top_boxes (fst (nodupseq s))), []%list))))) as conjL.
+        remember (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) as conjR.
+        apply derI with (ps:=[(Box (Neg conjR) :: Diam conjL :: X, Bot :: Y)]). apply ImpR. epose (ImpRRule_I _ _ [] _ [] _). simpl in i ; apply i.
+        apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[(Box (Neg conjR) :: X, Box (Neg conjL) :: :: Y);(Box (Neg conjR) :: :: X, :: Y)]).
+        apply ImpL. epose (ImpLRule_I _ _ [_] _ [] _). simpl in i. apply i. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+        2: apply derI with (ps:=[]) ; [ apply BotL ; epose (BotLRule_I [_] _) ; simpl in b ; auto | apply dlNil].
+        apply derI with (ps:=[(Neg conjR :: Box (Neg conjR) :: XBoxed_list (top_boxes X) ++ [Box (Neg conjL)], [Neg conjL])]). apply GLR.
+        epose (@GLRRule_I _ (Box (Neg conjR) :: (top_boxes X)) _ [] _). simpl in g ; apply g ; clear g ; auto. intros A HA. inversion HA ; subst.
+        eexists ; auto. apply in_top_boxes in H2. destruct H2. destruct s0. destruct s0. destruct p0 ; subst. eexists ; auto.
+        apply univ_gen_ext_cons. apply nobox_top_boxes. apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[(conjL :: Neg conjR :: Box (Neg conjR) :: XBoxed_list (top_boxes X) ++ [Box (Neg conjL)], [Bot])]). apply ImpR. epose (ImpRRule_I _ _ [] _ [] []). simpl in i ; apply i.
+        apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[(conjL :: Box (Neg conjR) :: XBoxed_list (top_boxes X) ++ [Box (Neg conjL)], [conjR;]);(conjL :: Bot :: Box (Neg conjR) :: XBoxed_list (top_boxes X) ++ [Box (Neg conjL)], [])]).
+        apply ImpL. epose (ImpLRule_I _ _ [_] _ [] [_]). simpl in i. apply i. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+        2: apply derI with (ps:=[]) ; [ apply BotL ; epose (BotLRule_I [_] _) ; simpl in b ; auto | apply dlNil].
+        remember (Box (Neg conjR) :: XBoxed_list (top_boxes X) ++ [Box (Neg conjL)]) as LHS0. rewrite HeqconjL. rewrite HeqconjR.
+        epose (list_conj_R _ (_,_)). apply g ; clear g. simpl ; intros. apply InT_map_iff in H2.
+        destruct H2. destruct p0 ; subst.
+        assert (J70: (nodupseq (XBoxed_list (top_boxes (nodup eq_dec_form (fst s))), []%list)) = (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))).
+        unfold nodupseq ; simpl. rewrite <- nodup_top_boxes. rewrite nodup_XBoxed_list ; auto. rewrite J70.
+        epose (list_conj_wkn_L _ (_,_) (N p (nodupseq s) x)). simpl in g. apply g ; clear g.
+        apply InT_map_iff. exists x ; split ; auto.
+ +
+        assert (J100: GLS_prv ([N p (nodupseq s) x], [N p s x])).
+        { (* Massage the Ns. *)
+          assert ((forall (x : Seq) (l m : MPropF), (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x l -> (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x m -> l = m)).
+          intros. subst. auto.
+          destruct (dec_init_rules x).
+          (* The sequent x is initial. *)
+           assert (is_init x) ; auto.
+           pose (N_spec p s x).
+           pose (GN_inv_init _ g). rewrite <- e ; auto.
+           epose (TopR _ [] []). simpl in g0 ; apply g0.
+          (* The sequent x is not initial. *)
+           assert (is_init x -> False) ; auto.
+           assert (J300: GUI p x (UI p x)). apply UI_GUI ; auto.
+           pose (Canopy_critical _ _ i).
+           pose (ub_nodupseq s).
+           destruct (Compare_dec.lt_dec (length (usable_boxes x)) (length (usable_boxes s))).
+           (* The sequent x0 has less usable boxes than s. *)
+           pose (N_spec p s x).
+           epose (@GN_inv_noinit_lessub _ _ _ _ _ g H3 l J300). rewrite <- e0 ; auto.
+           assert (J500: length (usable_boxes x) < length (usable_boxes (nodupseq s))). lia.
+           pose (N_spec p (nodupseq s) x).
+           epose (@GN_inv_noinit_lessub _ _ _ _ _ g0 H3 J500 J300). rewrite <- e1 ; auto.
+           epose (Id_all_form _ [] _ []). simpl in d ; apply d.
+           (* The sequent x does not have less usable boxes than s. *)
+           pose (N_spec p s x).
+           assert (J410: Gimap (GUI p) (GLR_prems (nodupseq x)) (map (UI p) (GLR_prems (nodupseq x)))).
+           apply Gimap_map ; auto. intros ; apply UI_GUI ; auto.
+           epose (@GN_inv_noinit_nolessub _ _ _ _ _ g H3 n J410). rewrite <- e0 ; auto.
+           assert (J42: (length (usable_boxes x) < length (usable_boxes (nodupseq s))) -> False). lia.
+           pose (N_spec p (nodupseq s) x).
+           assert (J43: Gimap (GUI p) (GLR_prems (nodupseq x)) (map (UI p) (GLR_prems (nodupseq x)))).
+           apply Gimap_map ; auto. intros ; apply UI_GUI ; auto.
+           epose (@GN_inv_noinit_nolessub _ _ _ _ _ g0 H3 J42 J43). rewrite <- e1 ; auto.
+           epose (Id_all_form _ [] _ []). simpl in d ; apply d. }
+
+        epose (@GLS_prv_list_wkn_R _ _ _). rewrite app_nil_r in g ; simpl in g. pose (g J100 [Bot]). simpl in g0.
+        epose (@GLS_prv_list_wkn_L [_] _ _). rewrite app_nil_r in g1 ; simpl in g1. epose (g1 g0 _).
+        simpl in g2 ; rewrite app_nil_r in g2. apply g2.
+  (* Sequents are not critical. *)
+  - assert (J0: GUI p s (UI p s)). apply UI_GUI ; auto. assert (J00: GUI p (nodupseq s) (UI p (nodupseq s))). apply UI_GUI ; auto.
+    assert (J1: Gimap (GUI p) (Canopy (nodupseq s)) (map (UI p) (Canopy (nodupseq s)))). apply Gimap_map. intros.
+    apply UI_GUI ; auto.
+    assert (J10: Gimap (GUI p) (Canopy (nodupseq (nodupseq s))) (map (UI p) (Canopy (nodupseq (nodupseq s))))). apply Gimap_map. intros.
+    apply UI_GUI ; auto.
+    pose (@GUI_inv_not_critic p s _ _ J0 f J1). rewrite <- e ; clear e.
+    assert (critical_Seq (nodupseq s) -> False). intro. apply f. apply critical_nodupseq ; auto.
+    pose (@GUI_inv_not_critic p (nodupseq s) _ _ J00 H J10). rewrite <- e ; clear e.
+    rewrite <- fixpoint_nodupseq.
+    epose (Id_all_form _ [] _ []). simpl in d ; apply d. }
+Qed.
+ +
+  Lemma UI_nodupseq_converse : forall s p X Y, GLS_prv (UI p s :: X, UI p (nodupseq s) :: Y).
+  Proof.
+  pose (d:=LexSeq_ind (fun (s:Seq) => forall p X Y, GLS_prv (UI p s :: X, UI p (nodupseq s) :: Y))).
+  apply d. clear d. intros s IH p X Y.
+  destruct (empty_seq_dec s) as [EE | DE].
+  { subst. unfold nodupseq. simpl. assert (J0: GUI p ([],[]) Bot). apply GUI_empty_seq ; auto. apply UI_GUI in J0.
+     rewrite J0 in *. apply derI with []. apply BotL ; apply (BotLRule_I []). apply dlNil. }
+  { destruct (critical_Seq_dec s).
+  (* Sequents are critical. *)
+  - assert (critical_Seq (nodupseq s)). apply (critical_nodupseq s) ; auto.
+    destruct (dec_init_rules s).
+    (* Sequents are initial. *)
+    * assert (is_init s) ; auto. assert (is_init (nodupseq s)). apply (is_init_nodupseq s) ; auto.
+      assert (J0: GUI p (nodupseq s) (UI p (nodupseq s))). apply UI_GUI ; auto.
+      pose (@GUI_inv_critic_init p (nodupseq s) _ J0 H X1). rewrite <- e. epose (TopR _ [] _). simpl in g ; apply g.
+    (* Sequents are not initial. *)
+    * assert ((is_init s) -> False) ; auto. assert ((is_init (nodupseq s)) -> False). intro. apply H0.
+      apply (is_init_nodupseq s) ; auto.
+      assert (J0: GUI p s (UI p s)). apply UI_GUI ; auto.
+      assert (J00: GUI p (nodupseq s) (UI p (nodupseq s))). apply UI_GUI ; auto.
+      assert (J1: Gimap (GUI p) (GLR_prems (nodupseq s)) (map (UI p) (GLR_prems (nodupseq s)))). apply Gimap_map. intros.
+      apply UI_GUI ; auto.
+      assert (J10: Gimap (GUI p) (GLR_prems (nodupseq (nodupseq s))) (map (UI p) (GLR_prems (nodupseq (nodupseq s))))). apply Gimap_map. intros.
+      apply UI_GUI ; auto.
+      assert (J2: (Gimap (GN p (GUI p) s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), [])))
+      (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), [])))))). apply Gimap_map. intros.
+      apply (N_spec p s x).
+      assert (J20: (Gimap (GN p (GUI p) (nodupseq s)) (Canopy (nodupseq (XBoxed_list (top_boxes (fst (nodupseq s))), [])))
+      (map (N p (nodupseq s)) (Canopy (nodupseq (XBoxed_list (top_boxes (fst (nodupseq s))), [])))))). apply Gimap_map. intros.
+      apply (N_spec p (nodupseq s) x).
+      assert (J41: (nodupseq s) <> ([],[])). intro. apply DE. destruct s. simpl in *. unfold nodupseq in *. simpl in H2. inversion H2 ; subst.
+      apply nodup_nil in H4 ; rewrite H4 in H5 ; apply nodup_nil in H5 ; subst ; auto.
+       pose (@GUI_inv_critic_not_init p s _ _ _ J0 c DE H0 J1 J2). rewrite <- e ; clear e.
+       pose (@GUI_inv_critic_not_init p (nodupseq s) _ _ _ J00 H J41 H1 J10 J20). rewrite <- e ; clear e.
+       repeat rewrite <- fixpoint_nodupseq.
+        epose (OrR (_,_)). simpl in g. apply g ; clear g.
+        epose (OrL (_,_)). simpl in g. apply g ; clear g.
+        epose (list_disj_L _ (_,_)). apply g ; clear g. simpl ; intros.
+        epose (restr_list_prop_nodup (snd s) A p). apply p0 in H2.
+        epose (list_disj_wkn_R _ (_,_) _ H2). simpl in g. apply g ; clear g.
+        epose (Id_all_form _ [] _ []). simpl in d ; apply d.
+        eapply GLS_prv_wkn_R with (s:=((Or (list_disj (map Neg (restr_list_prop p (fst s)))) (Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s)))))
+        (Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))))) :: X, Or (list_disj (map Neg (restr_list_prop p (fst (nodupseq s)))))
+        (Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s))))) (Diam (list_conj (map (N p (nodupseq s)) (Canopy (nodupseq (XBoxed_list (top_boxes (fst (nodupseq s))), []%list))))))) :: Y)) (A:=list_disj (restr_list_prop p (snd (nodupseq s)))).
+        2: epose (wkn_RI (list_disj (restr_list_prop p (snd (nodupseq s)))) _ [] _) ; simpl in w ; apply w.
+        epose (OrR (_,_)). simpl in g. apply g ; clear g.
+        epose (OrL (_,_)). simpl in g. apply g ; clear g.
+        epose (list_disj_L _ (_,_)). apply g ; clear g. simpl ; intros.
+        apply InT_map_iff in H2. destruct H2. destruct p0 ; subst.
+        epose (restr_list_prop_nodup (fst s) x p). apply p0 in i.
+        epose (list_disj_wkn_R _ (_,_) _). simpl in g. apply g ; clear g. apply InT_map_iff. exists x ; split ; auto.
+        epose (Id_all_form _ [] _ []). simpl in d ; apply d.
+        eapply GLS_prv_wkn_R with (s:=((Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s))))) (Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))))) :: X,
+        (Or (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s)))))
+        (Diam (list_conj (map (N p (nodupseq s)) (Canopy (nodupseq (XBoxed_list (top_boxes (fst (nodupseq s))), []%list))))))) :: Y)) (A:=list_disj (map Neg (restr_list_prop p (fst (nodupseq s))))).
+        2: epose (wkn_RI (list_disj (map Neg (restr_list_prop p (fst (nodupseq s))))) _ [] _) ; simpl in w ; apply w.
+        epose (OrR (_,_)). simpl in g. apply g ; clear g.
+        epose (OrL (_,_)). simpl in g. apply g ; clear g.
+        epose (list_disj_L _ (_,_)). apply g ; clear g. simpl ; intros. apply InT_map_iff in H2.
+        destruct H2. destruct p0 ; subst. apply InT_map_iff in i. destruct i. destruct p0 ; subst.
+        epose (list_disj_wkn_R _ (_,_) (Box (UI p x0))). simpl in g. apply g ; clear g.
+        apply InT_map_iff. exists (UI p x0). split ; auto. apply InT_map_iff. exists x0 ; split ; auto.
+        epose (Id_all_form _ [] _ []). simpl in d ; apply d.
+        eapply GLS_prv_wkn_R with (s:=((Diam (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))))) :: X,
+        Diam (list_conj (map (N p (nodupseq s)) (Canopy (nodupseq (XBoxed_list (top_boxes (fst (nodupseq s))), []%list))))) :: Y)) (A:=list_disj (map Box (map (UI p) (GLR_prems (nodupseq s))))).
+        2: epose (wkn_RI (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s))))) _ [] _) ; simpl in w ; apply w.
+        remember (list_conj (map (N p (nodupseq s)) (Canopy (nodupseq (XBoxed_list (top_boxes (fst (nodupseq s))), []%list))))) as conjR.
+        remember (list_conj (map (N p s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))))) as conjL.
+        apply derI with (ps:=[(Box (Neg conjR) :: Diam conjL :: X, Bot :: Y)]). apply ImpR. epose (ImpRRule_I _ _ [] _ [] _). simpl in i ; apply i.
+        apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[(Box (Neg conjR) :: X, Box (Neg conjL) :: :: Y);(Box (Neg conjR) :: :: X, :: Y)]).
+        apply ImpL. epose (ImpLRule_I _ _ [_] _ [] _). simpl in i. apply i. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+        2: apply derI with (ps:=[]) ; [ apply BotL ; epose (BotLRule_I [_] _) ; simpl in b ; auto | apply dlNil].
+        apply derI with (ps:=[(Neg conjR :: Box (Neg conjR) :: XBoxed_list (top_boxes X) ++ [Box (Neg conjL)], [Neg conjL])]). apply GLR.
+        epose (@GLRRule_I _ (Box (Neg conjR) :: (top_boxes X)) _ [] _). simpl in g ; apply g ; clear g ; auto. intros A HA. inversion HA ; subst.
+        eexists ; auto. apply in_top_boxes in H2. destruct H2. destruct s0. destruct s0. destruct p0 ; subst. eexists ; auto.
+        apply univ_gen_ext_cons. apply nobox_top_boxes. apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[(conjL :: Neg conjR :: Box (Neg conjR) :: XBoxed_list (top_boxes X) ++ [Box (Neg conjL)], [Bot])]). apply ImpR. epose (ImpRRule_I _ _ [] _ [] []). simpl in i ; apply i.
+        apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[(conjL :: Box (Neg conjR) :: XBoxed_list (top_boxes X) ++ [Box (Neg conjL)], [conjR;]);(conjL :: Bot :: Box (Neg conjR) :: XBoxed_list (top_boxes X) ++ [Box (Neg conjL)], [])]).
+        apply ImpL. epose (ImpLRule_I _ _ [_] _ [] [_]). simpl in i. apply i. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+        2: apply derI with (ps:=[]) ; [ apply BotL ; epose (BotLRule_I [_] _) ; simpl in b ; auto | apply dlNil].
+        remember (Box (Neg conjR) :: XBoxed_list (top_boxes X) ++ [Box (Neg conjL)]) as LHS0. rewrite HeqconjL. rewrite HeqconjR.
+        epose (list_conj_R _ (_,_)). apply g ; clear g. simpl ; intros. apply InT_map_iff in H2.
+        destruct H2. destruct p0 ; subst.
+        assert (J70: (nodupseq (XBoxed_list (top_boxes (nodup eq_dec_form (fst s))), []%list)) = (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))).
+        unfold nodupseq ; simpl. rewrite <- nodup_top_boxes. rewrite nodup_XBoxed_list ; auto. rewrite <- J70.
+        epose (list_conj_wkn_L _ (_,_) (N p s x)). simpl in g. apply g ; clear g.
+        apply InT_map_iff. exists x ; split ; auto.
+ +
+        assert (J100: GLS_prv ([N p s x], [N p (nodupseq s) x])).
+        { (* Massage the Ns. *)
+          assert ((forall (x : Seq) (l m : MPropF), (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x l -> (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x m -> l = m)).
+          intros. subst. auto.
+          destruct (dec_init_rules x).
+          (* The sequent x is initial. *)
+           assert (is_init x) ; auto.
+           pose (N_spec p (nodupseq s) x).
+           pose (GN_inv_init _ g). rewrite <- e ; auto.
+           epose (TopR _ [] []). simpl in g0 ; apply g0.
+          (* The sequent x is not initial. *)
+           assert (is_init x -> False) ; auto.
+           assert (J300: GUI p x (UI p x)). apply UI_GUI ; auto.
+           pose (Canopy_critical _ _ i).
+           pose (ub_nodupseq s).
+           destruct (Compare_dec.lt_dec (length (usable_boxes x)) (length (usable_boxes s))).
+           (* The sequent x0 has less usable boxes than s. *)
+           pose (N_spec p s x).
+           epose (@GN_inv_noinit_lessub _ _ _ _ _ g H3 l J300). rewrite <- e0 ; auto.
+           assert (J500: length (usable_boxes x) < length (usable_boxes (nodupseq s))). lia.
+           pose (N_spec p (nodupseq s) x).
+           epose (@GN_inv_noinit_lessub _ _ _ _ _ g0 H3 J500 J300). rewrite <- e1 ; auto.
+           epose (Id_all_form _ [] _ []). simpl in d ; apply d.
+           (* The sequent x does not have less usable boxes than s. *)
+           pose (N_spec p s x).
+           assert (J410: Gimap (GUI p) (GLR_prems (nodupseq x)) (map (UI p) (GLR_prems (nodupseq x)))).
+           apply Gimap_map ; auto. intros ; apply UI_GUI ; auto.
+           epose (@GN_inv_noinit_nolessub _ _ _ _ _ g H3 n J410). rewrite <- e0 ; auto.
+           assert (J42: (length (usable_boxes x) < length (usable_boxes (nodupseq s))) -> False). lia.
+           pose (N_spec p (nodupseq s) x).
+           assert (J43: Gimap (GUI p) (GLR_prems (nodupseq x)) (map (UI p) (GLR_prems (nodupseq x)))).
+           apply Gimap_map ; auto. intros ; apply UI_GUI ; auto.
+           epose (@GN_inv_noinit_nolessub _ _ _ _ _ g0 H3 J42 J43). rewrite <- e1 ; auto.
+           epose (Id_all_form _ [] _ []). simpl in d ; apply d. }
+
+        epose (@GLS_prv_list_wkn_R _ _ _). rewrite app_nil_r in g ; simpl in g. pose (g J100 [Bot]). simpl in g0.
+        epose (@GLS_prv_list_wkn_L [_] _ _). rewrite app_nil_r in g1 ; simpl in g1. epose (g1 g0 _).
+        simpl in g2 ; rewrite app_nil_r in g2. apply g2.
+  (* Sequents are not critical. *)
+  - assert (J0: GUI p s (UI p s)). apply UI_GUI ; auto. assert (J00: GUI p (nodupseq s) (UI p (nodupseq s))). apply UI_GUI ; auto.
+    assert (J1: Gimap (GUI p) (Canopy (nodupseq s)) (map (UI p) (Canopy (nodupseq s)))). apply Gimap_map. intros.
+    apply UI_GUI ; auto.
+    assert (J10: Gimap (GUI p) (Canopy (nodupseq (nodupseq s))) (map (UI p) (Canopy (nodupseq (nodupseq s))))). apply Gimap_map. intros.
+    apply UI_GUI ; auto.
+    pose (@GUI_inv_not_critic p s _ _ J0 f J1). rewrite <- e ; clear e.
+    assert (critical_Seq (nodupseq s) -> False). intro. apply f. apply critical_nodupseq ; auto.
+    pose (@GUI_inv_not_critic p (nodupseq s) _ _ J00 H J10). rewrite <- e ; clear e.
+    rewrite <- fixpoint_nodupseq.
+    epose (Id_all_form _ [] _ []). simpl in d ; apply d. }
+  Qed.
+ +
+  Lemma UI_nodupseq_gen : forall s0 s1 p X Y, (nodupseq s0 = nodupseq s1) -> GLS_prv (UI p s0 :: X, UI p s1 :: Y).
+  Proof.
+  intros.
+  pose (UI_nodupseq s1 p X Y).
+  pose (UI_nodupseq_converse s0 p X Y). rewrite H in *.
+  pose (GLS_cut_adm (UI p (nodupseq s1)) [] (UI p s0 :: X) [] (UI p s1 :: Y)). simpl in g1. apply g1 ; auto.
+  eapply GLS_prv_wkn_R with (s:=(UI p s0 :: X, UI p (nodupseq s1) :: Y)) (A:=UI p s1) ; auto.
+  epose (wkn_RI (UI p s1) _ [_] _) ; simpl in w ; apply w.
+  eapply GLS_prv_wkn_L with (s:=(UI p (nodupseq s1) :: X, UI p s1 :: Y)) (A:=UI p s0) ; auto.
+  epose (wkn_LI (UI p s0) [_] _ _) ; simpl in w ; apply w.
+  Qed.
+ +
+  Lemma N_nodupseq : forall s0 s1 p X Y, critical_Seq s1 -> GLS_prv (N p s0 s1 :: X, N p s0 (nodupseq s1) :: Y).
+  Proof.
+  intros s0 s1. revert s0. revert s1.
+  pose (d:=LexSeq_ind (fun (s:Seq) => forall s0 p X Y, critical_Seq s -> GLS_prv (N p s0 s :: X, N p s0 (nodupseq s) :: Y))).
+  apply d. clear d. intros s1 IH s0 p X Y crit.
+  assert ((forall (x : Seq) (l m : MPropF), (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x l -> (fun (s1 : Seq) (A : MPropF) => UI p s1 = A) x m -> l = m)).
+  intros. subst. auto.
+  destruct (dec_init_rules s1).
+  (* The sequent s1 is initial. *)
+   - assert (is_init s1) ; auto. assert (is_init (nodupseq s1)). apply is_init_nodupseq in X0; auto.
+     pose (N_spec p s0 (nodupseq s1)).
+     pose (GN_inv_init _ g). rewrite <- e ; auto.
+     epose (TopR _ [] _). simpl in g0 ; apply g0.
+  (* The sequent s1 is not initial. *)
+   - assert (is_init s1 -> False) ; auto. assert (is_init (nodupseq s1) -> False). intro ; apply H0 ; apply is_init_nodupseq ; auto.
+     assert (J300: GUI p s1 (UI p s1)). apply UI_GUI ; auto.
+     assert (J400: GUI p (nodupseq s1) (UI p (nodupseq s1))). apply UI_GUI ; auto.
+     assert (critical_Seq (nodupseq s1)). apply (critical_nodupseq s1) ; auto.
+     pose (ub_nodupseq s1).
+     destruct (Compare_dec.lt_dec (length (usable_boxes s1)) (length (usable_boxes s0))).
+     (* The sequent x0 has less usable boxes than s. *)
+     * pose (N_spec p s0 s1).
+       epose (@GN_inv_noinit_lessub _ _ _ _ _ g H0 l J300). rewrite <- e0 ; auto.
+       assert (J500: length (usable_boxes (nodupseq s1)) < length (usable_boxes s0)). rewrite <- ub_nodupseq ; auto.
+       pose (N_spec p s0 (nodupseq s1)).
+       epose (@GN_inv_noinit_lessub _ _ _ _ _ g0 H1 J500 J400). rewrite <- e1 ; auto.
+       apply UI_nodupseq_converse.
+     (* The sequent x does not have less usable boxes than s. *)
+     * pose (N_spec p s0 s1).
+       assert (J410: Gimap (GUI p) (GLR_prems (nodupseq s1)) (map (UI p) (GLR_prems (nodupseq s1)))).
+       apply Gimap_map ; auto. intros ; apply UI_GUI ; auto.
+       epose (@GN_inv_noinit_nolessub _ _ _ _ _ g H0 n J410). rewrite <- e0 ; auto.
+       assert (J42: (length (usable_boxes (nodupseq s1)) < length (usable_boxes s0)) -> False). rewrite <- ub_nodupseq ; auto.
+       pose (N_spec p s0 (nodupseq s1)).
+       assert (J43: Gimap (GUI p) (GLR_prems (nodupseq (nodupseq s1))) (map (UI p) (GLR_prems (nodupseq (nodupseq s1))))).
+       apply Gimap_map ; auto. intros ; apply UI_GUI ; auto.
+       epose (@GN_inv_noinit_nolessub _ _ _ _ _ g0 H1 J42 J43). rewrite <- e1 ; auto.
+       repeat rewrite <- fixpoint_nodupseq.
+       epose (OrR (_,_)). simpl in g1. apply g1 ; clear g1.
+       epose (OrL (_,_)). simpl in g1. apply g1 ; clear g1.
+       epose (list_disj_L _ (_,_)). apply g1 ; clear g1. simpl ; intros.
+       epose (restr_list_prop_nodup (snd s1) A p). apply p0 in H3 ; clear p0.
+       epose (list_disj_wkn_R _ (_,_) _ H3). simpl in g1. apply g1 ; clear g1.
+       epose (Id_all_form _ [] _ []). simpl in d ; apply d.
+       eapply GLS_prv_wkn_R with (s:=(Or (list_disj (map Neg (restr_list_prop p (fst s1)))) (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s1))))) :: X,
+       Or (list_disj (map Neg (restr_list_prop p (fst (nodupseq s1))))) (list_disj (map Box (map (UI p) (GLR_prems (nodupseq s1))))) :: Y)) (A:=list_disj (restr_list_prop p (snd (nodupseq s1)))).
+       2: epose (wkn_RI (list_disj (restr_list_prop p (snd (nodupseq s1)))) _ [] _) ; simpl in w ; apply w.
+       epose (OrR (_,_)). simpl in g1. apply g1 ; clear g1.
+       epose (OrL (_,_)). simpl in g1. apply g1 ; clear g1.
+       epose (list_disj_L _ (_,_)). apply g1 ; clear g1. simpl ; intros.
+       apply InT_map_iff in H3. destruct H3. destruct p0 ; subst.
+       epose (restr_list_prop_nodup (fst s1) x p). apply p0 in i ; clear p0.
+       epose (list_disj_wkn_R _ (_,_) _). simpl in g1. apply g1 ; clear g1. apply InT_map_iff. exists x ; split ; auto.
+       epose (Id_all_form _ [] _ []). simpl in d ; apply d.
+       eapply GLS_prv_wkn_R with (s:=(list_disj (map Box (map (UI p) (GLR_prems (nodupseq s1)))) :: X,
+       list_disj (map Box (map (UI p) (GLR_prems (nodupseq s1)))) :: Y)) (A:=list_disj (map Neg (restr_list_prop p (fst (nodupseq s1))))).
+       2: epose (wkn_RI (list_disj (map Neg (restr_list_prop p (fst (nodupseq s1))))) _ [] _) ; simpl in w ; apply w.
+       epose (Id_all_form _ [] _ []). simpl in d ; apply d.
+  Qed.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_UI_prelims.html b/GL.Interpolation.UIGL_UI_prelims.html new file mode 100644 index 0000000..53d94fe --- /dev/null +++ b/GL.Interpolation.UIGL_UI_prelims.html @@ -0,0 +1,767 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_UI_prelims

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+Require Import String.
+ +
+Require Import general_export.
+ +
+Require Import GLS_export.
+ +
+Require Import UIGL_Def_measure.
+Require Import UIGL_Canopy.
+Require Import UIGL_irred_short.
+Require Import UIGL_braga.
+Require Import UIGL_LexSeq.
+Require Import UIGL_nodupseq.
+Require Import UIGL_PermutationT.
+Require Import UIGL_PermutationTS.
+Require Import UIGL_And_Or_rules.
+Require Import UIGL_Canopy_nodupseq_perm.
+ +
+  Section Prop_Subform.
+ +
+  (* This is copied from the Craig interpolation file. Make a syntax file for interpolations. *)
+ +
+  Fixpoint propvar_subform (A : MPropF) : list MPropF :=
+  match A with
+    | Var p => (Var p) :: nil
+    | Bot => nil
+    | Imp B C => (propvar_subform B) ++ ( propvar_subform C)
+    | Box B => ( propvar_subform B)
+  end.
+ +
+  Fixpoint propvar_subform_list (l : list MPropF) : list MPropF :=
+  match l with
+    | nil => nil
+    | A :: t => (propvar_subform A) ++ (propvar_subform_list t)
+  end.
+ +
+  (* Lemmas about propvar_subform_list. *)
+ +
+  Lemma propvar_subform_list_app: forall l0 l1,
+        propvar_subform_list (l0 ++ l1) = (propvar_subform_list l0) ++ (propvar_subform_list l1).
+  Proof.
+  induction l0.
+  - simpl. auto.
+  - intros. simpl. rewrite (IHl0). rewrite <- app_assoc ; auto.
+  Qed.
+ +
+  Lemma propvar_subform_list_XBoxed_list : forall l A, In A (propvar_subform_list (XBoxed_list l)) -> In A (propvar_subform_list l).
+  Proof.
+  induction l.
+  - auto.
+  - simpl. intros. apply in_app_or in H. destruct H. apply in_or_app ; left. destruct a ; auto.
+    apply in_app_or in H. destruct H. apply in_or_app ; auto. apply in_or_app ; right ; auto.
+  Qed.
+ +
+  Lemma propvar_subform_list_nobox_gen_ext : forall l0 l1, nobox_gen_ext l0 l1 ->
+            (forall A, In A (propvar_subform_list l0) -> In A (propvar_subform_list l1)).
+  Proof.
+  intros l0 l1 H. induction H ; auto.
+  - simpl ; intros. apply in_or_app. apply in_app_or in H0 ; destruct H0 ; auto.
+  - simpl ; intros. apply in_or_app ; auto.
+  Qed.
+ +
+  Lemma propvar_subform_list_top_boxes : forall l A, In A (propvar_subform_list (top_boxes l)) -> In A (propvar_subform_list l).
+  Proof.
+  induction l ; simpl ; intros ; auto. destruct a ; simpl in H ; auto. 1-2: apply in_or_app ; apply IHl in H ; auto.
+  apply in_or_app ; apply in_app_or in H ; destruct H ; simpl ; auto.
+  Qed.
+ +
+  Lemma propvar_subform_list_conj : forall l A,
+            In A (propvar_subform (list_conj l)) -> In A (propvar_subform_list l).
+  Proof.
+  induction l ; simpl ; intros ; auto. repeat rewrite app_nil_r in H.
+  apply in_app_or in H. apply in_or_app. destruct H ; auto.
+  Qed.
+ +
+  Lemma propvar_subform_list_disj : forall l A,
+            In A (propvar_subform (list_disj l)) -> In A (propvar_subform_list l).
+  Proof.
+  induction l ; simpl ; intros ; auto. repeat rewrite app_nil_r in H.
+  apply in_app_or in H. apply in_or_app. destruct H ; auto.
+  Qed.
+ +
+  Lemma propvar_subform_list_witness : forall l A,
+            In A (propvar_subform_list l) -> (exists B, In B l /\ In A (propvar_subform B)).
+  Proof.
+  induction l ; simpl ; intros ; auto. inversion H. apply in_app_or in H. destruct H.
+  exists a ; auto. apply IHl in H. destruct H. exists x ; firstorder.
+  Qed.
+ +
+  Lemma propvar_subform_list_witnessT : forall l A,
+            InT A (propvar_subform_list l) -> (existsT2 B, (InT B l) * (InT A (propvar_subform B))).
+  Proof.
+  induction l ; simpl ; intros ; auto. inversion H. apply InT_app_or in H. destruct H.
+  exists a ; auto. split ; auto. apply InT_eq. apply IHl in i. destruct i. exists x ; firstorder. apply InT_cons ; auto.
+  Qed.
+ +
+  Lemma propvar_subform_list_Canopy : forall s ir A,
+            In ir (Canopy s) ->
+            In A (propvar_subform_list (fst ir ++ snd ir)) ->
+            In A (propvar_subform_list (fst s ++ snd s)).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros. remember (finite_ImpRules_premises_of_S s) as H1.
+  destruct H1. destruct x.
+  - assert (Canopy s = [s]). apply irred_nil. unfold inv_prems. rewrite <- HeqH1.
+    simpl. auto. rewrite H1 in H. inversion H. subst. auto. inversion H2.
+  - apply In_InT_seqs in H. apply fold_Canopy in H. destruct H ; subst ; auto.
+    destruct s0. destruct p0. unfold inv_prems in i. destruct (finite_ImpRules_premises_of_S s).
+    simpl in i. apply InT_flatten_list_InT_elem in i. destruct i. destruct p1. apply p0 in i1.
+    apply IHs with (y:=x0) in H0. 3: apply InT_In ; auto.
+    destruct i1. inversion i1 ; subst. simpl. inversion i ; subst. 2: inversion H1. simpl in H0.
+    repeat rewrite <- app_assoc in H0. repeat rewrite <- app_assoc.
+    repeat rewrite propvar_subform_list_app in H0. repeat rewrite propvar_subform_list_app.
+    simpl in H0. simpl. repeat rewrite <- app_assoc in H0. repeat rewrite <- app_assoc.
+    apply in_or_app. apply in_app_or in H0 ; destruct H0 ; auto. right. apply in_or_app.
+    apply in_app_or in H ; destruct H ; auto. right ; apply in_or_app ; right ; apply in_or_app ; auto.
+    apply in_app_or in H ; destruct H ; auto. right. apply in_or_app ; apply in_app_or in H ; destruct H ; auto.
+    right ; apply in_or_app ; right ; auto.
+    inversion i1 ; subst. simpl. inversion i ; subst. simpl in H0.
+    repeat rewrite <- app_assoc in H0. repeat rewrite <- app_assoc.
+    repeat rewrite propvar_subform_list_app in H0. repeat rewrite propvar_subform_list_app.
+    simpl in H0. simpl. repeat rewrite <- app_assoc in H0. repeat rewrite <- app_assoc.
+    apply in_or_app. apply in_app_or in H0 ; destruct H0 ; auto. right. apply in_or_app.
+    apply in_app_or in H ; destruct H ; auto. right ; apply in_or_app ; right ; apply in_or_app ; auto.
+    apply in_app_or in H ; destruct H ; auto. right. apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+    apply in_app_or in H ; destruct H ; auto. right ; apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+    inversion H1 ; subst. 2: inversion H2. simpl in H0.
+    repeat rewrite <- app_assoc in H0. repeat rewrite <- app_assoc.
+    repeat rewrite propvar_subform_list_app in H0. repeat rewrite propvar_subform_list_app.
+    simpl in H0. simpl. repeat rewrite <- app_assoc in H0. repeat rewrite <- app_assoc.
+    apply in_or_app. apply in_app_or in H0 ; destruct H0 ; auto. right. apply in_or_app.
+    apply in_app_or in H ; destruct H ; auto. right ; apply in_or_app ; auto.
+    apply in_app_or in H ; destruct H ; auto. right. apply in_or_app ; right ; apply in_or_app ; auto.
+    right ; apply in_or_app ; right ; apply in_or_app ; right ; auto.
+    destruct i1. inversion i1 ; subst. simpl. inversion i ; subst. 2: inversion H1. unfold n_imp_subformS ; simpl.
+    repeat rewrite n_imp_subformLF_dist_app ; simpl ; repeat rewrite n_imp_subformLF_dist_app. lia.
+    inversion i1. subst. inversion i ; subst. unfold n_imp_subformS ; simpl.
+    repeat rewrite n_imp_subformLF_dist_app ; simpl ; repeat rewrite n_imp_subformLF_dist_app. lia.
+    inversion H1. subst. 2: inversion H2. unfold n_imp_subformS ; simpl.
+    repeat rewrite n_imp_subformLF_dist_app ; simpl ; repeat rewrite n_imp_subformLF_dist_app. lia.
+  Qed.
+ +
+  Lemma propvar_subform_list_restr_list_prop : forall l (p q : string), In # q (propvar_subform_list (restr_list_prop p l)) ->
+                        ((q <> p) * (In # q (propvar_subform_list l))).
+  Proof.
+  induction l ; simpl ; intros ; auto. unfold restr_list_prop in H. destruct a as [n | | |]; simpl ; simpl in H ; auto.
+  destruct (eq_dec_form (# p) (# n)) ; subst. apply IHl in H. destruct H ; auto.
+  simpl in H. destruct H ; subst ; auto. split ; auto. rewrite H in n0. destruct (string_dec p q) ; subst; auto.
+  all: apply IHl in H ; destruct H ; auto.
+  all: split ; auto. all: apply in_or_app ; auto.
Qed.
+ +
+  Lemma In_list_prop_LF: forall l A, In A (list_prop_LF l) -> ((existsT2 q, A = # q) * In A l).
+  Proof.
+  induction l ; simpl ; intros ; auto. inversion H. apply In_InT in H. apply InT_app_or in H.
+  destruct H. destruct a as [n | | |]; simpl in i ; inversion i ; subst ; auto. split ; [exists n ; auto | auto]. inversion H0.
+  apply InT_In in i ; apply IHl in i ; auto. destruct i ; split ; auto.
+  Qed.
+ +
+  Lemma list_prop_LF_propvar_subform_list : forall l q, In # q (list_prop_LF l) -> In # q (propvar_subform_list l).
+  Proof.
+  induction l ; simpl ; intros ; auto. apply in_app_or in H ; destruct H ; auto. apply in_or_app ; left. destruct a ; simpl ; simpl in H ; try firstorder.
+  apply in_or_app ; right ; apply IHl in H ; auto.
+  Qed.
+ +
+  Lemma In_list_In_list_prop_LF : forall l P, In # P l -> In # P (list_prop_LF l).
+  Proof.
+  induction l ; simpl ; subst ; auto. intros. destruct H. subst ; simpl ; auto. apply in_or_app; right ; auto.
+  Qed.
+ +
+  Lemma In_list_In_propvar_subform_list : forall l P, In # P l -> In # P (propvar_subform_list l).
+  Proof.
+  induction l ; simpl ; subst ; auto. intros. destruct H. subst ; simpl ; auto. apply in_or_app; right ; auto.
+  Qed.
+ +
+  End Prop_Subform.
+ +
+  Section Diam_help.
+ +
+  Lemma In_subform_boxes:
+  forall (l : list MPropF) (A : MPropF), In A (subform_boxesLF l) -> exists B : MPropF, In A (subform_boxesF B) /\ In B l.
+  Proof.
+  induction l ; simpl ; intros ; auto. inversion H. apply in_app_or in H. destruct H. pose (In_subform_boxesF_box _ _ H).
+  unfold is_boxedT in i. destruct i. subst. exists a ; auto. apply In_remove_list_In_list in H. apply IHl in H. firstorder.
+  Qed.
+ +
+  Lemma nolessub_In : forall s A, (length (usable_boxes (XBoxed_list (top_boxes (fst s)), []%list)) < length (usable_boxes s) -> False) ->
+                                      (In (Box A) (top_boxes (XBoxed_list (top_boxes (fst s))))) -> In (Box A) (top_boxes (fst s)).
+  Proof.
+  intros. apply InT_In. pose (InT_dec (top_boxes (fst s)) (Box A)). destruct s0 ; auto. exfalso. apply H. destruct s.
+  simpl. simpl in f. simpl in H0. simpl in H. unfold usable_boxes. simpl. unfold subform_boxesS. simpl.
+  apply remove_list_incr_decr ; simpl. apply add_remove_list_preserve_NoDup. 2: apply NoDup_nil.
+  apply NoDup_subform_boxesLF. apply add_remove_list_preserve_NoDup. 1-2: apply NoDup_subform_boxesLF.
+  exists (Box A). repeat split ; auto.
+  apply in_or_app ; left. apply XBoxed_list_same_subform_boxes. apply top_boxes_incl_list in H0.
+  apply In_XBoxed_list in H0. destruct H0. apply In_incl_subform_boxes with (A:=Box A) ; auto. exfalso. apply f ; apply In_InT ; auto.
+  simpl ; auto. destruct H0. destruct H0. subst. apply XBoxed_list_same_subform_boxes. apply top_boxes_incl_list in H0.
+  apply In_incl_subform_boxes with (A:=(Box (Box A))) ; simpl ; auto.
+  intro ; apply f ; apply In_InT ; auto. intro. intros. pose (in_top_boxes _ _ H1). destruct s. destruct s.
+  destruct s. destruct p ; subst. rewrite top_boxes_distr_app. simpl. rewrite XBox_app_distrib. simpl.
+  rewrite top_boxes_distr_app. simpl. destruct x ; simpl. 1-3: apply in_or_app ; right ; apply in_eq.
+  apply in_or_app ; right ; apply in_cons ; apply in_eq.
+  intro. intros. apply in_app_or in H1. destruct H1. apply in_or_app. left.
+  pose (XBoxed_list_same_subform_boxes (top_boxes l)). apply a0 in H1. apply In_subform_boxes in H1. destruct H1.
+  destruct H1. apply In_incl_subform_boxes with (A:=x). apply top_boxes_incl_list ; auto. auto.
+  apply remove_list_is_in. rewrite remove_list_of_nil in H1. inversion H1.
Qed.
+ +
+  Lemma remove_list_decr_in: forall [l2 l1 l3 l4: list MPropF], NoDup l4 -> NoDup l3 ->
+    incl l1 l2 -> incl l3 l4 -> length (remove_list l2 l4) < length (remove_list l1 l3) ->
+    (exists A : MPropF, In A l2 /\ (In A l1 -> False)).
+  Proof.
+  induction l2 ; simpl.
+  - intros. destruct l1. simpl. simpl in H3. exfalso. pose (NoDup_incl_length H0 H2). simpl in l. lia.
+    exfalso. pose (H1 m). simpl in i ; apply i ; auto.
+  - intros. destruct (In_dec l2 a).
+    + assert (incl l1 l2). intro. intros. apply H1 in H4. inversion H4 ; subst ; auto.
+       pose (In_remove_list_remove_redund _ l4 _ i). rewrite e in H3.
+       pose (IHl2 _ _ _ H H0 H4 H2 H3). destruct e0. destruct H5. exists x ; split ; auto.
+    + destruct (In_dec l1 a).
+        * destruct (In_dec l4 a).
+          -- destruct (In_dec l3 a).
+            ++ assert (incl (remove eq_dec_form a l1) l2). intro. intros. apply in_remove in H4. destruct H4.
+                 apply H1 in H4. inversion H4 ; subst ; auto. exfalso ; apply H5 ; auto.
+                 assert ((remove_list l1 l3) = (remove_list (remove eq_dec_form a l1) (remove eq_dec_form a l3))).
+                 rewrite <- In_remove_list_remove_redund with (a:=a). rewrite permut_remove_remove_list.
+                 pose (permut_remove_remove_list a (remove eq_dec_form a l1) l3). rewrite <- e.
+                 pose (redund_remove_remove_list a l1 l3). rewrite e0. rewrite permut_remove_remove_list. auto. auto.
+                 assert (J0: NoDup (remove eq_dec_form a l4)). apply remove_preserv_NoDup ; auto.
+                 assert (J1: NoDup (remove eq_dec_form a l3)). apply remove_preserv_NoDup ; auto.
+                 assert (J2: incl (remove eq_dec_form a l3) (remove eq_dec_form a l4)). intro. intros.
+                 apply in_remove in H6. destruct H6. apply in_in_remove ; auto.
+                 rewrite H5 in H3. rewrite permut_remove_remove_list in H3.
+                 pose (IHl2 (remove eq_dec_form a l1) _ _ J0 J1 H4 J2 H3). destruct e. destruct H6.
+                 exists x ; split ; auto. intro. apply H7. apply in_in_remove ; auto. intro ; subst. auto.
+            ++ assert (incl (remove eq_dec_form a l1) l2). intro. intros. apply in_remove in H4. destruct H4.
+                 apply H1 in H4. inversion H4 ; subst ; auto. exfalso ; apply H5 ; auto.
+                 rewrite permut_remove_remove_list in H3.
+                 assert (J0: NoDup (remove eq_dec_form a l4)). apply remove_preserv_NoDup ; auto.
+                 assert (J1: incl l3 (remove eq_dec_form a l4)). intro. intros. apply in_in_remove ; auto.
+                 intro ; subst ; auto.
+                 assert (J:length (remove_list l2 (remove eq_dec_form a l4)) < length (remove_list (remove eq_dec_form a l1) l3)).
+                 assert ((remove_list l1 l3) = (remove_list (remove eq_dec_form a l1) l3)).
+                 pose (redund_remove_remove_list a l1 l3). rewrite notin_remove in e.
+                 symmetry in e. rewrite notin_remove in e. auto.
+                 1-2: intro ; apply In_remove_list_In_list in H5 ; auto. rewrite H5 in H3. auto.
+                 pose (IHl2 (remove eq_dec_form a l1) _ _ J0 H0 H4 J1 J). destruct e. destruct H5.
+                 exists x ; split ; auto. intro. apply H6. apply in_in_remove ; auto. intro ; subst. auto.
+          -- assert (In a l3 -> False). intro. apply n0 ; auto. rewrite permut_remove_remove_list in H3.
+              rewrite notin_remove in H3 ; auto.
+              assert (incl (remove eq_dec_form a l1) l2). intro. intros. apply in_remove in H5. destruct H5.
+              apply H1 in H5. inversion H5 ; subst ; auto. exfalso ; apply H6 ; auto.
+              assert (length (remove_list l2 l4) < length (remove_list (remove eq_dec_form a l1) l3)).
+              pose (redund_remove_remove_list a l1 l3). rewrite notin_remove in e. rewrite e. rewrite notin_remove ; auto.
+              intro. apply In_remove_list_In_list in H6 ; auto. intro. apply In_remove_list_In_list in H6 ; auto.
+              pose (IHl2 (remove eq_dec_form a l1) _ _ H H0 H5 H2 H6). destruct e. destruct H7.
+              exists x ; split ; auto. intro. apply H8. apply in_in_remove ; auto. intro ; subst. auto.
+        * exists a ; split ; auto.
+  Qed.
+ +
+  Lemma less_ub_witness : forall l, length (usable_boxes (XBoxed_list (top_boxes (XBoxed_list (top_boxes l))), []%list)) <
+    length (usable_boxes (XBoxed_list (top_boxes l), []%list)) ->
+    exists A, In (Box A) (top_boxes (XBoxed_list (top_boxes (XBoxed_list (top_boxes l))))) /\
+                  (In (Box A) (top_boxes (XBoxed_list (top_boxes l))) -> False).
+  Proof.
+  intros. unfold usable_boxes in H. simpl in H. unfold subform_boxesS in H. simpl in H.
+  repeat rewrite remove_list_of_nil in H. repeat rewrite app_nil_r in H.
+  apply remove_list_decr_in in H ; auto. destruct H. destruct H.
+  pose (in_top_boxes _ _ H). destruct s. destruct s. destruct s. destruct p. subst. exists x0 ; auto.
+  1-2: apply NoDup_subform_boxesLF.
+  intro. intros. pose (in_top_boxes _ _ H0). destruct s. destruct s. destruct s. destruct p ; subst.
+  apply is_box_in_top_boxes. apply top_boxes_incl_list in H0. apply In_XBoxed_list in H0.
+  destruct H0. apply list_preserv_XBoxed_list. apply is_box_in_top_boxes. 2,4: exists x ; auto.
+  apply list_preserv_XBoxed_list ; auto. destruct H0. destruct H0 ; subst. apply XBoxed_list_In_unfold.
+  exists (Box (Box x)) ; split ; auto. apply is_box_in_top_boxes. 2: exists (Box x) ; auto.
+  apply list_preserv_XBoxed_list ; auto.
+  intro. intros. apply In_subform_boxes in H0. destruct H0. destruct H0. apply In_XBoxed_list in H1.
+  destruct H1. apply In_incl_subform_boxes with (A:=x) ; auto. apply list_preserv_XBoxed_list.
+  apply is_box_in_top_boxes. apply list_preserv_XBoxed_list ; auto. apply in_top_boxes in H1.
+  destruct H1. destruct s. destruct s. destruct p ; subst. exists x0 ; auto.
+  destruct H1. destruct H1 ; subst. apply In_incl_subform_boxes with (A:= x) ; auto.
+  apply XBoxed_list_In_unfold. exists (Box x) ; split ; auto.
+  apply is_box_in_top_boxes. apply list_preserv_XBoxed_list ; auto. exists x ; auto.
+  Qed.
+ +
+  Lemma ub_stable : forall s, length (usable_boxes (XBoxed_list (top_boxes (XBoxed_list (top_boxes (fst s)))), []%list)) <
+     length (usable_boxes (XBoxed_list (top_boxes (fst s)), []%list)) ->
+    length (usable_boxes (XBoxed_list (top_boxes (fst s)), []%list)) < length (usable_boxes s).
+  Proof.
+  intros. unfold usable_boxes. simpl. unfold subform_boxesS. simpl. destruct s. simpl in H. simpl.
+  apply remove_list_incr_decr ; simpl. apply add_remove_list_preserve_NoDup. 2: apply NoDup_nil.
+  apply NoDup_subform_boxesLF. apply add_remove_list_preserve_NoDup. 1-2: apply NoDup_subform_boxesLF.
+  apply less_ub_witness in H. destruct H. destruct H.
+  assert (J0: In (Box (Box (Box x))) (top_boxes l)). apply top_boxes_incl_list in H. apply In_XBoxed_list in H.
+  destruct H. exfalso ; auto. destruct H. destruct H ; subst. apply top_boxes_incl_list in H. apply In_XBoxed_list in H.
+  destruct H. exfalso ; apply H0. apply is_box_in_top_boxes. apply XBoxed_list_In ; auto. unfold is_boxedT ; exists x ; auto.
+  destruct H. destruct H ; subst ; auto.
+  exists (Box (Box x)). repeat split.
+  apply is_box_in_top_boxes. 2: unfold is_boxedT ; eexists ; auto. apply XBoxed_list_In_unfold.
+  exists (Box (Box (Box x))) ; split ; auto. apply in_or_app ; left. apply In_incl_subform_boxes with (A:=Box (Box (Box x))) ; auto.
+  apply top_boxes_incl_list ; auto. simpl ; auto. intro. apply H0. apply is_box_in_top_boxes.
+  2: unfold is_boxedT ; exists x ; auto. apply XBoxed_list_In_unfold. exists (Box (Box x)) ; split ; auto.
+  intro. intros. apply is_box_in_top_boxes. apply list_preserv_XBoxed_list ; auto.
+  apply in_top_boxes in H0. destruct H0. destruct s. destruct s. destruct p ; subst. exists x ; auto.
+  intro. intros. apply in_app_or in H0. destruct H0. apply in_or_app. left.
+  pose (XBoxed_list_same_subform_boxes (top_boxes l)). apply a0 in H0. apply In_subform_boxes in H0. destruct H0.
+  destruct H0. apply In_incl_subform_boxes with (A:=x). apply top_boxes_incl_list ; auto. auto.
+  apply remove_list_is_in. rewrite remove_list_of_nil in H0. inversion H0.
+  Qed.
+ +
+  End Diam_help.
+ +
+  Section logic.
+ +
+  Lemma DiamL_lim : forall A Γ0 Δ, (is_Boxed_list ) ->
+                                                                      (nobox_gen_ext Γ0) ->
+                                                                      (GLS_prv (A :: XBoxed_list , [])) ->
+                                                                      (GLS_prv (Diam A :: Γ0, Δ)).
+  Proof.
+  intros. unfold Diam. unfold Neg.
+  apply derI with (ps:=[([] ++ Γ0, [] ++ Box (A --> ) :: Δ);([] ++ :: Γ0, [] ++ Δ)]).
+  apply ImpL. assert ((Box (A --> ) --> :: Γ0, Δ) = ([] ++ Box (A --> ) --> :: Γ0, [] ++ Δ)). auto.
+  rewrite H0. apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+  2: apply derI with (ps:=[]) ; try apply dlNil ; try apply BotL ; apply BotLRule_I.
+  apply derI with (ps:=[(XBoxed_list ++ [Box (A --> )], [A --> ])]).
+  apply GLR. apply GLRRule_I ; auto. apply dlCons. 2: apply dlNil.
+  apply derI with (ps:=[([] ++ A :: XBoxed_list ++ [Box (A --> )], [] ++ :: [])]).
+  apply ImpR. assert ((XBoxed_list ++ [Box (A --> )], [A --> ]) = ([] ++ XBoxed_list ++ [Box (A --> )], [] ++ A --> :: [])). auto.
+  rewrite H0. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+  assert (J0: derrec_height X0 = derrec_height X0) ; auto.
+  assert (J1: wkn_L (Box (A --> )) (A :: XBoxed_list , []%list) (A :: XBoxed_list ++ [Box (A --> )], []%list)).
+  assert (A :: XBoxed_list = (A :: XBoxed_list ) ++ []). rewrite app_nil_r. auto. rewrite H0.
+  assert (A :: XBoxed_list ++ [Box (A --> )] = (A :: XBoxed_list ) ++ Box (A --> ) :: []). auto. rewrite H1.
+  apply wkn_LI. pose (GLS_wkn_L X0 J0 J1). destruct s.
+  assert (J2: derrec_height x = derrec_height x) ; auto.
+  assert (J3: wkn_R (A :: XBoxed_list ++ [Box (A --> )], []%list) (A :: XBoxed_list ++ [Box (A --> )], [])).
+  assert ((A :: XBoxed_list ++ [Box (A --> )], @nil MPropF) = (A :: XBoxed_list ++ [Box (A --> )], [] ++ [])).
+  rewrite app_nil_r. auto. rewrite H0.
+  assert ((A :: XBoxed_list ++ [Box (A --> )], []) = (A :: XBoxed_list ++ [Box (A --> )], [] ++ :: [])). auto. rewrite H1.
+  apply wkn_RI. pose (GLS_wkn_R x J2 J3). destruct s. simpl. auto.
+  Qed.
+ +
+  Lemma nobox_top_boxes : forall l, nobox_gen_ext (top_boxes l) l.
+  Proof.
+  induction l ; simpl ; auto. apply univ_gen_ext_nil. destruct a.
+  1-3: apply univ_gen_ext_extra ; auto ; intro ; inversion X ; inversion H.
+  apply univ_gen_ext_cons ; auto.
+  Qed.
+ +
+  Lemma top_boxes_nodup : forall l, incl (top_boxes l) (top_boxes (nodup eq_dec_form l)).
+  Proof.
+  induction l ; intro ; intros ; auto. destruct a as [n | | |]; simpl ; simpl in H ; auto ; simpl ; subst.
+  destruct (in_dec eq_dec_form # n l) ; auto. destruct (in_dec eq_dec_form Bot l) ; auto.
+  destruct (in_dec eq_dec_form (a1 --> a2) l) ; auto. destruct (in_dec eq_dec_form (Box a) l) ; simpl ; auto.
+  destruct H ; subst ; auto. apply IHl. apply is_box_in_top_boxes ; auto. exists a ; auto. destruct H ; subst ; auto.
+  Qed.
+ +
+  Lemma subform_boxesLF_nodup : forall l a, In a (subform_boxesLF l) <-> In a (subform_boxesLF (nodup eq_dec_form l)).
+  Proof.
+  induction l ; simpl ; intros ; auto. intuition. split.
+  - destruct a as [n | | |]; simpl ; auto ; intros.
+    destruct (in_dec eq_dec_form # n l) ; apply IHl ; auto. destruct (in_dec eq_dec_form Bot l) ; apply IHl ; auto.
+    destruct (in_dec eq_dec_form (a1 --> a2) l) ; auto. apply in_app_or in H. destruct H.
+    apply IHl. apply In_incl_subform_boxes with (A:=a1 --> a2) ; auto. apply IHl.
+    apply In_remove_list_In_list in H ; auto. apply in_app_or in H. destruct H.
+    simpl. apply in_or_app. left. simpl in H. auto. simpl. apply in_or_app ; right.
+    apply not_removed_remove_list. apply IHl ; auto. apply In_remove_list_In_list in H ; auto.
+    intro. simpl in H. pose (remove_list_cont _ _ H0 _ H). auto.
+    destruct (in_dec eq_dec_form (Box a) l) ; auto. destruct H ; simpl ; auto.
+    apply IHl ; auto. subst. apply In_incl_subform_boxes with (A:=Box a) ; auto. simpl ; auto. apply IHl.
+    apply in_app_or in H ; destruct H. apply In_incl_subform_boxes with (A:=Box a) ; auto. simpl ; auto.
+    apply in_remove in H. destruct H. apply In_remove_list_In_list in H ; auto.
+    destruct H ; subst. simpl ; auto. simpl. right. apply in_or_app ; auto.
+    apply in_app_or in H ; destruct H ; auto. apply in_remove in H. destruct H. right.
+    apply in_not_touched_remove ; auto.
+    apply In_remove_list_In_list_not_In_remove_list in H ; auto. destruct H.
+    apply not_removed_remove_list ; auto.
+    apply IHl ; auto.
+  - destruct a as [n | | |]; simpl ; auto ; intros.
+    destruct (in_dec eq_dec_form # n l) ; apply IHl ; auto. destruct (in_dec eq_dec_form Bot l) ; apply IHl ; auto.
+    destruct (in_dec eq_dec_form (a1 --> a2) l) ; auto. destruct (in_dec eq_dec_form a0 (subform_boxesF a1 ++ remove_list (subform_boxesF a1) (subform_boxesF a2))) ; auto.
+    apply in_or_app ; auto. apply in_or_app ; right.
+    apply not_removed_remove_list ; auto. apply IHl ; auto. simpl in H. apply in_or_app ; apply in_app_or in H ; destruct H ; auto.
+    right. apply In_remove_list_In_list_not_In_remove_list in H ; auto. destruct H.
+    apply not_removed_remove_list ; auto. apply IHl ; auto.
+    destruct (in_dec eq_dec_form (Box a) l) ; auto.
+    destruct (in_dec eq_dec_form a0 (subform_boxesF (Box a))) ; auto. simpl in i0 ; destruct i0 ; auto.
+    right. apply in_or_app ; auto. right. simpl in n. apply in_or_app ; right. apply in_not_touched_remove ; auto.
+    apply not_removed_remove_list ; auto. apply IHl ; auto. simpl in H. destruct H ; auto. right.
+    apply in_or_app ; apply in_app_or in H ; destruct H ; auto.
+    right. apply in_remove in H. destruct H. apply In_remove_list_In_list_not_In_remove_list in H ; auto. destruct H.
+    apply in_not_touched_remove ; auto. apply not_removed_remove_list ; auto. apply IHl ; auto.
+  Qed.
+ +
+  Lemma set_leq_ub_unif : forall s, (length (usable_boxes (nodupseq (XBoxed_list (top_boxes (fst s)), [])))) <= (length (usable_boxes s)).
+  Proof.
+  intros. destruct s. simpl. unfold usable_boxes. simpl.
+  assert (J0: incl (top_boxes l) (top_boxes (XBoxed_list (top_boxes l)))). apply top_boxes_XBoxed_list.
+  assert (J01: incl (top_boxes (XBoxed_list (top_boxes l))) (top_boxes (nodup eq_dec_form (XBoxed_list (top_boxes l))))).
+  intro. intros. apply top_boxes_nodup ; auto.
+  assert (J03: incl (top_boxes l) (top_boxes (nodup eq_dec_form (XBoxed_list (top_boxes l))))).
+  intros a H ; apply J01 ; apply J0 ; auto.
+  pose (remove_list_incr_decr3 (subform_boxesS (nodupseq (XBoxed_list (top_boxes l), []%list))) _ _ J03).
+  assert (J1: NoDup (subform_boxesS (nodupseq (XBoxed_list (top_boxes l), []%list)))). apply NoDup_subform_boxesS.
+  assert (J2: NoDup (subform_boxesS (l, l0))). apply NoDup_subform_boxesS.
+  assert (J3: incl (subform_boxesS (nodupseq (XBoxed_list (top_boxes l), []%list))) (subform_boxesS (l, l0))).
+  intro ; intros. unfold subform_boxesS. simpl. unfold subform_boxesS in H. simpl in H.
+  rewrite remove_list_of_nil in H. rewrite app_nil_r in H. apply in_or_app ; left.
+  assert (J02: In a (subform_boxesLF (XBoxed_list (top_boxes l)))). apply subform_boxesLF_nodup ; auto.
+  apply XBoxed_list_same_subform_boxes with (l:=(top_boxes l)) in J02.
+  apply subform_boxesLF_top_boxes ; auto.
+  pose (remove_list_incr_decr2 _ _ (top_boxes l) J1 J2 J3). lia.
+  Qed.
+ +
+  Lemma is_init_Canopy : forall s, is_init s -> (forall leaf, InT leaf (Canopy s) -> is_init leaf).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros. apply fold_Canopy in H. destruct H ; subst ; auto.
+  destruct s0 ; destruct p. unfold inv_prems in i. apply InT_flatten_list_InT_elem in i. destruct i.
+  destruct p. destruct (finite_ImpRules_premises_of_S s). simpl in i1. subst.
+  apply p in i1. destruct i1.
+  - inversion i1 ; subst. inversion i ; subst. 2: inversion H0.
+    assert (J0: n_imp_subformS (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) < n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)).
+    unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+    lia. apply IHs with (leaf:=leaf) in J0 ; auto.
+    unfold is_init. destruct X. destruct s.
+    left. left. inversion i2 ; subst. assert (InT (# P) (Γ0 ++ A :: Γ1)). apply InT_or_app.
+    assert (InT (# P) (Γ0 ++ Γ1)). rewrite <- H. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. right ; apply InT_cons ; auto. apply InT_split in H0. destruct H0. destruct s. rewrite e.
+    assert (InT (# P) (Δ0 ++ B :: Δ1)). apply InT_or_app.
+    assert (InT (# P) (Δ0 ++ A --> B :: Δ1)). rewrite <- H1. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. inversion i3 ; subst. inversion H2. right ; apply InT_cons ; auto. apply InT_split in H0. destruct H0. destruct s.
+    rewrite e0. apply IdPRule_I.
+    left. right. inversion i2 ; subst. assert (InT (Box A0) (Γ0 ++ A :: Γ1)). apply InT_or_app.
+    assert (InT (Box A0) (Γ0 ++ Γ1)). rewrite <- H. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. right ; apply InT_cons ; auto. apply InT_split in H0. destruct H0. destruct s. rewrite e.
+    assert (InT (Box A0) (Δ0 ++ B :: Δ1)). apply InT_or_app.
+    assert (InT (Box A0) (Δ0 ++ A --> B :: Δ1)). rewrite <- H1. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. inversion i3 ; subst. inversion H2. right ; apply InT_cons ; auto. apply InT_split in H0. destruct H0. destruct s.
+    rewrite e0. apply IdBRule_I.
+    right. inversion b ; subst. assert (InT () (Γ0 ++ A :: Γ1)). apply InT_or_app.
+    assert (InT () (Γ0 ++ Γ1)). rewrite <- H. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. right ; apply InT_cons ; auto. apply InT_split in H0. destruct H0. destruct s. rewrite e. apply BotLRule_I.
+  - inversion i1 ; subst. inversion i ; subst. 2: inversion H0. 3: inversion H1.
+    assert (J0: n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+    unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+    lia. apply IHs with (leaf:=leaf) in J0 ; auto.
+    unfold is_init. destruct X. destruct s.
+    left. left. inversion i2 ; subst. assert (InT (# P) (Γ0 ++ Γ1)). apply InT_or_app.
+    assert (InT (# P) (Γ0 ++ A --> B :: Γ1)). rewrite <- H. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. inversion i3 ; subst. inversion H2. auto. apply InT_split in H0. destruct H0. destruct s. rewrite e.
+    assert (InT (# P) (Δ0 ++ A :: Δ1)). apply InT_or_app.
+    assert (InT (# P) (Δ0 ++ Δ1)). rewrite <- H1. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. right ; apply InT_cons ; auto. apply InT_split in H0. destruct H0. destruct s.
+    rewrite e0. apply IdPRule_I.
+    left. right. inversion i2 ; subst. assert (InT (Box A0) (Γ0 ++ Γ1)). apply InT_or_app.
+    assert (InT (Box A0) (Γ0 ++ A --> B :: Γ1)). rewrite <- H. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. inversion i3 ; subst. inversion H2. auto. apply InT_split in H0. destruct H0. destruct s. rewrite e.
+    assert (InT (Box A0) (Δ0 ++ A :: Δ1)). apply InT_or_app.
+    assert (InT (Box A0) (Δ0 ++ Δ1)). rewrite <- H1. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. right ; apply InT_cons ; auto. apply InT_split in H0. destruct H0. destruct s.
+    rewrite e0. apply IdBRule_I.
+    right. inversion b ; subst. assert (InT () (Γ0 ++ Γ1)). apply InT_or_app.
+    assert (InT () (Γ0 ++ A --> B :: Γ1)). rewrite <- H. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. inversion i2 ; subst. inversion H1. auto. apply InT_split in H0. destruct H0. destruct s. rewrite e. apply BotLRule_I.
+    assert (J0: n_imp_subformS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+    unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+    lia. subst. apply IHs with (leaf:=leaf) in J0 ; auto.
+    unfold is_init. destruct X. destruct s.
+    left. left. inversion i2 ; subst. assert (InT (# P) (Γ0 ++ B :: Γ1)). apply InT_or_app.
+    assert (InT (# P) (Γ0 ++ A --> B :: Γ1)). rewrite <- H. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H1.
+    destruct H1 ; auto. inversion i3 ; subst. inversion H3. right ; apply InT_cons ; auto. apply InT_split in H1. destruct H1. destruct s. rewrite e.
+    apply IdPRule_I.
+    left. right. inversion i2 ; subst. assert (InT (Box A0) (Γ0 ++ B :: Γ1)). apply InT_or_app.
+    assert (InT (Box A0) (Γ0 ++ A --> B :: Γ1)). rewrite <- H. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H1.
+    destruct H1 ; auto. inversion i3 ; subst. inversion H3. right ; apply InT_cons ; auto. apply InT_split in H1. destruct H1. destruct s. rewrite e.
+    apply IdBRule_I.
+    right. inversion b ; subst. assert (InT () (Γ0 ++ B :: Γ1)). apply InT_or_app.
+    assert (InT () (Γ0 ++ A --> B :: Γ1)). rewrite <- H. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H1.
+    destruct H1 ; auto. inversion i2 ; subst. inversion H2. right ; apply InT_cons ; auto. apply InT_split in H1. destruct H1. destruct s. rewrite e. apply BotLRule_I.
+  Qed.
+ +
+  Theorem is_init_UI_equiv_Top : forall s, is_init s -> forall p X Y0 Y1, GLS_prv (X, Y0 ++ Top --> (UI p s) :: Y1).
+  Proof.
+  intros. destruct (critical_Seq_dec s).
+  - assert (J0: GUI p s (UI p s)). apply UI_GUI ; auto.
+    pose (@GUI_inv_critic_init p s (UI p s) J0 c X). rewrite <- e.
+    apply derI with (ps:=[([] ++ Top :: X0, Y0 ++ Top :: Y1)]).
+    apply ImpR. assert ((X0, Y0 ++ Top --> Top :: Y1) = ([] ++ X0, Y0 ++ Top --> Top :: Y1)). auto. rewrite H.
+    apply ImpRRule_I. apply dlCons. 2: apply dlNil. apply TopR.
+  - assert (J0: GUI p s (UI p s)). apply UI_GUI ; auto.
+    assert (J1: Gimap (GUI p) (Canopy (nodupseq s)) (map (UI p) (Canopy (nodupseq s)))). apply Gimap_map. intros.
+    apply UI_GUI ; auto.
+    pose (@GUI_inv_not_critic p s (UI p s) (map (UI p) (Canopy (nodupseq s))) J0 f J1). rewrite <- e.
+    apply derI with (ps:=[([] ++ Top :: X0, Y0 ++ list_conj (map (UI p) (Canopy (nodupseq s))) :: Y1)]).
+    apply ImpR. assert ((X0, Y0 ++ Top --> list_conj (map (UI p) (Canopy (nodupseq s))) :: Y1) = ([] ++ X0, Y0 ++ Top --> list_conj (map (UI p) (Canopy (nodupseq s))) :: Y1)). auto. rewrite H.
+    apply ImpRRule_I. apply dlCons. 2: apply dlNil. simpl.
+    apply GLS_adm_list_exch_R with (s:=(Top :: X0, list_conj (map (UI p) (Canopy (nodupseq s))) :: Y0 ++ Y1)).
+    pose (list_conj_R (map (UI p) (Canopy (nodupseq s))) (Top :: X0, Y0 ++ Y1)). apply g. clear g.
+    intros. simpl. apply InT_map_iff in H. destruct H. destruct p0. subst.
+    assert (J2: GUI p x (UI p x)). apply UI_GUI ; auto.
+    assert (J3: critical_Seq x). apply Canopy_critical in i ; auto.
+    assert (J4: is_init x). apply is_init_Canopy in i ; auto.
+    pose (is_init_nodupseq s). destruct p0. apply i0 ; auto.
+    pose (@GUI_inv_critic_init p x (UI p x) J2 J3 J4). rewrite <- e0.
+    assert ((Top :: X0, Top :: Y0 ++ Y1) = (Top :: X0, [] ++ Top :: Y0 ++ Y1)). auto. rewrite H. apply TopR.
+    assert (list_conj (map (UI p) (Canopy (nodupseq s))) :: Y0 ++ Y1 = [] ++ [list_conj (map (UI p) (Canopy (nodupseq s)))] ++ Y0 ++ [] ++ Y1). auto. rewrite H.
+    assert (Y0 ++ list_conj (map (UI p) (Canopy (nodupseq s))) :: Y1 = [] ++ [] ++ Y0 ++ [list_conj (map (UI p) (Canopy (nodupseq s)))] ++ Y1). auto. rewrite H0.
+    apply list_exch_RI.
+  Qed.
+ +
+  Theorem is_init_UI : forall s, is_init s -> forall p X Y0 Y1, GLS_prv (X, Y0 ++ UI p s :: Y1).
+  Proof.
+  intros. eapply is_init_UI_equiv_Top in X. apply ImpR_inv with (prem:=([] ++ Top :: X0, Y0 ++ UI p s :: Y1)) in X.
+  apply TopL_remove in X. simpl in X ; auto. assert ((X0, Y0 ++ Top --> UI p s :: Y1) = ([] ++ X0, Y0 ++ Top --> UI p s :: Y1)).
+  auto. rewrite H. apply ImpRRule_I.
+  Qed.
+ +
+  End logic.
+ +
+  Section top_boxes_facts.
+ +
+  Theorem top_boxes_diam_jump : forall s, critical_Seq s -> (length (usable_boxes s) = length (usable_boxes (XBoxed_list (top_boxes (fst s)),[]))) ->
+          (forall A, In A (top_boxes (fst s)) <-> In A (top_boxes (XBoxed_list (top_boxes (fst s))))).
+  Proof.
+  intros. split.
+  - intro. apply top_boxes_XBoxed_list ; auto.
+  - intro. pose (in_top_boxes _ _ H1). repeat destruct s0. destruct p. clear e0 ; subst.
+    apply nolessub_In ; auto. lia.
+  Qed.
+ +
+  End top_boxes_facts.
+ +
+  Section nodup_facts.
+ +
+  Theorem list_prop_LF_In: forall l A B, In A l -> In B (list_prop_F A) -> In B (list_prop_LF l).
+  Proof.
+  induction l ; intuition. simpl. apply in_or_app. inversion H ; subst ; auto.
+  right. apply IHl with (A:=A) ; auto.
+  Qed.
+ +
+  Theorem In_propvar_subform: forall l A p, In A l -> In # p (propvar_subform A) -> In # p (propvar_subform_list l).
+  Proof.
+  induction l ; intuition. simpl. apply in_or_app. inversion H ; subst ; auto.
+  right. apply IHl with (A:=A) ; auto.
+  Qed.
+ +
+  Theorem restr_list_prop_nodup : forall l A p,
+      (InT A (restr_list_prop p (nodup eq_dec_form l)) -> InT A (restr_list_prop p l)) *
+      (InT A (restr_list_prop p l) -> InT A (restr_list_prop p (nodup eq_dec_form l))).
+  Proof.
+  induction l ; intros ; simpl ; intuition.
+  - destruct (in_dec eq_dec_form a l) ; auto. apply IHl in H. unfold restr_list_prop. simpl.
+    apply In_InT. apply InT_In in H. apply in_remove in H. destruct H.
+    apply in_not_touched_remove ; auto. apply in_or_app ; right ; auto.
+    unfold restr_list_prop. simpl.
+    apply In_InT. apply InT_In in H. apply in_remove in H. destruct H.
+    apply in_not_touched_remove ; auto. simpl in H. apply in_app_or in H.
+    apply in_or_app ; destruct H ; auto. right.
+    assert (InT A (restr_list_prop p (nodup eq_dec_form l))). apply In_InT.
+    apply in_not_touched_remove ; auto. apply IHl in H1.
+    apply InT_In in H1. apply in_remove in H1. destruct H1. auto.
+  - destruct (in_dec eq_dec_form a l) ; auto. apply IHl. unfold restr_list_prop. simpl.
+    apply In_InT. apply InT_In in H. apply in_remove in H. destruct H.
+    apply in_not_touched_remove ; auto. simpl in H. apply in_app_or in H. destruct H ; auto.
+    apply list_prop_LF_In with (A:=a) ; auto.
+    unfold restr_list_prop. simpl. apply In_InT. apply InT_In in H. apply in_remove in H. destruct H.
+    apply in_not_touched_remove ; auto. simpl in H. apply in_app_or in H. apply in_or_app ; destruct H ; auto.
+    right.
+    assert (InT A (restr_list_prop p l)). apply In_InT.
+    apply in_not_touched_remove ; auto. apply IHl in H1.
+    apply InT_In in H1. apply in_remove in H1. destruct H1. auto.
+  Qed.
+ +
+  Theorem propvar_subform_list_nodup: forall l q,
+  In # q (propvar_subform_list (nodup eq_dec_form l)) <-> In # q (propvar_subform_list l).
+  Proof.
+  induction l ; intuition.
+  - simpl. simpl in H. apply in_or_app. destruct (in_dec eq_dec_form a l).
+    + right ; apply IHl ; auto.
+    + simpl in H. apply in_app_or in H ; destruct H ; auto. right ; apply IHl ; auto.
+  - simpl. simpl in H. apply in_app_or in H. destruct (in_dec eq_dec_form a l).
+    + destruct H. apply In_propvar_subform with (A:=a) ; auto. apply nodup_In ; auto.
+       apply IHl ; auto.
+    + simpl. apply in_or_app. destruct H ; auto. right ; apply IHl ; auto.
+  Qed.
+ +
+  Lemma incl_hpadm_prv : forall s0 s1 (D0: GLS_prv s0), (incl (fst s0) (fst s1)) -> (incl (snd s0) (snd s1)) ->
+    existsT2 (D1: GLS_prv s1), derrec_height D1 <= derrec_height D0.
+  Proof.
+  intros. pose (incl_idS _ _ H H0). destruct s. destruct p. destruct s. destruct s.
+  pose (nodupseq_prv_hpadm_LR _ D0). destruct s.
+  assert (derrec_height x2 = derrec_height x2). auto.
+  apply PermutationTS_sym in p. pose (PermutationTS_prv_hpadm _ x2 _ p).
+  destruct s. destruct x ; simpl in *.
+  assert (derrec_height x3 = derrec_height x3). auto.
+  pose (@GLS_list_wkn_L _ [] l1 _ x3 H2). simpl in s. destruct (s x0).
+  assert (derrec_height x = derrec_height x). auto.
+  pose (@GLS_list_wkn_R _ _ [] l2 x H3). simpl in s2. destruct (s2 x1).
+  apply PermutationTS_sym in p0. pose (PermutationTS_prv_hpadm _ x4 _ p0).
+  destruct s3. pose (nodupseq_prv_hpadm_RL _ x5). destruct s3.
+  exists x6 ; lia.
+  Qed.
+ +
+  Lemma incl_prv : forall s0 s1, (incl (fst s0) (fst s1)) -> (incl (snd s0) (snd s1)) ->
+    (GLS_prv s0) -> (GLS_prv s1).
+  Proof.
+  intros. pose (incl_idS _ _ H H0). destruct s. destruct p. destruct s. destruct s.
+  pose (nodupseq_prv s0). destruct p1. apply g in X. apply PermutationTS_sym in p.
+  pose (PermutationTS_prv _ _ p X). destruct x ; simpl in *.
+  pose (GLS_prv_list_wkn_L [] l). simpl in g2. apply g2 with (l:=x0) in g1.
+  epose (GLS_prv_list_wkn_R []). simpl in g3. apply g3 with (l:=x1) in g1.
+  apply PermutationTS_sym in p0. pose (PermutationTS_prv _ _ p0 g1).
+  apply nodupseq_prv in g4 ; auto.
+  Qed.
+ +
+  Lemma Canopy_nodupseq_equiprv_genR : forall s A,
+    ((forall leaf, InT leaf (Canopy (nodupseq s)) -> GLS_prv (fst leaf, A :: snd leaf)) -> (GLS_prv (fst s, A :: snd s))) *
+    ((GLS_prv (fst s, A :: snd s)) -> (forall leaf, InT leaf (Canopy (nodupseq s)) -> GLS_prv (fst leaf, A :: snd leaf))).
+  Proof.
+  intros. split ; intros.
+  - apply Canopy_equiprv_genR in X. simpl in X.
+    apply incl_prv with (s0:=(nodup eq_dec_form (fst s), A :: nodup eq_dec_form (snd s))) ; simpl ; auto.
+    intros B HB. apply nodup_In in HB ; auto. intros B HB. inversion HB ; simpl ; auto. right. apply nodup_In in H ; auto.
+  - pose (Canopy_equiprv_genR s A). simpl in p. destruct p. clear g. apply Canopy_nodupseq_perm in H.
+    destruct H. destruct p ; subst. pose (g0 X _ i).
+    apply incl_prv with (s0:=((fst x), A :: (snd x))) ; simpl ; auto.
+    intros B HB. apply (nodup_In eq_dec_form) ; apply (nodup_In eq_dec_form) in HB. destruct p.
+    apply Permutation_in with (l:=(nodup eq_dec_form (fst x))) ; auto ; apply Permutation_PermutationT ; destruct x ; destruct leaf ; simpl in * ; auto.
+    intros B HB. apply (nodup_In eq_dec_form) ; apply (nodup_In eq_dec_form) in HB. destruct p.
+    simpl in *. destruct (in_dec eq_dec_form A (snd x)).
+    + destruct (in_dec eq_dec_form A (snd leaf)).
+       apply Permutation_in with (l:=(nodup eq_dec_form (snd x))) ; auto ; apply Permutation_PermutationT ; destruct x ; destruct leaf ; simpl in * ; auto.
+       exfalso. apply n. apply Permutation_PermutationT in p0. apply (nodup_In eq_dec_form).
+       apply Permutation_in with (l:=(nodup eq_dec_form (snd x))) ; auto. apply (nodup_In eq_dec_form) ; auto.
+    + destruct (in_dec eq_dec_form A (snd leaf)).
+       exfalso. apply n. apply Permutation_PermutationT in p0. apply (nodup_In eq_dec_form).
+       apply Permutation_in with (l:=(nodup eq_dec_form (snd leaf))) ; auto. apply Permutation_sym ; auto. apply (nodup_In eq_dec_form) ; auto.
+       simpl ; inversion HB ; auto. right.
+       apply Permutation_in with (l:=(nodup eq_dec_form (snd x))) ; auto ; apply Permutation_PermutationT ; destruct x ; destruct leaf ; simpl in * ; auto.
+  Qed.
+ +
+  Lemma Canopy_nodupseq_equiprv_genL : forall s A,
+    ((forall leaf, InT leaf (Canopy (nodupseq s)) -> GLS_prv (A :: fst leaf, snd leaf)) -> (GLS_prv (A :: fst s, snd s))) *
+    ((GLS_prv (A :: fst s, snd s)) -> (forall leaf, InT leaf (Canopy (nodupseq s)) -> GLS_prv (A :: fst leaf, snd leaf))).
+  Proof.
+  intros. split ; intros.
+  - apply Canopy_equiprv_genL in X. simpl in X.
+    apply incl_prv with (s0:=(A :: nodup eq_dec_form (fst s), nodup eq_dec_form (snd s))) ; simpl ; auto.
+    intros B HB. inversion HB ; simpl ; auto. right. apply nodup_In in H ; auto. intros B HB. apply nodup_In in HB ; auto.
+  - pose (Canopy_equiprv_genL s A). simpl in p. destruct p. clear g. apply Canopy_nodupseq_perm in H.
+    destruct H. destruct p ; subst. pose (g0 X _ i).
+    apply incl_prv with (s0:=(A :: (fst x), (snd x))) ; simpl ; auto.
+    intros B HB. apply (nodup_In eq_dec_form) ; apply (nodup_In eq_dec_form) in HB. destruct p.
+    simpl in *. destruct (in_dec eq_dec_form A (fst x)).
+    + destruct (in_dec eq_dec_form A (fst leaf)).
+       apply Permutation_in with (l:=(nodup eq_dec_form (fst x))) ; auto ; apply Permutation_PermutationT ; destruct x ; destruct leaf ; simpl in * ; auto.
+       exfalso. apply n. apply Permutation_PermutationT in p. apply (nodup_In eq_dec_form).
+       apply Permutation_in with (l:=(nodup eq_dec_form (fst x))) ; auto. apply (nodup_In eq_dec_form) ; auto.
+    + destruct (in_dec eq_dec_form A (fst leaf)).
+       exfalso. apply n. apply Permutation_PermutationT in p. apply (nodup_In eq_dec_form).
+       apply Permutation_in with (l:=(nodup eq_dec_form (fst leaf))) ; auto. apply Permutation_sym ; auto. apply (nodup_In eq_dec_form) ; auto.
+       simpl ; inversion HB ; auto. right.
+       apply Permutation_in with (l:=(nodup eq_dec_form (fst x))) ; auto ; apply Permutation_PermutationT ; destruct x ; destruct leaf ; simpl in * ; auto.
+    + intros B HB. apply (nodup_In eq_dec_form) ; apply (nodup_In eq_dec_form) in HB. destruct p.
+       apply Permutation_in with (l:=(nodup eq_dec_form (snd x))) ; auto ; apply Permutation_PermutationT ; destruct x ; destruct leaf ; simpl in * ; auto.
+  Qed.
+ +
+  End nodup_facts.
+ +
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_basics.html b/GL.Interpolation.UIGL_basics.html new file mode 100644 index 0000000..4c787a1 --- /dev/null +++ b/GL.Interpolation.UIGL_basics.html @@ -0,0 +1,137 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_basics

+ +
+  Require Import List Extraction.
+  Require Import Lia.
+ +
+  Require Import GLS_export.
+ +
+  Section Logic_Abrv.
+ +
+  (* Conjunction of a list of formulas. *)
+ +
+  Fixpoint list_conj (l : list MPropF) : MPropF :=
+  match l with
+   | nil => Top
+   | h :: t => And h (list_conj t)
+  end.
+ +
+  (* Disjunction of a list of formulas. *)
+ +
+  Fixpoint list_disj (l : list MPropF) : MPropF :=
+  match l with
+   | nil => Bot
+   | h :: t => Or h (list_disj t)
+  end.
+ +
+  (* List of propositional variables in a formula. *)
+ +
+  Definition list_prop_F (A : MPropF) : list MPropF :=
+  match A with
+   | # P => [# P]
+   | _ => []
+  end.
+ +
+  (* List of propositional variables in a list of formula. *)
+ +
+  Fixpoint list_prop_LF (l : list MPropF) : list MPropF :=
+  match l with
+   | nil => []
+   | h :: t => (list_prop_F h) ++ (list_prop_LF t)
+  end.
+ +
+  Lemma list_prop_LF_In : forall l A, In A l -> (existsT2 p, A = # p) -> In A (list_prop_LF l).
+  Proof.
+  induction l ; auto. intros. simpl. destruct H0 ; subst. simpl in H. destruct H ; subst.
+  apply in_or_app ; left ; apply in_eq. apply in_or_app ; right. apply IHl ; auto. eexists ; auto.
+  Qed.
+ +
+  Lemma In_list_prop_LF : forall l A, In A (list_prop_LF l) -> In A l.
+  Proof.
+  induction l ; auto. intros. simpl. simpl in H. apply in_app_or in H ; destruct H.
+  left. destruct a ; simpl in H ; subst. destruct H ; auto ; try inversion H.
+  inversion H. 1,2: inversion H. right. apply IHl ; auto.
+  Qed.
+ +
+  Lemma In_list_prop_LF_bis : forall l A, In A (list_prop_LF l) -> ((In A l) * (existsT2 p, A = # p)).
+  Proof.
+  induction l ; auto ; intros. inversion H. simpl in H. split. apply In_list_prop_LF ; auto.
+  apply In_InT in H. apply InT_app_or in H ; destruct H.
+  destruct a ; simpl in i ; inversion i ; subst. eexists ; auto. inversion H0.
+  apply InT_In in i ; apply IHl in i ; destruct i ; auto.
+  Qed.
+ +
+  (* Restricted list of propositional variables. *)
+ +
+  Definition restr_list_prop p (l : list MPropF) := remove eq_dec_form (# p) (list_prop_LF l).
+ +
+  End Logic_Abrv.
+ +
+  Section Random.
+ +
+  Lemma InT_In_Seq: forall (s: Seq) l, (InT s l -> In s l) * (In s l -> InT s l).
+  Proof.
+  intros. split ; intros.
+  - apply InT_In ; auto.
+  - destruct s. apply In_InT_seqs ; auto.
+  Qed.
+ +
+  End Random.
+ +
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_braga.html b/GL.Interpolation.UIGL_braga.html new file mode 100644 index 0000000..8dec0ee --- /dev/null +++ b/GL.Interpolation.UIGL_braga.html @@ -0,0 +1,497 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_braga

+ +
+(**************************************************************)
+(*   Copyright Ian Shillito *                 *)
+(*                                                            *)
+(*                             * Affiliation ANU  *)
+(**************************************************************)
+(*      This file is distributed under the terms of the       *)
+(*         CeCILL v2.1 FREE SOFTWARE LICENSE AGREEMENT        *)
+(**************************************************************)
+ +
+
+ +
+Certification of uniform interpolant function (define below) + +
+ + +
+
+ +
+  Require Import List Extraction.
+  Require Import Lia.
+  Require Import String.
+  Require Import GLS_export.
+ +
+  Require Import UIGL_Def_measure.
+  Require Import UIGL_Canopy.
+  Require Import UIGL_LexSeq.
+  Require Export UIGL_basics.
+  Require Import UIGL_nodupseq.
+ +
+  Import ListNotations.
+ +
+  #[local] Infix "∈" := (@In _) (at level 70, no associativity).
+ +
+  Section imap.
+ +
+  Variables (X Y : Type)
+            (F : X -> Y -> Prop) (* We will instantiate F with GUI (to have mutal recursion). *)
+            (Ffun : forall x l m, F x l -> F x m -> l = m) (*Require that F is a function. *)
+            (D : X -> Prop) (* Domain of F *)
+            (f : forall x, D x -> sig (F x)). (* F is defined on the domain. *)
+ +
+  (* Proceed similarly as Dominique did with flatmap. *)
+ +
+  Inductive Gimap : list X -> list Y -> Prop :=
+    | Gim_nil : Gimap [] []
+    | Gim_cons {x y l m} : F x y
+                         -> Gimap l m
+                         -> Gimap (x::l) (y::m).
+ +
+  Hint Constructors Gimap : core.
+ +
+  Fact Gimap_inv_left l m :
+        Gimap l m
+      -> match l with
+        | [] => [] = m
+        | x::l => exists y m', F x y /\ Gimap l m' /\ m = y :: m'
+        end.
+  Proof. destruct 1; eauto. Qed.
+ +
+  Fact Gimap_inv_sg_left x m : Gimap [x] [m] -> F x m.
+  Proof.
+    intros. apply Gimap_inv_left in H. destruct H. destruct H. destruct H.
+    destruct H0. inversion H1. subst. auto.
+  Qed.
+ +
+  Fact Gimap_app_inv_left l1 l2 m :
+        Gimap (l1++l2) m
+      -> exists m1 m2, Gimap l1 m1 /\ Gimap l2 m2 /\ m = m1++m2.
+  Proof.
+    induction l1 as [ | x l1 IH1 ] in m |- *; simpl.
+    + exists [], m; auto.
+    + intros (y & m' & H1 & (m1 & m2 & H2 & H3 & ->)%IH1 & ->)%Gimap_inv_left.
+      exists (y::m1), m2. repeat split ; auto.
+  Qed.
+ +
+  Fixpoint imap l : (forall x, x l -> D x) -> sig (Gimap l).
+  Proof.
+    refine (match l with
+    | [] => fun _ => exist _ [] Gim_nil
+    | x::l => fun dl => let (y,hy) := f x _ in
+                    let (m,hm) := imap l _ in
+                    exist _ (y::m) (Gim_cons hy hm)
+    end); auto.
+    apply dl ; apply in_eq. intros. apply dl ; apply in_cons ; auto.
+  Defined.
+ +
+  Variables (g : X -> Y) (Hg : forall x, F x (g x)).
+ +
+  Fact Gimap_map l : Gimap l (map g l).
+  Proof. induction l; simpl; now constructor. Qed.
+ +
+  Fact Gimap_fun l0 : forall l1 l2, Gimap l0 l1 -> Gimap l0 l2 -> l1 = l2.
+  Proof. induction l0. intros. apply Gimap_inv_left in H. subst.
+             apply Gimap_inv_left in H0. auto. intros.
+             apply Gimap_inv_left in H. apply Gimap_inv_left in H0.
+             destruct H. destruct H. destruct H. destruct H1. destruct H0.
+             destruct H0. destruct H0. destruct H3. subst. pose (Ffun _ _ _ H H0).
+             rewrite e. pose (IHl0 _ _ H1 H3). rewrite e0. auto. Qed.
+ +
+  End imap.
+ +
+Arguments Gimap {X} {Y} _.
+Arguments imap {X} {Y} _ {D} _ {l}.
+ +
+  Section Gimap_cont.
+ +
+  Variables (X Y : Type)
+            (F : X -> Y -> Prop) (* We will instantiate F with GUI (to have mutal recursion). *)
+            (D : X -> Prop) (* Domain of F *)
+            (f : forall x, D x -> sig (F x)). (* F is defined on the domain. *)
+ +
+  Fact Gimap_fun_rest l0 : forall l1 l2, (forall x, InT x l0 -> forall y0 y1, F x y0 -> F x y1 -> y0 = y1) -> Gimap F l0 l1 -> Gimap F l0 l2 -> l1 = l2.
+  Proof. induction l0. intros l1 l2 Dom H H0. apply Gimap_inv_left in H. subst.
+             apply Gimap_inv_left in H0. auto. intros l1 l2 Dom H H0.
+             apply Gimap_inv_left in H. apply Gimap_inv_left in H0.
+             destruct H. destruct H. destruct H. destruct H1. destruct H0.
+             destruct H0. destruct H0. destruct H3. subst.
+             assert (J0: InT a (a :: l0)). apply InT_eq.
+             pose (Dom _ J0 _ _ H H0). rewrite e.
+             assert (J1: forall x : X, InT x l0 -> forall y0 y1 : Y, F x y0 -> F x y1 -> y0 = y1).
+             intros. apply Dom with (x:=x3) ; auto. apply InT_cons ; auto.
+             pose (IHl0 _ _ J1 H1 H3). rewrite e0. auto. Qed.
+ +
+  End Gimap_cont.
+ +
+  Section GN.
+ +
+  Variables (p : string) (* The variable we exclude from the interpolant. *)
+            (F : Seq -> MPropF -> Prop) (* We will instantiate F with GUI (to have mutal recursion). *)
+            (Ffun : forall x l m, F x l -> F x m -> l = m). (* Require that F is a function. *)
+ +
+  (* First I define the graph of the function N, which is involved in UI. N is total. *)
+ +
+  Unset Elimination Schemes.
+ +
+
+ +
+I proceed as Dominique: Because of nesting, induction principles are too weak, + see below for better ones +
+
+ +
+  Inductive GN : Seq -> Seq -> MPropF -> Prop :=
+    (* If s is initial, send Top. *)
+    | GN_init_seq {s0 s} : is_init s -> GN s0 s Top
+    (* If s is not initial, and has less usable boxes than s0, then call UI. *)
+    | GN_less_ub {s0 s φ} : (is_init s -> False) ->
+                              (length (usable_boxes s) < length (usable_boxes s0)) ->
+                              F s φ ->
+                              GN s0 s φ
+    (* If s is not initial, and does not have less usable boxes than s0, then do an unfolding without recursive call. *)
+    | GN_less {s0 s l} : (is_init s -> False) ->
+                              ((length (usable_boxes s) < length (usable_boxes s0)) -> False) ->
+                              (Gimap F (GLR_prems (nodupseq s)) l) ->
+                              GN s0 s (Or (list_disj (restr_list_prop p (snd s))) (* Disjunction of propositional variables (different from p) on the right. *)
+                                            (Or (list_disj (map Neg (restr_list_prop p (fst s)))) (* Disjunction of propositional variables (different from p) on the left, negated. *)
+                                            (list_disj (map Box l)))).
+ +
+  Set Elimination Schemes.
+ +
+  Fact GN_inv_init0 {s0 s A} : GN s0 s A -> is_init s -> Top = A.
+  Proof. destruct 1 as [ Inits | ? ? ? Inits | ] ; intros; trivial ; exfalso ; auto. Qed.
+ +
+  Fact GN_inv_noinit_lessub0 {s0 s A φ} : GN s0 s A -> (is_init s -> False) ->
+                           (length (usable_boxes s) < length (usable_boxes s0)) ->
+                           F s φ ->
+                           φ = A.
+  Proof. destruct 1 as [ Inits | ? ? ? Inits | ] ; intros; trivial ; auto. 1, 3: exfalso ; auto.
+             apply (Ffun s) ; auto. Defined.
+ +
+  Fact GN_inv_noinit_nolessub0 {s0 s A l} : GN s0 s A -> (is_init s -> False) ->
+                           ((length (usable_boxes s) < length (usable_boxes s0)) -> False) ->
+                           (Gimap F (GLR_prems (nodupseq s)) l) ->
+          (Or (list_disj (restr_list_prop p (snd s))) (Or (list_disj (map Neg (restr_list_prop p (fst s)))) (list_disj (map Box l)))) = A.
+  Proof. destruct 1 as [ Inits | ? ? ? Inits | ] ; intros; trivial ; auto. 1, 2: exfalso ; auto.
+              pose (Gimap_fun _ _ F Ffun _ _ _ H1 H4). rewrite e. auto. Defined.
+ +
+  Hint Constructors Gimap GN : core.
+  Hint Resolve GN_inv_init0 GN_inv_noinit_lessub0 GN_inv_noinit_nolessub0 : core.
+ +
+  Lemma GN_fun : forall s0 s A, GN s0 s A -> (fun s0 s A => forall B, GN s0 s B -> A = B) s0 s A.
+  Proof.
+  intros. inversion H ; subst ; intros; auto.
+  - pose (GN_inv_init0 H0 X) ; auto.
+  - pose (GN_inv_noinit_lessub0 H3 H0 H1 H2) ; auto.
+  - pose (GN_inv_noinit_nolessub0 H3 H0 H1 H2) ; auto.
+  Qed.
+ +
+  Lemma GN_fun0 : forall s0 s A B, GN s0 s A -> GN s0 s B -> A = B.
+  Proof.
+  intros. apply GN_fun with (s0:=s0) (s:=s) ; auto.
+  Qed.
+ +
+  End GN.
+ +
+  Section UI.
+ +
+  (* Second I define the graph of the function UI. *)
+ +
+  Variables (p : string). (* The variable we exclude from the interpolant. *)
+ +
+  Unset Elimination Schemes.
+ +
+
+ +
+Because of nesting, induction principles are too weak, + see below for better ones +
+
+ +
+  Inductive GUI : Seq -> MPropF -> Prop :=
+    | GUI_empty_seq {s} : s = ([],[]) -> (* If s is the empty set, output Bot. *)
+                                      GUI s Bot
+    | GUI_critic_init {s} : critical_Seq s -> (* If critical and initial, output Top. *)
+                                      is_init s ->
+                                      GUI s Top
+    | GUI_not_critic {s l} : ((critical_Seq s) -> False) -> (* If not critical, output conjunction of recursive calls of GUI on Canopy. *)
+                                      (Gimap GUI (Canopy (nodupseq s)) l) ->
+                                      GUI s (list_conj l)
+    | GUI_critic_not_init {s l0 l1} : critical_Seq s -> (* If critical but not initial, store the propositional variables, recursively call on
+                                                                                                               the GLR premises of the sequent, and use GN. *)

+                                           (s <> ([],[])) ->
+                                           (is_init s -> False) ->
+                                           (Gimap GUI (GLR_prems (nodupseq s)) l0) ->
+                                           (Gimap (GN p GUI s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []))) l1) ->
+                                           GUI s (Or (list_disj (restr_list_prop p (snd s)))
+                                                     (Or (list_disj (map Neg (restr_list_prop p (fst s))))
+                                                     (Or (list_disj (map Box l0))
+                                                     (Diam (list_conj l1))))).
+ +
Set Elimination Schemes.
+ +
+  Lemma GUI_fun : forall x l m, GUI x l -> GUI x m -> l = m.
+  Proof.
+  apply (LexSeq_ind (fun x => forall l m, GUI x l -> GUI x m -> l = m)).
+  intros s IH l m H H0. inversion H ; inversion H0 ; subst ; auto ; simpl in *. 1-8: exfalso ; auto.
+  6-9: exfalso ; auto. 1,3: apply not_init_empty_seq ; auto. apply H4 ; apply critical_empty_seq.
+  apply H1 ; apply critical_empty_seq.
+  - assert (J0: (forall x : Seq, InT x (Canopy (nodupseq s)) -> forall y0 y1 : MPropF, GUI x y0 -> GUI x y1 -> y0 = y1)).
+    intros. apply IH with (s1:=x) ; auto. apply LexSeq_nodupseq. destruct (Canopy_LexSeq (nodupseq s) x H3) ; auto.
+    exfalso. apply H1. apply critical_nodupseq. apply Canopy_critical with (s:=nodupseq s) ; subst ; auto.
+    pose (Gimap_fun_rest _ _ GUI (Canopy (nodupseq s)) l0 l1 J0). rewrite e ; auto.
+  - assert (J0: list_disj (map Box l0) = list_disj (map Box l2)).
+    assert (J00: (forall x : Seq, InT x (GLR_prems (nodupseq s)) -> forall y0 y1 : MPropF, GUI x y0 -> GUI x y1 -> y0 = y1)).
+    intros. apply IH with (s1:=x) ; auto. apply LexSeq_nodupseq. apply GLR_prems_LexSeq ; auto.
+    intro. pose (is_init_nodupseq s). apply H3. apply p0. unfold is_init ; auto.
+    pose (Gimap_fun_rest _ _ GUI (GLR_prems (nodupseq s)) l0 l2 J00). rewrite e ; auto.
+    assert (J1: l1 = l3).
+    assert (J10: (forall x : Seq, InT x (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))) -> forall y0 y1 : MPropF, (GN p GUI s) x y0 -> (GN p GUI s) x y1 -> y0 = y1)).
+    intros. inversion H7 ; inversion H13 ; subst ; auto. 1-3: exfalso ; auto.
+    2-4: exfalso ; auto.
+    apply IH with (s1:=x) ; auto. unfold LexSeq. unfold less_thanS. apply DLW_wf_lex.lex_cons ; auto.
+    assert (J100: (forall x0 : Seq, InT x0 (GLR_prems (nodupseq x)) -> forall y0 y1 : MPropF, GUI x0 y0 -> GUI x0 y1 -> y0 = y1)).
+    intros. apply IH with (s1:=x0) ; auto. unfold LexSeq. apply DLW_wf_lex.lex_cons ; auto. apply GLR_prems_less_ub in H17.
+    rewrite <- ub_nodupseq in H17. pose (leq_ub_Canopy _ _ H6). rewrite <- ub_nodupseq in l5.
+    pose (leq_ub_unif s) ; lia. intros. pose (is_init_nodupseq x). apply H14. apply p0. unfold is_init ; left ; auto.
+    pose (Gimap_fun_rest _ _ GUI (GLR_prems (nodupseq x)) l l4 J100). rewrite e ; auto.
+    pose (Gimap_fun_rest _ _ _ _ l1 l3 J10). rewrite e ; auto.
+    rewrite J0. rewrite J1. auto.
+  Qed.
+ +
+  Definition GUI_tot : forall s : Seq, {A : MPropF | GUI s A}.
+  Proof.
+  apply (LexSeq_ind (fun x => existsT A : MPropF, GUI x A)).
+  intros s IH. destruct (empty_seq_dec s).
+  - subst. exists Bot. apply GUI_empty_seq ; auto.
+  - destruct (critical_Seq_dec s).
+    -- destruct (dec_init_rules s).
+      * assert (is_init s) ; auto. exists Top. apply GUI_critic_init ; auto.
+      * assert (is_init s -> False) ; auto.
+        assert ((forall x : Seq, In x (GLR_prems (nodupseq s)) -> {x0 : MPropF | GUI x x0})).
+        intros. apply IH with (s1:=x) ; auto. apply LexSeq_nodupseq. apply GLR_prems_LexSeq ; auto.
+        intro. pose (is_init_nodupseq s). apply f. apply p0. unfold is_init ; auto. apply InT_In_Seq ; auto.
+        epose (@imap _ _ GUI (fun (x : Seq) => In x (GLR_prems (nodupseq s))) H0 (GLR_prems (nodupseq s))). simpl in s0. destruct s0 ; auto.
+        assert (J10: (forall z : Seq, In z (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list))) -> existsT A : MPropF, (GN p GUI s) z A)).
+         { intros. destruct (dec_init_rules z).
+         -- exists Top. apply GN_init_seq ; auto.
+         -- destruct (Compare_dec.lt_dec (length (usable_boxes z)) (length (usable_boxes s))).
+             ** destruct (IH z). unfold LexSeq. apply DLW_wf_lex.lex_cons ; auto. exists x0. apply GN_less_ub ; auto.
+             ** assert (J100: (forall x0 : Seq, In x0 (GLR_prems (nodupseq z)) -> existsT A : MPropF, GUI x0 A)).
+                 intros. apply IH with (s1:=x0) ; auto. unfold LexSeq. apply DLW_wf_lex.lex_cons ; auto. apply InT_In_Seq in H2. apply GLR_prems_less_ub in H2.
+                 rewrite <- ub_nodupseq in H2. apply InT_In_Seq in H1. pose (leq_ub_Canopy _ _ H1). rewrite <- ub_nodupseq in l.
+                 pose (leq_ub_unif s) ; lia. intros. pose (is_init_nodupseq z). apply f0. apply p0. unfold is_init ; left ; auto.
+                 epose (@imap _ _ GUI (fun (x : Seq) => In x (GLR_prems (nodupseq z))) J100 (GLR_prems (nodupseq z))). simpl in s0. destruct s0 ; auto.
+                 exists (Or (list_disj (restr_list_prop p (snd z))) (Or (list_disj (map Neg (restr_list_prop p (fst z)))) (list_disj (map Box x0)))).
+                 apply GN_less ; auto. }
+         epose (@imap Seq MPropF (GN p GUI s) (fun (x : Seq) => In x (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))) J10
+         (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []%list)))). simpl in s0. destruct s0 ; auto.
+         exists (Or (list_disj (restr_list_prop p (snd s))) (Or (list_disj (map Neg (restr_list_prop p (fst s))))
+         (Or (list_disj (map Box x)) (Diam (list_conj x0))))). apply GUI_critic_not_init ; auto.
+    -- assert ((forall x : Seq, In x (Canopy (nodupseq s)) -> {x0 : MPropF | GUI x x0})).
+        intros. apply IH with (s1:=x) ; auto. destruct (Canopy_LexSeq (nodupseq s) x) ; auto.
+        apply InT_In_Seq ; auto. subst. exfalso. apply f. apply critical_nodupseq. apply InT_In_Seq in H ; apply Canopy_critical in H ; auto.
+        apply LexSeq_nodupseq ; auto.
+        epose (@imap _ _ GUI (fun (x : Seq) => In x (Canopy (nodupseq s))) H (Canopy (nodupseq s))). simpl in s0. destruct s0 ; auto.
+        exists (list_conj x). apply GUI_not_critic ; auto.
+Defined.
+ +
+  Fact GUI_inv_empty_seq {s A} : GUI s A -> s = ([],[]) -> Bot = A.
+  Proof. intros. pose (GUI_empty_seq H0). apply (GUI_fun _ _ _ g H). Qed.
+ +
+  Fact GUI_inv_critic_init {s A} : GUI s A -> critical_Seq s -> is_init s -> Top = A.
+  Proof. intros. pose (GUI_critic_init H0 X). apply (GUI_fun _ _ _ g H). Qed.
+ +
+  Fact GUI_inv_not_critic {s A l} : GUI s A -> (critical_Seq s -> False) ->
+                           (Gimap GUI (Canopy (nodupseq s)) l) ->
+                           ((list_conj l) = A).
+  Proof.
+  intros. pose (GUI_not_critic H0 H1). apply (GUI_fun _ _ _ g H).
+  Qed.
+ +
+  Fact GUI_inv_critic_not_init {s A l0 l1} : GUI s A -> critical_Seq s ->
+                           (s <> ([],[])) ->
+                           (is_init s -> False) ->
+                           (Gimap GUI (GLR_prems (nodupseq s)) l0) ->
+                           (Gimap (GN p GUI s) (Canopy (nodupseq (XBoxed_list (top_boxes (fst s)), []))) l1) ->
+                           ((Or (list_disj (restr_list_prop p (snd s)))
+                                                     (Or (list_disj (map Neg (restr_list_prop p (fst s))))
+                                                     (Or (list_disj (map Box l0))
+                                                     (Diam (list_conj l1))))) = A).
+  Proof.
+  intros. pose (GUI_critic_not_init H0 H1 H2 H3 H4). apply (GUI_fun _ _ _ g H).
+  Qed.
+ +
+  Let UI_pwc : forall x, sig (GUI x).
+  Proof.
+  apply GUI_tot.
+  Qed.
+ +
+  Definition UI x := proj1_sig (UI_pwc x).
+ +
+  Fact UI_spec x : GUI x (UI x).
+  Proof. apply (proj2_sig _). Qed.
+ +
+  Lemma UI_GUI : forall x A, UI x = A <-> GUI x A.
+  Proof.
+  intros. split ; intro ; subst.
+  apply UI_spec. unfold UI. destruct UI_pwc. simpl.
+  apply GUI_fun with (x:=x) ; auto.
+  Qed.
+ +
+  End UI.
+ +
+  Section N.
+ +
+  Definition N_pwc : forall p s0 s, sig (GN p (GUI p) s0 s).
+  Proof.
+  intros. destruct (dec_init_rules s).
+  - assert (is_init s) ; auto. exists Top. apply GN_init_seq ; auto.
+  - assert (is_init s -> False) ; auto.
+    destruct (Compare_dec.lt_dec (length (usable_boxes s)) (length (usable_boxes s0))).
+    + exists (UI p s). apply GN_less_ub ; auto ; apply UI_GUI ; auto.
+    + assert (J100: (forall x0 : Seq, In x0 (GLR_prems (nodupseq s)) -> existsT A : MPropF, GUI p x0 A)).
+       intros. apply GUI_tot.
+       epose (@imap _ _ (GUI p) (fun (x : Seq) => In x (GLR_prems (nodupseq s))) J100 (GLR_prems (nodupseq s))). simpl in s1. destruct s1 ; auto.
+       exists (Or (list_disj (restr_list_prop p (snd s))) (Or (list_disj (map Neg (restr_list_prop p (fst s)))) (list_disj (map Box x)))).
+       apply GN_less ; auto.
+  Qed.
+ +
+  Variables (p : string). (* Propositional variable we consider. *)
+ +
+  Definition N s0 s := proj1_sig (N_pwc p s0 s).
+ +
+  Fact N_spec s0 s : GN p (GUI p) s0 s (N s0 s).
+  Proof. apply (proj2_sig _). Qed.
+ +
+  Fact GN_inv_init {s0 s A} : GN p (GUI p) s0 s A -> is_init s -> Top = A.
+  Proof. destruct 1 as [ Inits | ? ? ? Inits | ] ; intros; trivial ; exfalso ; auto. Qed.
+ +
+  Fact GN_inv_noinit_lessub {s0 s A φ} : GN p (GUI p) s0 s A -> (is_init s -> False) ->
+                           (length (usable_boxes s) < length (usable_boxes s0)) ->
+                           GUI p s φ ->
+                           φ = A.
+  Proof. destruct 1 as [ Inits | ? ? ? Inits | ] ; intros; trivial ; auto. 1, 3: exfalso ; auto.
+             apply (GUI_fun p s) ; auto. Defined.
+ +
+  Fact GN_inv_noinit_nolessub {s0 s A l} : GN p (GUI p) s0 s A -> (is_init s -> False) ->
+                           ((length (usable_boxes s) < length (usable_boxes s0)) -> False) ->
+                           (Gimap (GUI p) (GLR_prems (nodupseq s)) l) ->
+          (Or (list_disj (restr_list_prop p (snd s))) (Or (list_disj (map Neg (restr_list_prop p (fst s)))) (list_disj (map Box l)))) = A.
+  Proof. destruct 1 as [ Inits | ? ? ? Inits | ] ; intros; trivial ; auto. 1, 2: exfalso ; auto.
+              pose (Gimap_fun _ _ (GUI p) (GUI_fun p) _ _ _ H1 H4). rewrite e. auto. Defined.
+ +
+  Hint Resolve N_spec : core.
+ +
+  End N.
+ +
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_irred_high_level.html b/GL.Interpolation.UIGL_irred_high_level.html new file mode 100644 index 0000000..e4eebaf --- /dev/null +++ b/GL.Interpolation.UIGL_irred_high_level.html @@ -0,0 +1,144 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_irred_high_level

+ +
+(**************************************************************)
+(*   Copyright Dominique Larchey-Wendling *                 *)
+(*                                                            *)
+(*                             * Affiliation LORIA -- CNRS  *)
+(**************************************************************)
+(*      This file is distributed under the terms of the       *)
+(*         CeCILL v2.1 FREE SOFTWARE LICENSE AGREEMENT        *)
+(**************************************************************)
+ +
+Require Import List Relations Utf8.
+ +
+Import ListNotations.
+ +
+#[local] Infix "∈" := (@In _) (at level 70, no associativity).
+ +
+Definition list_is_nil {X} (l : list X) : { l = [] } + { l [] }.
+Proof. now destruct l; [ left | right ]. Qed.
+ +
+Section irred_high_level.
+ +
+  Variables (X : Type)
+            (f : X list X)
+            (f_wf : well_founded (λ u v, u f v))
+            (irred : X list X)
+            (irred_nil : x, f x = [] irred x = [x])
+            (irred_not : x, f x [] irred x = flat_map irred (f x))
+            .
+ +
+  Fact irred_max x y : y irred x f y = [].
+  Proof.
+    induction (f_wf x) as [ x _ IHx ] in y.
+    destruct (list_is_nil (f x)) as [ H | H ].
+    + rewrite irred_nil; auto.
+      now intros [ <- | [] ].
+    + rewrite irred_not, in_flat_map; auto.
+      intros (z & ? & ?); eauto.
+  Qed.
+ +
+  Fact irred_reach x y : y irred x clos_refl_trans _ (λ u v, u f v) y x.
+  Proof.
+    induction (f_wf x) as [ x _ IHx ] in y.
+    destruct (list_is_nil (f x)) as [ H | H ].
+    + rewrite irred_nil; auto.
+      intros [ <- | [] ]; constructor 2.
+    + rewrite irred_not, in_flat_map; auto.
+      intros (z & Hz1 & Hz2).
+      constructor 3 with z; auto.
+      now constructor 1.
+  Qed.
+ +
+  Hint Resolve in_eq : core.
+ +
+  Theorem irred_high_level_spec x y : y irred x f y = [] clos_refl_trans _ (λ u v, u f v) y x.
+  Proof.
+    split.
+    + split.
+      * now apply irred_max with x.
+      * now apply irred_reach.
+    + intros (H1 & H2); revert H2 H1.
+      rewrite clos_rt_rtn1_iff.
+      induction 1 as [ | x z H1 H2 IH2 ]; intros H.
+      * rewrite irred_nil; auto.
+      * rewrite irred_not, in_flat_map.
+        - exists x; auto.
+        - now intros e; rewrite e in H1.
+  Qed.
+ +
+  Section provability.
+ +
+    Variables (P : X Prop)
+              (HP : x, f x [] P x Forall P (f x)).
+ +
+    Theorem irred_provability x : P x Forall P (irred x).
+    Proof.
+      induction (f_wf x) as [ x _ IHx ].
+      destruct (list_is_nil (f x)) as [ H | H ].
+      + rewrite irred_nil; auto.
+        split.
+        * repeat (constructor; auto).
+        * now inversion 1.
+      + rewrite irred_not; auto.
+        rewrite Forall_flat_map, HP; auto.
+        rewrite !Forall_forall.
+        split; firstorder.
+    Qed.
+ +
+  End provability.
+ +
+End irred_high_level.
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_irred_short.html b/GL.Interpolation.UIGL_irred_short.html new file mode 100644 index 0000000..60da2c4 --- /dev/null +++ b/GL.Interpolation.UIGL_irred_short.html @@ -0,0 +1,334 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_irred_short

+ +
+(**************************************************************)
+(*   Copyright Dominique Larchey-Wendling *                 *)
+(*                                                            *)
+(*                             * Affiliation LORIA -- CNRS  *)
+(**************************************************************)
+(*      This file is distributed under the terms of the       *)
+(*         CeCILL v2.1 FREE SOFTWARE LICENSE AGREEMENT        *)
+(**************************************************************)
+ +
+
+ +
+Certification of + +
+ + let rec flatmap f = function + | -> + | x::l -> f x ++ flatmap f l + +
+ + let rec irred f x = + match f x with + | -> x + | _ -> flatmap (irred f) (f x) + +
+ + by extraction. + +
+ + Following a question by Ian Schillito + Also look at the following PR + +
+ + https://github.com/DmxLarchey/Kruskal-Trees/pull/5 + +
+ + +
+
+ +
+(* 
+   This is a standalone file, directly compile with
+
+      coqc irred.v 
+ *)

+ +
+Require Import List Utf8 Extraction.
+Import ListNotations.
+ +
+#[local] Infix "∈" := (@In _) (at level 70, no associativity).
+#[local] Hint Resolve in_eq in_cons : core.
+ +
+Definition list_is_nil {X} (l : list X) : { l = [] } + { l [] }.
+Proof. now destruct l; [ left | right ]. Defined.
+ +
+
+ +
+Directly via Fix_F after cleaning up from Braga using + the domain Dirred := Acc (λ u v, u ∈ f v) directly +
+
+Section flatmap.
+ +
+  Variables (X : Type)
+            (F : X list X Prop)
+            (D : X Prop)
+            (f : x, D x sig (F x)).
+ +
+  Implicit Type (l : list X).
+ +
+  Inductive Gflatmap : list X list X Prop :=
+    | Gfm_nil : Gflatmap [] []
+    | Gfm_cons {x y l m} : F x y
+                          Gflatmap l m
+                          Gflatmap (x::l) (y++m).
+ +
+  Hint Constructors Gflatmap : core.
+ +
+  Fact Gflatmap_inv_left l m :
+        Gflatmap l m
+       match l with
+        | [] => [] = m
+        | x::l => y m', F x y Gflatmap l m' m = y++m'
+        end.
+  Proof. destruct 1; eauto. Qed.
+ +
+  Fact Gflatmap_inv_sg_left x m : Gflatmap [x] m F x m.
+  Proof.
+    intros (y & ? & ? & <-%Gflatmap_inv_left & ->)%Gflatmap_inv_left.
+    now rewrite app_nil_r.
+  Qed.
+ +
+  Fact Gflatmap_app_inv_left l1 l2 m :
+        Gflatmap (l1++l2) m
+       m1 m2, Gflatmap l1 m1 Gflatmap l2 m2 m = m1++m2.
+  Proof.
+    induction l1 as [ | x l1 IH1 ] in m |- *; simpl.
+    + exists [], m; auto.
+    + intros (y & m' & H1 & (m1 & m2 & H2 & H3 & ->)%IH1 & ->)%Gflatmap_inv_left.
+      exists (y++m1), m2; rewrite app_assoc; auto.
+  Qed.
+ +
+  Fixpoint flatmap l : (x, x l D x) sig (Gflatmap l).
+  Proof.
+    refine (match l with
+    | [] => λ _ , exist _ [] Gfm_nil
+    | x::l => λ dl, let (y,hy) := f x _ in
+                    let (m,hm) := flatmap l _ in
+                    exist _ (y++m) (Gfm_cons hy hm)
+    end); auto.
+  Defined.
+ +
+  Variables (g : X list X) (Hg : x, F x (g x)).
+ +
+  Fact Gflatmap_flat_map l : Gflatmap l (flat_map g l).
+  Proof. induction l; simpl; now constructor. Qed.
+ +
+End flatmap.
+ +
+Arguments Gflatmap {X} _.
+Arguments flatmap {X} _ {D} _ {l}.
+ +
+Section irred.
+ +
+  Variables (X : Type) (f : X list X).
+ +
+  Implicit Type l : list X.
+ +
+  Unset Elimination Schemes.
+ +
+
+ +
+Because of nesting, induction principles are too weak, + see below for better ones +
+
+ +
+  Inductive Girred : X list X Prop :=
+    | Girred_nil {x} : f x = []
+                        Girred x [x]
+    | Girred_not {x l} : f x []
+                        Gflatmap Girred (f x) l
+                        Girred x l.
+ +
+  Set Elimination Schemes.
+ +
+  Fact Girred_inv_nil {x l} : Girred x l f x = [] [x] = l.
+  Proof. destruct 1 as [ | ? ? Hx ]; intros; trivial; now destruct Hx. Qed.
+ +
+  Fact Girred_inv_not {x l} : Girred x l f x [] Gflatmap Girred (f x) l.
+  Proof. destruct 1; intros G; trivial; now destruct G. Defined.
+ +
+  Hint Constructors Gflatmap Girred : core.
+  Hint Resolve Girred_inv_nil Girred_inv_not : core.
+ +
+  Section Girred_ind.
+ +
+    Variables (P : list X list X Prop)
+              (Q : X list X Prop)
+
+              (HP0 : P [] [])
+              (HP1 : x y l m, Girred x y Q x y Gflatmap Girred l m P l m P (x::l) (y++m))
+
+              (HQ0 : x, f x = [] Q x [x])
+              (HQ1 : x m, f x [] Gflatmap Girred (f x) m P (f x) m Q x m).
+ +
+    Fixpoint Girred_ind x m (dxm : Girred x m) { struct dxm } : Q x m.
+    Proof.
+      destruct (list_is_nil (f x)) as [ H | H ].
+      + destruct (Girred_inv_nil dxm H); auto.
+      + apply HQ1; auto.
+        generalize (Girred_inv_not dxm H).
+        clear dxm H.
+        induction 1; eauto.
+    Qed.
+ +
+  End Girred_ind.
+ +
+  Lemma Girred_fun : x l, Girred x l (λ x l, m, Girred x m l = m) x l.
+  Proof.
+    (* the property which is proved for (Gflatmap Girred) cannot be guessed by unification *)
+    apply Girred_ind with (P := fun l m1 => m2, Gflatmap Girred l m2 m1 = m2); eauto.
+    + now intros ? ?%Gflatmap_inv_left.
+    + intros ? ? ? ? ? ? ? ? ? (y' & m' & ? & ? & ->)%Gflatmap_inv_left; f_equal; eauto.
+  Qed.
+ +
+
+ +
+We build irred packed with conformity to Girred by Fix_F + induction over Acc (λ u v, u ∈ f v) x directly +
+
+  Let irred_pwc : x (dx : Acc (λ u v, u f v) x), sig (Girred x).
+  Proof.
+    refine (Fix_F _ (λ x irred_pwc,
+      match list_is_nil (f x) with
+      | left Hxf => exist _ [x] _
+      | right Hxf => let (m,hm) := flatmap Girred irred_pwc (λ _ h, h) in
+                     exist _ m _
+      end)); auto.
+  Defined.
+ +
+
+ +
+Now we can instanciate for _ ∈ f _ is well founded + and define irred as a total function +
+
+ +
+  Hypothesis hf : well_founded (λ u v, u f v).
+ +
+  Definition irred x := proj1_sig (irred_pwc x (hf x)).
+ +
+  Fact irred_spec x : Girred x (irred x).
+  Proof. apply (proj2_sig _). Qed.
+ +
+  Hint Resolve irred_spec : core.
+ +
+
+ +
+We conclude with fixpoint equations +
+
+ +
+  Fact irred_nil x : f x = [] irred x = [x].
+  Proof. intros; eapply Girred_fun; eauto. Qed.
+ +
+  Hint Resolve Gflatmap_flat_map : core.
+ +
+  Fact irred_not x : f x [] irred x = flat_map irred (f x).
+  Proof. intros; eapply Girred_fun; eauto. Qed.
+ +
+End irred.
+ +
+Arguments Girred {X}.
+Arguments irred {X f}.
+ +
+
+
+ +
+ + + diff --git a/GL.Interpolation.UIGL_nodupseq.html b/GL.Interpolation.UIGL_nodupseq.html new file mode 100644 index 0000000..4691a07 --- /dev/null +++ b/GL.Interpolation.UIGL_nodupseq.html @@ -0,0 +1,641 @@ + + + + + + + + + + + + + +
+
+

GL.Interpolation.UIGL_nodupseq

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+ +
+Require Import general_export.
+ +
+Require Import GLS_export.
+ +
+Require Import UIGL_Def_measure.
+Require Import UIGL_Canopy.
+Require Import UIGL_irred_short.
+Require Import UIGL_basics.
+Require Import UIGL_LexSeq.
+Require Import UIGL_PermutationT.
+Require Import UIGL_PermutationTS.
+ +
+  Section nodupseq.
+ +
+  Definition nodupseq (s : Seq) := (nodup eq_dec_form (fst s), nodup eq_dec_form (snd s)).
+ +
+  End nodupseq.
+ +
+  Lemma nodup_app : forall l0 l1 l2, (nodup eq_dec_form l0 = nodup eq_dec_form l1) -> (nodup eq_dec_form (l0 ++ l2) = nodup eq_dec_form (l1 ++ l2)).
+  Proof.
+  induction l0.
+  - simpl ; intros. assert (l1 = []). destruct l1 ; auto. exfalso. simpl in H. destruct (in_dec eq_dec_form m l1).
+    apply (nodup_In eq_dec_form) in i. rewrite <- H in i ; inversion i. inversion H. subst. simpl. auto.
+  - induction l1.
+    + simpl ; intros. destruct (in_dec eq_dec_form a l0) ; simpl in *.
+       assert (l0 = []). apply (nodup_In eq_dec_form) in i. rewrite H in i. inversion i. subst. simpl. inversion i. inversion H.
+    + simpl in * ; intros. destruct (in_dec eq_dec_form a l0) ; simpl in *. destruct (in_dec eq_dec_form a0 l1) ; simpl in *.
+       destruct (in_dec eq_dec_form a (l0 ++ l2)) ; simpl in * ; auto. destruct (in_dec eq_dec_form a0 (l1 ++ l2)) ; simpl in * ; auto.
+       exfalso. apply n. apply in_or_app ; auto. exfalso. apply n. apply in_or_app ; auto.
+       destruct (in_dec eq_dec_form a (l0 ++ l2)). destruct (in_dec eq_dec_form a0 (l1 ++ l2)) ; simpl in * ; auto.
+       apply in_app_or in i1. destruct i1. exfalso ; auto. pose (IHl0 (a0 :: l1) l2). simpl in e.
+       assert (nodup eq_dec_form (l0 ++ l2) = (if in_dec eq_dec_form a0 (l1 ++ l2) then nodup eq_dec_form (l1 ++ l2) else a0 :: nodup eq_dec_form (l1 ++ l2))).
+       apply e. clear e. destruct (in_dec eq_dec_form a0 l1) ; auto. exfalso ; auto. clear e. destruct (in_dec eq_dec_form a0 (l1 ++ l2)).
+       auto. exfalso. apply n0 ; apply in_or_app ; auto. pose (IHl0 (a0 :: l1) l2). simpl in e.
+       assert (nodup eq_dec_form (l0 ++ l2) = (if in_dec eq_dec_form a0 (l1 ++ l2) then nodup eq_dec_form (l1 ++ l2) else a0 :: nodup eq_dec_form (l1 ++ l2))).
+       apply e. clear e. destruct (in_dec eq_dec_form a0 l1) ; auto. exfalso ; auto. clear e. destruct (in_dec eq_dec_form a0 (l1 ++ l2)) ; auto.
+       exfalso ; auto. destruct (in_dec eq_dec_form a0 (l1 ++ l2)) ; simpl in * ; auto. apply in_app_or in i0. destruct i0.
+       exfalso ; auto. exfalso. apply n0. apply in_or_app ; auto. exfalso. apply n0. apply in_or_app ; auto.
+       destruct (in_dec eq_dec_form a0 l1) ; simpl in *. pose (IHl1 l2 H). rewrite e. destruct (in_dec eq_dec_form a0 (l1 ++ l2)) ; auto.
+       exfalso ; apply n0 ; apply in_or_app ; auto. inversion H ; subst.
+       destruct (in_dec eq_dec_form a0 (l0 ++ l2)) ; simpl in *. apply in_app_or in i ; destruct i. exfalso ; auto.
+       destruct (in_dec eq_dec_form a0 (l1 ++ l2)) ; simpl in *. apply in_app_or in i ; destruct i. exfalso ; auto.
+       apply IHl0 ; auto. exfalso ; apply n1 ; apply in_or_app ; auto.
+       destruct (in_dec eq_dec_form a0 (l1 ++ l2)) ; simpl in *. apply in_app_or in i ; destruct i. exfalso ; auto.
+       exfalso ; apply n1 ; apply in_or_app ; auto. rewrite IHl0 with (l1:=l1) ; auto.
+  Qed.
+ +
+  Lemma In_XBoxed_list : forall l A, In A (XBoxed_list (top_boxes l)) -> (In A (top_boxes l) \/ exists B, In B (top_boxes l) /\ B = Box A).
+  Proof.
+  induction l ; intros ; auto. destruct a ; simpl ; simpl in H ; auto.
+  destruct H ; subst. right. exists (Box A) ; auto. destruct H ; subst. left ; auto.
+  apply IHl in H. destruct H. left ; auto. right. firstorder.
+  Qed.
+ +
+  Lemma In_XBoxed_list_gen : forall l A, In A (XBoxed_list l) -> (In A l \/ exists B, In B l /\ B = Box A).
+  Proof.
+  induction l ; intros ; auto. destruct a ; simpl ; simpl in H ; auto.
+  destruct H ; auto. destruct H ; auto. apply IHl in H ; destruct H ; auto. destruct H. destruct H ; subst. right.
+  exists (Box A) ; split ; auto.
+  destruct H ; auto. destruct H ; auto. apply IHl in H ; destruct H ; auto. destruct H. destruct H ; subst. right.
+  exists (Box A) ; split ; auto.
+  destruct H ; auto. destruct H ; auto. apply IHl in H ; destruct H ; auto. destruct H. destruct H ; subst. right.
+  exists (Box A) ; split ; auto.
+  destruct H ; subst ; auto. right. exists (Box A) ; split ; auto. destruct H ; subst ; auto.
+  apply IHl in H. destruct H ; auto. destruct H. destruct H ; subst. right. exists (Box A) ; split ; auto.
+  Qed.
+ +
+  Lemma XBoxed_list_In : forall l A, In (Box A) (top_boxes l) -> In A (XBoxed_list (top_boxes l)).
+  Proof.
+  induction l ; simpl ; intros ; auto. destruct a ; simpl ; simpl in H ; auto. destruct H. inversion H ; subst. auto.
+  apply IHl in H ; auto.
+  Qed.
+ +
+  Lemma XBoxed_list_In_gen : forall l A, In (Box A) l -> In A (XBoxed_list l).
+  Proof.
+  induction l ; simpl ; intros ; auto. destruct a ; simpl ; simpl in H ; auto. 1-3: destruct H ; [inversion H | subst ; auto].
+  destruct H. inversion H ; subst. auto. right. right. apply IHl ; auto.
+  Qed.
+ +
+  Lemma XBoxed_list_In_unfold : forall l A, (exists B, In B (top_boxes l) /\ B = Box A) -> In A (XBoxed_list (top_boxes l)).
+  Proof.
+  induction l ; simpl ; intros ; auto. destruct H. destruct H ; auto.
+  destruct a ; simpl ; simpl in H ; auto. destruct H. destruct H. subst. destruct H.
+  inversion H ; subst ; auto. right. right. apply XBoxed_list_In ; auto.
+  Qed.
+ +
+Theorem critical_nodupseq: forall s, critical_Seq s <-> critical_Seq (nodupseq s).
+Proof.
+intros. split ; intro.
+- intros A HA. destruct s ; simpl in HA. apply H ; simpl. apply in_app_or in HA. apply in_or_app.
+  destruct HA. left ; apply nodup_In in H0 ; auto. right ; apply nodup_In in H0 ; auto.
+- intros A HA. destruct s ; simpl in HA. apply H ; simpl. apply in_app_or in HA. apply in_or_app.
+  destruct HA. left ; apply nodup_In ; auto. right ; apply nodup_In ; auto.
+Qed.
+ +
+Theorem is_init_nodupseq: forall s, (is_init s -> is_init (nodupseq s)) * (is_init (nodupseq s) -> is_init s).
+Proof.
+intros. split ; intro.
+- destruct X. destruct s0.
+  + inversion i ; subst. unfold nodupseq ; simpl. left. left.
+     assert (InT (# P) (nodup eq_dec_form (Γ0 ++ # P :: Γ1))). apply In_InT. apply nodup_In.
+     apply in_or_app ; right ; apply in_eq.
+     assert (InT (# P) (nodup eq_dec_form (Δ0 ++ # P :: Δ1))). apply In_InT. apply nodup_In.
+     apply in_or_app ; right ; apply in_eq.
+     apply InT_split in H. destruct H. destruct s. rewrite e.
+     apply InT_split in H0. destruct H0. destruct s. rewrite e0.
+     apply IdPRule_I.
+  + inversion i ; subst. unfold nodupseq ; simpl. left. right.
+     assert (InT (Box A) (nodup eq_dec_form (Γ0 ++ Box A :: Γ1))). apply In_InT. apply nodup_In.
+     apply in_or_app ; right ; apply in_eq.
+     assert (InT (Box A) (nodup eq_dec_form (Δ0 ++ Box A:: Δ1))). apply In_InT. apply nodup_In.
+     apply in_or_app ; right ; apply in_eq.
+     apply InT_split in H. destruct H. destruct s. rewrite e.
+     apply InT_split in H0. destruct H0. destruct s. rewrite e0.
+     apply IdBRule_I.
+  + inversion b ; subst. unfold nodupseq ; simpl. right.
+     assert (InT Bot (nodup eq_dec_form (Γ0 ++ Bot :: Γ1))). apply In_InT. apply nodup_In.
+     apply in_or_app ; right ; apply in_eq.
+     apply InT_split in H. destruct H. destruct s. rewrite e.
+     apply BotLRule_I.
+- destruct X. destruct s. destruct s0.
+  + inversion i ; subst. left. left.
+     assert (InT (# P) l). apply In_InT. rewrite <- (nodup_In eq_dec_form). rewrite <- H.
+     apply in_or_app ; right ; apply in_eq.
+     assert (InT (# P) l0). apply In_InT. rewrite <- (nodup_In eq_dec_form). rewrite <- H1.
+     apply in_or_app ; right ; apply in_eq.
+     apply InT_split in H0. destruct H0. destruct s. rewrite e.
+     apply InT_split in H2. destruct H2. destruct s. rewrite e0.
+     apply IdPRule_I.
+  + inversion i ; subst. left. right.
+     assert (InT (Box A) l). apply In_InT. rewrite <- (nodup_In eq_dec_form). rewrite <- H.
+     apply in_or_app ; right ; apply in_eq.
+     assert (InT (Box A) l0). apply In_InT. rewrite <- (nodup_In eq_dec_form). rewrite <- H1.
+     apply in_or_app ; right ; apply in_eq.
+     apply InT_split in H0. destruct H0. destruct s. rewrite e.
+     apply InT_split in H2. destruct H2. destruct s. rewrite e0.
+     apply IdBRule_I.
+  + inversion b ; subst. destruct s ; simpl in *. right.
+     assert (InT Bot l). apply In_InT. rewrite <- (nodup_In eq_dec_form). rewrite <- H.
+     apply in_or_app ; right ; apply in_eq.
+     apply InT_split in H0. destruct H0. destruct s. rewrite e.
+     apply BotLRule_I.
+Qed.
+ +
+  Lemma incl_nodup_subform_boxesLF : forall l,
+              (incl (subform_boxesLF l) (subform_boxesLF (nodup eq_dec_form l))) *
+              (incl (subform_boxesLF (nodup eq_dec_form l)) (subform_boxesLF l)).
+  Proof.
+  induction l ; simpl; intuition auto with *.
+  - intros A HA. destruct (in_dec eq_dec_form a l). apply a0. apply in_app_or in HA.
+    destruct HA. apply In_incl_subform_boxes with (A:=a) ; auto. apply In_remove_list_In_list in H ; auto.
+    simpl. apply in_app_or in HA. destruct HA. apply in_or_app ; auto. apply In_remove_list_In_list_not_In_remove_list in H.
+    destruct H. apply in_or_app ; right. apply not_removed_remove_list ; auto.
+  - intros A HA. destruct (in_dec eq_dec_form a l). apply b in HA. apply remove_list_is_in ; auto.
+    simpl in HA. apply in_app_or in HA. destruct HA. apply in_or_app ; auto. apply In_remove_list_In_list_not_In_remove_list in H.
+    destruct H. apply b in H. apply remove_list_is_in ; auto.
+  Qed.
+ +
+  Lemma incl_nodupseq_subform_boxesS : forall s,
+              (incl (subform_boxesS s) (subform_boxesS (nodupseq s))) *
+              (incl (subform_boxesS (nodupseq s)) (subform_boxesS s)).
+  Proof.
+  destruct s. split ; intros A HA ; unfold subform_boxesS in * ; simpl in *.
+  - apply in_app_or in HA ; destruct HA. apply in_or_app ; left.
+    pose (incl_nodup_subform_boxesLF l). destruct p. auto.
+    apply In_remove_list_In_list_not_In_remove_list in H. destruct H.
+    apply remove_list_is_in ; auto. pose (incl_nodup_subform_boxesLF l0). destruct p. auto.
+  - apply in_app_or in HA ; destruct HA. apply in_or_app ; left.
+    pose (incl_nodup_subform_boxesLF l). destruct p. auto.
+    apply In_remove_list_In_list_not_In_remove_list in H. destruct H.
+    apply remove_list_is_in ; auto. pose (incl_nodup_subform_boxesLF l0). destruct p. auto.
+  Qed.
+ +
+  Lemma incl_nodup_top_boxes : forall l,
+              (incl (top_boxes l) (top_boxes (nodup eq_dec_form l))) *
+              (incl (top_boxes (nodup eq_dec_form l)) (top_boxes l)).
+  Proof.
+  induction l ; simpl ; intuition auto with *.
+  - intros A HA. destruct (in_dec eq_dec_form a l). apply a0. destruct a ; auto. inversion HA ; subst ; auto.
+    apply is_box_in_top_boxes ; auto. eexists ; auto.
+    simpl. destruct a ; simpl in * ; auto. destruct HA ; auto.
+  - intros A HA. destruct (in_dec eq_dec_form a l). apply b in HA. destruct a ; auto. apply in_cons ; auto.
+    destruct a ; simpl in * ; auto. destruct HA ; auto.
+  Qed.
+ +
+  Lemma ub_nodupseq : forall s, length (usable_boxes s) = length (usable_boxes (nodupseq s)).
+  Proof.
+  intros. destruct s. unfold usable_boxes ; simpl.
+  assert (J1: NoDup (subform_boxesS (l, l0))). apply NoDup_subform_boxesS.
+  assert (J2: NoDup (subform_boxesS (nodupseq (l, l0)))). apply NoDup_subform_boxesS.
+  assert (J3: incl (subform_boxesS (l, l0)) (subform_boxesS (nodupseq (l, l0)))).
+  apply incl_nodupseq_subform_boxesS.
+  pose (remove_list_incr_decr2 _ _ (top_boxes (nodup eq_dec_form l)) J1 J2 J3).
+  assert (J4: incl (top_boxes (nodup eq_dec_form l)) (top_boxes l)). apply incl_nodup_top_boxes.
+  pose (remove_list_incr_decr3 (subform_boxesS (l, l0)) _ _ J4).
+  assert (J5: incl (subform_boxesS (nodupseq (l, l0))) (subform_boxesS (l, l0))).
+  apply incl_nodupseq_subform_boxesS.
+  pose (remove_list_incr_decr2 _ _ (top_boxes l) J2 J1 J5).
+  assert (J6: incl (top_boxes l) (top_boxes (nodup eq_dec_form l))). apply incl_nodup_top_boxes.
+  pose (remove_list_incr_decr3 (subform_boxesS (nodupseq (l, l0))) _ _ J6).
+  lia.
+  Qed.
+ +
+  Lemma n_imp_subformLF_nodup : forall l, n_imp_subformLF (nodup eq_dec_form l) <= n_imp_subformLF l.
+  Proof.
+  induction l ; simpl ; intuition. destruct (in_dec eq_dec_form a l) ; simpl ; lia.
+  Qed.
+ +
+  Lemma n_imp_subformS_nodupseq : forall s, n_imp_subformS (nodupseq s) <= n_imp_subformS s.
+  Proof.
+  intro s. destruct s. unfold n_imp_subformS ; simpl. pose (n_imp_subformLF_nodup l).
+  pose (n_imp_subformLF_nodup l0). lia.
+  Qed.
+ +
+Theorem LexSeq_nodupseq: forall s0 s1, LexSeq s0 (nodupseq s1) -> LexSeq s0 s1.
+Proof.
+pose (d:=LexSeq_ind (fun x => forall s1, LexSeq x (nodupseq s1) -> LexSeq x s1)).
+apply d. clear d. intros s0 IH s1 H. inversion H ; subst ; intuition.
+- rewrite <- ub_nodupseq in H3. unfold LexSeq. unfold less_thanS. unfold GLS_termination_measure.measure.
+  rewrite H3. apply DLW_wf_lex.lex_skip. apply DLW_wf_lex.lex_cons ; auto. inversion H1 ; subst.
+  inversion H2. apply Nat.lt_le_trans with (m:=n_imp_subformS (nodupseq s1)) ; auto.
+  apply n_imp_subformS_nodupseq.
+- rewrite <- ub_nodupseq in H5. unfold LexSeq. unfold measure.
+  unfold less_thanS. unfold GLS_termination_measure.measure. apply DLW_wf_lex.lex_cons ; auto.
+Qed.
+ +
+Theorem LexSeq_nodupseq_case: forall s, LexSeq (nodupseq s) s +
+  ((n_imp_subformS (nodupseq s) = n_imp_subformS s) * (length (usable_boxes s) = length (usable_boxes (nodupseq s)))).
+Proof.
+intro s. pose (ub_nodupseq s). pose (n_imp_subformS_nodupseq s).
+unfold LexSeq. unfold less_thanS ;unfold GLS_termination_measure.measure. rewrite <- e.
+destruct (Compare_dec.lt_dec (n_imp_subformS (nodupseq s)) (n_imp_subformS s)).
+- left. apply DLW_wf_lex.lex_skip. apply DLW_wf_lex.lex_cons ; auto.
+- right. split ; auto. lia.
+Qed.
+ +
+Theorem fixpoint_nodupseq: forall s, nodupseq s = nodupseq (nodupseq s).
+Proof.
+unfold nodupseq. intros ; simpl.
+assert (nodup eq_dec_form (fst s) = nodup eq_dec_form (nodup eq_dec_form (fst s))).
+symmetry. apply nodup_fixed_point ; auto. apply NoDup_nodup.
+assert (nodup eq_dec_form (snd s) = nodup eq_dec_form (nodup eq_dec_form (snd s))).
+symmetry. apply nodup_fixed_point ; auto. apply NoDup_nodup. rewrite <- H ; rewrite <- H0 ; auto.
+Qed.
+ +
+Theorem nodup_nil : forall (l : list MPropF), l = nil <-> nodup eq_dec_form l = nil.
+Proof.
+induction l ; intuition ; simpl. inversion H1. simpl in H1. destruct (in_dec eq_dec_form a l) ; auto. apply H0 in H1.
+exfalso. rewrite H1 in i ; apply in_nil in i ; auto. inversion H1.
+Qed.
+ +
+Theorem nodup_top_boxes : forall l, nodup eq_dec_form (top_boxes l) = top_boxes (nodup eq_dec_form l).
+Proof.
+induction l ; intuition ; simpl. destruct a as [n | | |]; simpl ; auto.
+destruct (in_dec eq_dec_form # n l) ; auto. destruct (in_dec eq_dec_form l) ; auto.
+destruct (in_dec eq_dec_form (a1 --> a2) l) ; auto.
+destruct (in_dec eq_dec_form (Box a) l) ; destruct (in_dec eq_dec_form (Box a) (top_boxes l)) ; auto.
+exfalso. apply n. apply is_box_in_top_boxes ; auto. eexists ; auto.
+exfalso. apply in_top_boxes in i. destruct i. destruct s. destruct s. destruct p ; subst ; auto.
apply n. inversion e ; subst. apply in_or_app ; right ; apply in_eq.
+simpl ; rewrite IHl ; auto.
+Qed.
+ +
+Theorem nodup_XBoxed_list : forall l, nodup eq_dec_form (XBoxed_list (nodup eq_dec_form l)) = nodup eq_dec_form (XBoxed_list l).
+Proof.
+induction l ; intuition ; simpl. destruct a as [n | | |]; simpl ; auto.
+- destruct (eq_dec_form # n # n). destruct (in_dec eq_dec_form # n l).
+  destruct (in_dec eq_dec_form # n (XBoxed_list l)) ; simpl ; auto. exfalso. apply n0.
+  apply list_preserv_XBoxed_list ; auto. destruct (in_dec eq_dec_form # n) ; auto ; simpl.
+  destruct (eq_dec_form # n # n) ; auto. destruct (in_dec eq_dec_form # n (XBoxed_list (nodup eq_dec_form l))) ; simpl ; auto.
+  exfalso. apply n1. apply In_XBoxed_list_gen in i. destruct i ; auto. exfalso ; auto. destruct H. destruct H ; subst.
+  apply XBoxed_list_In_gen. apply nodup_In ; auto. exfalso ; auto.
+  destruct (eq_dec_form # n # n) ; simpl ; auto. destruct (in_dec eq_dec_form # n (XBoxed_list (nodup eq_dec_form l))) ; simpl ; auto.
+  exfalso. apply In_XBoxed_list_gen in i. destruct i. apply n0. apply nodup_In in H ; auto.
+  destruct H. destruct H ; subst. apply n1. apply XBoxed_list_In_gen. apply nodup_In in H ; auto.
+  rewrite IHl ; auto. destruct (in_dec eq_dec_form # n (XBoxed_list (nodup eq_dec_form l))) ; simpl ; auto.
+  exfalso. apply n1. apply In_XBoxed_list_gen in i. destruct i. apply nodup_In in H. apply list_preserv_XBoxed_list ; auto.
+  destruct H. destruct H ; subst. apply XBoxed_list_In_gen. apply nodup_In in H ; auto.
+  exfalso ; auto. exfalso ; auto.
+- destruct (eq_dec_form Bot Bot). destruct (in_dec eq_dec_form Bot l).
+  destruct (in_dec eq_dec_form Bot (XBoxed_list l)) ; simpl ; auto. exfalso. apply n.
+  apply list_preserv_XBoxed_list ; auto. destruct (in_dec eq_dec_form Bot) ; auto ; simpl.
+  destruct (eq_dec_form Bot Bot) ; auto. destruct (in_dec eq_dec_form Bot (XBoxed_list (nodup eq_dec_form l))) ; simpl ; auto.
+  exfalso. apply n0. apply In_XBoxed_list_gen in i. destruct i ; auto. exfalso ; auto. destruct H. destruct H ; subst.
+  apply XBoxed_list_In_gen. apply nodup_In ; auto. exfalso ; auto.
+  destruct (eq_dec_form Bot Bot) ; simpl ; auto. destruct (in_dec eq_dec_form Bot (XBoxed_list (nodup eq_dec_form l))) ; simpl ; auto.
+  exfalso. apply In_XBoxed_list_gen in i. destruct i. apply n. apply nodup_In in H ; auto.
+  destruct H. destruct H ; subst. apply n0. apply XBoxed_list_In_gen. apply nodup_In in H ; auto.
+  rewrite IHl ; auto. destruct (in_dec eq_dec_form Bot (XBoxed_list (nodup eq_dec_form l))) ; simpl ; auto.
+  exfalso. apply n0. apply In_XBoxed_list_gen in i. destruct i. apply nodup_In in H. apply list_preserv_XBoxed_list ; auto.
+  destruct H. destruct H ; subst. apply XBoxed_list_In_gen. apply nodup_In in H ; auto.
+  exfalso ; auto. exfalso ; auto.
+- destruct (eq_dec_form (a1 --> a2) (a1 --> a2)). destruct (in_dec eq_dec_form (a1 --> a2) l).
+  destruct (in_dec eq_dec_form (a1 --> a2) (XBoxed_list l)) ; simpl ; auto. exfalso. apply n.
+  apply list_preserv_XBoxed_list ; auto. destruct (in_dec eq_dec_form (a1 --> a2)) ; auto ; simpl.
+  destruct (eq_dec_form (a1 --> a2) (a1 --> a2)) ; auto. destruct (in_dec eq_dec_form (a1 --> a2) (XBoxed_list (nodup eq_dec_form l))) ; simpl ; auto.
+  exfalso. apply n0. apply In_XBoxed_list_gen in i. destruct i ; auto. exfalso ; auto. destruct H. destruct H ; subst.
+  apply XBoxed_list_In_gen. apply nodup_In ; auto. exfalso ; auto.
+  destruct (eq_dec_form (a1 --> a2) (a1 --> a2)) ; simpl ; auto. destruct (in_dec eq_dec_form (a1 --> a2) (XBoxed_list (nodup eq_dec_form l))) ; simpl ; auto.
+  exfalso. apply In_XBoxed_list_gen in i. destruct i. apply n. apply nodup_In in H ; auto.
+  destruct H. destruct H ; subst. apply n0. apply XBoxed_list_In_gen. apply nodup_In in H ; auto.
+  rewrite IHl ; auto. destruct (in_dec eq_dec_form (a1 --> a2) (XBoxed_list (nodup eq_dec_form l))) ; simpl ; auto.
+  exfalso. apply n0. apply In_XBoxed_list_gen in i. destruct i. apply nodup_In in H. apply list_preserv_XBoxed_list ; auto.
+  destruct H. destruct H ; subst. apply XBoxed_list_In_gen. apply nodup_In in H ; auto.
+  exfalso ; auto. exfalso ; auto.
+- destruct (in_dec eq_dec_form (Box a)). destruct (eq_dec_form (Box a) a). exfalso.
+  assert (size (Box a) = size a). rewrite e ; auto. destruct a ; simpl in H ; lia.
+  destruct (in_dec eq_dec_form a (XBoxed_list l)) ; simpl ; auto. destruct (in_dec eq_dec_form (Box a) (XBoxed_list l)) ; simpl ; auto.
+  exfalso. apply n0. apply list_preserv_XBoxed_list ; auto. exfalso. apply n0. apply XBoxed_list_In_gen ; auto.
+  destruct (eq_dec_form (Box a) a). assert (size (Box a) = size a). rewrite e ; auto. destruct a ; simpl in H ; lia.
+  destruct (in_dec eq_dec_form a (XBoxed_list l)) ; simpl ; auto. destruct ( eq_dec_form (Box a) a).
+  assert (size (Box a) = size a). rewrite e ; auto. destruct a ; simpl in H ; lia.
+  destruct (in_dec eq_dec_form a (XBoxed_list (nodup eq_dec_form l))).
+  destruct (in_dec eq_dec_form (Box a) (XBoxed_list (nodup eq_dec_form l))) ; simpl ; auto.
+  destruct (in_dec eq_dec_form (Box a) (XBoxed_list l)) ; simpl ; auto. exfalso. apply n2.
+  apply In_XBoxed_list_gen in i1. destruct i1 ; auto. apply list_preserv_XBoxed_list ; apply nodup_In in H ; auto.
+  destruct H. destruct H ; subst. apply XBoxed_list_In_gen. apply nodup_In in H ; auto.
+  destruct (in_dec eq_dec_form (Box a) (XBoxed_list l)) ; simpl ; auto. 2: rewrite IHl ; auto.
+  exfalso. apply n2. apply In_XBoxed_list_gen in i1. destruct i1 ; auto. apply list_preserv_XBoxed_list ; apply nodup_In ; auto.
+  destruct H. destruct H ; subst. apply XBoxed_list_In_gen. apply nodup_In ; auto.
+  exfalso. apply n2. apply In_XBoxed_list_gen in i. destruct i ; auto. apply list_preserv_XBoxed_list ; apply nodup_In ; auto.
+  destruct H. destruct H ; subst. apply XBoxed_list_In_gen. apply nodup_In ; auto.
+  destruct (eq_dec_form (Box a) a). assert (size (Box a) = size a). rewrite e ; auto. destruct a ; simpl in H ; lia.
+  destruct (in_dec eq_dec_form a (XBoxed_list (nodup eq_dec_form l))). exfalso.
+  apply n1. apply In_XBoxed_list_gen in i. destruct i ; auto. apply list_preserv_XBoxed_list ; apply nodup_In in H ; auto.
+  destruct H. destruct H ; subst. apply XBoxed_list_In_gen. apply nodup_In in H ; auto.
+  destruct (in_dec eq_dec_form (Box a) (XBoxed_list (nodup eq_dec_form l))) ; simpl ; auto.
+  destruct (in_dec eq_dec_form (Box a) (XBoxed_list l)) ; simpl ; auto. rewrite IHl ; auto.
+  exfalso. apply n4. apply In_XBoxed_list_gen in i. destruct i ; auto. apply list_preserv_XBoxed_list ; apply nodup_In in H ; auto.
+  destruct H. destruct H ; subst. apply XBoxed_list_In_gen. apply nodup_In in H ; auto.
+  destruct (in_dec eq_dec_form (Box a) (XBoxed_list l)) ; simpl ; auto. 2: rewrite IHl ; auto.
+  exfalso. apply n4. apply In_XBoxed_list_gen in i. destruct i ; auto. apply list_preserv_XBoxed_list ; apply nodup_In ; auto.
+  destruct H. destruct H ; subst. apply XBoxed_list_In_gen. apply nodup_In ; auto.
+Qed.
+ +
+Theorem fixpoint_nodup: forall l, nodup eq_dec_form l = nodup eq_dec_form (nodup eq_dec_form l).
+Proof.
+intros ; simpl. symmetry. apply nodup_fixed_point ; auto. apply NoDup_nodup.
+Qed.
+ +
+Theorem nodupseq_GLR_prems : forall s0 s1, InT s1 (GLR_prems (nodupseq s0)) ->
+        existsT2 s2, (nodup eq_dec_form (fst s1) = nodup eq_dec_form (fst s2)) * (snd s1 = snd s2) * InT s2 (GLR_prems s0).
+Proof.
+intros s0 s1 H. unfold GLR_prems in *. destruct (finite_GLR_premises_of_S (nodupseq s0)) ; simpl in *.
+apply InT_flatten_list_InT_elem in H. destruct H. destruct p0. apply p in i0. inversion i0 ; subst.
+destruct s0 ; simpl in *. unfold nodupseq in * ; subst ; simpl in *. inversion i ; subst. 2: inversion H0. simpl.
+assert (InT (Box A) l0). apply In_InT. apply (nodup_In eq_dec_form). rewrite <- H2. apply in_or_app ; right ; apply in_eq.
+apply InT_split in H. destruct H. destruct s. subst.
+exists (XBoxed_list (top_boxes l) ++ [Box A], [A]). repeat split ; simpl ; auto.
+pose (nobox_gen_ext_top_boxes_identity X). rewrite e ; auto. apply nodup_app.
+rewrite <- nodup_top_boxes. rewrite nodup_XBoxed_list. auto.
+ +
+apply InT_trans_flatten_list with (bs:=[(XBoxed_list (top_boxes l) ++ [Box A], [A])]). apply InT_eq.
+apply (@GLR_help2 (XBoxed_list (top_boxes l) ++ [Box A], [A]) (l, x0 ++ Box A :: x1)).
+apply GLRRule_I. intros B HB. apply in_top_boxes in HB. destruct HB as [x2 [x3 [x4 p1]]].
+destruct p1 ; subst. eexists ; auto. apply top_boxes_nobox_gen_ext.
+Qed.
+ +
+  Theorem incl_ctr_L_hpadm : forall Γ0 Γ1 Δ (D: GLS_prv (Γ0 ++ Γ1, Δ)), incl Γ0 Γ1 ->
+          existsT2 (D0: GLS_prv (Γ1, Δ)), derrec_height D0 <= derrec_height D.
+  Proof.
+  induction Γ0 ; simpl ; intros ; intuition. exists D ; auto.
+  assert (InT a Γ1). apply In_InT. apply H. apply in_eq.
+  apply InT_split in H0. destruct H0. destruct s ; subst.
+  assert (J1: derrec_height D = derrec_height D). auto.
+  assert (J2: ctr_L a (a :: Γ0 ++ x ++ a :: x0, Δ) (a :: Γ0 ++ x ++ x0, Δ)).
+  pose (ctr_LI a [] (Γ0 ++ x) x0). simpl in c ; repeat rewrite <- app_assoc in c ; apply c.
+  pose (GLS_hpadm_ctr_L _ J1 J2). destruct s.
+  assert (J3: derrec_height x1 = derrec_height x1). auto.
+  assert (J4: list_exch_L (a :: Γ0 ++ x ++ x0, Δ) (Γ0 ++ x ++ a :: x0, Δ)).
+  pose (list_exch_LI [] [a] (Γ0 ++ x) [] x0). simpl in l0. repeat rewrite <- app_assoc in l0; auto.
+  pose (GLS_hpadm_list_exch_L x1 J3 J4). destruct s.
+  pose (IHΓ0 (x ++ a :: x0) Δ x2). destruct s.
+  intros A HA. apply H. apply in_cons ; auto.
+  exists x3. lia.
+  Qed.
+ +
+  Theorem incl_ctr_L : forall Γ0 Γ1 Δ, incl Γ0 Γ1 -> GLS_prv (Γ0 ++ Γ1, Δ) -> GLS_prv (Γ1, Δ).
+  Proof.
+  intros. pose (incl_ctr_L_hpadm _ _ _ X H). destruct s ; auto.
+  Qed.
+ +
+  Theorem incl_ctr_R_hpadm : forall Γ Δ0 Δ1 (D: GLS_prv (Γ, Δ0 ++ Δ1)), incl Δ0 Δ1 ->
+        existsT2 (D0: GLS_prv (Γ, Δ1)), derrec_height D0 <= derrec_height D.
+  Proof.
+  intros Γ Δ0. revert Γ. induction Δ0 ; simpl ; intros ; intuition. exists D ; auto.
+  assert (InT a Δ1). apply In_InT. apply H. apply in_eq.
+  apply InT_split in H0. destruct H0. destruct s ; subst.
+  assert (J1: derrec_height D = derrec_height D). auto.
+  assert (J2: ctr_R a (Γ, a :: Δ0 ++ x ++ a :: x0) (Γ, a :: Δ0 ++ x ++ x0)).
+  pose (ctr_RI a Γ [] (Δ0 ++ x) x0). simpl in c ; repeat rewrite <- app_assoc in c ; apply c.
+  pose (GLS_hpadm_ctr_R _ J1 J2). destruct s.
+  assert (J3: derrec_height x1 = derrec_height x1). auto.
+  assert (J4: list_exch_R (Γ, a :: Δ0 ++ x ++ x0) (Γ, Δ0 ++ x ++ a :: x0)).
+  pose (list_exch_RI Γ [] [a] (Δ0 ++ x) [] x0). simpl in l0. repeat rewrite <- app_assoc in l0; auto.
+  pose (GLS_hpadm_list_exch_R x1 J3 J4). destruct s.
+  pose (IHΔ0 Γ (x ++ a :: x0) x2). destruct s.
+  intros A HA. apply H. apply in_cons ; auto.
+  exists x3. lia.
+  Qed.
+ +
+  Theorem incl_ctr_R : forall Γ Δ0 Δ1, incl Δ0 Δ1 -> GLS_prv (Γ, Δ0 ++ Δ1) -> GLS_prv (Γ, Δ1).
+  Proof.
+  intros. pose (incl_ctr_R_hpadm _ _ _ X H). destruct s ; auto.
+  Qed.
+ +
+  Lemma nodup_id: forall l,
+    existsT2 ln, (existsT2 l2, (PermutationT l (l2 ++ ln)) * (incl l2 ln)) *
+                          (PermutationT ln (nodup eq_dec_form l)).
+  Proof.
+  induction l ; simpl ; intros ; intuition.
+  - exists []. split ; auto. 2: apply Permutation_PermutationT ; apply Permutation_refl. exists [].
+    rewrite app_nil_r. split ; auto. apply Permutation_PermutationT ; apply Permutation_refl.
+    intro ; auto.
+  - destruct IHl. destruct p. destruct s. destruct p0. destruct (in_dec eq_dec_form a l) ; simpl ; auto.
+    exists x. split ; auto. exists (a :: x0). simpl. split. apply Permutation_PermutationT. apply perm_skip.
+    apply Permutation_PermutationT ; auto. intros A HA. inversion HA ; subst ; auto.
+    apply Permutation_PermutationT in p0. pose (Permutation_in _ p0 i0). apply in_app_or in i1 ; destruct i1 ; auto.
+    exists (a :: x). split. exists x0. split. apply Permutation_PermutationT. apply Permutation_cons_app. apply Permutation_PermutationT ; auto.
+    intros A HA. apply in_cons ; auto.
+    apply Permutation_PermutationT. apply perm_skip. apply Permutation_PermutationT ; auto.
+  Qed.
+ +
+  Lemma nodupseq_id: forall s,
+    existsT2 sn, (existsT2 LHS RHS, (PermutationTS s (LHS ++ fst sn, RHS ++ snd sn)) * (incl LHS (fst sn)) * (incl RHS (snd sn))) *
+                          (PermutationTS sn (nodupseq s)).
+  Proof.
+  intros. unfold nodupseq in *.
+  destruct (nodup_id (fst s)). destruct p. destruct s0. destruct p0.
+  destruct (nodup_id (snd s)). destruct p1. destruct s0. destruct p2.
+  unfold PermutationTS ; simpl. exists (x, x1) ; simpl. repeat split ; auto.
+  exists x0. exists x2. split ; auto.
+  Qed.
+ +
+Lemma nodupseq_hpadm_prv_LR : forall s (D0: GLS_prv s), existsT2 (D1: GLS_prv (nodupseq s)), derrec_height D1 <= derrec_height D0.
+Proof.
+intros s D0.
+destruct (nodupseq_id s). destruct p. destruct s0. destruct s0. destruct p0. destruct p0.
+pose (PermutationTS_prv_hpadm _ D0 _ p0). destruct s0.
+pose (incl_ctr_L_hpadm x0 (fst x) (x1 ++ snd x) x2 i0). destruct s0.
+pose (incl_ctr_R_hpadm (fst x) x1 (snd x) x3 i). destruct s0. destruct x ; simpl in *.
+pose (PermutationTS_prv_hpadm _ x4 _ p). destruct s0. exists x ; lia.
+Qed.
+ +
+Lemma nodupseq_hpadm_prv_RL : forall s (D0: GLS_prv (nodupseq s)), existsT2 (D1: GLS_prv s), derrec_height D1 <= derrec_height D0.
+Proof.
+intros s D0.
+destruct (nodupseq_id s). destruct p. destruct s0. destruct s0. destruct p0. destruct p0.
+pose (PermutationTS_prv_hpadm _ D0 _ (PermutationTS_sym _ _ p)). destruct s0. destruct x ; simpl in *.
+assert (derrec_height x2 = derrec_height x2). auto.
+pose (@GLS_list_wkn_L _ [] l0 _ x2 H). simpl in s0. destruct (s0 x0).
+assert (derrec_height x = derrec_height x). auto.
+pose (@GLS_list_wkn_R _ _ [] l1 x H0). simpl in s1. destruct (s1 x1).
+apply PermutationTS_sym in p0. pose (PermutationTS_prv_hpadm _ x3 _ p0). destruct s2. exists x4 ; lia.
+Qed.
+ +
+Lemma nodupseq_prv : forall s, ((GLS_prv s) -> (GLS_prv (nodupseq s))) * ((GLS_prv (nodupseq s)) -> (GLS_prv s)).
+Proof.
+intros s. split ; intro.
+- destruct (nodupseq_id s). destruct p. destruct s0. destruct s0. destruct p0. destruct p0.
+  apply (PermutationTS_prv _ _ p). destruct x. pose (incl_ctr_L x0 l). apply g ; auto.
+  pose (incl_ctr_R (x0 ++ l) x1 l0). apply g0 ; auto. simpl in p0. apply (PermutationTS_prv _ _ p0) ; auto.
+- destruct (nodupseq_id s). destruct p. destruct s0. destruct s0. destruct p0. destruct p0. apply PermutationTS_sym in p0.
+  apply (PermutationTS_prv _ _ p0). pose (GLS_prv_list_wkn_L [] (fst x)). simpl in g. apply g.
+  epose (@GLS_prv_list_wkn_R _ [] (snd x)). simpl in g0. apply g0. destruct x ; simpl in *.
+  apply PermutationTS_sym in p. apply (PermutationTS_prv _ _ p) ; auto.
+Qed.
+ +
+Lemma nodupseq_prv_hpadm_LR : forall s (D0: GLS_prv s), existsT2 (D1: GLS_prv (nodupseq s)), derrec_height D1 <= derrec_height D0.
+Proof.
+intros s D0.
+destruct (nodupseq_id s). destruct p. destruct s0. destruct s0. destruct p0. destruct p0.
+pose (PermutationTS_prv_hpadm _ D0 _ p0). destruct s0.
+pose (incl_ctr_L_hpadm _ _ _ x2 i0). destruct s0.
+pose (incl_ctr_R_hpadm _ _ _ x3 i). destruct s0. destruct x.
+pose (PermutationTS_prv_hpadm _ x4 _ p). destruct s0. exists x. lia.
+Qed.
+ +
+Lemma nodupseq_prv_hpadm_RL : forall s (D0: GLS_prv (nodupseq s)), existsT2 (D1: GLS_prv s), derrec_height D1 <= derrec_height D0.
+Proof.
+intros s D0.
+destruct (nodupseq_id s). destruct p. destruct s0. destruct s0. destruct p0. destruct p0. apply PermutationTS_sym in p0.
+pose (PermutationTS_prv_hpadm _ D0 _ (PermutationTS_sym _ _ p)). destruct s0.
+assert (derrec_height x2 = derrec_height x2). auto. destruct x ; simpl in *.
+pose (GLS_list_wkn_L [] l0 x2 H). simpl in s0. destruct (s0 x0).
+assert (derrec_height x = derrec_height x). auto.
+pose (GLS_list_wkn_R [] l1 x H0). simpl in s1. destruct (s1 x1).
+pose (PermutationTS_prv_hpadm _ x3 _ p0). destruct s2. exists x4. lia.
+Qed.
+ +
+Lemma remove_Permutation : forall l a, In a l -> Permutation (nodup eq_dec_form l) (nodup eq_dec_form (a :: remove eq_dec_form a l)).
+  Proof.
+  induction l ; simpl ; intros ; intuition ; subst.
+  - destruct (in_dec eq_dec_form a0 l) ; simpl ; auto. destruct (eq_dec_form a0 a0) ; auto.
+    destruct (in_dec eq_dec_form a0 (remove eq_dec_form a0 l)) ; simpl ; auto. exfalso.
+    apply remove_not_in_anymore in i0 ; auto. apply IHl in i. simpl in i. destruct (in_dec eq_dec_form a0 (remove eq_dec_form a0 l)) ; auto.
+    exfalso ; auto. exfalso ; auto. destruct (eq_dec_form a0 a0) ; subst. 2: exfalso ; auto.
+    destruct (in_dec eq_dec_form a0 (remove eq_dec_form a0 l)) ; simpl ; auto. exfalso.
+    apply remove_not_in_anymore in i ; auto. apply perm_skip.
+    assert ((remove eq_dec_form a0 l) = l). apply notin_remove ; auto. rewrite H ; apply Permutation_refl.
+  - destruct (in_dec eq_dec_form a l) ; simpl ; auto. destruct (eq_dec_form a0 a) ; auto ; subst.
+    destruct (in_dec eq_dec_form a (remove eq_dec_form a l)) ; simpl ; auto. exfalso.
+    apply remove_not_in_anymore in i0 ; auto. apply IHl in i. simpl in i. destruct (in_dec eq_dec_form a (remove eq_dec_form a l)) ; auto.
+    exfalso ; auto. destruct (in_dec eq_dec_form a0 (a :: remove eq_dec_form a0 l)). inversion i0 ;subst.
+    exfalso ; auto. exfalso. apply remove_not_in_anymore in H ; auto. simpl.
+    destruct (in_dec eq_dec_form a (remove eq_dec_form a0 l)) ; simpl ; auto. apply IHl in H0.
+    simpl in H0. destruct (in_dec eq_dec_form a0 (remove eq_dec_form a0 l)) ; auto. exfalso.
+    apply remove_not_in_anymore in i1 ; auto. exfalso. apply n1. apply in_not_touched_remove ; auto.
+    destruct (eq_dec_form a0 a) ; subst. exfalso ; auto. destruct (in_dec eq_dec_form a0 (a :: remove eq_dec_form a0 l)) ; auto.
+    inversion i ; auto. exfalso ; subst ; auto. exfalso. apply remove_not_in_anymore in H ; auto.
+    simpl. destruct (in_dec eq_dec_form a (remove eq_dec_form a0 l)). exfalso.
+    apply n. apply In_remove_In_list in i ; auto.
+    apply Permutation_trans with (l':=(a :: a0 :: nodup eq_dec_form (remove eq_dec_form a0 l))).
+    apply perm_skip. apply IHl in H0. simpl in H0. destruct (in_dec eq_dec_form a0 (remove eq_dec_form a0 l)) ; auto.
+    exfalso. apply remove_not_in_anymore in i ; auto. apply perm_swap.
+  Qed.
+ +
+  Lemma incl_id: forall l0 l1, (incl l0 l1) ->
+    existsT2 l0n, (existsT2 l2, (PermutationT (nodup eq_dec_form l1) (l2 ++ l0n))) *
+                          (PermutationT l0n (nodup eq_dec_form l0)).
+  Proof.
+  induction l0 ; simpl ; intros ; intuition.
+  - exists []. split ; auto. 2: apply Permutation_PermutationT ; apply Permutation_refl.
+    exists (nodup eq_dec_form l1). rewrite app_nil_r. apply Permutation_PermutationT ; apply Permutation_refl.
+  - assert (incl l0 l1). intros A HA. apply H. apply in_cons ; auto. destruct (in_dec eq_dec_form a l0).
+    apply IHl0 in H0 ; auto. assert (incl l0 (remove eq_dec_form a l1)). intros A HA. apply in_not_touched_remove.
+    apply H0 ; auto. intro ; subst ; auto. apply IHl0 in H1. destruct H1. destruct p. destruct s. exists (a::x) ; split.
+    2: apply Permutation_PermutationT ; apply Permutation_PermutationT in p ; apply perm_skip ; auto.
+    exists x0. apply Permutation_PermutationT. apply Permutation_PermutationT in p0.
+    pose (Permutation_middle x0 x a). apply Permutation_trans with (l':=a :: x0 ++ x) ; auto.
+    apply Permutation_trans with (l':=nodup eq_dec_form (a :: remove eq_dec_form a l1)) ; auto.
+    apply remove_Permutation. apply H. apply in_eq.
+    simpl. destruct (in_dec eq_dec_form a (remove eq_dec_form a l1)). exfalso. apply remove_not_in_anymore in i ; auto.
+    apply perm_skip ; auto.
+  Qed.
+ +
+  Lemma incl_idS: forall s0 s1, (incl (fst s0) (fst s1)) -> (incl (snd s0) (snd s1)) ->
+    existsT2 s0n, (existsT2 LHS RHS, (PermutationTS (nodupseq s1) (LHS ++ fst s0n, RHS ++ snd s0n))) *
+                          (PermutationTS s0n (nodupseq s0)).
+  Proof.
+  intros. unfold nodupseq in *.
+  pose (incl_id _ _ H). destruct s. destruct p. destruct s.
+  pose (incl_id _ _ H0). destruct s. destruct p1. destruct s.
+  unfold PermutationTS ; simpl. exists (x, x1) ; simpl. split.
+  - exists x0. exists x2. split ; auto.
+  - split ; auto.
+  Qed.
+ +
+Lemma PermutationTS_nodupseq : forall s0 s1, PermutationTS s0 s1 -> PermutationTS (nodupseq s0) (nodupseq s1).
+Proof.
+intros. split ; destruct H ; apply PermutationT_nodupseq ; auto.
+Qed.
+
+
+ +
+ + + diff --git a/General.List_lemmasT.html b/General.List_lemmasT.html new file mode 100644 index 0000000..db4b3ba --- /dev/null +++ b/General.List_lemmasT.html @@ -0,0 +1,1328 @@ + + + + + + + + + + + + + +
+
+

General.List_lemmasT

+ +
+Require Import List.
+Import ListNotations.
+Require Import PeanoNat.
+Set Implicit Arguments.
+ +
+Require Import existsT.
+Require Import genT gen.
+ +
+Open Scope type_scope.
+ +
+Ltac app_assoc_solve G := rewrite <- (app_assoc G); reflexivity.
+Ltac app_assoc_solve2 G H := rewrite <- (app_assoc G); simpl;
+                             rewrite <- (app_assoc H); reflexivity.
+Ltac eapp_assoc_solve2 G H := erewrite <- (app_assoc G); simpl;
+                             erewrite <- (app_assoc H); reflexivity.
+Ltac app_assoc_hyp G H := rewrite <- (app_assoc G) in H.
+Ltac app_assoc_hyp_inv G H := rewrite <- (app_assoc G) in H; apply app_inv_head in H.
+ +
+Ltac list_assoc_l := repeat (rewrite !app_assoc || rewrite !app_comm_cons).
+Ltac list_assoc_r :=
+  repeat (rewrite <- !app_assoc || rewrite <- !app_comm_cons).
+Ltac list_app_nil := repeat (rewrite !app_nil_l || rewrite !app_nil_r).
+Ltac list_assoc_l_simp := repeat
+  (rewrite !app_assoc || rewrite !app_comm_cons || list_app_nil).
+Ltac list_assoc_r_simp := repeat
+  (rewrite <- !app_assoc || rewrite <- !app_comm_cons || list_app_nil).
+Ltac list_assoc_l_simp' := repeat
+  (rewrite !app_assoc || rewrite !app_comm_cons || rewrite !app_nil_l
+  || rewrite !app_nil_r).
+Ltac list_assoc_r_simp' := repeat
+  (rewrite <- !app_assoc || rewrite <- !app_comm_cons || rewrite !app_nil_l
+  || rewrite !app_nil_r).
+Ltac list_eq_assoc := list_assoc_r ; reflexivity.
+ +
+Lemma if_eq_rev_eq: forall {T} (a b : list T),
+  a = b -> (rev a = rev b).
+Proof. intros. subst. reflexivity. Qed.
+ +
+Lemma if_rev_eq: forall {T} (a b : list T),
+  (rev a = rev b) -> a = b.
+Proof. intros.
+pose (@if_eq_rev_eq T (rev a) (rev b) H).
+rewrite -> !rev_involutive in e.
+exact e.
+Qed.
+ +
+(* rewriting with this won't loop, useful following list_assoc_l *)
+Lemma cons_single A X (v : A) Y: X ++ v :: Y = X ++ [v] ++ Y.
+Proof. simpl. reflexivity. Qed.
+ +
+Lemma partition_2_2 : forall {A : Type} (l1 l2 l3 l4 : list A) a b,
+l1 ++ a :: l2 = l3 ++ b :: l4 ->
+  (exists l5, l1 = l3 ++ b :: l5 /\ l4 = l5 ++ a :: l2) \/
+  (l3 = l1 /\ a = b /\ l2 = l4) \/
+  (exists l5, l3 = l1 ++ a :: l5 /\ l2 = l5 ++ b :: l4).
+Proof.
+  induction l1; intros l2 l3 l4 b c H.
+  - simpl in *. destruct l3.
+    right. left. simpl in *. inversion H.
+    subst. apply conj. reflexivity. apply conj; reflexivity.
+    simpl in H. inversion H as [[H2 H3]].
+    subst. right. right. exists l3. apply conj; reflexivity.
+ +
+  - destruct l3. simpl in *. inversion H as [[H2 H3]].
+    subst. left. exists l1. apply conj; reflexivity.
+    simpl in H. inversion H as [[H2 H3]]. subst.
+    apply IHl1 in H3. destruct H3 as [[l5 [H4 H5]] | [[H4 H5] | [l5 [H4 H5]]]];
+                        subst.
+    + left. exists l5. simpl. apply conj; reflexivity.
+    + right. left. apply conj. reflexivity. assumption.
+    + right. right. exists l5. apply conj; reflexivity.
+Qed.
+ +
+Lemma partition_2_2T : forall {A : Type} (l1 l2 l3 l4 : list A) a b,
+l1 ++ a :: l2 = l3 ++ b :: l4 ->
+  (existsT2 l5, (l1 = l3 ++ b :: l5) * (l4 = l5 ++ a :: l2)) +
+  (((l3 = l1)* (a = b) * (l2 = l4)) +
+  (existsT l5, (l3 = l1 ++ a :: l5) * (l2 = l5 ++ b :: l4))).
+Proof.
+  induction l1; intros l2 l3 l4 b c H.
+  - simpl in *. destruct l3.
+    right. left. simpl in *. inversion H.
+    subst. repeat split.
+    simpl in H. inversion H as [[H2 H3]].
+    subst. right. right. exists l3. repeat split.
+ +
+  - destruct l3. simpl in *. inversion H as [[H2 H3]].
+    subst. left. exists l1. repeat split.
+    simpl in H. inversion H as [[H2 H3]]. subst.
+    apply IHl1 in H3. destruct H3 as [[l5 [H4 H5]] | [[[H4 H5]] | [l5 [H4 H5]]]];
+                        subst.
+    + left. exists l5. simpl. repeat split.
+    + right. left. repeat split.
+    + right. right. exists l5. repeat split.
+Qed.
+ +
+Lemma partition_3_2 : forall {A : Type} (Gam Delt : list A) G' H' Gam1 Delt1 Gam2 Delt2 G H J,
+    G ++ (Gam1, Delt1) :: H ++ (Gam2, Delt2) :: J = G' ++ (Gam, Delt) :: H' ->
+    (exists l, G = G' ++ (Gam,Delt) :: l /\ H' = l ++ (Gam1, Delt1) :: H ++ (Gam2, Delt2) :: J) \/
+    (G' = G /\ Gam1 = Gam /\ Delt1 = Delt /\ H' = H ++ (Gam2, Delt2) :: J) \/
+    (exists l1 l2, G' = G ++ (Gam1, Delt1) :: l1 /\
+                   H = l1 ++ (Gam, Delt) :: l2 /\
+                   H' = l2 ++ (Gam2, Delt2) :: J) \/
+    (G' = G ++ (Gam1,Delt1) :: H /\ Gam2 = Gam /\ Delt2 = Delt /\ J = H' ) \/
+    (exists l, G' = G ++ (Gam1, Delt1) :: H ++ (Gam2, Delt2) :: l /\
+               J = l++ (Gam, Delt) ::H').
+Proof.
+  intros A l1 m1 G' H' l2 m2 l3 m3 G H J.
+  revert G J H l1 m1 G' H' l2 m2 l3 m3.
+  induction G; intros J H l1 m1 G' H' l2 m2 l3 m3 H2.
+  - simpl in *. destruct G'.
+    right. left. simpl in H2. inversion H2.
+    repeat apply conj; reflexivity.
+    simpl in H2. inversion H2 as [[H3 H4]].
+    right. right. edestruct (partition_2_2 _ _ _ _ _ _ H4) as [H0 | [[H0 H5] | H0]].
+    + left. destruct H0 as [l5 [H0' HH]]. subst. exists G', l5.
+      repeat apply conj; try reflexivity.
+    + right. left. subst. inversion H2 as [H3]. apply app_inv_head in H3.
+      inversion H3.
+      repeat apply conj; reflexivity.
+    + right. right. destruct H0 as [l5 [H0' H5]]. exists l5.
+      subst. inversion H2. app_assoc_hyp_inv H H1. simpl in H1.
+      inversion H1.
+      repeat apply conj; reflexivity.
+  - simpl in *. destruct G'. simpl in *. left.
+     inversion H2 as [[H3 H4]].
+     exists G.
+     repeat apply conj; reflexivity.
+     simpl in H2. inversion H2 as [[H3 H4]].
+     apply IHG in H4.
+     destruct H4 as [ [ll [HH1 HH2]] |
+                      [[HH1 [HH2 [HH3]]] |
+                       [ [ll1 [ll2 [HH1 [HH2 HH3]]]] |
+                         [[HH1 [HH2 [HH3 HH4]]] | [ll [HH1 HH2]]]]]]; subst.
+     + left. exists ll.
+       repeat apply conj; reflexivity.
+     + right. left.
+       repeat apply conj; reflexivity.
+     + right. right. left. exists ll1. exists ll2.
+       repeat apply conj; reflexivity.
+     + right. right. right. left.
+       repeat apply conj; reflexivity.
+     + right. right. right. right. exists ll.
+       repeat apply conj; reflexivity.
+ +
+Unshelve.
+all : try assumption.
+Qed.
+ +
+Lemma eq_app_canc1 : forall {A : Type} (l1 l2 l2': list A),
+  (l1 ++ l2 = l1 ++ l2') <-> (l2 = l2').
+Proof. intros. unfold iff. split ; intros.
+  induction l1. simpl in H. exact H.
+  eapply IHl1. simpl in H. inversion H. reflexivity.
+  subst. reflexivity. Qed.
+ +
+Lemma eq_app_canc2 : forall {A : Type} (l1 l1' l2: list A),
+  (l1 ++ l2 = l1' ++ l2) <-> (l1 = l1').
+Proof. intros. unfold iff. split ; intros.
+  apply if_eq_rev_eq in H.
+  rewrite -> !rev_app_distr in H.
+  rewrite -> eq_app_canc1 in H.
+  apply if_rev_eq in H. exact H.
+  subst. reflexivity. Qed.
+ +
+Lemma app_cons_single : forall {A : Type} (l1 l2 : list A) a,
+  l1 ++ a :: l2 = (l1 ++ [a]) ++ l2.
+Proof.
+  induction l1; intros. reflexivity.
+  simpl. rewrite IHl1. reflexivity.
+Qed.
+ +
+Lemma partition_2_3 : forall {A : Type} (l1 l2 l3 l4 : list A) a b,
+    l1 ++ a :: b :: l2 = l3 ++ l4 ->
+    (l3 = l1 /\ l4 = a :: b :: l2) \/
+    (exists l5, l1 = l3 ++ l5 /\ l4 = l5 ++ a :: b :: l2) \/
+    (l3 = l1 ++ [a] /\ l4 = b :: l2) \/
+    (l3 = l1 ++ [a;b] /\ l4 = l2) \/
+    (exists l5, l3 = l1 ++ [a;b] ++ l5 /\ l2 = l5 ++ l4).
+Proof.
+  induction l1; intros *; intros H.
+  - destruct l3. left. auto.
+    right.
+    simpl in *. inversion H as [[H1 H2]]. subst.
+    destruct l3. simpl in *. subst.
+    right. left. auto.
+    simpl in H2. inversion H2 as [[H1 H3]].
+    subst. right. right. right. exists l3. auto.
+ +
+  - simpl in *. destruct l3. right. left.
+    exists (a::l1). auto.
+    simpl in *. inversion H as [[H1 H2]]. subst.
+    apply IHl1 in H2.
+    destruct H2 as [ [H3 H4] | [[l5 [H3 H4]] | [ [H3 H4] | [ [H3 H4] | [l5 [ H4 H5]]]]]];
+      subst.
+    + left. auto.
+    + inversion H as [H2]. app_assoc_hyp_inv l3 H2. subst. right. left.
+      exists l5. auto.
+    + inversion H as [H2]. rewrite <- app_assoc in H2.
+      apply app_inv_head in H2. simpl in H2. inversion H2 as [H3].
+      subst. right. right. left. apply conj; reflexivity.
+    + inversion H as [H2]. app_assoc_hyp_inv l1 H2. simpl in H2.
+      inversion H2 as [H3]. subst. right. right. right. left.
+      apply conj; reflexivity.
+    + subst. right. right. right. right. inversion H as [H2].
+      app_assoc_hyp_inv l1 H2. simpl in *. inversion H2. subst.
+      exists l5. apply conj; reflexivity.
+Qed.
+ +
+Lemma subst_dep : forall (T : Type) (G1 G2 : T) P (P2 : forall (G : T), P G -> nat) (D1 : P G1),
+    G1 = G2 ->
+    exists (D2 : P G2), P2 G1 D1 = P2 G2 D2.
+Proof.
+  intros T G1 G2 P P2 D1 Heq.
+  generalize dependent D1. subst.
+  intros D1. exists D1. reflexivity.
+Qed.
+ +
+Ltac finish_ht_admis_ex1 := simpl; apply le_n_S; assumption.
+Ltac finish_ht_admis_ex2 := simpl; apply le_n_S;
+                            eapply (Nat.le_trans _ _ _ _ _);
+                            assumption.
+Ltac find_trans_solve := match goal with
+               | [ H1 : ?n1 <= ?n2, H2 : ?n2 <= ?n3 |- ?n1 <= ?n3] =>
+                 apply (Nat.le_trans n1 n2 n3 H1 H2) end.
+Ltac finish_ht_admis_ex3 := simpl; apply le_n_S; find_trans_solve.
+Ltac ap_part_2_2 P1 l5 P3 P4 P5 :=
+  apply partition_2_2 in P1;
+  destruct P1 as [ [l5 [P3 P4]] | [ [P3 [P4 P5]] | [l5 [P3 P4]]]].
+ +
+Ltac ap_part_2_3 P5 l5 P55 := apply partition_2_3 in P5;
+    destruct P5 as [ [P5 PP5] | [ [l5 [P5 PP5]]
+ | [[P5 PP5] | [[P5 PP5] | [l5 [P5 PP5]]]]]].
+ +
+Lemma list_rearr1 : forall {A : Type} (a : A) G0 l5 H,
+      (G0 ++ a :: l5 ++ H) =
+           (((G0 ++ [a]) ++ l5) ++ H).
+Proof.
+  intros. rewrite app_cons_single.
+  rewrite app_assoc. reflexivity.
+Qed.
+ +
+Lemma list_rearr2 : forall {A : Type} (a : A) G0 l5 H,
+  ((G0 ++ [a]) ++ l5) ++ H = G0 ++ a :: l5 ++ H.
+Proof. intros. do 2 rewrite <- app_assoc. reflexivity. Qed.
+ +
+Lemma list_rearr4 : forall {T1 T2 T3 : Type} G (A B E : T1) (Delt : list T2)
+                           Gam1 Gam2 (delt : T3) H,
+    G ++ (Gam1 ++ E :: A :: B :: Gam2, Delt, delt) :: H =
+    G ++ ((Gam1 ++ [E]) ++ A :: B :: Gam2, Delt, delt) :: H.
+Proof. intros. rewrite <- app_assoc. reflexivity. Qed.
+ +
+Lemma list_rearr5 : forall {T1 T2 T3 : Type} G (E B : T1)
+                           Gam1 Gam2 (Delt : list T2) (delt : T3) H,
+    G ++ ((Gam1 ++ [E]) ++ B :: Gam2, Delt, delt) :: H =
+    G ++ (Gam1 ++ E :: B :: Gam2, Delt, delt) :: H.
+Proof. intros. rewrite <- app_assoc. reflexivity. Qed.
+ +
+Lemma list_rearr6 : forall {T1 T2 T3 : Type} (E : T1) G l5 Gam3 Gam2
+                           (Delt : list T2) (delt : T3) H,
+    G ++ (Gam3 ++ E :: l5 ++ Gam2, Delt, delt) :: H =
+    G ++ (((Gam3 ++ [E]) ++ l5) ++ Gam2, Delt, delt) :: H.
+Proof. intros. rewrite (app_cons_single Gam3).
+       rewrite (app_assoc _ l5). reflexivity.
+Qed.
+ +
+Lemma list_rearr7 : forall {T1 T2 T3 : Type} G (E : T1) l5 Gam3 Gam2
+                           (Delt : list T2) (delt : T3) H,
+G ++ (((Gam3 ++ [E]) ++ l5) ++ Gam2, Delt, delt) :: H =
+      G ++ (Gam3 ++ E :: l5 ++ Gam2, Delt, delt) :: H.
+Proof. intros. do 2 rewrite <- app_assoc. reflexivity. Qed.
+ +
+Lemma list_rearr8 : forall {T1 T2 T3 : Type} G Gam1 Gam2 (A B : T1)
+                           (Delt : list T2) (delt : T3) H,
G ++ ((Gam1 ++ [A; B]) ++ Gam2, Delt, delt) :: H =
+      G ++ (Gam1 ++ A :: B :: Gam2, Delt, delt) :: H.
+Proof. intros. rewrite <- app_assoc. reflexivity. Qed.
+ +
+Lemma list_rearr9 : forall {T1 T2 T3 : Type} G Gam1 Gam2 (A B : T1)
+                           (Delt : list T2) (delt : T3) H,
+G ++ (Gam1 ++ B :: A :: Gam2, Delt, delt) :: H =
+G ++ (((Gam1 ++ [B]) ++ [A]) ++ Gam2, Delt, delt) :: H.
+Proof. intros. rewrite (app_cons_single _ _ B);
+  rewrite (app_cons_single _ _ A). reflexivity.
+Qed.
+ +
+Lemma list_rearr10 : forall {T1 T2 T3 : Type} G Gam1 Gam4 (A B : T1) l5
+                           (Delt : list T2) (delt : T3) H,
+G ++ ((Gam1 ++ [A; B] ++ l5) ++ Gam4, Delt, delt) :: H =
+       G ++ (Gam1 ++ A :: B :: l5 ++ Gam4, Delt, delt) :: H.
+Proof. intros. rewrite <- app_assoc. reflexivity. Qed.
+ +
+Lemma list_rearr11 : forall {T1 T2 T3 : Type} G Gam1 Gam4 (A B : T1) l5
+                           (Delt : list T2) (delt : T3) H,
+G ++ (Gam1 ++ B :: A :: l5 ++ Gam4, Delt, delt) :: H =
+      G ++ ((((Gam1 ++ [B]) ++ [A]) ++ l5) ++ Gam4, Delt, delt) :: H.
+Proof.
+  intros. rewrite (app_cons_single _ _ B).
+  rewrite (app_cons_single _ _ A).
+  rewrite (app_assoc _ l5). reflexivity.
+Qed.
+ +
+Lemma list_rearr13 : forall {T : Type} a (G l5 H : list T),
+     G ++ a :: l5 ++ H = (G ++ a :: l5) ++ H.
+Proof.
+  intros. rewrite app_comm_cons. rewrite app_assoc.
+  reflexivity. Qed.
+ +
+Lemma list_rearr14 : forall {T : Type} a b (F G H : list T),
+  F ++ a :: (G ++ b :: H) = (F ++ a :: G) ++ b :: H.
+Proof.
+  intros. rewrite app_comm_cons. rewrite app_assoc.
+  reflexivity. Qed.
+ +
+Lemma list_rearr15 : forall {T Xt : Type} (F G H : list T) (X : Xt),
+  (F ++ (G ++ H), X) = ((F ++ G) ++ H, X).
+Proof. intros. rewrite app_assoc. reflexivity. Qed.
+ +
+Lemma list_rearr15_R : forall {T Xt : Type} (F G H : list T) (X : Xt),
+  (X, F ++ (G ++ H)) = (X, (F ++ G) ++ H).
+Proof. intros. rewrite app_assoc. reflexivity. Qed.
+ +
+Lemma list_rearr16' : forall {T : Type} (F G : list T) (a : T),
+  F ++ (a :: G) = (F ++ [a]) ++ G.
+Proof. intros. rewrite <- app_assoc. simpl. reflexivity. Qed.
+ +
+Lemma list_rearr16 : forall {T Xt : Type} (F G : list T) (a : T) (X : Xt),
+  (F ++ (a :: G), X) = ((F ++ [a]) ++ G, X).
+Proof. intros. rewrite <- app_assoc. simpl. reflexivity. Qed.
+ +
+Lemma list_rearr16_R : forall {T Xt : Type} (F G : list T) (a : T) (X : Xt),
+  (X, F ++ (a :: G)) = (X, (F ++ [a]) ++ G).
+Proof. intros. rewrite <- app_assoc. simpl. reflexivity. Qed.
+ +
+Lemma list_rearr17_R : forall {T1 T2 : Type} (Phi : T2) Delt1 (B A : T1) eqr3 U Psi2,
+(Phi, Delt1 ++ B :: A :: eqr3 ++ U :: Psi2) =
+(Phi, (Delt1 ++ B :: A :: eqr3) ++ U :: Psi2).
+Proof. intros. rewrite <- app_assoc. reflexivity. Qed.
+ +
+(* not sure if we ever need this *)
+Lemma list_rearr18 : forall {T : Type} (F G H : list T) (a : T),
+  (F ++ G ++ a :: H) = (F ++ G) ++ a :: H.
+Proof. intros. apply app_assoc. Qed.
+ +
+Lemma list_rearr19 : forall {T : Type} (F G H : list T) (a : T),
+  (F ++ G) ++ a :: H = F ++ (G ++ [a]) ++ H.
+Proof. intros. list_assoc_r. simpl. reflexivity. Qed.
+ +
+Lemma list_rearr20 : forall {T : Type} (F G : list T) (a b : T),
+  F ++ a :: b :: G = F ++ [a ; b] ++ G.
+Proof. intros. list_assoc_r. simpl. reflexivity. Qed.
+ +
+Lemma list_rearr21 : forall {T : Type} (F G : list T) (a b : T),
+  (F ++ [a]) ++ b :: G = F ++ [a ; b] ++ G.
+Proof. intros. list_assoc_r. simpl. reflexivity. Qed.
+ +
+Lemma list_rearr22 : forall {T : Type} (F G : list T) (a b : T),
+  F ++ a :: b :: G = (F ++ [a]) ++ b :: G.
+Proof. intros. list_assoc_r. simpl. reflexivity. Qed.
+ +
+Lemma list_rearr23 : forall {T : Type} (b a : T) (F G : list T),
+  a :: F ++ b :: G = (a :: F) ++ b :: G.
+Proof. intros. list_assoc_r. simpl. reflexivity. Qed.
+ +
+Lemma cons_eq_app: forall (A : Type) (x y z : list A) (a : A),
+  a :: x = y ++ z -> y = [] /\ z = a :: x \/
+  exists (y' : list A), y = a :: y' /\ x = y' ++ z.
+Proof.
+intros.
+destruct y. simpl in H. subst. tauto.
+simpl in H.
+injection H.
+intros. right. subst.
+exists y. tauto.
+Qed.
+ +
+Lemma cons_eq_appT: forall (A : Type) (x y z : list A) (a : A),
+  a :: x = y ++ z -> sum ((y = []) * (z = a :: x))
+  (sigT (fun y' : list A => prod (y = a :: y') (x = y' ++ z))).
+Proof.
+intros.
+destruct y. simpl in H. subst. tauto.
+simpl in H.
+injection H.
+intros. right. subst.
+exists y. tauto.
+Qed.
+ +
+Lemma cons_eq_appT2: forall (A : Type) (x y z : list A) (a : A),
+    a :: x = y ++ z ->
+    ((y = []) * (z = a :: x)) +
+  existsT2 (y' : list A), (y = a :: y') * (x = y' ++ z).
+Proof.
+  intros.
+  destruct y. simpl in H. subst. tauto.
+  simpl in H.
+  injection H.
+  intros. right. subst.
+  exists y. tauto.
+Qed.
+ +
+Definition app_eq_cons (A : Type) (x y z : list A) (a : A) p :=
+  @cons_eq_app A x y z a (eq_sym p).
+ +
+Definition app_eq_consT2 (A : Type) (x y z : list A) (a : A) p :=
+  @cons_eq_appT2 A x y z a (eq_sym p).
+ +
+Lemma app_eq_nilT : forall (A : Type) (l l' : list A),
+    l ++ l' = [] -> (l = []) * (l' = []).
+Proof. destruct l; intros l' H. tauto. discriminate. Qed.
+ +
+Lemma app_eq_app: forall (A : Type) (w x y z : list A),
+  w ++ x = y ++ z -> exists (m : list A),
+    w = y ++ m /\ z = m ++ x \/ y = w ++ m /\ x = m ++ z.
+Proof.
+intro. intro.
+induction w.
+simpl. intros.
+exists y. rewrite H. tauto.
+intros. simpl in H.
+apply cons_eq_app in H.
+destruct H. destruct H. rewrite H. simpl.
+exists (a :: w). rewrite H0. simpl. tauto.
+destruct H. destruct H.
+apply IHw in H0. destruct H0. destruct H0. destruct H0.
+rewrite H. rewrite H0. rewrite H1. simpl.
+exists x1. tauto.
+destruct H0.
+rewrite H. rewrite H0. rewrite H1. simpl.
+exists x1. tauto.
+Qed.
+ +
+Lemma app_eq_appT: forall (A : Type) (w x y z : list A),
+  w ++ x = y ++ z -> sigT (fun m : list A =>
+    sum ((w = y ++ m) * (z = m ++ x)) ((y = w ++ m) * (x = m ++ z))).
+Proof. intro. intro. induction w.
+simpl. intros.
+exists y. rewrite H. tauto.
+intros. simpl in H.
+apply cons_eq_appT in H.
+destruct H. destruct p. subst. simpl.
+exists (a :: w). simpl. tauto.
+destruct s. destruct p.
+apply IHw in e0. destruct e0.
+destruct s ; destruct p ; subst ; simpl ; exists x1 ; tauto.
+Qed.
+ +
+Lemma app_eq_appT2: forall (A : Type) (w x y z : list A),
+  w ++ x = y ++ z -> existsT2 (m : list A),
+    ((w = y ++ m) * (z = m ++ x)) + ((y = w ++ m) * (x = m ++ z)).
+Proof.
+  induction w; intros *; intros H; simpl in *.
+  subst. exists y. right. tauto.
+  apply cons_eq_appT2 in H. destruct H as [[H1 H2]| [l [? H3]]]; subst.
+  exists (a :: w). tauto.
+  eapply IHw in H3. destruct H3 as [l2 [[H3 H4] | [H3 H4]]]; subst.
+  exists l2. tauto.
+  exists l2. tauto.
+Qed.
+ +
+Definition app_eq_consT (A : Type) (x y z : list A) (a : A) p :=
+  @cons_eq_appT A x y z a (eq_sym p).
+ +
+Lemma list_eq_nil: forall (A : Type) (x y : list A) (u : A),
+  x ++ u :: y = [] -> False.
+Proof. intros. apply app_eq_nil in H. cD. discriminate. Qed.
+ +
+Lemma app_eq_unitT2 :
+  forall {A : Type} (x y:list A) (a:A),
+    x ++ y = [a] -> ((x = []) * (y = [a])) + ((x = [a]) * (y = [])).
+Proof.
+  intros *; intros H.
+  destruct x. auto.
+  simpl in *. inversion H. subst. right.
+  rewrite H2. apply app_eq_nilT in H2. destruct H2 as [H2a H2b].
+  subst. auto.
+Qed.
+ +
+Definition nil_eq_list A x y u p := @list_eq_nil A x y u (eq_sym p).
+Definition nil_eq_app A u v p := @app_eq_nil A u v (eq_sym p).
+Definition nil_eq_appT A u v p := @app_eq_nilT A u v (eq_sym p).
+Definition unit_eq_app A x y a p := @app_eq_unit A x y a (eq_sym p).
+Definition unit_eq_appT2 A x y a p := @app_eq_unitT2 A x y a (eq_sym p).
+ +
+Lemma list_eq_single: forall (A : Type) (x y : list A) (u v : A),
+  x ++ u :: y = [v] -> x = [] /\ y = [] /\ u = v.
+Proof. intros. apply app_eq_cons in H. sD. injection H0 as. subst. tauto.
+        apply app_cons_not_nil in H1. contradiction. Qed.
+ +
+Lemma list_eq_singleT: forall (A : Type) (x y : list A) (u v : A),
+  x ++ u :: y = [v] -> prod (x = []) (prod (y = []) (u = v)).
+Proof. intros. apply app_eq_consT in H. sD. injection H0 as. subst. tauto.
+  apply nil_eq_appT in H1. cD. discriminate H2. Qed.
+ +
+Lemma list_eq_singleT_nobrac: forall (A : Type) (x y : list A) (u v : A),
+  x ++ u :: y = [v] -> (x = []) * (y = []) * (u = v).
+Proof. intros. apply app_eq_consT2 in H. sD. injection H0 as. subst. tauto.
+  apply app_cons_not_nil in H1. contradiction. Qed.
+ +
+Definition single_eq_list A x y u v p := @list_eq_single A x y u v (eq_sym p).
+Definition single_eq_listT A x y u v p := @list_eq_singleT A x y u v (eq_sym p).
+Definition single_eq_listT_nobrac A x y u v p := @list_eq_singleT_nobrac A x y u v (eq_sym p).
+ +
+Lemma nnn_app_eq: forall {A : Type} (x : list A), [] ++ [] ++ [] ++ x = x.
+Proof. intros. simpl. reflexivity. Qed.
+ +
+Definition eq_nnn_app {A : Type} (x : list A) := eq_sym (nnn_app_eq x).
+ +
+(* Caitlin added from here for weakening. *)
+ +
+Lemma cons_singleton : forall {A : Type} (l : list A) a,
+    a :: l = [a] ++ l.
+Proof. induction l; intros b; firstorder. Qed.
+ +
+Ltac list_cons_singleton a := repeat rewrite (cons_singleton _ a).
+Ltac tac_cons_singleton_arg a l :=
+    match l with
+    | nil => idtac
+    | _ => rewrite (cons_singleton l a)
+    end.
+ +
+Ltac tac_cons_singleton :=
+  repeat
+  match goal with
+   | [ |- context [?a :: ?l]] => progress (tac_cons_singleton_arg a l)
+  end.
+ +
+(* Caitlin added from here for contraction. *)
+ +
+Ltac rem_nil_goal := repeat rewrite app_nil_l; repeat rewrite app_nil_r.
+Ltac rem_nil_hyp_arg H := repeat rewrite app_nil_l in H; repeat rewrite app_nil_r in H.
+Ltac rem_nil_hyp :=
+  match goal with
+  | [ H : context[ [] ++ ?A ] |- _ ] => progress rem_nil_hyp_arg H
+  | [ H : context[ ?A ++ [] ] |- _ ] => progress rem_nil_hyp_arg H
+  | _ => idtac
+  end.
+ +
+Ltac rem_nil := rem_nil_hyp; rem_nil_goal.
+ +
+Ltac list_assoc_r_single :=
+  list_assoc_r; tac_cons_singleton; rem_nil.
+ +
+Ltac app_bracket_middle_arg l :=
+  repeat match l with
+         | ?l1 ++ ?l2 ++ ?l3 ++ ?l4 => rewrite (app_assoc l2)
+         end.
+ +
+Ltac add_empty_hyp_L l H := rewrite <- (app_nil_l l) in H.
+Ltac add_empty_goal_L l := rewrite <- (app_nil_l l).
+Ltac add_empty_hyp_R l H := rewrite <- (app_nil_r l) in H.
+Ltac add_empty_goal_R l := rewrite <- (app_nil_r l).
+Ltac rem_empty_hyp_L l H := rewrite (app_nil_l l) in H.
+Ltac rem_empty_goal_L l := rewrite (app_nil_l l).
+Ltac rem_empty_hyp_R l H := rewrite (app_nil_r l) in H.
+Ltac rem_empty_goal_R l := rewrite (app_nil_r l).
+ +
+Ltac breakdown :=
+  repeat (
+      repeat (match goal with
+              | [ H : ?A ++ ?B = ?x ++ ?y |- _ ] => apply app_eq_app in H; sE; subst
+              end) ;
+      repeat (match goal with
+              | [H2 : [?a] = ?A ++ ?B |- _ ] => apply unit_eq_app in H2; sE; subst
+              end));
+  repeat try rewrite app_nil_r; repeat try rewrite app_nil_l;
+  repeat (match goal with
+          | [ H3 : context[ ?x ++ [] ] |- _ ] => rewrite (app_nil_r x) in H3
+          end);
+  repeat (match goal with
+          | [ H3 : context[ [] ++ ?x ] |- _ ] => rewrite (app_nil_l x) in H3
+          end).
+ +
+Ltac tac_cons_singleton_arg_hyp H a l :=
+    match l with
+    | nil => idtac
+    | _ => rewrite (cons_singleton l a) in H
+    end.
+ +
+Ltac tac_cons_singleton_hyp H :=
+  repeat
+  match goal with
+  | [ H : context [?a :: ?l] |- _] => progress (tac_cons_singleton_arg_hyp H a nil ||
+                                                tac_cons_singleton_arg_hyp H a l)
+  end.
+ +
+Ltac list_assoc_r_s_arg H :=
+  tac_cons_singleton_hyp H; repeat rewrite <- !app_assoc in H.
+ +
+Ltac list_assoc_r_arg H :=
+  repeat (rewrite <- !app_assoc in H || rewrite <- !app_comm_cons in H).
+Ltac list_assoc_l'_arg H := repeat (rewrite !app_assoc in H || rewrite !app_comm_cons in H).
+Ltac list_assoc_l'_arg_conc H := list_assoc_l; list_assoc_l'_arg H.
+Ltac list_assoc_r_arg_conc H := list_assoc_r; list_assoc_r_arg H.
+ +
+Ltac list_assoc_r_singleton_hyp H :=
+  list_assoc_r_arg H; tac_cons_singleton_hyp H.
+ +
+Ltac list_assoc_r_singleton_hyp2 H :=
+  list_assoc_r_s_arg H.
+ +
+Definition non_empty {A : Type} (l : list A) :=
+  match l with
+  | nil => False
+  | _ => True
+  end.
+ +
+Ltac check_app_head l1 l2 :=
+  match l1 with
+  | l2 ++ ?l3 => idtac
+  | _ => fail
+  end.
+ +
+Ltac check_app_tail l1 l2 :=
+  match l1 with
+  | ?l3 ++ l2 => idtac
+  | _ => fail
+  end.
+ +
+(* Updated *)
+Ltac clear_useless :=
+  repeat match goal with
+         | [H : ?a = ?a |- _] => clear H
+         | [H : [?a] = [?a] |- _] => clear H
+         | [H : ?a :: ?b = ?a :: ?b |- _] => clear H
+         | [H1 : ?a, H2 : ?a |- _] => clear H2
+         | [H1 : [?a] = [?b], H2 : ?c = ?d |- _ ] =>
+           rewrite H2 in H1; match type of H1 with ?d = ?d => clear H1 end
+         | [H1 : [?a] = [?b], H2 : ?c = ?d |- _ ] =>
+           rewrite <- H2 in H1; match type of H1 with ?d = ?d => clear H1 end
+         end.
+ +
+Ltac clear_useless_weak :=
+  repeat match goal with
+         | [H : ?a = ?a |- _] => clear H
+         | [H : [?a] = [?a] |- _] => clear H
+         | [H : ?a :: ?b = ?a :: ?b |- _] => clear H
+         | [H1 : ?a, H2 : ?a |- _] => clear H2
+         end.
+ +
+(*
+Lemma testing_clear_useless : forall (a b c : nat) (l1 l2 l3 : list nat),
+    a::l1 = b::l2 ->
+    b = c ->
+    c = a ->
+    l2 = l2 ->
+    l2 = l2 ->
+    True.
+Proof.  
+  clear_useless.
+Admitted.
+ *)

+ +
+Ltac inv_singleton :=
+    repeat ( match goal with
+       | [ H : ?a :: [] = ?c :: ?d |- _ ] => inversion H; subst
+       | [ H : ?a :: ?b = ?c :: [] |- _ ] => inversion H; subst
+       | [ H : ?a :: ?b = ?c :: ?d |- _ ] => inversion H; subst
+       | [ H : ((?a,?b) = ?c) |- _ ] => inversion H; subst
+       | [ H : ?c = (?a,?b) |- _ ] => inversion H; subst
+             end; clear_useless).
+ +
+Ltac inversion_cons :=
+  repeat match goal with
+         | [ H : ?a :: ?l1 = ?b :: ?l2 |- _] => inversion H; subst; clear_useless
+         end.
+ +
+(* begin git conflict 1 *)
+ +
+Ltac inversion_pair :=
+  repeat (clear_useless; match goal with
+  | [ H : (?a,?b)=(?c,?d) |- _ ] => inversion H; clear H; subst
+  end; clear_useless).
+ +
+Ltac inv_singleton_str :=
+    repeat ( match goal with
+       | [ H : ?a :: [] = ?c :: ?d |- _ ] => inversion H; subst
+       | [ H : ?a :: ?b = ?c :: [] |- _ ] => inversion H; subst
+       | [ H : ?a :: ?b = ?c :: ?d |- _ ] => inversion H; subst
+       | [ H : ((?a,?b) = ?c) |- _ ] => inversion H; subst
+       | [ H : ?c = (?a,?b) |- _ ] => inversion H; subst
+       | [ H : ?C ?a = ?C ?b |- _ ] => inversion H; subst
+             end; clear_useless).
+ +
+Lemma tail_inv_singleton : forall {T : Type} (l1 l2 : list T) a b,
+    l1 ++ [a] = l2 ++ [b] -> (l1 = l2) * (a = b).
+Proof.
+  induction l1; intros l2 c d Heq.
+  simpl in *. destruct l2. simpl in Heq. inversion Heq. firstorder.
+  simpl in Heq. destruct l2. simpl in Heq. inversion Heq.
+  simpl in Heq. inversion Heq.
+  simpl in Heq. destruct l2. simpl in Heq. destruct l1. simpl in Heq. inversion Heq.
+  simpl in Heq. inversion Heq.
+  simpl in Heq. inversion Heq. subst.
+  apply IHl1 in H1. destruct H1 as [IH1 IH2].
+  subst. firstorder.
+Qed.
+ +
+Lemma tail_inv_singleton2 : forall {T : Type} (l1 l2 : list T) a b a' b',
+    l1 ++ [a;a'] = l2 ++ [b;b'] -> (l1 = l2) * (a = b) * (a' = b').
+Proof.
+  induction l1; intros l2 c d a' b' Heq.
+  simpl in *. destruct l2. simpl in Heq. inversion Heq. firstorder.
+  simpl in Heq. destruct l2. simpl in Heq. inversion Heq.
+  simpl in Heq. destruct l2. inversion Heq.
+  simpl in Heq. inversion Heq.
+  destruct l2. simpl in Heq. destruct l1. simpl in Heq. inversion Heq.
+  simpl in Heq. destruct l1; inversion Heq.
+  simpl in Heq. inversion Heq. subst.
+  apply IHl1 in H1. destruct H1 as [[H1 H2] H3].
+  subst. firstorder.
+Qed.
+ +
+Lemma list_insert1 : forall {T : Type} (Gam1 Gam2 Sigm1 Sigm2 : list T) A B,
+    Gam1 ++ [A] ++ Gam2 = Sigm1 ++ Sigm2 ->
+    existsT2 Gam1' Gam2', (Sigm1 ++ [B] ++ Sigm2 = Gam1' ++ [A] ++ Gam2') *
+                      (forall B, InT B Gam1 -> InT B Gam1') *
+                      (forall B, InT B Gam2 -> InT B Gam2').
+Proof.
+  intros *; intros Heq.
+  destruct Sigm2. rewrite app_nil_r.
+  rewrite app_nil_r in Heq. subst.
+  eexists. eexists.
+  split. split. rewrite <- app_assoc. simpl. reflexivity.
+  firstorder.
+  intros C HC. apply InT_appL. assumption.
+  apply partition_2_2T in Heq.
+  sD. subst.
+  eexists (Sigm1 ++ [B] ++ [t] ++ Heq).
+  eexists Gam2. split. split. list_assoc_r. reflexivity. firstorder.
+  apply InT_appE in X. destruct X. apply InT_appL. assumption.
+  apply InT_appR. apply InT_appR.
+  assumption.
+  firstorder.
+  subst.
+  eexists (Gam1 ++ [B]), (Sigm2). split. split.
+  assert (Hyp: t :: Sigm2 = [t] ++ Sigm2). simpl. reflexivity.
+  rewrite Hyp. apply app_assoc.
+  intros C HC. apply InT_appL. assumption.
+  firstorder.
+  subst.
+  list_assoc_r. eexists Gam1, (Heq ++ [B] ++ [t] ++ Sigm2).
+  split. split. reflexivity.
+  firstorder.
+  intros C HC. apply InT_appE in HC.
+  destruct HC. apply InT_appL. assumption.
+  apply InT_appR. apply InT_appR. assumption.
+Qed.
+ +
+  Inductive InT_pair_triple {T1 T2 T3 : Type} (t12 : T1*T2) : list ((list T1) * (list T2) * T3) -> Type :=
+  | InT_pt_hd l a b c t1 t2 : t12 = (t1,t2) -> InT t1 a -> InT t2 b -> InT_pair_triple t12 ((a,b,c) :: l)
+  | InT_pt_tl l a b c : InT_pair_triple t12 l -> InT_pair_triple t12 ((a,b,c) :: l).
+ +
+Lemma InT_pt_I : forall {T1 T2 T3 : Type} L1 (l1 l2 : list T1) (l3 l4 : list T2) (d : T3) A B,
+  InT_pair_triple (A,B) (L1 ++ [(l1 ++ [A] ++ l2, l3 ++ [B] ++ l4, d)]).
+Proof.
+  induction L1; intros. simpl.
+  econstructor. reflexivity.
+  apply InT_appR. econstructor. reflexivity.
+  apply InT_appR. econstructor. reflexivity.
+ +
+  simpl. destruct a as [[a b] c].
+  econstructor 2. apply IHL1.
+Qed.
+ +
+Lemma partition_singleton_app : forall {T : Type} (L1 L2 L3 : list T) A B,
+    L1 ++ [A] = L2 ++ [B] ++ L3 ->
+    ((L3 = []) * (L1 = L2) * (A = B)) +
+    (existsT2 L4, (L3 = L4 ++ [A]) * (L1 = L2 ++ [B] ++ L4)).
+Proof.
+  induction L1; intros L2 L3 A B H.
+  simpl in *. destruct L2. simpl in *. inversion H. firstorder.
+  simpl in *. destruct L2; discriminate.
+  simpl in H. destruct L2. simpl in *. inversion H. subst.
+  right. exists L1. firstorder.
+  simpl in H. inversion H. subst.
+  apply IHL1 in H2. sD. subst. firstorder.
+  subst. right. eexists. split; reflexivity.
+Qed.
+ +
+Lemma InT_mid : forall {T : Type} (l1 l2 : list T) A,
+  InT A (l1 ++ [A] ++ l2).
+Proof.
+  intros. apply InT_appR. apply InT_appL.
+  econstructor. reflexivity.
+Qed.
+ +
+Lemma InT_singleton_mid : forall {T : Type} (l1 l2 l3 l4 : list T) A B,
+    A <> B ->
+    l1 ++ [A] ++ l2 = l3 ++ [B] ++ l4 ->
+    InT A l3 + InT A l4.
+Proof.
+  intros *. intros Hneq Heq.
+  pose proof (InT_mid l1 l2 A) as Hin.
+  rewrite Heq in Hin.
+  apply InT_appE in Hin.
+  destruct Hin. left. assumption.
+  inversion i. subst. contradiction.
+  subst. right. assumption.
+Qed.
+ +
+Lemma list_nil_or_tail_singleton : forall {T : Type} (l : list T),
+    (l = []) + existsT2 l2 a, l = l2 ++ [a].
+Proof.
+  induction l.
+  firstorder.
+  right. destruct IHl. subst. exists nil, a. firstorder.
+  destruct s as [l2' [a' H]].
+  subst. exists (a :: l2'), a'. firstorder.
+Qed.
+ +
+Definition InT_app_or : forall {T : Type} (l1 l2 : list T) A,
+      InT A (l1 ++ l2) -> InT A l1 + InT A l2.
+Proof.
+induction l1. intros. rewrite app_nil_l in X. right. assumption.
+intros. remember ((a :: l1) ++ l2) as l. destruct X.
+subst. inversion Heql. left. apply InT_eq. inversion Heql.
+subst. apply IHl1 in X. destruct X. left. apply InT_cons. assumption.
+right. assumption.
+Defined.
+ +
+Definition InT_or_app : forall {T : Type} (l1 l2 : list T) A,
+       (InT A l1 + InT A l2) -> InT A (l1 ++ l2).
+Proof.
+induction l1. intros. rewrite app_nil_l. destruct X. inversion i.
+assumption.
+intros. destruct X. remember (a:: l1) as l. destruct i.
+inversion Heql. subst. apply InT_eq. inversion Heql. subst.
+simpl. apply InT_cons. apply IHl1. left. assumption.
+simpl. apply InT_cons. apply IHl1. right. assumption.
+Defined.
+ +
+(*
+Lemma partition_LNS_app_mid : forall {T1 T2 : Type} L1 L2 L3 (Gam Sigm Sigm' : list T1) (Delt \u03a0 \u03a0' : list T2) d,
+    L1 ++ (Gam,Delt,d);(Sigm,\u03a0,bac) =
+    L2 ++ (Sigm',\u03a0',fwd) :: L3 ->
+    existsT2 L4, (L3 = L4 ++ (Sigm,\u03a0,bac)) * (L1 ++ (Gam,Delt,d) = L2 ++ (Sigm',\u03a0',fwd) ++ L4).
+Proof.
+  intros *; intros Heq.
+  rewrite app_cons_single in Heq.
+  destruct (list_nil_or_tail_singleont L3) as |[l2 [a Heq2]];
+  subst. eapply tail_inv_singleton in Heq.
+  destruct Heq as H1 H2. inversion H2.
+  exists l2. subst.
+  rewrite (cons_singleton (l2 ++ _)) in Heq.
+  list_assoc_l'_arg Heq.
+  eapply tail_inv_singleton in Heq.
+  destruct Heq as H1 H2. subst. rewrite H1.
+  firstorder.
+Qed.
+*)

+Ltac hd_tl_inv_arg H :=
+    match goal with
+  | [ H : context[?a :: nil] |- _ ] => fail
+  | [ H : context[?a :: ?l] |- _ ] => repeat rewrite (cons_singleton l a) in H
+    end.
+ +
+Ltac list_assoc_r_single_hyp :=
+  match goal with
+  | [ l1 : list ?T, H : ?l1 = ?l2 |- _ ] => list_assoc_r_arg H; tac_cons_singleton_hyp H ; rem_nil_hyp_arg H
+  end.
+ +
+Ltac list_assoc_r_single_arg H :=
+  list_assoc_r_arg H; tac_cons_singleton_hyp H ; rem_nil_hyp_arg H.
+ +
+Lemma app_singleton_inversion : forall {T : Type} (l1 l2 : list T) a b,
+    [a] ++ l1 = [b] ++ l2 -> (a = b) * (l1 = l2).
+Proof. intros *; intros H; inversion H. firstorder. Qed.
+ +
+Lemma app_singleton_tl_inversion : forall {T : Type} (l1 l2 : list T) a b,
+    l1 ++ [a] = l2 ++ [b] -> (a = b) * (l1 = l2).
+Proof.
+  intros T l1 l2 a b H.
+  eapply if_eq_rev_eq in H.
+  do 2 rewrite rev_unit in H.
+  inversion H. apply if_rev_eq in H2.
+  subst. firstorder.
+Qed.
+ +
+Ltac inv_app_hd :=
+  repeat match goal with
+  | [ H : [?a] ++ ?l1 = [?b] ++ ?l2 |- _ ] => apply app_singleton_inversion in H; destruct H as [? H]; try subst a; try subst b
+  | _ => idtac
+         end.
+ +
+Ltac inv_app_tl :=
+  repeat match goal with
+  | [ H : ?l1 ++ [?a] = ?l2 ++ [?b] |- _ ] => apply app_singleton_tl_inversion in H; destruct H as [? H]; try subst a; try subst b
+  | _ => idtac
+         end.
+ +
+Lemma app_hd_inversion : forall {T : Type} (l : list T) a b,
+    [a] = [b] ++ l -> ( (a = b) * (l = []) ).
+Proof.
+  intros *; intros H.
+  inversion H. firstorder.
+Qed.
+ +
+Lemma app_tl_inversion : forall {T : Type} (l : list T) a b,
+    [a] = l ++ [b] -> ( (a = b) * (l = []) ).
+Proof.
+  induction l; intros aa bb H.
+  simpl in *. inversion H. firstorder.
+  simpl in H. inversion H.
+  destruct l; discriminate.
+Qed.
+ +
+Ltac inv_app_hd_arg H :=
+  repeat match type of H with
+  | [?a] ++ ?l1 = [?b] ++ ?l2 => apply app_singleton_inversion in H; let H' := fresh "H" in destruct H as [H' H]; try rewrite H' in *; try rewrite <- H' in *
+  | [?a] = [?b] ++ ?l2 => apply app_hd_inversion in H; let H' := fresh "H" in destruct H as [H' H]; try rewrite H' in *; try rewrite <- H' in *
+  | [?b] ++ ?l2 = [?a] => symmetry in H; apply app_hd_inversion in H; let H' := fresh "H" in destruct H as [H' H]; try rewrite H' in *; try rewrite <- H' in *
+  | _ => idtac
+         end.
+ +
+Ltac inv_app_tl_arg H :=
+  repeat match type of H with
+  | ?l1 ++ [?a] = ?l2 ++ [?b] => apply app_singleton_tl_inversion in H;let H' := fresh "H" in destruct H as [H' H]; try rewrite H' in *; try rewrite <- H' in *
+  | [?a] = ?l2 ++ [?b] => apply app_tl_inversion in H; let H' := fresh "H" in destruct H as [H' H]; try rewrite H' in *; try rewrite <- H' in *
+  | ?l2 ++ [?b] = [?a] => symmetry in H; apply app_tl_inversion in H; let H' := fresh "H" in destruct H as [H' H]; try rewrite H' in *; try rewrite <- H' in *
+  | _ => idtac
+         end.
+ +
+Ltac inv_app_hd_tl_arg H :=
+  list_assoc_r_single_arg H;
+  inv_app_hd_arg H;
+  list_assoc_l'_arg H;
+  inv_app_tl_arg H;
+  list_assoc_r_single_arg H;
+  clear_useless.
+ +
+(* Any equality between lists that have singletons as heads or tails -> destruct into respective smaller equalities. *)
+Ltac inv_app_hd_tl :=
+  repeat match goal with
+  | [ H : ?l1 = ?l2 |- _ ] => inv_app_hd_tl_arg H
+  end.
+ +
+Ltac tac_cons_singleton_eq_hyp :=
+  repeat match goal with
+         | [ l1 : list ?T, H : ?l1 = ?l2 |- _ ] => tac_cons_singleton_hyp H;
+                                                   list_assoc_r_single_arg H
+         end.
+ +
+(* A version of app_eq_appT2_nn to rule out overlap between the two branchs where m =  (hence No Nil mnemonic). *)
+Lemma app_eq_appT2_nn: forall (A : Type) (w x y z : list A),
+  w ++ x = y ++ z -> existsT2 (m : list A),
+    ((w = y ++ m) * (z = m ++ x) * (m <> [])) + ((y = w ++ m) * (x = m ++ z)).
+Proof.
+  induction w; intros *; intros H; simpl in *.
+  subst. exists y. right. tauto.
+  apply cons_eq_appT2 in H. destruct H as [[H1 H2]| [l [? H3]]]; subst.
+  exists (a :: w). left. simpl. split. split ; try auto. intro. inversion H.
+  eapply IHw in H3. destruct H3 as [l2 [[H3 H4] | [H3 H4]]]; subst.
+  exists l2. sD. subst. left. tauto.
+  exists l2. right. tauto.
+Qed.
+ +
+Ltac app_eq_app_dest_arg H :=
+  eapply app_eq_appT2_nn in H; sD; subst.
+ +
+Ltac app_single_eq_dest_arg H :=
+  apply unit_eq_appT2 in H; sD; subst.
+ +
+Lemma app_eq_appT2_single_hdL : forall (A : Type) (x y z : list A) w,
+    [w] ++ x = y ++ z ->
+    (existsT2 m : list A, ((y = [w] ++ m) * (x = m ++ z)))
+       + ((y = []) * (z = [w] ++ x)).
+Proof.
+  intros *.
+  intros H.
+  destruct y. simpl in *. subst.
+  right. firstorder.
+  left. simpl in *. inversion H.
+  subst. exists y. firstorder.
+Qed.
+ +
+Lemma app_eq_appT2_single_hdR : forall (A : Type) (x z w : list A) y,
+    w ++ x = [y] ++ z ->
+    (existsT2 m : list A, (w = [y] ++ m) * (z = m ++ x)) +
+    ( (w = []) * (x = [y] ++ z)).
+Proof.
+  intros *.
+  intros H.
+  symmetry in H.
+  eapply app_eq_appT2_single_hdL.
+  assumption.
+Qed.
+ +
+Lemma app_eq_appT2_single_tlL : forall (A : Type) (x y z : list A) w,
+    x ++ [w] = y ++ z ->
+    (existsT2 m : list A, ((z = m ++ [w]) * (x = y ++ m)))
+       + ((z = []) * (y = x ++ [w])).
+Proof.
+  intros *.
+  intros H.
+  destruct (list_nil_or_tail_singleton z). subst.
rewrite app_nil_r in H. subst.
+  right. firstorder. sD. subst.
+  left. list_assoc_l'_arg H.
+  eapply tail_inv_singleton in H.
+  sD. subst.
+  eexists. firstorder.
+Qed.
+ +
+Lemma app_eq_appT2_single_tlR : forall (A : Type) (x y z : list A) w,
+     y ++ z = x ++ [w] ->
+    (existsT2 m : list A, ((z = m ++ [w]) * (x = y ++ m)))
+       + ((z = []) * (y = x ++ [w])).
+Proof.
+  intros *.
+  intros H.
+  symmetry in H.
+  eapply app_eq_appT2_single_tlL.
+  assumption.
+Qed.
+ +
+(* Where we have a partitioning of lists, split into cases.  *)
+Ltac app_eq_app_dest :=
+  repeat match goal with
+         | [ H : [?a] = ?l1 ++ ?l2 |- _ ] => app_single_eq_dest_arg H
+         | [ H : ?l1 ++ ?l2 = [?a] |- _ ] => symmetry in H; app_single_eq_dest_arg H
+         | [ H : [?a] = [?b] |- _ ] => inversion H
+         | [ H : ?l1 ++ ?l2 = ?l3 ++ ?l4 |- _ ] => app_eq_app_dest_arg H
+         end.
+ +
+Ltac inv_app_hd_tl_full :=
+  inv_app_hd_tl; repeat inversion_pair;
+  tac_cons_singleton_eq_hyp.
+ +
+Ltac app_eq_app_dest2 :=
+  repeat (inv_app_hd_tl_full ; subst ; try match goal with
+         | [ H : [?a] = ?l1 ++ ?l2 |- _ ] => app_single_eq_dest_arg H
+         | [ H : ?l1 ++ ?l2 = [?a] |- _ ] => symmetry in H; app_single_eq_dest_arg H
+         | [ H : [?a] = [?b] |- _ ] => inversion H
+         | [ H : [?a] ++ ?l2 = ?l3 ++ ?l4 |- _ ] => eapply app_eq_appT2_single_hdL in H
+         | [ H : ?l1 ++ ?l2 = [?a] ++ ?l4 |- _ ] => eapply app_eq_appT2_single_hdR in H
+         | [ H : ?l1 ++ ?l2 = ?l3 ++ ?l4 |- _ ] => app_eq_app_dest_arg H
+                                           end).
+ +
+Ltac app_eq_app_dest3_arg_pre H :=
+      (match goal with
+      | H:[?a] = ?l1 ++ ?l2 |- _ => app_single_eq_dest_arg H
+      | H:?l1 ++ ?l2 = [?a] |- _ => symmetry in H; app_single_eq_dest_arg H
+      | H:[?a] = [?b] |- _ => inversion H; clear H
+       end).
+ +
+Ltac app_eq_app_dest3_argL H :=
+      (match goal with
+      | H:[?a] ++ ?l2 = ?l3 ++ ?l4 |- _ => eapply app_eq_appT2_single_hdL in H
+      | H:?l1 ++ ?l2 = [?a] ++ ?l4 |- _ => eapply app_eq_appT2_single_hdR in H
+       end).
+ +
+Ltac app_eq_app_dest3_argR H :=
+      (match goal with
+      | H: ?l2 ++ [?a] = ?l3 ++ ?l4 |- _ => eapply app_eq_appT2_single_tlL in H
+      | H:?l1 ++ ?l2 = ?l4 ++ [?a] |- _ => eapply app_eq_appT2_single_tlR in H
+       end).
+ +
+Ltac app_eq_app_dest3_arg_app H :=
+      (match goal with
+      | H:?l1 ++ ?l2 = ?l3 ++ ?l4 |- _ => app_eq_app_dest_arg H
+       end).
+ +
+Ltac app_eq_app_dest3_arg H :=
+  (progress app_eq_app_dest3_arg_pre H) ||
+  (progress (list_assoc_r_single_arg H; app_eq_app_dest3_argL H)) ||
+  (progress (list_assoc_l'_arg H; app_eq_app_dest3_argR H)) ||
+  (progress (list_assoc_r_single_arg H; app_eq_app_dest3_arg_app H)).
+ +
+Ltac app_eq_app_dest3 :=
+  repeat (inv_app_hd_tl_full ; subst ; match goal with
+  | [l1 : list ?T, H : ?l1 = ?l2 |- _ ] => app_eq_app_dest3_arg H; sD; subst
+          end); try (inv_app_hd_tl_full ; subst).
+ +
+Ltac app_eq_app_dest3' :=
+  repeat ((inv_app_hd_tl_full ; subst ; match goal with
+  | [l1 : list ?T, H : ?l1 = ?l2 |- _ ] => app_eq_app_dest3_arg H; sD; subst
+          end); try (inv_app_hd_tl_full ; subst)).
+ +
+Ltac eapply_refl tac := eapply tac; reflexivity.
+ +
+Ltac assoc_mid_loc L :=
+  repeat match goal with
+         | [ |- context[ ?l1 ++ ?l2 ++ L ++ ?l3 ] ] => rewrite (app_assoc l1)
+         end.
+ +
+Ltac tac_match l1 l2 :=
+  match l1 with
+  | [] => fail
+  | l2 ++ ?s1 => idtac
+  | ?s1 ++ l2 => try rewrite <- (app_nil_r ?L1)
+  | ?s1 ++ l2 ++ ?s2 => try rewrite (app_assoc _ s1)
+  | ?s1 ++ ?s2 => try rewrite (app_assoc _ s1); tac_match s2 l2
+  end.
+ +
+      Ltac tac_match' l1 AA :=
+  match l1 with
+  | [] => fail
+  | AA :: ?s1 => idtac
+  | ?s1 ++ [AA] => try rewrite <- (app_nil_r ?L1)
+  | ?s1 ++ AA :: ?s2 => try rewrite (app_assoc _ s1)
+  | ?s1 ++ ?s2 => try rewrite (app_assoc _ s1); tac_match' s2 AA
+  end.
+ +
+ +
+      Ltac get_last_app H :=
+  match H with
+  | ?H1 ++ ?H2 => get_last_app H2
+  | _ => constr:(H)
+  end.
+ +
+Ltac get_snd_last_app H :=
+  match H with
+  | ?H1 ++ ?H2 ++ ?H3 => get_snd_last_app (H2 ++ H3)
+  | ?H1 ++ ?H2 => constr:(H1)
+  | _ => constr:(H)
+  end.
+ +
+(* end git conflict 1 *)
+ +
+(* begin git conflict 2 *)
+ +
+(* for manipulating lists got by appending shorter lists *)
+Inductive app_split_at X (T : list X) : list X -> list X -> list X -> Type :=
+  | asa_single : app_split_at T T [] []
+  | asa_appL : forall A B C D,
+    app_split_at T A B C -> app_split_at T (A ++ D) B (C ++ D)
+  | asa_appR : forall A B C D,
+    app_split_at T A B C -> app_split_at T (D ++ A) (D ++ B) C
+  .
+ +
+(* to show/solve app_split_at T A ?BC *)
+Ltac solve_asa := apply asa_single ||
+  (apply asa_appL ; solve_asa) ||
+  (apply asa_appR ; solve_asa) .
+ +
+Lemma asa_eq X (T A B C : list X) : app_split_at T A B C -> A = B ++ T ++ C.
+Proof. intro asa. induction asa ; subst.
+rewrite app_nil_r. reflexivity. list_eq_assoc. list_eq_assoc. Qed.
+ +
+(* end git conflict 2 *)
+
+ +
+ + + diff --git a/General.ddT.html b/General.ddT.html new file mode 100644 index 0000000..b31915e --- /dev/null +++ b/General.ddT.html @@ -0,0 +1,915 @@ + + + + + + + + + + + + + +
+
+

General.ddT

+ +
+ +
+(* derrec, derl, etc, other useful stuff *)
+ +
+Require Export List.
+Set Implicit Arguments.
+Export ListNotations.
+ +
+Require Import Coq.Program.Equality. (* for dependent induction/destruction *)
+ +
+Require Import genT gen existsT.
+Require Import PeanoNat.
+ +
+(* note, this doesn't work Type replaced by Prop,
+  although the actual version used allows prems : X -> Prop 
+Reset derrec.
+
+Inductive derrec X (rules : list X -> X -> Prop) :
+  (X -> Type) -> X -> Prop := 
+  | dpI : forall prems concl,
+    prems concl -> derrec rules prems concl
+  | derI : forall ps prems concl,
+    rules ps concl -> dersrec rules prems ps -> derrec rules prems concl 
+with dersrec X (rules : list X -> X -> Prop) :
+  (X -> Type) -> list X -> Prop :=
+  | dlNil : forall prems, dersrec rules prems 
+  | dlCons : forall prems seq seqs, 
+    derrec rules prems seq -> dersrec rules prems seqs ->
+    dersrec rules prems (seq :: seqs)
+    .
+    *)

+ +
+(* definition using Forall, seems equivalent *)
+Inductive aderrec X (rules : list X -> X -> Prop)
+  (prems : X -> Prop) : X -> Prop :=
+  | adpI : forall concl,
+    prems concl -> aderrec rules prems concl
+  | aderI : forall ps concl, rules ps concl ->
+    Forall (aderrec rules prems) ps -> aderrec rules prems concl.
+(* need type version of Forall, to change this to Type *)
+ +
+(* derrec: type of derivation of a sequent ; dersrec: same idea but for
+multiple sequents *)

+ +
+Inductive derrec X (rules : list X -> X -> Type) (prems : X -> Type) :
+  X -> Type :=
+  | dpI : forall concl,
+    prems concl -> derrec rules prems concl
+  | derI : forall ps concl,
+    rules ps concl -> dersrec rules prems ps -> derrec rules prems concl
+with dersrec X (rules : list X -> X -> Type) (prems : X -> Type) :
+  list X -> Type :=
+  | dlNil : dersrec rules prems []
+  | dlCons : forall seq seqs,
+    derrec rules prems seq -> dersrec rules prems seqs ->
+    dersrec rules prems (seq :: seqs)
+    .
+ +
+Scheme derrec_rect_mut := Induction for derrec Sort Type
+with dersrec_rect_mut := Induction for dersrec Sort Type.
+Scheme derrec_rec_mut := Induction for derrec Sort Set
+with dersrec_rec_mut := Induction for dersrec Sort Set.
+Scheme derrec_ind_mut := Induction for derrec Sort Prop
+with dersrec_ind_mut := Induction for dersrec Sort Prop.
+(*
+Check derrec_ind_mut.
+Check dersrec_ind_mut.
+*)

+(* combine the two inductive principles *)
+Definition derrec_dersrec_rect_mut X rules prems P P0 dp der dln dlc :=
+  pair (@derrec_rect_mut X rules prems P P0 dp der dln dlc)
+    (@dersrec_rect_mut X rules prems P P0 dp der dln dlc).
+ +
+Ltac solve_dersrec := repeat (apply dlCons || apply dlNil || assumption).
+ +
+(* this should be a more useful induction principle for derrec *)
+Definition dim_all X rules prems Q :=
+  @derrec_ind_mut X rules prems (fun y => fun _ => Q y)
+  (fun ys => fun _ => Forall Q ys).
+ +
+Definition dim_allT X rules (prems Q : X -> Type) :=
+  @derrec_rect_mut X rules prems (fun y => fun _ => Q y)
+  (fun ys => fun _ => ForallT Q ys).
+ +
+(* this doesn't work
+Check (dim_all _ _ (Forall_nil X Q)).
+*)

+(* here is how to get the tautologies out of dim_all *)
+Definition dim_all3 X rules prems Q h1 h2 :=
+  @dim_all X rules prems Q h1 h2 (Forall_nil Q).
+ +
+Definition fce3 X Q D Ds seq seqs (d : D seq) qs (ds : Ds seqs) qss :=
+  @Forall_cons X Q seq seqs qs qss.
+ +
+Definition dim_all4 X rules prems Q h1 h2 :=
+  @dim_all3 X rules prems Q h1 h2
+  (@fce3 X Q (derrec rules prems) (dersrec rules prems)).
+ +
+Definition dim_all8 X rules prems Q h1 h2 :=
+  @dim_all3 X rules prems Q h1 h2
+  (fun seq seqs _ qs _ qss => @Forall_cons X Q seq seqs qs qss).
+ +
+(* so dim_all4, or dim_all8 better, is the same as derrec_all_ind below *)
+ +
+Lemma derrec_all_ind:
+  forall X (rules : list X -> X -> Type) (prems Q : X -> Prop),
+     (forall concl : X, prems concl -> Q concl) ->
+     (forall (ps : list X) (concl : X),
+      rules ps concl -> dersrec rules prems ps -> Forall Q ps -> Q concl) ->
+     forall y : X, derrec rules prems y -> Q y.
+Proof. intros.
+eapply dim_all. exact H. exact H0.
+apply Forall_nil.
+intros. apply Forall_cons. assumption. assumption.
+assumption. Qed.
+ +
+Lemma derrec_all_indT:
+  forall X (rules : list X -> X -> Type) (prems Q : X -> Type),
+     (forall concl : X, prems concl -> Q concl) ->
+     (forall (ps : list X) (concl : X),
+      rules ps concl -> dersrec rules prems ps -> ForallT Q ps -> Q concl) ->
+     forall y : X, derrec rules prems y -> Q y.
+Proof. intros X rules prems Q. intros H H0.
+eapply dim_allT. exact H. exact H0.
+apply ForallT_nil.
+intros. apply ForallT_cons. assumption. assumption.
+Qed.
+ +
+Lemma derrec_all_rect:
+  forall X (rules : list X -> X -> Type) (prems Q : X -> Type),
+     (forall concl : X, prems concl -> Q concl) ->
+     (forall (ps : list X) (concl : X),
+      rules ps concl -> dersrec rules prems ps -> ForallT Q ps -> Q concl) ->
+     forall y : X, derrec rules prems y -> Q y.
+Proof. intros.
+eapply dim_allT. exact X0. exact X1.
+apply ForallT_nil.
+intros. apply ForallT_cons. assumption. assumption.
+assumption. Qed.
+ +
+Lemma derrec_derrec' X rules prems:
+  (forall c : X, derrec rules (derrec rules prems) c -> derrec rules prems c) *
+  (forall cs, dersrec rules (derrec rules prems) cs -> dersrec rules prems cs).
+Proof. apply derrec_dersrec_rect_mut.
+- intros. assumption.
+- intros. eapply derI ; eassumption.
+- apply dlNil.
+- intros. apply dlCons ; assumption. Qed.
+ +
+Definition derrec_derrec X rules prems := fst (@derrec_derrec' X rules prems).
+Definition dersrec_derrec X rules prems := snd (@derrec_derrec' X rules prems).
+ +
+Inductive derl X (rules : list X -> X -> Type) : list X -> X -> Type :=
+  | asmI : forall p, derl rules [p] p
+  | dtderI : forall pss ps concl, rules ps concl ->
+    dersl rules pss ps -> derl rules pss concl
+with dersl X (rules : list X -> X -> Type) : list X -> list X -> Type :=
+  | dtNil : dersl rules [] []
+  | dtCons : forall ps c pss cs,
+    derl rules ps c -> dersl rules pss cs -> dersl rules (ps ++ pss) (c :: cs)
+  .
+ +
+Scheme derl_ind_mut := Induction for derl Sort Prop
+with dersl_ind_mut := Induction for dersl Sort Prop.
+Scheme derl_rec_mut := Induction for derl Sort Set
+with dersl_rec_mut := Induction for dersl Sort Set.
+Scheme derl_rect_mut := Induction for derl Sort Type
+with dersl_rect_mut := Induction for dersl Sort Type.
+(*
+Check derl_ind_mut.
+Check dersl_ind_mut.
+*)

+Lemma dtCons_eq X rules ps c pss cs psa: derl rules ps (c : X) ->
+  dersl rules pss cs -> psa = ps ++ pss -> dersl rules psa (c :: cs).
+Proof. intros. subst. apply dtCons ; assumption. Qed.
+ +
+Lemma derl_dersl_single X rules ps (c : X) :
+  iffT (dersl rules ps [c]) (derl rules ps c).
+Proof. split.
+intro. inversion X0. inversion X2. subst. rewrite app_nil_r. assumption.
+intro. eapply (dtCons_eq X0 (dtNil _)). rewrite app_nil_r. reflexivity. Qed.
+ +
+(* combine the two inductive principles *)
+Definition derl_dersl_rect_mut X rules P P0 asm dtd dtn dtc :=
+  pair (@derl_rect_mut X rules P P0 asm dtd dtn dtc)
+    (@dersl_rect_mut X rules P P0 asm dtd dtn dtc).
+ +
+Lemma asmsI X rules ps: @dersl X rules ps ps .
+Proof. induction ps. apply dtNil. pose (asmI rules a).
+pose (dtCons d IHps). simpl in d0. exact d0. Qed.
+ +
+Lemma in_derl X rules ps c: rules ps c -> @derl X rules ps c.
+Proof. intro. eapply dtderI. eassumption. apply asmsI. Qed.
+ +
+Definition rsub_derl X rules := rsubI _ _ (@in_derl X rules).
+ +
+Inductive dercl X (rules : list X -> X -> Type) :
+  list X -> X -> Type :=
+  | casmI : forall p, dercl rules [p] p
+  | dtcderI : forall pss ps concl, rules ps concl ->
+    dercsl rules pss ps -> dercl rules (concat pss) concl
+with dercsl X (rules : list X -> X -> Type) :
+  list (list X) -> list X -> Type :=
+  | dtcNil : dercsl rules [] []
+  | dtcCons : forall ps c pss cs, dercl rules ps c ->
+      dercsl rules pss cs -> dercsl rules (ps :: pss) (c :: cs)
+  .
+ +
+Scheme dercl_ind_mut := Induction for dercl Sort Prop
+with dercsl_ind_mut := Induction for dercsl Sort Prop.
+Scheme dercl_rec_mut := Induction for dercl Sort Set
+with dercsl_rec_mut := Induction for dercsl Sort Set.
+Scheme dercl_rect_mut := Induction for dercl Sort Type
+with dercsl_rect_mut := Induction for dercsl Sort Type.
+(*
+Check dercl_ind_mut.
+Check dercsl_ind_mut.
+*)

+(* combine the two inductive principles *)
+Definition dercl_dercsl_rect_mut X rules P P0 asm dtd dtn dtc :=
+  pair (@dercl_rect_mut X rules P P0 asm dtd dtn dtc)
+    (@dercsl_rect_mut X rules P P0 asm dtd dtn dtc).
+ +
+Inductive ccps X f (qs cs : list X) : Type :=
+  | ccpsI : forall pss, f pss cs -> qs = concat pss -> ccps f qs cs.
+ +
+Lemma ccpsD X f qs cs: ccps f qs cs ->
+  {pss : list (list X) & qs = concat pss & f pss cs}.
+Proof. intro cc. destruct cc. subst. exists pss ; tauto. Qed.
+ +
+Definition drl_allT X (rules Q : list X -> X -> Type) R :=
+  @derl_rect_mut X rules (fun ps => fun c => fun _ => Q ps c)
+  (fun pss => fun cs => fun _ => R pss cs).
+ +
+Definition drsl_allT X (rules Q : list X -> X -> Type) R :=
+  @dersl_rect_mut X rules (fun ps => fun c => fun _ => Q ps c)
+  (fun pss => fun cs => fun _ => R pss cs).
+ +
+(* these may be too strong, have a condition that has to hold
+  even if dersl and Forall2T Q hold for different partition of pss *)

+Definition drl_allT' X (rules Q : list X -> X -> Type) :=
+  @derl_rect_mut X rules (fun ps => fun c => fun _ => Q ps c)
+  (fun ps => fun cs => fun _ => ccps (Forall2T Q) ps cs).
+ +
+Definition drsl_allT' X (rules Q : list X -> X -> Type) :=
+  @dersl_rect_mut X rules (fun ps => fun c => fun _ => Q ps c)
+  (fun ps => fun cs => fun _ => ccps (Forall2T Q) ps cs).
+ +
+Definition dcl_allT X (rules Q : list X -> X -> Type) :=
+  @dercl_rect_mut X rules (fun ps => fun c => fun _ => Q ps c)
+  (fun pss => fun cs => fun _ => Forall2T Q pss cs).
+ +
+Definition dcsl_allT X (rules Q : list X -> X -> Type) :=
+  @dercsl_rect_mut X rules (fun ps => fun c => fun _ => Q ps c)
+  (fun pss => fun cs => fun _ => Forall2T Q pss cs).
+ +
+Lemma dercl_all_rect: forall X (rules Q : list X -> X -> Type),
+  (forall p : X, Q [p] p) ->
+  (forall pss qs ps concl, rules ps concl -> dercsl rules pss ps ->
+    Forall2T Q pss ps -> qs = concat pss -> Q qs concl) ->
+  forall ps c, dercl rules ps c -> Q ps c.
+Proof. intros. eapply dcl_allT. exact X0.
+{ intros. eapply X1. eassumption.
+  eassumption. eassumption. reflexivity. }
+apply Forall2T_nil.
+intros. apply Forall2T_cons ; assumption. assumption. Qed.
+ +
+Lemma derscl_all_dercl: forall X (rules : list X -> X -> Type),
+  forall pss cs, dercsl rules pss cs -> Forall2T (dercl rules) pss cs.
+Proof. intros X rules. apply dcsl_allT. apply casmI.
+intros. eapply dtcderI ; eassumption.
+apply Forall2T_nil. intros. apply Forall2T_cons ; assumption. Qed.
+ +
+Lemma all_dercl_derscl: forall X (rules : list X -> X -> Type),
+  forall pss cs, Forall2T (dercl rules) pss cs -> dercsl rules pss cs.
+Proof. induction pss.
+intros. inversion X0. apply dtcNil.
+intros. inversion X0. subst. apply dtcCons. assumption.
+apply IHpss. assumption. Qed.
+ +
+Lemma all_derl_dersl: forall X (rules : list X -> X -> Type),
+  forall pss cs, Forall2T (derl rules) pss cs -> dersl rules (concat pss) cs.
+Proof. induction pss.
+intros. inversion X0. simpl. apply dtNil.
+intros. inversion X0. subst. simpl. apply dtCons. assumption.
+apply IHpss. assumption. Qed.
+ +
+Lemma all_derl_dersl': forall X (rules : list X -> X -> Type),
+  forall qs cs, ccps (Forall2T (derl rules)) qs cs -> dersl rules qs cs.
+Proof. intros. destruct X0. subst. apply all_derl_dersl. exact f. Qed.
+ +
+Lemma dersl_all_derl: forall X (rules : list X -> X -> Type),
+  forall qs cs, dersl rules qs cs ->
+  {pss : list (list X) & qs = concat pss & Forall2T (derl rules) pss cs}.
+Proof. intros X rules. eapply drsl_allT. apply asmI.
+intros. destruct X0. subst. eapply dtderI. apply r. apply d.
+exists []. simpl. reflexivity. apply Forall2T_nil.
+intros. destruct X1. subst. exists (ps :: x). simpl. reflexivity.
+apply Forall2T_cons ; assumption. Qed.
+ +
+Lemma dersl_all_derl': forall X (rules : list X -> X -> Type),
+  forall qs cs, dersl rules qs cs -> ccps (Forall2T (derl rules)) qs cs.
+Proof. intros X rules. eapply drsl_allT'. apply asmI.
+intros. destruct X0. eapply dtderI ; eassumption.
+eapply ccpsI. apply Forall2T_nil. simpl. reflexivity.
+intros. destruct X1. subst. eapply ccpsI.
+apply Forall2T_cons ; eassumption. simpl. reflexivity. Qed.
+ +
+Lemma dercl_derl': forall X (rules : list X -> X -> Type),
+  prod (forall ps c, dercl rules ps c -> derl rules ps c)
+    (forall pss cs, dercsl rules pss cs -> dersl rules (concat pss) cs).
+Proof. intros.
+eapply (dercl_dercsl_rect_mut (rules := rules)
+  (fun ps : list X => fun c => fun _ => derl rules ps c)
+  (fun pss cs => fun _ => dersl rules (concat pss) cs)).
+apply asmI.
+intros. eapply dtderI. eassumption.
+subst. assumption.
+simpl. apply dtNil.
+intros. simpl. apply dtCons ; assumption. Qed.
+ +
+Definition dercl_derl X rules := fst (@dercl_derl' X rules).
+Definition dercsl_dersl X rules := snd (@dercl_derl' X rules).
+ +
+Lemma derl_dercl: forall X (rules : list X -> X -> Type),
+  forall ps c, derl rules ps c -> dercl rules ps c.
+Proof. intros X rules.
+eapply (drl_allT (dercl rules) (ccps (dercsl rules))).
+apply casmI.
+{ intros. destruct X0. subst.
+eapply dtcderI. eassumption. eassumption. }
+{ eapply ccpsI. apply dtcNil. simpl. reflexivity. }
+{ intros. destruct X1. subst.
+eapply ccpsI. eapply dtcCons ; eassumption.
+simpl. reflexivity. } Qed.
+ +
+Lemma derl_all_rect: forall X (rules Q : list X -> X -> Type),
+  (forall p : X, Q [p] p) ->
+  (forall pss qs ps concl, rules ps concl -> dersl rules qs ps ->
+    Forall2T Q pss ps -> qs = concat pss -> Q qs concl) ->
+  forall ps c, derl rules ps c -> Q ps c.
+Proof. intros X rules Q asm dtd.
+eapply (drl_allT Q (ccps (Forall2T Q))).
+exact asm.
+{ intros. destruct X0. subst.
+eapply dtd. eassumption. eassumption. eassumption. reflexivity. }
+{ eapply ccpsI. apply Forall2T_nil. simpl. reflexivity. }
+{ intros. destruct X1. subst.
+eapply ccpsI. eapply Forall2T_cons ; eassumption.
+simpl. reflexivity. } Qed.
+(*
+Check derl_all_rect.  
+Check derl_dercl. 
+Check dercl_derl.
+*)

+(* no convenient way of expressing the corresponding result
+  for dercsl except using sth like allrel *)

+ +
+Lemma derrec_same: forall X rules prems (c c' : X),
+  derrec rules prems c -> c = c' -> derrec rules prems c'.
+Proof. intros. subst. assumption. Qed.
+ +
+(* further detailed versions of derrec_same *)
+Lemma derrec_same_nsL: forall Y X D rules prems G H unk0 d (unk1 unk1' : X),
+  derrec rules prems (G ++ (unk1 : X, unk0 : Y, d : D) :: H) ->
+    unk1 = unk1' -> derrec rules prems (G ++ (unk1', unk0, d) :: H).
+Proof. intros. subst. assumption. Qed.
+ +
+Lemma derrec_same_nsR: forall Y X D rules prems G H unk1 d (unk0 unk0' : X),
+  derrec rules prems (G ++ (unk1 : Y, unk0 : X, d : D) :: H) ->
+    unk0 = unk0' -> derrec rules prems (G ++ (unk1, unk0', d) :: H).
+Proof. intros. subst. assumption. Qed.
+ +
+Lemma dersrec_all: forall X rules prems (cs : list X),
+  iffT (dersrec rules prems cs) (ForallT (derrec rules prems) cs).
+Proof. intros.
+induction cs ; unfold iffT ; apply pair ; intro.
+apply ForallT_nil. apply dlNil.
+inversion X0. apply ForallT_cons. assumption.
+unfold iffT in IHcs. destruct IHcs. tauto.
+inversion X0. subst. apply dlCons. assumption.
+unfold iffT in IHcs. destruct IHcs. tauto.
+Qed.
+ +
+Definition dersrecD_all X rs ps cs := iffT_D1 (@dersrec_all X rs ps cs).
+Definition dersrecI_all X rs ps cs := iffT_D2 (@dersrec_all X rs ps cs).
+ +
+Lemma prems_dersrec X rules prems cs:
+  ForallT prems cs -> @dersrec X rules prems cs.
+Proof. induction cs ; intros. apply dlNil.
+inversion X0. subst. apply dlCons. apply dpI. assumption. tauto. Qed.
+ +
+Lemma dersrec_forall: forall X rules prems (cs : list X),
+  iffT (dersrec rules prems cs) (forall c, InT c cs -> derrec rules prems c).
+Proof. intros. rewrite dersrec_all. rewrite ForallT_forall. reflexivity. Qed.
+ +
+Definition dersrecD_forall X rs ps cs := iffT_D1 (@dersrec_forall X rs ps cs).
+Definition dersrecI_forall X rs ps cs := iffT_D2 (@dersrec_forall X rs ps cs).
+ +
+Lemma dersrec_nil: forall X rules prems, dersrec rules prems ([] : list X).
+Proof. apply dlNil. Qed.
+ +
+(* this is very difficult for such an obvious result,
+  better if we can rewrite based on iffT *)

+Lemma dersrec_app: forall X rules prems cs ds,
+  iffT (dersrec rules prems (cs ++ ds : list X))
+    (prod (dersrec rules prems cs) (dersrec rules prems ds)).
+Proof. intros. eapply iffT_trans. apply dersrec_forall.
+unfold iffT. split ; intros.
+split ; apply dersrecI_forall ; intros ; apply X0.
+apply InT_appL. assumption. apply InT_appR. assumption.
+apply InT_appE in X1. sD.
+eapply dersrecD_forall. 2 : eassumption. assumption.
+eapply dersrecD_forall. 2 : eassumption. assumption. Qed.
+ +
+Definition dersrec_appD X rules prems cs ds :=
+  iffT_D1 (@dersrec_app X rules prems cs ds).
+Definition dersrec_appL X rules prems cs ds da :=
+  fst (@dersrec_appD X rules prems cs ds da).
+Definition dersrec_appR X rules prems cs ds da :=
+  snd (@dersrec_appD X rules prems cs ds da).
+Definition dersrec_appJ X rules prems cs ds :=
+  iffT_D2 (@dersrec_app X rules prems cs ds).
+Definition dersrec_appI X rules prems cs ds :=
+  curry (@dersrec_appJ X rules prems cs ds).
+ +
+Lemma dersrec_single: forall X rules prems c,
+  iffT (dersrec rules prems [c]) (derrec rules prems (c : X)).
+Proof. intros. rewrite dersrec_all. rewrite ForallT_single. reflexivity. Qed.
+ +
+Definition dersrec_singleD X rs ps c := iffT_D1 (@dersrec_single X rs ps c).
+Definition dersrec_singleI X rs ps c := iffT_D2 (@dersrec_single X rs ps c).
+ +
+Lemma dersrec_map_single: forall X Y (f : X -> Y) rules prems c,
+  iffT (dersrec rules prems (map f [c])) (derrec rules prems (f c)).
+Proof. simpl. intros. apply dersrec_single. Qed.
+ +
+Lemma dersrec_map_2: forall X Y (f : X -> Y) rules prems c d,
+  iffT (dersrec rules prems (map f [c ; d]))
+    (derrec rules prems (f c) * derrec rules prems (f d)).
+Proof. intros. rewrite dersrec_all. rewrite ForallT_map_2. reflexivity. Qed.
+ +
+(* try using the induction principle derrec_all_rect *)
+Theorem derrec_trans_imp: forall X rules prems (concl : X),
+  derrec rules (derrec rules prems) concl -> derrec rules prems concl.
+Proof. intros. revert X0.
+eapply derrec_all_rect. tauto.
+intros. eapply derI. exact X0.
+apply dersrecI_all. exact X2. Qed.
+ +
+Lemma derrec_rmono_s: forall W (rulesa rulesb : rlsT W) prems,
+  rsub rulesa rulesb ->
+  (forall concl, derrec rulesa prems concl -> derrec rulesb prems concl) *
+  (forall cs, dersrec rulesa prems cs -> dersrec rulesb prems cs).
+Proof. intros. apply derrec_dersrec_rect_mut ; intros.
+- apply dpI. assumption.
+- eapply derI. unfold rsub in X. apply X. eassumption. assumption.
+- apply dlNil.
+- apply dlCons ; assumption. Qed.
+ +
+Definition derrec_rmono W rulesa rulesb prems concl rs :=
+  fst (@derrec_rmono_s W rulesa rulesb prems rs) concl.
+Definition dersrec_rmono W rulesa rulesb prems rs :=
+  snd (@derrec_rmono_s W rulesa rulesb prems rs).
+ +
+Theorem derl_derrec_trans': forall X rules prems,
+  (forall rps (concl : X), derl rules rps concl ->
+    dersrec rules prems rps -> derrec rules prems concl) *
+  (forall rps cs, dersl rules rps cs ->
+    dersrec rules prems rps -> dersrec rules prems cs).
+Proof. intros.
+apply derl_dersl_rect_mut.
+- intros. inversion X0. assumption.
+- intros. eapply derI. eassumption. tauto.
+- tauto.
+- intros ps c pss cs. intros dc dsdc dscs dspc dspps.
+apply dersrecD_all in dspps. apply dlCons.
++ apply dsdc. apply ForallT_appendD1 in dspps.
+apply dersrecI_all. exact dspps.
++ apply dspc. apply ForallT_appendD2 in dspps.
+apply dersrecI_all. exact dspps. Qed.
+ +
+Definition derl_derrec_trans X rules prems :=
+  fst (@derl_derrec_trans' X rules prems).
+Definition dersl_dersrec_trans X rules prems :=
+  snd (@derl_derrec_trans' X rules prems).
+ +
+Theorem derrec_derl_deriv': forall X rules prems,
+  (forall (concl : X),
+    derrec (derl rules) prems concl -> derrec rules prems concl) *
+  (forall cs, dersrec (derl rules) prems cs -> dersrec rules prems cs).
+Proof. intros.
+apply derrec_dersrec_rect_mut.
+- apply dpI.
+- intros. eapply derl_derrec_trans in r. eassumption. assumption.
+- apply dlNil.
+- intros. apply dlCons ; assumption. Qed.
+ +
+Definition derrec_derl_deriv X rules prems :=
+  fst (@derrec_derl_deriv' X rules prems).
+Definition dersrec_derl_deriv X rules prems :=
+  snd (@derrec_derl_deriv' X rules prems).
+ +
+Definition derl_derrec X rules prems rps (concl : X) drrc prems_cond :=
+  @derl_derrec_trans X rules prems rps (concl : X) drrc
+    (@prems_dersrec X rules prems rps prems_cond).
+ +
+Definition derl_derrec_nil X rules prems (concl : X) drrc :=
+  @derl_derrec_trans X rules prems [] (concl : X) drrc
+    (@dlNil X rules prems).
+ +
+Lemma dersl_dersrec_nil X rules prems (cs : list X):
+  dersl rules [] cs -> dersrec rules prems cs.
+Proof. induction cs ; intros. apply dlNil.
+inversion X0. destruct ps. simpl in H0. subst.
+apply dlCons. apply derl_derrec_nil. assumption. tauto.
+simpl in H0. discriminate H0. Qed.
+ +
+Lemma dersl_cons: forall X rules qs p (ps : list X),
+  dersl rules qs (p :: ps) -> sigT (fun qsa => sigT (fun qsb =>
+    prod (qs = qsa ++ qsb) (prod (derl rules qsa p) (dersl rules qsb ps)))).
+Proof. intros. inversion X0. subst.
+eapply existT. eapply existT. apply pair. reflexivity. tauto. Qed.
+ +
+Lemma dersl_app_eq: forall X rules (psa psb : list X) qs,
+  dersl rules qs (psa ++ psb) -> sigT (fun qsa => sigT (fun qsb =>
+    prod (qs = qsa ++ qsb) (prod (dersl rules qsa psa) (dersl rules qsb psb)))).
+Proof. intro. intro. intro. intro. induction psa. intros.
+apply existT with []. apply existT with qs. simpl. simpl in X0.
+apply pair. trivial.
+apply pair. apply dtNil. apply X0.
+ +
+simpl. intros. apply dersl_cons in X0.
+cD. pose (IHpsa _ X4). cD. subst.
+eapply existT. eapply existT.
+apply pair. apply app_assoc. apply pair.
+apply dtCons. assumption. assumption. assumption.
+Qed.
+ +
+Lemma derl_trans': forall X (rules : list X -> X -> Type),
+  (forall (rps : list X) (concl : X), derl rules rps concl ->
+  forall (pss : list X), dersl rules pss rps -> derl rules pss concl) *
+  (forall (rps : list X) (cs : list X), dersl rules rps cs ->
+  forall (pss : list X), dersl rules pss rps -> dersl rules pss cs).
+Proof. intros.
+apply derl_dersl_rect_mut.
+- intros. inversion_clear X0. inversion_clear X2.
+rewrite app_nil_r. assumption.
+- intros pss ps concl. intros rps dsl dsds pss0 ds0. apply dsds in ds0.
+eapply dtderI. eassumption. assumption.
+- intros. assumption.
+- intros ps c pss cs. intros d dsd dsl dsds pss0 dspps.
+apply dersl_app_eq in dspps. cD. subst. apply dtCons.
+apply dsd. assumption. apply dsds. assumption. Qed.
+ +
+Definition derl_trans X rules pss rps concl d :=
+  fst (@derl_trans' X rules) rps concl d pss.
+Definition dersl_trans X rules pss rps cs ds :=
+  snd (@derl_trans' X rules) rps cs ds pss.
+ +
+(* alternatively, just induction on the list of conclusions *)
+Lemma dersl_trans_alt: forall X (rules : list X -> X -> Type)
+           (cs rps : list X), dersl rules rps cs ->
+         forall (pss : list X), dersl rules pss rps -> dersl rules pss cs.
+Proof. intro. intro. intro.
+induction cs.
+intros. inversion X0. subst. assumption.
+intros. apply dersl_cons in X0. cD. subst.
+apply dersl_app_eq in X1. cD. subst.
+apply dtCons. eapply derl_trans. eassumption. assumption.
+firstorder. Qed.
+ +
+Theorem derl_dersl_deriv': forall X rules,
+  (forall prems (concl : X),
+    derl (derl rules) prems concl -> derl rules prems concl) *
+  (forall prems cs,
+    dersl (derl rules) prems cs -> dersl rules prems cs).
+Proof. intros.
+apply derl_dersl_rect_mut.
+- intro. apply asmI.
+- intros. eapply derl_trans. eassumption. assumption.
+- apply dtNil.
+- intros. apply dtCons. assumption. assumption. Qed.
+ +
+Definition derl_deriv' X rules := fst (@derl_dersl_deriv' X rules).
+Definition dersl_deriv' X rules := snd (@derl_dersl_deriv' X rules).
+Definition derl_deriv X rules := rsubI _ _ (@derl_deriv' X rules).
+Definition dersl_deriv X rules := rsubI _ _ (@dersl_deriv' X rules).
+ +
+Theorem derl_dersl_mono': forall X rulesa rulesb, rsub rulesa rulesb ->
+  (forall prems (concl : X),
+    derl rulesa prems concl -> derl rulesb prems concl) *
+  (forall prems cs,
+    dersl rulesa prems cs -> dersl rulesb prems cs).
+Proof. intros X rulesa rulesb rsab.
+apply derl_dersl_rect_mut.
+- apply asmI.
+- intros. eapply dtderI. unfold rsub in rsab.
+apply rsab. eassumption. assumption.
+- apply dtNil.
+- intros. apply dtCons. assumption. assumption. Qed.
+ +
+Definition derl_mono' X rulesa rulesb rsab :=
+  fst (@derl_dersl_mono' X rulesa rulesb rsab).
+Definition dersl_mono' X rulesa rulesb rsab :=
+  snd (@derl_dersl_mono' X rulesa rulesb rsab).
+ +
+Definition derl_mono X rulesa rulesb rsab :=
+  rsubI _ _ (@derl_mono' X rulesa rulesb rsab).
+Definition dersl_mono X rulesa rulesb rsab :=
+  rsubI _ _ (@dersl_mono' X rulesa rulesb rsab).
+ +
+Lemma derrec_nil_derl_s X rules: (forall concl,
+  derrec rules (@emptyT X) concl -> derl rules [] concl) *
+  (forall cs, dersrec rules (@emptyT X) cs -> dersl rules [] cs).
+Proof.
+apply derrec_dersrec_rect_mut ; intros.
+- inversion p.
+- eapply dtderI ; eassumption.
+- apply dtNil.
+- eapply dtCons_eq. eassumption. eassumption. tauto. Qed.
+ +
+Definition derrec_nil_derl X rules := fst (@derrec_nil_derl_s X rules).
+Definition dersrec_nil_dersl X rules := snd (@derrec_nil_derl_s X rules).
+ +
+Definition derI_rules_mono X rules rulesb prems ps concl rs fuv :=
+  @derI X rulesb prems ps concl (@rsub_imp _ _ rules rulesb rs ps concl fuv).
+(*
+Check derrec_trans_imp.
+Check derl_derrec_trans.
+Check derrec_derl_deriv.
+Check dersl_app_eq.
+Check derl_trans.
+Check dersl_trans.
+Check derl_deriv.
+*)

+ +
+
+ +
+induction for two proof trees +
+
+ +
+Lemma derrec_all_rect2:
+  forall X Y (rulesx : list X -> X -> Type) (rulesy : list Y -> Y -> Type)
+    (premsx : X -> Type) (premsy : Y -> Type) (Q : X -> Y -> Type),
+    (forall px, premsx px -> forall cy, derrec rulesy premsy cy -> Q px cy) ->
+    (forall py, premsy py -> forall cx, derrec rulesx premsx cx -> Q cx py) ->
+    (forall psx cx psy cy, rulesx psx cx -> rulesy psy cy ->
+      dersrec rulesx premsx psx -> dersrec rulesy premsy psy ->
+      ForallT (fun px => Q px cy) psx -> ForallT (Q cx) psy -> Q cx cy) ->
+    forall (conclx : X), derrec rulesx premsx conclx ->
+    forall (concly : Y), derrec rulesy premsy concly ->
+    Q conclx concly.
+Proof. intros until conclx. intro Dx.
+eapply (derrec_all_rect (Q := fun conclx =>
+  forall concly : Y, derrec rulesy premsy concly -> Q conclx concly)).
+intros. apply X0. exact X3. exact X4.
+intros until concly. intro Dy.
+eapply (derrec_all_rect (Q := Q concl)).
+intros. apply X1. exact X6. eapply derI ; eassumption.
+intros. eapply X2. eassumption. eassumption. assumption. assumption.
+eapply ForallT_impl in X5. exact X5.
+intros. simpl. apply X9. eapply derI ; eassumption.
+assumption. assumption. assumption. Qed.
+(*
+Check derrec_all_rect2.
+*)

+(* version with no premises *)
+Definition derrec_all_rect2_nops X Y rulesx rulesy Q :=
+  @derrec_all_rect2 X Y rulesx rulesy emptyT emptyT Q
+  (@emptyT_any' X _) (@emptyT_any' Y _).
+(*
+Check derrec_all_rect2_nops.
+*)

+
+ +
+admissibility +
+
+ +
+Inductive adm X rules ps c : Type :=
+  | admI : (dersrec rules (@emptyT X) ps -> derrec rules (@emptyT X) c) ->
+    adm X rules ps c.
+ +
+Definition admD X rules ps c (a : @adm X rules ps c) :=
+  match a with | admI d => d end.
+Definition admDs X rules p c a d := @admD X rules [p] c a (dersrec_singleI d).
+ +
+Lemma derl_sub_adm X rules ps c : @derl X rules ps c -> adm rules ps c.
+Proof. intro. apply admI. apply derl_derrec_trans. assumption. Qed.
+ +
+Definition rsub_derl_adm X rules := rsubI _ _ (@derl_sub_adm X rules).
+ +
+Definition in_adm X rules ps c r := derl_sub_adm (@in_derl X rules ps c r).
+Definition rsub_adm X rules := rsubI _ _ (@in_adm X rules).
+ +
+Lemma derrec_adm' X rls:
+  (forall c, derrec (adm rls) (@emptyT X) c -> derrec rls (@emptyT X) c) *
+  (forall cs, dersrec (adm rls) (@emptyT X) cs -> dersrec rls (@emptyT X) cs).
+Proof. apply derrec_dersrec_rect_mut ; intros.
+- inversion p.
+- inversion r. apply X1. apply X0.
+- apply dlNil.
+- apply dlCons ; assumption. Qed.
+ +
+Definition derrec_adm X rls := fst (@derrec_adm' X rls).
+Definition dersrec_adm X rls := snd (@derrec_adm' X rls).
+ +
+Lemma adm_adm X rules ps c : @adm X (adm rules) ps c -> adm rules ps c.
+Proof. intros aa. inversion aa. apply admI. intros dps.
+apply derrec_adm. apply X0. eapply dersrec_rmono.
+apply rsubI. apply in_adm. assumption. Qed.
+ +
+Lemma derl_adm_s X rules :
+  (forall ps (c : X), derl (adm rules) ps c -> adm rules ps c) *
+  (forall ps cs, dersl (adm rules) ps cs -> ForallT (adm rules ps) cs).
+Proof. apply derl_dersl_rect_mut ; intros.
+- apply admI. intro. inversion X0. assumption.
+- apply admI. destruct r. intros dpss. apply d0.
+apply dersrecI_forall. intros c icp.
+eapply ForallTD_forall in X0.
+destruct X0. apply d1. apply dpss. apply icp.
+- apply ForallT_nil.
+- apply ForallT_cons. apply admI. inversion X0.
+intro. apply X2. apply dersrec_appL in X3. assumption.
+apply ForallTI_forall. intros x ixcs.
+apply admI. intros dsa.
+eapply ForallTD_forall in X1.
+inversion X1. apply X2. apply dersrec_appR in dsa.
+exact dsa. exact ixcs. Qed.
+ +
+Definition derl_adm X rules := fst (@derl_adm_s X rules).
+Definition dersl_adm X rules := snd (@derl_adm_s X rules).
+ +
+(* also adm (derl rules) = adm rules *)
+ +
+(* plug-in replacement for derl_derrec_trans *)
+Lemma adm_derrec_trans X rules rps concl: @adm X rules rps concl ->
+  dersrec rules (@emptyT X) rps -> derrec rules (@emptyT X) concl.
+Proof. intros a drs. destruct a. apply d. apply drs. Qed.
+ +
+Lemma adm_single_trans X rules prems p c:
+  adm rules prems p -> @adm X rules [p] c -> adm rules prems c.
+Proof. split. destruct X0. inversion X1.
+intro dps. apply X0. right. apply (d dps). left. Qed.
+ +
+Lemma derrec_eq_swap : forall (T : Type) rules prems G H
+    (pf : (G : T) = H),
+    derrec rules prems G ->
+    derrec rules prems H.
+Proof. intros. subst. assumption. Qed.
+ +
+Lemma dersrec_double: forall X rules prems c1 c2,
+  iffT (dersrec rules prems [c1;c2]) ((derrec rules prems (c1 : X)) * (derrec rules prems (c2 : X))).
+Proof.
+  intros. split; intros H.
+  split; (eapply dersrecD_forall; [apply H |]).
+  constructor 1. reflexivity.
+  constructor 2. constructor 1. reflexivity.
+  eapply dersrecI_forall. intros c Hc.
+  inversion Hc as [ | ? ? H2]; subst. apply H.
+  inversion H2 as [ | ? ? H3]; subst. apply H.
+  inversion H3.
+Qed.
+ +
+Definition dersrec_doubleD X rs ps c1 c2 := iffT_D1 (@dersrec_double X rs ps c1 c2).
+
+
+ +
+ + + diff --git a/General.dd_fc.html b/General.dd_fc.html new file mode 100644 index 0000000..fa1a565 --- /dev/null +++ b/General.dd_fc.html @@ -0,0 +1,865 @@ + + + + + + + + + + + + + +
+
+

General.dd_fc

+ +
+ +
+
+ +
+results relating to derivation trees (derrec, dersrec) as data structures, + like Isabelle dertrees, rather than purely as properties of conclusions, + including use of derrec_fc ie without the conclusion as part of the type +
+
+ +
+Require Export List.
+Set Implicit Arguments.
+Export ListNotations.
+ +
+Require Import Coq.Program.Equality. (* for dependent induction/destruction *)
+ +
+Require Import genT gen ddT existsT.
+Require Import PeanoNat.
+Require Import Lia.
+ +
+(* tried to do an inductive property where property Q also involved the 
+proof tree (as well as the endsequent): this created a problem that
+the list of proof trees which are part of the dersrec object are not 
+all of the same type - so one cannot go from 
+ds : dersrec rules prems concls to ForallT (dersrec rules prems ??) ds'
+instead need to define allPder and do the following *)

+ +
+Inductive allPder X (rules : rlsT X) (prems : X -> Type) P :
+  forall concls : list X, dersrec rules prems concls -> Type :=
+  | allPder_Nil : @allPder X rules prems P [] (dlNil rules prems)
+  | allPder_Cons : forall seq seqs d, P seq d -> forall ds,
+    @allPder X rules prems P seqs ds ->
+    @allPder X rules prems P (seq :: seqs) (dlCons d ds)
+  .
+ +
+Lemma allPderD : forall X rules prems Q ps (dpss : dersrec rules prems ps) p,
+  allPder Q dpss -> InT (p : X) ps -> {d : derrec rules prems p & Q p d}.
+Proof. induction ps.
+intros. inversion X1.
+intros dpss p adp inp. inversion adp. subst.
+inversion inp ; subst.
+exists d. assumption.
+clear X0 inp adp. exact (IHps ds p X1 X2). Qed.
+ +
+(* destruct for allPder dlCons *)
+Lemma allPder_dlConsD: forall X rules prems Q seq seqs d ds,
+  @allPder X rules prems Q (seq :: seqs) (dlCons d ds) ->
+    Q seq d * allPder Q ds.
+Proof.
+intros. (* inversion X0 produces existT equalities *)
+(* induction X0 produces trivial subgoal 2, unsolvable subgoal 1 *)
+(* dependent induction X0. OK, but irrelevant IHX0, trivial subgoal *)
+dependent destruction X0.
+split ; assumption. Qed.
+ +
+Definition derrec_rect_mut_all X (rules : rlsT X) prems Q cl1 cl2 :=
+  derrec_rect_mut Q (@allPder X rules prems Q) cl1 cl2
+    (allPder_Nil Q) (@allPder_Cons X rules prems Q).
+(*
+Check derrec_rect_mut_all.
+*)

+Inductive in_dersrec X (rules : rlsT X) prems concl
+  (d : derrec rules prems concl) :
+  forall concls, dersrec rules prems concls -> Type :=
+  | in_dersrec_hd : forall concls ds, in_dersrec d
+    (@dlCons X rules prems concl concls d ds)
+  | in_dersrec_tl : forall concl' d' concls ds, in_dersrec d ds ->
+    in_dersrec d (@dlCons X rules prems concl' concls d' ds)
+  .
+ +
+Inductive is_nextup X (rules : rlsT X) prems (concl : X) (concls : list X)
+  (ds : dersrec rules prems concls) : derrec rules prems concl -> Type :=
+  | is_nextupI : forall rps, is_nextup ds (derI concl rps ds)
+  (* can't make this next line work
+  | is_nextup_nil : is_nextup (dlNil rules prems) (dpI _ _ _ _) 
+  *)

+  .
+ +
+Inductive in_nextup X (rules : rlsT X) prems (concln concl : X)
+  (dn : derrec rules prems concln) (d : derrec rules prems concl) : Type :=
+  | in_nextupI : forall concls (ds : dersrec rules prems concls),
+      is_nextup ds d -> in_dersrec dn ds -> in_nextup dn d
+  .
+ +
+Lemma in_drs_concl_in W rules ps (cn : W) (drs : dersrec rules emptyT ps)
+  (dtn : derrec rules emptyT cn) : in_dersrec dtn drs -> InT cn ps.
+Proof. intro ind. induction ind. apply InT_eq.
+apply InT_cons. assumption. Qed.
+ +
+Lemma in_nextup_concl_in W rules ps (concl cn : W) rpc
+  (drs : dersrec rules emptyT ps) (dtn : derrec rules emptyT cn) :
+  in_nextup dtn (derI concl rpc drs) -> InT cn ps.
+Proof. intro ind. inversion ind. inversion X. subst.
+dependent destruction H2. clear H1 rps0 ind X.
+exact (in_drs_concl_in X0). Qed.
+ +
+Lemma all_in_d_allP: forall X rules prems Q ps (dpss : dersrec rules prems ps),
+  (forall (p : X) (d : derrec rules prems p), in_dersrec d dpss -> Q p d) ->
+  allPder Q dpss.
+Proof. induction dpss. intros. apply allPder_Nil.
+intros. apply allPder_Cons. apply X0. apply in_dersrec_hd.
+apply IHdpss. intros. apply X0. apply in_dersrec_tl. assumption. Qed.
+(* alternative proof, longer, shows need to use dependent inversion 
+Proof. induction ps. intros. dependent inversion dpss. apply allPder_Nil.
+intro. dependent inversion dpss. subst. 
+intros.  apply allPder_Cons. apply X0. apply in_dersrec_hd.
+apply IHps. intros. apply X0. apply in_dersrec_tl. assumption. Qed.
+*)

+ +
+Lemma allP_all_in_d: forall X rules prems Q ps (dpss : dersrec rules prems ps),
+  allPder Q dpss ->
+  forall (p : X) (d : derrec rules prems p), in_dersrec d dpss -> Q p d.
+Proof. induction ps. intro. dependent inversion dpss.
+intros. inversion X1.
+intro. dependent inversion dpss. subst.
+intro. (* inversion X0 gives existT equalities *)
+dependent destruction X0.
+intros. (* inversion X1 gives existT equalities *)
+dependent destruction X1. assumption.
+eapply IHps. eassumption. assumption. Qed.
+ +
+Lemma allPderD_in :
+  forall X rules prems Q ps (dpss : dersrec rules prems ps) p,
+    allPder Q dpss -> InT (p : X) ps ->
+      {d : derrec rules prems p & in_dersrec d dpss & Q p d}.
+Proof. induction ps.
+intros. inversion X1.
+intros dpss p adp inp. dependent destruction adp.
+inversion inp ; subst.
+exists d. apply in_dersrec_hd. assumption.
+pose (IHps ds p adp X0). destruct s. (* cD doesn't work here - why?? *)
+exists x. apply in_dersrec_tl. assumption. assumption. Qed.
+(*
+Check allPderD_in.
+*)

+Fixpoint derrec_height X rules prems concl
+  (der : @derrec X rules prems concl) :=
+  match der with
+    | dpI _ _ _ _ => 0
+    | derI _ _ ds => S (dersrec_height ds)
+  end
+with dersrec_height X rules prems concls
+  (ders : @dersrec X rules prems concls) :=
+  match ders with
+    | dlNil _ _ => 0
+    | dlCons d ds => max (derrec_height d) (dersrec_height ds)
+  end.
+ +
+Fixpoint derrec_size X rules prems concl
+  (der : @derrec X rules prems concl) :=
+  match der with
+    | dpI _ _ _ _ => 0
+    | derI _ _ ds => S (dersrec_size ds)
+  end
+with dersrec_size X rules prems concls
+  (ders : @dersrec X rules prems concls) :=
+  match ders with
+    | dlNil _ _ => 0
+    | dlCons d ds => (derrec_size d) + (dersrec_size ds)
+  end.
+ +
+Definition derrec_concl X rules prems concl
+  (der : @derrec X rules prems concl) :=
+  match der with
+    | dpI _ _ c _ => c
+    | derI c _ _ => c
+  end.
+ +
+Fixpoint dersrec_concls X rules prems concls
+  (ders : @dersrec X rules prems concls) :=
+  match ders with
+    | dlNil _ _ => []
+    | dlCons d ds => derrec_concl d :: dersrec_concls ds
+  end.
+ +
+Definition der_botr_ps X rules prems concl
+  (der : @derrec X rules prems concl) :=
+  match der with
+    | dpI _ _ _ _ => []
+    | @derI _ _ _ ps _ _ _ => ps
+  end.
+ +
+Definition dersrec_hd X rules prems c cs
+  (ders : @dersrec X rules prems (c :: cs)) : derrec rules prems c :=
+  match
+    ders in (dersrec _ _ l) return match l with
+                                   | [] => IDProp
+                                   | c1 :: _ => derrec rules prems c1
+                                   end
+  with
+  | dlNil _ _ => idProp
+  | dlCons d _ => d
+  end.
+ +
+Definition dersrec_tl X rules prems c cs
+  (ders : @dersrec X rules prems (c :: cs)) :=
+  match
+    ders as ders0 in (dersrec _ _ l)
+    return
+      (match l as x return (dersrec rules prems x -> Type) with
+       | [] => fun _ : dersrec rules prems [] => IDProp
+       | c1 :: c0 => fun _ : dersrec rules prems (c1 :: c0) => dersrec rules prems c0
+       end ders0)
+  with
+  | dlNil _ _ => idProp
+  | dlCons _ ds => ds
+  end.
+ +
+Definition dersrec_singleD' X rules prems c
+  (ders : @dersrec X rules prems [c]) := dersrec_hd ders.
+ +
+Definition dersrec_singleI' X rules prems c
+  (d : @derrec X rules prems c) := dlCons d (@dlNil X rules prems).
+ +
+Definition dersrec_single' X rules prems c :=
+  (@dersrec_singleD' X rules prems c, @dersrec_singleI' X rules prems c).
+ +
+(*
+Lemma in_dersrec_single X rs ps c (ds : @dersrec X rs ps c) :
+  in_dersrec (dersrec_singleD ds) ds.
+Proof. dependent destruction ds.  (* dependent induction ds. also seems OK *)
+HOW TO CONTINUE PROOF ?? NB works better for dersrec_singleD'
+*)

+ +
+Lemma botr_ps_der W rules prems c (d : derrec rules prems c) :
+  @dersrec W rules prems (der_botr_ps d).
+Proof. destruct d ; simpl. apply dlNil. apply d. Qed.
+ +
+Lemma in_dersrec_single' X rs ps c (ds : @dersrec X rs ps [c]) :
+  in_dersrec (dersrec_singleD' ds) ds.
+Proof. dependent destruction ds. (* dependent induction ds. also seems OK,
+but dependent inversion gives a type error *)

+unfold dersrec_singleD'. simpl. apply in_dersrec_hd. Qed.
+ +
+(* can't do this, gives The term "ds" has type "dersrec rules prems l"
+  while it is expected to have type "dersrec rules prems ".  
+Fixpoint derrec_nextup X rules prems concl
+  (der : @derrec X rules prems concl) :=
+  match der with 
+    | dpI _ _ _ _ => dlNil rules prems 
+    | derI _ _ ds => ds
+  end.
+*)

+ +
+Lemma dersrec_hd_eq X rs ps c cs
+  (d : @derrec X rs ps c) (ds : @dersrec X rs ps cs) :
+  dersrec_hd (dlCons d ds) = d.
+Proof. simpl. reflexivity. Qed.
+ +
+Lemma dersrec_tl_eq X rs ps c cs
+  (d : @derrec X rs ps c) (ds : @dersrec X rs ps cs) :
+  dersrec_tl (dlCons d ds) = ds.
+Proof. simpl. reflexivity. Qed.
+ +
+Lemma in_drs_drs_hd X rs ps c cs (ds : @dersrec X rs ps (c :: cs)) :
+  in_dersrec (dersrec_hd ds) ds.
+Proof. dependent destruction ds. (* dependent induction ds. also seems OK *)
+simpl. apply in_dersrec_hd. Qed.
+ +
+Lemma dersrec_height_nil : forall X rules prems ps (ds : @dersrec X rules prems ps),
+    ps = [] -> dersrec_height ds = 0.
+Proof.
+induction ds.
+- simpl. reflexivity.
+- intro. inversion H.
+Qed.
+ +
+Lemma dersrec_height_le: forall X rules prems n ps
+  (ds : dersrec rules prems ps),
+  (forall (p : X) (d : derrec rules prems p),
+  in_dersrec d ds -> derrec_height d <= n) -> dersrec_height ds <= n.
+Proof. (* induction ps. 
+intros. inversion ds.  this step seems to do nothing *)

+induction ds.
+intros. simpl. apply le_0_n.
+intros. simpl. apply Nat.max_lub.
+apply H. apply in_dersrec_hd.
+apply IHds. intros. apply H. apply in_dersrec_tl. assumption. Qed.
+ +
+Lemma le_dersrec_height: forall X rules prems n ps
+  (ds : dersrec rules prems ps),
+  forall (p : X) (d : derrec rules prems p),
+  in_dersrec d ds -> n <= derrec_height d -> n <= dersrec_height ds.
+Proof. (* induction ps. 
+intros. inversion ds.  this step seems to do nothing *)

+(* this doesn't work - why ??
+induction ds ; intros ; inversion X0 ; subst ; simpl ; rewrite Nat.max_le_iff.
+left. assumption.
+right.  eapply IHds. 2: eassumption.
+WHAT NOW ???
+*)

+intros. induction X0 ; simpl ; rewrite Nat.max_le_iff ; tauto. Qed.
+ +
+(*
+Fixpoint aderrec_height X 
+  (rules : list X -> X -> Prop) (prems : X -> Prop) concl 
+  (der : @aderrec X rules prems concl) :=
+  match der with 
+    | adpI _ _ _ _ => 0
+    | aderI _ _ _ => 0
+  end.
+  *)

+ +
+Fixpoint derl_height X
+  (rules : list X -> X -> Prop) (prems : list X) (concl : X)
+  (der : @derl X rules prems concl) :=
+  match der with
+    | asmI _ _ => 0
+    | dtderI _ _ ds => S (dersl_height ds)
+  end
+with dersl_height X (rules : list X -> X -> Prop) (prems concls : list X)
+  (ders : @dersl X rules prems concls) :=
+  match ders with
+    | dtNil _ => 0
+    | dtCons d ds => max (derl_height d) (dersl_height ds)
+  end.
+ +
+Lemma der_concl_eq: forall X (rules : rlsT X) prems concl
+  (d : derrec rules prems concl), derrec_concl d = concl.
+Proof. dependent inversion d ; simpl ; reflexivity. Qed.
+ +
+Lemma ders_concls_eq: forall X (rules : rlsT X) prems concls
+  (ds : dersrec rules prems concls), dersrec_concls ds = concls.
+Proof. induction ds ; simpl. reflexivity.
+rewrite -> (der_concl_eq d). rewrite IHds. reflexivity. Qed.
+ +
+
+ +
+der(s)rec_fc(s) - trees without conclusion as part of the type +
+
+ +
+Inductive derrec_fc X rules (prems : X -> Type) : Type :=
+  | fcI : forall concl, derrec rules prems concl -> derrec_fc rules prems.
+ +
+Inductive dersrec_fcs X rules (prems : X -> Type) : Type :=
+  | fcsI : forall concls, dersrec rules prems concls -> dersrec_fcs rules prems.
+ +
+Inductive in_nextup_fc X (rules : rlsT X) prems :
+    relationT (derrec_fc rules prems) :=
+  | in_nextup_fcI : forall concln concl
+    (dn : derrec rules prems concln) (d : derrec rules prems concl),
+    in_nextup dn d -> in_nextup_fc (fcI dn) (fcI d)
+  .
+ +
+Lemma AccT_in_nextup_fc X rules prems dt: AccT (@in_nextup_fc X rules prems) dt.
+Proof. destruct dt. revert d. revert concl.
+eapply derrec_rect_mut_all.
+- intros. apply AccT_intro. intros y iny.
+dependent destruction iny. inversion i. inversion X0.
+- intros * apd. apply AccT_intro. intros y iny.
+dependent destruction iny. inversion i. dependent destruction X0.
+exact (allP_all_in_d apd X1). Qed.
+ +
+Fixpoint dersrec_trees X rules prems concls
+  (ders : @dersrec X rules prems concls) :=
+  match ders with
+    | dlNil _ _ => []
+    | dlCons d ds => fcI d :: dersrec_trees ds
+  end.
+ +
+Definition nextup W rules prems (dt : @derrec_fc W rules prems) :=
+  match dt with
+    | fcI (dpI _ _ _ _) => []
+    | fcI (derI _ _ ds) => dersrec_trees ds
+  end.
+ +
+Definition derrec_fc_concl X rules prems
+  (der : @derrec_fc X rules prems) :=
+  match der with
+    | fcI d => derrec_concl d
+  end.
+ +
+Definition dersrec_fc_concls X rules prems
+  (ders : @dersrec_fcs X rules prems) :=
+  match ders with
+    | fcsI ds => dersrec_concls ds
+  end.
+ +
+(* note, this includes case where the tree is simply a premise *)
+Inductive botRule_fc X rules prems (der : @derrec_fc X rules prems) : rlsT X :=
+  | botRule_fcI : botRule_fc der
+    (map (@derrec_fc_concl _ _ _) (nextup der)) (derrec_fc_concl der).
+ +
+(* this fails, d has type "derrec rules prems x", but x not in scope
+Fixpoint derrec_of_fc X rules prems 
+  (der : @derrec_fc X rules prems) :=
+  match der with 
+    | fcI d => d
+  end.
+  *)

+ +
+(* while we can't get something of type derrec rules prems _
+  from something of type derrec_fc ..., we can get it and then
+  apply any function to it whose result type doesn't involve the conclusion *)

+Definition derrec_fc_size X rules prems
+  (der : @derrec_fc X rules prems) :=
+  match der with
+    | fcI d => derrec_size d
+  end.
+ +
+Definition dersrec_fc_size X rules prems
+  (ders : @dersrec_fcs X rules prems) :=
+  match ders with
+    | fcsI ds => dersrec_size ds
+  end.
+ +
+Definition derrec_fc_height X rules prems
+  (der : @derrec_fc X rules prems) :=
+  match der with
+    | fcI d => derrec_height d
+  end.
+ +
+Definition dersrec_fc_height X rules prems
+  (ders : @dersrec_fcs X rules prems) :=
+  match ders with
+    | fcsI ds => dersrec_height ds
+  end.
+ +
+Lemma der_fc_concl_eq: forall X (rules : rlsT X) prems concl
+  (d : derrec rules prems concl), derrec_fc_concl (fcI d) = concl.
+Proof. simpl. apply der_concl_eq. Qed.
+ +
+Lemma dersrec_trees_concls_eq X rules prems ps (ds : dersrec rules prems ps) :
+  map (@derrec_fc_concl X rules prems) (dersrec_trees ds) = ps.
+Proof. induction ds. simpl. reflexivity.
+simpl. rewrite (der_concl_eq d). rewrite IHds. reflexivity. Qed.
+ +
+Lemma der_botr_ps_eq X rules prems c (dt : derrec rules prems c) :
+  map (@derrec_fc_concl X rules prems) (nextup (fcI dt)) = der_botr_ps dt.
+Proof. destruct dt ; simpl. reflexivity. apply dersrec_trees_concls_eq. Qed.
+ +
+Lemma der_der_fc X rules prems (der : @derrec_fc X rules prems) :
+  derrec rules prems (derrec_fc_concl der).
+Proof. destruct der. simpl. rewrite der_concl_eq. exact d. Qed.
+ +
+Lemma ders_ders_fcs X rules prems (ders : @dersrec_fcs X rules prems) :
+  dersrec rules prems (dersrec_fc_concls ders).
+Proof. destruct ders. simpl. rewrite ders_concls_eq. exact d. Qed.
+ +
+Lemma in_drs_trees: forall X rules prems cs ds c (d : derrec rules prems c),
+  in_dersrec d ds -> InT (fcI d) (@dersrec_trees X rules prems cs ds).
+Proof. intros. induction X0 ; simpl.
+apply InT_eq. apply InT_cons. assumption. Qed.
+ +
+Lemma in_trees_drs: forall X rules prems cs ds c (d : derrec rules prems c),
+  InT (fcI d) (@dersrec_trees X rules prems cs ds) -> in_dersrec d ds.
+Proof. induction cs ; intro ; dependent inversion ds ; simpl ; intros.
+inversion X0.
+(* inversion X0. injection H2. gives existT equality *)
+subst. dependent destruction X0. apply in_dersrec_hd.
+apply in_dersrec_tl. apply IHcs. assumption. Qed.
+ +
+Lemma der_botRule W rules (dt : derrec_fc rules emptyT) :
+  {ps : list W & {c : W & rules ps c & botRule_fc dt ps c}}.
+Proof. destruct dt. destruct d. destruct e.
+exists ps. exists concl. exact r.
+pose botRule_fcI.
+specialize (b W rules emptyT (fcI (derI concl r d))).
+simpl in b. rewrite dersrec_trees_concls_eq in b. exact b. Qed.
+ +
+Lemma botRule_fc_concl W rules prems ps (c : W) (dt : derrec_fc rules prems) :
+  botRule_fc dt ps c -> derrec_fc_concl dt = c.
+Proof. intro br. destruct br. reflexivity. Qed.
+ +
+Lemma botRule_fc_rules W rules ps (c : W) (dt : derrec_fc rules emptyT) :
+  botRule_fc dt ps c -> rules ps c.
+Proof. intro br. destruct br. destruct dt.
+rewrite (der_fc_concl_eq d).
+destruct d. destruct e. simpl.
+rewrite (dersrec_trees_concls_eq d). exact r. Qed.
+ +
+Lemma botRule_fc_drs W rules prems ps (c : W) (dt : derrec_fc rules prems) :
+  botRule_fc dt ps c -> dersrec rules prems ps.
+Proof. intro br. destruct br. destruct dt.
+destruct d. simpl. apply dlNil.
+simpl. rewrite (dersrec_trees_concls_eq d). exact d. Qed.
+ +
+Lemma botRule_fc_ps W rules prems ps (c : W) (dt : derrec_fc rules prems) :
+  botRule_fc dt ps c -> map (@derrec_fc_concl W rules prems) (nextup dt) = ps.
+Proof. intro br. destruct br. destruct dt. reflexivity. Qed.
+ +
+Lemma get_botrule W rules prems (c : W) (dt : derrec rules prems c) :
+  botRule_fc (fcI dt) (der_botr_ps dt) c.
+Proof. rewrite <- der_botr_ps_eq.
+  eapply eq_rect. apply botRule_fcI. apply der_fc_concl_eq. Qed.
+ +
+Definition bot_is_rule W rules (c : W) (dt : derrec rules emptyT c) :=
+  botRule_fc_rules (get_botrule dt).
+ +
+Lemma botRule_fc_prems W rules prems (c : W) (dt : derrec rules prems c) ps c' :
+  botRule_fc (fcI dt) ps c' -> (c = c') * (der_botr_ps dt = ps).
+Proof. intro br. rewrite <- der_botr_ps_eq. rewrite (botRule_fc_ps br).
+split. destruct br. rewrite der_fc_concl_eq. reflexivity. reflexivity. Qed.
+ +
+Lemma in_nextup_eqv W rules prems (concln concl : W)
+  (dtn : derrec rules prems concln) (dt : derrec rules prems concl) :
+  iffT (in_nextup dtn dt) (InT (fcI dtn) (nextup (fcI dt))).
+Proof. apply pair ; intros.
+- destruct X. destruct i. simpl. exact (in_drs_trees i0).
+- simpl in X. destruct dt. inversion X.
+  apply in_trees_drs in X.
+  eapply in_nextupI. apply is_nextupI. exact X. Qed.
+ +
+Definition in_nextup_nu W rules prems concln concl dtn dt :=
+  iffT_D1 (@in_nextup_eqv W rules prems concln concl dtn dt).
+Definition nextup_in_nu W rules prems concln concl dtn dt :=
+  iffT_D2 (@in_nextup_eqv W rules prems concln concl dtn dt).
+ +
+Lemma in_nextup_fc_eqv W rules prems (dtn dt : @derrec_fc W rules prems) :
+  iffT (in_nextup_fc dtn dt) (InT dtn (nextup dt)).
+Proof. apply pair ; intros.
+- destruct X. exact (in_nextup_nu i).
+- destruct dtn. destruct dt. apply in_nextup_fcI. exact (nextup_in_nu _ X).
+Qed.
+ +
+Definition in_nextup_fc_nu W rules prems dtn dt :=
+  iffT_D1 (@in_nextup_fc_eqv W rules prems dtn dt).
+Definition nextup_in_nu_fc W rules prems dtn dt :=
+  iffT_D2 (@in_nextup_fc_eqv W rules prems dtn dt).
+ +
+(* converse to this requires is_nextup (dlNil rules prems) (dpI _ _ _ _) *)
+Lemma is_nextup_ndt W rules prems concls (concl : W)
+  (dts : dersrec rules prems concls)
+  (dt : derrec rules prems concl) :
+  is_nextup dts dt -> nextup (fcI dt) = dersrec_trees dts.
+Proof. unfold nextup. intros. destruct X. reflexivity. Qed.
+ +
+Lemma drs_trees_height W rules prems ps (ds : @dersrec W rules prems ps) dn:
+  InT dn (dersrec_trees ds) -> derrec_fc_height dn <= dersrec_height ds.
+Proof. induction ds ; simpl ; intro inn ; inversion inn.
+subst. simpl. apply PeanoNat.Nat.le_max_l.
+apply (Nat.le_trans _ _ _ (IHds X)). apply PeanoNat.Nat.le_max_r. Qed.
+ +
+Lemma nextup_height W rules prems dt dn: InT dn (nextup dt) ->
+  (@derrec_fc_height W rules prems dn) < derrec_fc_height dt.
+Proof. intro inn. destruct dt. destruct d ; simpl in inn. inversion inn.
+simpl. apply Nat.lt_succ_r, drs_trees_height, inn. Qed.
+ +
+Lemma fcI_inj: forall X rules prems concl (d1 : @derrec X rules prems concl) d2,
+  fcI d1 = fcI d2 -> d1 = d2.
+Proof. intros. (* injection H gives existT equality *)
+  dependent destruction H. reflexivity. Qed.
+ +
+(* this doesn't work - type of Q 
+Goal forall X rules prems Q cs (ds : @dersrec X rules prems cs),
+  allPder Q ds -> Forall2T Q cs (dersrec_trees ds).
+ *)

+ +
+Open Scope type_scope.
+ +
+Lemma dersrecD_forall_in_dersrec : forall (X : Type) (rs : list X -> X -> Type) (ps : X -> Type) (cs : list X) (ds : dersrec rs ps cs) (c : X),
+    InT c cs -> (existsT2 d : derrec rs ps c, in_dersrec d ds).
+Proof.
+  induction ds; intros c Hin.
+  inversion Hin.
+  inversion Hin.
+  + subst. exists d. constructor.
+  + subst. eapply IHds in X0. destruct X0 as [d2 Hin2].
+    exists d2. constructor 2. eapply Hin2.
+Qed.
+ +
+Lemma dersrec_double_verb: forall X rules prems c1 c2 (d : (dersrec rules prems [c1;c2])),
+    existsT2 (d1 : (derrec rules prems (c1 : X))) (d2 : (derrec rules prems (c2 : X))),
+      (in_dersrec d1 d) * (in_dersrec d2 d).
+Proof.
+  intros.
+  assert (InT c1 [c1;c2]) as Hin1. constructor. reflexivity.
+  assert (InT c2 [c1;c2]) as Hin2. constructor 2. constructor. reflexivity.
+  eapply dersrecD_forall_in_dersrec in Hin1.
+  destruct Hin1 as [d1 Hin1]. exists d1.
+  eapply dersrecD_forall_in_dersrec in Hin2.
+  destruct Hin2 as [d2 Hin2]. exists d2.
+  split. apply Hin1. apply Hin2.
+Qed.
+ +
+Definition dp {X : Type} {rules : list X -> X -> Type} {prems : X -> Type}
+  {concl : X} (der : derrec rules prems concl) := @derrec_height X rules prems concl der.
+Lemma dersrec_derrec_height : forall n {X : Type} {rules prems G}
+                                     (D2 : dersrec rules prems [G]),
+    dersrec_height D2 = n ->
+    existsT2 (D1 : derrec rules prems G),
+      @derrec_height X _ _ _ D1 = n.
+Proof.
+  intros *.
+  intros Ht.
+  remember D2 as D2'.
+  remember [G] as GG.
+  destruct D2. discriminate.
+  subst. simpl.
+  inversion HeqGG. subst.
+  exists d.
+  remember [] as l.
+  destruct D2. simpl.
+  rewrite PeanoNat.Nat.max_0_r. reflexivity.
+  discriminate.
+Qed.
+ +
+Lemma dersrec_derrec2_height : forall n {X : Type} {rules prems G1 G2}
+                                     (D2 : dersrec rules prems [G1;G2]),
+    dersrec_height D2 = n ->
+    existsT2 (D1a : derrec rules prems G1) (D1b : derrec rules prems G2),
+     n = max (@derrec_height X _ _ _ D1a) (@derrec_height X _ _ _ D1b).
+Proof.
+  intros *.
+  intros Ht.
+  remember D2 as D2'.
+  remember [G1;G2] as GG.
+  destruct D2. discriminate.
+  destruct seqs. discriminate.
+  destruct seqs. 2 : discriminate.
+  edestruct (@dersrec_derrec_height (@dersrec_height _ _ _ _ D2)_ _ _ _ D2).
+  reflexivity.
+  subst. simpl.
+  inversion HeqGG. subst.
+  exists d. exists x0.
+  rewrite e. reflexivity.
+Qed.
+ +
+Lemma dersrec_derrec_dp : forall n {X : Type} {rules prems G}
+                                     (D2 : dersrec rules prems [G]),
+    dersrec_height D2 = n ->
+    existsT2 (D1 : derrec rules prems G),
+      @dp X _ _ _ D1 = n.
+Proof. eapply dersrec_derrec_height. Qed.
+ +
+Lemma dersrec_derrec2_dp : forall n {X : Type} {rules prems G1 G2}
+                                     (D2 : dersrec rules prems [G1;G2]),
+    dersrec_height D2 = n ->
+    existsT2 (D1a : derrec rules prems G1) (D1b : derrec rules prems G2),
+      n = max (@dp X _ _ _ D1a) (@dp X _ _ _ D1b).
+Proof. eapply dersrec_derrec2_height. Qed.
+ +
+Lemma dersrec_derrec_height_le : forall {T : Type} rules prems ps p
+    (ds : dersrec rules prems ps)
+    (d : derrec rules prems p),
+    in_dersrec d ds ->
+    derrec_height d <= @dersrec_height T _ _ _ ds.
+Proof.
+  intros T rules prems ps p ds d Hin.
+  eapply le_dersrec_height.
+  2 : eapply le_n.
+  assumption.
+Qed.
+ +
+Lemma dp_same : forall {T : Type} {rules prems} (l1 l2 : list T)
+     (D1 : derrec rules prems l1)
+    (Heq : l1 = l2),
+    dp (eq_rect _ (fun l => derrec rules prems l) D1 l2 Heq) = dp D1.
+Proof. induction D1; intros Heq; subst; reflexivity. Qed.
+ +
+Lemma dp_same_fun : forall {T T2 : Type} {rules prems} (l1 l2 : list T) (f : list T -> T2)
+     (D1 : derrec rules prems (f l1))
+    (Heq : l1 = l2),
+    dp (eq_rect _ (fun l => derrec rules prems (f l)) D1 l2 Heq) = dp D1.
+Proof. intros; inversion D1; subst; reflexivity. Qed.
+ +
+Lemma derrec_dp_same :
+  forall {X : Type} rules (prems : X -> Type) G H (D1 : derrec rules prems G),
+    G = H ->
+    existsT2 (D2 : derrec rules prems H), dp D1 = dp D2.
+Proof. intros. subst. exists D1. reflexivity. Qed.
+ +
+Lemma derrec_dp_same2 :
+  forall {X : Type} rules (prems : X -> Type) G (D1 : derrec rules prems G) H,
+    G = H ->
+    existsT2 (D2 : derrec rules prems H), dp D1 = dp D2.
+Proof. intros. subst. exists D1. reflexivity. Qed.
+ +
+Definition get_D {X} rules prems G H D pf :=
+(let (D', HD') := (fun (X : Type) (rules : list X -> X -> Type) (prems : X -> Type)
+  (G H : X) (D1 : derrec rules prems G) (H0 : G = H) =>
+eq_rect_r
+  (fun G0 : X =>
+   forall D2 : derrec rules prems G0,
+   existsT2 D3 : derrec rules prems H, dp D2 = dp D3)
+  (fun D2 : derrec rules prems H =>
+     existT (fun D3 : derrec rules prems H => dp D2 = dp D3) D2 eq_refl) H0 D1)
+              X rules prems
+G H D pf in D').
+ +
+(*
+Parameter (X : Type) (rules : list X -> X -> Type) (prems : X -> Type) 
+  (G H : X) (D : derrec rules prems G) (pf : G = H).
+Compute (get_D rules prems G H D pf).
+*)

+Lemma dp_get_D : forall (X : Type) (rules : list X -> X -> Type) (prems : X -> Type)
+                      (G H : X) (D : derrec rules prems G) (pf : G = H),
+    dp D = dp (get_D D pf).
+Proof. intros. subst. reflexivity. Qed.
+ +
+Definition get_dpD {X : Type} (rules : list X -> X -> Type) (prems : X -> Type) (G H : X)
+  (D : derrec rules prems G) (pf : G = H) :=
EqdepFacts.internal_eq_rew_r_dep
+   (fun (G0 : X) (pf0 : G0 = H) =>
+    forall D0 : derrec rules prems G0, dp D0 = dp (get_D D0 pf0))
+   (fun D0 : derrec rules prems H => eq_refl) pf D.
+ +
+Ltac tfm_dersrec_derrec_dp D2s D2 Hdp HdpD2 Hdp'' Hdp' :=
+  destruct (dersrec_derrec_dp D2s eq_refl) as [D2 HdpD2];
+  match goal with
+  | [ H : dp ?D1 + S (dersrec_height D2s) <= ?m |- _ ] =>
+    assert (dp D1 + (S (dp D2)) <= m) as Hdp'';
+    [rewrite HdpD2; assumption | ];
+    assert (dp D1 + dp D2 <= m - 1) as Hdp';
+    [lia | ]; clear HdpD2 D2s Hdp
+  end.
+ +
+Ltac tfm_dersrec_derrec2_dp D2s D2 Hdp HdpD2 Hdpa'' Hdpb'' Hdpa' Hdpb' HeqD2s Hmax1 Hmax2 :=
+  assert (dersrec_height D2s = dersrec_height D2s) as HeqD2s;
+  [reflexivity |];
+  destruct (dersrec_derrec2_dp D2s HeqD2s) as [D2a [D2b HdpD2]];
+  clear HeqD2s;
+  epose proof (Nat.le_max_r _ _) as Hmax1;
+  epose proof (Nat.le_max_r _ _) as Hmax2;
+  rewrite <- HdpD2 in Hmax1;
+  rewrite <- HdpD2 in Hmax2;
+  match goal with
+  | [ H : dp ?D1 + S (dersrec_height D2s) <= ?m |- _ ] =>
+  assert (dp D1 + (S (dp D2a)) <= m) as Hdpa'';
+  [lia | ];
+  assert (dp D1 + (S (dp D2b)) <= m) as Hdpb'';
+  [lia | ];
+  assert (dp D1 + (dp D2a) <= m - 1) as Hdpa';
+  [lia | ];
+  assert (dp D1 + (dp D2b) <= m - 1) as Hdpb';
+  [lia | ];
+  clear HdpD2 D2s Hdp Hmax1 Hmax2
+  end.
+
+
+ +
+ + + diff --git a/General.existsT.html b/General.existsT.html new file mode 100644 index 0000000..b1bc878 --- /dev/null +++ b/General.existsT.html @@ -0,0 +1,50 @@ + + + + + + + + + + + + + +
+
+

General.existsT

+ +
+Notation "'existsT' x .. y , p" := (sig (fun x => .. (sig (fun y => p)) ..))
+  (at level 200, x binder, right associativity,
+   format "'[' 'existsT' '/ ' x .. y , '/ ' p ']'")
+  : type_scope.
+ +
+Notation "'existsT2' x .. y , p" := (sigT (fun x => .. (sigT (fun y => p)) ..))
+  (at level 200, x binder, right associativity,
+   format "'[' 'existsT2' '/ ' x .. y , '/ ' p ']'")
+  : type_scope.
+
+
+ +
+ + + diff --git a/General.gen.html b/General.gen.html new file mode 100644 index 0000000..ed7ce79 --- /dev/null +++ b/General.gen.html @@ -0,0 +1,398 @@ + + + + + + + + + + + + + +
+
+

General.gen

+ +
+Set Implicit Arguments.
+Require Import List.
+Import ListNotations.
+ +
+Definition rsub U V f g := forall (u : U) (v : V), f u v -> g u v.
+ +
+Lemma rsub_def: forall U V (f g : U -> V -> Type),
+  @rsub U V f g = forall (u : U) (v : V), f u v -> g u v.
+Proof. intros. unfold rsub. reflexivity. Qed.
+ +
+Lemma rsub_trans U V (f g h : U -> V -> Type) :
+  rsub f g -> rsub g h -> rsub f h.
+Proof. unfold rsub. firstorder. Qed.
+ +
+Lemma rsub_id U V (f : U -> V -> Type) : rsub f f.
+Proof. unfold rsub. firstorder. Qed.
+ +
+Definition req U V f g := prod (@rsub U V f g) (rsub g f).
+ +
+Lemma req_refl U V f : @req U V f f.
+Proof. unfold req. split ; apply rsub_id. Qed.
+ +
+Lemma req_sym U V f g : @req U V f g -> @req U V g f.
+Proof. unfold req. tauto. Qed.
+ +
+Lemma req_trans U V f g h : @req U V f g -> @req U V g h -> @req U V f h.
+Proof. unfold req. intros F B. destruct F. destruct B.
+split ; eapply rsub_trans ; eassumption. Qed.
+ +
+Definition rls W := list W -> W -> Prop.
+ +
+(* lemmas which shouldn't be necessary at all! *)
+ +
+Lemma or_false: forall P : Prop, iff (or P False) P. Proof. tauto. Qed.
+Lemma false_or: forall P : Prop, iff (or False P) P. Proof. tauto. Qed.
+Lemma and_true: forall P : Prop, iff (and P True) P. Proof. tauto. Qed.
+Lemma true_and: forall P : Prop, iff (and True P) P. Proof. tauto. Qed.
+ +
+Lemma rappl: forall (A B : Prop), A -> (A -> B) -> B.
+Proof. tauto. Qed.
+ +
+Lemma appl: forall (A B : Prop), (A -> B) -> A -> B.
+Proof. tauto. Qed.
+ +
+Lemma gen_cong: forall T U f g, f = g ->
+  forall x y, x = y -> (f (x : U) : T) = g y.
+Proof. intros. subst. reflexivity. Qed.
+ +
+Lemma fun_cong: forall T U f g, f = g ->
+  forall x, (f (x : U) : T) = g x.
+Proof. intros. subst. reflexivity. Qed.
+ +
+(* similar to Coq.Init.Logic.f_equal *)
+Lemma arg_cong: forall T U f x y, x = y -> (f (x : U) : T) = f y.
+Proof. intros. subst. reflexivity. Qed.
+ +
+Lemma arg_cong_imp: forall U f x y, x = y -> f (x : U) -> f y.
+Proof. intros. subst. assumption. Qed.
+ +
+(* similar to Coq.Init.Logic.eq_rect *)
+Lemma arg_cong_imp': forall U f x y, f (x : U) -> x = y -> f y.
+Proof. intros. subst. assumption. Qed.
+ +
+Lemma arg1_cong_imp: forall U V f x y z, x = y -> f (x : U) (z : V) -> f y z.
+Proof. intros. subst. assumption. Qed.
+ +
+Lemma arg1_cong_imp': forall U V f x y z, f (x : U) (z : V) -> x = y -> f y z.
+Proof. intros. subst. assumption. Qed.
+ +
+(* iffD1, iffD2 for Type *)
+Lemma iffD1: forall x y, (x = y) -> x -> y.
+Proof. intros. subst. assumption. Qed.
+ +
+Lemma iffD2: forall x y, (x = y) -> y -> x.
+Proof. intros. subst. assumption. Qed.
+ +
+(* PiffD1, PiffD2 for Prop *)
+Lemma PiffD1: forall x y, (x <-> y) -> x -> y.
+Proof. intros. rewrite -> H in H0. assumption. Qed.
+ +
+Lemma PiffD2: forall x y, (x <-> y) -> y -> x.
+Proof. intros. rewrite <- H in H0. assumption. Qed.
+ +
+Lemma eq_TrueI: forall (P : Prop), (P -> (P <-> True)).
+intros. unfold iff. apply conj ; intro. apply I. assumption.
+Qed.
+ +
+Definition rsub_imp U V (f g : U -> V -> Type) := iffD1 (@rsub_def U V f g).
+Definition rsubI U V f g := iffD2 (@rsub_def U V f g).
+Definition rsubD U V f g := iffD1 (@rsub_def U V f g).
+ +
+(* and do req_def, reqI, reqD as for rsub *)
+ +
+(* see also eq_refl, eq_trans, eq_sym, eq_ind, eq_ind_r *)
+ +
+Ltac refl_ni :=
+  match goal with
+    | [ |- ?P = ?P ] => reflexivity
+    end.
+ +
+Lemma pair_eqI: forall T U (u v : T) (x y : U),
+  u = v -> x = y -> (u,x) = (v,y).
+Proof. intros. subst. reflexivity. Qed.
+ +
+Ltac rename_last name :=
+  match goal with
+    | [ K : _ |- _ ] => rename K into name
+    end.
+ +
+Ltac clear_one :=
+  match goal with
+    | [ K : _ |- _ ] => clear K
+    end.
+ +
+Ltac cE :=
+  repeat match goal with
+    | [ H : _ /\ _ |- _ ] => inversion_clear H
+    | [ H : ex _ |- _ ] => inversion_clear H
+    | [ H : False |- _ ] => contradiction H
+    end.
+ +
+(* one step of cDv *)
+Ltac cD' :=
+  match goal with
+    | [ H : _ /\ _ |- _ ] => destruct H as [?H ?H]
+    | [ H : prod _ _ |- _ ] => destruct H as [?H ?H]
+    | [ H : ex _ |- _ ] => destruct H as [?H ?H]
+    | [ H : sig _ |- _ ] => destruct H as [?H ?H]
+    | [ H : sigT _ |- _ ] => destruct H as [?H ?H]
+    | [ H : ex2 _ _ |- _ ] => destruct H as [?H ?H ?H]
+    | [ H : sig2 _ _ |- _ ] => destruct H as [?H ?H ?H]
+    | [ H : sigT2 _ _ |- _ ] => destruct H as [?H ?H ?H]
+    | [ H : False |- _ ] => contradiction H
+    end.
+ +
+Ltac cD := repeat cD'.
+ +
+Ltac sE :=
+  repeat match goal with
+    | [ H : _ /\ _ |- _ ] => inversion_clear H
+    | [ H : _ \/ _ |- _ ] => inversion_clear H
+    | [ H : ex _ |- _ ] => inversion_clear H
+    | [ H : False |- _ ] => contradiction H
+    end.
+ +
+Ltac sD' :=
+  match goal with
+    | [ H : _ /\ _ |- _ ] => destruct H as [?H ?H]
+    | [ H : prod _ _ |- _ ] => destruct H as [?H ?H]
+    | [ H : _ \/ _ |- _ ] => destruct H as [?H | ?H]
+    | [ H : sumbool _ _ |- _ ] => destruct H as [?H | ?H]
+    | [ H : sum _ _ |- _ ] => destruct H as [?H | ?H]
+    | [ H : ex _ |- _ ] => destruct H as [?H ?H]
+    | [ H : sig _ |- _ ] => destruct H as [?H ?H]
+    | [ H : sigT _ |- _ ] => destruct H as [?H ?H]
+    | [ H : False |- _ ] => contradiction H
+    end.
+ +
+(* extra stuff used in sD, not in cD *)
+Ltac sDx :=
+  match goal with
+    | [ H : _ \/ _ |- _ ] => destruct H as [?H | ?H]
+    | [ H : sumbool _ _ |- _ ] => destruct H as [?H | ?H]
+    | [ H : sum _ _ |- _ ] => destruct H as [?H | ?H]
+    end.
+ +
+Ltac sD := repeat (cD' || sDx).
+ +
+(* various solutions to dealing with hypothesis forall x, A x -> B x 
+  see emails 8-9 Jan 
+evar (z : list (rel (list (PropF V)) * dir)).
+specialize (H1 z).
+subst z. (* subst. alone doesn't work *)
+
+match type of H1 with
+| ?A -> _ =>
+  assert (I : A); | apply H1 in I
+  end. 
+
+apply (fun G2 G1 => G1 (H1 G2)). 
+
+eassert _ as I*)

+ +
+(* tactics from Lily Chung <ikdc@mit.edu> Tue, 8 Jan 2019
+  https://gist.github.com/ichung/032b849da0c3c5e3987c83f835d111ee *)

+ +
+(* require, when called on a hypothesis H : P -> Q,
+   asserts that P actually holds,
+   and thus that H's type can be replaced with Q *)

+Ltac require H :=
+  match type of H with
+  | forall _ : ?H1, _ =>
+    let x := fresh in
+    let y := x in
+    assert H1 as x; [| specialize (H x); clear y]
+  end.
+ +
+(* erequire H, when called on a hypothesis H : forall x, Q x,
+   specializes H to a new evar to be filled in later *)

+Ltac erequire H :=
+  match type of H with
+  | forall _ : ?H1, _ =>
+    let x := fresh in
+    evar (x : H1); specialize (H x); subst x
+end.
+ +
+(* solution from  Marko Doko <mdoko@mpi-sws.org> Tue, 8 Jan 2019
+  solves question for quantified implication, changed to use Ltac
+
+Tactic Notation "specialize_full" ident(H) :=
+  let foo := fresh in
+  evar (foo : Prop); cut (foo); subst foo; cycle 1;
+  eapply H|try clear H; intro H.
+*)

+ +
+Ltac specialize_full H :=
+  let foo := fresh in
+  evar (foo : Prop); cut (foo); subst foo; cycle 1;
+  [eapply H|try clear H; intro H].
+ +
+Ltac prgt t :=
+  match goal with
+    | [ |- ?P ] => idtac t P
+    end.
+ +
+Lemma in_single: forall (A : Type) (a x : A), In a [x] <-> a = x.
+Proof. intros. unfold iff. split ; intros.
+  apply in_inv in H. sD.
+  subst. reflexivity.
+  apply in_nil in H. contradiction.
+  subst. apply in_eq. Qed.
+ +
+Lemma Forall_cons_inv: forall A (P : A -> Prop) (x : A) (l : list A),
+  Forall P (x :: l) -> P x /\ Forall P l.
+Proof. intros. inversion H. tauto. Qed.
+ +
+Lemma Forall_cons_iff: forall A (P : A -> Prop) (x : A) (l : list A),
+  Forall P (x :: l) <-> P x /\ Forall P l.
+Proof. intros. unfold iff. apply conj ; intro.
+apply Forall_cons_inv. assumption.
+inversion H. apply Forall_cons ; assumption.
+Qed.
+ +
+Lemma Forall_append: forall X P (xs ys: list X),
+  Forall P (xs ++ ys) <-> Forall P xs /\ Forall P ys.
+Proof.
+intros. induction xs. easy.
+simpl. rewrite !Forall_cons_iff. rewrite IHxs. tauto.
+Qed.
+ +
+Lemma Forall_single: forall (A : Type) P x, @Forall A P [x] <-> P x.
+Proof. intros. unfold iff. rewrite Forall_forall.
+  split ; intros.
+  apply H. rewrite in_single. reflexivity.
+  inversion H0. subst. exact H.
+  apply in_nil in H1. contradiction. Qed.
+ +
+Lemma Forall_map_single: forall (A B : Type) P (f : A -> B) x,
+  Forall P (map f [x]) <-> P (f x).
+Proof. simpl. intros. apply Forall_single. Qed.
+ +
+Lemma Forall_map_2: forall (A B : Type) P (f : A -> B) x y,
+  Forall P (map f [x; y]) <-> P (f x) /\ P (f y).
+Proof. intros. rewrite Forall_forall. unfold iff. split.
+  intros. split.
+  pose (H (f x)). apply p. rewrite in_map_iff. exists x. simpl. tauto.
+  pose (H (f y)). apply p. rewrite in_map_iff. exists y. simpl. tauto.
+  intros. rewrite -> in_map_iff in H0. cD. simpl in H3.
+  sD ; subst ; assumption. Qed.
+ +
+Lemma map_cons_ex T U (f : T -> U) ys x : forall ws,
+  map f ws = x :: ys -> {u : T & x = f u &
+    {vs : list _ & ys = map f vs & ws = u :: vs}}.
+Proof. intro. destruct ws ; simpl ; intro. discriminate.
+injection H as . subst. exists t. reflexivity.
+exists ws ; reflexivity. Qed.
+ +
+Lemma map_cons_ex' T U (f : T -> U) ys x : forall ws,
+  map f ws = x :: ys -> {u : T & x = f u &
+    {vs : list _ & map f vs = ys & ws = u :: vs}}.
+Proof. intros ws meq. apply map_cons_ex in meq. cD.
+exists meq. assumption. exists meq1. subst. reflexivity. assumption. Qed.
+ +
+Lemma map_app_ex T U (f : T -> U) ys xs : forall ws,
+  map f ws = xs ++ ys -> {us : _ & map f us = xs &
+    {vs : _ & map f vs = ys & ws = us ++ vs}}.
+Proof. induction xs ; simpl ; intros.
+exists []. simpl. reflexivity.
+simpl. exists ws. subst. reflexivity. reflexivity.
+apply map_cons_ex in H. destruct H. destruct s. subst.
+apply eq_sym in e0. apply IHxs in e0. destruct e0. destruct s. subst.
+exists (x :: x1). simpl. reflexivity. exists x2. reflexivity.
+simpl. reflexivity. Qed.
+ +
+Lemma map_eq_nil T U (f : T -> U) xs : map f xs = [] -> xs = [].
+Proof. intro mx. destruct xs. reflexivity. simpl in mx. discriminate mx. Qed.
+ +
+Ltac name_goal name := refine ?[name].
+ +
+
+
+ +
+ + + diff --git a/General.genT.html b/General.genT.html new file mode 100644 index 0000000..92d169e --- /dev/null +++ b/General.genT.html @@ -0,0 +1,688 @@ + + + + + + + + + + + + + +
+
+

General.genT

+ +
+ +
+(* general purpose stuff, using Type rather than Prop *)
+ +
+Set Implicit Arguments.
+Require Import List.
+Import ListNotations.
+Require Import existsT.
+ +
+Require Export Coq.Classes.CRelationClasses.
+ +
+Require Import gen.
+ +
+Polymorphic Definition rlsT W := list W -> W -> Type.
+ +
+(* how to express the empty set *)
+Inductive emptyT {X : Type} : X -> Type := .
+ +
+Lemma emptyT_any': forall (sty : Type) Q (prem : sty), emptyT prem -> Q prem.
+Proof. intros. induction H. Qed.
+ +
+Lemma emptyT_any: forall (sty : Type) Q (prem : sty), emptyT prem -> Q.
+Proof. intros. induction H. Qed.
+ +
+(* compare 
+  https://coq.inria.fr/stdlib/Coq.Relations.Relation_Definitions.html *)

+Polymorphic Definition relationT (A : Type) := A -> A -> Type.
+Inductive empty_relT {A B : Type} : A -> B -> Type := .
+ +
+Lemma rsub_emptyT {A B} r : @rsub A B empty_relT r.
+Proof. intros u v e. destruct e. Qed.
+ +
+Definition transitiveT W (R : relationT W) :=
+  forall (x y z : W), R x y -> R y z -> R x z.
+ +
+(*
+Definition iffT A B : Type := (A -> B) * (B -> A).
+*)

+Lemma iffT_trans: forall A B C, iffT A B -> iffT B C -> iffT A C.
+Proof. unfold iffT. intros. destruct X. destruct X0. tauto. Qed.
+ +
+Lemma iffT_sym': forall A B, iffT A B -> iffT B A.
+Proof. unfold iffT. intros. destruct X. tauto. Qed.
+ +
+Lemma iffT_refl: forall A, iffT A A.
+Proof. unfold iffT. intros. tauto. Qed.
+ +
+Lemma iffT_D1': forall A B, iffT A B -> A -> B.
+Proof. unfold iffT. intros. tauto. Qed.
+ +
+Lemma iffT_D2': forall A B, iffT B A -> A -> B.
+Proof. unfold iffT. intros. tauto. Qed.
+ +
+(* simpler proof objects *)
+Definition iffT_sym (A B : Type) (X : iffT A B) := let (f, g) := X in (g, f).
+Definition iffT_D1 (A B : Type) (X : iffT A B) a := let (f, _) := X in f a.
+Definition iffT_D2 (A B : Type) (X : iffT A B) b := let (_, g) := X in g b.
+ +
+Lemma prod_mono A A' B B' : (A -> A') -> (B -> B') -> (A * B -> A' * B').
+Proof. intros. destruct X1. tauto. Qed.
+ +
+Lemma iffT_prod A A' B B' : iffT A A' -> iffT B B' -> iffT (A * B) ( A' * B').
+Proof. unfold iffT. intros. destruct X. destruct X0.
+split ; apply prod_mono ; assumption. Qed.
+ +
+(* or defined versions of these
+Definition prod_mono_d A A' B B' aa bb (ab : A * B) :=
+  let (a, b) := ab in (aa a : A', bb b : B').
+
+Definition iffT_prod_d A A' B B' (iaa : iffT A A') (ibb : iffT B B') :=
+  let (af, ab) := iaa in 
+    let (bf, bb) := ibb in (prod_mono af bf, prod_mono ab bb).
+*)

+ +
+Inductive AccT (A : Type) (R : A -> A -> Type) (x : A) : Type :=
+    AccT_intro : (forall y : A, R y x -> AccT R y) -> AccT R x.
+ +
+Definition well_foundedT (A : Type) (R : A -> A -> Type) :=
+  forall a : A, AccT R a.
+ +
+Inductive ForallT (A : Type) (P : A -> Type) : list A -> Type :=
+    ForallT_nil : ForallT P []
+  | ForallT_cons : forall (x : A) (l : list A),
+                  P x -> ForallT P l -> ForallT P (x :: l).
+ +
+Lemma ForallT_inv:
+  forall (A : Type) (P : A -> Type) (a : A) (l : list A),
+  ForallT P (a :: l) -> P a.
+Proof. intros. inversion X. subst. exact X0. Qed.
+ +
+Lemma ForallT_cons_inv:
+  forall (A : Type) (P : A -> Type) (x : A) (l : list A),
+  ForallT P (x :: l) -> P x * ForallT P l.
+Proof. intros. inversion X. subst. split. exact X0. exact X1. Qed.
+ +
+Lemma ForallT_single:
+  forall (A : Type) (P : A -> Type) (x : A), iffT (ForallT P [x]) (P x).
+Proof. intros. unfold iffT. split ; intros.
+  inversion X. subst. exact X0.
+  apply ForallT_cons. exact X. apply ForallT_nil. Qed.
+ +
+Definition ForallT_singleD A P x := iffT_D1 (@ForallT_single A P x).
+Definition ForallT_singleI A P x := iffT_D2 (@ForallT_single A P x).
+ +
+Lemma ForallT_cons_iff:
+  forall (A : Type) (P : A -> Type) (x : A) (l : list A),
+    iffT (ForallT P (x :: l)) (P x * ForallT P l).
+Proof. intros. unfold iffT. split ; intros.
+  apply ForallT_cons_inv. exact X.
+  destruct X. apply ForallT_cons. exact p. exact f. Qed.
+ +
+Lemma ForallT_append:
+  forall (X : Type) (P : X -> Type) (xs ys : list X),
+  iffT (ForallT P (xs ++ ys)) (ForallT P xs * ForallT P ys).
+Proof. intros. unfold iffT.
+  induction xs. simpl. split ; intros. split.
+  apply ForallT_nil. exact X0. destruct X0. exact f0.
+  destruct IHxs. split ; intros.
+  simpl in X0. inversion X0. subst. apply p in X2. destruct X2.
+  split. apply ForallT_cons ; assumption. assumption.
+  simpl. destruct X0. inversion f0. subst.
+  apply ForallT_cons. exact X0. apply f. split ; assumption. Qed.
+ +
+Definition ForallT_appendD A P xs ys := iffT_D1 (@ForallT_append A P xs ys).
+Definition ForallT_appendD1 A P xs ys aa := fst (@ForallT_appendD A P xs ys aa).
+Definition ForallT_appendD2 A P xs ys aa := snd (@ForallT_appendD A P xs ys aa).
+Definition ForallT_appendI' A P xs ys := iffT_D2 (@ForallT_append A P xs ys).
+Definition ForallT_appendI A P xs ys ax ay :=
+  @ForallT_appendI' A P xs ys (pair ax ay).
+ +
+Lemma ForallT_2: forall (A : Type) (P : A -> Type) (x y : A),
+      iffT (ForallT P [x; y]) (P x * P y).
+Proof. intros. unfold iffT. split ; intros.
+inversion X. subst. inversion X1. subst. tauto.
+destruct X. apply ForallT_cons. exact p.
+apply ForallT_cons. exact p0. apply ForallT_nil. Qed.
+ +
+Lemma ForallT_map_2: forall (A B : Type) (P : B -> Type) (f : A -> B) (x y : A),
+      iffT (ForallT P (map f [x; y])) (P (f x) * P (f y)).
+Proof. intros. simpl. apply ForallT_2. Qed.
+ +
+Lemma ForallT_map: forall (A B : Type) (P : B -> Type) (f : A -> B) (x : A),
+      iffT (ForallT P (map f [x])) (P (f x)).
+Proof. intros. simpl. apply ForallT_single. Qed.
+ +
+Lemma ForallT_map_rev: forall (A B : Type) (P : B -> Type) (f : A -> B) (x : A),
+      iffT (P (f x)) (ForallT P (map f [x])).
+Proof. intros. simpl. split; intros HH; apply ForallT_single; tauto. Qed.
+ +
+Definition ForallT_2D A P x y := iffT_D1 (@ForallT_2 A P x y).
+Definition ForallT_D1 A P x y aa := fst (@ForallT_2D A P x y aa).
+Definition ForallT_D2 A P x y aa := snd (@ForallT_2D A P x y aa).
+Definition ForallT_2I' A P x y := iffT_D2 (@ForallT_2 A P x y).
+Definition ForallT_2I A P x y ax ay := @ForallT_2I' A P x y (pair ax ay).
+ +
+Lemma ForallT_impl:
+  forall (A : Type) (P Q : A -> Type),
+  (forall a : A, P a -> Q a) -> forall l : list A, ForallT P l -> ForallT Q l.
+Proof. intros. induction X0. apply ForallT_nil.
+  apply ForallT_cons. apply X. apply p. assumption. Qed.
+ +
+(*
+ForallT_Exists_neg:
+  forall (A : Type) (P : A -> Prop) (l : list A),
+  ForallT (fun x : A => ~ P x) l <-> ~ Exists P l
+ForallT_dec:
+  forall (A : Type) (P : A -> Prop),
+  (forall x : A, {P x} + {~ P x}) ->
+  forall l : list A, {ForallT P l} + {~ ForallT P l}
+ForallT_map_single:
+  forall (A B : Type) (P : B -> Prop) (f : A -> B) (x : A),
+  ForallT P (map f x) <-> P (f x)
+*)

+ +
+Inductive Forall2T (A B : Type) R : list A -> list B -> Type :=
+    Forall2T_nil : Forall2T R [] []
+  | Forall2T_cons : forall (x : A) (y : B) (l : list A) (l' : list B),
+                   R x y -> Forall2T R l l' -> Forall2T R (x :: l) (y :: l')
+  .
+ +
+Theorem Forall2T_app_inv_l : forall A B (R : A -> B -> Type) l1 l2 l',
+  Forall2T R (l1 ++ l2) l' ->
+  sigT2 (fun l1' => Forall2T R l1 l1') (fun l1' => sigT2 (fun l2' =>
+    Forall2T R l2 l2') (fun l2' => l' = l1' ++ l2')).
+Proof. intros until l1. induction l1. simpl.
+intros. exists []. apply Forall2T_nil.
+exists l'. assumption. simpl. reflexivity.
+simpl. intros. inversion_clear X.
+apply IHl1 in X1. destruct X1.
+exists (y :: x). apply Forall2T_cons ; assumption.
+destruct s. subst. simpl. eexists. eassumption. reflexivity. Qed.
+ +
+Theorem Forall2T_app_inv_r : forall A B (R : A -> B -> Type) l1' l2' l,
+  Forall2T R l (l1' ++ l2') ->
+  sigT2 (fun l1 => Forall2T R l1 l1') (fun l1 => sigT2 (fun l2 =>
+    Forall2T R l2 l2') (fun l2 => l = l1 ++ l2)).
+Proof. intros until l1'. induction l1'. simpl.
+intros. exists []. apply Forall2T_nil.
+exists l. assumption. simpl. reflexivity.
+simpl. intros. inversion_clear X.
+apply IHl1' in X1. destruct X1.
+exists (x :: x0). apply Forall2T_cons ; assumption.
+destruct s. subst. simpl. eexists. eassumption. reflexivity. Qed.
+ +
+Theorem Forall2T_app : forall A B (R : A -> B -> Type) l1 l2 l1' l2',
+  Forall2T R l1 l1' -> Forall2T R l2 l2' -> Forall2T R (l1 ++ l2) (l1' ++ l2').
+Proof. intros until l1. induction l1. simpl.
+intros. inversion_clear X. simpl. assumption.
+intros. inversion_clear X. simpl. apply Forall2T_cons. assumption.
+apply IHl1 ; assumption. Qed.
+ +
+(* this isn't usable, because destruct doesn't work for first clause 
+Inductive InT A (a : A) : list A -> Type :=
+  | InT_eq : forall l, @InT A a (a :: l)
+  | InT_cons : forall b l, @InT A a l -> @InT A a (b :: l).
+ *)

+  Ltac cET :=
+  repeat match goal with
+    | [ H : _ /\ _ |- _ ] => inversion_clear H
+    | [ H : ex _ |- _ ] => inversion_clear H
+    | [ H : False |- _ ] => contradiction H
+    | [ H : sig _ |- _ ] => inversion_clear H
+    | [ H : sigT _ |- _ ] => inversion_clear H
+    | [ H : False |- _ ] => contradiction H
+    | [ H : _ * _ |- _ ] => inversion_clear H
+         end.
+ +
+  Ltac cET_nr :=
+  match goal with
+    | [ H : _ /\ _ |- _ ] => inversion_clear H
+    | [ H : ex _ |- _ ] => inversion_clear H
+    | [ H : False |- _ ] => contradiction H
+    | [ H : sig _ |- _ ] => inversion_clear H
+    | [ H : sigT _ |- _ ] => inversion_clear H
+    | [ H : False |- _ ] => contradiction H
+    | [ H : _ * _ |- _ ] => inversion_clear H
+    end.
+ +
+Inductive InT A (a : A) : list A -> Type :=
+  | InT_eq' : forall b l, b = a -> @InT A a (b :: l)
+  | InT_cons : forall b l, @InT A a l -> @InT A a (b :: l).
+ +
+Definition InT_eq: forall A a l, @InT A a (a :: l).
+Proof. intros. apply InT_eq'. reflexivity. Defined.
+ +
+Definition InT_2nd A (a b : A) l := InT_cons a (InT_eq b l).
+ +
+Lemma InT_appL: forall A a X Y, InT (a : A) X -> InT a (X ++ Y).
+Proof. intros. induction X0 ; simpl. subst.
+apply InT_eq. apply InT_cons. assumption. Qed.
+ +
+Lemma InT_appR: forall A a X Y, InT (a : A) Y -> InT a (X ++ Y).
+Proof. intros. induction X ; simpl. assumption.
+apply InT_cons. assumption. Qed.
+ +
+Ltac solve_InT := apply InT_eq ||
+  ((apply InT_cons || (apply InT_appL + apply InT_appR)) ; solve_InT).
+ +
+Lemma InT_appE': forall A a Z, InT (a : A) Z ->
+  forall X Y, Z = X ++ Y -> InT a X + InT a Y.
+Proof. intros *. intro. induction X ; intros.
+destruct X ; simpl in H. subst. right. apply InT_eq.
+injection H. intros. subst. left. apply InT_eq.
+destruct X0 ; simpl in H. subst. right. apply InT_cons. assumption.
+injection H. intros. subst. pose (@eq_refl (list A)). apply IHX in e.
+destruct e. left. apply InT_cons. assumption.
+right. assumption. Qed.
+ +
+Lemma InT_appE: forall A a X Y, InT (a : A) (X ++ Y) -> InT a X + InT a Y.
+Proof. intros. eapply InT_appE'. eassumption. reflexivity. Qed.
+ +
+Lemma InT_nilE': forall A a Z any, InT (a : A) Z -> Z = [] -> any.
+Proof. intros. induction X ; discriminate. Qed.
+ +
+Lemma InT_nilE: forall A a any, InT (a : A) [] -> any.
+Proof. intros. eapply InT_nilE'. eassumption. reflexivity. Qed.
+ +
+Lemma InT_split: forall (A : Type) (x : A) (l : list A),
+  InT x l -> sigT (fun l1 => sigT (fun l2 => l = l1 ++ x :: l2)).
+Proof. intros. induction X.
+exists []. exists l. simpl. subst. reflexivity.
+destruct IHX. destruct s. subst.
+exists (b :: x0). exists x1. simpl. reflexivity. Qed.
+ +
+Lemma InT_inv: forall A a b Y, InT (a : A) (b :: Y) -> (b = a) + InT a Y.
+Proof. intros. inversion X ; subst ; tauto. Qed.
+ +
+Lemma InT_map: forall (A B : Type) (f : A -> B) (l : list A) (x : A),
+  InT x l -> InT (f x) (map f l).
+Proof. intros. induction X.
+subst. simpl. apply InT_eq.
+simpl. apply InT_cons. assumption. Qed.
+ +
+Lemma InT_mapE: forall (A B : Type) (f : A -> B) (l : list A) (y : B),
+       (InT y (map f l)) -> (sigT (fun x => prod (f x = y) (InT x l))).
+Proof. intros.
+induction l. eapply InT_nilE in X. apply X.
+simpl in X. inversion X. subst. exists a.
+split. reflexivity. apply InT_eq.
+subst. apply IHl in X0. cD. exists X0. subst. split. reflexivity.
+apply InT_cons. exact X2. Qed.
+ +
+Definition InT_map_iffT: forall (A B : Type) (f : A -> B) (l : list A) (y : B),
+       iffT (InT y (map f l)) (sigT (fun x => prod (f x = y) (InT x l))).
+Proof. intros. apply pair. apply InT_mapE.
+intro. cD. subst. apply InT_map. exact X1. Defined.
+ +
+Definition InT_mapI A B f l y := iffT_D2 (@InT_map_iffT A B f l y).
+ +
+Lemma InT_concat: forall (A : Type) a (xs : list A) pss,
+     InT a xs -> InT xs pss -> InT a (concat pss).
+Proof. intros. induction X0. subst. simpl. apply InT_appL. assumption.
+simpl. apply InT_appR. assumption. Qed.
+ +
+Lemma Forall2T_ex_l: forall A B (R : A -> B -> Type) xs ys x,
+  Forall2T R xs ys -> InT x xs -> sigT2 (fun y => InT y ys) (fun y => R x y).
+Proof. intros *. intro. induction X.
+intro. eapply InT_nilE in X. eassumption.
+intro. inversion X0 ; subst. eexists. apply InT_eq. assumption.
+apply IHX in X1. destruct X1. eexists. eapply InT_cons. eassumption.
+assumption. Qed.
+ +
+Lemma Forall2T_ex_r: forall A B (R : A -> B -> Type) xs ys x,
+  Forall2T R ys xs -> InT x xs -> sigT2 (fun y => InT y ys) (fun y => R y x).
+Proof. intros *. intro. induction X.
+intro. eapply InT_nilE in X. eassumption.
+intro. inversion X0 ; subst. eexists. apply InT_eq. assumption.
+apply IHX in X1. destruct X1. eexists. eapply InT_cons. eassumption.
+assumption. Qed.
+ +
+Lemma ForallT_forall: forall (A : Type) (P : A -> Type) (l : list A),
+  iffT (ForallT P l) (forall x : A, InT x l -> P x).
+Proof. intros. induction l ; unfold iffT ; split ; intros.
+  eapply InT_nilE in X0. exact X0. apply ForallT_nil.
+  unfold iffT in IHl. destruct IHl. inversion X.
+  inversion X0 ; subst ; firstorder.
+  unfold iffT in IHl. destruct IHl.
+  apply ForallT_cons. apply X. apply InT_eq.
+  apply f. intros. apply X. apply InT_cons. exact X0. Qed.
+ +
+Definition ForallTD_forall A P x := iffT_D1 (@ForallT_forall A P x).
+Definition ForallTI_forall A P x := iffT_D2 (@ForallT_forall A P x).
+ +
+Lemma InT_In: forall A a Y, InT (a : A) Y -> In a Y.
+Proof. intros. induction X. subst. apply in_eq.
+apply in_cons. assumption. Qed.
+ +
+Lemma In_InT: forall A a Y, In (a : A) Y -> ex (fun _ : InT a Y => True).
+Proof. intros. induction Y. apply in_nil in H. contradiction.
+apply in_inv in H. destruct H. subst. exists. apply InT_eq. apply I.
+apply IHY in H. destruct H. exists. apply InT_cons. assumption. apply I. Qed.
+ +
+(* generalise this *)
+Definition anon (p : Type) := ex (fun _ : p => True).
+ +
+Lemma anonI : forall p, p -> anon p.
+Proof. intros. unfold anon. exists. assumption. apply I. Qed.
+ +
+Lemma InT_In': forall A a Y, ex (fun _ : InT (a : A) Y => True) -> In a Y.
+Proof. intros. destruct H. apply InT_In. assumption. Qed.
+(* why can't we do anon p -> p in general, we do it here?
+  note, trying apply InT_In. before destruct H. causes the error below *)

+ +
+(*
+Lemma anonD : forall p, anon p -> p.
+Proof. unfold anon. intros. destruct H.
+Error: Case analysis on sort Type is not allowed for inductive definition ex.
+*)

+Lemma anonD : forall p (q : Prop), (p -> q) -> (anon p -> q).
+Proof. unfold anon. intros. destruct H0. tauto. Qed.
+ +
+Lemma anon_eq: forall P : Prop, anon P <-> P.
+Proof. intros. unfold iff. split. apply anonD. tauto. apply anonI. Qed.
+ +
+Lemma InT_In_eq: forall A a Y, anon (InT (a : A) Y) <-> In a Y.
+Proof. unfold anon. intros. unfold iff. split ; intros.
+apply InT_In'. assumption. apply In_InT. assumption. Qed.
+ +
+Lemma InT_In_eq': forall A a Y, anon (InT (a : A) Y) <-> In a Y.
+Proof. intros. unfold iff. split.
+apply anonD. apply InT_In.
+intro. unfold anon. apply In_InT. assumption. Qed.
+ +
+Lemma anon_prod: forall t u, anon (prod t u) <-> anon t /\ anon u.
+Proof. intros. unfold iff. unfold anon. split ; intros ;
+  cD ; try split ; exists ; tauto. Qed.
+ +
+Lemma anon_sum: forall t u, anon (sum t u) <-> anon t \/ anon u.
+Proof. intros. unfold iff. unfold anon. split ; intros ; sD ;
+  [> left | right | | ] ; exists ; tauto. Qed.
+ +
+(* doubt if converse is valid *)
+Lemma anon_imp: forall t u, anon (t -> u) -> (anon t -> anon u).
+Proof. unfold anon. intros. cD. exists ; tauto. Qed.
+ +
+Lemma anon_iffT: forall t u, anon (iffT t u) -> (anon t <-> anon u).
+Proof. unfold iff. unfold iffT. intros.
+rewrite -> anon_prod in H. destruct H.
+split ; intros ; eapply anon_imp ; eassumption. Qed.
+ +
+Lemma anon_sigT: forall A P, anon (@sigT A P) -> @ex A (fun x => anon (P x)).
+Proof. unfold anon. intros. cD. eexists. eexists. eassumption. apply I. Qed.
+ +
+Lemma anon_forall: forall T P,
+  anon (forall x : T, P x) -> forall x : T, anon (P x).
+Proof. unfold anon. intros. destruct H. exists. apply (x0 x). apply I. Qed.
+ +
+(* example to use the above - to prove in_inv 
+Goal forall (A : Type) (a b : A) l, In b (a :: l) -> a = b \/ In b l.
+Proof.  intros.  pose InT_inv.
+apply anonI in s.
+eapply anon_forall in s.
+eapply anon_forall in s.
+eapply anon_forall in s.
+eapply anon_forall in s.
+eapply anon_imp in s. (* this doesn't work as I'd expect *)
+Undo.
+pose anon_imp.
+pose (a0 (InT ?x0 (?x1 :: ?x2)) (?x1 = ?x0) + InT ?x0 ?x2). (* fails *)
+*)

+ +
+Lemma ForallT_Forall': forall A (P : A -> Prop) (xs : list A),
+  ForallT P xs -> Forall P xs.
+Proof. intros. induction X. apply Forall_nil.
+apply Forall_cons. assumption. assumption. Qed.
+ +
+Lemma ForallT_Forall: forall A P (xs : list A),
+  ForallT P xs -> Forall (fun x => anon (P x)) xs.
+Proof. intros. induction X. apply Forall_nil.
+apply Forall_cons. apply anonI. assumption. assumption. Qed.
+ +
+Lemma Forall_ForallT: forall A P (xs : list A),
+  Forall P xs -> anon (ForallT P xs).
+Proof. intros. induction H. apply anonI. apply ForallT_nil.
+unfold anon in IHForall. cD. apply anonI. (* can't do this before cD *)
+apply ForallT_cons ; assumption. Qed.
+ +
+(* note proof carefully, intros then induction H fails,
+  inversion H too early fails *)

+Lemma Forall_ForallT': forall A P (xs : list A), Forall P xs -> ForallT P xs.
+Proof. intros. induction xs. apply ForallT_nil.
+apply ForallT_cons. inversion H. subst. assumption.
+apply IHxs. inversion H. subst. assumption.
+Qed.
+ +
+Lemma inhabited_anon: forall A, inhabited A <-> anon A.
+Proof. unfold iff. unfold anon. intros. split ; intros.
destruct H. exists ; tauto.
destruct H. apply inhabits. assumption. Qed.
+ +
+Lemma want_left_prod_under_universal : forall (T : Type) (P : T -> Type) (Q1 : T -> Type) (S : Type),
+    (forall y : T, P y -> ((Q1 y) * S)) ->
+    forall y : T, P y -> Q1 y.
+Proof. firstorder. Qed.
+ +
+Lemma want_right_prod_under_universal : forall (T : Type) (P : T -> Type) (Q1 : T -> Type) (S : Type),
+    (forall y : T, P y -> (S * (Q1 y))) ->
+    forall y : T, P y -> Q1 y.
+Proof. firstorder. Qed.
+ +
+Lemma want_right_prod_under_universal' : forall (T : Type) (P : T -> Type) (Q1 S : T -> Type),
+    (forall y : T, P y -> ((S y) * (Q1 y))) ->
+    forall y : T, P y -> Q1 y.
+Proof. firstorder. Qed.
+ +
+Lemma want_prod_under_universal4 : forall (T : Type) (P : T -> Type) (Q1 Q2 Q3 Q4 : T -> Type),
+    (forall y : T, P y -> ((Q1 y) * (Q2 y) * (Q3 y) * (Q4 y))) ->
+    (forall y : T, P y -> Q1 y) *
+    (forall y : T, P y -> Q2 y) *
+    (forall y : T, P y -> Q3 y) *
+    (forall y : T, P y -> Q4 y).
+Proof. firstorder. Qed.
+ +
+Lemma prod_nat_split : forall (P : (nat * nat) -> Type),
+    (forall y : nat * nat, P y) ->
+    (forall n m : nat, P (n,m)).
+Proof. firstorder. Qed.
+ +
+Inductive empty : Type := .
+ +
+Lemma empty_explosion : forall (A : Type), empty -> A.
+Proof. intros A H. inversion H. Qed.
+ +
+Notation "T~ A" := (A -> empty) (at level 60).
+ +
+Lemma False_empty : False -> empty.
+Proof. intros H. inversion H. Qed.
+ +
+Lemma empty_False : empty -> False.
+Proof. intros H. inversion H. Qed.
+ +
+Inductive leT (n : nat) : nat -> Type :=
+  | leT_n : leT n n | leT_S : forall m : nat, leT n m -> leT n (S m).
+ +
+Theorem leT_n_S : forall n m, leT n m -> leT (S n) (S m).
+Proof. intros. induction H. apply leT_n. apply (leT_S IHleT). Qed.
+ +
+Lemma leT_S_n' : forall sn sm, leT sn sm ->
+  forall n m, sn = S n -> sm = S m -> leT n m.
+Proof. intros * ss. induction ss.
+- intros. subst. inversion H0. apply leT_n.
+- destruct m.
++ inversion ss. intros. inversion H0.
++ intros. subst. specialize (IHss _ _ eq_refl eq_refl).
+inversion H0. exact (leT_S IHss). Qed.
+ +
+(* forall n m, leT (S n) (S m) -> leT n m *)
+Definition leT_S_n n m l := @leT_S_n' _ _ l n m eq_refl eq_refl.
+ +
+Lemma leT_trans' l m n: leT m n -> leT l m -> leT l n.
+Proof. intro. induction H ; intro. apply H. exact (leT_S (IHleT H0)). Qed.
+ +
+Definition leT_trans l m n llm lmn := @leT_trans' l m n lmn llm.
+ +
+Lemma leT_0_n n: leT 0 n.
+Proof. induction n. apply leT_n. apply (leT_S IHn). Qed.
+ +
+Lemma leT_plus_r n m : leT m (n + m).
+Proof. induction n ; simpl. apply leT_n. apply (leT_S IHn). Qed.
+ +
+Lemma leT_plus_l n m : leT n (n + m).
+Proof. induction n ; simpl. apply leT_0_n. apply (leT_n_S IHn). Qed.
+ +
+Theorem eq_S_F n : S n = n -> False.
+Proof. intro. induction n ; inversion H. tauto. Qed.
+ +
+Theorem leT_S_F n : leT (S n) n -> False.
+Proof. induction n ; intro. inversion H. apply leT_S_n in H. tauto. Qed.
+ +
+Lemma leT_S_or_eq n m : leT n m -> leT (S n) m + (n = m).
+Proof. intro. induction H. tauto. left. exact (leT_n_S H). Qed.
+ +
+Lemma leT_or_gt n m : leT n m + leT (S m) n.
+Proof. induction n. left. apply leT_0_n.
+destruct IHn. apply leT_S_or_eq in l. destruct l. exact (inl l).
+subst. exact (inr (leT_n _)). exact (inr (leT_S l)). Qed.
+ +
+Lemma leT_ex_plus k n : leT k n -> { m : nat & Nat.add m k = n }.
+Proof. intro lkn. induction lkn. exists 0. simpl. reflexivity.
+cD. subst. exists (S IHlkn). simpl. reflexivity. Qed.
+
+
+ +
+ + + diff --git a/General.gen_seq.html b/General.gen_seq.html new file mode 100644 index 0000000..4f30c17 --- /dev/null +++ b/General.gen_seq.html @@ -0,0 +1,736 @@ + + + + + + + + + + + + + +
+
+

General.gen_seq

+ +
+Require Export List.
+Export ListNotations.
+Set Implicit Arguments.
+ +
+From Coq Require Import ssreflect.
+ +
+(* Add LoadPath "../modal".
+Add LoadPath "../tense-lns". *)

+Require Import gen genT ddT gen_tacs.
+Require Import gstep.
+Require Import List_lemmasT swappedT existsT.
+Require Import Coq.Program.Basics.
+ +
+Inductive rlsmap U W (f : U -> W) (rls : rlsT U) : rlsT W :=
+  | rmI : forall ps c, rls ps c -> rlsmap f rls (map f ps) (f c).
+ +
+Lemma rmI_eq U W (f : U -> W) (rls : rlsT U) ps c mps mc :
+  rls ps c -> mps = map f ps -> mc = f c -> rlsmap f rls mps mc.
+Proof. intros. subst. apply rmI ; assumption. Qed.
+ +
+Inductive relmap U W (f : U -> W) (rel : relationT U) : relationT W :=
+  | rlI : forall p c, rel p c -> relmap f rel (f p) (f c).
+ +
+Lemma rlI_eq U W (f : U -> W) (rel : relationT U) p c mp mc :
+  rel p c -> mp = f p -> mc = f c -> relmap f rel mp mc.
+Proof. intros. subst. apply rlI ; assumption. Qed.
+ +
+
+ +
+seqext, seqrule, extending sequent and rule with left- and right-contexts + in antecedent and consequent +
+
+Definition seqext (W : Type) Gam1 Gam2 Delt1 Delt2 (seq : rel (list W)) :=
+  match seq with | pair U V => pair (Gam1 ++ U ++ Gam2) (Delt1 ++ V ++ Delt2) end.
+ +
+Lemma seqext_seqext: forall V (Gam1 Gam2 Delt1 Delt2 Phi1 Phi2 Psi1 Psi2 : list V) seq,
+  seqext Gam1 Gam2 Delt1 Delt2 (seqext Phi1 Phi2 Psi1 Psi2 seq) =
+  seqext (Gam1 ++ Phi1) (Phi2 ++ Gam2) (Delt1 ++ Psi1) (Psi2 ++ Delt2) seq.
+Proof. intros. unfold seqext. destruct seq.
+rewrite !app_assoc. reflexivity. Qed.
+ +
+Lemma map_seqext_seqext: forall V (Gam1 Gam2 Delt1 Delt2 Phi1 Phi2 Psi1 Psi2 : list V) seqs,
+  map (seqext Gam1 Gam2 Delt1 Delt2) (map (seqext Phi1 Phi2 Psi1 Psi2) seqs) =
+  map (seqext (Gam1 ++ Phi1) (Phi2 ++ Gam2) (Delt1 ++ Psi1) (Psi2 ++ Delt2)) seqs.
+Proof. induction seqs. tauto.
+simpl. rewrite IHseqs. rewrite seqext_seqext. reflexivity. Qed.
+ +
+Inductive seqrule (W : Type) (pr : rlsT (rel (list W))) :
+    rlsT (rel (list W)) :=
+  | Sctxt : forall ps c Phi1 Phi2 Psi1 Psi2, pr ps c ->
+    seqrule pr (map (seqext Phi1 Phi2 Psi1 Psi2) ps) (seqext Phi1 Phi2 Psi1 Psi2 c).
+ +
+Lemma seqext_def : forall (W : Type) Phi1 Phi2 Psi1 Psi2 U V,
+      @seqext W Phi1 Phi2 Psi1 Psi2 (U,V) = (Phi1 ++ U ++ Phi2, Psi1 ++ V ++ Psi2).
+Proof. reflexivity. Qed.
+ +
+Lemma Sctxt_e: forall (W : Type) (pr : rlsT (rel (list W))) ps U V Phi1 Phi2 Psi1 Psi2,
+  pr ps (U, V) ->
+  seqrule pr (map (seqext Phi1 Phi2 Psi1 Psi2) ps) (Phi1 ++ U ++ Phi2, Psi1 ++ V ++ Psi2).
+Proof.
+  intros *. intros H. rewrite <- seqext_def.
+  apply Sctxt. exact H.
+Qed.
+ +
+Lemma Sctxt_eq: forall (W : Type) pr ps mps (ca cs U V Phi1 Phi2 Psi1 Psi2 : list W),
+  pr ps (U, V) -> ca = Phi1 ++ U ++ Phi2 -> cs = Psi1 ++ V ++ Psi2 ->
+  mps = map (seqext Phi1 Phi2 Psi1 Psi2) ps -> seqrule pr mps (ca, cs).
+Proof. intros. subst. apply Sctxt_e. exact X. Qed.
+ +
+Lemma seqrule_id (W : Type) (pr : rlsT (rel (list W))) :
+  forall ps c, pr ps c -> seqrule pr ps c.
+Proof. intros. destruct c as [ca cs].
+apply (Sctxt_eq pr ps ca cs [] [] [] []). assumption.
+simpl. rewrite app_nil_r. reflexivity.
+simpl. rewrite app_nil_r. reflexivity.
+clear X. induction ps. simpl. reflexivity.
+simpl. rewrite <- IHps.
+destruct a. unfold seqext. simpl. rewrite !app_nil_r.
+reflexivity. Qed.
+ +
+Lemma seqrule_seqrule (W : Type) (pr : rlsT (rel (list W))) :
+  rsub (seqrule (seqrule pr)) (seqrule pr).
+Proof. unfold rsub. intros. inversion X. subst. clear X.
+inversion X0. subst. clear X0.
+rewrite seqext_seqext.
+destruct c0 as [ca cs].
+eapply Sctxt_eq. exact X.
+reflexivity. reflexivity.
+clear X. induction ps0. simpl. reflexivity.
+simpl. rewrite IHps0. rewrite seqext_seqext. reflexivity. Qed.
+ +
+Definition seqrule_seqrule' (W : Type) pr :=
+  rsubD (@seqrule_seqrule W pr).
+ +
+Lemma derl_seqrule'' (W : Type) (rules : rlsT (rel (list W))) :
+  forall Phi1 Phi2 Psi1 Psi2, (forall ps c, derl rules ps c ->
+   derl (seqrule rules) (map (seqext Phi1 Phi2 Psi1 Psi2) ps) (seqext Phi1 Phi2 Psi1 Psi2 c)) *
+  (forall ps cs, dersl rules ps cs ->
+    dersl (seqrule rules) (map (seqext Phi1 Phi2 Psi1 Psi2) ps)
+    (map (seqext Phi1 Phi2 Psi1 Psi2)cs)).
+Proof. intros Phi1 Phi2 Psi1 Psi2.
+eapply (derl_dersl_rect_mut (rules := rules)
+  (fun ps c => fun _ => derl (seqrule rules)
+    (map (seqext Phi1 Phi2 Psi1 Psi2) ps) (seqext Phi1 Phi2 Psi1 Psi2 c))
+  (fun ps cs : list _ => fun _ => dersl (seqrule rules)
+    (map (seqext Phi1 Phi2 Psi1 Psi2) ps) (map (seqext Phi1 Phi2 Psi1 Psi2) cs))).
+- simpl. intros. apply asmI.
+- intros. eapply dtderI. apply Sctxt. eassumption. assumption.
+- simpl. apply dtNil.
+- intros. rewrite map_app. simpl. apply dtCons ; assumption. Qed.
+ +
+Definition derl_seqrule' W rules Phi1 Phi2 Psi1 Psi2 :=
+  fst (@derl_seqrule'' W rules Phi1 Phi2 Psi1 Psi2).
+Definition dersl_seqrule' W rules Phi1 Phi2 Psi1 Psi2 :=
+  snd (@derl_seqrule'' W rules Phi1 Phi2 Psi1 Psi2).
+ +
+Lemma derl_seqrule (W : Type) (rules : rlsT (rel (list W))) :
+  rsub (seqrule (derl rules)) (derl (seqrule rules)).
+Proof. unfold rsub. intros. destruct X.
+apply derl_seqrule'. assumption. Qed.
+ +
+Lemma seqrule_derl_seqrule (W : Type) (rules : rlsT (rel (list W))) :
+  rsub (seqrule (derl (seqrule rules))) (derl (seqrule rules)).
+Proof. eapply rsub_trans. apply derl_seqrule.
unfold rsub. intros. eapply derl_mono. 2: eassumption.
apply seqrule_seqrule. Qed.
+ +
+Definition seqrule_derl_seqrule' W rules :=
+  rsubD (@seqrule_derl_seqrule W rules).
+ +
+(* seqrule_s ps c qs d means that d is a sequent extension of c 
+  and that each q in qs is a corresponding sequent extension of the
+  corresponding p in ps *)

+Inductive seqrule_s (W : Type) (ps : list (rel (list W))) (c : rel (list W)) :
+    rlsT (rel (list W)) :=
+  | Sctxt_s : forall Phi1 Phi2 Psi1 Psi2,
+    seqrule_s ps c (map (seqext Phi1 Phi2 Psi1 Psi2) ps) (seqext Phi1 Phi2 Psi1 Psi2 c).
+ +
+Inductive seqrule' (W : Type) (pr : rlsT (rel (list W))) :
+    rlsT (rel (list W)) :=
+  | Sctxt' : forall ps c pse ce,
+    pr ps c -> seqrule_s ps c pse ce -> seqrule' pr pse ce.
+ +
+(* Check, get same as Sctxt but for seqrule' *)
+Lemma Sctxt_alt : forall (W : Type) (pr : rlsT (rel (list W))) ps c Phi1 Phi2 Psi1 Psi2,
+    pr ps c -> seqrule' pr (map (seqext Phi1 Phi2 Psi1 Psi2) ps) (seqext Phi1 Phi2 Psi1 Psi2 c).
+Proof.
+  intros *. intros H.
+  eapply Sctxt'. exact H. apply Sctxt_s.
+Qed.
+ +
+Lemma Sctxt_e': forall (W : Type) (pr : rlsT (rel (list W))) ps U V Phi1 Phi2 Psi1 Psi2,
+  pr ps (U, V) ->
+  seqrule pr (map (seqext Phi1 Phi2 Psi1 Psi2) ps) ((Phi1 ++ U) ++ Phi2, Psi1 ++ V ++ Psi2).
+Proof.
+  intros *. intros H.
+  rewrite <- app_assoc. apply Sctxt_e. exact H.
+Qed.
+ +
+Lemma seqext_defp : forall (W : Type) Phi1 Phi2 Psi1 Psi2 seq,
+      @seqext W Phi1 Phi2 Psi1 Psi2 seq =
+        let (U, V) := seq in (Phi1 ++ U ++ Phi2, Psi1 ++ V ++ Psi2).
+Proof. reflexivity. Qed.
+ +
+Lemma seqrule_same: forall (W : Type) pr ps (c c' : rel (list W)),
+  seqrule pr ps c -> c = c' -> seqrule pr ps c'.
+Proof. intros. subst. assumption. Qed.
+ +
+Lemma seqrule_mono X (rulesa rulesb : rlsT (rel (list X))) :
+  rsub rulesa rulesb -> rsub (seqrule rulesa) (seqrule rulesb).
+Proof. unfold rsub. intros. destruct X1. apply Sctxt. firstorder. Qed.
+ +
+Definition seqrule_mono' X rulesa rulesb rs :=
+  rsubD (@seqrule_mono X rulesa rulesb rs).
+ +
+Lemma Sctxt_nil: forall (W : Type) pr c Gam1 Gam2 Delt1 Delt2, (pr [] c : Type) ->
+  @seqrule W pr [] (seqext Gam1 Gam2 Delt1 Delt2 c).
+Proof.
+  intros *. intros H. eapply Sctxt in H.
+  simpl in H. exact H.
+Qed.
+ +
+Lemma InT_seqextL : forall {W : Type} Gam Delt A,
+    InT A Gam ->
+    existsT2 Phi1 Phi2, @seqext W Phi1 Phi2 Delt [] ([A], []) = (Gam, Delt).
+Proof.
+  induction Gam; intros Delt A Hin.
+  inversion Hin.
+  inversion Hin. subst.
+  repeat eexists. unfold seqext.
+  do 2 rewrite app_nil_r. erewrite app_nil_l.
+     reflexivity.
+  subst. destruct (IHGam Delt _ X) as [H1 [H2 H3]].
+  unfold seqext in *.
+  inversion H3.
+  repeat rewrite app_nil_r.
+  repeat eexists. rewrite app_comm_cons. reflexivity.
+Qed.
+ +
+Lemma InT_seqextR : forall {W : Type} Gam Delt B,
+    InT B Delt ->
+    existsT2 Psi1 Psi2, @seqext W Gam [] Psi1 Psi2 ([], [B]) = (Gam, Delt).
+Proof.
+  induction Delt; intros A Hin.
+  inversion Hin.
+  inversion Hin. subst.
+  repeat eexists. unfold seqext.
+  do 2 rewrite app_nil_r. erewrite app_nil_l.
+     reflexivity.
+  subst. destruct (IHDelt _ X) as [H1 [H2 H3]].
+  unfold seqext in *.
+  inversion H3.
+  repeat rewrite app_nil_r.
+  repeat eexists. rewrite app_comm_cons. reflexivity.
+Qed.
+ +
+Lemma InT_seqext : forall {W : Type} Gam Delt A B,
+    InT A Gam ->
+    InT B Delt ->
+    existsT2 Phi1 Phi2 Psi1 Psi2, @seqext W Phi1 Phi2 Psi1 Psi2 ([A], [B]) = (Gam, Delt).
+Proof.
+  intros *. intros Hin1 Hin2.
+  destruct (@InT_seqextL _ _ Delt _ Hin1) as [H1 [H2 H3]].
+  destruct (@InT_seqextR _ Gam _ _ Hin2) as [J1 [J2 J3]].
+  unfold seqext in *.
+  repeat rewrite app_nil_r in H3.
+  repeat rewrite app_nil_r in J3.
+  inversion H3. inversion J3.
+  subst. repeat eexists.
+Qed.
+ +
+(* fmlsext copied from ../ll/fmlsext.v *)
+Definition fmlsext (W : Type) Gam1 Gam2 (fmls : (list W)) := (Gam1 ++ fmls ++ Gam2).
+ +
+Lemma fmlsext_fmlsext: forall V (Gam1 Gam2 Phi1 Phi2 : list V) seq,
+  fmlsext Gam1 Gam2 (fmlsext Phi1 Phi2 seq) = fmlsext (Gam1 ++ Phi1) (Phi2 ++ Gam2) seq.
+Proof. intros. unfold fmlsext. rewrite !app_assoc. reflexivity. Qed.
+ +
+Lemma map_fmlsext_fmlsext: forall V (Gam1 Gam2 Phi1 Phi2 : list V) seqs,
+  map (fmlsext Gam1 Gam2) (map (fmlsext Phi1 Phi2) seqs) =
+  map (fmlsext (Gam1 ++ Phi1) (Phi2 ++ Gam2)) seqs.
+Proof. induction seqs. tauto.
+simpl. rewrite IHseqs. rewrite fmlsext_fmlsext. reflexivity. Qed.
+ +
+Lemma fmlsext_def : forall (W : Type) Phi1 Phi2 U,
+      @fmlsext W Phi1 Phi2 U = (Phi1 ++ U ++ Phi2).
+Proof. reflexivity. Qed.
+ +
+Definition apfst U V W (f : U -> V) (p : U * W) := let (x, y) := p in (f x, y).
+Definition apsnd U V W (f : U -> V) (p : W * U) := let (x, y) := p in (x, f y).
+ +
+
+ +
+fst_ext_rls - adding left- and right-context + to the antecedent of a sequent rule +
+
+Inductive fst_ext_rls U W rls : rlsT (list U * W) :=
+  | fextI : forall Gam1 Gam2 ps c,
+    rlsmap (apfst (fmlsext Gam1 Gam2)) rls ps c -> fst_ext_rls rls ps c.
+ +
+Inductive snd_ext_rls U W rls : rlsT (U * list W) :=
+  | sextI : forall Gam1 Gam2 ps c,
+    rlsmap (apsnd (fmlsext Gam1 Gam2)) rls ps c -> snd_ext_rls rls ps c.
+ +
+Definition fextI' U W rls Gam1 Gam2 ps c rpc :=
+  @fextI U W rls Gam1 Gam2 _ _ (rmI _ _ ps c rpc).
+ +
+Lemma fextI_eq' U W rls Gam1 Gam2 ps (c : list U * W) mps mc :
+  rls ps c -> mps = map (apfst (fmlsext Gam1 Gam2)) ps ->
+  mc = apfst (fmlsext Gam1 Gam2) c -> fst_ext_rls rls mps mc.
+Proof. intros. subst. apply fextI'. exact X. Qed.
+ +
+Definition fextI_eqc' U W rls Gam1 Gam2 ps (c : list U * W) mc rpc :=
+  @fextI_eq' U W rls Gam1 Gam2 ps (c : list U * W) _ mc rpc eq_refl.
+ +
+Lemma fst_snd_ext W (rls : rlsT (list W * list W)) :
+  req (seqrule rls) (fst_ext_rls (snd_ext_rls rls)).
+Proof. split ; intros ps c.
+- intro sr. destruct sr. eapply fextI. eapply rmI_eq.
+eapply sextI. apply rmI. exact r.
+2: destruct c. 2: simpl. 2: unfold fmlsext. 2: reflexivity.
+clear r. induction ps. reflexivity.
+destruct a. simpl. rewrite - IHps. unfold fmlsext. reflexivity.
+- intro fs. destruct fs. inversion r. clear r. subst.
+destruct X. inversion r. clear r. subst.
+destruct c0. simpl. unfold fmlsext.
+eapply Sctxt_eq. exact X. reflexivity. reflexivity.
+clear X. induction ps0. reflexivity.
+destruct a. simpl. rewrite IHps0. reflexivity. Qed.
+ +
+Lemma snd_fst_ext W (rls : rlsT (list W * list W)) :
+  req (seqrule rls) (snd_ext_rls (fst_ext_rls rls)).
+Proof. split ; intros ps c.
+- intro sr. destruct sr. eapply sextI. eapply rmI_eq.
+eapply fextI. apply rmI. exact r.
+2: destruct c. 2: simpl. 2: unfold fmlsext. 2: reflexivity.
+clear r. induction ps. reflexivity.
+destruct a. simpl. rewrite - IHps. unfold fmlsext. reflexivity.
+- intro fs. destruct fs. inversion r. clear r. subst.
+destruct X. inversion r. clear r. subst.
+destruct c0. simpl. unfold fmlsext.
+eapply Sctxt_eq. exact X. reflexivity. reflexivity.
+clear X. induction ps0. reflexivity.
+destruct a. simpl. rewrite IHps0. reflexivity. Qed.
+ +
+Lemma rm_mono U W (f : U -> W) rlsa rlsb :
+  rsub rlsa rlsb -> rsub (rlsmap f rlsa) (rlsmap f rlsb).
+Proof. intros rab ps c ra.
+destruct ra. pose (rab _ _ r).
+apply rmI. apply r0. Qed.
+ +
+Lemma fer_mono U W (rlsa rlsb : rlsT (list U * W)) :
+  rsub rlsa rlsb -> rsub (fst_ext_rls rlsa) (fst_ext_rls rlsb).
+Proof. intros rab ps c fea.
+destruct fea. destruct r. pose (rab _ _ r).
+eapply fextI. apply rmI. apply r0. Qed.
+ +
+Lemma ser_mono U W (rlsa rlsb : rlsT (U * list W)) :
+  rsub rlsa rlsb -> rsub (snd_ext_rls rlsa) (snd_ext_rls rlsb).
+Proof. intros rab ps c sea.
+destruct sea. destruct r. pose (rab _ _ r).
+eapply sextI. apply rmI. apply r0. Qed.
+ +
+(* derl_fst_ext_rls - similar for seqrule above *)
+Lemma fst_ext_rls_fst_ext_rls (U W : Type) (pr : rlsT (list U * W)) :
+  rsub (fst_ext_rls (fst_ext_rls pr)) (fst_ext_rls pr).
+Proof. unfold rsub. intros. inversion X. subst. clear X.
+inversion X0. subst. clear X0. destruct X. destruct r.
+destruct c. simpl. rewrite fmlsext_fmlsext.
+eapply fextI' in p. simpl in p.
+eapply arg1_cong_imp. 2: exact p. clear p.
+induction ps ; simpl. reflexivity.
+rewrite IHps. destruct a. simpl. rewrite fmlsext_fmlsext. reflexivity. Qed.
+ +
+Definition fst_ext_rls_fst_ext_rls' (U W : Type) pr :=
+  rsubD (@fst_ext_rls_fst_ext_rls U W pr).
+ +
+Lemma derl_fst_ext_rls'' (U W : Type) (rules : rlsT (list U * W)) :
+  forall Phi1 Phi2, (forall ps c, derl rules ps c ->
+   derl (fst_ext_rls rules)
+     (map (apfst (fmlsext Phi1 Phi2)) ps) (apfst (fmlsext Phi1 Phi2) c)) *
+  (forall ps cs, dersl rules ps cs ->
+    dersl (fst_ext_rls rules) (map (apfst (fmlsext Phi1 Phi2)) ps)
+    (map (apfst (fmlsext Phi1 Phi2)) cs)).
+Proof. intros Phi1 Phi2.
+eapply (derl_dersl_rect_mut (rules := rules)
+  (fun ps c => fun _ => derl (fst_ext_rls rules)
+    (map (apfst (fmlsext Phi1 Phi2)) ps) (apfst (fmlsext Phi1 Phi2) c))
+  (fun ps cs : list _ => fun _ => dersl (fst_ext_rls rules)
+    (map (apfst (fmlsext Phi1 Phi2)) ps) (map (apfst (fmlsext Phi1 Phi2)) cs))).
+- simpl. intros. apply asmI.
+- intros. eapply dtderI. eapply fextI. apply rmI. eassumption. assumption.
+- simpl. apply dtNil.
+- intros. rewrite map_app. simpl. apply dtCons ; assumption. Qed.
+ +
+Definition derl_fst_ext_rls' U W rules Phi1 Phi2 :=
+  fst (@derl_fst_ext_rls'' U W rules Phi1 Phi2).
+Definition dersl_fst_ext_rls' U W rules Phi1 Phi2 :=
+  snd (@derl_fst_ext_rls'' U W rules Phi1 Phi2).
+ +
+Lemma derl_fst_ext_rls (U W : Type) (rules : rlsT (list U * W)) :
+  rsub (fst_ext_rls (derl rules)) (derl (fst_ext_rls rules)).
+Proof. unfold rsub. intros. destruct X. destruct r.
+apply derl_fst_ext_rls'. assumption. Qed.
+ +
+Lemma fst_ext_rls_derl_fst_ext_rls (U W : Type) (rules : rlsT (list U * W)) :
+  rsub (fst_ext_rls (derl (fst_ext_rls rules))) (derl (fst_ext_rls rules)).
+Proof. eapply rsub_trans. apply derl_fst_ext_rls.
unfold rsub. intros. eapply derl_mono. 2: eassumption.
apply fst_ext_rls_fst_ext_rls. Qed.
+ +
+Definition fst_ext_rls_derl_fst_ext_rls' U W rules :=
+  rsubD (@fst_ext_rls_derl_fst_ext_rls U W rules).
+ +
+(* simple version of weakening, new stuff added at beginning or end,
+  could do more complicated, but why bother, have exchange *)

+Definition wkL_valid V W rules (cl : list V) cr :=
+  forall Gam1 Gam2, derrec rules (@emptyT _) (fmlsext Gam1 Gam2 cl, cr : W).
+Definition wkL_valid' V W rules seq := @wkL_valid V W rules (fst seq) (snd seq).
+ +
+Definition can_wkL V W rules seq :=
+  derrec rules emptyT seq -> @wkL_valid' V W rules seq.
+ +
+Lemma can_wkL_req V W rlsa rlsb seq : req rlsa rlsb ->
+  @can_wkL V W rlsa seq -> can_wkL rlsb seq.
+Proof. unfold can_wkL. unfold wkL_valid'. unfold wkL_valid.
+intros rab da derb *.
+specialize (da (derrec_rmono (snd rab) derb)).
+exact (derrec_rmono (fst rab) (da Gam1 Gam2)). Qed.
+ +
+Lemma weakeningL: forall V W seq rules, @can_wkL V W (fst_ext_rls rules) seq.
+Proof. unfold can_wkL. intros.
+eapply derrec_all_rect in X. exact X.
+intros. contradiction H.
+intros ps concl ljpc dsps fwk. destruct ljpc. inversion r.
+destruct c0. unfold wkL_valid'. unfold wkL_valid. simpl. subst. clear r.
+intros *. rewrite fmlsext_fmlsext.
+eapply derI. eapply fextI. eapply rmI_eq. apply X0.
+reflexivity. reflexivity.
+apply dersrecI_forall. intros c0 incm.
+apply InT_mapE in incm. cD.
+eapply ForallTD_forall in fwk.
+2: apply InT_map. 2: exact incm1.
+simpl in incm0. destruct incm0. simpl in fwk.
+unfold wkL_valid' in fwk. unfold wkL_valid in fwk. simpl in fwk.
+rewrite - fmlsext_fmlsext. apply fwk. Qed.
+ +
+
+ +
+exchange +
+
+(* properties can exchange adjacent sublists, and resulting sequent
+  is derivable (not conditional on unexchanged version being derivable *)

+Definition can_exchL W Y rules seq :=
+  forall (Gam Gams : list W) (Delt : Y), seq = pair Gam Delt -> swapped Gam Gams ->
+  derrec rules (@emptyT _) (pair Gams Delt).
+ +
+Definition can_exchR W Y rules seq :=
+  forall (Gam : Y) (Delt Delts : list W), seq = pair Gam Delt -> swapped Delt Delts ->
+  derrec rules (@emptyT _) (pair Gam Delts).
+ +
+Inductive sing_empty X : list X -> Type :=
+  | se_empty : sing_empty []
+  | se_single : forall a, sing_empty [a].
+ +
+Lemma sing_empty_app X (xs ys : list X):
+  sing_empty (xs ++ ys) -> sum (xs = []) (ys = []).
+Proof. intro. inversion X0. destruct xs. tauto.
+simpl in H0. discriminate H0.
+destruct xs. tauto.
+injection H0 as. destruct xs. simpl in H0. subst. tauto.
+simpl in H0. discriminate H0. Qed.
+ +
+Lemma sing_empty_app_cons X z (xs ys : list X):
+  sing_empty (xs ++ z :: ys) -> (xs = []) * (ys = []).
+Proof. intro se. inversion se.
+list_eq_ncT. inversion H0. list_eq_ncT. sD. inversion H1. tauto.
+list_eq_ncT. Qed.
+ +
+Inductive fst_rel (A B : Type) (R : relationT A) : relationT (A * B) :=
+  fst_relI : forall x y z, R x y -> @fst_rel A B R (x, z : B) (y, z).
+ +
+Inductive snd_rel (A B : Type) (R : relationT A) : relationT (B * A) :=
+  snd_relI : forall x y z, R x y -> @snd_rel A B R (z : B, x) (z, y).
+ +
+Lemma fext_e: forall (U W : Type) (pr : rlsT (list U * W)) ps cl cr Phi1 Phi2,
+  pr ps (cl, cr) ->
+  fst_ext_rls pr (map (apfst (fmlsext Phi1 Phi2)) ps) (Phi1 ++ cl ++ Phi2, cr).
+Proof. intros * H. rewrite <- fmlsext_def.
+  eapply fextI. eapply rmI_eq. exact H. reflexivity. reflexivity. Qed.
+ +
+Lemma sext_e: forall (U W : Type) (pr : rlsT (U * list W)) ps cl cr Phi1 Phi2,
+  pr ps (cl, cr) ->
+  snd_ext_rls pr (map (apsnd (fmlsext Phi1 Phi2)) ps) (cl, Phi1 ++ cr ++ Phi2).
+Proof. intros * H. rewrite <- fmlsext_def.
+  eapply sextI. eapply rmI_eq. exact H. reflexivity. reflexivity. Qed.
+ +
+Ltac concl_in_app X0 r sea :=
+  pose X0 as r ; apply sea in r ;
+  destruct r ; subst ; rewrite ?app_nil_r ; rewrite ?app_nil_l ;
+  simpl in X0 ; rewrite ?app_nil_r in X0.
+ +
+Ltac fwl_tac mid := eexists ; split ;
+  [> assoc_mid mid ; apply fext_e ; eassumption |
+    apply ForallTI_forall ; intros x inms ; apply InT_mapE in inms ;
+    destruct inms as [x0 p] ; destruct p as [sex int] ;
+    destruct x0 ; simpl in sex ; unfold fmlsext in sex ; destruct sex ;
+    eexists ; split ;
+      [> eapply InT_map ; eassumption |
+      simpl ; unfold fmlsext ; apply fst_relI ; swap_tac ]].
+ +
+Ltac fwr_tac mid := eexists ; split ;
+  [> assoc_mid mid ; apply sext_e ; eassumption |
+    apply ForallTI_forall ; intros x inms ; apply InT_mapE in inms ;
+    destruct inms as [x0 p] ; destruct p as [sex int] ;
+    destruct x0 ; simpl in sex ; unfold fmlsext in sex ; destruct sex ;
+    eexists ; split ;
+      [> eapply InT_map ; eassumption |
+      simpl ; unfold fmlsext ; apply snd_relI ; swap_tac ]].
+ +
+Lemma exchL_std_rule: forall U W (rules : rlsT (list U * W)),
+  (forall ps U S, rules ps (U, S) -> sing_empty U) ->
+  forall ps c, fst_ext_rls rules ps c ->
+    can_trf_rules (fst_rel (@swapped _)) (fst_ext_rls rules) ps c.
+Proof. unfold can_trf_rules.
+intros U W rules se ps c sqr c' fr.
+pose (fun ps xs ys S rps =>
+  sing_empty_app xs ys (se ps (xs ++ ys) S rps)) as sea.
+inversion fr. subst. clear fr.
+inversion sqr. clear sqr. subst.
+inversion X0. destruct c as [pl pr].
+simpl in H1. unfold fmlsext in H1.
+inversion H1. subst. clear H1. clear X0.
+inversion X. subst.
+acacD'T2 ; subst.
+- concl_in_app X1 r sea. + fwl_tac H3. + fwl_tac H1.
+- concl_in_app X1 r sea. concl_in_app X1 r sea.
++ fwl_tac H5. + fwl_tac C.
++ list_eq_nc. destruct e. subst. rewrite ?app_nil_r. rewrite ?app_nil_l.
+simpl in X1. rewrite ?app_nil_r in X1.
+fwl_tac H1.
+- fwl_tac pl.
+- concl_in_app X1 r sea. + fwl_tac H5. + fwl_tac H3.
+- fwl_tac pl.
+- fwl_tac pl.
+- concl_in_app X1 r sea. + fwl_tac H1. + fwl_tac H.
+- concl_in_app X1 r sea. concl_in_app X1 r sea.
++ fwl_tac H3. + fwl_tac B.
++ list_eq_ncT. destruct e. subst. rewrite ?app_nil_r. rewrite ?app_nil_l.
+  simpl in X1 ; rewrite ?app_nil_r in X1.
+fwl_tac H.
+- concl_in_app X1 r sea. concl_in_app X1 r sea. concl_in_app X1 r sea.
++ fwl_tac H5. + fwl_tac C.
++ list_eq_ncT. destruct e. subst. rewrite ?app_nil_r. rewrite ?app_nil_l.
+  simpl in X1 ; rewrite ?app_nil_r in X1.
+fwl_tac B.
++ list_eq_nc. destruct e. list_eq_nc. destruct H1. subst.
+rewrite ?app_nil_r. rewrite ?app_nil_l.
+  simpl in X1 ; rewrite ?app_nil_r in X1.
+fwl_tac H.
+- fwl_tac pl.
+Qed.
+ +
+Lemma exchR_std_rule: forall U W (rules : rlsT (U * list W)),
+  (forall ps U S, rules ps (U, S) -> sing_empty S) ->
+  forall ps c, snd_ext_rls rules ps c ->
+    can_trf_rules (snd_rel (@swapped _)) (snd_ext_rls rules) ps c.
+Proof. unfold can_trf_rules.
+intros U W rules se ps c sqr c' fr.
+pose (fun ps xs ys U rps =>
+  sing_empty_app xs ys (se ps U (xs ++ ys) rps)) as sea.
+inversion fr. subst. clear fr.
+inversion sqr. clear sqr. subst.
+inversion X0. destruct c as [pl pr].
+simpl in H1. unfold fmlsext in H1.
+inversion H1. subst. clear H1. clear X0.
+inversion X. subst.
+acacD'T2 ; subst.
+- concl_in_app X1 r sea. + fwr_tac H3. + fwr_tac H1.
+- concl_in_app X1 r sea. concl_in_app X1 r sea.
++ fwr_tac H5. + fwr_tac C.
++ list_eq_nc. destruct e. subst. rewrite ?app_nil_r. rewrite ?app_nil_l.
+simpl in X1. rewrite ?app_nil_r in X1.
+fwr_tac H1.
+- fwr_tac pr.
+- concl_in_app X1 r sea. + fwr_tac H5. + fwr_tac H3.
+- fwr_tac pr.
+- fwr_tac pr.
+- concl_in_app X1 r sea. + fwr_tac H1. + fwr_tac H.
+- concl_in_app X1 r sea. concl_in_app X1 r sea.
++ fwr_tac H3. + fwr_tac B.
++ list_eq_ncT. destruct e. subst. rewrite ?app_nil_r. rewrite ?app_nil_l.
+  simpl in X1 ; rewrite ?app_nil_r in X1.
+fwr_tac H.
+- concl_in_app X1 r sea. concl_in_app X1 r sea. concl_in_app X1 r sea.
++ fwr_tac H5. + fwr_tac C.
++ list_eq_ncT. destruct e. subst. rewrite ?app_nil_r. rewrite ?app_nil_l.
+  simpl in X1 ; rewrite ?app_nil_r in X1.
+fwr_tac B.
++ list_eq_nc. destruct e. list_eq_nc. destruct H1. subst.
+rewrite ?app_nil_r. rewrite ?app_nil_l.
+  simpl in X1 ; rewrite ?app_nil_r in X1.
+fwr_tac H.
+- fwr_tac pr.
+Qed.
+ +
+Definition rev_pair {U W} (p : U * W) := let (x, y) := p in (y, x).
+ +
+Lemma sext_rev_fext U W (rules : rlsT (U * list W)) ps c :
+  snd_ext_rls rules ps c ->
+  fst_ext_rls (rlsmap rev_pair rules) (map rev_pair ps) (rev_pair c).
+Proof. intro ser. destruct ser. inversion r. destruct c0.
+clear r. subst. simpl.
+eapply fextI. eapply rmI_eq. apply rmI. exact X.
+2: reflexivity.
+clear X. induction ps0. reflexivity.
+simpl. rewrite IHps0. destruct a. reflexivity. Qed.
+ +
+(*
+this is not going to be worthwhile without a bunch more lemmas 
+such as sext_rev_fext above, and more
+
+Lemma exchR_std_rule: forall U W (rules : rlsT (U * list W)),
+  (forall ps U S, rules ps (U, S) -> sing_empty S) ->
+  forall ps c, snd_ext_rls rules ps c ->
+    can_trf_rules (snd_rel (@swapped _)) (snd_ext_rls rules) ps c.
+Proof. intros * se * ser.
+pose (rlsmap rev_pair rules) as rrules.
+pose (@exchL_std_rule _ _ rrules).
+require c0.
+{ intros * rr.  inversion rr. destruct c1. simpl in H1. inversion H1. subst.
+eapply se. subst rrules. exact X. }
+specialize (c0 (map rev_pair ps) (rev_pair c)).
+require c0.  { subst rrules. exact (sext_rev_fext ser). }
+
+destruct ser.
+eapply fextI. inversion r.
+
+*)

+ +
+(* we may also want to refer to rules individually *)
+Inductive Idrule (W : Type) : rlsT (rel (list W)) :=
+  | Idrule_I : forall A, Idrule [] (pair [A] [A]).
+ +
+Lemma sr_Id_alt X (A : X) ant suc: InT A ant -> InT A suc ->
+  seqrule (@Idrule X) [] (ant, suc).
+Proof. intros. apply InT_split in X1.
+apply InT_split in X0. cD. subst.
+eapply Sctxt_eq. apply (Idrule_I A).
+simpl. reflexivity. simpl. reflexivity. simpl. reflexivity. Qed.
+ +
+
+
+ +
+ + + diff --git a/General.gen_tacs.html b/General.gen_tacs.html new file mode 100644 index 0000000..bb7657e --- /dev/null +++ b/General.gen_tacs.html @@ -0,0 +1,275 @@ + + + + + + + + + + + + + +
+
+

General.gen_tacs

+ +
+ +
+Require Export List.
+Set Implicit Arguments.
+Export ListNotations.
+ +
+From Coq Require Import ssreflect.
+ +
+Require Import genT gen.
+Require Import List_lemmasT.
+(*
+Require Import swappedT.
+*)

+ +
+Definition rel (W : Type) : Type := prod W W.
+Definition trf (W : Type) : Type := W -> W.
+ +
+Lemma midI: forall T (a b c d : list T) x,
+  a = c -> b = d -> a ++ x :: b = c ++ x :: d.
+Proof. intros. subst. reflexivity. Qed.
+ +
+Lemma appI: forall T (a b c d : list T),
+  a = b -> c = d -> a ++ c = b ++ d.
+Proof. intros. subst. reflexivity. Qed.
+ +
+Lemma apprI: forall T (a b c : list T),
+  a = b -> a ++ c = b ++ c.
+Proof. intros. subst. reflexivity. Qed.
+ +
+Lemma appl_cong: forall {T} (a b c : list T),
+  (c ++ a = c ++ b) <-> (a = b).
+Proof. intros. unfold iff. apply conj ; intro.
+  induction c. simpl in H. exact H.
+  simpl in H. inversion H. tauto.
+  intros. subst. reflexivity. Qed.
+ +
+Lemma appr_cong: forall {T} (a b c : list T),
+  (a ++ c = b ++ c) <-> (a = b).
+Proof. intros. unfold iff. apply conj ; intro.
+pose (@if_eq_rev_eq T (a ++ c) (b ++ c) H).
+rewrite -> !rev_app_distr in e.
+rewrite -> appl_cong in e.
+apply if_rev_eq in e. exact e.
+subst. reflexivity. Qed.
+ +
+Lemma app_eq_nil_iff: forall {A} (l l' : list A),
+  l ++ l' = [] <-> l = [] /\ l' = [].
+Proof. intros. unfold iff. split ; intros.
+  destruct l ; simpl in H ; [ tauto | discriminate].
+  destruct H. subst. simpl. tauto. Qed.
+ +
+Lemma applI: forall {T} (a b c : list T),
+  a = b -> c ++ a = c ++ b.
+Proof. intros. subst. reflexivity. Qed.
+ +
+Definition app_assoc_cons {A} (x : A) l m xs := app_assoc l m (x :: xs).
+ +
+(* in ssreflect *)
+Ltac list_assoc_l' := repeat (rewrite !app_assoc || rewrite !app_comm_cons).
+Ltac list_assoc_r' :=
+  repeat (rewrite - !app_assoc || rewrite - !app_comm_cons).
+(* tactic to strip off same sublists on lhs or rhs of append sequence *)
+Ltac apps_eq_tac := list_assoc_r' ; rewrite ?eq_app_canc1 ;
+  list_assoc_l' ; rewrite ?eq_app_canc2 ; reflexivity.
+ +
+(* to rearrange a ++ b ++ l ++ d ++ e so that l is central, 
+  ie to give (a ++ b) ++ l ++ (d ++ e),
+  can affect terms not containing l *)

+Ltac assoc_mid l :=
+  list_assoc_r' ;
+  rewrite ?app_comm_cons ;
+  repeat ((rewrite - (app_assoc _ l _) ; fail 1) || rewrite app_assoc) ;
+  rewrite - (app_assoc _ l _).
+ +
+(* to rearrange a ++ b ++ x :: d ++ e so that x is central,
+  ie to give (a ++ b) ++ x :: d ++ e *)

+Ltac assoc_single_mid := list_assoc_r' ; rewrite ?app_assoc_cons.
+ +
+(* as assoc_single_mid, but to specify x *)
+Ltac assoc_single_mid' x := list_assoc_r' ;
+  repeat (rewrite (app_assoc_cons x) || rewrite (list_rearr23 x)).
+ +
+(* test of assoc_mid
+Lemma x : forall T (a b c d e f g : list T) (x y z : T),
+  a ++ x :: b ++ c ++ y :: d ++ e ++ z :: f = g.
+intros.
+assoc_mid b. (* doesn't work *)
+assoc_mid c.
+assoc_mid d. (* doesn't work *)
+assoc_mid e.
+*)

+ +
+Ltac acacE :=
+  repeat match goal with
+    | [ H : _ |- _ ] => apply app_eq_app in H ; sE
+    | [ H : _ |- _ ] => apply cons_eq_app in H ; sE
+    | [ H : _ |- _ ] => apply app_eq_cons in H ; sE
+    end.
+ +
+Ltac acacD :=
+  repeat match goal with
+    | [ H : _ |- _ ] => apply app_eq_app in H ; sD
+    | [ H : _ |- _ ] => apply cons_eq_app in H ; sD
+    | [ H : _ |- _ ] => apply app_eq_cons in H ; sD
+    | [ H : _ :: _ = _ :: _ |- _ ] => injection H as ?H ?H
+    end.
+ +
+Ltac acacD' :=
+  repeat match goal with
+    | [ H : _ ++ _ = _ ++ _ |- _ ] => apply app_eq_app in H ; sD
+    | [ H : _ :: _ = _ ++ _ |- _ ] => apply cons_eq_app in H ; sD
+    | [ H : _ ++ _ = _ :: _ |- _ ] => apply app_eq_cons in H ; sD
+    | [ H : _ :: _ = _ :: _ |- _ ] => injection H as ?H ?H
+    | [ H : (_, _) = (_, _) |- _ ] => injection H as ?H ?H
+    | [ H : _ :: _ = [] |- _ ] => discriminate H
+    | [ H : [] = _ :: _ |- _ ] => discriminate H
+         end.
+ +
+Ltac acacD'T2 :=
+  repeat match goal with
+    | [ H : _ ++ _ = _ ++ _ |- _ ] => apply app_eq_appT2 in H ; sD
+    | [ H : _ :: _ = _ ++ _ |- _ ] => apply cons_eq_appT2 in H ; sD
+    | [ H : _ ++ _ = _ :: _ |- _ ] => apply app_eq_consT2 in H ; sD
+    | [ H : _ :: _ = _ :: _ |- _ ] => injection H as ?H ?H
+    | [ H : (_, _) = (_, _) |- _ ] => injection H as ?H ?H
+    | [ H : _ :: _ = [] |- _ ] => discriminate H
+    | [ H : [] = _ :: _ |- _ ] => discriminate H
+         end.
+ +
+Ltac acacDe' :=
+  match goal with
+    | [ H : _ ++ _ = _ ++ _ |- _ ] => apply app_eq_app in H ; sD
+    | [ H : _ :: _ = _ ++ _ |- _ ] => apply cons_eq_app in H ; sD
+    | [ H : _ ++ _ = _ :: _ |- _ ] => apply app_eq_cons in H ; sD
+    | [ H : _ :: _ = _ :: _ |- _ ] => injection H as ?H ?H
+    | [ H : (_, _) = (_, _) |- _ ] => injection H as ?H ?H
+    | [ H : _ :: _ = [] |- _ ] => discriminate H
+    | [ H : [] = _ :: _ |- _ ] => discriminate H
+    | [ H : _ ++ _ = [] |- _ ] => apply app_eq_nil in H
+    | [ H : [] = _ ++ _ |- _ ] => apply nil_eq_app in H
+    end.
+ +
+Ltac acacDe'T2 :=
+  match goal with
+    | [ H : _ ++ _ = _ ++ _ |- _ ] => apply app_eq_appT2 in H ; sD
+    | [ H : _ :: _ = _ ++ _ |- _ ] => apply cons_eq_appT2 in H ; sD
+    | [ H : _ ++ _ = _ :: _ |- _ ] => apply app_eq_consT2 in H ; sD
+    | [ H : _ :: _ = _ :: _ |- _ ] => injection H as ?H ?H
+    | [ H : (_, _) = (_, _) |- _ ] => injection H as ?H ?H
+    | [ H : _ :: _ = [] |- _ ] => discriminate H
+    | [ H : [] = _ :: _ |- _ ] => discriminate H
+    | [ H : _ ++ _ = [] |- _ ] => apply app_eq_nilT in H
+    | [ H : [] = _ ++ _ |- _ ] => apply nil_eq_appT in H
+  end.
+ +
+Ltac acacDe := repeat (sD' || acacDe').
+Ltac acacDeT2 := repeat (sD' || acacDe'T2).
+ +
+Theorem app_eq_unitT :
+    forall {A : Type } (x y:list A) (a:A),
+      x ++ y = [a] -> (x = [] /\ y = [a]) + (x = [a] /\ y = []).
+Proof.
+  intros *; intros H; destruct x; auto.
+  simpl in H; inversion H as [[H1 H2]]; subst.
+  apply app_eq_nil in H2. destruct H2. subst. auto.
+Qed.
+ +
+Theorem unit_eq_appT :
+    forall {A : Type } (x y:list A) (a:A),
+      [a] = x ++ y -> (x = [] /\ y = [a]) + (x = [a] /\ y = []).
+Proof.
+  intros *; intros H.
+  apply app_eq_unitT. auto.
+Qed.
+ +
+Ltac list_eq_nc :=
+   match goal with
+     | [ H : _ ++ _ :: _ = [] |- _ ] => apply list_eq_nil in H
+     | [ H : [] = _ ++ _ :: _ |- _ ] => apply nil_eq_list in H
+     | [ H : _ ++ _ = [] |- _ ] => apply app_eq_nil in H
+     | [ H : [] = _ ++ _ |- _ ] => apply nil_eq_app in H
+     | [ H : _ ++ _ = [_] |- _ ] => apply app_eq_unit in H
+     | [ H : [_] = _ ++ _ |- _ ] => apply unit_eq_app in H
+     | [ H : _ ++ _ :: _ = [_] |- _ ] => apply list_eq_single in H
+     | [ H : [_] = _ ++ _ :: _ |- _ ] => apply single_eq_list in H
+     | [ H : _ :: _ = [] |- _ ] => discriminate H
+     | [ H : _ :: _ = _ :: _ |- _ ] => injection H as
+     end.
+ +
+(* Type version of list_eq_nc *)
+Ltac list_eq_ncT :=
+   match goal with
+     | [ H : _ ++ _ :: _ = [] |- _ ] => apply list_eq_nil in H
+     | [ H : [] = _ ++ _ :: _ |- _ ] => apply nil_eq_list in H
+     | [ H : _ ++ _ = [] |- _ ] => apply app_eq_nilT in H
+     | [ H : [] = _ ++ _ |- _ ] => apply nil_eq_appT in H
+     | [ H : _ ++ _ = [_] |- _ ] => apply app_eq_unitT in H
+     | [ H : [_] = _ ++ _ |- _ ] => apply unit_eq_appT in H
+     | [ H : _ ++ _ :: _ = [_] |- _ ] => apply list_eq_singleT in H
+     | [ H : [_] = _ ++ _ :: _ |- _ ] => apply single_eq_listT in H
+     | [ H : _ :: _ = [] |- _ ] => discriminate H
+     | [ H : _ :: _ = _ :: _ |- _ ] => injection H as
+     end.
+ +
+Ltac sD_list_eq := repeat (cD' || list_eq_nc || sDx).
+ +
+
+
+ +
+ + + diff --git a/General.general_export.html b/General.general_export.html new file mode 100644 index 0000000..090c24d --- /dev/null +++ b/General.general_export.html @@ -0,0 +1,54 @@ + + + + + + + + + + + + + +
+
+

General.general_export

+ +
+Require Export List_lemmasT.
+Require Export ddT.
+Require Export dd_fc.
+Require Export existsT.
+Require Export gen.
+Require Export genT.
+Require Export gen_seq.
+Require Export gen_tacs.
+Require Export gentree.
+Require Export gstep.
+Require Export rtcT.
+Require Export swappedT.
+Require Export univ_gen_ext.
+Require Export univ_gen_mod.
+
+
+ +
+ + + diff --git a/General.gentree.html b/General.gentree.html new file mode 100644 index 0000000..99c7d0f --- /dev/null +++ b/General.gentree.html @@ -0,0 +1,592 @@ + + + + + + + + + + + + + +
+
+

General.gentree

+ +
+ +
+(* constructions for inductive proofs about derivations,
+  adapted from ~jeremy/isabelle/2005/seqms/gentree.{thy,ML} *)

+ +
+Set Implicit Arguments.
+Require Import Coq.Program.Equality. (* for dependent induction/destruction *)
+Require Import PeanoNat. (* for Nat *)
+ +
+Require Import gen.
+Require Import genT.
+Require Import ddT.
+Require Import dd_fc.
+Require Import rtcT.
+Require Import Lia.
+Require Import gstep.
+ +
+
+ +
+conditions for inductive proofs for a tree +
+
+ +
+Definition gen_step_tr W rules fty P (A : fty) sub
+  (dt : @derrec_fc W rules emptyT) :=
+  (forall A' : fty, sub A' A -> forall d, P A' d) ->
+  (forall dtn, in_nextup_fc dtn dt -> P A dtn) -> P A dt.
+ +
+(* here is the same thing based the conclusion of the tree *)
+Definition gen_step_c W rules fty (P : fty -> W -> Type) A sub c
+  (dt : derrec rules emptyT c) :=
+  (forall A' : fty, sub A' A ->
+    forall c (d : derrec rules emptyT c), P A' c) ->
+  (forall cn (dtn : derrec rules emptyT cn),
+    in_nextup dtn dt -> P A cn) -> P A c.
+ +
+Definition gf2_step_tr W fty (P : fty -> W -> Type) A sub dtsr dts :=
+    ((forall A', sub A' A -> (forall dts, AccT dtsr dts -> P A' dts)) ->
+    (forall dts', dtsr dts' dts -> P A dts') -> P A dts).
+ +
+
+ +
+results linking the conditions for inductive proofs for a tree +
+
+ +
+Lemma gs_gsc W fty rules P A sub (c : W) (dt : derrec rules emptyT c):
+  iffT (@gen_step W fty P A sub (derrec rules emptyT)
+    (map (@derrec_fc_concl _ _ _) (nextup (fcI dt))) c)
+  (@gen_step_c W rules fty P A sub c dt).
+Proof. unfold gen_step. unfold gen_step_c. apply pair ; intros.
+- specialize (X X0). clear X0.
+apply X. clear X.
+apply ForallTI_forall.
+intros x inmn. apply InT_mapE in inmn. cD. subst. split.
++ apply der_der_fc.
++ destruct inmn. apply nextup_in_nu in inmn1.
+simpl. rewrite der_concl_eq. eapply X1 in inmn1. exact inmn1.
++ exact dt.
+- specialize (X X0). clear X0.
+apply X. clear X.
+intros * inn.
+eapply ForallTD_forall in X1. cD. exact X0.
+apply in_nextup_nu in inn. apply InT_mapI.
+exists (fcI dtn). split. simpl. rewrite der_concl_eq. reflexivity.
+exact inn. Qed.
+ +
+Lemma gstr_gf2 W rules fty P A sub (dt : @derrec_fc W rules emptyT) :
+  iffT (@gen_step_tr W rules fty P A sub dt)
+    (@gf2_step_tr _ fty P A sub (@in_nextup_fc _ _ _) dt).
+Proof. unfold gen_step_tr. unfold gf2_step_tr. apply pair ; intros.
+- pose (fun A' saa dts => X0 A' saa dts (AccT_in_nextup_fc dts)) as X0'.
+exact (X X0' X1).
+- revert X1. apply X. intros. apply (X0 A' X1). Qed.
+ +
+Lemma gsc_gstr W rules fty P A sub c dt:
+  iffT (@gen_step_c W rules fty P A sub c dt)
+    (@gen_step_tr W rules fty (fun A' d => P A' (derrec_fc_concl d))
+      (A : fty) sub (fcI dt)).
+Proof. unfold gen_step_tr. unfold gen_step_c. simpl.
+apply pair ; intros.
+- rewrite (der_concl_eq dt). apply X.
++ intros. specialize (X0 A' X2 (fcI d)). simpl in X0.
+rewrite (der_concl_eq d) in X0. exact X0.
++ intros * inn.
+specialize (X1 (fcI dtn)). simpl in X1.
+rewrite (der_concl_eq dtn) in X1. apply X1.
+exact (in_nextup_fcI inn).
+- rewrite (der_concl_eq dt) in X. apply X.
++ intros. apply (X0 A' X2).
+destruct d. simpl. rewrite (der_concl_eq d). exact d.
++ intros dtn inn. destruct dtn.
+simpl. rewrite (der_concl_eq d).
+apply (X1 concl d). dependent destruction inn. exact i. Qed.
+ +
+(* so we have these results linking these various conditions *)
+ +
+
+ +
+lemmas enabling inductive proofs for a tree +
+
+ +
+Lemma gen_step_c_lem W rules fty (P : fty -> W -> Type) A sub : AccT sub A ->
+  (forall A c dt, @gen_step_c W rules fty P A sub c dt) ->
+  forall c (dt : derrec rules emptyT c), P A c.
+Proof. intros acc gs. induction acc.
+eapply derrec_all_rect.
+intros. destruct H.
+unfold gen_step_c in gs.
+intros ps concl rpc drs fps.
+pose (derI _ rpc drs).
+specialize (gs x concl d X).
+apply gs. clear gs a X.
+intros. eapply ForallTD_forall in fps. apply fps.
+exact (in_nextup_concl_in X). Qed.
+ +
+(* this also gives an induction principle for derrec_fc *)
+Lemma gen_step_tr_lem W rules fty P A sub : AccT sub A ->
+  (forall A dt, @gen_step_tr W rules fty P A sub dt) -> forall dt, P A dt.
+Proof. intros acc gs. induction acc.
+unfold gen_step_tr in gs.
+pose (fun dt => gs x dt X) as p.
+intro. destruct dt. revert d. revert concl.
+(* note derrec_all_rect is forall conclusions, we want forall trees *)
+eapply derrec_rect_mut_all.
+- intros. destruct p0.
+- intros * apd. apply p. unfold nextup.
+intros dtn ind. destruct dtn.
+exact (allP_all_in_d apd (in_trees_drs d (in_nextup_fc_nu ind))). Qed.
+ +
+Lemma gf2_step_tr_lem W fty (P : fty -> W -> Type) A sub dtsr :
+  (forall A dts, gf2_step_tr P A sub dtsr dts) ->
+     AccT sub A -> (forall dts, AccT dtsr dts -> P A dts).
+Proof. intros gs acc. induction acc.
+intros dts add. induction add.
+unfold gf2_step_tr in gs. exact (gs _ _ X X0). Qed.
+ +
+
+ +
+conditions for inductive proofs for two trees +
+
+ +
+Definition dt2fun fty U W rlsa rlsb (P : fty -> U -> W -> Type) (A : fty)
+  (da : @derrec_fc U rlsa emptyT) (db : @derrec_fc W rlsb emptyT) :=
+  P A (derrec_fc_concl da) (derrec_fc_concl db).
+ +
+Definition gen_step2_tr U W rulesa rulesb fty P (A : fty) sub
+  (dta : @derrec_fc U rulesa emptyT) (dtb : @derrec_fc W rulesb emptyT) :=
+  (forall A' : fty, sub A' A -> forall da db, P A' da db) ->
+  (forall dtna, in_nextup_fc dtna dta -> P A dtna dtb) ->
+  (forall dtnb, in_nextup_fc dtnb dtb -> P A dta dtnb) -> P A dta dtb.
+ +
+Definition gen_step2_c U W rulesa rulesb fty
+  (P : fty -> U -> W -> Type) (A : fty) sub ca cb
+  (dta : derrec rulesa emptyT ca)
+  (dtb : derrec rulesb emptyT cb) :=
+  (forall A' : fty, sub A' A ->
+    forall ca (dta : derrec rulesa emptyT ca)
+      cb (dtb : derrec rulesb emptyT cb), P A' ca cb) ->
+  (forall cp (dtp : derrec rulesa emptyT cp),
+    in_nextup dtp dta -> P A cp cb) ->
+  (forall cq (dtq : derrec rulesb emptyT cq),
+    in_nextup dtq dtb -> P A ca cq) -> P A ca cb.
+ +
+Definition gf_step2_tr U W fty (P : fty -> U -> W -> Type)
+    A sub gfl gfr dta dtb :=
+  (forall A', sub A' A ->
+    forall a b, AccT gfl a -> AccT gfr b -> P A' a b) ->
+  (forall dtp, gfl dtp dta -> P A dtp dtb) ->
+  (forall dtq, gfr dtq dtb -> P A dta dtq) -> P A dta dtb.
+ +
+Definition sum_step2_tr U W fty (P : fty -> U -> W -> Type)
+    A sub gsl gsr dta dtb :=
+  (forall A', sub A' A -> forall a b, P A' a b) ->
+  (forall dta' dtb', gsl dta' + gsr dtb' < gsl dta + gsr dtb ->
+    P A dta' dtb') -> P A dta dtb.
+ +
+
+ +
+results linking the conditions for intudtive proofs for two trees +
+
+Lemma gs2_gs2c U W rulesa rulesb fty P (A : fty) sub ca cb dta dtb:
+  iffT (@gen_step2 U W fty P A sub
+    (derrec rulesa emptyT) (derrec rulesb emptyT)
+    (der_botr_ps dta) ca (der_botr_ps dtb) cb)
+  (@gen_step2_c U W rulesa rulesb fty P A sub ca cb dta dtb).
+Proof. unfold gen_step2. unfold gen_step2_c.
+  rewrite <- !der_botr_ps_eq. apply pair ; intros.
+- specialize (X X0). clear X0.
+apply (fun fa fb => X fa fb dta dtb) ; clear X ; apply ForallTI_forall ;
+intros x inmn ; apply InT_mapE in inmn ; cD ; subst ; split ;
+try apply der_der_fc.
++ destruct inmn. apply nextup_in_nu in inmn1.
+simpl. rewrite der_concl_eq. eapply X1 in inmn1. exact inmn1.
++ destruct inmn. apply nextup_in_nu in inmn1.
+simpl. rewrite der_concl_eq. eapply X2 in inmn1. exact inmn1.
+- specialize (X X0). clear X0.
+apply X ; clear X ; intros * inn.
++ eapply ForallTD_forall in X1. cD. exact X0.
+apply in_nextup_nu in inn. apply InT_mapI.
+exists (fcI dtp). split. simpl. rewrite der_concl_eq. reflexivity. exact inn.
++ eapply ForallTD_forall in X2. cD. exact X0.
+apply in_nextup_nu in inn. apply InT_mapI.
+exists (fcI dtq). split. simpl. rewrite der_concl_eq. reflexivity. exact inn.
+Qed.
+ +
+(*
+(** results linking the conditions for intudtive proofs for two trees **)
+Lemma gs2_gs2c U W rulesa rulesb fty P (A : fty) sub ca cb dta dtb:
+  iffT (@gen_step2 U W fty P A sub
+    (derrec rulesa emptyT) (derrec rulesb emptyT)
+    (map (@derrec_fc_concl _ _ _) (nextup (fcI dta))) ca
+    (map (@derrec_fc_concl _ _ _) (nextup (fcI dtb))) cb)
+  (@gen_step2_c U W rulesa rulesb fty P A sub ca cb dta dtb).
+Proof. unfold gen_step2.  unfold gen_step2_c. apply pair ; intros.
+- specialize (X X0). clear X0.
+apply (fun fa fb => X fa fb dta dtb) ; clear X ; apply ForallTI_forall ;
+intros x inmn ; apply InT_mapE in inmn ; cD ; subst ;  split ;
+try apply der_der_fc.
++ destruct inmn.  apply nextup_in_nu in inmn1.
+simpl. rewrite der_concl_eq.  eapply X1 in inmn1. exact inmn1.
++ destruct inmn.  apply nextup_in_nu in inmn1.
+simpl. rewrite der_concl_eq.  eapply X2 in inmn1. exact inmn1.
+- specialize (X X0). clear X0.
+apply X ; clear X ; intros * inn.
++ eapply ForallTD_forall in X1. cD. exact X0.
+apply in_nextup_nu in inn.  apply InT_mapI.
+exists (fcI dtp). split. simpl. rewrite der_concl_eq. reflexivity.  exact inn.
++ eapply ForallTD_forall in X2. cD. exact X0.
+apply in_nextup_nu in inn.  apply InT_mapI.
+exists (fcI dtq). split. simpl. rewrite der_concl_eq. reflexivity.  exact inn.
+Qed.
+*)

+ +
+Lemma gs2tr_gf2 U W rulesa rulesb fty P A sub dta dtb :
+  iffT (@gen_step2_tr U W rulesa rulesb fty P A sub dta dtb)
+    (@gf_step2_tr _ _ fty P A sub
+      (@in_nextup_fc _ _ _) (@in_nextup_fc _ _ _) dta dtb).
+Proof. unfold gen_step2_tr. unfold gf_step2_tr. apply pair ; intros.
+- pose (fun A' saa a b =>
+  X0 A' saa a b (AccT_in_nextup_fc a) (AccT_in_nextup_fc b)) as X0'.
+exact (X X0' X1 X2).
+- revert X2. revert X1. apply X. intros. apply (X0 A' X1). Qed.
+ +
+Lemma gs2c_gs2tr U W rulesa rulesb fty P A sub ca cb dta dtb:
+  iffT (@gen_step2_c U W rulesa rulesb fty P A sub ca cb dta dtb)
+  (@gen_step2_tr U W rulesa rulesb fty (dt2fun P) A sub (fcI dta) (fcI dtb)).
+Proof. unfold gen_step2_tr. unfold gen_step2_c. unfold dt2fun. simpl.
+apply pair ; intros.
+- rewrite (der_concl_eq dta). rewrite (der_concl_eq dtb). apply X.
++ intros A' saa ca0 da cb0 db.
+specialize (X0 A' saa (fcI da) (fcI db)). simpl in X0.
+rewrite (der_concl_eq da) in X0. rewrite (der_concl_eq db) in X0. exact X0.
++ intros * inn. specialize (X1 (fcI dtp)). simpl in X1.
+rewrite (der_concl_eq dtp) in X1. rewrite (der_concl_eq dtb) in X1. apply X1.
+exact (in_nextup_fcI inn).
++ intros * inn. specialize (X2 (fcI dtq)). simpl in X2.
+rewrite (der_concl_eq dtq) in X2. rewrite (der_concl_eq dta) in X2. apply X2.
+exact (in_nextup_fcI inn).
+- rewrite (der_concl_eq dta) in X. rewrite (der_concl_eq dtb) in X. apply X.
++ intros A' saa *. apply (X0 A' saa).
+destruct da. simpl. rewrite (der_concl_eq d). exact d.
+destruct db. simpl. rewrite (der_concl_eq d). exact d.
++ intros * inn. destruct dtna.
+simpl. rewrite (der_concl_eq d). apply (X1 concl d).
+dependent destruction inn. exact i.
++ intros * inn. destruct dtnb.
+simpl. rewrite (der_concl_eq d). apply (X2 concl d).
+dependent destruction inn. exact i. Qed.
+ +
+(* so we have these results linking these various conditions *)
+ +
+
+ +
+lemmas enabling inductive proofs for two trees +
+
+ +
+Lemma gen_step2_c_lem U W rulesa rulesb fty P A sub : AccT sub A ->
+  (forall A ca cb dta dtb,
+    @gen_step2_c U W rulesa rulesb fty P A sub ca cb dta dtb) ->
+  forall ca (dta : derrec rulesa emptyT ca) cb (dtb : derrec rulesb emptyT cb),
+    P A ca cb.
+Proof. intros acc gs. induction acc.
+eapply derrec_all_rect2.
+intros. destruct H. intros. destruct H.
+unfold gen_step2_c in gs.
+intros *. intros rx ry drx dry fpx fpy.
+pose (derI _ rx drx) as dx. pose (derI _ ry dry) as dy.
+specialize (gs x cx cy dx dy X).
+apply gs ; clear gs a X ; intros.
++ eapply ForallTD_forall in fpx. apply fpx. exact (in_nextup_concl_in X).
++ eapply ForallTD_forall in fpy. apply fpy. exact (in_nextup_concl_in X).
+Qed.
+ +
+Lemma gen_step2_tr_lem U W rulesa rulesb fty P A sub : AccT sub A ->
+  (forall A dta dtb, @gen_step2_tr U W rulesa rulesb fty P A sub dta dtb) ->
+  forall dta dtb, P A dta dtb.
+Proof. intros acc gs. induction acc.
+unfold gen_step2_tr in gs. pose (fun dta dtb => gs x dta dtb X) as p.
+intro. destruct dta. revert d. revert concl.
+eapply (@derrec_rect_mut_all U rulesa emptyT
+  (fun ca (d : derrec rulesa emptyT ca) => forall dtb, P x (fcI d) dtb)).
+- intros. destruct p0.
+- intros * apd dtb. destruct dtb. revert d0. revert concl0.
+eapply (derrec_rect_mut_all).
++ intros. destruct p0.
++ intros * apdb. apply p. unfold nextup.
+intros dtna inda. destruct dtna.
+exact (allP_all_in_d apd (in_trees_drs d (in_nextup_fc_nu inda)) _).
+intros dtnb indb. destruct dtnb.
+exact (allP_all_in_d apdb (in_trees_drs _ (in_nextup_fc_nu indb))). Qed.
+ +
+Lemma gf_step2_tr_lem U W fty (P : fty -> U -> W -> Type) A sub gra grb :
+  (forall A dta dtb, gf_step2_tr P A sub gra grb dta dtb) -> AccT sub A ->
+    (forall dta, AccT gra dta -> forall dtb, AccT grb dtb -> P A dta dtb).
+Proof. intros gs acc. induction acc.
+unfold gf_step2_tr in gs.
+pose (fun y s dta dtb adg => X y s dta adg dtb) as X'.
+pose (fun dta dtb => gs x dta dtb X').
+intros dta aga. induction aga.
+intros dtb agb. pose agb. induction a1.
+apply p.
+intros dtp gad. apply X0 ; assumption.
+intros dtq gbd. apply (X1 dtq gbd (a1 dtq gbd)).
+Qed.
+ +
+Definition measure {U} f (dtn dt : U) := f dtn < f dt.
+ +
+Lemma AccT_measure' U f n : forall dt : U, f dt < n -> AccT (measure f) dt.
+Proof. induction n.
+- intros. apply Nat.nlt_0_r in H. contradiction H.
+- intros. apply AccT_intro. intros. unfold measure in H0. apply IHn.
+apply Nat.lt_succ_r in H. lia. Qed.
+ +
+Definition AccT_measure U f dt :=
+  @AccT_measure' U f _ dt (Nat.lt_succ_diag_r _).
+ +
+Definition size_step2_tr U W fty rulesa rulesb P (A : fty) sub :=
+    gf_step2_tr P A sub (measure (@derrec_fc_size U rulesa emptyT))
+      (measure (@derrec_fc_size W rulesb emptyT)).
+ +
+Definition height_step2_tr U W fty rulesa rulesb P (A : fty) sub :=
+    gf_step2_tr P A sub (measure (@derrec_fc_height U rulesa emptyT))
+      (measure (@derrec_fc_height W rulesb emptyT)).
+ +
+Lemma size_step2_tr_lem U W fty (rulesa : rlsT U) (rulesb : rlsT W)
+  (P : fty -> derrec_fc rulesa emptyT -> derrec_fc rulesb emptyT -> Type)
+  A sub dta dtb: AccT sub A ->
+  (forall A dta dtb, size_step2_tr P A sub dta dtb) -> P A dta dtb.
+Proof. unfold size_step2_tr. intros acc fgf.
+apply (gf_step2_tr_lem fgf acc) ; apply AccT_measure. Qed.
+ +
+Lemma height_step2_tr_lem U W fty (rulesa : rlsT U) (rulesb : rlsT W)
+  (P : fty -> derrec_fc rulesa emptyT -> derrec_fc rulesb emptyT -> Type)
+  A sub dta dtb: AccT sub A ->
+  (forall A dta dtb, height_step2_tr P A sub dta dtb) -> P A dta dtb.
+Proof. unfold height_step2_tr. intros acc fgf.
+apply (gf_step2_tr_lem fgf acc) ; apply AccT_measure. Qed.
+ +
+Lemma nextup_size W rules prems (d dn : @derrec_fc W rules prems):
+  InT dn (nextup d) -> derrec_fc_size dn < derrec_fc_size d.
+Proof. destruct d. destruct dn.
+unfold derrec_fc_size. unfold nextup.
+destruct d. intro. inversion X.
+intro idt. apply in_trees_drs in idt.
+simpl. clear r. (* otherwise complicates induction *)
+induction idt ; simpl.
++ apply Nat.lt_succ_r. apply Nat.le_add_r.
++ eapply Nat.lt_le_trans. apply IHidt. apply le_n_S. apply Nat.le_add_l. Qed.
+ +
+Lemma nextup_height W rules prems (d dn : @derrec_fc W rules prems):
+  InT dn (nextup d) -> derrec_fc_height dn < derrec_fc_height d.
+Proof. destruct d. destruct dn.
+unfold derrec_fc_height. unfold nextup.
+destruct d. intro. inversion X.
+intro idt. apply in_trees_drs in idt.
+simpl. clear r. (* otherwise complicates induction *)
+induction idt ; simpl.
++ apply Nat.lt_succ_r. apply Nat.le_max_l.
++ eapply Nat.lt_le_trans. apply IHidt. apply le_n_S. apply Nat.le_max_r. Qed.
+ +
+Definition in_nextup_size W rules prems d dn inn :=
+  @nextup_size W rules prems d dn (in_nextup_fc_nu inn).
+Definition in_nextup_height W rules prems d dn inn :=
+  @nextup_height W rules prems d dn (in_nextup_fc_nu inn).
+ +
+Lemma gs2_tr_size U W fty (rulesa : rlsT U) (rulesb : rlsT W)
+  (P : fty -> derrec_fc rulesa emptyT -> derrec_fc rulesb emptyT -> Type)
+  A sub dta dtb:
+  gen_step2_tr P A sub dta dtb -> size_step2_tr P A sub dta dtb.
+Proof. unfold size_step2_tr. unfold gf_step2_tr. unfold gen_step2_tr.
+intros gs2 saa.
+specialize (gs2 (fun A' s a b =>
+  saa A' s a b (AccT_measure _ _) (AccT_measure _ _))).
+clear saa. intros pb aq. apply gs2.
+intros. apply (pb dtna). unfold measure. apply (in_nextup_size X).
+intros. apply (aq dtnb). unfold measure. apply (in_nextup_size X). Qed.
+ +
+Lemma gs2_tr_height U W fty (rulesa : rlsT U) (rulesb : rlsT W)
+  (P : fty -> derrec_fc rulesa emptyT -> derrec_fc rulesb emptyT -> Type)
+  A sub dta dtb:
+  gen_step2_tr P A sub dta dtb -> height_step2_tr P A sub dta dtb.
+Proof. unfold height_step2_tr. unfold gf_step2_tr. unfold gen_step2_tr.
+intros gs2 saa.
+specialize (gs2 (fun A' s a b =>
+  saa A' s a b (AccT_measure _ _) (AccT_measure _ _))).
+clear saa. intros pb aq. apply gs2.
+intros. apply (pb dtna). unfold measure. apply (in_nextup_height X).
+intros. apply (aq dtnb). unfold measure. apply (in_nextup_height X). Qed.
+ +
+Lemma gs2_hs2 (U W fty : Type) rlsl rlsr (P : fty -> U -> W -> Type)
+  A sub cl cr (dl : derrec rlsl emptyT cl) (dr : derrec rlsr emptyT cr)
+  psl psr (brl : botRule_fc (fcI dl) psl cl) (brr : botRule_fc (fcI dr) psr cr):
+  gen_step2 P A sub (derrec rlsl emptyT) (derrec rlsr emptyT) psl cl psr cr ->
+  height_step2_tr (dt2fun P) A sub (fcI dl) (fcI dr).
+Proof. intro gs2. apply gs2_tr_height. apply gs2c_gs2tr. apply gs2_gs2c.
+rewrite (snd (botRule_fc_prems brl)). rewrite (snd (botRule_fc_prems brr)).
+exact gs2. Qed.
+ +
+Definition sumh_step2_tr U W fty (rulesa : rlsT U) (rulesb : rlsT W)
+  (P : fty -> derrec_fc rulesa emptyT -> derrec_fc rulesb emptyT -> Type)
+    A sub :=
+      sum_step2_tr P A sub (@derrec_fc_height _ _ _) (@derrec_fc_height _ _ _).
+ +
+Lemma sum_step2_tr_gf2 U W fty (P : fty -> U -> W -> Type)
+    A sub gsa gsb dta dtb :
+  iffT (sum_step2_tr P A sub gsa gsb dta dtb)
+    (gf2_step_tr (fun fml ab => P fml (fst ab) (snd ab)) A sub
+      (measure (fun ab => Nat.add (gsa (fst ab)) (gsb (snd ab)))) (dta, dtb)).
+Proof. unfold sum_step2_tr. unfold gf2_step_tr.
+unfold iffT. split.
+- intros fsglp sp glpp.
+simpl. apply fsglp.
++ intros A' saa a b.
+apply (sp A' saa (a, b)). apply AccT_measure.
++ intros *. specialize (glpp (dta', dtb')).
+unfold measure in glpp. simpl in glpp. exact glpp.
+- intros sglpp sp glp.
+simpl in sglpp. apply sglpp.
+intros. destruct dts. simpl. apply sp. apply X.
+intros. destruct dts'. simpl. apply glp.
+unfold measure in H. simpl in H. exact H.
+Qed.
+ +
+Definition sum_step2_tr_D_gf2 U W fty P A sub gsa gsb dta dtb :=
+  iffT_D1 (@sum_step2_tr_gf2 U W fty P A sub gsa gsb dta dtb).
+ +
+Lemma sum_step2_tr_lem U W fty (P : fty -> U -> W -> Type)
+    A sub gsa gsb dta dtb : AccT sub A ->
+  (forall A dta dtb, sum_step2_tr P A sub gsa gsb dta dtb) -> P A dta dtb.
+Proof. intros *. intros acc ss.
+pose (fun fty UW => P fty (fst UW) (snd UW)) as Q.
+assert (Q A (dta, dtb)).
+eapply gf2_step_tr_lem.
+intros. apply sum_step2_tr_D_gf2.
+all: cycle 1. exact acc. apply AccT_measure.
+subst Q. simpl in X. exact X.
+destruct dts. apply ss. Qed.
+ +
+Lemma gf2_sum U W fty (P : fty -> U -> W -> Type) A sub gsa gsb dta dtb:
+  gf_step2_tr P A sub (measure gsa) (measure gsb) dta dtb ->
+    sum_step2_tr P A sub gsa gsb dta dtb.
+Proof. unfold sum_step2_tr. unfold gf_step2_tr.
+intros gf2 saa lgss.
+require gf2. intros. exact (saa A' X a b).
+apply gf2 ; intros ; apply lgss ; unfold measure in H; lia. Qed.
+ +
+Lemma sumh_step2_tr_lem U W fty (rulesa : rlsT U) (rulesb : rlsT W)
+  (P : fty -> derrec_fc rulesa emptyT -> derrec_fc rulesb emptyT -> Type)
+  (A : fty) sub dta dtb : AccT sub A ->
+  (forall A dta dtb, sumh_step2_tr P A sub dta dtb) -> P A dta dtb.
+Proof. unfold sumh_step2_tr. apply sum_step2_tr_lem. Qed.
+ +
+Lemma hs2_sumh U W fty rulesa rulesb P A sub dta dtb:
+  @height_step2_tr U W fty rulesa rulesb P A sub dta dtb ->
+  @sumh_step2_tr U W fty rulesa rulesb P A sub dta dtb.
+Proof. unfold height_step2_tr. unfold sumh_step2_tr. apply gf2_sum. Qed.
+ +
+(* TODO
+
+if possible, need to look at gen_step2sr
+gs2_tr_sr
+gs2_sr_tr
+
+val _ = qed_goal_spec_mp "gs2_sr_tr" gentree.thy
+  "valid rls dta --> valid rls dtb --> \
+    \ gen_step2sr P A sub rls (botRule dta, botRule dtb) --> \
+    \ gen_step2_tr (*)

+(* summary of some results for two trees *)
+ +
+
+
+ +
+ + + diff --git a/General.gstep.html b/General.gstep.html new file mode 100644 index 0000000..d507b73 --- /dev/null +++ b/General.gstep.html @@ -0,0 +1,809 @@ + + + + + + + + + + + + + +
+
+

General.gstep

+ +
+ +
+(* constructions for inductive proofs about derivations,
+  part adapted from ~jeremy/isabelle/2005/seqms/gstep.{thy,ML}
+  but can_trf_rules and friends are new *)

+ +
+Set Implicit Arguments.
+ +
+Require Import Init.Wf. (* wfp called Acc, note Acc_intro, Acc_rect,
+  or AccT for Type version *)

+ +
+Require Import Coq.Program.Equality. (* for dependent induction/destruction *)
+Require Import PeanoNat. (* for Nat *)
+ +
+(* Add LoadPath "../tense-lns". *)
+Require Import gen genT.
+Require Import ddT dd_fc.
+Require Import rtcT.
+ +
+(*
+"gen_step ?P ?A ?sub ?derivs (?ps, ?concl) =
+  ((ALL A'. (A', ?A) : ?sub --> Ball ?derivs (?P A')) -->
+  (ALL p:set ?ps. p : ?derivs & ?P ?A p) -->
+  ?concl : ?derivs --> ?P ?A ?concl)"
+  *)

+ +
+Definition gen_step (seq fml : Type) P A (sub : fml -> fml -> Type)
+  derivs ps (concl : seq) :=
+  (forall A', sub A' A -> (forall x, derivs x -> P A' x)) ->
+  ForallT (fun p => prod (derivs p) (P A p)) ps -> derivs concl -> P A concl.
+ +
+Lemma gen_step_sub_mono seq fml P A sub1 sub2 derivs ps c :
+  rsub sub1 sub2 -> gen_step P A sub1 derivs ps c ->
+  @gen_step seq fml P A sub2 derivs ps c.
+Proof. unfold gen_step. intros rs gs saa. apply gs.
+intros A' s1aa. exact (saa A' (rsubD rs _ _ s1aa)). Qed.
+ +
+Lemma gen_step_def: forall (seq fml : Type) P A sub derivs ps (concl : seq),
+  @gen_step seq fml P A sub derivs ps concl =
+  ((forall A', sub A' A -> (forall x, derivs x -> P A' x)) ->
+  ForallT (fun p => prod (derivs p) (P A p)) ps -> derivs concl -> P A concl).
+Proof. intros. unfold gen_step. reflexivity. Qed.
+ +
+Inductive gen_step' (seq fml : Type) P A (sub : fml -> fml -> Type)
+  derivs ps (concl : seq) :=
+  | gsI : ((forall A', sub A' A -> (forall x, derivs x -> P A' x)) ->
+  ForallT (fun p => prod (derivs p) (P A p)) ps -> derivs concl -> P A concl) ->
+  gen_step' P A (sub : fml -> fml -> Type) derivs ps (concl : seq).
+ +
+Lemma gs_gs': forall (seq fml : Type) P A (sub : fml -> fml -> Type)
+  derivs ps (concl : seq),
+  iffT (gen_step P A sub derivs ps concl) (gen_step' P A sub derivs ps concl).
+Proof. intros. unfold gen_step. unfold iffT. split ; intros.
+apply gsI. exact X.
+destruct X. apply p ; assumption. Qed.
+ +
+(*
+"gen_step2 ?P ?A ?sub (?dls, ?drs) ((?psl, ?cl), ?psr, ?cr) =
+  ((ALL A'.
+       (A', ?A) : ?sub --> (ALL dl:?dls. ALL dr:?drs. ?P A' (dl, dr))) -->
+   (ALL pl:set ?psl. pl : ?dls & ?P ?A (pl, ?cr)) -->
+   (ALL pr:set ?psr. pr : ?drs & ?P ?A (?cl, pr)) -->
+   ?cl : ?dls --> ?cr : ?drs --> ?P ?A (?cl, ?cr))"
+*)

+ +
+Definition gen_step2 (seql seqr fml : Type) (P : fml -> seql -> seqr -> Type)
+  A (sub : fml -> fml -> Type) dls drs psl cl psr cr :=
+  (forall A', sub A' A ->
+    forall dl, dls dl -> forall dr, drs dr -> P A' dl dr) ->
+  ForallT (fun pl => prod (dls pl) (P A pl cr)) psl ->
+  ForallT (fun pr => prod (drs pr) (P A cl pr)) psr ->
+  dls cl -> drs cr -> P A cl cr.
+ +
+Lemma gen_step2_sub_mono seql seqr fml P A sub1 sub2 dls drs psl cl psr cr :
+  rsub sub1 sub2 -> gen_step2 P A sub1 dls drs psl cl psr cr ->
+  @gen_step2 seql seqr fml P A sub2 dls drs psl cl psr cr.
+Proof. unfold gen_step2. intros rs gs saa. apply gs.
+intros A' s1aa. exact (saa A' (rsubD rs _ _ s1aa)). Qed.
+ +
+Definition gen_step2_empty seql seqr fml P A sub dls drs psl cl psr cr :=
+  (@gen_step2_sub_mono seql seqr fml P A _ sub dls drs psl cl psr cr)
+  (rsub_emptyT sub).
+ +
+(* generalised version of inductive step proof *)
+Lemma gen_step_lem_psT: forall (sty fty : Type) (P : fty -> sty -> Type)
+  A sub rules prems, AccT sub A ->
+    (forall A ps concl, rules ps concl ->
+      gen_step P A sub (derrec rules prems) ps concl) ->
+    (forall A prem, prems prem -> P A prem) ->
+    (forall seq, derrec rules prems seq -> P A seq).
+Proof. intros *. intros acc gs prs. induction acc.
+intros. eapply derrec_all_rect. apply prs.
+intros. unfold gen_step in gs. eapply gs. exact X1. exact X.
+apply ForallTI_forall. intros. split.
+eapply dersrecD_forall in X2. exact X2. exact X4.
+eapply ForallTD_forall in X3. exact X3. exact X4.
+eapply derI ; eassumption. exact X0. Qed.
+ +
+Lemma gen_step_lem_ps: forall (sty fty : Type) (P : fty -> sty -> Type)
+  A sub rules prems, Acc sub A ->
+    (forall A ps concl, rules ps concl ->
+      gen_step P A sub (derrec rules prems) ps concl) ->
+    (forall A prem, prems prem -> P A prem) ->
+    (forall seq, derrec rules prems seq -> P A seq).
+Proof. intros *. intros acc gs prs. induction acc.
+intros. eapply derrec_all_rect. apply prs.
+intros. unfold gen_step in gs. eapply gs. exact X1. exact X.
+apply ForallTI_forall. intros. split.
+eapply dersrecD_forall in X2. exact X2. exact X4.
+eapply ForallTD_forall in X3. exact X3. exact X4.
+eapply derI ; eassumption. exact X0. Qed.
+ +
+Definition gen_step_lem sty fty P A sub rules acc gs :=
+  @gen_step_lem_ps sty fty P A sub rules (@emptyT sty) acc gs
+  (fun A0 => @emptyT_any' sty (P A0)).
+ +
+Definition gen_step_lemT sty fty P A sub rules acc gs :=
+  @gen_step_lem_psT sty fty P A sub rules (@emptyT sty) acc gs
+  (fun A0 => @emptyT_any' sty (P A0)).
+ +
+(* this one does allow for premises *)
+Lemma gen_step2_lem_ps: forall (stya styb fty : Type) P (A : fty) sub
+  rlsa rlsb (premsa : stya -> Type) (premsb : styb -> Type),
+  Acc sub A -> (forall A psa psb ca cb, rlsa psa ca -> rlsb psb cb ->
+  gen_step2 P A sub (derrec rlsa premsa)
+    (derrec rlsb premsb) psa ca psb cb) ->
(forall A pa, premsa pa -> forall cb, derrec rlsb premsb cb -> P A pa cb) ->
(forall A pb, premsb pb -> forall ca, derrec rlsa premsa ca -> P A ca pb) ->
+  forall seqa, derrec rlsa premsa seqa ->
+  forall seqb, derrec rlsb premsb seqb -> P A seqa seqb.
+Proof. intros *. intros acc gs prsa prsb. induction acc.
+eapply derrec_all_rect2.
+intros. eapply prsa in X0. exact X0. exact X1.
+intros. eapply prsb in X0. exact X0. exact X1.
+intros. unfold gen_step2 in gs. eapply gs. exact X0. exact X1. exact X.
+apply ForallTI_forall. intros. split.
+eapply dersrecD_forall in X2. exact X2. exact X6.
+eapply ForallTD_forall in X4. exact X4. exact X6.
+apply ForallTI_forall. intros. split.
+eapply dersrecD_forall in X3. exact X3. exact X6.
+eapply ForallTD_forall in X5. exact X5. exact X6.
+eapply derI ; eassumption. eapply derI ; eassumption. Qed.
+ +
+Lemma gen_step2_lem_psT: forall (stya styb fty : Type) P (A : fty) sub
+  rlsa rlsb (premsa : stya -> Type) (premsb : styb -> Type),
+  AccT sub A -> (forall A psa psb ca cb, rlsa psa ca -> rlsb psb cb ->
+  gen_step2 P A sub (derrec rlsa premsa)
+    (derrec rlsb premsb) psa ca psb cb) ->
(forall A pa, premsa pa -> forall cb, derrec rlsb premsb cb -> P A pa cb) ->
(forall A pb, premsb pb -> forall ca, derrec rlsa premsa ca -> P A ca pb) ->
+  forall seqa, derrec rlsa premsa seqa ->
+  forall seqb, derrec rlsb premsb seqb -> P A seqa seqb.
+Proof. intros *. intros acc gs prsa prsb. induction acc.
+eapply derrec_all_rect2.
+intros. eapply prsa in X0. exact X0. exact X1.
+intros. eapply prsb in X0. exact X0. exact X1.
+intros. unfold gen_step2 in gs. eapply gs. exact X0. exact X1. exact X.
+apply ForallTI_forall. intros. split.
+eapply dersrecD_forall in X2. exact X2. exact X6.
+eapply ForallTD_forall in X4. exact X4. exact X6.
+apply ForallTI_forall. intros. split.
+eapply dersrecD_forall in X3. exact X3. exact X6.
+eapply ForallTD_forall in X5. exact X5. exact X6.
+eapply derI ; eassumption. eapply derI ; eassumption. Qed.
+ +
+(* this one doesn't allow for premises *)
+Definition gen_step2_lem stya styb fty P A sub rlsa rlsb acc gs :=
+  @gen_step2_lem_ps stya styb fty P A sub rlsa rlsb
+  (@emptyT stya) (@emptyT styb) acc gs
+  (fun _ => @emptyT_any' stya _) (fun _ => @emptyT_any' styb _).
+ +
+Definition gen_step2_lemT stya styb fty P A sub rlsa rlsb acc gs :=
+  @gen_step2_lem_psT stya styb fty P A sub rlsa rlsb
+  (@emptyT stya) (@emptyT styb) acc gs
+  (fun _ => @emptyT_any' stya _) (fun _ => @emptyT_any' styb _).
+ +
+(* simplified versions, forget A, then derive version with A *)
+Definition gen_steps (seq : Type) P derivs ps (concl : seq) :=
+  ForallT (fun p => prod (derivs p) (P p)) ps -> derivs concl -> P concl.
+ +
+Definition gen_step2s (seql seqr : Type) (P : seql -> seqr -> Type)
+  dls drs psl cl psr cr :=
+  ForallT (fun pl => prod (dls pl) (P pl cr)) psl ->
+  ForallT (fun pr => prod (drs pr) (P cl pr)) psr ->
+  dls cl -> drs cr -> P cl cr.
+ +
+(* generalised version of inductive step proof *)
+Lemma gen_steps_lem_ps (sty : Type) (P : sty -> Type) rules prems:
+    (forall ps concl, rules ps concl ->
+      gen_steps P (derrec rules prems) ps concl) ->
+    (forall prem, prems prem -> P prem) ->
+    (forall seq, derrec rules prems seq -> P seq).
+Proof. intros *. intros gs prs.
+intros. eapply derrec_all_rect. apply prs.
+intros. unfold gen_steps in gs. eapply gs. exact X0.
+apply ForallTI_forall. intros. split.
+eapply dersrecD_forall in X1 ; eassumption.
+eapply ForallTD_forall in X2 ; eassumption.
+eapply derI ; eassumption. exact X. Qed.
+ +
+Definition gen_steps_lem sty P rules gs :=
+  @gen_steps_lem_ps sty P rules (@emptyT sty) gs (@emptyT_any' sty P).
+ +
+Lemma gen_step2s_lem_ps: forall (stya styb : Type) P
+  rlsa rlsb (premsa : stya -> Type) (premsb : styb -> Type),
+  (forall psa psb ca cb, rlsa psa ca -> rlsb psb cb ->
+  gen_step2s P (derrec rlsa premsa) (derrec rlsb premsb) psa ca psb cb) ->
(forall pa, premsa pa -> forall cb, derrec rlsb premsb cb -> P pa cb) ->
(forall pb, premsb pb -> forall ca, derrec rlsa premsa ca -> P ca pb) ->
+  forall seqa, derrec rlsa premsa seqa ->
+  forall seqb, derrec rlsb premsb seqb -> P seqa seqb.
+Proof. intros *. intros gs prsa prsb.
+eapply derrec_all_rect2.
+- intros px ppx cy db. eapply prsa in db ; eassumption.
+- intros py ppy cx da. eapply prsb in da ; eassumption.
+- intros *. intros ra rb da db fx fy.
+unfold gen_step2s in gs. eapply gs.
++ exact ra. + exact rb.
++ apply ForallTI_forall. intros x inx. split.
+eapply dersrecD_forall in da ; eassumption.
+eapply ForallTD_forall in fx ; eassumption.
++ apply ForallTI_forall. intros y iny. split.
+eapply dersrecD_forall in db ; eassumption.
+eapply ForallTD_forall in fy ; eassumption.
++ eapply derI ; eassumption.
++ eapply derI ; eassumption. Qed.
+ +
+Definition gen_step2s_lem stya styb P rlsa rlsb gs :=
+  @gen_step2s_lem_ps stya styb P rlsa rlsb
+  (@emptyT stya) (@emptyT styb) gs
+  (@emptyT_any' stya _) (@emptyT_any' styb _).
+ +
+(* proof of version depending on formula A from versions not depending on A,
+  showing this is possible, however, since this is difficult and
+  proving (for example) gen_step2_lem_psT is not much harder
+  than proving gen_step2s_lem_ps, might as welll use gen_step2_lem_psT *)

+Lemma gen_step_lem' sty fty P (A : fty) sub rules:
+  AccT sub A -> (forall A0 ps concl, rules ps concl ->
+    gen_step P A0 sub (derrec rules (emptyT (X:=sty))) ps concl) ->
+    forall seq : sty, derrec rules (emptyT (X:=sty)) seq -> P A seq.
+Proof. intros acc gs. induction acc.
+remember (fun s => (forall y, sub y x ->
+  forall seq, derrec rules (emptyT (X:=sty)) seq -> P y seq) -> P x s) as Q.
+pose (@gen_steps_lem sty Q).
+rewrite HeqQ in q. intros seq ds. eapply q. 2: apply ds.
+all: cycle 1. intros y syx. eapply X. exact syx.
+clear q. intros ps concl rpc.
+eapply gs in rpc. unfold gen_step in rpc.
+unfold gen_steps. intros ft drc sp.
+apply rpc. exact sp. 2: exact drc.
+apply ForallTI_forall. intros x0 inxp.
+eapply ForallTD_forall in ft. 2: apply inxp. cD.
+split. exact ft. apply ft0. exact sp. Qed.
+ +
+(* alternative approach to admissibility, useful for swap in Box rule of K4,
+  where single swap in conclusion requires two swaps in premises,
+  which requires the _rtc;
+  very easily extended to derl rules in def of can_trf_rules
+  (though this doesn't give height preservation),
+  can we extend this to reflexive transitive closure of R ?? *)

+ +
+(* note - although we can't seem to be able to extend this to derl
+  and reflexive transitive closure of R together,
+  we do need reflexive closure of R together with
+  a sort of reflexive closure of the rules, eg
+  where R is that a certain rule can be inverted, 
+  where the rule is that same rule, then we don't want a R step or
+  a single rule application step; 
+  for the K4 rule which allows weakening, where the formula to be
+  inverted is among what is added, then the changed version is
+  derived from the original premise, not from a related premise *)

+ +
+Unset Universe Polymorphism.
+ +
+Definition can_trf_rules (sty : Type) R rules (ps : list sty) (c : sty) :=
+  forall c' : sty, R c c' ->
+  (sigT (fun ps' : list sty => prod (rules ps' c')
+    (ForallT (fun p' => sigT (fun p => prod (InT p ps) (R p p'))) ps'))).
+ +
+Definition can_trf_rules_rc (sty : Type) R rules (ps : list sty) (c : sty) :=
+  forall c' : sty, R c c' ->
+  (sigT (fun ps' : list sty => prod (rules ps' c') (ForallT
+    (fun p' => sigT (fun p => prod (InT p ps) (clos_reflT R p p'))) ps'))).
+ +
+(* can_trf_rules_rc would be a bit pointless if we specified that
+  ps to c is a rule, because then can_trf_rules R would imply
+  can_trf_rules (clos_reflT R) *)

+ +
+Lemma can_trf_rules_imp_rc sty R rules ps c:
+  @can_trf_rules sty R rules ps c -> @can_trf_rules_rc sty R rules ps c.
+Proof. unfold can_trf_rules. unfold can_trf_rules_rc.
+intros. apply X in X0. cD. exists X0. split. assumption.
+apply ForallTI_forall. intros.
+eapply ForallTD_forall in X2. 2: eassumption. cD.
+exists X2. split. assumption.
+apply rT_step. assumption. Qed.
+ +
+Lemma can_trf_rules_mono' sty R rulesa rulesb:
+  rsub rulesa rulesb -> forall ps (c : sty),
+  can_trf_rules R rulesa ps c -> can_trf_rules R rulesb ps c.
+Proof. unfold can_trf_rules.
+intros. apply X0 in X1. clear X0. cD.
+eexists. split. unfold rsub in X. apply X. apply X0. apply X2. Qed.
+ +
+Lemma can_trf_rules_rc_mono' sty R rulesa rulesb:
+  rsub rulesa rulesb -> forall ps (c : sty),
+  can_trf_rules_rc R rulesa ps c -> can_trf_rules_rc R rulesb ps c.
+Proof. unfold can_trf_rules_rc.
+intros. apply X0 in X1. clear X0. cD.
+eexists. split. unfold rsub in X. apply X. apply X0. apply X2. Qed.
+ +
+Definition can_trf_rules_mono sty R rulesa rulesb r :=
+  rsubI _ _ (@can_trf_rules_mono' sty R rulesa rulesb r).
+Definition can_trf_rules_rc_mono sty R rulesa rulesb r :=
+  rsubI _ _ (@can_trf_rules_rc_mono' sty R rulesa rulesb r).
+ +
+(* union of two relations *)
+Polymorphic Inductive runion U V ra rb (ps : U) (c : V) : Type :=
+  | run_l : ra ps c -> @runion U V ra rb ps c
+  | run_r : rb ps c -> @runion U V ra rb ps c.
+ +
+(* union of set of rule sets *)
+Polymorphic Inductive rUnion U V rr (ps : U) (c : V) : Type :=
+  | rUnI : forall r, rr r -> r ps c -> @rUnion U V rr ps c.
+ +
+(* union property for R in can_trf_rules... *)
+Lemma can_trf_rules_un sty R R' rules ps (c : sty):
+  can_trf_rules R rules ps c -> can_trf_rules R' rules ps c ->
+    can_trf_rules (runion R R') rules ps c.
+Proof. unfold can_trf_rules. intros. destruct X1.
+apply X in r. cD. exists r. split. assumption.
+apply ForallTI_forall. intros. eapply ForallTD_forall in r1. cD.
+exists r1. split. assumption. apply run_l. eassumption. assumption.
+apply X0 in r. cD. exists r. split. assumption.
+apply ForallTI_forall. intros. eapply ForallTD_forall in r1. cD.
+exists r1. split. assumption. apply run_r. eassumption. assumption.
+Qed.
+ +
+(* Union property for R in can_trf_rules... *)
+Lemma can_trf_rules_Un sty rr rules ps (c : sty):
+  (forall r, rr r -> can_trf_rules r rules ps c) ->
+    can_trf_rules (rUnion rr) rules ps c.
+Proof. unfold can_trf_rules. intros. destruct X0.
+pose (X r r0 c' r1). cD. exists s. split. assumption.
+apply ForallTI_forall. intros. eapply ForallTD_forall in s1. cD.
+exists s1. split. assumption. eapply rUnI ; eassumption. assumption. Qed.
+ +
+Lemma can_trf_rules_req V R R' rules : req R R' -> forall ps c,
+  @can_trf_rules V R rules ps c -> @can_trf_rules V R' rules ps c.
+Proof. unfold can_trf_rules. unfold req. unfold rsub.
+intros ss ps c fri c' rcc. cD.
+apply ss0 in rcc. apply fri in rcc. cD.
+exists rcc. split. assumption. apply ForallTI_forall. intros.
+eapply ForallTD_forall in rcc1. cD.
+exists rcc1. split. assumption. apply ss. eassumption. assumption. Qed.
+ +
+Lemma der_trf_rc_adm: forall (sty : Type) R rules,
+  (forall ps c, rules ps c -> can_trf_rules_rc R (adm rules) ps c) ->
+  forall concl, derrec rules (@emptyT sty) concl ->
+    forall concl', R concl concl' -> derrec rules (@emptyT sty) concl'.
+Proof. intros *. intro.
+eapply (derrec_all_rect (Q := (fun concl => forall concl' : sty,
+  R concl concl' -> derrec rules (emptyT (X:=sty)) concl'))).
+intros. destruct H.
+intros ps concl rpc dpss fall concl' Rcc.
+apply X in rpc. unfold can_trf_rules_rc in rpc.
+apply rpc in Rcc. cD. clear rpc X.
+(* here, weaker results by using derI or adm_derrec_trans
+  instead of adm_derrec_trans *)

+eapply adm_derrec_trans. exact Rcc0.
+apply dersrecI_forall. intros.
+eapply ForallTD_forall in Rcc1. 2: eassumption. cD.
+inversion Rcc3. subst.
+eapply ForallTD_forall in fall. 2: eassumption.
+apply fall. assumption.
+subst. eapply dersrecD_forall in dpss. exact dpss. assumption. Qed.
+ +
+Lemma der_trf_rc_derl: forall (sty : Type) R rules,
+  (forall ps c, rules ps c -> can_trf_rules_rc R (derl rules) ps c) ->
+  forall concl, derrec rules (@emptyT sty) concl ->
+    forall concl', R concl concl' -> derrec rules (@emptyT sty) concl'.
+Proof. intros sty R rules rtc. apply der_trf_rc_adm.
+intros ps c rpc. apply rtc in rpc.
+eapply can_trf_rules_rc_mono'.
+apply rsub_derl_adm. apply rpc. Qed.
+ +
+Lemma der_trf_rc: forall (sty : Type) R rules,
+  (forall ps c, rules ps c -> can_trf_rules_rc R rules ps c) ->
+  forall concl, derrec rules (@emptyT sty) concl ->
+    forall concl', R concl concl' -> derrec rules (@emptyT sty) concl'.
+Proof. intros sty R rules rtc. apply der_trf_rc_adm.
+intros ps c rpc. apply rtc in rpc.
+eapply can_trf_rules_rc_mono'.
+apply rsub_adm. apply rpc. Qed.
+ +
+Lemma der_trf_derl: forall (sty : Type) R rules,
+  (forall ps c, rules ps c -> can_trf_rules R (derl rules) ps c) ->
+  forall concl, derrec rules (@emptyT sty) concl ->
+    forall concl', R concl concl' -> derrec rules (@emptyT sty) concl'.
+Proof. intros *. intro.
+apply der_trf_rc_derl. intros. apply can_trf_rules_imp_rc.
+exact (X ps c X0). Qed.
+ +
+(* or can do the following *)
+Definition der_trf_derl' sty R rules ct :=
+  @der_trf_rc_derl sty R rules
+    (fun ps c rpc => can_trf_rules_imp_rc (ct ps c rpc)).
+ +
+Lemma can_trf_derl X rules R ps (c : X): can_trf_rules R rules ps c ->
+    can_trf_rules R (derl rules) ps c.
+Proof. unfold can_trf_rules. intros.
+apply X0 in X1. cD. exists X1. split. apply in_derl. assumption.
+assumption. Qed.
+ +
+Lemma der_trf: forall (sty : Type) R rules,
+  (forall ps c, rules ps c -> can_trf_rules R rules ps c) ->
+  forall concl, derrec rules (@emptyT sty) concl ->
+    forall concl', R concl concl' -> derrec rules (@emptyT sty) concl'.
+Proof. intros *. intro rct. apply der_trf_derl.
+intros. apply can_trf_derl. apply rct. assumption. Qed.
+ +
+Definition can_trf_rules_rtc (sty : Type) R rules (ps : list sty) (c : sty) :=
+  forall c' : sty, R c c' ->
+  (sigT (fun ps' : list sty => prod (rules ps' c')
+    (ForallT (fun p' => sigT (fun p => prod (InT p ps)
+      (clos_refl_transT_n1 R p p'))) ps'))).
+ +
+Lemma can_trf_rules_imp_rtc sty R rules ps c:
+  @can_trf_rules sty R rules ps c -> @can_trf_rules_rtc sty R rules ps c.
+Proof. unfold can_trf_rules. unfold can_trf_rules_rtc.
+intros. apply X in X0. cD. exists X0. split. assumption.
+apply ForallTI_forall. intros.
+eapply ForallTD_forall in X2. 2: eassumption. cD.
+exists X2. split. assumption.
+eapply rtn1T_trans. eassumption. apply rtn1T_refl. Qed.
+ +
+Lemma can_trf_rules_rtc_mono' sty R rulesa rulesb ps c:
+  rsub rulesa rulesb -> @can_trf_rules_rtc sty R rulesa ps c ->
+  @can_trf_rules_rtc sty R rulesb ps c.
+Proof. unfold rsub. unfold can_trf_rules_rtc. intros.
+apply X0 in X1. clear X0. cD. exists X1. split. firstorder.
+exact X2. Qed.
+ +
+Definition can_trf_rules_rtc_mono sty R rulesa rulesb r :=
+  rsubI _ _ (@can_trf_rules_rtc_mono' sty R rulesa rulesb r).
+ +
+Lemma trf_rules_rtc: forall (sty : Type) R rules (c : sty),
+  (forall ps' c', clos_refl_transT_n1 R c c' ->
+    rules ps' c' -> can_trf_rules_rtc R rules ps' c') ->
+  forall ps, rules ps c -> can_trf_rules (clos_refl_transT_n1 R) rules ps c.
+Proof. intros. unfold can_trf_rules. intro. intro rtc.
+induction rtc. exists ps. split. assumption.
+apply ForallTI_forall. intros. exists x. split. assumption.
+apply rtn1T_refl.
+cD. eapply X in rtc.
+unfold can_trf_rules_rtc in rtc. apply rtc in r. clear rtc. cD.
+eexists. split. eassumption.
+apply ForallTI_forall. intros.
+eapply ForallTD_forall in r1. 2: eassumption. cD.
+eapply ForallTD_forall in IHrtc1. 2: eassumption. cD.
+eexists. split. eassumption.
+(* now need transitivity of clos_refl_transT_n1 *)
+apply clos_rtn1_rtT in r3.
+apply clos_rtn1_rtT in IHrtc3.
+apply clos_rt_rtn1T.
+eapply rtT_trans ; eassumption. assumption. Qed.
+ +
+(* try to adapt proof of trf_rules_derl to also do _rtc 
+Lemma trf_rules_rtc_derl: forall (sty : Type) R (rules : rlsT sty), 
+  (forall ps c, rules ps c -> can_trf_rules_rtc R (derl rules) ps c) ->
+  (forall ps c, derl rules ps c -> 
+    can_trf_rules (clos_refl_transT_n1 R) (derl rules) ps c).
+NOT ACTUALLY SURE THIS IS VALID
+Check trf_rules_rtc_derl.
+*)

+ +
+Lemma trf_rules_derl: forall (sty : Type) R (rules : rlsT sty),
+  (forall ps c, rules ps c -> can_trf_rules R (derl rules) ps c) ->
+  (forall ps c, derl rules ps c -> can_trf_rules R (derl rules) ps c).
+Proof. intros *. intro rctd.
+eapply derl_all_rect.
+{ intro. unfold can_trf_rules. intros. exists [c'].
+split. apply asmI. apply ForallTI_forall. intros.
+exists p. split. apply InT_eq. inversion X0 ; subst. assumption.
+eapply InT_nilE in X1. eassumption. }
+
+{ intros *. intros rpc drsl fcd qcp.
+apply rctd in rpc. subst. clear rctd.
+unfold can_trf_rules. intros c' Rcc.
+unfold can_trf_rules in rpc. apply rpc in Rcc. cD. clear rpc.
+ +
+assert {cqss : list sty &
+  (dersl rules cqss Rcc * ForallT (fun p' : sty =>
+    {p : sty & InT p (concat pss) * R p p'}) cqss)%type}.
+ +
+{ clear Rcc0. induction Rcc1.
+exists []. simpl. split. apply dtNil. apply ForallT_nil.
+cD.
+eapply Forall2T_ex_r in fcd. 2: eassumption. destruct fcd.
+unfold can_trf_rules in c. eapply c in p1. clear c.
+destruct p1. cD.
+eexists. split. eapply dtCons ; eassumption.
+apply ForallTI_forall. simpl. intros.
+apply InT_appE in X. sD.
+eapply ForallTD_forall in p2. 2: eassumption. cD.
+eexists. split. 2: eassumption.
+eapply InT_concat ; eassumption.
+eapply ForallTD_forall in IHRcc2. 2: eassumption. assumption. }
+
+{ cD. eexists. split. 2: eassumption.
+eapply derl_trans ; eassumption. } } Qed.
+ +
+Lemma der_trf_rtc: forall (sty : Type) R rules,
+  (forall ps c, rules ps c -> can_trf_rules_rtc R rules ps c) ->
+  forall concl, derrec rules (@emptyT sty) concl ->
+    forall concl', clos_refl_transT_n1 R concl concl' ->
+    derrec rules (@emptyT sty) concl'.
+Proof. intros until 1. apply der_trf.
+intros *. apply trf_rules_rtc.
+intros until 1. apply X. Qed.
+ +
+(* how to do this - maybe need to try _rtc variant of trf_rules_derl 
+Lemma der_trf_rtc_derl: forall (sty : Type) R rules, 
+  (forall ps c, rules ps c -> can_trf_rules_rtc R (derl rules) ps c) ->
+  forall concl, derrec rules (@emptyT sty) concl -> 
+    forall concl', clos_refl_transT_n1 R concl concl' ->
+      derrec rules (@emptyT sty) concl'.
+*)

+ +
+Lemma der_trf_ht: forall (sty : Type) R rules,
+  (forall ps c, rules ps c -> can_trf_rules R rules ps c) ->
+  forall concl (D : derrec rules (@emptyT sty) concl),
+    forall concl', R concl concl' ->
+    sigT (fun D' : derrec rules (@emptyT sty) concl' =>
+      derrec_height D' <= derrec_height D).
+Proof. intros *. intros ctr.
+eapply (derrec_rect_mut_all (Q := (fun concl D => forall concl' : sty,
+  R concl concl' -> {D' : derrec rules (emptyT (X:=sty)) concl' &
+  derrec_height D' <= derrec_height D}))).
+intros c p. destruct p.
+intros ps concl rpc dpss apd concl' Rcc.
+pose (ctr ps concl rpc) as ctrr.
+unfold can_trf_rules in ctrr.
+apply ctrr in Rcc. cD. clear ctrr ctr.
+ +
+assert { Ds' : dersrec rules (emptyT (X:=sty)) Rcc &
+  dersrec_height Ds' <= dersrec_height dpss }.
+assert (forall p, InT p Rcc -> { D' : derrec rules (emptyT (X:=sty)) p &
+  derrec_height D' <= dersrec_height dpss }).
+ +
+{ intros.
+eapply ForallTD_forall in Rcc1. 2: eassumption. cD.
+eapply allPderD_in in apd. 2: eassumption. destruct apd. (* cD doesn't work *)
+apply s in Rcc3. cD. clear s.
+eexists. (* shelves a goal *)
+eapply le_dersrec_height. eassumption. eassumption. }
+
+{ clear apd concl' Rcc0 Rcc1 R rpc.
+(* this may be a useful lemma *)
+induction Rcc. eexists. Unshelve. 3: apply dlNil. simpl. apply le_0_n.
+require IHRcc. intros. apply X. apply InT_cons. assumption. cD.
+pose (X a (InT_eq a Rcc)). cD.
+exists (dlCons s IHRcc). simpl. apply Nat.max_lub ; assumption. }
+
+cD. exists (derI concl' Rcc0 X). simpl. apply le_n_S. assumption. Qed.
+ +
+(* this proof gets quite unmanageable, need to use @dersrecI_forall' instead,
+  which is a much simpler proof object 
+Goal forall X rules prems seq seqs f,
+  @dersrecI_forall X rules prems (seq :: seqs) f =
+  @dlCons X rules prems seq seqs (f seq (InT_eq seq seqs))
+    (@dersrecI_forall X rules prems seqs (fun c i => f c (InT_cons seq i))).
+Proof. intros.  
+unfold dersrecI_forall.  unfold dersrec_forall.
+unfold iffT_D2.  unfold prod_rect.  unfold iffT_trans.
+(etc, can do lots of unfolds)
+*)

+ +
+Lemma dlCons_inj: forall X rules prems seq seqs d ds d' ds',
+  @dlCons X rules prems seq seqs d ds = dlCons d' ds' ->
+  prod (d = d') (ds = ds').
+(* shorter proof follows 
+Proof. intros.  injection H. intros. inversion_sigma. 
+unfold eq_rect in H3.  unfold eq_rect in H4. 
+dependent destruction H2.  dependent destruction H1.
+split ; assumption. Defined.
+*)

+Proof. intros. dependent destruction H. tauto. Defined.
+ +
+(* formerly managed to prove these
+Lemma dersrecI_forall_alt_cons: forall X rules prems seq seqs f,
+  @dersrecI_forall X rules prems (seq :: seqs) f =
+  @dlCons X rules prems seq seqs (f seq (InT_eq seq seqs))
+    (@dersrecI_forall X rules prems seqs (fun c i => f c (InT_cons seq i))).
+
+Lemma dersrecI_forall_alt_nil: forall X rules prems f,
+  @dersrecI_forall X rules prems  f = @dlNil X rules prems.
+
+Lemma dlc_drsf: forall X rules prems seq seqs d ds f,
+  @dlCons X rules prems seq seqs d ds = 
+    @dersrecI_forall X rules prems (seq :: seqs) f -> 
+  prod (d = f seq (InT_eq seq seqs)) 
+  (ds = @dersrecI_forall X rules prems seqs (fun c i => f c (InT_cons seq i))).
+*)

+ +
+Lemma existT_inj: forall A P (x : A) px px',
+  existT P x px = existT P x px' -> (px = px').
+Proof. intros. dependent destruction H. tauto. Defined.
+ +
+Lemma existT_inj': forall A P (x x' : A) px px',
+  existT P x px = existT P x' px' -> (x = x').
+Proof. intros. dependent destruction H. tauto. Defined.
+ +
+(* Print Assumptions existT_inj. 
+Fetching opaque proofs from disk for Coq.Logic.EqdepFacts
+Axioms:
+Eqdep.Eq_rect_eq.eq_rect_eq : forall (U : Type) (p : U) 
+                                (Q : U -> Type) (x : Q p) 
+                                (h : p = p), x = eq_rect p Q x p h
+JMeq_eq : forall (A : Type) (x y : A), x ~= y -> x = y
+*)

+ +
+(* soundness proofs *)
+ +
+(* according to some semantics, if each rule preserves validity
+  then a derivation preserves validity *)

+(* note - proof doesn't work using derl instead of dercl *)
+Lemma dercl_soundness W rules valid
+  (rules_sound : forall ps c, rules ps c -> ForallT valid ps -> valid c) :
+  forall ps (c : W), dercl rules ps c -> ForallT valid ps -> valid c.
+Proof.
+apply (@dercl_all_rect _ _ (fun ps c => ForallT valid ps -> valid c)).
+- intros p fvps. exact (ForallT_singleD fvps).
+- intros * rpsc dcsl fvv qseq fvqs. subst.
+eapply rules_sound. exact rpsc.
+clear rpsc dcsl. (* otherwise spoils induction *)
+induction fvv. apply ForallT_nil.
+simpl in fvqs. apply ForallT_appendD in fvqs. destruct fvqs.
+exact (ForallT_cons y (r f) (IHfvv f0)).
+Qed.
+ +
+Lemma derrec_soundness W rules prems valid
+  (rules_sound : forall ps (c : W), rules ps c -> ForallT valid ps -> valid c) :
+  (forall p, prems p -> valid p) -> forall c, derrec rules prems c -> valid c.
+Proof. intro pv. apply (derrec_all_rect pv).
+intros * rps drs. exact (rules_sound ps concl rps). Qed.
+ +
+Unset Universe Polymorphism.
+ +
+(* useful predicates for proving admissibility *)
+(* extend the idea of admissibility to relations *)
+Inductive radm X rules p c : Type :=
+  | radmI : (derrec rules (@emptyT X) p -> derrec rules (@emptyT X) c) ->
+    radm X rules p c.
+ +
+Definition radmD X rules p c (r : @radm X rules p c) :=
+  match r with | radmI d => d end.
+ +
+(* admissibility for a relation *)
+Inductive rel_adm X rules R : Type :=
+  | rel_admI : (forall p c, R p c -> @radm X rules p c) -> rel_adm X rules R.
+ +
+Definition rel_admD X rules R (r : @rel_adm X rules R) :=
+  match r with | rel_admI _ r0 => r0 end.
+ +
+(* similar to rel_adm, but useful for gen_step_lemT *)
+Definition can_rel sty fty rules (R : fty -> sty -> sty -> Type)
+  (fml : fty) (seq : sty) :=
+  forall seq', R fml seq seq' -> derrec rules emptyT seq'.
+ +
+Lemma rel_adm_rtc X rules R :
+  @rel_adm X rules R -> rel_adm rules (clos_refl_transT R).
+Proof. repeat split. destruct X0.
+induction X1. exact (radmD (r x y r0)). tauto. tauto. Qed.
+ +
+(* lemma relating rel_adm to can_rel *)
+Lemma crd_ra sty fty rules (R : fty -> sty -> sty -> Type) fml:
+  iffT (rel_adm rules (R fml))
+  (forall seq, derrec rules emptyT seq -> can_rel rules R fml seq).
+Proof. split.
+- intros ra seq ds seq' rf.
+inversion ra. specialize (X seq seq' rf).
+destruct X. exact (d ds).
+- intro dc. repeat split. intro dp.
+exact (dc p dp c X). Qed.
+ +
+
+
+ +
+ + + diff --git a/General.rtcT.html b/General.rtcT.html new file mode 100644 index 0000000..082c1b5 --- /dev/null +++ b/General.rtcT.html @@ -0,0 +1,154 @@ + + + + + + + + + + + + + +
+
+

General.rtcT

+ +
+ +
+(* Reflexive_Transitive_Closure stuff, using Type rather than Prop *)
+ +
+Set Implicit Arguments.
+Require Import List.
+Import ListNotations.
+ +
+Require Import gen genT.
+ +
+(* compare 
+  https://coq.inria.fr/stdlib/Coq.Relations.Relation_Definitions.html
+  https://coq.inria.fr/stdlib/Coq.Relations.Relation_Operators.html
+  https://coq.inria.fr/stdlib/Coq.Relations.Operators_Properties.html
+  Require Import Coq.Relations.Relation_Definitions.
+  Require Import Coq.Relations.Relation_Operators.
+  Require Import Coq.Relations.Operators_Properties.  
+  *)

+(* this in genT.v in ../lnt/tense-logic-in-Coq 
+Definition relationT (A : Type) := A -> A -> Type.
+*)

+ +
+Definition transitiveT W (R : relationT W) :=
+  forall (x y z : W), R x y -> R y z -> R x z.
+ +
+(* see https://coq.inria.fr/stdlib/Coq.Relations.Relation_Operators.html *)
+Section Reflexive_ClosureT.
+  Variable A : Type.
+  Variable R : relationT A.
+ +
+Inductive clos_reflT (x: A) : A -> Type :=
+  | rT_step (y:A) : R x y -> clos_reflT x y
+  | rT_refl : clos_reflT x x.
+ +
+End Reflexive_ClosureT.
+ +
+Section Reflexive_Transitive_ClosureT.
+  Variable A : Type.
+  Variable R : relationT A.
+ +
+Inductive clos_refl_transT (x:A) : A -> Type :=
+  | rtT_step (y:A) : R x y -> clos_refl_transT x y
+  | rtT_refl : clos_refl_transT x x
+  | rtT_trans (y z:A) :
+        clos_refl_transT x y -> clos_refl_transT y z -> clos_refl_transT x z.
+ +
+(* Alternative definition by transitive extension on the left/right *)
+ +
+Inductive clos_refl_transT_1n (x: A) : A -> Type :=
+  | rt1nT_refl : clos_refl_transT_1n x x
+  | rt1nT_trans (y z:A) :
+       R x y -> clos_refl_transT_1n y z -> clos_refl_transT_1n x z.
+ +
+Inductive clos_refl_transT_n1 (x: A) : A -> Type :=
+  | rtn1T_refl : clos_refl_transT_n1 x x
+  | rtn1T_trans (y z:A) :
+      R y z -> clos_refl_transT_n1 x y -> clos_refl_transT_n1 x z.
+ +
+End Reflexive_Transitive_ClosureT.
+ +
+(* equivalences between above, need to reprove for ...T *)
+Lemma clos_rt1n_rtT : forall A R (x y : A),
+  clos_refl_transT_1n R x y -> clos_refl_transT R x y.
+Proof. intros. induction X. apply rtT_refl.
+eapply rtT_trans. apply rtT_step. eassumption. eassumption. Qed.
+ +
+Lemma clos_rt_rt1nT : forall A R (x y : A),
+  clos_refl_transT R x y -> clos_refl_transT_1n R x y.
+Proof. intros. induction X.
+eapply rt1nT_trans. eassumption. apply rt1nT_refl.
+apply rt1nT_refl.
+clear X1 X2. induction IHX1. assumption.
+apply IHIHX1 in IHX2. eapply rt1nT_trans ; eassumption. Qed.
+ +
+Lemma clos_rtn1_rtT : forall A R (x y : A),
+  clos_refl_transT_n1 R x y -> clos_refl_transT R x y.
+Proof. intros. induction X. apply rtT_refl.
+eapply rtT_trans. eassumption. apply rtT_step. eassumption. Qed.
+ +
+Lemma clos_rt_rtn1T : forall A R (x y : A),
+  clos_refl_transT R x y -> clos_refl_transT_n1 R x y.
+Proof. intros. induction X.
+eapply rtn1T_trans. eassumption. apply rtn1T_refl.
+apply rtn1T_refl.
+clear X1 X2. induction IHX2. assumption.
+eapply rtn1T_trans ; eassumption. Qed.
+ +
+(*
+Lemma clos_rt_rt1n_iffT : forall A R (x y : A),
+  clos_refl_transT R x y <-> clos_refl_transT_1n R x y.
+
+Lemma clos_rt_rtn1_iffT : forall A R (x y : A),
+  clos_refl_transT R x y <-> clos_refl_transT_n1 R x y.
+*)

+ +
+
+
+ +
+ + + diff --git a/General.swappedT.html b/General.swappedT.html new file mode 100644 index 0000000..8c2672a --- /dev/null +++ b/General.swappedT.html @@ -0,0 +1,437 @@ + + + + + + + + + + + + + +
+
+

General.swappedT

+ +
+ +
+(* Add LoadPath "../tense-lns". *)
+ +
+Require Import List.
+Require Import existsT.
+Require Import gen_tacs.
+Require Import gen.
+Require Import List_lemmasT.
+ +
+Set Implicit Arguments.
+Import ListNotations.
+ +
+(* Contains definitions and lemmas for swapped swapped_spec and swapped_gen, all used for contraction. *)
+ +
+Inductive swapped T: list T -> list T -> Type :=
+| swapped_I : forall (X Y A B C D : list T),
+    X = (A ++ B ++ C ++ D) -> Y = (A ++ C ++ B ++ D) -> swapped X Y.
+ +
+Lemma swapped_I': forall T (A B C D : list T),
+  swapped (A ++ B ++ C ++ D) (A ++ C ++ B ++ D).
+Proof. intros. eapply swapped_I ; reflexivity. Qed.
+ +
+Lemma swapped_same: forall T X, swapped X (X : list T).
+Proof. intros. apply (swapped_I [] [] [] X) ; simpl ; reflexivity. Qed.
+ +
+Lemma swapped_L: forall T X Y Z,
+  swapped X (Y : list T) -> swapped (Z ++ X) (Z ++ Y).
+Proof. intros *; intros X0. inversion X0. subst.
+  rewrite !(app_assoc Z). apply swapped_I'. Qed.
+ +
+Lemma swapped_R: forall T X Y Z,
+  swapped X (Y : list T) -> swapped (X ++ Z) (Y ++ Z).
+Proof. intros *; intros X0. destruct X0. subst. rewrite <- !app_assoc. apply swapped_I'. Qed.
+ +
+Lemma swapped_cons: forall T (x : T) Y Z,
+  swapped Y Z -> swapped (x :: Y) (x :: Z).
+Proof.
+  intros *; intros H. destruct H.
+  subst. repeat rewrite app_comm_cons.
+  apply swapped_I'.
+Qed.
+ +
+Definition swapped_single T (x : T) := swapped_cons x (swapped_same []).
+ +
+Lemma swapped_nilLE T Y: @swapped T [] Y -> Y = [].
+Proof. intro sw. inversion sw. subst.
+repeat (list_eq_ncT ; cD ; subst) ;
+simpl ; rewrite ?app_nil_r ; try reflexivity. Qed.
+ +
+Lemma swapped_nilRE T Y: @swapped T Y [] -> Y = [].
+Proof. intro sw. inversion sw. subst.
+repeat (list_eq_ncT ; cD ; subst) ;
+simpl ; rewrite ?app_nil_r ; try reflexivity. Qed.
+ +
+Lemma swapped_singleLE T (x : T) Y: swapped [x] Y -> Y = [x].
+Proof. intro sw. inversion sw. subst.
+acacD'T2 ; subst ; repeat (list_eq_ncT ; cD ; subst) ;
+simpl ; rewrite ?app_nil_r ; try reflexivity. Qed.
+ +
+Lemma swapped_singleRE T (x : T) Y: swapped Y [x] -> Y = [x].
+Proof. intro sw. inversion sw. subst.
+acacD'T2 ; subst ; repeat (list_eq_ncT ; cD ; subst) ;
+simpl ; rewrite ?app_nil_r ; try reflexivity. Qed.
+ +
+Lemma swapped_simple: forall T U V X Y,
+  U = X ++ Y -> V = Y ++ X -> swapped U (V : list T).
+Proof. intros. subst.
+  apply (swapped_I [] X Y []) ; simpl ; rewrite app_nil_r ; reflexivity. Qed.
+ +
+Lemma swapped_simple': forall T X Y, swapped (X ++ Y : list T) (Y ++ X).
+Proof. intros. eapply swapped_simple ; reflexivity. Qed.
+ +
+Lemma swapped_simpleL: forall T X Y Z,
+  Y = Z -> swapped (X ++ Y) (Z ++ X : list T).
+Proof. intros. subst. apply swapped_simple'. Qed.
+ +
+Lemma swapped_simpleR: forall T X Y Z,
+  Y = Z -> swapped (Y ++ X) (X ++ Z : list T).
+Proof. intros. subst. apply swapped_simple'. Qed.
+ +
+Lemma swapped_comm : forall {T} (A B : list T),
+    swapped A B ->
+    swapped B A.
+Proof.
+  intros T A B H.
+  inversion H. subst.
+  eapply swapped_I'.
+Qed.
+ +
+Definition single X (a : X) := [a].
+ +
+Lemma cons_app_single X (a : X) xs : a :: xs = single a ++ xs.
+Proof. unfold single. simpl. reflexivity. Qed.
+ +
+Lemma single_eq X a : [a : X] = single a.
+Proof. unfold single. reflexivity. Qed.
+ +
+(* note some of the complexity of swap_tac involving cons
+  may be avoided by rewriting with cons_app_single and single_eq *)

+ +
+Lemma swapped_Rc2 T A H B C:
+  swapped C (H ++ [A : T]) -> swapped (C ++ B) (H ++ A :: B).
+Proof. intros sw. eapply swapped_R in sw. revert sw.
+rewrite <- app_assoc. simpl. intro. eassumption. Qed.
+ +
+Lemma swapped_Rc1 T A H B C:
+  swapped (H ++ [A : T]) C -> swapped (H ++ A :: B) (C ++ B).
+Proof. intros sw. eapply swapped_R in sw. revert sw.
+rewrite <- app_assoc. simpl. intro. eassumption. Qed.
+ +
+Lemma swapped_ca1 T A H: swapped (A :: H) (H ++ [A : T]).
+Proof. pose (swapped_simple' [A] H). simpl in s. exact s. Qed.
+ +
+Lemma swapped_ca2 T A H: swapped (H ++ [A : T]) (A :: H).
+Proof. pose (swapped_simple' H [A]). simpl in s. exact s. Qed.
+ +
+Lemma swapped_map_ex T U (f : T -> U) xs ys:
+  swapped (map f xs) ys -> sigT2 (swapped xs) (fun zs => ys = map f zs).
+Proof. intro sw. inversion sw. subst. clear sw.
+repeat (match goal with | [ H : _ |- _ ] => eapply map_app_ex in H ; cD end).
+subst. eexists. apply swapped_I'. rewrite !map_app. reflexivity. Qed.
+ +
+Lemma swapped_map T U (f : T -> U) xs ys:
+  swapped xs ys -> swapped (map f xs) (map f ys).
+Proof. intro sw. inversion sw. subst. clear sw.
+rewrite !map_app. apply swapped_I'. Qed.
+ +
+(* Sequences of swaps of length n+1. *)
+Inductive swapped_spec {T} : nat -> list T -> list T -> Type :=
+  swapped_spec_I X Y : swapped X Y -> swapped_spec 0 X Y
+| swapped_spec_step n A B C :
+    swapped_spec n A B -> swapped B C -> swapped_spec (S n) A C.
+ +
+Lemma swapped_spec_refl : forall {T} n (A : list T),
+    swapped_spec n A A.
+Proof.
+  induction n; intros. econstructor. apply swapped_same.
+  econstructor. apply IHn.
+  apply swapped_same.
+Qed.
+ +
+Lemma swapped_app_L : forall {T} n (l A B : list T),
+    swapped_spec n A B ->
+    swapped_spec n (l ++ A) (l ++ B).
+Proof.
+  induction n; intros *; intros Hswap.
+  constructor. apply swapped_L. inversion Hswap. auto.
+  inversion Hswap as [ | ? ? ? ? X X0]. subst.
+  econstructor. eapply IHn. exact X.
+  apply swapped_L. assumption.
+Qed.
+ +
+Lemma swapped_spec_trans : forall {T} n1 n2 (l1 l2 l3 : list T),
+    swapped_spec n1 l1 l2 ->
+    swapped_spec n2 l2 l3 ->
+    existsT2 m, swapped_spec m l1 l3.
+Proof.
+  induction n2; intros *; intros H1 H2.
+  inversion H2. subst. exists (S n1).
+  econstructor. apply H1. assumption.
+  inversion H2 as [ | ? ? ? ? X X0]. subst.
+  eapply IHn2 in H1. destruct H1 as [m H1].
+  exists (S m). econstructor.
+  apply H1. apply X0. apply X.
+Qed.
+ +
+Lemma swapped_spec_trans_exact : forall {T} n1 n2 (l1 l2 l3 : list T),
+    swapped_spec n1 l1 l2 ->
+    swapped_spec n2 l2 l3 ->
+    swapped_spec (S (n1 + n2)) l1 l3.
+Proof.
+  induction n2; intros *; intros H1 H2.
+  inversion H2 as [? ? X | ]. subst. rewrite PeanoNat.Nat.add_0_r.
+  econstructor. apply H1. apply X.
+  inversion H2 as [| ? ? ? ? X X0]. subst.
+  eapply IHn2 in H1. simpl. econstructor.
+  rewrite <- PeanoNat.Nat.add_succ_comm.
+  apply H1. apply X0. assumption.
+Qed.
+ +
+Lemma swapped_spec_comm : forall {T} n (A B : list T),
+    swapped_spec n A B ->
+    swapped_spec n B A.
+Proof.
+  induction n; intros *; intros H.
+  constructor. inversion H as [? ? X | ]. subst.
+  eapply swapped_comm. assumption.
+  inversion H as [ | ? ? ? ? X X0]. subst.
+  eapply swapped_comm in X0.
+  eapply swapped_spec_I in X0.
+  apply IHn in X.
+  apply (@swapped_spec_trans_exact T _ _ _ _ _ X0 X).
+Qed.
+ +
+Lemma swapped_spec_conv : forall {T} n m (A B : list T),
+  n = m ->
+  swapped_spec n A B ->
+  swapped_spec m A B.
+Proof. intros. subst. auto. Qed.
+ +
+Lemma swapped_app_mid_L : forall {T} n (A B C D E : list T),
+    swapped_spec n (A ++ B ++ C ++ D) E ->
+    swapped_spec (S n) (A ++ C ++ B ++ D) E.
+Proof.
+  intros *; intros Hswap.
+  assert (S n = S (0 + n)) as Hass.
+  reflexivity.
+  eapply swapped_spec_conv. symmetry. apply Hass.
+  eapply swapped_spec_trans_exact.
+  constructor. apply swapped_I'.
+  apply Hswap.
+Qed.
+ +
+Lemma swapped_app_mid_R : forall {T} n (A B C D E : list T),
+    swapped_spec n E (A ++ B ++ C ++ D) ->
+    swapped_spec (S n) E (A ++ C ++ B ++ D).
+Proof.
+  intros *; intros H.
+  eapply swapped_spec_comm in H.
+  eapply swapped_spec_comm.
+  eapply swapped_app_mid_L.
+  apply H.
+Qed.
+ +
+Lemma swapped_spec_front_mid : forall {T} n (A B C D : list T),
+    swapped_spec n B (C ++ D) ->
+    existsT2 m, swapped_spec m (A ++ B) (C ++ A ++ D).
+Proof.
+  intros T n A B C D Hswap.
+  eapply swapped_app_L in Hswap.
+  eapply swapped_spec_trans. exact Hswap.
+  rewrite <- app_nil_l.
+  eapply swapped_app_mid_R.
+  apply swapped_spec_refl.
+  Unshelve. apply 0.
+Qed.
+ +
+Lemma swapped__n_mid : forall {T} m (l Gam1 Gam2 Gam1' Gam2' : list T),
+    swapped_spec m (Gam1 ++ Gam2) (Gam1' ++ Gam2') ->
+    existsT2 n, swapped_spec n (Gam1 ++ l ++ Gam2) (Gam1' ++ l ++ Gam2').
+Proof.
+  intros *.
+  intros H. eapply swapped_app_L in H.
+  rewrite <- app_nil_l in H.
+  eexists.
+  replace (Gam1 ++ l ++ Gam2) with (nil ++ Gam1 ++ l ++ Gam2).
+  replace (Gam1' ++ l ++ Gam2') with (nil ++ Gam1' ++ l ++ Gam2').
+  eapply swapped_app_mid_R.
+  eapply swapped_app_mid_L.
+  eapply H. all : reflexivity.
+Qed.
+ +
+(* Sequences of swaps, length implicit. *)
+Inductive swapped_gen {T} Gam Delt :=
+  swapped_gen_I : (existsT2 n, @swapped_spec T n Gam Delt) -> swapped_gen Gam Delt.
+ +
+Lemma swapped_gen_front_mid : forall {T} (A B C D : list T),
+    swapped_gen B (C ++ D) ->
+    swapped_gen (A ++ B) (C ++ A ++ D).
+Proof.
+  intros T A B C D Hswap. inversion Hswap as [Hs].
+  destruct Hs as [n Hs].
+  constructor.
+  eapply swapped_spec_front_mid. exact Hs.
+Qed.
+ +
+Lemma swapped_spec_opp : forall {T} n (A B C : list T),
+    swapped_spec n B C ->
+    swapped A B ->
+    swapped_spec (S n) A C.
+Proof.
+  intros *; intros H1 H2.
+  eapply swapped_spec_I in H2.
+  eapply swapped_spec_trans_exact in H1.
+  2 : eapply H2. auto.
+Qed.
+ +
+Lemma swapped__gen : forall {T} (A B : list T),
+  swapped A B -> swapped_gen A B.
+Proof.
+  intros T A B H. constructor.
+  exists 0. constructor. exact H.
+Qed.
+ +
+Lemma swapped_gen_app_L : forall {T} (l A B : list T),
+    swapped_gen A B ->
+    swapped_gen (l ++ A) (l ++ B).
+Proof.
+  intros T l A B H. inversion H as [H2].
+  destruct H2 as [n H2]. constructor.
+  eapply swapped_app_L in H2. exists n. exact H2.
+Qed.
+ +
+Lemma swapped_gen_refl : forall {T} (A : list T),
+    swapped_gen A A.
+Proof.
+  intros T A. constructor.
+  exists 0. apply swapped_spec_refl.
+Qed.
+ +
+(* tactics to identify swapped lists, where one of swap is single list *)
+ +
+Ltac show_swapped_1 :=
+  list_assoc_r' ;
+  try (eapply arg_cong_imp ; [> list_assoc_l' ; reflexivity | ] ;
+    apply swapped_simpleL ; list_eq_assoc) ;
+  try (eapply arg1_cong_imp ; [> list_assoc_l' ; reflexivity | ] ;
+    apply swapped_simpleR ; list_eq_assoc).
+ +
+Ltac show_swapped_1_ns :=
+  list_assoc_r ; (* not the ssreflext version *)
+  try (eapply arg_cong_imp ; [> list_assoc_l' ; reflexivity | ] ;
+    apply swapped_simpleL ; list_eq_assoc) ;
+  try (eapply arg1_cong_imp ; [> list_assoc_l' ; reflexivity | ] ;
+    apply swapped_simpleR ; list_eq_assoc).
+ +
+(* this should work wherever swap_tac does, but trying to use it in place of
+  swap_tac produces occasional failures - why?? - to investigate *)

+Ltac swap_tac_Rc :=
+  list_assoc_r ; try (apply swapped_same) ;
+    repeat (apply swapped_L || apply swapped_cons) ;
+    list_assoc_l ;
+    repeat (apply swapped_R || apply swapped_Rc1 || apply swapped_Rc2) ;
+    (show_swapped_1 || apply swapped_ca2 || apply swapped_ca1).
+ +
+Ltac swap_tac :=
+  list_assoc_r ; try (apply swapped_same) ;
+    repeat (apply swapped_L || apply swapped_cons) ;
+    list_assoc_l ; repeat (apply swapped_R) ; show_swapped_1.
+ +
+Ltac swap_tac_ns :=
+  list_assoc_r ; try (apply swapped_same) ;
+    repeat (apply swapped_L || apply swapped_cons) ;
+    list_assoc_l ; repeat (apply swapped_R) ; show_swapped_1_ns.
+ +
+Goal forall T A B C D, swapped (A ++ B ++ C ++ D : list T) (D ++ A ++ B ++ C).
+Proof. intros. show_swapped_1. Qed.
+ +
+Goal forall T A B C D, swapped (D ++ A ++ B ++ C) (A ++ B ++ C ++ D : list T).
+Proof. intros. show_swapped_1. Qed.
+ +
+
+
+ +
+ + + diff --git a/General.univ_gen_ext.html b/General.univ_gen_ext.html new file mode 100644 index 0000000..e5df2e3 --- /dev/null +++ b/General.univ_gen_ext.html @@ -0,0 +1,624 @@ + + + + + + + + + + + + + +
+
+

General.univ_gen_ext

+ +
+Require Export List.
+Export ListNotations.
+Set Implicit Arguments.
+ +
+From Coq Require Import ssreflect.
+ +
+Require Import gen.
+Require Import genT.
+Require Import gen_tacs.
+Require Import gen_seq.
+Require Import List_lemmasT.
+Require Import FunctionalExtensionality.
+Require Import Lia.
+ +
+(* The following definition is a generalization of the gen_ext property.
+   As gen_ext, univ_gen_ext gives a precise definition of embedding between
+   lists: l1 is embedded in l2 if all the elements in l1 appear in l2 in the
+   same order as in l1. Some elements might be added in l2, under the condition
+   that these elements satisfy a certain given property P.
+
+   Effectively, univ_gen_ext allows to restrict the weakening of gen_ext_extra to
+   elements of a type A satisfying some property P. *)

+ +
+Inductive univ_gen_ext W (P : W -> Type) : relationT (list W) :=
+  | univ_gen_ext_nil : univ_gen_ext P [] []
+  | univ_gen_ext_cons : forall x l le, univ_gen_ext P l le -> univ_gen_ext P (x :: l) (x :: le)
+  | univ_gen_ext_extra : forall x l le, P x -> univ_gen_ext P l le -> univ_gen_ext P l (x :: le)
+  .
+ +
+(* We can prove some general properties about univ_gen_ext. *)
+ +
+(* univ_gen_ext is a reflexive relation. *)
+ +
+Lemma univ_gen_ext_refl: forall A (l : list A) P, univ_gen_ext P l l.
+Proof.
+induction l.
+- apply univ_gen_ext_nil.
+- intro. apply univ_gen_ext_cons. apply IHl.
+Qed.
+ +
+(* It is also transitive. *)
+ +
+Lemma univ_gen_ext_trans: forall A P (ys zs : list A),
+  univ_gen_ext P ys zs ->
+  forall xs, univ_gen_ext P xs ys -> univ_gen_ext P xs zs.
+Proof. intros until 1. induction X. tauto.
+intros. inversion X0. subst. apply univ_gen_ext_cons. firstorder.
+subst. apply univ_gen_ext_extra. firstorder. apply IHX. assumption.
+intros. firstorder. firstorder. apply univ_gen_ext_extra. firstorder. apply IHX.
+assumption.
+Qed.
+ +
+(* The empty list can be embedded in any other list xs as long as the
+   elements of that list are all satisfying P. *)

+ +
+Lemma all_P_univ_gen_ext_nil: forall A P (xs : list A),
+              (forall x, InT x xs -> P x) -> (univ_gen_ext P [] xs).
+Proof.
+induction xs.
+- intros. apply univ_gen_ext_nil.
+- intros. apply univ_gen_ext_extra. apply X. apply InT_eq'. reflexivity.
+  apply IHxs. intros. apply X. apply InT_cons. assumption.
+Qed.
+ +
+(* Reciprocally, if the empty list is embedded in another list then
+   we know that all the elements of that list are satisfying P. *)

+ +
+Lemma univ_gen_ext_nil_all_P: forall A P (xs : list A),
+              (univ_gen_ext P [] xs) -> (forall x, InT x xs -> P x).
+Proof.
+induction xs.
+- intros. inversion X0.
+- intros. remember (a :: xs) as l0. remember [] as l1. destruct X.
+  * inversion X0.
+  * inversion Heql1.
+  * inversion Heql0. subst. pose (IHxs X). inversion X0.
+    + subst. assumption.
+    + apply p0. assumption.
+Qed.
+ +
+(* The next lemmas state that if a list xs is embedded in a list
+   ys, then xs is also embedded in the list ys appended (on the
+   right or left of it) with a list zs of which all elements are
+   satsfying the property P. *)

+ +
+Lemma univ_gen_ext_appL: forall A P (xs ys zs : list A),
+  univ_gen_ext P xs ys ->
+  (forall z, InT z zs -> P z) ->
+  univ_gen_ext P xs (zs ++ ys).
+Proof.
+induction zs. tauto.
+intros. simpl. apply univ_gen_ext_extra. apply X0. apply InT_eq.
+apply IHzs. assumption. intros. apply X0. apply InT_cons. assumption.
+Qed.
+ +
+Lemma univ_gen_ext_appR: forall A P (xs ys zs : list A),
+  univ_gen_ext P xs ys ->
+  (forall z, InT z zs -> P z) ->
+  univ_gen_ext P xs (ys ++ zs).
+Proof.
+intros. induction X.
+- induction zs.
+  * apply univ_gen_ext_nil.
+  * apply univ_gen_ext_extra. apply X0. apply InT_eq. apply IHzs.
+    intros. apply X0. apply InT_cons. assumption.
+- simpl. apply univ_gen_ext_cons. assumption.
+- simpl. apply univ_gen_ext_extra. assumption. assumption.
+Qed.
+ +
+(* The lemma univ_gen_ext_lem states that if a list x::Z is embedded in
+   a list Y, then x must be appearing in Y, i.e. Y = Y1++x::Y2, and Y2 is
+   is such that Z is embedded in Y2. Note that Y1 is here as it could well
+   be that some elements were added via univ_gen_ext_extra before even
+   treating x. *)

+ +
+Lemma univ_gen_ext_lem: forall A (x : A) P Z Y,
+  univ_gen_ext P (x :: Z) Y -> sigT (fun Y1 => sigT (fun Y2 =>
+    prod (Y = Y1 ++ x :: Y2) (prod (univ_gen_ext P Z Y2)
+      (forall y, InT y Y1 -> P y)))).
+Proof.
+intros A x P Z. induction Y.
+intro. inversion X. intro. inversion X ; subst.
+exists []. exists Y. simpl. split. tauto. split. tauto. intros.
+inversion X1.
+apply IHY in X1. cD. subst.
+exists (a :: X1). exists X2. simpl. split.
+auto. split. assumption. intros. remember (a :: X1) as l. destruct X3.
+- subst. inversion Heql. assumption.
+- apply X5. inversion Heql. subst. assumption.
+Qed.
+ +
+(* The next two lemmas deal with the interaction between univ_gen_ext
+   and append. In essence, they say that if the embedded (resp. embedding)
+   list is of the shape X1++X2, then the embedding list (resp. embedded)
+   is of the shape W1++W2 where W1 embedds (resp. is embedded in) X1 and
+   W2 embedds (resp. is embedded in) X1. *)

+ +
+Lemma univ_gen_ext_splitL: forall A P (Z2 Z1 Y : list A),
+  univ_gen_ext P (Z1 ++ Z2) Y -> sigT (fun Y1 => sigT (fun Y2 =>
+    prod (Y = Y1 ++ Y2) (prod (univ_gen_ext P Z1 Y1) (univ_gen_ext P Z2 Y2)))).
+Proof.
+intros A P Z2. induction Z1 ; simpl.
+- exists []. exists Y. simpl. split. trivial.
+split. apply univ_gen_ext_nil. trivial.
+- intro. intro. apply univ_gen_ext_lem in X. cD. subst.
+apply IHZ1 in X2. cD. subst.
+exists (X ++ a :: X2). exists X1.
+split. rewrite app_comm_cons. rewrite app_assoc. trivial.
+split. apply univ_gen_ext_appL. apply univ_gen_ext_cons. assumption.
+2: assumption. assumption.
+Qed.
+ +
+Lemma univ_gen_ext_splitR: forall A P (Z2 Z1 Y : list A),
+  univ_gen_ext P Y (Z1 ++ Z2) -> sigT (fun Y1 => sigT (fun Y2 =>
+    prod (Y = Y1 ++ Y2) (prod (univ_gen_ext P Y1 Z1) (univ_gen_ext P Y2 Z2)))).
+Proof.
+intros V Z2. induction Z1 ; simpl.
+- exists []. exists Y. simpl. split. trivial.
+  split. apply univ_gen_ext_nil. trivial.
+- intro. intro. inversion X ; subst.
+apply IHZ1 in X0. cD. subst.
+exists (a :: X0). exists X1. simpl. split. trivial.
+split. apply univ_gen_ext_cons. assumption. assumption.
+apply IHZ1 in X1. cD. subst.
+exists X1. exists X2. split. trivial. split. apply univ_gen_ext_extra.
+assumption. assumption. assumption.
+Qed.
+ +
+(* univ_gen_ext_combine claims that if Y1 is embedded in Z1 and Y2 is embedded
+   in Z2, then we can combine the embedded lists in the shape of Y1++Y2 and combine
+   the embedding lists in Z1++Z2 to preserve the relation of embedding between the
+   newly created lists.*)

+ +
+Lemma univ_gen_ext_combine: forall A P (Z2 Z1 Y2 Y1 : list A),
+    univ_gen_ext P Y1 Z1 -> univ_gen_ext P Y2 Z2 -> univ_gen_ext P (Y1 ++ Y2) (Z1 ++ Z2).
+Proof.
+intros A P Z2 Z1 Y2 Y1 gen1 gen2. induction gen1.
+- repeat rewrite app_nil_l. assumption.
+- simpl. apply univ_gen_ext_cons. assumption.
+- simpl. apply univ_gen_ext_extra. assumption. assumption.
+Qed.
+ +
+(* The next lemma states that if a::Y is embedded in a::Z, then we know
+   for sure that Y is embedded in Z. Note that this is not direct as the
+   a in the embedding list could have been added via univ_gen_ext_extra.
+   Effectively, this lemma allows one to remove the identical heads of two
+   lists univ_gen_ext and preserve that relation. *)

+ +
+Lemma univ_gen_ext_same_hd: forall A P (Y Z : list A) (a : A),
+    univ_gen_ext P (a::Y) (a::Z) -> univ_gen_ext P Y Z.
+Proof.
+intros A P Y Z a gen. inversion gen.
+- assumption.
+- subst. assert (H: univ_gen_ext P Y (a :: Y)).
+  apply univ_gen_ext_extra. assumption. apply univ_gen_ext_refl.
+  apply univ_gen_ext_trans with (ys:=(a :: Y)). assumption. assumption.
+Qed.
+ +
+(* The lemma univ_gen_ext_elem_deep considers a list l1 embedded in a
+   list l2 in which an element a appears deeply. Essentially, the lemma
+   makes a case distinction about a: either it has been added by univ_gen_ext_extra
+   (this is the first case of the sum) or it was added by univ_gen_ext_cons
+   in which case it has to appear somewhere in l1. *)

+ +
+Lemma univ_gen_ext_elem_deep {A : Type} : forall P (l1 l2 l3 l4: list A) a,
+          univ_gen_ext P l1 l2 ->
+          (l2 = l3 ++ a :: l4) ->
+            ((univ_gen_ext P l1 (l3 ++ l4) * P a) +
+            sigT (fun l5 => sigT (fun l6 =>
+              (prod (l1 = l5 ++ a :: l6) (prod (univ_gen_ext P l5 l3) (univ_gen_ext P l6 l4)))))).
+Proof.
+intros. subst. rewrite cons_single in X. apply univ_gen_ext_splitR in X.
+destruct X. destruct s. repeat destruct p. subst.
+apply univ_gen_ext_splitR in u0. destruct u0. destruct s. repeat destruct p.
+subst. inversion u0.
+- right. exists x. exists (l ++ x2). split. auto.
+  split. assumption. inversion X. subst. simpl. assumption.
+- left. subst. inversion X0. subst. split. rewrite app_nil_l.
+  apply univ_gen_ext_combine. assumption. assumption. assumption.
+Qed.
+ +
+(* The next lemma states that if a list l1 is embedded in another list,
+   then one can add an element a however deep in the embedding list and
+   keep the relation of embedding, as long as a satisfies P. *)

+ +
+Lemma univ_gen_ext_add_elem_deep {A : Type} : forall P (l1 l2 l3: list A) a,
+    univ_gen_ext P l1 (l2 ++ l3) ->
+    P a -> univ_gen_ext P l1 (l2 ++ a :: l3).
+Proof.
+intros. apply univ_gen_ext_splitR in X. destruct X. destruct s.
+repeat destruct p. subst. apply univ_gen_ext_combine.
+assumption. apply univ_gen_ext_extra. assumption. assumption.
+Qed.
+ +
+(* This last lemma claims that if l0 is embedded in l1 with a property P,
+   then l0 is also embedded in l1 with the property Q. Obviously, all elements
+   which were added in l1 via univ_gen_ext_extra satisfied the property P, and
+   as Q is weaker than P we get that these elements aso satisfy Q. Thus we preserve
+   the embedding relation. *)

+ +
+Lemma univ_gen_ext_Q_weaker_than_P {A : Type} : forall P Q (l0 l1 : list A),
+          (forall a, P a -> Q a) ->
+          (univ_gen_ext P l0 l1) ->
+          (univ_gen_ext Q l0 l1).
+Proof.
+intros. induction X0.
+- apply univ_gen_ext_nil.
+- apply univ_gen_ext_cons. assumption.
+- apply univ_gen_ext_extra. apply X. assumption. assumption.
+Qed.
+ +
+Lemma univ_gen_ext_In {A : Type} : forall (l0 l1 : list A) a P, univ_gen_ext P l0 l1 ->
+                                        In a l0 -> In a l1.
+Proof.
+intros. induction X.
+- subst. inversion H.
+- subst. inversion H. subst. apply in_eq. subst. apply in_cons. apply IHX. assumption.
+- apply in_cons. apply IHX. assumption.
+Qed.
+ +
+Lemma univ_gen_ext_smaller_length : forall {A: Type} (l1 l2 : list A) P,
+                      univ_gen_ext P l1 l2 -> length l1 <= length l2.
+Proof.
+intros. induction X.
+- auto.
+- simpl. apply le_n_S. assumption.
+- simpl. lia.
+Qed.
+ +
+Lemma univ_gen_ext_same_length_id : forall {A: Type} (l1 l2 : list A) P,
+              (length l1 = length l2) -> univ_gen_ext P l1 l2 -> l1 = l2.
+Proof.
+intros A l1 l2 P H X. induction X.
+- firstorder.
+- simpl in H. inversion H. apply IHX in H1. subst. auto.
+- simpl in H. exfalso. pose (univ_gen_ext_smaller_length X). lia.
+Qed.
+ +
+Lemma univ_gen_ext_not_In_delete : forall {A : Type} (l1 l2 : list A) P (a : A),
+            ((In a l1) -> False) -> univ_gen_ext P l1 (a :: l2) -> univ_gen_ext P l1 l2.
+Proof.
+intros. remember (a :: l2) as l3. induction X.
+- inversion Heql3.
+- inversion Heql3. subst. exfalso. apply H. apply in_eq.
+- inversion Heql3. subst. assumption.
+Qed.
+ +
+Lemma InT_univ_gen_ext : forall {A : Type} (l1 l2 : list A) (P : A -> Type) (a : A),
+          (InT a l2) -> (univ_gen_ext P l1 l2) -> ((P a) + (InT a l1)).
+Proof.
+intros. induction X0.
+- inversion X.
+- inversion X. subst. right. apply InT_eq. apply IHX0 in X1. destruct X1. auto.
+  right. apply InT_cons. assumption.
+- inversion X. subst. auto. apply IHX0 in X1. assumption.
+Qed.
+ +
+(* univ_gen_ext simulates gen_ext: *)
+ +
+Definition gen_ext {W : Type} := @univ_gen_ext W (fun x => True).
+ +
+Lemma gen_ext_refl: forall W (l : list W), gen_ext l l.
+Proof. induction l. apply univ_gen_ext_nil. apply univ_gen_ext_cons. exact IHl. Qed.
+ +
+Lemma gen_ext_appL: forall W (xs ys zs : list W),
gen_ext xs ys ->gen_ext xs (zs ++ ys).
+Proof. induction zs. tauto. intros. apply univ_gen_ext_extra. tauto. tauto. Qed.
+ +
+Lemma gen_ext_appR: forall W (xs ys zs : list W),
gen_ext xs ys -> gen_ext xs (ys ++ zs).
+Proof. intros. induction X.
+induction zs. simpl. apply univ_gen_ext_nil. simpl.
+apply univ_gen_ext_extra. apply I. assumption.
+simpl. apply univ_gen_ext_cons. assumption.
+simpl. apply univ_gen_ext_extra. assumption. assumption. Qed.
+ +
+Lemma gen_ext_nil_any: forall W (xs : list W),gen_ext [] xs.
+Proof. induction xs. apply univ_gen_ext_nil. apply univ_gen_ext_extra. tauto. tauto. Qed.
+ +
+Lemma gen_ext_trans: forall W (ys zs : list W),
gen_ext ys zs -> forall xs, gen_ext xs ys -> gen_ext xs zs.
+Proof. intros until 1. induction X. tauto.
+intros. inversion X0. subst. apply univ_gen_ext_cons. firstorder.
+subst. apply univ_gen_ext_extra. firstorder. firstorder.
+intros. apply univ_gen_ext_extra. firstorder. firstorder. Qed.
+ +
+Lemma gen_ext_app: forall W (ys zs : list W),
gen_ext ys zs -> forall us vs, gen_ext us vs -> gen_ext (us ++ ys) (vs ++ zs).
+Proof. intros. induction X0 ; simpl. exact X.
+apply univ_gen_ext_cons. assumption.
+apply univ_gen_ext_extra. assumption. assumption. Qed.
+ +
+Definition gen_ext_sameL W xs ys zs ge :=
+  @gen_ext_app W ys zs ge xs xs (@gen_ext_refl W xs).
+Definition gen_ext_sameR W xs ys zs ge :=
+  @gen_ext_app W xs xs (@gen_ext_refl W xs) ys zs ge.
+ +
+Lemma gen_ext_lem: forall A (x : A) Z Y,
gen_ext (x :: Z) Y -> sigT (fun Y1 => sigT (fun Y2 =>
+    prod (Y = Y1 ++ x :: Y2) (gen_ext Z Y2))).
+Proof. intros A x Z. induction Y.
+intro. inversion X. intro. inversion X ; subst.
+exists []. exists Y. simpl. tauto.
+apply IHY in X0. cD. subst.
+exists (a :: X0). exists X1. simpl. tauto. Qed.
+ +
+Lemma gen_ext_splitL: forall A Z2 Z1 Y,
gen_ext (Z1 ++ Z2 : list A) Y -> sigT (fun Y1 => sigT (fun Y2 =>
+    prod (Y = Y1 ++ Y2) (prod (gen_ext Z1 Y1) (gen_ext Z2 Y2)))).
+Proof. intros A Z2. induction Z1 ; simpl.
+exists []. exists Y. simpl. split. trivial.
+split. apply univ_gen_ext_nil. trivial.
+intro. intro. apply gen_ext_lem in X. cD. subst.
+apply IHZ1 in X2. cD. subst.
+exists (X ++ a :: X2). exists X1.
+split. rewrite app_comm_cons. rewrite app_assoc. trivial.
+split. apply gen_ext_appL. apply univ_gen_ext_cons. assumption. assumption. Qed.
+ +
+Lemma gen_ext_splitR: forall A Z2 Z1 Y,
gen_ext Y (Z1 ++ Z2 : list A) -> sigT (fun Y1 => sigT (fun Y2 =>
+    prod (Y = Y1 ++ Y2) (prod (gen_ext Y1 Z1) (gen_ext Y2 Z2)))).
+Proof. intros A Z2. induction Z1 ; simpl.
+exists []. exists Y. simpl. split. trivial.
+split. apply univ_gen_ext_nil. trivial.
+intro. intro. inversion X ; subst.
+apply IHZ1 in X0. cD. subst.
+exists (a :: X0). exists X1. simpl. split. trivial.
+split. apply univ_gen_ext_cons. assumption. assumption.
+apply IHZ1 in X0. cD. subst.
+exists X0. exists X1. split. trivial.
+split. apply univ_gen_ext_extra. assumption. assumption. assumption. Qed.
+ +
+Lemma gen_ext_combine: forall A (Z2 Z1 Y2 Y1 : list A),
+   gen_ext Y1 Z1 ->gen_ext Y2 Z2 ->gen_ext (Y1 ++ Y2) (Z1 ++ Z2).
+Proof.
+intros A Z2 Z1 Y2 Y1 gen1 gen2. induction gen1.
+- repeat rewrite app_nil_l. assumption.
+- simpl. apply univ_gen_ext_cons. assumption.
+- simpl. apply univ_gen_ext_extra. assumption. assumption.
+Qed.
+ +
+Lemma gen_ext_same_hd: forall A (Y Z : list A) a,
+   gen_ext (a::Y) (a::Z) ->gen_ext Y Z.
+Proof.
+intros A Y Z a gen. inversion gen.
+- assumption.
+- subst. assert (H:gen_ext Y (a :: Y)).
+  apply univ_gen_ext_extra. apply I. apply gen_ext_refl.
+  apply gen_ext_trans with (ys:=(a :: Y)). assumption. assumption.
+Qed.
+ +
+Lemma gen_ext_single: forall A (l : list A), sing_empty l ->
+  forall Y Z le,gen_ext (Z ++ l ++ Y) le -> sigT (fun Ze => sigT (fun Ye =>
+    prod (prod (gen_ext Z Ze) (gen_ext Y Ye)) (le = Ze ++ l ++ Ye))).
+Proof. intros A l es Y. destruct es ; simpl ; intros.
+apply gen_ext_splitL in X. cD. subst. firstorder.
+apply gen_ext_splitL in X. cD.
+apply gen_ext_lem in X3. cD. subst.
+exists (X ++ X3). exists X4.
+split. split. apply gen_ext_appR. assumption. assumption.
+rewrite app_assoc. trivial. Qed.
+ +
+Lemma gen_ext_one': forall A (x : A) (xs l : list A),
+  xs = [x] ->gen_ext xs l -> InT x l.
+Proof. intros. induction X.
+- discriminate H.
+- injection H as . subst. apply InT_eq.
+- apply InT_cons. apply (IHX H). Qed.
+ +
+Definition gen_ext_one A x l := @gen_ext_one' A x [x] l eq_refl.
+(* and note result InT_split *)
+ +
+Lemma InT_gen_ext A x l: InT x l ->gen_ext [x : A] l.
+Proof. intros. apply InT_split in X. cD. subst.
+apply gen_ext_appL. apply univ_gen_ext_cons. apply gen_ext_nil_any. Qed.
+ +
+Lemma gen_ext_InT A (x : A) l m:gen_ext l m -> InT x l -> InT x m.
+Proof. intro ge. induction ge. tauto.
+intro. inversion X ; subst. apply InT_eq.
+apply InT_cons. exact (IHge X0).
+intro. apply InT_cons. exact (IHge X). Qed.
+ +
+Lemma gen_ext_diff' V X r :gen_ext X r -> forall (y : V) Y Z,
+    r = (Y ++ y :: Z) -> InT y X +gen_ext X (Y ++ Z).
+Proof. intro ge. induction ge.
+- intros. list_eq_ncT. contradiction.
+- intros. acacD'T2 ; subst.
++ left. apply InT_eq.
++ erequire IHge. erequire IHge. erequire IHge. require IHge.
+  reflexivity. destruct IHge.
+ * left. apply InT_cons. assumption.
+ * right. simpl. apply univ_gen_ext_cons. assumption.
+- intros. acacD'T2 ; subst.
++ right. simpl. assumption.
++ erequire IHge. erequire IHge. erequire IHge. require IHge.
+  reflexivity. destruct IHge.
+ * left. assumption.
+ * right. simpl. apply univ_gen_ext_extra. apply I. assumption.
+Qed.
+ +
+Definition gen_ext_diff V X y Y Z ge := @gen_ext_diff' V X _ ge y Y Z eq_refl.
+ +
+Lemma gen_ext_delet_hd {A : Type} : forall (l1 l2 l3: list A) (a : A),
+       gen_ext l1 l2 -> (l1 = a :: l3) ->gen_ext l3 l2.
+Proof.
+intros l1 l2 l3 a gen. generalize dependent l3. induction gen.
+- intros l3 E. inversion E.
+- intros l3 E. inversion E. destruct l3.
+  * subst. apply gen_ext_nil_any.
+  * inversion E. subst. apply univ_gen_ext_extra. apply I. assumption.
+- intros l3 E. apply univ_gen_ext_extra. apply I. apply IHgen. assumption.
+Qed.
+ +
+Lemma gen_ext_elem_deep {A : Type} : forall (l1 l2 l3 l4: list A) (a : A),
+         gen_ext l1 l2 ->
+          (l2 = l3 ++ a :: l4) ->
+            ((gen_ext l1 (l3 ++ l4)) +
+            sigT (fun l5 => sigT (fun l6 =>
+              (prod (l1 = l5 ++ a :: l6) (prod (gen_ext l5 l3) (gen_ext l6 l4)))))).
+Proof.
+intros l1 l2 l3 l4 a gen. generalize dependent a. generalize dependent l4.
+generalize dependent l3. induction gen.
+- intros l3 l4 a E. destruct l3. inversion E. inversion E.
+- intros l3 l4 a E. destruct l3.
+  * inversion E. simpl in E. destruct l4.
+    + right. exists []. exists []. split. simpl. destruct l.
+      reflexivity. exfalso. subst. inversion gen. split.
+      apply univ_gen_ext_nil. apply univ_gen_ext_nil.
+    + pose (IHgen [] l4 a0). simpl in s. pose (s H1). destruct s0.
+      { right. exists []. exists l. split. reflexivity. split.
+        apply univ_gen_ext_nil. apply univ_gen_ext_extra. apply I. assumption. }
+      { repeat destruct s0. repeat destruct p. subst. right.
+        exists []. exists (x0 ++ a0 :: x1). split. reflexivity.
+        split. apply univ_gen_ext_nil. destruct x0. simpl. apply univ_gen_ext_cons. assumption.
+        inversion g. }
+  * inversion E. pose (IHgen l3 l4 a H1). destruct s.
+    + left. apply univ_gen_ext_cons. assumption.
+    + repeat destruct s. repeat destruct p. subst. right. exists (a0 :: x0).
+      exists x1. split. reflexivity. split. apply univ_gen_ext_cons. assumption.
+      assumption.
+- intros l3 l4 a E. destruct l3.
+  * simpl in E. inversion E. subst. left. simpl. assumption.
+  * inversion E. pose (IHgen l3 l4 a H1). destruct s.
+    + left. apply univ_gen_ext_extra. apply I. assumption.
+    + repeat destruct s. repeat destruct p0. subst. right.
+      exists x0. exists x1. split. reflexivity. split.
+      apply univ_gen_ext_extra. apply I. assumption. assumption.
+Qed.
+ +
+Lemma gen_ext_add_elem_deep {A : Type} : forall (l1 l2 l3: list A) (a : A),
+   gen_ext l1 (l2 ++ l3) ->gen_ext l1 (l2 ++ a :: l3).
+Proof.
+induction l1.
+- intros. apply gen_ext_nil_any.
+- induction l2.
+  * intros l3 a0 gen. simpl. simpl in gen. apply univ_gen_ext_extra. apply I. assumption.
+  * intros l3 a1 gen. remember ((a0 :: l2) ++ l3) as l4. remember (a :: l1) as l5. destruct gen.
+    + apply gen_ext_nil_any.
+    + inversion Heql4. simpl. subst. apply univ_gen_ext_cons.
+      inversion Heql5. apply IHl1. rewrite <- H1. assumption.
+    + inversion Heql4. subst. simpl. apply univ_gen_ext_extra. apply I.
+      apply IHl2. assumption.
+Qed.
+ +
+Ltac solve_gen_ext :=
+  repeat (apply gen_ext_appR ||
+      apply gen_ext_nil_any || apply gen_ext_refl ||
+      apply gen_ext_sameL || apply gen_ext_appL ||
+      apply univ_gen_ext_cons || apply univ_gen_ext_extra).
+ +
+Ltac solve_univ_gen_ext :=
+  repeat (apply univ_gen_ext_appR || apply univ_gen_ext_refl ||
+      apply univ_gen_ext_appL || apply univ_gen_ext_cons ||
+      apply univ_gen_ext_extra).
+ +
+(* univ_gen_ext simulates rest_gen_ext. The latter allows to restrict
+   the elements you can add to the embedding list to elements of a specific
+   list l. *)

+ +
+Definition rest_gen_ext {W : Type} l := univ_gen_ext (fun x => (@InT W x l)).
+
+
+ +
+ + + diff --git a/General.univ_gen_mod.html b/General.univ_gen_mod.html new file mode 100644 index 0000000..e27f9c1 --- /dev/null +++ b/General.univ_gen_mod.html @@ -0,0 +1,228 @@ + + + + + + + + + + + + + +
+
+

General.univ_gen_mod

+ +
+Require Export List.
+Export ListNotations.
+Set Implicit Arguments.
+ +
+From Coq Require Import ssreflect.
+ +
+Require Import gen.
+Require Import existsT.
+Require Import genT.
+Require Import gen_tacs.
+Require Import gen_seq.
+Require Import List_lemmasT.
+Require Import FunctionalExtensionality.
+Require Import Lia.
+ +
+(* Effectively, univ_gen_mod allows to take a list and modify it by
+    substituting elements (say x) in the initial list by other elements
+    (say y) such that they are satisfying a specific relation (i.e. P x y).  *)

+ +
+Inductive univ_gen_mod W (P : W -> W -> Type) : relationT (list W) :=
+  | univ_gen_mod_nil : univ_gen_mod P [] []
+  | univ_gen_mod_cons : forall x l lm, univ_gen_mod P l lm -> univ_gen_mod P (x :: l) (x :: lm)
+  | univ_gen_mod_modif : forall x y l lm, P x y -> univ_gen_mod P l lm -> univ_gen_mod P (x :: l) (y :: lm)
+  .
+ +
+(* We can prove some general properties about univ_gen_mod. *)
+ +
+(* univ_gen_mod is a reflexive relation. *)
+ +
+Lemma univ_gen_mod_refl: forall A (l : list A) P, univ_gen_mod P l l.
+Proof.
+induction l.
+- apply univ_gen_mod_nil.
+- intro. apply univ_gen_mod_cons. apply IHl.
+Qed.
+ +
+(* The lemma univ_gen_mod_lem states that if a list x::Z is embedded in
+   a list Y, then x must be appearing in Y, i.e. Y = Y1++x::Y2, and Y2 is
+   is such that Z is embedded in Y2. Note that Y1 is here as it could well
+   be that some elements were added via univ_gen_mod_modif before even
+   treating x. *)

+ +
+Lemma univ_gen_mod_lem: forall A (x : A) P Z Y,
+  univ_gen_mod P (x :: Z) Y -> sigT (fun Y1 => sigT (fun y =>
+  prod (P x y + (x = y)) (prod (Y = y :: Y1) (univ_gen_mod P Z Y1)))).
+Proof.
+intros A x P Z. induction Y.
+intro. inversion X. intro. inversion X ; subst. exists Y. exists a. split ; auto.
+exists Y. exists a ; repeat split ; auto.
+Qed.
+ +
+(* The next two lemmas deal with the interaction between univ_gen_mod
+   and append. In essence, they say that if the embedded (resp. embedding)
+   list is of the shape X1++X2, then the embedding list (resp. embedded)
+   is of the shape W1++W2 where W1 embedds (resp. is embedded in) X1 and
+   W2 embedds (resp. is embedded in) X1. *)

+ +
+Lemma univ_gen_mod_splitL: forall A P (Z2 Z1 Y : list A),
+  univ_gen_mod P (Z1 ++ Z2) Y -> sigT (fun Y1 => sigT (fun Y2 =>
+    prod (Y = Y1 ++ Y2) (prod (univ_gen_mod P Z1 Y1) (univ_gen_mod P Z2 Y2)))).
+Proof.
+intros A P Z2. induction Z1 ; simpl.
+- exists []. exists Y. simpl. split. trivial. split. apply univ_gen_mod_nil. trivial.
+- intro. intro. apply univ_gen_mod_lem in X. destruct X. destruct s. repeat destruct p.
+  destruct s ; subst.
+  + apply IHZ1 in u. destruct u. destruct s. repeat destruct p0.
+     exists (x0 :: x1). exists x2. repeat split ; auto. subst ; trivial.
+     apply univ_gen_mod_modif ; auto.
+  + apply IHZ1 in u. destruct u. destruct s. repeat destruct p ; subst.
+     exists (x0 :: x1). exists x2. repeat split ; auto.
+     apply univ_gen_mod_cons ; auto.
+Qed.
+ +
+Lemma univ_gen_mod_splitR: forall A P (Z2 Z1 Y : list A),
+  univ_gen_mod P Y (Z1 ++ Z2) -> sigT (fun Y1 => sigT (fun Y2 =>
+    prod (Y = Y1 ++ Y2) (prod (univ_gen_mod P Y1 Z1) (univ_gen_mod P Y2 Z2)))).
+Proof.
+intros V Z2. induction Z1 ; simpl.
+- exists []. exists Y. simpl. split. trivial. split. apply univ_gen_mod_nil. trivial.
+- intro. intro. inversion X ; subst. apply IHZ1 in X0. cD. subst.
+  exists (a :: X0). exists X1. simpl. split. trivial.
+  split. apply univ_gen_mod_cons. assumption. assumption.
+  apply IHZ1 in X1. cD. subst.
+  exists (x :: X1). exists X2. split. trivial. split. apply univ_gen_mod_modif ; auto.
+  assumption.
+Qed.
+ +
+(* univ_gen_mod_combine claims that if Y1 is embedded in Z1 and Y2 is embedded
+   in Z2, then we can combine the embedded lists in the shape of Y1++Y2 and combine
+   the embedding lists in Z1++Z2 to preserve the relation of embedding between the
+   newly created lists.*)

+ +
+Lemma univ_gen_mod_combine: forall A P (Z2 Z1 Y2 Y1 : list A),
+    univ_gen_mod P Y1 Z1 -> univ_gen_mod P Y2 Z2 -> univ_gen_mod P (Y1 ++ Y2) (Z1 ++ Z2).
+Proof.
+intros A P Z2 Z1 Y2 Y1 gen1 gen2. induction gen1.
+- repeat rewrite app_nil_l. assumption.
+- simpl. apply univ_gen_mod_cons. assumption.
+- simpl. apply univ_gen_mod_modif. assumption. assumption.
+Qed.
+ +
+(* The next lemma states that if a::Y is embedded in a::Z, then we know
+   for sure that Y is embedded in Z. Note that this is not direct as the
+   a in the embedding list could have been added via univ_gen_mod_modif.
+   Effectively, this lemma allows one to remove the identical heads of two
+   lists univ_gen_mod and preserve that relation. *)

+ +
+Lemma univ_gen_mod_same_hd: forall A P (Y Z : list A) (a : A),
+    univ_gen_mod P (a :: Y) (a :: Z) -> univ_gen_mod P Y Z.
+Proof.
+intros A P Y Z a gen. inversion gen ; auto.
+Qed.
+ +
+(* The lemma univ_gen_mod_elem_deep considers a list l1 embedded in a
+   list l2 in which an element a appears deeply. Essentially, the lemma
+   makes a case distinction about a: either it has been added by univ_gen_mod_modif
+   (this is the first case of the sum) or it was added by univ_gen_mod_cons
+   in which case it has to appear somewhere in l1. *)

+ +
+Lemma univ_gen_mod_elem_deep {A : Type} : forall P (l1 l2 l3 l4: list A) a,
+          univ_gen_mod P l1 l2 ->
+          (l2 = l3 ++ a :: l4) ->
+            sigT (fun l5 => sigT (fun l6 => sigT (fun b =>
+              (prod (l1 = l5 ++ b :: l6) (prod (P b a + (a = b)) (prod (univ_gen_mod P l5 l3) (univ_gen_mod P l6 l4))))))).
+Proof.
+intros. subst. rewrite cons_single in X. apply univ_gen_mod_splitR in X.
+destruct X. destruct s. repeat destruct p. subst.
+apply univ_gen_mod_splitR in u0. destruct u0. destruct s. repeat destruct p.
+subst. inversion u0 ; subst.
+- inversion X ; subst. exists x. exists x2. exists a. repeat split ; auto.
+- inversion X0. subst. exists x. exists x2. exists x0. repeat split ; auto.
+Qed.
+ +
+Lemma univ_gen_mod_In {A : Type} : forall (l0 l1 : list A) a P, univ_gen_mod P l0 l1 ->
+                                        InT a l0 -> (InT a l1 + (existsT2 b, InT b l1 * P a b)).
+Proof.
+intros. induction X ; subst.
+- inversion X0.
+- inversion X0 ; subst. left ; apply InT_eq. apply IHX in X1. destruct X1.
+  left ; apply InT_cons ; auto. destruct s ; destruct p. right ; exists x0 ; split ; auto.
+  apply InT_cons ; auto.
+- inversion X0 ; subst. right. exists y ; split ; auto. apply InT_eq. apply IHX in X1. destruct X1.
+  left ; apply InT_cons ; auto. destruct s ; destruct p0. right ; exists x0 ; split ; auto.
+  apply InT_cons ; auto.
+Qed.
+ +
+Lemma univ_gen_mod_smaller_length : forall {A: Type} (l1 l2 : list A) P,
+                      univ_gen_mod P l1 l2 -> length l1 = length l2.
+Proof.
+intros. induction X.
+- auto.
+- simpl. lia.
+- simpl. lia.
+Qed.
+ +
+Lemma InT_univ_gen_mod : forall {A : Type} (l1 l2 : list A) (P : A -> A -> Type) (a : A),
+          (InT a l2) -> (univ_gen_mod P l1 l2) -> ((existsT2 b, InT b l1 * P b a) + (InT a l1)).
+Proof.
+intros. induction X0 ; subst ; simpl.
+- inversion X.
+- inversion X ; subst. right. apply InT_eq. apply IHX0 in X1. destruct X1. destruct s ; destruct p.
+  left. exists x0. split ; auto. apply InT_cons. assumption. right ; apply InT_cons ; auto.
+- inversion X ; subst. left. exists x ; split ; auto. apply InT_eq. apply IHX0 in X1. destruct X1.
+  destruct s ; destruct p0. left ; exists x0 ; split ; auto. apply InT_cons ; auto. right ; apply InT_cons ; auto.
+Qed.
+ +
+
+
+ +
+ + + diff --git a/ISL.Cut.html b/ISL.Cut.html new file mode 100644 index 0000000..601121c --- /dev/null +++ b/ISL.Cut.html @@ -0,0 +1,356 @@ + + + + + + + + + + + + + +
+
+

ISL.Cut

+ +
+Require Import ISL.Formulas ISL.Sequents ISL.Order.
+Require Import ISL.SequentProps .
+ +
+Local Hint Rewrite elements_env_add : order.
+ +
+(* From "A New Calculus for Intuitionistic Strong Löb Logic" *)
+Theorem additive_cut Γ φ ψ :
+  Γ φ -> Γ φ ψ ->
+  Γ ψ.
+Proof.
+remember (weight φ) as w. assert(Hw : weight φ w) by lia. clear Heqw.
+revert φ Hw ψ Γ.
+induction w; intros φ Hw; [pose (weight_pos φ); lia|].
+intros ψ Γ.
+remember (Γ, ψ) as pe.
+replace Γ with pe.1 by now subst.
+replace ψ with pe.2 by now subst. clear Heqpe Γ ψ. revert pe.
+refine (@well_founded_induction _ _ wf_pointed_env_ms_order _ _).
+intros (Γ &ψ). simpl. intro IHW'. assert (IHW := fun Γ0 => fun ψ0 => IHW' (Γ0, ψ0)).
+simpl in IHW. clear IHW'. intros HPφ HPψ.
+Ltac otac Heq := subst; repeat rewrite env_replace in Heq by trivial; repeat rewrite env_add_remove by trivial; order_tac; rewrite Heq; order_tac.
+destruct HPφ; simpl in Hw.
+- now apply contraction.
+- apply ExFalso.
+- apply AndL_rev in HPψ. do 2 apply IHw in HPψ; trivial; try lia; apply weakening; assumption.
+- apply AndL. apply IHW; auto with proof. order_tac.
+- apply OrL_rev in HPψ; apply (IHw φ); [lia| |]; tauto.
+- apply OrL_rev in HPψ; apply (IHw ψ0); [lia| |]; tauto.
+- apply OrL; apply IHW; auto with proof.
+  + otac Heq.
+  + exch 0. eapply (OrL_rev _ φ ψ0). exch 0. exact HPψ.
+  + order_tac.
+  + exch 0. eapply (OrL_rev _ φ ψ0). exch 0. exact HPψ.
+- (* (V) *) (* hard:  *)
+(* START *)
+  remember (Γ (φ ψ0)) as Γ' eqn:HH.
+  assert (Heq: Γ Γ' {[ φ ψ0]}) by ms.
+  assert(Hin : (φ ψ0) Γ')by ms.
+  rw Heq 0. destruct HPψ.
+  + forward. auto with proof.
+  + forward. auto with proof.
+  + apply AndR.
+     * rw (symmetry Heq) 0. apply IHW.
+     -- unfold pointed_env_ms_order. order_tac.
+     -- now apply ImpR.
+     -- peapply HPψ1.
+     * rw (symmetry Heq) 0. apply IHW.
+       -- order_tac.
+       -- apply ImpR. box_tac. peapply HPφ.
+       -- peapply HPψ2.
+  + forward. apply AndL. apply IHW.
+     * unfold pointed_env_ms_order. otac Heq.
+     * apply AndL_rev. backward. rw (symmetry Heq) 0. apply ImpR, HPφ.
+     * backward. peapply HPψ.
+  + apply OrR1, IHW.
+    * rewrite HH, env_add_remove. order_tac.
+    * rw (symmetry Heq) 0. apply ImpR, HPφ.
+    * peapply HPψ.
+  + apply OrR2, IHW.
+    * rewrite HH, env_add_remove. order_tac.
+    * rw (symmetry Heq) 0. apply ImpR, HPφ.
+    * peapply HPψ.
+  + forward. apply ImpR in HPφ.
+       assert(Hin' : (φ0 ψ) ((Γ0 φ0 ψ) {[φ ψ0]}))
+            by (apply in_difference; [discriminate|ms]).
+       assert(HPφ' : (((Γ0 φ0 ψ) {[φ ψ0]}) {[φ0 ψ]} φ0 ψ) (φ ψ0))
+            by (rw (symmetry (difference_singleton _ (φ0 ψ) Hin')) 0; peapply HPφ).
+       assert (HP := (OrL_rev _ φ0 ψ (φ ψ0) HPφ')).
+       apply OrL.
+      * apply IHW.
+        -- rewrite env_replace in Heq by trivial. order_tac. rewrite Heq. order_tac.
+        -- peapply HP.1.
+        -- exch 0. rw (symmetry (difference_singleton _ _ Hin0)) 1. exact HPψ1.
+      * apply IHW.
+        -- rewrite env_replace in Heq by trivial. order_tac. rewrite Heq. order_tac.
+        -- peapply HP.2.
+        -- exch 0. rw (symmetry (difference_singleton _ _ Hin0)) 1. exact HPψ2.
+  + rw (symmetry Heq) 0. apply ImpR, IHW.
+      -- order_tac.
+      -- apply weakening, ImpR, HPφ.
+      -- exch 0. rewrite <- HH. exact HPψ.
+  + case (decide ((Var p φ0) = (φ ψ0))).
+      * intro Heq'; inversion Heq'; subst. clear Heq'.
+         replace ((Γ0 Var p (p ψ0)) {[p ψ0]}) with (Γ0 Var p) by ms.
+         apply (IHw ψ0).
+        -- lia.
+        -- apply contraction. peapply HPφ.
+        -- assumption.
+      * intro Hneq. do 2 forward. exch 0. apply ImpLVar, IHW.
+        -- repeat rewrite env_replace in Heq by trivial. order_tac. rewrite Heq. order_tac.
+        -- apply imp_cut with (φ := Var p). exch 0. do 2 backward.
+            rw (symmetry Heq) 0. apply ImpR, HPφ.
+        -- exch 0; exch 1. rw (symmetry (difference_singleton _ _ Hin1)) 2. exact HPψ.
+  + case (decide (((φ1 φ2) φ3)= (φ ψ0))).
+      * intro Heq'; inversion Heq'; subst. clear Heq'. rw (symmetry Heq) 0.
+         apply (IHw (φ1 φ2 ψ0)).
+        -- simpl in *. lia.
+        -- apply ImpR, ImpR, AndL_rev, HPφ.
+        -- peapply HPψ.
+      * intro Hneq. forward. apply ImpLAnd, IHW.
+        -- rewrite env_replace in Heq by trivial. order_tac. rewrite Heq. order_tac.
+        -- apply ImpLAnd_rev. backward. rw (symmetry Heq) 0. apply ImpR, HPφ.
+        -- exch 0. rw (symmetry (difference_singleton _ _ Hin0)) 1. exact HPψ.
+  + case (decide (((φ1 φ2) φ3)= (φ ψ0))).
+      * intro Heq'; inversion Heq'; subst. clear Heq'. rw (symmetry Heq) 0. apply OrL_rev in HPφ.
+         apply (IHw (φ1 ψ0)).
+        -- simpl in *. lia.
+        -- apply (IHw (φ2 ψ0)).
+           ++ simpl in *; lia.
+           ++ apply ImpR, HPφ.
+           ++ apply weakening, ImpR, HPφ.
+        -- apply (IHw (φ2 ψ0)).
+           ++ simpl in *; lia.
+           ++ apply weakening, ImpR, HPφ.
+           ++ peapply HPψ.
+      * intro Hneq. forward. apply ImpLOr, IHW.
+        -- rewrite env_replace in Heq by trivial. order_tac. rewrite Heq. order_tac.
+        -- apply ImpLOr_rev. backward. rw (symmetry Heq) 0. apply ImpR, HPφ.
+        -- exch 0. exch 1. rw (symmetry (difference_singleton _ _ Hin0)) 2. exact HPψ.
+  + case (decide (((φ1 φ2) φ3) = (φ ψ0))).
+     * intro Heq'. inversion Heq'; subst. clear Heq'. rw (symmetry Heq) 0. apply (IHw ψ0).
+      -- lia.
+      -- apply (IHw(φ1 φ2)).
+        ++ lia.
+        ++ apply (IHw (φ2 ψ0)).
+            ** simpl in *. lia.
+            ** apply ImpR. eapply imp_cut, HPφ.
+            ** peapply HPψ1.
+        ++ exact HPφ.
+    -- peapply HPψ2.
+   * (* (V-d) *)
+       intro Hneq. forward. apply ImpLImp.
+      -- apply ImpR, IHW.
+        ++ otac Heq.
+        ++ exch 0. apply contraction, ImpLImp_dup. backward. rw (symmetry Heq) 0.
+                apply ImpR, HPφ.
+        ++ exch 0. apply ImpR_rev. exch 0. rw (symmetry (difference_singleton _ _ Hin0)) 1.
+                exact HPψ1.
+      -- apply IHW.
+        ++ otac Heq.
+        ++ apply imp_cut with (φ1 φ2). backward. rw (symmetry Heq) 0.
+                apply ImpR, HPφ.
+        ++ exch 0. rw (symmetry (difference_singleton _ _ Hin0)) 1. exact HPψ2.
+  + case (decide (( φ1 φ2) = (φ ψ0))).
+     * intro Heq'. inversion Heq'; subst. clear Heq'. rw (symmetry Heq) 0.
+        assert(Γ = Γ0) by ms. subst Γ0. clear Hin.
+        apply (IHw ( φ1)).
+      -- lia.
+      -- apply BoxR, (IHw(ψ0)).
+        ++ lia.
+        ++ apply open_boxes_R, HPφ.
+        ++ exact HPψ1.
+     -- apply (IHw(ψ0)).
+        ++ lia.
+        ++ exact HPφ.
+        ++ exch 0. apply weakening, HPψ2.
+    * (* (V-f ) *)
+       intro Hneq. forward. apply ImpBox.
+       -- apply IHW.
+        ++ otac Heq. rewrite elements_open_boxes. otac Heq.
+        ++ apply ImpR_rev, open_boxes_R, ImpR.
+                apply ImpLBox_prev with φ1. exch 0. apply weakening.
+                backward. rw (symmetry Heq) 0. apply ImpR, HPφ.
+        ++ exch 0. exch 1. box_tac. apply In_open_boxes in Hin0. simpl in Hin0.
+               rw (symmetry (difference_singleton _ _ Hin0)) 2. exact HPψ1.
+       -- apply IHW.
+        ++ otac Heq.
+        ++ apply ImpLBox_prev with φ1. backward. rw (symmetry Heq) 0.
+                apply ImpR, HPφ.
+        ++ exch 0. rw (symmetry (difference_singleton _ _ Hin0)) 1. exact HPψ2.
+  + subst. rw (symmetry Heq) 0. rewrite open_boxes_add in HPψ. simpl in HPψ.
+      apply BoxR. apply IHW.
+    * otac Heq. rewrite elements_open_boxes. otac Heq.
+    * apply open_boxes_R, weakening, ImpR, HPφ.
+    * exch 0. exact HPψ.
+- apply ImpLVar. eapply IHW; eauto.
+  + otac Heq.
+  + exch 0. apply (imp_cut (Var p)). exch 0; exact HPψ.
+- apply ImpLAnd. eapply IHW; eauto.
+  + otac Heq.
+  + exch 0. apply ImpLAnd_rev. exch 0. exact HPψ.
+- apply ImpLOr. eapply IHW; eauto.
+  + otac Heq.
+  + exch 0. exch 1. apply ImpLOr_rev. exch 0. exact HPψ.
+- apply ImpLImp; [assumption|].
+  apply IHW.
+  + otac Heq.
+  + assumption.
+  + exch 0. eapply ImpLImp_prev. exch 0. exact HPψ.
+- apply ImpBox. trivial. apply IHW.
+  * otac Heq.
+  * assumption.
+  * exch 0. eapply ImpLBox_prev. exch 0. exact HPψ.
+  Require Import Coq.Program.Equality.
+(* (VIII) *)
+- remember (Γ φ) as Γ' eqn:HH.
+  assert (Heq: Γ Γ' {[ φ ]}) by ms.
+  assert(Hin : ( φ) Γ')by ms.
+  rw Heq 0. destruct HPψ.
+  + forward. auto with proof.
+  + forward. auto with proof.
+  + apply AndR.
+     * apply IHW.
+     -- subst. rewrite env_add_remove. otac H.
+     -- rw (symmetry Heq) 0. now apply BoxR.
+     -- peapply HPψ1.
+     * apply IHW.
+       -- otac Heq.
+       -- apply BoxR. box_tac. peapply HPφ. rewrite Heq.
+           rewrite open_boxes_remove; trivial.
+       -- peapply HPψ2.
+  + forward. apply AndL. apply IHW.
+     * otac Heq.
+     * apply AndL_rev. backward. rw (symmetry Heq) 0. apply BoxR, HPφ.
+     * backward. peapply HPψ.
+  + apply OrR1, IHW.
+    * otac Heq.
+    * rw (symmetry Heq) 0. apply BoxR, HPφ.
+    * peapply HPψ.
+  + apply OrR2, IHW.
+    * otac Heq.
+    * rw (symmetry Heq) 0. apply BoxR, HPφ.
+    * peapply HPψ.
+  + forward. apply BoxR in HPφ.
+       assert(Hin' : (φ0 ψ) ((Γ0 φ0 ψ) {[ φ]}))
+            by (apply in_difference; [discriminate|ms]).
+       assert(HPφ' : (((Γ0 φ0 ψ) {[ φ]}) {[φ0 ψ]} φ0 ψ) φ)
+            by (rw (symmetry (difference_singleton _ (φ0 ψ) Hin')) 0; peapply HPφ).
+       assert (HP := (OrL_rev _ φ0 ψ (φ) HPφ')).
+       apply OrL.
+      * apply IHW.
+        -- otac Heq.
+        -- peapply HP.1.
+        -- exch 0. rw (symmetry (difference_singleton _ _ Hin0)) 1. exact HPψ1.
+      * apply IHW.
+        -- otac Heq.
+        -- peapply HP.2.
+        -- exch 0. rw (symmetry (difference_singleton _ _ Hin0)) 1. exact HPψ2.
+  + rw (symmetry Heq) 0. apply ImpR, IHW.
+      -- otac Heq.
+      -- apply weakening, BoxR, HPφ.
+      -- exch 0. rewrite <- HH. exact HPψ.
+  + do 2 forward. exch 0. apply ImpLVar, IHW.
+      * otac Heq.
+      * apply imp_cut with (φ := Var p). exch 0. do 2 backward.
+         rewrite HH. apply BoxR in HPφ. peapply HPφ.
+      * exch 0; exch 1. rw (symmetry (difference_singleton _ _ Hin1)) 2. exact HPψ.
+  + forward. apply ImpLAnd, IHW.
+      * otac Heq.
+      * apply BoxR in HPφ. apply ImpLAnd_rev. backward. rewrite HH. peapply HPφ.
+      * exch 0. rw (symmetry (difference_singleton _ _ Hin0)) 1. exact HPψ.
+  + forward. apply ImpLOr, IHW.
+      * otac Heq.
+      * apply BoxR in HPφ. apply ImpLOr_rev. backward. rewrite HH. peapply HPφ.
+      * exch 0. exch 1. rw (symmetry (difference_singleton _ _ Hin0)) 2. exact HPψ.
+  + forward. apply ImpLImp.
+      -- apply ImpR, IHW.
+        ++ otac Heq.
+        ++ exch 0. apply contraction, ImpLImp_dup. backward. rw (symmetry Heq) 0.
+                apply BoxR, HPφ.
+        ++ exch 0. apply ImpR_rev. exch 0. rw (symmetry (difference_singleton _ _ Hin0)) 1.
+                exact HPψ1.
+      -- apply IHW.
+        ++ otac Heq.
+        ++ apply imp_cut with (φ1 φ2). backward. rw (symmetry Heq) 0.
+                apply BoxR, HPφ.
+        ++ exch 0. rw (symmetry (difference_singleton _ _ Hin0)) 1. exact HPψ2.
+  + (* (VIII-b) *)
+      forward. apply ImpBox.
+     * (* π0 *)
+        apply IHW.
+      -- otac Heq. rewrite elements_open_boxes. otac Heq.
+      -- apply ImpLBox_prev with (φ1 := φ1).
+          exch 0. apply weakening.
+          apply open_boxes_R. backward. rw (symmetry Heq) 0. apply BoxR, HPφ.
+      -- (* π1 *)
+          apply (IHw φ).
+          ++ lia.
+          ++ exch 1; exch 0. apply weakening.
+                  exch 0. apply ImpLBox_prev with (φ1 := φ1). exch 0.
+                  replace ( φ1 φ2) with ( ( φ1 φ2)) by trivial.
+                  rewrite <- (open_boxes_add (Γ0 {[φ]}) ( φ1 φ2)).
+                  assert(Heq0 : (Γ0 {[ φ]} ( φ1 φ2)) Γ)
+                      by (rewrite Heq; now rewrite env_replace).
+                 rw (proper_open_boxes _ _ Heq0) 1. exact HPφ.
+          ++ box_tac. exch 0. apply weakening. exch 0. exch 1.
+                  assert(Hin1 : φ Γ0) by(apply In_open_boxes in Hin0; now simpl).
+                  rw (symmetry (difference_singleton _ _ Hin1)) 2. exact HPψ1.
+     * apply IHW.
+      -- otac Heq.
+      -- apply ImpLBox_prev with (φ1 := φ1). backward.
+          rw (symmetry Heq) 0. apply BoxR, HPφ.
+      -- exch 0. rw (symmetry (difference_singleton _ _ Hin0)) 1. exact HPψ2.
+  + (* (VIII-c) *)
+      subst. rw (symmetry Heq) 0. rewrite open_boxes_add in HPψ. simpl in HPψ.
+      apply BoxR. apply IHW.
+    * otac Heq. rewrite elements_open_boxes. otac Heq.
+    * apply open_boxes_R, weakening, BoxR, HPφ.
+    * apply (IHw φ).
+      -- lia.
+      -- exch 0. apply weakening, HPφ.
+      -- exch 0. apply weakening. exch 0. exact HPψ.
+Qed.
+ +
+(* Multiplicative cut rule *)
+Theorem cut Γ Γ' φ ψ :
+  Γ φ -> Γ' φ ψ ->
+  Γ Γ' ψ.
+Proof.
+intros π1 π2. apply additive_cut with φ.
+- apply generalised_weakeningR, π1.
+- replace (Γ Γ' φ) with (Γ (Γ' φ)) by ms. apply generalised_weakeningL, π2.
+Qed.
+
+
+ +
+ + + diff --git a/ISL.DecisionProcedure.html b/ISL.DecisionProcedure.html new file mode 100644 index 0000000..1ca188c --- /dev/null +++ b/ISL.DecisionProcedure.html @@ -0,0 +1,663 @@ + + + + + + + + + + + + + +
+
+

ISL.DecisionProcedure

+ +
+Require Import ISL.Sequents ISL.SequentProps ISL.Order.
+ +
+Global Instance proper_rm : Proper ((=) ==> (≡ₚ) ==> (≡ₚ)) rm.
+Proof.
+intros x y Heq. subst y.
+induction 1; simpl; trivial.
+- case form_eq_dec; auto with *.
+- case form_eq_dec; auto with * ;
+   case form_eq_dec; auto with *. intros. apply Permutation_swap.
+- now rewrite IHPermutation1.
+Qed.
+ +
+Definition exists_dec {A : Type} (P : A -> bool) (l : list A): {x & (In x l) /\ P x} + {forall x, In x l -> ¬ P x}.
+Proof.
+induction l as [|x l].
+- right. tauto.
+- case_eq (P x); intro Heq.
+  + left. exists x. split; auto with *.
+  + destruct IHl as [(y & Hin & Hy)|Hf].
+    * left. exists y. split; auto with *.
+    * right. simpl. intros z [Hz|Hz]; subst; try rewrite Heq; auto with *.
+Defined.
+ +
+(* This function computes a proof tree of a sequent, if there is one, or produces a proof that there is none *)
+Proposition Proof_tree_dec Γ φ :
+  {_ : list_to_set_disj Γ φ & True} + {forall H : list_to_set_disj Γ φ, False}.
+Proof.
+(* duplicate *)
+Ltac l_tac := repeat rewrite list_to_set_disj_open_boxes;
+    rewrite (proper_Provable _ _ (list_to_set_disj_env_add _ _) _ _ eq_refl)
+|| rewrite (proper_Provable _ _ (equiv_disj_union_compat_r (list_to_set_disj_env_add _ _)) _ _ eq_refl)
+|| rewrite (proper_Provable _ _ (equiv_disj_union_compat_r (equiv_disj_union_compat_r (list_to_set_disj_env_add _ _))) _ _ eq_refl)
+|| rewrite (proper_Provable _ _ (equiv_disj_union_compat_r(equiv_disj_union_compat_r (equiv_disj_union_compat_r (list_to_set_disj_env_add _ _)))) _ _ eq_refl).
+remember (Γ, φ) as pe.
+replace Γ with pe.1 by now inversion Heqpe.
+replace φ with pe.2 by now inversion Heqpe. clear Heqpe Γ φ.
+revert pe.
+refine (@well_founded_induction _ _ wf_pointed_order _ _).
+intros (Γ& φ) Hind; simpl.
+assert(Hind' := λ Γ' φ', Hind(Γ', φ')). simpl in Hind'. clear Hind. rename Hind' into Hind.
+ +
+case (decide ( Γ)); intro Hbot.
+{ left. eexists; trivial. apply elem_of_list_to_set_disj in Hbot. exhibit Hbot 0. apply ExFalso. }
+assert(HAndR : {φ1 & {φ2 & φ = (And φ1 φ2)}} + { φ1 φ2, φ (And φ1 φ2)}) by (destruct φ; eauto).
+destruct HAndR as [(φ1 & φ2 & Heq) | HAndR].
+{ subst.
+  destruct (Hind Γ φ1) as [(Hp1&_) | H1]. order_tac.
+  - destruct (Hind Γ φ2) as [(Hp2&_) | H2]. order_tac.
+    + left. eexists; trivial. apply AndR; assumption.
+    + right. intro Hp. apply AndR_rev in Hp. tauto.
+  - right. intro Hp. apply AndR_rev in Hp. tauto.
+}
+assert(Hvar : {p & φ = Var p & Var p Γ} + { p, φ = Var p -> Var p Γ -> False}). {
+  destruct φ. 2-6: right; auto with *.
+  case (decide (Var v Γ)); intro Hin.
+  - left. exists v; trivial.
+  - right; auto with *. }
+destruct Hvar as [[p Heq Hp]|Hvar].
+{ subst. left. eexists; trivial. apply elem_of_list_to_set_disj in Hp. exhibit Hp 0. apply Atom. }
+assert(HAndL : {ψ1 & {ψ2 & (And ψ1 ψ2) Γ}} + { ψ1 ψ2, (And ψ1 ψ2) Γ -> False}). {
+  pose (fA := (fun θ => match θ with |And _ _ => true | _ => false end)).
+  destruct (exists_dec fA Γ) as [(θ & Hin & ) | Hf].
+  - left. subst fA. destruct θ. 3: { eexists. eexists. apply elem_of_list_In. eauto. }
+    all: auto with *.
+  - right. intros ψ1 ψ2 Hψ. rewrite elem_of_list_In in Hψ. apply Hf in Hψ. subst fA. simpl in Hψ. tauto.
+}
+destruct HAndL as [(ψ1 & ψ2 & Hin)|HAndL].
+{ destruct (Hind (ψ1 :: ψ2 :: rm (And ψ1 ψ2) Γ) φ) as [[Hp' _] | Hf]. order_tac.
+  - left. eexists; trivial. apply elem_of_list_to_set_disj in Hin.
+    exhibit Hin 0.
+    rewrite (proper_Provable _ _ (equiv_disj_union_compat_r (list_to_set_disj_rm _ _)) _ _ eq_refl).
+    apply AndL. peapply Hp'.
+ - right. intro Hf'. apply Hf.
+   rw (symmetry (list_to_set_disj_env_add (ψ2 :: rm (And ψ1 ψ2) Γ) ψ1)) 0.
+   rw (symmetry (list_to_set_disj_env_add (rm (And ψ1 ψ2) Γ) ψ2)) 1.
+   exch 0. apply AndL_rev.
+   rw (symmetry (list_to_set_disj_rm Γ(And ψ1 ψ2))) 1.
+   apply elem_of_list_to_set_disj in Hin.
+   pose (difference_singleton (list_to_set_disj Γ) (And ψ1 ψ2)).
+   peapply Hf'.
+}
+assert(HImpR : {φ1 & {φ2 & φ = (Implies φ1 φ2)}} + { φ1 φ2, φ (Implies φ1 φ2)}) by (destruct φ; eauto).
+destruct HImpR as [(φ1 & φ2 & Heq) | HImpR].
+{ subst.
+  destruct (Hind (φ1 :: Γ) φ2) as [(Hp1&_) | H1]. order_tac.
+  - left. eexists; trivial. apply ImpR. peapply Hp1.
+  - right. intro Hf. apply H1. apply ImpR_rev in Hf. peapply Hf.
+}
+assert(HOrL : {ψ1 & {ψ2 & (Or ψ1 ψ2) Γ}} + { ψ1 ψ2, (Or ψ1 ψ2) Γ -> False}). {
+  pose (fA := (fun θ => match θ with |Or _ _ => true | _ => false end)).
+  destruct (exists_dec fA Γ) as [(θ & Hin & ) | Hf].
+  - left. subst fA. destruct θ. 4: { eexists. eexists. apply elem_of_list_In. eauto. }
+    all: auto with *.
+  - right. intros ψ1 ψ2 Hψ. rewrite elem_of_list_In in Hψ. apply Hf in Hψ. subst fA. simpl in Hψ. tauto.
+}
+destruct HOrL as [(ψ1 & ψ2 & Hin)|HOrL].
+{ apply elem_of_list_to_set_disj in Hin.
+  destruct (Hind (ψ1 :: rm (Or ψ1 ψ2) Γ) φ) as [[Hp1 _] | Hf]. order_tac.
+  - destruct (Hind (ψ2 :: rm (Or ψ1 ψ2) Γ) φ) as [[Hp2 _] | Hf]. order_tac.
+    + left. eexists; trivial. exhibit Hin 0.
+         rewrite (proper_Provable _ _ (equiv_disj_union_compat_r (list_to_set_disj_rm _ _)) _ _ eq_refl).
+         apply OrL. peapply Hp1. peapply Hp2.
+    + right; intro Hf'. assert(Hf'' :list_to_set_disj (rm (Or ψ1 ψ2) Γ) Or ψ1 ψ2 φ). {
+          rw (symmetry (list_to_set_disj_rm Γ(Or ψ1 ψ2))) 1.
+          pose (difference_singleton (list_to_set_disj Γ) (Or ψ1 ψ2)). peapply Hf'.
+         }
+        apply OrL_rev in Hf''. apply Hf. peapply Hf''.
+  - right; intro Hf'. assert(Hf'' :list_to_set_disj (rm (Or ψ1 ψ2) Γ) Or ψ1 ψ2 φ). {
+          rw (symmetry (list_to_set_disj_rm Γ(Or ψ1 ψ2))) 1.
+          pose (difference_singleton (list_to_set_disj Γ) (Or ψ1 ψ2)). peapply Hf'.
+         }
+        apply OrL_rev in Hf''. apply Hf. peapply Hf''.1.
+}
+assert(HImpLVar : {p & {ψ & Var p Γ /\ (Implies (Var p) ψ) Γ}} +
+                                 { p ψ, Var p Γ -> (Implies (Var p) ψ) Γ -> False}). {
+  pose (fIp :=λ p θ, match θ with | Implies (Var q) _ => if decide (p = q) then true else false | _ => false end).
+  pose (fp:= (fun θ => match θ with |Var p => if (exists_dec (fIp p) Γ) then true else false | _ => false end)).
+  destruct (exists_dec fp Γ) as [(θ & Hin & ) | Hf].
+  - left. subst fp. destruct θ. 2-6: auto with *.
+    case exists_dec as [(ψ &Hinψ & Hψ)|] in ; [|auto with *].
+    unfold fIp in Hψ. destruct ψ. 1-4, 6: auto with *.
+    destruct ψ1. 2-6: auto with *. case decide in Hψ; [|auto with *].
+    subst. apply elem_of_list_In in Hinψ, Hin.
+    do 2 eexists. split; eauto.
+  - right. intros p ψ Hp Hψ. rewrite elem_of_list_In in Hp, Hψ. apply Hf in Hp. subst fp fIp.
+    simpl in Hp. case exists_dec as [|Hf'] in Hp. auto with *.
+    apply (Hf' _ Hψ). rewrite decide_True; trivial. auto with *.
+}
+destruct HImpLVar as [[p [ψ [Hinp Hinψ]]]|HImpLVar].
+{ apply elem_of_list_to_set_disj in Hinp.
+  apply elem_of_list_to_set_disj in Hinψ.
+  assert(Hinp' : Var p (list_to_set_disj Γ {[Implies p ψ]} : env))
+    by (apply in_difference; [discriminate| assumption]).
+  destruct (Hind:: rm (Implies (Var p) ψ) Γ) φ) as [[Hp _]|Hf]. order_tac.
+  - left. eexists; trivial. exhibit Hinψ 0.
+     exhibit Hinp' 1. apply ImpLVar.
+     rw (symmetry (difference_singleton (list_to_set_disj Γ {[Implies p ψ]}) (Var p) Hinp')) 1.
+     rw (list_to_set_disj_rm Γ(Implies p ψ)) 1. l_tac. exact Hp.
+  - right. intro Hf'. apply Hf.
+     rw (symmetry (list_to_set_disj_env_add (rm (Implies p ψ) Γ) ψ)) 0.
+     rw (symmetry (list_to_set_disj_rm Γ(Implies p ψ))) 1.
+     exhibit Hinp' 1. apply ImpLVar_rev.
+     rw (symmetry (difference_singleton _ _ Hinp')) 1.
+     rw (symmetry (difference_singleton _ _ Hinψ)) 0.
+     exact Hf'.
+}
+assert(HImpLAnd : {φ1 & {φ2 & {φ3 & (Implies (And φ1 φ2) φ3) Γ}}} +
+                                 { φ1 φ2 φ3, (Implies (And φ1 φ2) φ3) Γ -> False}). {
+    pose (fII := (fun θ => match θ with |Implies (And _ _) _ => true | _ => false end)).
+   destruct (exists_dec fII Γ) as [(θ & Hin & ) | Hf].
+    - left. subst fII. destruct θ. 1-4, 6: auto with *.
+      destruct θ1. 1-2,4-6: auto with *. do 3 eexists; apply elem_of_list_In; eauto.
+    - right. intros ψ1 ψ2 ψ3 Hψ. rewrite elem_of_list_In in Hψ. apply Hf in Hψ. subst fII. simpl in Hψ. tauto.
+}
+destruct HImpLAnd as [(φ1&φ2&φ3&Hin)|HImpLAnd].
+{ apply elem_of_list_to_set_disj in Hin.
+  destruct (Hind (Implies φ1 (Implies φ2 φ3) :: rm (Implies (And φ1 φ2) φ3) Γ) φ) as [[Hp _]|Hf]. order_tac.
+  - left. eexists; trivial. exhibit Hin 0. apply ImpLAnd.
+     rw (list_to_set_disj_rm Γ(Implies (And φ1 φ2) φ3)) 1. l_tac. exact Hp.
+  - right. intro Hf'. apply Hf.
+     rw (symmetry (list_to_set_disj_env_add (rm (Implies (And φ1 φ2) φ3) Γ) (Implies φ1 (Implies φ2 φ3)))) 0.
+     rw (symmetry (list_to_set_disj_rm Γ(Implies (And φ1 φ2) φ3))) 1.
+     apply ImpLAnd_rev.
+     rw (symmetry (difference_singleton _ _ Hin)) 0. exact Hf'.
+}
+assert(HImpLOr : {φ1 & {φ2 & {φ3 & (Implies (Or φ1 φ2) φ3) Γ}}} +
+                                 { φ1 φ2 φ3, (Implies (Or φ1 φ2) φ3) Γ -> False}). {
+    pose (fII := (fun θ => match θ with |Implies (Or _ _) _ => true | _ => false end)).
+   destruct (exists_dec fII Γ) as [(θ & Hin & ) | Hf].
+    - left. subst fII. destruct θ. 1-4, 6: auto with *.
+      destruct θ1. 1-3, 5-6: auto with *. do 3 eexists; apply elem_of_list_In; eauto.
+    - right. intros ψ1 ψ2 ψ3 Hψ. rewrite elem_of_list_In in Hψ. apply Hf in Hψ. subst fII. simpl in Hψ. tauto.
+}
+destruct HImpLOr as [(φ1&φ2&φ3&Hin)|HImpLOr].
+{ apply elem_of_list_to_set_disj in Hin.
+  destruct (Hind (Implies φ2 φ3 :: Implies φ1 φ3 :: rm (Implies (Or φ1 φ2) φ3) Γ) φ) as [[Hp _]|Hf]. order_tac.
+  - left. eexists; trivial. exhibit Hin 0. apply ImpLOr.
+     rw (list_to_set_disj_rm Γ(Implies (Or φ1 φ2) φ3)) 2. do 2 l_tac. exact Hp.
+  - right. intro Hf'. apply Hf.
+     rw (symmetry (list_to_set_disj_env_add ( Implies φ1 φ3 :: rm (Implies (Or φ1 φ2) φ3) Γ) (Implies φ2 φ3))) 0.
+     rw (symmetry (list_to_set_disj_env_add (rm (Implies (Or φ1 φ2) φ3) Γ) (Implies φ1 φ3))) 1.
+     rw (symmetry (list_to_set_disj_rm Γ(Implies (Or φ1 φ2) φ3))) 2.
+     apply ImpLOr_rev.
+     rw (symmetry (difference_singleton _ _ Hin)) 0. exact Hf'.
+}
+(* non invertible right rules *)
+assert(HOrR1 : {φ1 & {φ2 & {Hp : (list_to_set_disj Γ φ1) & φ = (Or φ1 φ2)}}} +
+                       { φ1 φ2, (H : list_to_set_disj Γ φ1), φ = (Or φ1 φ2) -> False}).
+{
+  destruct φ. 4: { destruct (Hind Γ φ1)as [[Hp _]|Hf]. order_tac.
+  - left. do 3 eexists; eauto.
+  - right. intros ? ? Hp Heq. inversion Heq. subst. tauto.
+  }
+  all: right; auto with *.
+}
+destruct HOrR1 as [(φ1 & φ2 & Hp & Heq)| HOrR1].
+{ subst. left. eexists; trivial. apply OrR1, Hp. }
+assert(HOrR2 : {φ1 & {φ2 & {Hp : (list_to_set_disj Γ φ2) & φ = (Or φ1 φ2)}}} +
+                       { φ1 φ2, (H : list_to_set_disj Γ φ2), φ = (Or φ1 φ2) -> False}).
+{
+  destruct φ. 4: { destruct (Hind Γ φ2)as [[Hp _]|Hf]. order_tac.
+  - left. do 3 eexists; eauto.
+  - right. intros ? ? Hp Heq. inversion Heq. subst. tauto.
+  }
+  all: right; auto with *.
+}
+destruct HOrR2 as [(φ1 & φ2 & Hp & Heq)| HOrR2 ].
+{ subst. left. eexists; trivial. apply OrR2, Hp. }
+assert(HBoxR : {φ' & {Hp : ( (list_to_set_disj Γ) φ' φ') & φ = ( φ')}} +
+                       { φ', (H : (list_to_set_disj Γ) φ' φ'), φ = ( φ') -> False}).
+{
+  destruct φ. 6: { destruct (Hind (( φ) :: map open_box Γ) φ)as [[Hp _]|Hf]. order_tac.
+  - left. do 2 eexists; eauto. l_tac. exact Hp.
+  - right. intros ? Hp Heq. inversion Heq. subst. apply Hf.
+     rw (symmetry (list_to_set_disj_env_add (map open_box Γ) ( φ'))) 0.
+     rewrite <- list_to_set_disj_open_boxes. exact Hp.
+  }
+  all: right; auto with *.
+}
+destruct HBoxR as [(φ' & Hp & Heq)| HBoxR ].
+{ left. subst. eexists; trivial. apply BoxR, Hp. }
+assert(Hempty: (Δ : env) φ,((Δ φ) = ) -> False).
+{
+  intros Δ θ Heq. assert (Hm:= multiplicity_empty θ).
+  unfold base.empty in *.
+  rewrite <- Heq, union_mult, singleton_mult_in in Hm by trivial. lia.
+}
+(* non invertible left rules *)
+assert(HImpLImp : Γ2 Γ1, Γ1 ++ Γ2 = Γ -> {φ1 & {φ2 & {φ3 &{H2312 : ((list_to_set_disj (rm (Implies (Implies φ1 φ2) φ3) Γ) (Implies φ2 φ3)) (Implies φ1 φ2))
+                                          & {H3: (list_to_set_disj (rm (Implies (Implies φ1 φ2) φ3) Γ) φ3 φ) & (Implies (Implies φ1 φ2) φ3) Γ2}}}}} +
+    { φ1 φ2 φ3 (_ : (list_to_set_disj (rm (Implies (Implies φ1 φ2) φ3) Γ) (Implies φ2 φ3)) (Implies φ1 φ2))
+                              (_: list_to_set_disj (rm (Implies (Implies φ1 φ2) φ3) Γ) φ3 φ),
+                               Implies (Implies φ1 φ2) φ3 Γ2 False}).
+{
+  induction Γ2 as [|θ Γ2]; intros Γ1 Heq.
+  - right. intros φ1 φ2 φ3 _ _ Hin. inversion Hin.
+  - assert(Heq' : (Γ1 ++ [θ]) ++ Γ2 = Γ) by (subst; auto with *).
+    destruct (IHΓ2 (Γ1 ++ [θ]) Heq') as [(φ1 & φ2 & φ3 & Hp1 & Hp2 & Hin)|Hf].
+   + left. repeat eexists; eauto. now right.
+   + destruct θ.
+        5: destruct θ1.
+        9 : {
+        destruct (Hind (Implies θ1_2 θ2 :: rm (Implies (Implies θ1_1 θ1_2) θ2) Γ) (Implies θ1_1 θ1_2))
+          as [[Hp1 _] | Hf'].
+        - order_tac. rewrite <- Permutation_middle. unfold rm.
+          destruct form_eq_dec; [|tauto]. order_tac.
+        - destruct (Hind (θ2 :: rm (Implies (Implies θ1_1 θ1_2) θ2) Γ) φ) as [[Hp2 _] | Hf''].
+          + order_tac. rewrite <- Permutation_middle. unfold rm.
+               destruct form_eq_dec; [|tauto]. order_tac.
+          + left. repeat eexists; try l_tac; eauto. ms.
+          + right; intros φ1 φ2 φ3 Hp1' Hp2 He; apply elem_of_list_In in He;
+               destruct He as [Heq''| Hin]; [|apply elem_of_list_In in Hin; eapply Hf; eauto].
+               inversion Heq''. subst. apply Hf''. peapply Hp2.
+      - right; intros φ1 φ2 φ3 Hp1 Hp2 He; apply elem_of_list_In in He;
+               destruct He as [Heq''| Hin]; [|apply elem_of_list_In in Hin; eapply Hf; eauto].
+               inversion Heq''. subst. apply Hf'. peapply Hp1.
+        }
+        all: (right; intros φ1 φ2 φ3 Hp1 Hp2 He; apply elem_of_list_In in He; destruct He as [Heq''| Hin];
+     [discriminate|apply elem_of_list_In in Hin; eapply Hf; eauto]).
+}
+destruct (HImpLImp Γ [] (app_nil_l _)) as [(φ1 & φ2 & φ3 & Hp1 & Hp2 & Hin)|HfImpl].
+{ apply elem_of_list_to_set_disj in Hin.
+  left. eexists; trivial. exhibit Hin 0. rw (list_to_set_disj_rm Γ(Implies (Implies φ1 φ2) φ3)) 1.
+  apply ImpLImp; assumption.
+}
+(* ImpBox *)
+assert(HImpLBox : Γ2 Γ1, Γ1 ++ Γ2 = Γ -> {φ1 & {φ2 & {H2312 : ((⊗(list_to_set_disj ((rm (Implies ( φ1) φ2) Γ))) φ1 φ2) φ1)
+                                          & {H3: (list_to_set_disj (rm (Implies ( φ1) φ2) Γ) φ2 φ) & (Implies ( φ1) φ2) Γ2}}}} +
+    { φ1 φ2 (_ : (( (list_to_set_disj ((rm (Implies ( φ1) φ2) Γ))) φ1 φ2) φ1))
+                              (_: list_to_set_disj (rm (Implies ( φ1) φ2) Γ) φ2 φ),
+                               Implies ( φ1) φ2 Γ2 False}).
+{
+  induction Γ2 as [|θ Γ2]; intros Γ1 Heq.
+  - right. intros φ1 φ2 _ _ Hin. inversion Hin.
+  - assert(Heq' : (Γ1 ++ [θ]) ++ Γ2 = Γ) by (subst; auto with *).
+    destruct (IHΓ2 (Γ1 ++ [θ]) Heq') as [(φ1 & φ2 & Hp1 & Hp2 & Hin)|Hf].
+   + left. repeat eexists; eauto. now right.
+   + destruct θ.
+        5: destruct θ1.
+        10 : {
+        destruct (Hind (θ2 :: (θ1) :: map open_box (rm (Implies ( θ1) θ2) Γ)) θ1)
+          as [[Hp1 _] | Hf'].
+        - order_tac. rewrite <- Permutation_middle. unfold rm.
+          destruct form_eq_dec; [|tauto]. order_tac.
+        - destruct (Hind (θ2 :: rm (Implies ( θ1) θ2) Γ) φ) as [[Hp2 _] | Hf''].
+          + order_tac. rewrite <- Permutation_middle. unfold rm.
+              destruct form_eq_dec; [|tauto]. order_tac.
+          + left. repeat eexists; repeat l_tac; eauto. ms.
+          + right; intros φ1 φ2 Hp1' Hp2 He; apply elem_of_list_In in He;
+               destruct He as [Heq''| Hin]; [|apply elem_of_list_In in Hin; eapply Hf; eauto].
+               inversion Heq''. subst. apply Hf''. peapply Hp2.
+      - right; intros φ1 φ2 Hp1 Hp2 He; apply elem_of_list_In in He;
+               destruct He as [Heq''| Hin]; [|apply elem_of_list_In in Hin; eapply Hf; eauto].
+               inversion Heq''. subst. apply Hf'.
+             (erewrite proper_Provable; [| |reflexivity]); [eapply Hp1|].
+             repeat rewrite <- ?list_to_set_disj_env_add, list_to_set_disj_open_boxes. trivial.
+        }
+        all: (right; intros φ1 φ2 Hp1 Hp2 He; apply elem_of_list_In in He; destruct He as [Heq''| Hin];
+     [discriminate|apply elem_of_list_In in Hin; eapply Hf; eauto]).
+}
+destruct (HImpLBox Γ [] (app_nil_l _)) as [(φ1 & φ2 & Hp1 & Hp2 & Hin)|HfImpLBox].
+{ apply elem_of_list_to_set_disj in Hin.
+  left. eexists; trivial. exhibit Hin 0. rw (list_to_set_disj_rm Γ(Implies ( φ1) φ2)) 1.
+  apply ImpBox; assumption.
+}
+clear Hind HImpLImp HImpLBox.
+right.
+Ltac eqt := match goal with | H : (_ ) = list_to_set_disj ?Γ |- _ =>
+  let Heq := fresh "Heq" in assert(Heq := H);
+  assert(Hinφ : φ Γ) by (apply elem_of_list_to_set_disj; setoid_rewrite <- H; ms);
+  apply env_equiv_eq, env_add_inv', symmetry in Heq; rewrite list_to_set_disj_rm in Heq end.
+intro Hp. inversion Hp; subst; try eqt; eauto 2.
+- eapply HAndR; eauto.
+- eapply HImpR; eauto.
+- eapply HImpLVar; eauto. apply elem_of_list_to_set_disj. setoid_rewrite <- H; ms.
+- eapply HfImpl; eauto.
+  + now rw Heq 1.
+  + now rw Heq 1.
+- eapply HfImpLBox; eauto.
+  + now rw (proper_open_boxes _ _ Heq) 2.
+  + now rw Heq 1.
+Defined.
+ +
+(* This function decides whether a sequent is provable *)
+Proposition Provable_dec Γ φ :
+  (exists _ : list_to_set_disj Γ φ, True) + (forall H : list_to_set_disj Γ φ, False).
+Proof.
+remember (Γ, φ) as pe.
+replace Γ with pe.1 by now inversion Heqpe.
+replace φ with pe.2 by now inversion Heqpe. clear Heqpe Γ φ.
+revert pe.
+refine (@well_founded_induction _ _ wf_pointed_order _ _).
+intros (Γ& φ) Hind; simpl.
+assert(Hind' := λ Γ' φ', Hind(Γ', φ')). simpl in Hind'. clear Hind. rename Hind' into Hind.
+ +
+case (decide ( Γ)); intro Hbot.
+{ left. eexists; trivial. apply elem_of_list_to_set_disj in Hbot. exhibit Hbot 0. apply ExFalso. }
+assert(HAndR : {φ1 & {φ2 & φ = (And φ1 φ2)}} + { φ1 φ2, φ (And φ1 φ2)}) by (destruct φ; eauto).
+destruct HAndR as [(φ1 & φ2 & Heq) | HAndR].
+{ subst.
+  destruct (Hind Γ φ1) as [Hp1| H1]. order_tac.
+  - destruct (Hind Γ φ2) as [Hp2| H2]. order_tac.
+    + left. destruct Hp1, Hp2. eexists; trivial. apply AndR; assumption.
+    + right. intro Hp. apply AndR_rev in Hp. tauto.
+  - right. intro Hp. apply AndR_rev in Hp. tauto.
+}
+assert(Hvar : {p & φ = Var p & Var p Γ} + { p, φ = Var p -> Var p Γ -> False}). {
+  destruct φ. 2-6: right; auto with *.
+  case (decide (Var v Γ)); intro Hin.
+  - left. exists v; trivial.
+  - right; auto with *. }
+destruct Hvar as [[p Heq Hp]|Hvar].
+{ subst. left. eexists; trivial. apply elem_of_list_to_set_disj in Hp. exhibit Hp 0. apply Atom. }
+assert(HAndL : {ψ1 & {ψ2 & (And ψ1 ψ2) Γ}} + { ψ1 ψ2, (And ψ1 ψ2) Γ -> False}). {
+  pose (fA := (fun θ => match θ with |And _ _ => true | _ => false end)).
+  destruct (exists_dec fA Γ) as [(θ & Hin & ) | Hf].
+  - left. subst fA. destruct θ. 3: { eexists. eexists. apply elem_of_list_In. eauto. }
+    all: auto with *.
+  - right. intros ψ1 ψ2 Hψ. rewrite elem_of_list_In in Hψ. apply Hf in Hψ. subst fA. simpl in Hψ. tauto.
+}
+destruct HAndL as [(ψ1 & ψ2 & Hin)|HAndL].
+{ destruct (Hind (ψ1 :: ψ2 :: rm (And ψ1 ψ2) Γ) φ) as [Hp' | Hf]. order_tac.
+  - left. destruct Hp' as [Hp' _]. eexists; trivial. apply elem_of_list_to_set_disj in Hin.
+    exhibit Hin 0.
+    rewrite (proper_Provable _ _ (equiv_disj_union_compat_r (list_to_set_disj_rm _ _)) _ _ eq_refl).
+    apply AndL. peapply Hp'.
+ - right. intro Hf'. apply Hf.
+   rw (symmetry (list_to_set_disj_env_add (ψ2 :: rm (And ψ1 ψ2) Γ) ψ1)) 0.
+   rw (symmetry (list_to_set_disj_env_add (rm (And ψ1 ψ2) Γ) ψ2)) 1.
+   exch 0. apply AndL_rev.
+   rw (symmetry (list_to_set_disj_rm Γ(And ψ1 ψ2))) 1.
+   apply elem_of_list_to_set_disj in Hin.
+   pose (difference_singleton (list_to_set_disj Γ) (And ψ1 ψ2)).
+   peapply Hf'.
+}
+assert(HImpR : {φ1 & {φ2 & φ = (Implies φ1 φ2)}} + { φ1 φ2, φ (Implies φ1 φ2)}) by (destruct φ; eauto).
+destruct HImpR as [(φ1 & φ2 & Heq) | HImpR].
+{ subst.
+  destruct (Hind (φ1 :: Γ) φ2) as [Hp1| H1]. order_tac.
+  - left. destruct Hp1 as [Hp1 _]. eexists; trivial. apply ImpR. peapply Hp1.
+  - right. intro Hf. apply H1. apply ImpR_rev in Hf. peapply Hf.
+}
+assert(HOrL : {ψ1 & {ψ2 & (Or ψ1 ψ2) Γ}} + { ψ1 ψ2, (Or ψ1 ψ2) Γ -> False}). {
+  pose (fA := (fun θ => match θ with |Or _ _ => true | _ => false end)).
+  destruct (exists_dec fA Γ) as [(θ & Hin & ) | Hf].
+  - left. subst fA. destruct θ. 4: { eexists. eexists. apply elem_of_list_In. eauto. }
+    all: auto with *.
+  - right. intros ψ1 ψ2 Hψ. rewrite elem_of_list_In in Hψ. apply Hf in Hψ. subst fA. simpl in Hψ. tauto.
+}
+destruct HOrL as [(ψ1 & ψ2 & Hin)|HOrL].
+{ apply elem_of_list_to_set_disj in Hin.
+  destruct (Hind (ψ1 :: rm (Or ψ1 ψ2) Γ) φ) as [Hp1| Hf]. order_tac.
+  - destruct (Hind (ψ2 :: rm (Or ψ1 ψ2) Γ) φ) as [Hp2| Hf]. order_tac.
+    + left. destruct Hp1 as [Hp1 _]. destruct Hp2 as [Hp2 _]. eexists; trivial. exhibit Hin 0.
+         rewrite (proper_Provable _ _ (equiv_disj_union_compat_r (list_to_set_disj_rm _ _)) _ _ eq_refl).
+         apply OrL. peapply Hp1. peapply Hp2.
+    + right; intro Hf'. assert(Hf'' :list_to_set_disj (rm (Or ψ1 ψ2) Γ) Or ψ1 ψ2 φ). {
+          rw (symmetry (list_to_set_disj_rm Γ(Or ψ1 ψ2))) 1.
+          pose (difference_singleton (list_to_set_disj Γ) (Or ψ1 ψ2)). peapply Hf'.
+         }
+        apply OrL_rev in Hf''. apply Hf. peapply Hf''.
+  - right; intro Hf'. assert(Hf'' :list_to_set_disj (rm (Or ψ1 ψ2) Γ) Or ψ1 ψ2 φ). {
+          rw (symmetry (list_to_set_disj_rm Γ(Or ψ1 ψ2))) 1.
+          pose (difference_singleton (list_to_set_disj Γ) (Or ψ1 ψ2)). peapply Hf'.
+         }
+        apply OrL_rev in Hf''. apply Hf. peapply Hf''.1.
+}
+assert(HImpLVar : {p & {ψ & Var p Γ /\ (Implies (Var p) ψ) Γ}} +
+                                 { p ψ, Var p Γ -> (Implies (Var p) ψ) Γ -> False}). {
+  pose (fIp :=λ p θ, match θ with | Implies (Var q) _ => if decide (p = q) then true else false | _ => false end).
+  pose (fp:= (fun θ => match θ with |Var p => if (exists_dec (fIp p) Γ) then true else false | _ => false end)).
+  destruct (exists_dec fp Γ) as [(θ & Hin & ) | Hf].
+  - left. subst fp. destruct θ. 2-6: auto with *.
+    case exists_dec as [(ψ &Hinψ & Hψ)|] in ; [|auto with *].
+    unfold fIp in Hψ. destruct ψ. 1-4, 6: auto with *.
+    destruct ψ1. 2-6: auto with *. case decide in Hψ; [|auto with *].
+    subst. apply elem_of_list_In in Hinψ, Hin.
+    do 2 eexists. split; eauto.
+  - right. intros p ψ Hp Hψ. rewrite elem_of_list_In in Hp, Hψ. apply Hf in Hp. subst fp fIp.
+    simpl in Hp. case exists_dec as [|Hf'] in Hp. auto with *.
+    apply (Hf' _ Hψ). rewrite decide_True; trivial. auto with *.
+}
+destruct HImpLVar as [[p [ψ [Hinp Hinψ]]]|HImpLVar].
+{ apply elem_of_list_to_set_disj in Hinp.
+  apply elem_of_list_to_set_disj in Hinψ.
+  assert(Hinp' : Var p (list_to_set_disj Γ {[Implies p ψ]} : env))
+    by (apply in_difference; [discriminate| assumption]).
+  destruct (Hind:: rm (Implies (Var p) ψ) Γ) φ) as [Hp|Hf]. order_tac.
+  - left. destruct Hp as [Hp _]. eexists; trivial. exhibit Hinψ 0.
+     exhibit Hinp' 1. apply ImpLVar.
+     rw (symmetry (difference_singleton (list_to_set_disj Γ {[Implies p ψ]}) (Var p) Hinp')) 1.
+     rw (list_to_set_disj_rm Γ(Implies p ψ)) 1. l_tac. exact Hp.
+  - right. intro Hf'. apply Hf.
+     rw (symmetry (list_to_set_disj_env_add (rm (Implies p ψ) Γ) ψ)) 0.
+     rw (symmetry (list_to_set_disj_rm Γ(Implies p ψ))) 1.
+     exhibit Hinp' 1. apply ImpLVar_rev.
+     rw (symmetry (difference_singleton _ _ Hinp')) 1.
+     rw (symmetry (difference_singleton _ _ Hinψ)) 0.
+     exact Hf'.
+}
+assert(HImpLAnd : {φ1 & {φ2 & {φ3 & (Implies (And φ1 φ2) φ3) Γ}}} +
+                                 { φ1 φ2 φ3, (Implies (And φ1 φ2) φ3) Γ -> False}). {
+    pose (fII := (fun θ => match θ with |Implies (And _ _) _ => true | _ => false end)).
+   destruct (exists_dec fII Γ) as [(θ & Hin & ) | Hf].
+    - left. subst fII. destruct θ. 1-4, 6: auto with *.
+      destruct θ1. 1-2,4-6: auto with *. do 3 eexists; apply elem_of_list_In; eauto.
+    - right. intros ψ1 ψ2 ψ3 Hψ. rewrite elem_of_list_In in Hψ. apply Hf in Hψ. subst fII. simpl in Hψ. tauto.
+}
+destruct HImpLAnd as [(φ1&φ2&φ3&Hin)|HImpLAnd].
+{ apply elem_of_list_to_set_disj in Hin.
+  destruct (Hind (Implies φ1 (Implies φ2 φ3) :: rm (Implies (And φ1 φ2) φ3) Γ) φ) as [Hp|Hf]. order_tac.
+  - left. destruct Hp as [Hp _]. eexists; trivial. exhibit Hin 0. apply ImpLAnd.
+     rw (list_to_set_disj_rm Γ(Implies (And φ1 φ2) φ3)) 1. l_tac. exact Hp.
+  - right. intro Hf'. apply Hf.
+     rw (symmetry (list_to_set_disj_env_add (rm (Implies (And φ1 φ2) φ3) Γ) (Implies φ1 (Implies φ2 φ3)))) 0.
+     rw (symmetry (list_to_set_disj_rm Γ(Implies (And φ1 φ2) φ3))) 1.
+     apply ImpLAnd_rev.
+     rw (symmetry (difference_singleton _ _ Hin)) 0. exact Hf'.
+}
+assert(HImpLOr : {φ1 & {φ2 & {φ3 & (Implies (Or φ1 φ2) φ3) Γ}}} +
+                                 { φ1 φ2 φ3, (Implies (Or φ1 φ2) φ3) Γ -> False}). {
+    pose (fII := (fun θ => match θ with |Implies (Or _ _) _ => true | _ => false end)).
+   destruct (exists_dec fII Γ) as [(θ & Hin & ) | Hf].
+    - left. subst fII. destruct θ. 1-4, 6: auto with *.
+      destruct θ1. 1-3, 5-6: auto with *. do 3 eexists; apply elem_of_list_In; eauto.
+    - right. intros ψ1 ψ2 ψ3 Hψ. rewrite elem_of_list_In in Hψ. apply Hf in Hψ. subst fII. simpl in Hψ. tauto.
+}
+destruct HImpLOr as [(φ1&φ2&φ3&Hin)|HImpLOr].
+{ apply elem_of_list_to_set_disj in Hin.
+  destruct (Hind (Implies φ2 φ3 :: Implies φ1 φ3 :: rm (Implies (Or φ1 φ2) φ3) Γ) φ) as [Hp|Hf]. order_tac.
+  - left. destruct Hp as [Hp _]. eexists; trivial. exhibit Hin 0. apply ImpLOr.
+     rw (list_to_set_disj_rm Γ(Implies (Or φ1 φ2) φ3)) 2. do 2 l_tac. exact Hp.
+  - right. intro Hf'. apply Hf.
+     rw (symmetry (list_to_set_disj_env_add ( Implies φ1 φ3 :: rm (Implies (Or φ1 φ2) φ3) Γ) (Implies φ2 φ3))) 0.
+     rw (symmetry (list_to_set_disj_env_add (rm (Implies (Or φ1 φ2) φ3) Γ) (Implies φ1 φ3))) 1.
+     rw (symmetry (list_to_set_disj_rm Γ(Implies (Or φ1 φ2) φ3))) 2.
+     apply ImpLOr_rev.
+     rw (symmetry (difference_singleton _ _ Hin)) 0. exact Hf'.
+}
+(* non invertible right rules *)
+assert(HOrR1 : {φ1 & {φ2 & (exists (_ : list_to_set_disj Γ φ1), φ = (Or φ1 φ2))}} +
+                       { φ1 φ2, (H : list_to_set_disj Γ φ1), φ = (Or φ1 φ2) -> False}).
+{
+  destruct φ. 4: { destruct (Hind Γ φ1)as [Hp|Hf]. order_tac.
+  - left. do 2 eexists. destruct Hp as [Hp _]. eexists; eauto.
+  - right. intros ? ? Hp Heq. inversion Heq. subst. tauto.
+  }
+  all: right; auto with *.
+}
+destruct HOrR1 as [(φ1 & φ2 & Hp)| HOrR1].
+{ left. destruct Hp as (Hp & Heq). subst. eexists; trivial. apply OrR1, Hp. }
+assert(HOrR2 : {φ1 & {φ2 & exists (_ : list_to_set_disj Γ φ2), φ = (Or φ1 φ2)}} +
+                       { φ1 φ2, (H : list_to_set_disj Γ φ2), φ = (Or φ1 φ2) -> False}).
+{
+  destruct φ. 4: { destruct (Hind Γ φ2)as [Hp|Hf]. order_tac.
+  - left. do 2 eexists. destruct Hp as [Hp _]; eauto.
+  - right. intros ? ? Hp Heq. inversion Heq. subst. tauto.
+  }
+  all: right; auto with *.
+}
+destruct HOrR2 as [(φ1 & φ2 & Hp)| HOrR2 ].
+{ left. destruct Hp as [Hp Heq]. subst. eexists; trivial. apply OrR2, Hp. }
+assert(HBoxR : {φ' & exists (_ : ( (list_to_set_disj Γ) φ' φ')), φ = ( φ')} +
+                       { φ', (H : (list_to_set_disj Γ) φ' φ'), φ = ( φ') -> False}).
+{
+  destruct φ. 6: { destruct (Hind (( φ) :: map open_box Γ) φ)as [Hp|Hf]. order_tac.
+  - left. eexists. destruct Hp as [Hp _]. eexists; eauto. l_tac. exact Hp.
+  - right. intros ? Hp Heq. inversion Heq. subst. apply Hf.
+     rw (symmetry (list_to_set_disj_env_add (map open_box Γ) ( φ'))) 0.
+     rewrite <- list_to_set_disj_open_boxes. exact Hp.
+  }
+  all: right; auto with *.
+}
+destruct HBoxR as [(φ' & Hp)| HBoxR ].
+{ left. destruct Hp as [Hp Heq]. subst. eexists; trivial. apply BoxR, Hp. }
+assert(Hempty: (Δ : env) φ,((Δ φ) = ) -> False).
+{
+  intros Δ θ Heq. assert (Hm:= multiplicity_empty θ).
+  unfold base.empty in *.
+  rewrite <- Heq, union_mult, singleton_mult_in in Hm by trivial. lia.
+}
+(* non invertible left rules *)
+assert(HImpLImp : Γ2 Γ1, Γ1 ++ Γ2 = Γ -> {φ1 & {φ2 & {φ3 & exists (_ : (list_to_set_disj (rm (Implies (Implies φ1 φ2) φ3) Γ) (Implies φ2 φ3)) (Implies φ1 φ2)),
+                                          exists (_: list_to_set_disj (rm (Implies (Implies φ1 φ2) φ3) Γ) φ3 φ), (Implies (Implies φ1 φ2) φ3) Γ2}}} +
+    { φ1 φ2 φ3 (_ : (list_to_set_disj (rm (Implies (Implies φ1 φ2) φ3) Γ) (Implies φ2 φ3)) (Implies φ1 φ2))
+                              (_: list_to_set_disj (rm (Implies (Implies φ1 φ2) φ3) Γ) φ3 φ),
+                               Implies (Implies φ1 φ2) φ3 Γ2 False}).
+{
+  induction Γ2 as [|θ Γ2]; intros Γ1 Heq.
+  - right. intros φ1 φ2 φ3 _ _ Hin. inversion Hin.
+  - assert(Heq' : (Γ1 ++ [θ]) ++ Γ2 = Γ) by (subst; auto with *).
+    destruct (IHΓ2 (Γ1 ++ [θ]) Heq') as [(φ1 & φ2 & φ3 & Hp)|Hf].
+   + left. do 3 eexists. destruct Hp as ( Hp1 & Hp2 & Hin). do 2 (eexists; eauto). now right.
+   + destruct θ.
+        5: destruct θ1.
+        9 : {
+        destruct (Hind (Implies θ1_2 θ2 :: rm (Implies (Implies θ1_1 θ1_2) θ2) Γ) (Implies θ1_1 θ1_2))
+          as [Hp1| Hf'].
+        - order_tac. rewrite <- Permutation_middle. unfold rm.
+          destruct form_eq_dec; [|tauto]. order_tac.
+        - destruct (Hind (θ2 :: rm (Implies (Implies θ1_1 θ1_2) θ2) Γ) φ) as [Hp2| Hf''].
+          + order_tac. rewrite <- Permutation_middle. unfold rm.
+               destruct form_eq_dec; [|tauto]. order_tac.
+          + left. do 3 eexists. destruct Hp1 as [Hp1 _]. destruct Hp2 as [Hp2 _].
+              eexists; try l_tac; eauto. ms.
+          + right; intros φ1 φ2 φ3 Hp1' Hp2 He; apply elem_of_list_In in He;
+               destruct He as [Heq''| Hin]; [|apply elem_of_list_In in Hin; eapply Hf; eauto].
+               inversion Heq''. subst. apply Hf''. peapply Hp2.
+      - right; intros φ1 φ2 φ3 Hp1 Hp2 He; apply elem_of_list_In in He;
+               destruct He as [Heq''| Hin]; [|apply elem_of_list_In in Hin; eapply Hf; eauto].
+               inversion Heq''. subst. apply Hf'. peapply Hp1.
+        }
+        all: (right; intros φ1 φ2 φ3 Hp1 Hp2 He; apply elem_of_list_In in He; destruct He as [Heq''| Hin];
+     [discriminate|apply elem_of_list_In in Hin; eapply Hf; eauto]).
+}
+destruct (HImpLImp Γ [] (app_nil_l _)) as [(φ1 & φ2 & φ3 & Hp1)|HfImpl].
+{ left. destruct Hp1 as (Hp1 & Hp2 & Hin). eexists; trivial.
+  apply elem_of_list_to_set_disj in Hin. exhibit Hin 0.
+  rw (list_to_set_disj_rm Γ(Implies (Implies φ1 φ2) φ3)) 1.
+  apply ImpLImp; assumption.
+}
+(* ImpBox *)
+assert(HImpLBox : Γ2 Γ1, Γ1 ++ Γ2 = Γ -> {φ1 & {φ2 & exists (_ : (⊗(list_to_set_disj ((rm (Implies ( φ1) φ2) Γ))) φ1 φ2) φ1),
+                                          exists (_ : list_to_set_disj (rm (Implies ( φ1) φ2) Γ) φ2 φ),
+                                          (Implies ( φ1) φ2) Γ2}} +
+    { φ1 φ2 (_ : (( (list_to_set_disj ((rm (Implies ( φ1) φ2) Γ))) φ1 φ2) φ1))
+                              (_: list_to_set_disj (rm (Implies ( φ1) φ2) Γ) φ2 φ),
+                               Implies ( φ1) φ2 Γ2 False}).
+{
+  induction Γ2 as [|θ Γ2]; intros Γ1 Heq.
+  - right. intros φ1 φ2 _ _ Hin. inversion Hin.
+  - assert(Heq' : (Γ1 ++ [θ]) ++ Γ2 = Γ) by (subst; auto with *).
+    destruct (IHΓ2 (Γ1 ++ [θ]) Heq') as [(φ1 & φ2 & Hp1)|Hf].
+   + left. do 2 eexists. destruct Hp1 as (Hp1 & Hp2 & Hin). do 2 (eexists; eauto). now right.
+   + destruct θ.
+        5: destruct θ1.
+        10 : {
+        destruct (Hind (θ2 :: (θ1) :: map open_box (rm (Implies ( θ1) θ2) Γ)) θ1)
+          as [Hp1|Hf'].
+        - order_tac. rewrite <- Permutation_middle. unfold rm.
+          destruct form_eq_dec; [|tauto]. order_tac.
+        - destruct (Hind (θ2 :: rm (Implies ( θ1) θ2) Γ) φ) as [Hp2| Hf''].
+          + order_tac. rewrite <- Permutation_middle. unfold rm.
+              destruct form_eq_dec; [|tauto]. order_tac.
+          + left. do 2 eexists. destruct Hp1 as [Hp1 _]. destruct Hp2 as [Hp2 _].
+               repeat eexists; repeat l_tac; eauto. ms.
+          + right; intros φ1 φ2 Hp1' Hp2 He; apply elem_of_list_In in He;
+               destruct He as [Heq''| Hin]; [|apply elem_of_list_In in Hin; eapply Hf; eauto].
+               inversion Heq''. subst. apply Hf''. peapply Hp2.
+      - right; intros φ1 φ2 Hp1 Hp2 He; apply elem_of_list_In in He;
+               destruct He as [Heq''| Hin]; [|apply elem_of_list_In in Hin; eapply Hf; eauto].
+               inversion Heq''. subst. apply Hf'.
+             (erewrite proper_Provable; [| |reflexivity]); [eapply Hp1|].
+             repeat rewrite <- ?list_to_set_disj_env_add, list_to_set_disj_open_boxes. trivial.
+        }
+        all: (right; intros φ1 φ2 Hp1 Hp2 He; apply elem_of_list_In in He; destruct He as [Heq''| Hin];
+     [discriminate|apply elem_of_list_In in Hin; eapply Hf; eauto]).
+}
+destruct (HImpLBox Γ [] (app_nil_l _)) as [(φ1 & φ2 & Hp1)|HfImpLBox].
+{ left. destruct Hp1 as (Hp1 & Hp2 & Hin). eexists; trivial.
+  apply elem_of_list_to_set_disj in Hin. exhibit Hin 0.
+  rw (list_to_set_disj_rm Γ(Implies ( φ1) φ2)) 1.
+  apply ImpBox; assumption.
+}
+clear Hind HImpLImp HImpLBox.
+right.
+intro Hp. inversion Hp; subst; try eqt; eauto 2.
+- eapply HAndR; eauto.
+- eapply HImpR; eauto.
+- eapply HImpLVar; eauto. apply elem_of_list_to_set_disj. setoid_rewrite <- H; ms.
+- eapply HfImpl; eauto.
+  + now rw Heq 1.
+  + now rw Heq 1.
+- eapply HfImpLBox; eauto.
+  + now rw (proper_open_boxes _ _ Heq) 2.
+  + now rw Heq 1.
+Defined.
+
+
+ +
+ + + diff --git a/ISL.Environments.html b/ISL.Environments.html new file mode 100644 index 0000000..b49a622 --- /dev/null +++ b/ISL.Environments.html @@ -0,0 +1,874 @@ + + + + + + + + + + + + + +
+
+

ISL.Environments

+ +
+
+ +
+

Overview: Environments

+ + +
+ + An environment is a multiset of formulas. We rely on stdpp multisets + mostly for their powerful multiset equivalence tactic. +
+ + Notion of wellfoundedness +
+
+Require Import Coq.Program.Wf.
+ +
+
+ +
+Stdpp implementation of multisets +
+
+Require Export stdpp.gmultiset.
+ +
+
+ +
+Our propositional formulas, including their countability. +
+
+Require Export ISL.Formulas.
+ +
+
+ +
+An environment is defined as a finite multiset of formulas +(in the sense of the stdpp library). +This requires decidable equality and countability of the underlying set. +
+
+Definition env := @gmultiset form form_eq_dec form_count.
+ +
+Global Instance singleton : Singleton form env := gmultiset_singleton.
+Global Instance singletonMS : SingletonMS form env := base.singleton.
+ +
+Global Hint Unfold mult empty singleton union intersection env : mset.
+(* useful notations :
+  { x } : singleton
+      ⊎ : disjoint union
+   \: difference (setminus)
+   { x; y; } union of singletons
+   {[+ x; y; +]} *disjoint* union of singletons
+      ⊂@ : include
+*)

+ +
+Definition empty := : env.
+ +
+Ltac ms :=
+  unfold base.singletonMS, singletonMS, base.empty, gmultiset_empty in *;
+  autounfold with mset in *;
+  autounfold with mset; multiset_solver.
+ +
+Global Instance proper_elem_of : Proper ((=) ==> (≡@{env}) ==> (fun x y => x <-> y)) elem_of.
+Proof. intros Γ Γ' Heq φ φ' Heq'. ms. Qed.
+ +
+Global Instance proper_disj_union : Proper ((≡@{env}) ==> (≡@{env}) ==> (≡@{env})) disj_union.
+Proof. intros Γ Γ' Heq Δ Δ' Heq'. ms. Qed.
+ +
+Global Notation "Γ • φ" := (disj_union Γ (base.singletonMS φ)) (at level 105, φ at level 85, left associativity).
+ +
+Lemma elements_env_add (Γ : env) φ : elements(Γ φ) ≡ₚ φ :: elements Γ.
+Proof.
+rewrite (gmultiset_elements_disj_union Γ).
+setoid_rewrite (gmultiset_elements_singleton φ).
+symmetry. apply Permutation_cons_append.
+Qed.
+ +
+
+ +
+

Multiset utilities

+ +
+
+ +
+Lemma multeq_meq (M N: env) : (forall x, multiplicity x M = multiplicity x N) -> M N.
+  Proof. multiset_solver. Qed.
+ +
+Lemma diff_mult (M N : env) (x : form):
+  multiplicity x (M N) = (multiplicity x M - multiplicity x N)%nat.
+Proof. apply multiplicity_difference. Qed.
+ +
+Lemma union_mult M N (x : form) :
+  multiplicity x (M N) = (multiplicity x M + multiplicity x N)%nat.
+Proof. apply multiplicity_disj_union. Qed.
+ +
+Lemma singleton_mult_in (x y: form): x = y -> multiplicity x {[y]} = 1.
+Proof.
+  intro Heq. rewrite Heq. apply multiplicity_singleton. Qed.
+ +
+Lemma singleton_mult_notin (x y: form): x <> y -> multiplicity x {[y]} = 0.
+Proof. apply multiplicity_singleton_ne. Qed.
+ +
+(* Two useful basic facts about multisets containing (or not) certain elements. *)
+Lemma env_replace {Γ : env} φ {ψ : form}:
+  (ψ Γ) -> (Γ φ) {[ψ]} (Γ {[ψ]} φ).
+Proof.
+intro Hin. apply multeq_meq. intros θ.
+rewrite diff_mult, union_mult, union_mult, diff_mult.
+apply PeanoNat.Nat.add_sub_swap.
+case (decide (θ = ψ)); intro; subst.
+- now rewrite singleton_mult_in.
+- rewrite singleton_mult_notin; trivial. lia.
+Qed.
+ +
+Lemma diff_not_in (Γ : env) φ : φ Γ -> Γ {[φ]} Γ.
+Proof.
+intro Hf. apply multeq_meq. intros ψ.
+rewrite diff_mult. rewrite (elem_of_multiplicity φ Γ) in Hf.
+unfold mult.
+case (decide= ψ)).
+- intro; subst. lia.
+- intro Hneq. setoid_rewrite (multiplicity_singleton_ne ψ φ); trivial. lia.
+  auto.
+Qed.
+ +
+Lemma env_add_remove : (Γ: env) (φ : form), (Γ φ) {[φ]} =Γ.
+Proof. intros; ms. Qed.
+ +
+
+ +
+

Conjunction, disjunction, and implication

+ In the construction of propositional quantifiers, we often want to take the conjunction, disjunction, or implication of a (multi)set of formulas. The following results give some small optimizations of this process, by reducing "obvious" conjunctions such as ⊤ ∧ ϕ, ⊥ ∧ ϕ, etc. +
+
+ +
+Definition irreducible (Γ : env) :=
+  ( p φ, (Var p φ) Γ -> ¬ Var p Γ) /\
+  ¬ Γ /\
+   φ ψ, ¬ (φ ψ) Γ /\ ¬ (φ ψ) Γ.
+ +
+Definition is_double_negation φ ψ := φ = ¬ ¬ ψ.
+Global Instance decidable_is_double_negation φ ψ : Decision (is_double_negation φ ψ) := decide= ¬ ¬ ψ).
+ +
+Definition is_implication φ ψ := exists θ, φ = (θ ψ).
+Global Instance decidable_is_implication φ ψ : Decision (is_implication φ ψ).
+Proof.
+unfold is_implication.
+destruct φ; try solve[right; intros [θ ]; discriminate].
+case (decide (φ2 = ψ)).
+- intro; subst. left. eexists; reflexivity.
+- intro. right; intros [θ ]; inversion . subst. tauto.
+Defined.
+ +
+Definition is_negation φ ψ := φ = ¬ ψ.
+Global Instance decidable_is_negation φ ψ : Decision (is_negation φ ψ) := decide= ¬ ψ).
+ +
+(* Checks "obvious" entailment conditions. If φ ⊢ ψ "obviously" then it returns Lt,
+if ψ ⊢ φ "obviously" then it returns Gt. Eq corresponds to the unknown category, 
+this means that we don't have enough information to determine a possible entailment. *)

+Fixpoint obviously_smaller (φ : form) (ψ : form) :=
+match (φ, ψ) with
+  |(Bot, _) => Lt
+  |(_, Bot) => Gt
+  |(Bot _, _) => Gt
+  |(_, Bot _) => Lt
+  |(φ ψ, ϴ) => match (obviously_smaller φ ϴ, obviously_smaller ψ ϴ) with
+      | (Lt, _) | (_, Lt) => Lt
+      | (Gt, Gt) => Gt
+      | _ => Eq
+      end
+  |(φ ψ, ϴ) => match (obviously_smaller φ ϴ, obviously_smaller ψ ϴ) with
+      | (Gt, _) | (_, Gt) => Gt
+      | (Lt, Lt) => Lt
+      | _ => Eq
+      end
+  |(φ, ψ) => if decide (φ = ψ) then Lt else
+                       if decide (is_double_negation φ ψ) then Gt else
+                       if decide (is_double_negation ψ φ) then Lt else
+                       if decide (is_implication φ ψ) then Gt else
+                       if decide (is_implication ψ φ ) then Lt else
+                       Eq
+end.
+ +
+Definition choose_conj φ ψ :=
+match obviously_smaller φ ψ with
+  | Lt => φ
+  | Gt => ψ
+  | Eq => φ ψ
end.
+ +
+Definition make_conj φ ψ :=
+match ψ with
+  | ψ1 ψ2 =>
+      match obviously_smaller φ ψ1 with
+      | Lt => φ ψ2
+      | Gt => ψ1 ψ2
+      | Eq => φ (ψ1 ψ2)
+      end
+  | ψ1 ψ2 =>
+      if decide (obviously_smaller φ ψ1 = Lt ) then φ
+      else if decide (obviously_smaller φ ψ2 = Lt ) then φ
+      else choose_conj φ (ψ1 ψ2)
+  | ψ1 ψ2 =>
+      if decide (obviously_smaller φ ψ1 = Lt) then choose_conj φ ψ2
+      else choose_conj φ ψ
+  | ψ => match φ with
+      | φ1 φ2 =>
+          if decide (obviously_smaller ψ φ1 = Lt)
+          then choose_conj φ2 ψ
+          else choose_conj φ ψ
+      | _ => choose_conj φ ψ
+       end
+end.
+ +
+Infix "⊼" := make_conj (at level 60).
+ +
+Lemma occurs_in_make_conj v φ ψ : occurs_in v (φ ψ) -> occurs_in v φ \/ occurs_in v ψ.
+Proof.
+generalize ψ.
+induction φ; intro ψ0; destruct ψ0;
+intro H; unfold make_conj in H; unfold choose_conj in H;
+repeat match goal with
+    | H: occurs_in _ (if ?cond then _ else _) |- _ => case decide in H
+    | H: occurs_in _ (match ?x with _ => _ end) |- _ => destruct x
+    | |- _ => simpl; simpl in H; tauto
+end.
+Qed.
+ +
+Definition choose_disj φ ψ :=
+match obviously_smaller φ ψ with
+  | Lt => ψ
+  | Gt => φ
+  | Eq =>match obviously_smaller ψ φ with
+    | Lt => φ
+    | Gt => ψ
+    | Eq => φ ψ
+    end
end.
+ +
+Definition make_disj φ ψ :=
+match ψ with
+  | ψ1 ψ2 =>
+      match obviously_smaller φ ψ1 with
+      | Lt => ψ1 ψ2
+      | Gt => φ ψ2
+      | Eq => φ (ψ1 ψ2)
+      end
+  | ψ1 ψ2 =>
+      if decide (obviously_smaller φ ψ1 = Gt ) then φ
+      else if decide (obviously_smaller φ ψ2 = Gt ) then φ
+      else choose_disj φ (ψ1 ψ2)
+  |_ => choose_disj φ ψ
+end.
+ +
+Infix "⊻" := make_disj (at level 65).
+ +
+Lemma occurs_in_make_disj v φ ψ : occurs_in v (φ ψ) -> occurs_in v φ occurs_in v ψ.
+Proof.
+generalize ψ.
+induction φ; intro ψ0; destruct ψ0;
+intro H; unfold make_disj in H; unfold choose_disj in H;
+repeat match goal with
+    | H: occurs_in _ (if ?cond then _ else _) |- _ => case decide in H
+    | H: occurs_in _ (match ?x with _ => _ end) |- _ => destruct x
+    | |- _ => simpl; simpl in H; tauto
+end.
+Qed.
+ +
+(* "lazy" implication, which produces a potentially simpler, equivalent formula *)
+ +
+(* Same as `simp_ors` but for nested implications. *)
+Fixpoint make_impl φ ψ :=
+match ψ with
+  |(ψ1 ψ2) => make_impl (make_conj φ ψ1) ψ2
+  |_ =>
+     if decide (obviously_smaller φ ψ = Lt) then
+     else if decide (obviously_smaller φ = Lt) then
+     else if decide (obviously_smaller ψ = Gt) then
+     else if decide (obviously_smaller φ = Gt) then ψ
+     else if decide (obviously_smaller ψ = Lt) then ¬φ
+     else if decide (is_negation φ ψ) then ¬φ
+     else if decide (is_negation ψ φ) then ψ
+    else φ ψ
+end.
+ +
+Infix "⇢" := make_impl (at level 66).
+ +
+Lemma occurs_in_make_impl v x y : occurs_in v (x y) -> occurs_in v x occurs_in v y.
+Proof.
+generalize x.
+induction y; intro ψ0;
+intro H; unfold make_impl in H; fold make_impl in H;
+repeat match goal with
+    | H: occurs_in _ (if ?cond then _ else _) |- _ => case decide in H
+    | H: occurs_in _ (match ?x with _ => _ end) |- _ => destruct x
+    | |- _ => simpl; simpl in H; tauto
+end.
+apply IHy2 in H. destruct H as [H|H]; [ apply occurs_in_make_conj in H|]; simpl; tauto.
+Qed.
+ +
+Lemma occurs_in_make_impl2 v x y z: occurs_in v (x (y z)) -> occurs_in v x occurs_in v y occurs_in v z.
+Proof.
+intro H. apply occurs_in_make_impl in H. destruct H as [H|H]; try tauto.
+apply occurs_in_make_impl in H. tauto.
+Qed.
+ +
+
+ +
+To be noted: we remove duplicates first +
+
+Definition conjunction l := foldl make_conj ( ) (nodup form_eq_dec l).
+Notation "⋀" := conjunction.
+ +
+Definition disjunction l := foldl make_disj (nodup form_eq_dec l).
+Notation "⋁" := disjunction.
+ +
+Lemma variables_conjunction x l : occurs_in x ( l) -> exists φ, φ l /\ occurs_in x φ.
+Proof.
+unfold conjunction.
+assert (Hcut : forall ψ, occurs_in x (foldl make_conj ψ (nodup form_eq_dec l))
+  -> occurs_in x ψ \/ ( φ : form, (φ l occurs_in x φ)%type)).
+{
+induction l; simpl.
+- tauto.
+- intros ψ Hocc.
+  case in_dec in Hocc; apply IHl in Hocc; simpl in Hocc;
+  destruct Hocc as [Hx|(φ&Hin&Hx)]; try tauto.
+  + right. exists φ. split; auto with *.
+  + apply occurs_in_make_conj in Hx; destruct Hx as [Hx|Hx]; auto with *.
+      right. exists a. auto with *.
+  + right. exists φ. split; auto with *.
+}
+intro Hocc. apply Hcut in Hocc. simpl in Hocc. tauto.
+Qed.
+ +
+Lemma variables_disjunction x l : occurs_in x ( l) -> exists φ, φ l /\ occurs_in x φ.
+Proof.
+unfold disjunction.
+assert (Hcut : forall ψ, occurs_in x (foldl make_disj ψ (nodup form_eq_dec l))
+  -> occurs_in x ψ \/ ( φ : form, (φ l occurs_in x φ)%type)).
+{
+induction l; simpl.
+- tauto.
+- intros ψ Hocc.
+  case in_dec in Hocc; apply IHl in Hocc; simpl in Hocc;
+  destruct Hocc as [Hx|(φ&Hin&Hx)]; try tauto.
+  + right. exists φ. split; auto with *.
+  + apply occurs_in_make_disj in Hx; destruct Hx as [Hx|Hx]; auto with *.
+      right. exists a. auto with *.
+  + right. exists φ. split; auto with *.
+}
+intro Hocc. apply Hcut in Hocc. simpl in Hocc. tauto.
+Qed.
+ +
+
+ +
+

A dependent version of `map`

+ +
+
+(* a dependent map on lists, with knowledge that we are on that list *)
+(* should work with any set-like type *)
+ +
+Program Fixpoint in_map_aux {A : Type} (Γ : list form) (f : forall φ, (φ Γ) -> A)
Γ' (HΓ' : Γ' Γ) : list A:=
+match Γ' with
+| [] => []
+| a::Γ' => f a _ :: in_map_aux Γ f Γ' _
+end.
+Next Obligation.
+intros. auto with *.
+Qed.
+Next Obligation. auto with *. Qed.
+ +
+Definition in_map {A : Type} (Γ : list form)
+  (f : forall φ, (φ Γ) -> A) : list A :=
+  in_map_aux Γ f Γ (reflexivity _).
+ +
+(* This generalises to any type. decidability of equality over this type is necessary for a result in "Type" *)
+Lemma in_in_map {A : Type} {HD : forall a b : A, Decision (a = b)}
+  Γ (f : forall φ, (φ Γ) -> A) ψ :
+  ψ (in_map Γ f) -> {ψ0 & {Hin | ψ = f ψ0 Hin}}.
+Proof.
+unfold in_map.
+assert(Hcut : forall Γ' (HΓ' : Γ' Γ), ψ in_map_aux Γ f Γ' HΓ'
+   {ψ0 & {Hin : ψ0 Γ | ψ = f ψ0 Hin}}); [|apply Hcut].
+induction Γ'; simpl; intros HΓ' Hin.
+- contradict Hin. auto. now rewrite elem_of_nil.
+- match goal with | H : ψ ?a :: (in_map_aux _ _ _ ?HΓ'') |- _ =>
+  case (decide= a)); [| pose (myHΓ' := HΓ'')] end.
+  + intro Heq; subst. exists a. eexists. reflexivity.
+  + intro Hneq. apply (IHΓ' myHΓ').
+    apply elem_of_cons in Hin. tauto.
+Qed.
+ +
+Local Definition in_subset {Γ : env} {Γ'} (Hi : Γ' elements Γ) {ψ0} (Hin : ψ0 Γ') : ψ0 Γ.
+Proof. apply gmultiset_elem_of_elements,Hi, Hin. Defined.
+ +
+(* converse *)
+(* we require proof irrelevance for the mapped function *)
+Lemma in_map_in {A : Type} {HD : forall a b : A, Decision (a = b)}
+  {Γ} {f : forall φ, (φ Γ) -> A} {ψ0} (Hin : ψ0 Γ):
+  {Hin' | f ψ0 Hin' (in_map Γ f)}.
+Proof.
+unfold in_map.
+assert(Hcut : forall Γ' (HΓ' : Γ' Γ) ψ0 (Hin : In ψ0 Γ'),
+  {Hin' | f ψ0 Hin' in_map_aux Γ f Γ' HΓ'}).
+- induction Γ'; simpl; intros HΓ' ψ' Hin'; [auto with *|].
+  case (decide (ψ' = a)).
+  + intro; subst a. eexists. left.
+  + intro Hneq. assert (Hin'' : In ψ' Γ') by (destruct Hin'; subst; tauto).
+      pose (Hincl := (in_map_aux_obligation_2 Γ (a :: Γ') HΓ' a Γ' eq_refl)).
+      destruct (IHΓ' Hincl ψ' Hin'') as [Hin0 Hprop].
+      eexists. right. apply Hprop.
+- destruct (Hcut Γ (reflexivity Γ) ψ0) as [Hin' Hprop].
+  + auto. now apply elem_of_list_In.
+  + exists Hin'. exact Hprop.
+Qed.
+ +
+Lemma in_map_empty A f : @in_map A [] f = [].
+Proof. auto with *. Qed.
+ +
+Lemma in_map_ext {A} Δ f g:
+  (forall φ H, f φ H = g φ H) -> @in_map A Δ f = in_map Δ g.
+Proof.
+  intros Heq.
+  unfold in_map.
+  assert(forall Γ , in_map_aux Δ f Γ = in_map_aux Δ g Γ ); [|trivial].
+  induction Γ; intro .
+  - trivial.
+  - simpl. now rewrite Heq, IHΓ.
+Qed.
+ +
+Lemma difference_singleton (Δ: env) (φ : form): φ Δ -> Δ ((Δ {[φ]}) φ).
+Proof.
+intro Hin. rewrite (gmultiset_disj_union_difference {[φ]}) at 1. ms.
+now apply gmultiset_singleton_subseteq_l.
+Qed.
+ +
+Lemma env_in_add (Δ : env) ϕ φ: φ (Δ ϕ) <-> φ = ϕ \/ φ Δ.
+Proof.
+rewrite (gmultiset_elem_of_disj_union Δ), gmultiset_elem_of_singleton.
+tauto.
+Qed.
+ +
+Lemma equiv_disj_union_compat_r {Δ Δ' Δ'' : env} : Δ Δ'' -> Δ Δ' Δ'' Δ'.
+Proof. ms. Qed.
+ +
+Lemma env_add_comm (Δ : env) φ ϕ : (Δ φ ϕ) (Δ ϕ φ).
+Proof. ms. Qed.
+ +
+Lemma in_difference (Δ : env) φ ψ : φ ψ -> φ Δ -> φ Δ {[ψ]}.
+Proof.
+intros Hne Hin.
+unfold elem_of, gmultiset_elem_of.
+rewrite (multiplicity_difference Δ {[ψ]} φ).
+assert( HH := multiplicity_singleton_ne φ ψ Hne).
+unfold singletonMS, base.singletonMS in HH.
+unfold base.singleton, Environments.singleton. ms.
+Qed.
+ +
+Global Hint Resolve in_difference : multiset.
+ +
+(* could be used in disj_inv *)
+Lemma env_add_inv (Γ Γ' : env) (φ ψ : form): φ ψ -> ((Γ φ) (Γ' ψ)) -> (Γ' ((Γ {[ψ]}) φ)).
+Proof.
+intros Hneq Heq. rewrite <- env_replace.
+- ms.
+- assert (Γ φ)); [rewrite Heq|]; ms.
+Qed.
+ +
+Lemma env_add_inv' (Γ Γ' : env) (φ : form): (Γ φ) Γ' -> (Γ (Γ' {[φ]})).
+Proof. intro Heq. ms. Qed.
+ +
+Lemma env_equiv_eq (Γ Γ' :env) : Γ = Γ' -> Γ Γ'.
+Proof. intro; subst; trivial. Qed.
+ +
+(* reprove the following principles, proved in stdpp for Prop, but
+   we need them in Type *)

+Lemma gmultiset_choose_or_empty (X : env) : {x | x X} + {X = }.
+Proof.
+  destruct (elements X) as [|x l] eqn:HX; [right|left].
+  - by apply gmultiset_elements_empty_inv.
+  - exists x. rewrite <- (gmultiset_elem_of_elements x X).
+    replace (elements X) with (x :: l). left.
+Qed.
+ +
+(* We need this induction principle in type. *)
+Lemma gmultiset_rec (P : env Type) :
+  P ( x X, P X P ({[+ x +]} X)) X, P X.
+Proof.
+  intros Hemp Hinsert X. induction (gmultiset_wf X) as [X _ IH].
+  destruct (gmultiset_choose_or_empty X) as [[x Hx]| ->]; auto.
+  rewrite (gmultiset_disj_union_difference' x X) by done.
+  apply Hinsert, IH; multiset_solver.
+Qed.
+ +
+Lemma difference_include (θ θ' : form) (Δ : env) :
+  (θ' Δ) ->
+  θ Δ {[θ']} -> θ Δ.
+Proof.
+intros Hin' Hin.
+rewrite gmultiset_disj_union_difference with (X := {[θ']}).
+- apply gmultiset_elem_of_disj_union. tauto.
+- now apply gmultiset_singleton_subseteq_l.
+Qed.
+ +
+Fixpoint rm x l := match l with
+| h :: t => if form_eq_dec x h then t else h :: rm x t
+| [] => []
+end.
+ +
+Lemma in_rm l x y: In x (rm y l) -> In x l.
+Proof.
+induction l; simpl. tauto.
+destruct form_eq_dec. tauto. firstorder.
+Qed.
+ +
+Lemma remove_include (θ θ' : form) (Δ : list form) :
+  (θ' Δ) ->
+  θ rm θ' Δ -> θ Δ.
+Proof. intros Hin' Hin. eapply elem_of_list_In, in_rm, elem_of_list_In, Hin. Qed.
+ +
+(* technical lemma : one can constructively find whether an environment contains
+   an element satisfying a decidable property *)

+Lemma decide_in (P : form -> Prop) (Γ : env) :
+  (forall φ, Decision (P φ)) ->
+  {φ : form| (φ Γ) /\ P φ} + {forall φ, φ Γ -> ¬ P φ}.
+Proof.
+intro HP.
+induction Γ using gmultiset_rec.
+- right. intros φ Hφ; inversion Hφ.
+- destruct IHΓ as [(φ&Hφ) | HF].
+  + left. exists φ. ms.
+  + case (HP x); intro Hx.
+    * left; exists x. ms.
+    * right. intros. ms.
+Qed.
+ +
+Lemma union_difference_L (Γ : env) Δ ϕ: ϕ Γ -> (Γ Δ) {[ϕ]} Γ {[ϕ]} Δ.
+Proof. intro Hin. pose (difference_singleton _ _ Hin). ms. Qed.
+ +
+Lemma union_difference_R (Γ : env) Δ ϕ: ϕ Δ -> (Γ Δ) {[ϕ]} Γ (Δ {[ϕ]}).
+Proof. intro Hin. pose (difference_singleton _ _ Hin). ms. Qed.
+ +
+Global Instance equiv_assoc : @Assoc env equiv disj_union.
+Proof. intros x y z. ms. Qed.
+Global Hint Immediate equiv_assoc : proof.
+ +
+Global Instance proper_difference : Proper ((≡@{env}) ==> eq ==> (≡@{env})) difference.
+Proof. intros Γ Γ' Heq Δ Heq'. ms. Qed.
+ +
+Definition var_not_in_env p (Γ : env):= ( φ0, φ0 Γ -> ¬ occurs_in p φ0).
+ +
+
+ +
+

Tactics

+ +
+
+(* helper tactic split cases given an assumption about belonging to a multiset *)
+ +
+Ltac in_tac :=
+repeat
+match goal with
+| H : ?θ {[?θ1; ?θ2]} |- _ => apply gmultiset_elem_of_union in H; destruct H as [H|H]; try subst
+| H : ?θ (?Δ {[?θ']}) |- _ => apply difference_include in H; trivial
+| H : context [?θ (?d ?θ2)] |- _ =>
+    rewrite (env_in_add d) in H; destruct H as [H|H]; try subst
+| H : context [?θ {[ ?θ2 ]}] |- _ => rewrite gmultiset_elem_of_singleton in H; subst
+end.
+ +
+Definition open_box φ : form := match φ with
+| φ => φ
+| φ => φ
+end.
+ +
+(* inefficient conversion from multisets to lists and back *)
+Definition open_boxes (Γ : env) : env := list_to_set_disj (map open_box (elements Γ)).
+ +
+Global Notation "⊙ φ" := (open_box φ) (at level 75).
+Global Notation "⊗ Γ" := (open_boxes Γ) (at level 75).
+ +
+Global Instance proper_open_boxes : Proper ((≡@{env}) ==> (≡@{env})) open_boxes.
+Proof. intros Γ Heq Δ Heq'. ms. Qed.
+ +
+Lemma open_boxes_empty : open_boxes = .
+Proof. auto. Qed.
+ +
+Lemma open_boxes_disj_union (Γ : env) Δ : (open_boxes (Γ Δ)) = (open_boxes Γ open_boxes Δ).
+Proof.
+unfold open_boxes. rewrite (gmultiset_elements_disj_union Γ Δ).
+rewrite map_app. apply list_to_set_disj_app.
+Qed.
+ +
+Lemma open_boxes_singleton φ : open_boxes {[φ]} = {[ φ]}.
+Proof.
+unfold open_boxes.
+assert (HH := gmultiset_elements_singleton φ).
+unfold elements, base.singletonMS, singletonMS, base.singleton, Environments.singleton in *.
+rewrite HH. simpl. unfold base.singletonMS, disj_union, empty.
+apply gmultiset_disj_union_right_id.
+Qed.
+ +
+Lemma open_boxes_add (Γ : env) φ : (open_boxes (Γ φ)) = (open_boxes Γ open_box φ).
+Proof.
+rewrite open_boxes_disj_union.
+unfold open_boxes. f_equal. apply open_boxes_singleton.
+Qed.
+ +
+Lemma elem_of_open_boxes φ Δ : φ (Δ) -> φ Δ \/ (φ) Δ.
+Proof.
+intro Hin.
+induction Δ as [|θ Δ Hind] using gmultiset_rec.
+- auto with proof.
+- rewrite open_boxes_disj_union in Hin.
+  apply gmultiset_elem_of_disj_union in Hin.
+  destruct Hin as [ | ].
+  + rewrite open_boxes_singleton in . apply gmultiset_elem_of_singleton in .
+      subst φ. destruct θ; ms.
+  + destruct (Hind ); ms.
+Qed.
+ +
+Lemma occurs_in_open_boxes x φ Δ : occurs_in x φ -> φ (Δ) -> exists θ, θ Δ /\ occurs_in x θ.
+Proof.
+intros Hx Hφ. apply elem_of_open_boxes in Hφ. destruct Hφ as [Hφ|Hφ]; eauto.
+Qed.
+ +
+Lemma occurs_in_map_open_box x φ Δ : occurs_in x φ -> φ (map open_box Δ) -> exists θ, θ Δ /\ occurs_in x θ.
+Proof.
+intros Hx Hφ. apply elem_of_list_In, in_map_iff in Hφ.
+destruct Hφ as [ψ [Hφ Hin]]; subst.
+exists ψ. split. now apply elem_of_list_In. destruct ψ; trivial.
+Qed.
+ +
+Global Hint Rewrite open_boxes_disj_union : proof.
+ +
+Lemma open_boxes_remove Γ φ : φ Γ -> (≡@{env}) (⊗ (Γ {[φ]})) ((⊗ Γ) {[⊙ φ]}).
+Proof.
+intro Hin.
pose (difference_singleton Γ φ Hin). rewrite e at 2.
+rewrite open_boxes_add. ms.
+Qed.
+ +
+Definition is_box φ := match φ with
+| _ => true
+| _ => false
+end.
+ +
+Lemma open_boxes_spec Γ φ : φ open_boxes Γ -> {φ Γ is_box φ = false} + {( φ) Γ}.
+Proof.
+unfold open_boxes. intro Hin. apply elem_of_list_to_set_disj in Hin.
+apply elem_of_list_In in Hin. apply in_map_iff in Hin.
+case (decide (( φ) Γ)).
+- right; trivial.
+- intro Hout. left.
+  destruct Hin as (y & Hin & Hy). subst.
+  destruct y; simpl in *; split; trivial;
+  try (apply gmultiset_elem_of_elements,elem_of_list_In; trivial);
+  contradict Hout; apply gmultiset_elem_of_elements,elem_of_list_In; trivial.
+Qed.
+ +
+Lemma is_not_box_open_box φ : is_box φ = false -> (φ) = φ.
+Proof. destruct φ; simpl; intuition. discriminate. Qed.
+ +
+Lemma open_boxes_spec' Γ φ : {φ Γ is_box φ = false} + {( φ) Γ} -> φ open_boxes Γ.
+Proof.
+intros [[Hin Heq] | Hin];
+unfold open_boxes; apply elem_of_list_to_set_disj, elem_of_list_In, in_map_iff.
+- exists φ. apply is_not_box_open_box in Heq. rewrite Heq. split; trivial.
+  now apply elem_of_list_In, gmultiset_elem_of_elements.
+- exists ( φ). simpl. split; trivial. now apply elem_of_list_In, gmultiset_elem_of_elements.
+Qed.
+ +
+Lemma In_open_boxes (Γ : env) (φ : form) : (φ Γ) -> open_box φ open_boxes Γ.
+Proof.
+intro Hin. apply difference_singleton in Hin.
+rewrite Hin, open_boxes_add. auto with *.
+Qed.
+ +
+Global Hint Resolve In_open_boxes : proof.
+Global Hint Unfold open_box : proof.
+Global Hint Rewrite open_boxes_empty : proof.
+Global Hint Rewrite open_boxes_add : proof.
+Global Hint Rewrite open_boxes_remove : proof.
+Global Hint Rewrite open_boxes_singleton : proof.
+ +
+Global Hint Resolve open_boxes_spec' : proof.
+Global Hint Resolve open_boxes_spec : proof.
+ +
+Global Instance Proper_elements : Proper ((≡) ==> (≡ₚ)) ((λ Γ : env, elements Γ)).
+Proof.
+intros Γ Δ Heq; apply AntiSymm_instance_0; apply gmultiset_elements_submseteq; ms.
+Qed.
+ +
+Lemma elements_open_boxes Γ: elements ( Γ) ≡ₚ map open_box (elements Γ).
+Proof.
+unfold open_boxes. remember (elements Γ) as l. clear Γ Heql.
+induction l as [| a l].
+- ms.
+- simpl. setoid_rewrite gmultiset_elements_disj_union.
+  rewrite IHl. setoid_rewrite gmultiset_elements_singleton. trivial.
+Qed.
+ +
+Lemma list_to_set_disj_env_add Δ v: ((list_to_set_disj Δ : env) v : env) list_to_set_disj (v :: Δ).
+Proof. ms. Qed.
+ +
+Lemma list_to_set_disj_rm Δ v: (list_to_set_disj Δ : env) {[v]} list_to_set_disj (rm v Δ).
+Proof.
+induction Δ as [|φ Δ]; simpl; [ms|].
+case form_eq_dec; intro; subst; [ms|].
+simpl. rewrite <- IHΔ. case (decide (v (list_to_set_disj Δ: env))).
+- intro. rewrite union_difference_R by assumption. ms.
+- intro. rewrite diff_not_in by auto with *. rewrite diff_not_in; auto with *.
+Qed.
+ +
+Lemma gmultiset_elements_list_to_set_disj l: gmultiset_elements(list_to_set_disj l) ≡ₚ l.
+Proof.
+induction l as [| x l]; [ms|].
+rewrite Proper_elements; [|symmetry; apply list_to_set_disj_env_add].
+rewrite elements_env_add, IHl. trivial.
+Qed.
+ +
+Lemma list_to_set_disj_open_boxes Δ: (( (list_to_set_disj Δ)) = list_to_set_disj (map open_box Δ)).
+Proof. apply list_to_set_disj_perm, Permutation_map', gmultiset_elements_list_to_set_disj. Qed.
+ +
+(* TODO: move in optimisations *)
+
+ +
+ + + diff --git a/ISL.Formulas.html b/ISL.Formulas.html new file mode 100644 index 0000000..9a2327a --- /dev/null +++ b/ISL.Formulas.html @@ -0,0 +1,238 @@ + + + + + + + + + + + + + +
+
+

ISL.Formulas

+ +
+
+ +
+

Overview: formulas

+ + +
+ +This file defines propositional formulas, the proof that there are countably many, and the definition of the well-founded ordering on the set of formulas, via weight. +
+ + Theory of countability from Iris +
+
+From stdpp Require Import countable strings.
+ +
+Local Open Scope string_scope.
+ +
+
+ +
+

Definitions and notations.

+ +
+
+Definition variable := string.
+ +
+Inductive form : Type :=
+| Var : variable -> form
+| Bot : form
+| And : form -> form -> form
+| Or : form -> form -> form
+| Implies : form -> form -> form
+| Box : form -> form.
+ +
+Fixpoint occurs_in (x : variable) (φ : form) :=
+match φ with
+| Var y => x = y
+| Bot => False
+| And φ ψ => (occurs_in x φ) \/ (occurs_in x ψ)
+| Or φ ψ => (occurs_in x φ) \/ (occurs_in x ψ)
+| Implies φ ψ => (occurs_in x φ) \/ (occurs_in x ψ)
+| Box φ => occurs_in x φ
+
+end.
+ +
+
+ +
+Pretty notations for formulas +
+
+Notation "¬ φ" := (Implies φ Bot) (at level 75, φ at level 75).
+Notation " ⊥ " := Bot.
+Notation " ⊤ " := (Implies Bot Bot).
+Notation " A ∧ B" := (And A B) (at level 80, B at level 80).
+Notation " A ∨ B" := (Or A B) (at level 85, B at level 85).
+Notation " A → B" := (Implies A B) (at level 99, B at level 200).
+Notation "□ φ" := (Box φ) (at level 75, φ at level 75).
+Infix " φ ⇔ ψ " := (And (Implies φ ψ) (Implies ψ φ)) (at level 100).
+Global Instance fomula_bottom : base.Bottom form := Bot.
+ +
+Global Coercion Var : variable >-> form.
+ +
+Global Instance form_top : base.Top form := .
+ +
+
+ +
+Formulas have decidable equality. +
+
+Global Instance string_dec : EqDecision string := string_dec.
+Global Instance form_eq_dec : EqDecision form.
+Proof. solve_decision . Defined.
+ +
+Section CountablyManyFormulas.
+
+ +
+

Countability of the set of formulas

+ We prove that there are countably many formulas by exhibiting an injection + into general trees over nat for countability. +
+
+Local Fixpoint form_to_gen_tree (φ : form) : gen_tree (option string) :=
+match φ with
+| => GenLeaf None
+| Var v => GenLeaf (Some v)
+| φ ψ => GenNode 0 [form_to_gen_tree φ ; form_to_gen_tree ψ]
+| φ ψ => GenNode 1 [form_to_gen_tree φ ; form_to_gen_tree ψ]
+| φ ψ => GenNode 2 [form_to_gen_tree φ ; form_to_gen_tree ψ]
+| φ => GenNode 3 [form_to_gen_tree φ]
+end.
+ +
+Local Fixpoint gen_tree_to_form (t : gen_tree (option string)) : option form :=
+match t with
+| GenLeaf None => Some
+| GenLeaf (Some v) => Some (Var v)
+| GenNode 0 [t1 ; t2] =>
+    gen_tree_to_form t1 ≫= fun φ => gen_tree_to_form t2 ≫= fun ψ =>
+      Some (φ ψ)
+| GenNode 1 [t1 ; t2] =>
+    gen_tree_to_form t1 ≫= fun φ => gen_tree_to_form t2 ≫= fun ψ =>
+      Some (φ ψ)
+| GenNode 2 [t1 ; t2] =>
+    gen_tree_to_form t1 ≫= fun φ => gen_tree_to_form t2 ≫= fun ψ =>
+      Some (φ ψ)
+ | GenNode 3 [t] => gen_tree_to_form t ≫= fun φ => Some (φ)
+| _=> None
+end.
+ +
+Global Instance form_count : Countable form.
+Proof.
+  eapply inj_countable with (f := form_to_gen_tree) (g := gen_tree_to_form).
+  intro φ; induction φ; simpl; trivial; now rewrite IHφ1, IHφ2 || rewrite IHφ.
+Defined.
+ +
+End CountablyManyFormulas.
+ +
+Inductive subform : form -> form -> Prop :=
+| SubEq : φ, subform φ φ
+| SubAnd : φ ψ1 ψ2, (subform φ ψ1 + subform φ ψ2) -> subform φ (ψ1 ψ2)
+| SubOr : φ ψ1 ψ2, (subform φ ψ1 + subform φ ψ2) -> subform φ (ψ1 ψ2)
+| SubImpl : φ ψ1 ψ2, (subform φ ψ1 + subform φ ψ2) -> subform φ (ψ1 ψ2)
+| SubBox : φ ψ, subform φ ψ -> subform φ ( ψ).
+Local Hint Constructors subform : dyckhoff.
+ +
+
+ +
+

Weight

+ + +
+ +We define the weight function on formulas, following (Dyckhoff Negri 2000) +
+
+Fixpoint weight (φ : form) : nat := match φ with
+| => 1
+| Var _ => 1
+| φ ψ => 2 + weight φ + weight ψ
+| φ ψ => 3 + weight φ + weight ψ
+| φ ψ => 1 + weight φ + weight ψ
+| φ => 1 + weight φ
+end.
+ +
+Lemma weight_pos φ : weight φ > 0.
+Proof. induction φ; simpl; lia. Qed.
+ +
+
+ +
+We obtain an induction principle based on weight. +
+
+Definition weight_ind (P : form -> Type) :
(forall ψ, ( φ, (weight φ < weight ψ) -> P φ) -> P ψ) ->
( φ, P φ).
+Proof.
+  intros Hc φ. remember (weight φ) as w.
+  assert(Hw : weight φ w) by now subst. clear Heqw.
+  revert φ Hw. induction w; intros φ Hw.
+  - pose (Hw' := weight_pos φ). auto with *.
+  - destruct φ; simpl in Hw; trivial;
+    apply Hc; intros φ' Hw'; apply IHw; simpl in Hw'; lia.
+Defined.
+ +
+Definition form_order φ ψ := weight φ > weight ψ.
+ +
+Global Instance transitive_form_order : Transitive form_order.
+Proof. unfold form_order. auto with *. Qed.
+ +
+Global Instance irreflexive_form_order : Irreflexive form_order.
+Proof. unfold form_order. intros x y. lia. Qed.
+ +
+Notation "φ ≺f ψ" := (form_order ψ φ) (at level 149).
+
+
+ +
+ + + diff --git a/ISL.Optimizations.html b/ISL.Optimizations.html new file mode 100644 index 0000000..74624f2 --- /dev/null +++ b/ISL.Optimizations.html @@ -0,0 +1,820 @@ + + + + + + + + + + + + + +
+
+

ISL.Optimizations

+ +
+Require Import ISL.Environments ISL.Sequents ISL.SequentProps ISL.Cut.
+Require Import Program Equality.
+ +
+Definition Lindenbaum_Tarski_preorder φ ψ :=
+   φ ψ.
+ +
+Notation "φ ≼ ψ" := (Lindenbaum_Tarski_preorder φ ψ) (at level 150).
+ +
+Corollary weak_cut φ ψ θ:
+  (φ ψ) -> (ψ θ) ->
+  φ θ.
+Proof.
+intros H1 H2.
+eapply additive_cut.
+- apply H1.
+- exch 0. now apply weakening.
+Qed.
+ +
+Lemma top_provable Γ :
Γ .
+Proof.
+  apply ImpR. apply ExFalso.
+Qed.
+ +
+(* Some tactics for the obviously_smaller proofs. *)
+ +
+(* Solve goals involving the equality decision at the end of the match *)
+Ltac eq_clean := match goal with
+| H : (if decide (?f1 = ?f2) then ?t else Eq) = ?t |- _ =>
+    case decide in H;
+    match goal with
+    | e : ?f1 = ?f2 |- _ => rewrite e; apply generalised_axiom
+    | _ => discriminate
+    end
+| H : (if decide (?f1 = ?f2) then Lt else Eq) = Gt |- _ =>
+    case decide in H; discriminate
+| H : matchwith _ => _ end = _ |- _ => destruct φ; try discriminate; eq_clean
+end.
+ +
+(* Solve goals that involve directly using ExFalso *)
+Ltac bot_clean := match goal with
+| [ |- Bot _] => apply ExFalso
+| [ |- _ Bot _ ] => apply ImpR; apply ExFalso
+| _ => idtac
+end.
+ +
+(* Solve induction goals *)
+Ltac induction_auto := match goal with
+| IH : obviously_smaller ?f ?f2 = Lt ?f ?f2 , H : obviously_smaller ?f ?f2 = Lt |- ( ?f) ?f2 =>
+    apply IH; assumption
+| IH : obviously_smaller ?f ?f2 = Gt ?f2 ?f , H : obviously_smaller ?f ?f2 = Gt |- ( ?f2) ?f =>
+    apply IH; assumption
+
+| IH : obviously_smaller ?f _ = Lt ?f _ , H : obviously_smaller ?f _ = Lt |- ?f _ _ =>
+    apply AndL; apply weakening; apply IH; assumption
+| IH : obviously_smaller ?f _ = Lt ?f _ , H : obviously_smaller ?f _ = Lt |- _ ?f _ =>
+    apply AndL; exch 0; apply weakening; apply IH; assumption
+
+| IH : obviously_smaller ?f _ = Gt _ ?f , H : obviously_smaller ?f _ = Gt |- _ ?f _ =>
+    apply OrR1; apply IH; assumption
+| IH : obviously_smaller ?f _ = Gt _ ?f , H : obviously_smaller ?f _ = Gt |- _ _ ?f =>
+    apply OrR2; apply IH; assumption
+| _ => idtac
+end.
+ +
+Lemma double_negation_obviously_smaller φ ψ:
is_double_negation φ ψ -> ψ φ.
+Proof.
+intro H; rewrite H. apply ImpR; auto with proof.
+Qed.
+ +
+Lemma is_implication_obviously_smaller φ ψ:
is_implication φ ψ -> ψ φ.
+Proof.
+unfold is_implication. intro H.
+destruct φ; try (contradict H; intros [θ ]; discriminate).
+case (decide (φ2 = ψ)).
+- intro; subst. apply ImpR, weakening, generalised_axiom.
+- intro Hneq. contradict H; intros [θ ]. inversion . tauto.
+Qed.
+ +
+Lemma obviously_smaller_compatible_LT φ ψ :
+  obviously_smaller φ ψ = Lt -> φ ψ.
+Proof.
+intro H.
+induction φ; destruct ψ;
+repeat (unfold obviously_smaller in H; fold obviously_smaller in H; try discriminate; eq_clean); bot_clean;
+
+repeat match goal with
+  | [ H : obviously_smaller _ (?f _) = Lt |- _ ?f _ ] =>
+      destruct f; simpl in H; try discriminate; bot_clean
+  | |- _ _ ?f =>
+    case_eq (obviously_smaller φ1 f); case_eq (obviously_smaller φ2 f);
+    intros H0 H1;
+    simpl in H; try rewrite H0 in H; try rewrite H1 in H; try discriminate; induction_auto
+  | |- _ _ ?f =>
+    case_eq (obviously_smaller φ1 f); case_eq (obviously_smaller φ2 f);
+    intros H0 H1;
+    simpl in H; rewrite H0 in H; rewrite H1 in H; try discriminate;
+    apply OrL; induction_auto
+  | |- (?f _) _ => destruct f; try eq_clean; discriminate
+end;
+try destruct ψ1; try discriminate; bot_clean;
+simpl in H; try case decide in H; try discriminate; bot_clean;
+try (now apply double_negation_obviously_smaller);
+try case decide in H;
+try (now apply is_implication_obviously_smaller);
+try (inversion e; subst; apply generalised_axiom);
+try solve[destruct φ1; inversion H];
+destruct φ1; repeat case decide in H; try discriminate;
+   try (now apply is_implication_obviously_smaller);
+   try (now apply double_negation_obviously_smaller).
+Qed.
+ +
+Lemma obviously_smaller_compatible_GT φ ψ :
+  obviously_smaller φ ψ = Gt -> ψ φ .
+Proof.
+intro H.
+induction φ; destruct ψ;
+try match goal with H : ?H0 -> _ |- _ => assert(Hw' : H0) by lia; specialize (Hw Hw') end;
+try (unfold obviously_smaller in H; try discriminate; eq_clean); bot_clean;
+repeat match goal with
+  | |- ?f _ _ =>
+    case_eq (obviously_smaller φ1 f); case_eq (obviously_smaller φ2 f); intros H0 H1;
+    simpl in H; rewrite H0 in H; rewrite H1 in H; try discriminate; apply AndR; induction_auto
+  | |- ?f _ _ =>
+    case_eq (obviously_smaller φ1 f); case_eq (obviously_smaller φ2 f); intros H0 H1;
+    simpl in H; rewrite H0 in H; rewrite H1 in H; try discriminate; induction_auto
+  | |- (?f1 _) ?f2 _ =>
+    simpl in H; destruct f1; destruct f2; bot_clean; try eq_clean; discriminate
+  | |- (?f _) _ => destruct f; discriminate
+  | |- ( (?f _)) _ => destruct f; discriminate
+  | |- _ (?f _) => destruct f; bot_clean; discriminate
+end;
+simpl in H;
+try solve[destruct ψ1; try discriminate; eq_clean];
+  destruct φ1; try discriminate; repeat eq_clean;
+  try destruct ψ1;
try (unfold obviously_smaller in H; try discriminate; eq_clean); bot_clean;
repeat case decide in H; try discriminate; bot_clean;
+try (now apply double_negation_obviously_smaller);
+try (now apply is_implication_obviously_smaller);
+try (now apply ImpR, weakening, IHφ2).
+Qed.
+ +
+Lemma and_congruence φ ψ φ' ψ':
+  (φ φ') -> (ψ ψ') -> (φ ψ) φ' ψ'.
+Proof.
+intros Hφ Hψ.
+apply AndL.
+apply AndR.
+- now apply weakening.
+- exch 0. now apply weakening.
+Qed.
+ +
+Lemma choose_conj_equiv_L φ ψ φ' ψ':
+  (φ φ') -> (ψ ψ') -> (φ ψ) choose_conj φ' ψ'.
+Proof.
+intros Hφ Hψ.
+unfold choose_conj.
+case_eq (obviously_smaller φ' ψ'); intro Heq.
+- apply and_congruence; assumption.
+- apply AndL, weakening, Hφ.
+- apply AndL. exch 0. apply weakening, Hψ.
+Qed.
+ +
+Lemma choose_conj_equiv_R φ ψ φ' ψ':
+  (φ' φ) -> (ψ' ψ) -> choose_conj φ' ψ' φ ψ.
+Proof.
+intros Hφ Hψ.
+unfold choose_conj.
+case_eq (obviously_smaller φ' ψ'); intro Heq.
+- now apply and_congruence.
+- apply AndR.
+  + assumption.
+  + eapply weak_cut.
+    * apply obviously_smaller_compatible_LT, Heq.
+    * assumption.
+- apply AndR.
+  + eapply weak_cut.
+    * apply obviously_smaller_compatible_GT, Heq.
+    * assumption.
+  + assumption.
+Qed.
+ +
+Hint Unfold Lindenbaum_Tarski_preorder : proof.
+ +
+Lemma make_conj_equiv_L φ ψ φ' ψ' :
+  (φ φ') -> (ψ ψ') -> (φ ψ) φ' ψ'.
+Proof.
+intros Hφ Hψ.
+unfold make_conj.
+destruct ψ'; try (apply choose_conj_equiv_L; assumption).
+- destruct φ'; try (apply choose_conj_equiv_L; assumption).
+  case decide; intro; try (apply choose_conj_equiv_L; assumption).
+  apply obviously_smaller_compatible_LT in e.
+  apply weak_cut with ((φ φ'1) ψ).
+  + apply AndL; repeat apply AndR. auto with proof.
+      * exch 0. apply weakening; apply weak_cut with v; assumption.
+      * apply generalised_axiom.
+  + apply choose_conj_equiv_L; auto with proof.
+- apply exfalso, AndL. exch 0. apply weakening, Hψ.
+- case_eq (obviously_smaller φ' ψ'1); intro Heq.
+  + apply and_congruence; assumption.
+  + apply and_congruence.
+    * assumption.
+    * apply AndR_rev in Hψ; apply Hψ.
+  + apply AndL. exch 0. apply weakening. assumption.
+- repeat case decide; intros.
+  + apply AndL. now apply weakening.
+  + apply AndL. now apply weakening.
+  + apply choose_conj_equiv_L ; assumption.
+- case (decide (obviously_smaller φ' ψ'1 = Lt)); intro.
+  + apply weak_cut with (φ ψ)).
+     * apply AndR; auto with proof.
+     * apply choose_conj_equiv_L. assumption.
+        apply obviously_smaller_compatible_LT in e.
+        apply contraction, ImpR_rev. apply weak_cut with ψ'1.
+        -- apply weak_cut with φ'; auto with proof.
+        -- apply ImpR. exch 0. apply ImpR_rev, AndL. exch 0. apply weakening, Hψ.
+  + apply choose_conj_equiv_L; assumption.
+- destruct φ'; try (apply choose_conj_equiv_L; assumption).
+  case decide; intro; try (apply choose_conj_equiv_L; assumption).
+  apply weak_cut with (φ φ'1)).
+  + apply AndL, AndR. auto with proof. apply AndR. auto with proof.
+      exch 0. apply weakening. apply weak_cut with ( ψ'). auto with proof.
+      now apply obviously_smaller_compatible_LT.
+  + apply weak_cut with ((φ φ'1) ψ).
+     * apply AndR; auto with proof.
+     * apply choose_conj_equiv_L; auto with proof.
+Qed.
+ +
+Lemma make_conj_equiv_R φ ψ φ' ψ' :
+  (φ' φ) -> (ψ' ψ) -> φ' ψ' φ ψ.
+Proof.
+intros Hφ Hψ.
+unfold make_conj.
+destruct ψ'.
+- destruct φ'; try case decide; intros; apply choose_conj_equiv_R; try assumption.
+  eapply imp_cut; eassumption.
+- destruct φ'; try case decide; intros; apply choose_conj_equiv_R; try assumption.
+   eapply imp_cut; eassumption.
+- case_eq (obviously_smaller φ' ψ'1); intro Heq.
+  + now apply and_congruence.
+  + apply AndR.
+    * apply AndL. now apply weakening.
+    * apply (weak_cut _ ( ψ'1 ψ'2) _).
+      -- apply and_congruence;
+         [now apply obviously_smaller_compatible_LT | apply generalised_axiom].
+      -- assumption.
+  + apply AndR.
+    * apply AndL. apply weakening. eapply weak_cut.
+      -- apply obviously_smaller_compatible_GT; apply Heq.
+      -- assumption.
+    * assumption.
+- repeat case decide; intros.
+  + apply AndR.
+    * assumption.
+    * eapply weak_cut.
+      -- apply obviously_smaller_compatible_LT; eassumption.
+      -- apply OrL_rev in Hψ; apply Hψ.
+  + apply AndR.
+    * assumption.
+    * eapply weak_cut.
+      -- apply obviously_smaller_compatible_LT; eassumption.
+      -- apply OrL_rev in Hψ; apply Hψ.
+  + apply choose_conj_equiv_R; assumption.
+- case decide; intro Heq.
+  + apply choose_conj_equiv_R. assumption. eapply weak_cut; [|exact Hψ]. auto with proof.
+  + apply choose_conj_equiv_R; assumption.
+- destruct φ'; try case decide; intros; apply choose_conj_equiv_R; try assumption.
+  eapply imp_cut; eassumption.
+Qed.
+ +
+Lemma specialised_weakening Γ φ ψ : (φ ψ) -> Γφ ψ.
+Proof.
+intro H.
+apply generalised_weakeningL.
+peapply H.
+Qed.
+ +
+Lemma make_conj_sound_L Γ φ ψ θ : Γφ ψ θ -> Γ φ ψ θ.
+Proof.
+intro H.
+eapply additive_cut.
+- apply specialised_weakening.
+  apply make_conj_equiv_R; apply generalised_axiom.
+- exch 0. now apply weakening.
+Qed.
+ +
+Global Hint Resolve make_conj_sound_L : proof.
+ +
+Lemma make_conj_complete_L Γ φ ψ θ : Γ φ ψ θ -> Γφ ψ θ.
+Proof.
+intro H.
+eapply additive_cut.
+- apply specialised_weakening.
+  apply make_conj_equiv_L; apply generalised_axiom.
+- exch 0. now apply weakening.
+Qed.
+ +
+Lemma make_conj_sound_R Γ φ ψ : Γ φ ψ -> Γ φ ψ.
+Proof.
+intro H.
+eapply additive_cut.
+- apply H.
+- apply make_conj_complete_L, generalised_axiom.
+Qed.
+ +
+Global Hint Resolve make_conj_sound_R : proof.
+ +
+Lemma make_conj_complete_R Γ φ ψ : Γ φ ψ -> Γ φ ψ.
+Proof.
+intro H.
+eapply additive_cut.
+- apply H.
+- apply make_conj_sound_L, generalised_axiom.
+Qed.
+ +
+Lemma or_congruence φ ψ φ' ψ':
+  (φ φ') -> (ψ ψ') -> (φ ψ) φ' ψ'.
+Proof.
+intros Hφ Hψ.
+apply OrL.
+- now apply OrR1.
+- now apply OrR2.
+Qed.
+ +
+Lemma choose_disj_equiv_L φ ψ φ' ψ':
+  (φ φ') -> (ψ ψ') -> (φ ψ) choose_disj φ' ψ'.
+Proof.
+intros Hφ Hψ.
+unfold choose_disj.
+case_eq (obviously_smaller φ' ψ'); intro Heq.
+- case_eq (obviously_smaller ψ' φ'); intro Heq'.
+  + apply or_congruence; assumption.
+  + apply OrL. assumption.
+       eapply weak_cut.
+        * apply Hψ.
+        * apply obviously_smaller_compatible_LT; assumption.
+  + apply OrL; [| assumption].
+       eapply weak_cut.
+        * apply Hφ.
+        * apply obviously_smaller_compatible_GT; assumption.
+- apply OrL.
+  + eapply weak_cut.
+    * apply Hφ.
+    * apply obviously_smaller_compatible_LT; assumption.
+  + assumption.
+- apply OrL.
+  + assumption.
+  + eapply weak_cut.
+    * eapply weak_cut.
+      -- apply Hψ.
+      -- apply obviously_smaller_compatible_GT. apply Heq.
+    * apply generalised_axiom.
+Qed.
+ +
+Lemma choose_disj_equiv_R φ ψ φ' ψ' :
+  (φ' φ) -> (ψ' ψ) -> choose_disj φ' ψ' φ ψ.
+Proof.
+intros Hφ Hψ.
+unfold choose_disj.
+case_eq (obviously_smaller φ' ψ'); intro Heq;
+[| apply OrR2| apply OrR1]; try assumption.
+case_eq (obviously_smaller ψ' φ'); intro Heq';
+[apply or_congruence| apply OrR1| apply OrR2]; try assumption.
+Qed.
+ +
+Lemma make_disj_equiv_L φ ψ φ' ψ' :
+  (φ φ') -> (ψ ψ') -> (φ ψ) φ' ψ'.
+Proof.
+intros Hφ Hψ.
+unfold make_disj.
+destruct ψ'; try (apply choose_disj_equiv_L; assumption).
+- repeat case decide; intros.
+  + apply OrL.
+    * assumption.
+    * eapply weak_cut.
+      -- apply Hψ.
+      -- apply AndL; apply weakening; now apply obviously_smaller_compatible_GT.
+  + apply OrL.
+    * assumption.
+    * eapply weak_cut.
+      -- apply Hψ.
+      -- apply AndL; exch 0. apply weakening; now apply obviously_smaller_compatible_GT.
+  + now apply choose_disj_equiv_L.
+- case_eq (obviously_smaller φ' ψ'1); intro Heq.
+  + now apply or_congruence.
+  + apply OrL.
+    * eapply weak_cut.
+      -- apply Hφ.
+      -- apply OrR1. now apply obviously_smaller_compatible_LT.
+    * assumption.
+  + apply OrL.
+    * now apply OrR1.
+    * eapply weak_cut.
+      -- apply Hψ.
+      -- apply or_congruence; [apply obviously_smaller_compatible_GT; assumption| apply generalised_axiom].
+Qed.
+ +
+Lemma make_disj_equiv_R φ ψ φ' ψ' :
+  (φ' φ) -> (ψ' ψ) -> φ' ψ' φ ψ.
+Proof.
+intros Hφ Hψ.
+unfold make_disj.
+destruct ψ'.
+- now apply choose_disj_equiv_R.
+- now apply choose_disj_equiv_R.
+- repeat case decide; intros.
+  + now apply OrR1.
+  + now apply OrR1.
+  + now apply choose_disj_equiv_R.
+- case_eq (obviously_smaller φ' ψ'1); intro Heq.
+ + now apply or_congruence.
+ + now apply OrR2.
+ + apply OrL.
+   * now apply OrR1.
+   * apply OrL_rev in Hψ.
+     apply OrR2, Hψ.
+- now apply choose_disj_equiv_R.
+- now apply choose_disj_equiv_R.
+Qed.
+ +
+Lemma make_disj_sound_L Γ φ ψ θ : Γφ ψ θ -> Γmake_disj φ ψ θ.
+Proof.
+intro H.
+eapply additive_cut.
+- apply specialised_weakening.
+  apply make_disj_equiv_R; apply generalised_axiom.
+- exch 0. now apply weakening.
+Qed.
+ +
+Global Hint Resolve make_disj_sound_L : proof.
+ +
+Lemma make_disj_complete_L Γ φ ψ θ : Γmake_disj φ ψ θ -> Γφ ψ θ.
+Proof.
+intro H.
+eapply additive_cut.
+- apply specialised_weakening.
+  apply make_disj_equiv_L; apply generalised_axiom.
+- exch 0. now apply weakening.
+Qed.
+ +
+Lemma make_disj_sound_R Γ φ ψ : Γ φ ψ -> Γ make_disj φ ψ.
+Proof.
+intro H.
+eapply additive_cut.
+- apply H.
+- apply make_disj_complete_L, generalised_axiom.
+Qed.
+ +
+Global Hint Resolve make_disj_sound_R : proof.
+ +
+Lemma make_disj_complete_R Γ φ ψ : Γ make_disj φ ψ -> Γ φ ψ.
+Proof.
+intro H.
+eapply additive_cut.
+- apply H.
+- apply make_disj_sound_L, generalised_axiom.
+Qed.
+ +
+
+ +
+

Generalized rules

+ + +
+ +In this section we prove that generalizations of or-left and and-right rules +that take more than two formulas are admissible and invertible in the calculus +G4ip. This is important in the correctness proof of propositional quantifiers +because the propositional quantifiers are defined as large disjunctions / +conjunctions of various individual formulas. + +
+ +

Generalized OrL and its invertibility

+ +
+
+ +
+Lemma disjunction_L Γ Δ θ :
+  ((forall φ, φ Δ -> (Γφ θ)) -> (Γ Δ θ)) *
+  ((Γ Δ θ) -> (forall φ, φ Δ -> (Γφ θ))).
+Proof.
+unfold disjunction.
+assert(Hcut :
+  (forall ψ, (Γψ θ) -> (forall φ, φ Δ -> (Γφ θ)) ->
+    (Γfoldl make_disj ψ (nodup form_eq_dec Δ) θ)) *
+  (forall ψ,((Γfoldl make_disj ψ (nodup form_eq_dec Δ)) θ ->
+    (Γψ θ) * ( φ : form, φ Δ (Γφ) θ)))).
+{
+  induction Δ; simpl; split; intros ψ Hψ.
+  - intro. apply Hψ.
+  - split; trivial. intros φ Hin. contradict Hin. auto with *.
+  - intro Hall. case in_dec; intro; apply (fst IHΔ); auto with *.
+  - case in_dec in Hψ; apply IHΔ in Hψ;
+    destruct Hψ as [Hψ Hind].
+    + split; trivial; intros φ Hin; destruct (decide= a)); auto 2 with *.
+        subst. apply Hind. now apply elem_of_list_In.
+    + apply make_disj_complete_L in Hψ.
+        apply OrL_rev in Hψ as [Hψ Ha].
+        split; trivial; intros φ Hin; destruct (decide= a)); auto with *.
+}
+split; apply Hcut. constructor 2.
+Qed.
+ +
+
+ +
+

Generalized OrR

+ +
+
+ +
+Lemma disjunction_R Γ Δ φ : (φ Δ) -> (Γ φ) -> (Γ Δ).
+Proof.
+intros Hin Hprov. unfold disjunction. revert Hin.
+assert(Hcut : forall θ, ((Γ θ) + (φ Δ)) -> Γ foldl make_disj θ (nodup form_eq_dec Δ)).
+{
+  induction Δ; simpl; intros θ [ | Hin].
+  - assumption.
+  - contradict Hin; auto with *.
+  - case in_dec; intro; apply IHΔ; left; trivial. apply make_disj_sound_R. now apply OrR1.
+  - apply elem_of_cons in Hin.
+    destruct (decide= a)).
+    + subst. case in_dec; intro; apply IHΔ.
+        * right. now apply elem_of_list_In.
+        * left. apply make_disj_sound_R. now apply OrR2.
+    + case in_dec; intro; apply IHΔ; right; tauto.
+}
+intro Hin. apply Hcut; now right.
+Qed.
+ +
+
+ +
+

Generalized invertibility of AndR

+ +
+ +

Generalized AndR

+ +
+
+ +
+Lemma conjunction_R1 Γ Δ : (forall φ, φ Δ -> Γ φ) -> (Γ Δ).
+Proof.
+intro Hprov. unfold conjunction.
+assert(Hcut : forall θ, Γ θ -> Γ foldl make_conj θ (nodup form_eq_dec Δ)).
+{
+  induction Δ; intros θ ; simpl; trivial.
+  case in_dec; intro; auto with *.
+  apply IHΔ.
+  - intros; apply Hprov. now right.
+  - apply make_conj_sound_R, AndR; trivial. apply Hprov. now left.
+}
+apply Hcut. apply ImpR, ExFalso.
+Qed.
+ +
+Lemma conjunction_R2 Γ Δ : (Γ Δ) -> (forall φ, φ Δ -> Γ φ).
+Proof.
unfold conjunction.
+assert(Hcut : forall θ, Γ foldl make_conj θ (nodup form_eq_dec Δ) -> (Γ θ) * (forall φ, φ Δ -> Γ φ)).
+{
+  induction Δ; simpl; intros θ .
+  - split; trivial. intros φ Hin; contradict Hin. auto with *.
+  - case in_dec in ; destruct (IHΔ _ ) as (Hθ' & Hi);
+     try (apply make_conj_complete_R in Hθ'; destruct (AndR_rev Hθ')); split; trivial;
+     intros φ Hin; apply elem_of_cons in Hin;
+     destruct (decide= a)); subst; trivial.
+     + apply Hi. rewrite elem_of_list_In; tauto.
+     + apply (IHΔ _ ). tauto.
+     + apply (IHΔ _ ). tauto.
+}
+apply Hcut.
+Qed.
+ +
+
+ +
+

Generalized AndL

+ +
+
+ +
+Lemma conjunction_L Γ Δ φ θ: (φ Δ) -> (Γφ θ) -> (Γ Δ θ).
+Proof.
+intros Hin Hprov. unfold conjunction. revert Hin.
+assert(Hcut : forall ψ, ((φ Δ) + (Γψ θ)) -> (Γfoldl make_conj ψ (nodup form_eq_dec Δ) θ)).
+{
+  induction Δ; simpl; intros ψ [Hin | Hψ].
+  - contradict Hin; auto with *.
+  - trivial.
+  - case in_dec; intro; apply IHΔ; destruct (decide= a)).
+    + subst. left. now apply elem_of_list_In.
+    + left. auto with *.
+    + subst. right. apply make_conj_sound_L. auto with proof.
+    + left. auto with *.
+  - case in_dec; intro; apply IHΔ; right; trivial.
+     apply make_conj_sound_L. auto with proof.
+}
+intro Hin. apply Hcut. now left.
+Qed.
+ +
+(* TODO move up *)
+
+ +
+

Correctness of optimizations

+ + +
+ +To make the definitions of the propositional quantifiers that we extract from the Coq definition more readable, we introduced functions "make_impl", "make_conj" and "make_disj" in Environments.v which perform obvious simplifications such as reducing φ ∧ ⊥ to ⊥ and φ ∨ ⊥ to φ. The following results show that the definitions of these functions are correct, in the sense that it does not make a difference for provability of a sequent whether one uses the literal conjunction, disjunction, and implication, or its optimized version. +
+
+ +
+(* TODO: suitable name *)
+Lemma tautology_cut {Γ} {φ ψ θ : form} : Γ (φ ψ) θ -> (φ ψ) -> Γ θ.
+Proof.
+intros Hp H.
+apply additive_cut with ψ).
+  + apply ImpR, generalised_weakeningL. peapply H.
+  + apply Hp.
+Qed.
+ +
+Lemma Lindenbaum_Tarski_preorder_Bot φ : φ.
+Proof. apply ExFalso. Qed.
+ +
+Local Hint Resolve Lindenbaum_Tarski_preorder_Bot : proof.
+ +
+Lemma make_impl_sound_L Γ φ ψ θ: Γ•(φ ψ) θ -> Γ•(φ ψ) θ.
+Proof.
+revert φ. induction ψ; intros φ HP; simpl; repeat case decide; intros;
+repeat match goal with
+| H : obviously_smaller _ _ = Lt |- _ => apply obviously_smaller_compatible_LT in H
+| H : obviously_smaller _ _ = Gt |- _ => apply obviously_smaller_compatible_GT in H
+| H : is_negation _ _ |- _ => eapply additive_cut; [| exch 0; apply weakening, HP]; apply ImpR, exfalso; exch 0; auto with proof
+end; trivial; try (solve [eapply imp_cut; eauto]);
+try solve[apply weakening, (tautology_cut HP); trivial; try apply weak_cut with ; auto with proof].
+apply IHψ2.
+apply ImpLAnd in HP.
+apply additive_cut with ((φ ψ1 ψ2) θ).
+- apply weakening, ImpR, HP.
+- apply ImpL; [|auto with proof].
+  apply weakening, ImpR. exch 0. apply ImpL; [|auto with proof].
+  apply weakening, make_conj_complete_L, generalised_axiom.
+Qed.
+ +
+Global Hint Resolve make_impl_sound_L : proof.
+ +
+Lemma make_impl_sound_R Γ φ ψ: Γ (φ ψ) -> Γ φ ψ.
+Proof.
+revert φ. induction ψ; intros φ HP; simpl; repeat case decide; intros;
+repeat match goal with
+| H : obviously_smaller _ _ = Lt |- _ => apply obviously_smaller_compatible_LT in H
+| H : obviously_smaller _ _ = Gt |- _ => apply obviously_smaller_compatible_GT in H
+| H : is_negation _ _ |- _ => rewrite H in *; apply ImpR; eapply additive_cut; [apply ImpR_rev, HP| exch 0; auto with *]
+end; trivial; auto with proof;
+try (solve[peapply (cut Γ φ); auto with proof; eapply TopL_rev; eauto]).
+apply IHψ2, ImpR, make_conj_sound_L, AndL, ImpR_rev, ImpR_rev, HP.
+Qed.
+ +
+Global Hint Resolve make_impl_sound_R : proof.
+ +
+Lemma make_impl_sound_L2 Γ φ1 φ2 ψ θ: Γ•(φ1 (φ2 ψ)) θ -> Γ•(φ1 (φ2 ψ)) θ.
+Proof.
+intro HP. apply make_impl_sound_L in HP.
+apply additive_cut with (φ1 (φ2 ψ)).
+- apply make_impl_sound_L, make_impl_sound_R.
+  apply ImpR. exch 0. apply ImpL.
+  + apply weakening, generalised_axiom.
+  + exch 0. apply weakening, make_impl_sound_L, generalised_axiom.
+- exch 0. apply weakening, HP.
+Qed.
+ +
+Global Hint Resolve make_impl_sound_L2: proof.
+ +
+Lemma make_impl_sound_L2' Γ φ1 φ2 ψ θ: Γ•((φ1 φ2) ψ) θ -> Γ•((φ1 φ2) ψ) θ.
+Proof.
+intro HP. apply make_impl_sound_L.
+apply additive_cut with ((φ1 φ2) ψ); [|exch 0; apply weakening, HP].
+apply ImpR. exch 0. apply ImpL.
+- apply weakening, make_impl_sound_R, generalised_axiom.
+- apply generalised_axiom.
+Qed.
+ +
+Lemma make_impl_complete_L Γ φ ψ θ: Γ•(φ ψ) θ -> Γ•(φ ψ) θ.
+Proof.
+intro HP.
+apply additive_cut with ψ); [|exch 0; apply weakening, HP].
+apply make_impl_sound_R, generalised_axiom.
+Qed.
+ +
+Lemma make_impl_complete_L2 Γ φ1 φ2 ψ θ: Γ•(φ1 (φ2 ψ)) θ -> Γ•(φ1 (φ2 ψ)) θ.
+Proof.
+intro HP. apply make_impl_complete_L in HP.
+apply additive_cut with (φ1 φ2 ψ); [|exch 0; apply weakening, HP].
+apply ImpR. exch 0. apply ImpL.
+- apply weakening, generalised_axiom.
+- exch 0. apply weakening, make_impl_sound_R, generalised_axiom.
+Qed.
+ +
+Lemma make_impl_complete_R Γ φ ψ: Γ φ ψ -> Γ (φ ψ).
+Proof.
+intro HP.
+apply additive_cut with ψ); [apply HP| apply make_impl_sound_L, generalised_axiom ].
+Qed.
+ +
+Lemma OrR_idemp Γ ψ : Γ ψ ψ -> Γ ψ.
+Proof. intro Hp. dependent induction Hp; auto with proof. Qed.
+ +
+Lemma strongness φ : φ φ.
+Proof.
+apply BoxR. box_tac. apply weakening, open_box_L, generalised_axiom.
+Qed.
+
+
+ +
+ + + diff --git a/ISL.Order.html b/ISL.Order.html new file mode 100644 index 0000000..c1b88ff --- /dev/null +++ b/ISL.Order.html @@ -0,0 +1,497 @@ + + + + + + + + + + + + + +
+
+

ISL.Order

+ +
+Require Export ISL.Environments.
+ +
+(* Note 3 or 4 would suffice for IPC ; iSL requires 5 *)
+Definition env_weight (Γ : list form) := list_sum (map (fun x => 5^ weight x) Γ).
+ +
+Lemma env_weight_disj_union Γ Δ : env_weight (Γ ++ Δ) = env_weight Γ + env_weight Δ.
+Proof.
+unfold env_weight. now rewrite map_app, list_sum_app.
+Qed.
+ +
+(* TODO: dirty hack *)
+Local Notation "Δ '•' φ" := (cons φ Δ).
+ +
+Lemma env_weight_add Γ φ : env_weight (Γ φ) = env_weight Γ + (5 ^ weight φ).
+Proof.
+unfold env_weight. simpl. lia.
+Qed.
+ +
+Global Hint Rewrite env_weight_add : order.
+ +
+Definition env_order := ltof (list form) env_weight.
+Infix "≺" := env_order (at level 150).
+ +
+Lemma env_weight_singleton (φ : form) : env_weight [ φ ] = 5 ^ weight φ.
+Proof.
+unfold env_weight, ltof. simpl. lia.
+Qed.
+ +
+Lemma env_order_singleton (φ ψ : form) : weight φ < weight ψ -> [φ ] [ ψ ].
+Proof.
+intro Hw. unfold env_order, ltof. do 2 rewrite env_weight_singleton.
+apply Nat.pow_lt_mono_r. lia. trivial.
+Qed.
+ +
+Definition env_order_refl Δ Δ' := (Δ Δ') \/ Δ ≡ₚ Δ'.
+ +
+Local Notation "Δ ≼ Δ'" := (env_order_refl Δ Δ') (at level 150).
+ +
+Global Instance Proper_env_weight: Proper ((≡ₚ) ==> (=)) env_weight.
+Proof.
+intros Γ Δ Heq. unfold env_weight. now rewrite Heq.
+Qed.
+ +
+Global Instance Proper_env_order_refl_env_weight:
+  Proper ((env_order_refl) ==> le) env_weight.
+Proof.
+intros Γ Δ.
+unfold env_order. intros [Hle | Heq].
+- auto with *.
+- now rewrite Heq.
+Qed.
+ +
+Global Hint Resolve Proper_env_order_refl_env_weight : order.
+ +
+Global Hint Unfold form_order : mset.
+ +
+Global Instance env_order_trans : Transitive env_order.
+Proof. unfold env_order, env_weight, ltof. auto with *. Qed.
+ +
+Definition wf_env_order : well_founded env_order.
+Proof. now apply well_founded_lt_compat with env_weight.
+Defined.
+ +
+(* We introduce a notion of "pointed" environment, which is simply
+ * a pair (Δ, φ), where Δ is an environment and φ is a formula,
+ * not necessarily an element of Δ.  *)

+Definition pointed_env := (list form * form)%type.
+ +
+(* The order on pointed environments is given by considering the
+ * environment order on the sum of Δ and {φ}. *)

(* TODO: modified from G4IP : right-hand side counts twice, to account for the right box rule. Is this working? *)
+Definition pointed_env_order (pe1 : pointed_env) (pe2 : pointed_env) :=
+  env_order (fst pe1 snd pe1 snd pe1) (fst pe2 snd pe2 snd pe2).
+ +
+Lemma wf_pointed_order : well_founded pointed_env_order.
+Proof. apply well_founded_ltof. Qed.
+ +
+Definition pointed_env_ms_order (Γφ Δψ : env * form) :=
+  pointed_env_order (elements Γφ.1, Γφ.2) (elements Δψ.1, Δψ.2).
+ +
+Lemma wf_pointed_env_ms_order : well_founded pointed_env_ms_order.
+Proof. apply well_founded_ltof. Qed.
+ +
+Infix "≺·" := pointed_env_order (at level 150).
+ +
+Lemma env_order_equiv_right_compat {Δ Δ' Δ'' }:
+  Δ' ≡ₚ Δ'' ->
+  (Δ Δ'') ->
+  Δ Δ'.
+Proof.
+unfold equiv, env_order, ltof, env_weight. intro Heq. rewrite Heq. trivial.
+Qed.
+ +
+Lemma env_order_equiv_left_compat {Δ Δ' Δ'' }:
+  Δ ≡ₚ Δ'' ->
+  (Δ'' Δ') ->
+  Δ Δ'.
+Proof. unfold equiv, env_order, ltof, env_weight. intro Heq. rewrite Heq. trivial. Qed.
+ +
+Global Instance Proper_env_order : Proper ((≡ₚ) ==> (≡ₚ) ==> (fun x y => x <-> y)) env_order.
+Proof. intros Δ1 Δ2 H12 Δ3 Δ4 H34; unfold equiv, env_order, ltof, env_weight. rewrite H12, H34. tauto. Qed.
+ +
+Global Instance Proper_env_order_refl : Proper ((≡ₚ) ==> (≡ₚ) ==> (fun x y => x <-> y)) env_order_refl.
+Proof.
+intros Δ1 Δ2 H12 Δ3 Δ4 H34; unfold equiv, env_order, ltof, env_weight, env_order_refl.
+now rewrite H12, H34.
+Qed.
+ +
+Lemma env_order_1 Δ φ1 φ : weight φ1 < weight φ -> Δ φ1 Δ φ.
+Proof.
+intros Hw. unfold env_order, ltof. do 2 rewrite env_weight_add.
+apply Nat.add_lt_mono_l. apply Nat.pow_lt_mono_r. lia. trivial.
+Qed.
+ +
+Local Hint Resolve Nat.pow_lt_mono_r : order.
+ +
+Lemma env_order_compat Δ Δ' φ1 φ : weight φ1 < weight φ -> (Δ' Δ) -> Δ' φ1 Δ φ.
+Proof.
+intros. unfold env_order, ltof. repeat rewrite env_weight_add.
+apply Nat.add_le_lt_mono; auto with *.
+Qed.
+ +
+Global Hint Resolve env_order_compat : order.
+ +
+Lemma env_order_compat' Δ Δ' φ1 φ : weight φ1 weight φ -> (Δ' Δ) -> Δ' φ1 Δ φ.
+Proof.
+intros. unfold env_order, ltof. repeat rewrite env_weight_add.
+apply Nat.add_lt_le_mono; auto with *. now apply Nat.pow_le_mono_r.
+Qed.
+ +
+Lemma env_order_add_compat Δ Δ' φ : (Δ Δ') -> (Δ φ) (Δ' φ).
+Proof.
+unfold env_order, ltof. do 2 rewrite env_weight_add. lia.
+Qed.
+ +
+(* TODO: this is just a special case *)
+Lemma env_order_disj_union_compat_left Δ Δ' Δ'':
+  (Δ Δ'') -> Δ ++ Δ' Δ'' ++ Δ'.
+Proof.
+unfold env_order, ltof. intro. do 2 rewrite env_weight_disj_union. lia.
+Qed.
+ +
+Lemma env_order_disj_union_compat_right Δ Δ' Δ'':
+  (Δ Δ'') -> Δ' ++ Δ Δ' ++ Δ''.
+Proof.
+unfold env_order, ltof. repeat rewrite env_weight_disj_union. lia.
+Qed.
+ +
+Global Hint Resolve env_order_disj_union_compat_right : order.
+ +
+Lemma env_order_disj_union_compat Δ Δ' Δ'' Δ''':
+  (Δ Δ'') -> (Δ' Δ''') -> Δ ++ Δ' Δ'' ++ Δ'''.
+Proof.
+unfold env_order, ltof. repeat rewrite env_weight_disj_union. lia.
+Qed.
+ +
+Lemma env_order_refl_disj_union_compat Δ Δ' Δ'' Δ''':
+  (env_order_refl Δ Δ'') -> (env_order_refl Δ' Δ''') -> env_order_refl (Δ ++ Δ') (Δ'' ++ Δ''').
+Proof.
+unfold env_order_refl, env_order, ltof. repeat rewrite env_weight_disj_union.
+intros [Hlt1 | Heq1] [Hlt2 | Heq2]; try rewrite Heq1; try rewrite Heq2; try lia.
+right. trivial.
+Qed.
+ +
+Global Hint Resolve env_order_refl_disj_union_compat : order.
+ +
+Hint Unfold env_order_refl : order.
+Lemma env_order_disj_union_compat_strong_right Δ Δ' Δ'' Δ''':
+  (Δ Δ'') -> (Δ' Δ''') -> Δ ++ Δ' Δ'' ++ Δ'''.
+Proof.
+intros H1 H2.
+destruct H2 as [Hlt|Heq].
+- unfold env_order, ltof in *. do 2 rewrite env_weight_disj_union. lia.
+- rewrite Heq. now apply env_order_disj_union_compat_left.
+Qed.
+ +
+Lemma env_order_disj_union_compat_strong_left Δ Δ' Δ'' Δ''':
+  (Δ Δ'') -> (Δ' Δ''') -> Δ ++ Δ' Δ'' ++ Δ'''.
+Proof.
+intros H1 H2.
+destruct H1 as [Hlt|Heq].
+- unfold env_order, ltof in *. do 2 rewrite env_weight_disj_union. lia.
+- rewrite Heq. now apply env_order_disj_union_compat_right.
+Qed.
+ +
+Global Hint Resolve env_order_disj_union_compat_strong_left : order.
+Global Hint Rewrite elements_open_boxes : order.
+ +
+Lemma weight_open_box φ : weight ( φ) weight φ.
+Proof. destruct φ; simpl; lia. Qed.
+ +
+Lemma open_boxes_env_order Δ : (map open_box Δ) Δ.
+Proof.
+induction Δ as [|φ Δ].
+- right. trivial.
+- destruct IHΔ as [Hlt | Heq]; simpl.
+  + left. apply env_order_compat'; trivial. apply weight_open_box.
+  + rewrite Heq. auto with order. destruct φ; simpl; try auto with order.
+       left. auto with order.
+Qed.
+ +
+Global Hint Resolve open_boxes_env_order : order.
+ +
+Lemma env_order_0 Δ φ: Δ Δ φ.
+Proof.
+unfold env_order, ltof. rewrite env_weight_add.
+apply Nat.lt_add_pos_r. transitivity (5 ^ 0). simpl. lia. apply Nat.pow_lt_mono_r. lia.
+apply weight_pos.
+Qed.
+ +
+(* TODO: ok? to replace env_order_* ?
+Lemma env_order_l (Δ' Δ: env) φ1 φ: weight φ1 < weight φ -> (Δ' ≺ Δ • φ) -> (Δ' • φ1) ≺ (Δ • φ).
+Proof.
+*)

+ +
+Local Lemma pow5_gt_0 n : 1 5 ^ n.
+Proof. transitivity (5^0). simpl. lia. apply Nat.pow_le_mono_r; lia. Qed.
+ +
+Local Hint Resolve pow5_gt_0: order.
+ +
+Lemma env_order_2 Δ Δ' φ1 φ2 φ: weight φ1 < weight φ -> weight φ2 < weight φ ->
+  (Δ' Δ) -> Δ' φ1 φ2 Δ φ.
+Proof.
+intros Hw1 Hw2 Hor.
+unfold env_order, ltof. repeat rewrite env_weight_add.
+apply Proper_env_order_refl_env_weight in Hor.
+replace (weight φ) with (S (pred (weight φ))) by lia.
+apply Nat.lt_le_pred in Hw1, Hw2.
+simpl. repeat rewrite Nat.add_assoc.
+pose (pow5_gt_0 (Init.Nat.pred (weight φ))).
+rewrite Nat.add_0_r.
+repeat (apply Nat.add_lt_le_mono; [|apply Nat.pow_le_mono_r; lia]).
+pose (pow5_gt_0 (Init.Nat.pred (weight φ))).
+lia.
+Qed.
+ +
+Lemma env_order_3 Δ Δ' φ1 φ2 φ3 φ:
+  weight φ1 < weight φ -> weight φ2 < weight φ -> weight φ3 < weight φ -> (Δ' Δ) ->
+  Δ' φ1 φ2 φ3 Δ φ.
+Proof.
+intros Hw1 Hw2 Hw3 Hor.
+unfold env_order, ltof. repeat rewrite env_weight_add.
+apply Proper_env_order_refl_env_weight in Hor.
+replace (weight φ) with (S (pred (weight φ))) by lia.
+apply Nat.lt_le_pred in Hw1, Hw2.
+simpl. repeat rewrite Nat.add_assoc.
+pose (pow5_gt_0 (Init.Nat.pred (weight φ))).
+rewrite Nat.add_0_r.
+do 3 (apply Nat.add_lt_le_mono; [|apply Nat.pow_le_mono_r; lia]).
+pose (pow5_gt_0 (Init.Nat.pred (weight φ))).
+lia.
+Qed.
+ +
+Lemma env_order_4 Δ Δ' φ1 φ2 φ3 φ4 φ:
+  weight φ1 < weight φ -> weight φ2 < weight φ -> weight φ3 < weight φ -> weight φ4 < weight φ ->
+   (Δ' Δ) -> Δ' φ1 φ2 φ3 φ4 Δ φ.
+Proof.
+intros Hw1 Hw2 Hw3 Hw4 Hor.
+unfold env_order, ltof. repeat rewrite env_weight_add.
+apply Proper_env_order_refl_env_weight in Hor.
+replace (weight φ) with (S (pred (weight φ))) by lia.
+apply Nat.lt_le_pred in Hw1, Hw2.
+simpl. repeat rewrite Nat.add_assoc.
+pose (pow5_gt_0 (Init.Nat.pred (weight φ))).
+rewrite Nat.add_0_r.
+do 4 (apply Nat.add_lt_le_mono; [|apply Nat.pow_le_mono_r; lia]).
+pose (pow5_gt_0 (Init.Nat.pred (weight φ))).
+lia.
+Qed.
+ +
+Lemma env_order_cancel_right Δ Δ' φ: (Δ Δ') -> Δ (Δ' φ).
+Proof. etransitivity; [|apply env_order_0]. assumption. Qed.
+ +
+Lemma env_order_eq_add Δ Δ' φ: (Δ Δ') -> (Δ φ) (Δ' φ).
+Proof. intros[Heq|Hlt]. left. now apply env_order_add_compat. right. ms. Qed.
+ +
+Global Hint Resolve env_order_0 : order.
+Global Hint Resolve env_order_1 : order.
+Global Hint Resolve env_order_2 : order.
+Global Hint Resolve env_order_3 : order.
+Global Hint Resolve env_order_4 : order.
+Global Hint Resolve env_order_add_compat : order.
+Global Hint Resolve env_order_cancel_right : order.
+Global Hint Resolve env_order_eq_add : order.
+Global Hint Extern 1 (?a < ?b) => subst; simpl; lia : order.
+ +
+Ltac get_diff_form g := match g with
+| ?Γ {[]} => φ
+| _ (?Γ {[]}) => φ
+| _ (rm_) => φ
+| ?Γ _ => get_diff_form Γ
+end.
+ +
+Ltac get_diff_env g := match g with
+| ?Γ {[]} => Γ
+| ?Γ _ => get_diff_env Γ
+end.
+ +
+Global Hint Rewrite open_boxes_remove : order.
+ +
+Lemma remove_env_order Δ φ: rm φ Δ Δ.
+Proof.
+induction Δ as [|ψ Δ].
+- simpl. right. auto.
+- simpl. destruct form_eq_dec; auto with order.
+Qed.
+ +
+Global Hint Resolve remove_env_order : order.
+ +
+Lemma remove_In_env_order_refl Δ φ: In φ Δ -> rm φ Δ φ Δ.
+Proof.
+induction Δ as [|ψ Δ].
+- intro Hf; contradict Hf.
+- intros [Heq | Hin].
+  + subst. simpl. destruct form_eq_dec; [|tauto]. auto with order.
+  + specialize (IHΔ Hin). simpl. case form_eq_dec as [Heq | Hneq].
+      * subst. auto with order.
+      * rewrite (Permutation_swap ψ φ (rm φ Δ)). auto with order.
+Qed.
+ +
+Global Hint Resolve remove_In_env_order_refl : order.
+ +
+Lemma env_order_lt_le_trans Γ Γ' Γ'' : (Γ Γ') -> (Γ' Γ'') -> Γ Γ''.
+Proof. intros Hlt [Hlt' | Heq]. transitivity Γ'; auto with order. now rewrite <- Heq. Qed.
+ +
+Lemma env_order_le_lt_trans Γ Γ' Γ'' : (Γ Γ') -> (Γ' Γ'') -> Γ Γ''.
+Proof. intros [Hlt' | Heq] Hlt. transitivity Γ'; auto with order. now rewrite Heq. Qed.
+ +
+Lemma remove_In_env_order Δ φ: In φ Δ -> rm φ Δ Δ.
+Proof.
+intro Hin. apply remove_In_env_order_refl in Hin.
+eapply env_order_lt_le_trans; [|apply Hin]. auto with order.
+Qed.
+ +
+Global Hint Resolve remove_In_env_order : order.
+ +
+Lemma elem_of_list_In_1 {A : Type}: (l : list A) (x : A), x l -> In x l.
+Proof. apply elem_of_list_In. Qed.
+ +
+Global Hint Resolve elem_of_list_In_1 : order.
+ +
+Lemma elements_elem_of {Γ : env} {φ : form} : φ Γ -> elements Γ ≡ₚ φ :: elements (Γ {[φ]}).
+Proof. intro Hin. rewrite <- elements_env_add. apply Proper_elements, difference_singleton, Hin. Qed.
+ +
+Ltac prepare_order :=
+repeat (apply env_order_add_compat);
+unfold pointed_env_order; subst; simpl; repeat rewrite open_boxes_add; try match goal with
+| Δ := _ |- _ => subst Δ; try prepare_order
+| Hin : ?a ?Γ |- context[elements ?Γ] => rewrite (elements_elem_of Hin); try prepare_order
+| H : _ list_to_set_disj _ |- _ => apply elem_of_list_to_set_disj in H; try prepare_order
+| H : ?ψ ?Γ |- ?Γ' ?Γ => let ψ' := (get_diff_form Γ') in
+    apply (env_order_equiv_right_compat (difference_singleton Γ ψ' H)) ||
+    (eapply env_order_lt_le_trans ; [| apply (remove_In_env_order_refl _ ψ'); try apply elem_of_list_In; trivial])
+| H : ?ψ ?Γ |- ?Γ' ?Γ ?φ => let ψ' := (get_diff_form Γ') in
+    apply (env_order_equiv_right_compat (equiv_disj_union_compat_r(difference_singleton Γ ψ' H)))
+| H : ?ψ ?Γ |- ?Γ' ?Γ _ _ => let ψ' := (get_diff_form Γ') in
+apply (env_order_equiv_right_compat (equiv_disj_union_compat_r(equiv_disj_union_compat_r(difference_singleton Γ ψ' H)))) ||
+(eapply env_order_le_lt_trans; [| apply env_order_add_compat;
+eapply env_order_lt_le_trans; [| (apply env_order_eq_add; apply (remove_In_env_order_refl _ ψ'); try apply elem_of_list_In; trivial) ] ] )
+end.
+ +
+(* ad hoc *)
+Lemma openboxes_env_order Δ δ : (map open_box Δ) δ δ Δ δ.
+Proof.
+induction Δ as [|x Δ].
+- simpl. unfold env_order, ltof, env_weight. simpl.
+  repeat rewrite <- plus_n_O. apply Nat.add_lt_mono_l.
+  rewrite plus_n_O at 1. auto with *.
+- apply (@env_order_equiv_right_compat _ _ (Δ δ x)). constructor.
+  simpl.
+  eapply (@env_order_equiv_left_compat _ _ (map open_box Δ δ δ x)).
+  + do 2 (rewrite (Permutation_swap δ ( x)); apply Permutation_skip). trivial.
+  + case x; intros; simpl; try (solve[now apply env_order_add_compat]).
+      transitivity (Δ δ f).
+      * auto with *.
+      * apply env_order_1. simpl. auto.
+Qed.
+ +
+Global Hint Resolve openboxes_env_order : order.
+ +
+Ltac order_tac :=
+try unfold pointed_env_ms_order; prepare_order;
+repeat rewrite elements_env_add;
+simpl; auto 10 with order;
+try (apply env_order_disj_union_compat_right; order_tac).
+
+
+ +
+ + + diff --git a/ISL.PropQuantifiers.html b/ISL.PropQuantifiers.html new file mode 100644 index 0000000..0550ba9 --- /dev/null +++ b/ISL.PropQuantifiers.html @@ -0,0 +1,1209 @@ + + + + + + + + + + + + + +
+
+

ISL.PropQuantifiers

+ +
+Require Import ISL.Sequents.
+Require Import ISL.SequentProps ISL.Order ISL.Optimizations.
+Require Import Coq.Program.Equality. (* for dependent induction *)
+ +
+
+ +
+

Overview: Propositional Quantifiers

+ + +
+ +The main theorem proved in this file was first proved as Theorem 1 in: + +
+ +(Pitts 1992). A. M. Pitts. On an interpretation of second order quantification in first order intuitionistic propositional logic. J. Symb. Log., 57(1):33–52. +It has been further extended to handle iSL + +
+ +It consists of two parts: + +
+ +1) the inductive construction of the propositional quantifiers; + +
+ +2) a proof of its correctness. +
+
+ +
+Section UniformInterpolation.
+ +
+
+ +
+Throughout the construction and proof, we fix a variable p, with respect to + which the propositional quantifier will be computed. +
+
+Variable p : variable.
+ +
+
+ +
+

Definition of propositional quantifiers.

+ +
+
+ +
+Section PropQuantDefinition.
+ +
+
+ +
+We define the formulas Eφ and Aφ associated to any formula φ. This + is an implementation of Pitts' Table 5, together with a (mostly automatic) + proof that the definition terminates +
+
+ +
+Local Notation "Δ '•' φ" := (cons φ Δ).
+ +
+(* solves the obligations of the following programs *)
+Obligation Tactic := intros; order_tac.
+ +
+Notation "□⁻¹ Γ" := (map open_box Γ) (at level 75).
+ +
+
+ +
+First, the implementation of the rules for calculating E. The names of the rules + refer to the table in Pitts' paper. note the use of "lazy" conjunctions, disjunctions and implications +
+
+Program Definition e_rule {Δ : list form } {ϕ : form}
+  (EA0 : pe (Hpe : pe ≺· (Δ, ϕ)), form * form)
+  (θ: form) (Hin : θ Δ) : form :=
+let E Δ H := fst (EA0 (Δ, ϕ) H) in
+let A pe0 H := snd (EA0 pe0 H) in
+let Δ' := rm θ Δ in
+match θ with
+| Bot => (* E0 *)
+| Var q =>
+    if decide (p = q) then (* default *)
+    else q (* E1 modified *)
+(* E2 *)
+| δ₁ δ₂ => E ((Δ'δ₁)•δ₂) _
+(* E3 *)
+| δ₁ δ₂ => E (Δ'δ₁) _ E (Δ' δ₂) _
+| Var q δ =>
+    if decide (Var q Δ) then E (Δ'δ) _ (* E5 modified *)
+    else if decide (p = q) then
+    else q E (Δ'δ) _ (* E4 *)
+(* E6 *)
+| (δ₁ δ₂)→ δ₃ => E (Δ'•(δ₁ (δ₂ δ₃))) _
+(* E7 *)
+| (δ₁ δ₂)→ δ₃ => E (Δ'•(δ₁ δ₃)•(δ₂ δ₃)) _
+(* E8 modified *)
+| ((δ₁ δ₂)→ δ₃) =>
+  (E (Δ'•(δ₂ δ₃) δ₁) _ A (Δ'•(δ₂ δ₃) δ₁, δ₂) _) E (Δ'δ₃) _
+| Bot _ =>
+| φ => □(E ((⁻¹ Δ') φ ) _) (* very redundant ; identical for each box *)
+| (δ1 δ2) => (□(E((⁻¹ Δ') δ2 δ1) _ A((⁻¹ Δ') δ2 δ1, δ1) _)) E(Δ' δ2) _
+end.
+ +
+
+ +
+The implementation of the rules for defining A is separated into two pieces. + Referring to Table 5 in Pitts, the definition a_rule_env handles A1-8 and A10, + and the definition a_rule_form handles A9 and A11-13. +
+
+Program Definition a_rule_env {Δ : list form} {ϕ : form}
+  (EA0 : pe (Hpe : pe ≺· (Δ, ϕ)), form * form)
+  (θ: form) (Hin : θ Δ) : form :=
+let E Δ H := fst (EA0 (Δ, ϕ) H) in
+let A pe0 H := snd (EA0 pe0 H) in
+let Δ' := rm θ Δ in
+match θ with
+| Var q =>
+    if decide (p = q)
+    then
+      if decide (Var p = ϕ) then (* A10 *)
+      else
+    else (* A1 modified : A (Δ', ϕ) can be removed *)
+(* A2 *)
+| δ₁ δ₂ => A ((Δ'δ₁)•δ₂, ϕ) _
+(* A3 *)
+| δ₁ δ₂ =>
+      (E (Δ'δ₁) _ A (Δ'δ₁, ϕ) _)
+   (E (Δ'δ₂) _ A (Δ'δ₂, ϕ) _)
+| Var q δ =>
+    if decide (Var q Δ) then A (Δ'δ, ϕ) _ (* A5 modified *)
+    else if decide (p = q) then
+    else q A (Δ'δ, ϕ) _ (* A4 *)
+(* A6 *)
+| (δ₁ δ₂)→ δ₃ =>
+  A (Δ'•(δ₁ (δ₂ δ₃)), ϕ) _
+(* A7 *)
+| (δ₁ δ₂)→ δ₃ =>
+  A ((Δ'•(δ₁ δ₃))•(δ₂ δ₃), ϕ) _
+(* A8 modified*)
+| ((δ₁ δ₂)→ δ₃) =>
+  (E (Δ'•(δ₂ δ₃) δ₁) _ A (Δ'•(δ₂ δ₃) δ₁, δ₂) _)
+   A (Δ'δ₃, ϕ) _
+| Bot =>
+| Bot _ =>
+| δ =>
+| ((δ1) δ2) => (□(E((⁻¹ Δ')• δ2 δ1) _ A((⁻¹ Δ')• δ2 δ1, δ1) _)) A(Δ' δ2, ϕ) _
+(* using ⊼ here breaks congruence *)
+end.
+ +
+(* make sure that the proof obligations do not depend on EA0 *)
+Obligation Tactic := intros Δ ϕ _ _ _; intros; order_tac.
+Program Definition a_rule_form {Δ : list form} {ϕ : form}
+  (EA0 : pe (Hpe : pe ≺· (Δ, ϕ)), form * form) : form :=
+let E pe0 H := fst (EA0 pe0 H) in
+let A pe0 H := snd (EA0 pe0 H) in
+match ϕ with
+| Var q =>
+    if decide (p = q) (* TODO : change this to p∈Vars(ϕ) *)
+    then
+    else Var q (* A9 *)
+(* A11 *)
+| ϕ₁ ϕ₂ => A (Δ, ϕ₁) _ A (Δ, ϕ₂) _
+(* A12 *)
+| ϕ₁ ϕ₂ => A (Δ, ϕ₁) _ A (Δ, ϕ₂) _
+(* A13 *)
+| ϕ₁ ϕ₂ => E (Δϕ₁, ϕ₂) _ A (Δϕ₁, ϕ₂) _
+    (* TODO would a general right-implication rule be useful efficient? *)
+| Bot =>
+| δ => □((E ((⁻¹ Δ) δ, δ) _) A((⁻¹ Δ) δ, δ) _)
+end.
+ +
+Obligation Tactic := intros; order_tac.
+Program Fixpoint EA (pe : list form * form) {wf pointed_env_order pe} :=
+  let Δ := fst pe in
+  ( (in_map Δ (e_rule EA)),
+    (in_map Δ (a_rule_env EA)) a_rule_form EA).
+Next Obligation. apply wf_pointed_order. Defined.
+ +
+Definition E pe := (EA pe).1.
+Definition A pe := (EA pe).2.
+ +
+Definition Ef (ψ : form) := E ([ψ], ).
+Definition Af (ψ : form) := A ([], ψ).
+ +
+
+ +
+Congruence lemmas: if we apply any of e_rule, a_rule_env, or a_rule_form + to two equal environments, then they give the same results. +
+
+Lemma e_rule_cong Δ ϕ θ (Hin: θ Δ) EA1 EA2:
+  (forall pe Hpe, EA1 pe Hpe = EA2 pe Hpe) ->
+  @e_rule Δ ϕ EA1 θ Hin = @e_rule Δ ϕ EA2 θ Hin.
+Proof.
+  intro Heq.
+  destruct θ; simpl; try (destruct θ1); repeat (destruct decide);
+  f_equal; repeat erewrite Heq; trivial.
+Qed.
+ +
+Lemma e_rule_cong_strong Δ ϕ θ (Hin1 Hin2: θ Δ) EA1 EA2:
+  (forall pe Hpe1 Hpe2, EA1 pe Hpe1 = EA2 pe Hpe2) ->
+  @e_rule Δ ϕ EA1 θ Hin1 = @e_rule Δ ϕ EA2 θ Hin2.
+Proof.
+  intro Heq.
+  destruct θ; simpl; try (destruct θ1); repeat (destruct decide);
+  f_equal; repeat erewrite Heq; trivial.
+Qed.
+ +
+Lemma a_rule_env_cong Δ ϕ θ Hin EA1 EA2:
+  (forall pe Hpe, EA1 pe Hpe = EA2 pe Hpe) ->
+  @a_rule_env Δ ϕ EA1 θ Hin = @a_rule_env Δ ϕ EA2 θ Hin.
+Proof.
+  intro Heq.
+  destruct θ; simpl; trivial; repeat (destruct decide);
+  f_equal; repeat erewrite Heq; trivial;
+  destruct θ1; try (destruct decide); trivial; simpl;
+  repeat erewrite Heq; trivial; (destruct decide); trivial.
+Qed.
+ +
+Lemma a_rule_env_cong_strong Δ ϕ θ Hin1 Hin2 EA1 EA2:
+  (forall pe Hpe1 Hpe2, EA1 pe Hpe1 = EA2 pe Hpe2) ->
+  @a_rule_env Δ ϕ EA1 θ Hin1 = @a_rule_env Δ ϕ EA2 θ Hin2.
+Proof.
+  intro Heq.
+  destruct θ; simpl; trivial; repeat (destruct decide);
+  f_equal; repeat erewrite Heq; trivial;
+  destruct θ1; try (destruct decide); trivial; simpl;
+  repeat erewrite Heq; trivial; (destruct decide); trivial.
+Qed.
+ +
+Lemma a_rule_form_cong Δ ϕ EA1 EA2:
+  (forall pe Hpe, EA1 pe Hpe = EA2 pe Hpe) ->
+  @a_rule_form Δ ϕ EA1 = @a_rule_form Δ ϕ EA2.
+Proof.
+  intro Heq.
+  destruct ϕ; simpl; repeat (destruct decide); trivial;
+  repeat (erewrite Heq; eauto); trivial.
+Qed.
+ +
+Lemma a_rule_form_cong_strong Δ ϕ EA1 EA2:
+  (forall pe Hpe1 Hpe2, EA1 pe Hpe1 = EA2 pe Hpe2) ->
+  @a_rule_form Δ ϕ EA1 = @a_rule_form Δ ϕ EA2.
+Proof.
+  intro Heq.
+  destruct ϕ; simpl; repeat (destruct decide); trivial;
+  repeat (erewrite Heq; eauto); trivial.
+Qed.
+ +
+Lemma EA_eq Δ ϕ:
+  (E (Δ, ϕ) = (in_map Δ (@e_rule Δ ϕ (λ pe _, EA pe)))) /\
+  (A (Δ, ϕ) = ( (in_map Δ (@a_rule_env Δ ϕ (λ pe _, EA pe))))
+       @a_rule_form Δ ϕ (λ pe _, EA pe)).
+Proof.
+simpl. unfold E, A, EA. simpl.
+rewrite -> Wf.Fix_eq.
+- simpl. split; trivial.
+- intros Δ' f g Heq. f_equal; f_equal.
+  + apply in_map_ext. intros. apply e_rule_cong; intros.
+      now rewrite Heq.
+  + f_equal. apply in_map_ext. intros. apply a_rule_env_cong; intros.
+      now rewrite Heq.
+  + apply a_rule_form_cong; intros. now rewrite Heq.
+Qed.
+ +
+Definition E_eq Δ ϕ := proj1 (EA_eq Δ ϕ).
+Definition A_eq Δ ϕ := proj2 (EA_eq Δ ϕ).
+ +
+End PropQuantDefinition.
+ +
+
+ +
+

Correctness

+ +
+
+Section Correctness.
+ +
+
+ +
+This section contains the proof of Proposition 5, the main correctness result, stating that the E- and A-formulas defined above are indeed existential and universal propositional quantified versions of the original formula, respectively. +
+ +

(i) Variables

+ +
+
+Section VariablesCorrect.
+ +
+
+ +
+In this subsection we prove (i), which states that the variable p no longer + occurs in the E- and A-formulas, and that the E- and A-formulas contain no more variables than the original formula. + +
+
+ +
+(* A general tactic for variable occurrences *)
+Ltac vars_tac :=
+intros; subst;
+repeat match goal with
+| HE : context [occurs_in ?x (?E _ _)], H : occurs_in ?x (?E _ _) |- _ =>
+    apply HE in H
+end;
+intuition;
+repeat match goal with | H : exists x, _ |- _ => destruct H end;
+intuition;
+simpl in *; in_tac; try (split; [tauto || auto with *|]); simpl in *;
+try match goal with
+| H : occurs_in _ (?a (?b ?c)) |- _ => apply occurs_in_make_impl2 in H
+| H : occurs_in _ (?a ?b) |- _ => apply occurs_in_make_impl in H
+| H : occurs_in _ (?a ?b) |- _ => apply occurs_in_make_disj in H
+| H : occurs_in _ (?a ?b) |- _ => apply occurs_in_make_conj in H
+|H1 : ?x0 ( ?Δ), H2 : occurs_in ?x ?x0 |- _ =>
+      apply (occurs_in_open_boxes _ _ _ H2) in H1
+|H1 : ?x0 (map open_box ?Δ), H2 : occurs_in ?x ?x0 |- _ =>
+      apply (occurs_in_map_open_box _ _ _ H2) in H1
+end; repeat rewrite elem_of_cons in * ; intuition; subst;
+repeat match goal with | H : exists x, _ |- _ => destruct H end; intuition;
+try multimatch goal with
+| H : ?θ0 ?Δ0 |- context [exists θ, θ ?Δ /\ occurs_in ?x θ] =>
+  solve[try right; exists θ0; split; [eauto using remove_include|simpl; tauto]; eauto] end.
+ +
+
+ +
+

(a)

+ +
+
+ +
+Lemma e_rule_vars Δ (θ : form) (Hin : θ Δ) (ϕ : form)
+  (EA0 : pe (Hpe : pe ≺· (Δ, ϕ)), form * form) x
+  (HEA0 : pe Hpe,
+      (occurs_in x (fst (EA0 pe Hpe)) -> x p θ, θ pe.1 /\ occurs_in x θ) /\
+      (occurs_in x (snd (EA0 pe Hpe)) -> x p (occurs_in x pe.2 \/ θ, θ pe.1 /\ occurs_in x θ))) :
+occurs_in x (e_rule EA0 θ Hin) -> x p θ, θ Δ /\ occurs_in x θ.
+Proof.
+destruct θ; unfold e_rule; simpl; try tauto; try solve [repeat case decide; repeat vars_tac].
+destruct θ1; repeat case decide; repeat vars_tac.
+Qed.
+ +
+
+ +
+

(b)

+ +
+
+ +
+Lemma a_rule_env_vars Δ θ Hin ϕ
+  (EA0 : pe (Hpe : pe ≺· (Δ, ϕ)), form * form) x
+  (HEA0 : pe Hpe,
+      (occurs_in x (fst (EA0 pe Hpe)) -> x p θ, θ pe.1 /\ occurs_in x θ) /\
+      (occurs_in x (snd (EA0 pe Hpe)) -> x p (occurs_in x pe.2 \/ θ, θ pe.1 /\ occurs_in x θ))):
+occurs_in x (a_rule_env EA0 θ Hin) -> x p (occurs_in x ϕ \/ θ, θ Δ /\ occurs_in x θ).
+Proof.
+destruct θ; unfold a_rule_env; simpl; try tauto; try solve [repeat case decide; repeat vars_tac].
+destruct θ1; repeat case decide; repeat vars_tac.
+Qed.
+ +
+Lemma a_rule_form_vars Δ ϕ
+  (EA0 : pe (Hpe : pe ≺· (Δ, ϕ)), form * form) x
+  (HEA0 : pe Hpe,
+      (occurs_in x (fst (EA0 pe Hpe)) -> x p θ, θ pe.1 /\ occurs_in x θ) /\
+      (occurs_in x (snd (EA0 pe Hpe)) -> x p (occurs_in x pe.2 \/ θ, θ pe.1 /\ occurs_in x θ))):
+  occurs_in x (a_rule_form EA0) -> x p (occurs_in x ϕ \/ θ, θ Δ /\ occurs_in x θ).
+Proof.
+destruct ϕ; unfold a_rule_form; simpl; try tauto; try solve [repeat case decide; repeat vars_tac].
+Qed.
+ +
+Proposition EA_vars Δ ϕ x:
+  (occurs_in x (E (Δ, ϕ)) -> x <> p /\ θ, θ Δ /\ occurs_in x θ) /\
+  (occurs_in x (A (Δ, ϕ)) -> x <> p /\ (occurs_in x ϕ \/ ( θ, θ Δ /\ occurs_in x θ))).
+Proof.
+remember (Δ, ϕ) as pe.
+replace Δ with pe.1 by now subst.
+replace ϕ with pe.2 by now subst. clear Heqpe Δ ϕ. revert pe.
+refine (@well_founded_induction _ _ wf_pointed_order _ _).
+intros [Δ ϕ] Hind. simpl.
+rewrite E_eq, A_eq. simpl.
+split.
+(* E *)
+- intros Hocc. apply variables_conjunction in Hocc as (φ&Hin&Hφ).
+  apply in_in_map in Hin as (ψ&Hin&Heq). subst φ.
+  apply e_rule_vars in Hφ.
+  + trivial.
+  + intros; now apply Hind.
+(* A *)
+- intro Hocc. apply occurs_in_make_disj in Hocc as [Hocc|Hocc].
+  (* disjunction *)
+  + apply variables_disjunction in Hocc as (φ&Hin&Hφ).
+      apply in_in_map in Hin as (ψ&Hin&Heq). subst φ.
+      apply a_rule_env_vars in Hφ; trivial.
+  (* pointer rule *)
+  + apply a_rule_form_vars in Hocc.
+    * destruct Hocc as [Hneq [Hocc | Hocc]]; vars_tac.
+    * vars_tac; apply Hind in H; trivial; tauto.
+Qed.
+ +
+End VariablesCorrect.
+ +
+Ltac foldEA := repeat match goal with
+| |- context C [(EA ?pe).1] => fold (E pe)
+| |- context C [(EA ?pe).2] => fold (A pe)
+end.
+ +
+
+ +
+

(ii) Entailment

+ +
+
+Section EntailmentCorrect.
+ +
+
+ +
+In this section we prove (ii), which states that the E- and A-formula are + entailed by the original formula and entail the original formula, + respectively. +
+
+ +
+Hint Extern 5 (?a ?b) => order_tac : proof.
+Opaque make_disj.
+Opaque make_conj.
+ +
+Local Ltac l_tac := repeat rewrite list_to_set_disj_open_boxes;
+    rewrite (proper_Provable _ _ (list_to_set_disj_env_add _ _) _ _ eq_refl)
+|| rewrite (proper_Provable _ _ (equiv_disj_union_compat_r (list_to_set_disj_env_add _ _)) _ _ eq_refl)
+|| rewrite (proper_Provable _ _ (equiv_disj_union_compat_r (equiv_disj_union_compat_r (list_to_set_disj_env_add _ _))) _ _ eq_refl)
+|| rewrite (proper_Provable _ _ (equiv_disj_union_compat_r(equiv_disj_union_compat_r (equiv_disj_union_compat_r (list_to_set_disj_env_add _ _)))) _ _ eq_refl).
+ +
+Lemma a_rule_env_spec (Δ : list form) θ ϕ Hin (EA0 : pe, (pe ≺· (Δ, ϕ)) form * form)
+  (HEA : forall Δ ϕ Hpe, (list_to_set_disj Δ fst (EA0 (Δ, ϕ) Hpe)) * (list_to_set_disj Δ snd(EA0 (Δ, ϕ) Hpe) ϕ)) :
+  (list_to_set_disj Δ a_rule_env EA0 θ Hin ϕ).
+Proof with (auto with proof).
+assert (HE := λ Δ0 ϕ0 Hpe, fst (HEA Δ0 ϕ0 Hpe)).
+assert (HA := λ Δ0 ϕ0 Hpe, snd (HEA Δ0 ϕ0 Hpe)).
+clear HEA.
+assert(Hi : θ list_to_set_disj Δ) by now apply elem_of_list_to_set_disj.
+destruct θ; exhibit Hi 1;
+rewrite (proper_Provable _ _ (equiv_disj_union_compat_r (equiv_disj_union_compat_r (list_to_set_disj_rm _ _))) _ _ eq_refl).
+- simpl; case decide; intro Hp.
+  + subst. case_decide; subst; auto with proof.
+  + exch 0...
+- constructor 2.
+- simpl; exch 0. apply AndL. exch 1; exch 0. do 2 l_tac...
+- apply make_conj_sound_L.
+  exch 0. apply OrL; exch 0.
+  + apply AndL. apply make_impl_sound_L. exch 0. apply make_impl_sound_L.
+      l_tac. apply ImpL...
+  + apply AndL. l_tac. apply make_impl_sound_L. exch 0. apply make_impl_sound_L...
+- destruct θ1.
+  + simpl; case decide; intro Hp.
+    * assert (Hin'' : Var v (list_to_set_disj (rm (v θ2) Δ) : env))
+       by (rewrite <- list_to_set_disj_rm; apply in_difference; try easy; now apply elem_of_list_to_set_disj).
+       exhibit Hin'' 2. exch 0; exch 1. apply ImpLVar. exch 0. backward.
+       rewrite env_add_remove. exch 0. l_tac...
+    * case decide; intro; subst.
+     -- apply ExFalso.
+     -- apply make_conj_sound_L. constructor 4. exch 0. exch 1. exch 0. apply ImpLVar.
+         exch 0. exch 1. l_tac. apply weakening...
+  + constructor 2.
+  + simpl; exch 0. apply ImpLAnd. exch 0. l_tac...
+  + simpl; exch 0. apply ImpLOr. exch 1. l_tac. exch 0. l_tac...
+  + apply make_conj_sound_L. exch 0. apply ImpLImp; exch 0.
+      * apply AndL. exch 0. apply make_impl_sound_L. l_tac.
+         apply ImpR. exch 0. exch 1. l_tac...
+      * apply AndL. exch 0. l_tac. apply weakening, HA.
+  + exch 0. exch 0. simpl. apply AndL. exch 1; exch 0. apply ImpBox.
+      * box_tac. box_tac. exch 0; exch 1; exch 0. apply weakening. exch 1; exch 0.
+         apply make_impl_sound_L. do 2 l_tac. apply ImpL.
+         -- auto with proof.
+         -- apply HA.
+      * exch 1; exch 0. apply weakening. exch 0. l_tac. auto with proof.
+- auto with proof.
+Qed.
+ +
+Proposition entail_correct Δ ϕ : (list_to_set_disj Δ E (Δ, ϕ)) * (list_to_set_disj ΔA (Δ, ϕ) ϕ).
+Proof with (auto with proof).
+remember (Δ, ϕ) as pe.
+replace Δ with pe.1 by now subst.
+replace ϕ with pe.2 by now subst. clear Heqpe Δ ϕ. revert pe.
+refine (@well_founded_induction _ _ wf_pointed_order _ _).
+unfold pointed_env_order.
+intros (Δ, ϕ) Hind. simpl.
+rewrite E_eq, A_eq.
+(* uncurry the induction hypothesis for convenience *)
+assert (HE := fun d f x=> fst (Hind (d, f) x)).
+assert (HA := fun d f x=> snd (Hind (d, f) x)).
+unfold E, A in *; simpl in HE, HA.
+simpl in *. clear Hind.
+split. {
+(* E *)
+apply conjunction_R1. intros φ Hin. apply in_in_map in Hin.
+destruct Hin as (ψ&Hin&Heq). subst.
+assert(Hi : ψ list_to_set_disj Δ) by now apply elem_of_list_to_set_disj.
+destruct ψ; unfold e_rule; exhibit Hi 0; rewrite (proper_Provable _ _ (equiv_disj_union_compat_r (list_to_set_disj_rm _ _)) _ _ eq_refl).
+- case decide; intro; subst; simpl; auto using HE with proof.
+- auto with proof.
+- apply AndL. do 2 l_tac...
+- apply make_disj_sound_R, OrL.
+  + l_tac. apply OrR1, HE. order_tac.
+  + l_tac. apply OrR2, HE. order_tac.
+- destruct ψ1; auto 3 using HE with proof.
+  + case decide; intro Hp.
+    * assert(Hin'' : Var v (list_to_set_disj (rm (v ψ2) Δ) : env))
+          by (rewrite <- list_to_set_disj_rm; apply in_difference; try easy; now apply elem_of_list_to_set_disj).
+          exhibit Hin'' 1. apply ImpLVar. exch 0. backward. rewrite env_add_remove.
+          l_tac. apply HE...
+    * case decide; intro; subst.
+      -- apply ImpR, ExFalso.
+      -- apply make_impl_sound_R, ImpR. exch 0. apply ImpLVar. exch 0.
+          l_tac. apply weakening, HE. order_tac.
+  + apply ImpLAnd. l_tac...
+  + apply ImpLOr. do 2 l_tac...
+  + apply make_impl_sound_R, ImpR, make_impl_sound_L. exch 0. apply ImpLImp.
+      * exch 0. l_tac. apply ImpR. exch 0. l_tac. auto with proof.
+      * exch 0. l_tac. auto with proof.
+  + foldEA. apply make_impl_sound_R, ImpR. exch 0. apply ImpBox.
+         -- box_tac. exch 0; exch 1; exch 0. apply make_impl_sound_L, ImpL.
+            ++ do 2 l_tac. apply weakening, HE. order_tac.
+            ++ do 2 l_tac. apply HA. order_tac.
+         -- exch 0. l_tac. apply weakening, HE. order_tac.
+- apply BoxR. apply weakening. box_tac. l_tac. apply HE. order_tac.
+}
+(* A *)
+apply make_disj_sound_L, OrL.
+- apply disjunction_L. intros φ Hin.
+  apply in_in_map in Hin as (φ' & Heq & Hφ'). subst φ.
+  apply a_rule_env_spec; intros; split ; apply HE || apply HA; order_tac.
+- destruct ϕ; simpl; auto using HE with proof.
+  + case decide; intro; subst; [constructor 2|constructor 1].
+  + apply make_conj_sound_L, AndR; apply AndL; auto using HE with proof.
+  + apply ImpR. exch 0. l_tac. apply make_impl_sound_L, ImpL; auto using HE, HA with proof.
+  + foldEA. apply BoxR. box_tac. exch 0. l_tac. apply make_impl_sound_L, ImpL.
+      * apply weakening, HE. order_tac.
+      * apply HA. order_tac.
+Qed.
+ +
+End EntailmentCorrect.
+ +
+
+ +
+

Uniformity

+ +
+
+Section PropQuantCorrect.
+ +
+Hint Extern 5 (?a ≺· ?b) => order_tac : proof.
+ +
+
+ +
+The proof in this section, which is the most complex part of the argument, + shows that the E- and A-formulas constructed above are indeed their propositionally quantified versions, that is, *any* formula entailed by the original formula and + using only variables from that formula except p is already a consequence of + the E-quantified version, and similarly on the other side for the A-quantifier. + +
+ + E's second argument is mostly irrelevant and is only there for uniform treatment with A +
+
+Lemma E_irr ϕ' Δ ϕ : E (Δ, ϕ) = E (Δ, ϕ').
+Proof.
+remember ((Δ, ϕ) : pointed_env) as pe.
+replace Δ with pe.1 by now subst.
+replace ϕ with pe.2 by now subst. clear Heqpe Δ ϕ.
+  induction pe as [[Γ φ] Hind0] using (well_founded_induction_type wf_pointed_order).
+assert(Hind : Γ0 φ0, ((Γ0, φ0) ≺· (Γ, φ)) E (Γ0, φ0) = E (Γ0, ϕ'))
+  by exact (fun Γ0 φ0 => (Hind0 (Γ0, φ0))).
+unfold E in Hind. simpl in Hind.
+do 2 rewrite E_eq. f_equal. apply in_map_ext.
+intros φ' Hin. unfold e_rule.
+destruct φ'; repeat rewrite (Hind _ φ) by (trivial; order_tac); trivial.
+destruct φ'1; repeat rewrite (Hind _ φ) by (trivial; order_tac); trivial.
+Qed.
+ +
+Lemma E_left {Γ} {θ} {Δ} {φ φ'} (Hin : φ Δ) :
+(Γe_rule (λ pe (_ : pe ≺· (Δ, φ')), EA pe) φ Hin) θ ->
+ΓE (Δ, φ') θ.
+Proof.
+intro Hp. rewrite E_eq.
+destruct (@in_map_in _ _ _ (e_rule (λ pe (_ : pe ≺· (Δ, φ')), EA pe)) _ Hin) as [Hin' Hrule].
+eapply conjunction_L.
+- apply Hrule.
+- exact Hp.
+Qed.
+ +
+Lemma A_right {Γ} {Δ} {φ φ'} (Hin : φ Δ) :
+Γ a_rule_env (λ pe (_ : pe ≺· (Δ, φ')), EA pe) φ Hin ->
+Γ A (Δ, φ').
+Proof. intro Hp. rewrite A_eq.
+destruct (@in_map_in _ _ _ (a_rule_env (λ pe (_ : pe ≺· (Δ, φ')), EA pe)) _ Hin) as [Hin' Hrule].
+eapply make_disj_sound_R, OrR1, disjunction_R.
+- exact Hrule.
+- exact Hp.
+Qed.
+ +
+Proposition pq_correct Γ Δ ϕ:
+  ( φ0, φ0 Γ -> ¬ occurs_in p φ0) ->
+  (Γ list_to_set_disj Δ ϕ) ->
+  (¬ occurs_in p ϕ -> ΓE (Δ, ϕ) ϕ) * (ΓE (Δ, ϕ) A (Δ, ϕ)).
+Proof.
+(* This proof goes by induction on the ordering w.r.t (Γ ⊎Δ, ϕ)
+  instead of on the structure of Γ ⊎Δ ⊢ ϕ, to allow better rules *)

+(* we want to use an E rule *)
+Local Ltac Etac := foldEA; intros; match goal with
+| Hin : ?a list_to_set_disj ?Δ |- _E (?Δ, _) _=>
+    apply (E_left (proj1 (elem_of_list_to_set_disj _ _) Hin)); unfold e_rule end.
+ +
+(* we want to use an A rule defined in a_rule_env *)
+Local Ltac Atac := foldEA; match goal with | Hin : ?a list_to_set_disj ?Δ |- _ A (?Δ, _) =>
+  apply (A_right (proj1 (elem_of_list_to_set_disj _ _) Hin)); unfold a_rule_env end.
+ +
+(* we want to use an A rule defined in a_rule_form *)
+Local Ltac Atac' := foldEA; rewrite A_eq; apply make_disj_sound_R, OrR2; simpl.
+ +
+Local Ltac occ := simpl; tauto ||
+match goal with
+| Hnin : φ0 : form, φ0 ?Γ ¬ occurs_in p φ0 |- _ =>
+
+  let Hin := fresh "Hin" in
+  try (match goal with |Hocc : ?a ?Γ |- _ => let Hocc' := fresh "Hocc" in assert (Hocc' := Hnin _ Hocc); simpl in Hocc';
+  let Hin' := fresh "Hinx" in assert(Hin' := In_open_boxes _ _ Hocc); simpl in *;
+  try rewrite open_boxes_remove in * by trivial end);
+  intro; repeat rewrite env_in_add; repeat rewrite difference_include; simpl;
+  intro Hin; try tauto;
+  try (destruct Hin as [Hin|[Hin|Hin]] ||destruct Hin as [Hin|Hin]);
+  subst; simpl; try tauto;
+  repeat (apply difference_include in Hin; [|assumption]);
+  try (now apply Hnin)
+end.
+ +
+Local Ltac equiv_tac :=
+multimatch goal with
+| Heq' : __ _ |- _ => fail
+| Heq' : _ _ |- _ _ =>
+  try (rewrite <- difference_singleton; trivial);
+  try rewrite Heq';
+  repeat rewrite <- list_to_set_disj_env_add;
+  try rewrite <- list_to_set_disj_rm;
+  try (rewrite union_difference_L by trivial);
+  try (rewrite union_difference_R by trivial);
+  try ms
+end.
+ +
+Local Ltac peapply' th := (erewrite proper_Provable; [| |reflexivity]); [eapply th|equiv_tac].
+ +
+remember (elements Γ++ Δ, ϕ) as pe.
+revert pe Γ Δ ϕ Heqpe.
+refine (@well_founded_induction _ _ wf_pointed_order _ _).
+intros (ΓΔ, ϕ0) Hind Γ Δ ϕ Heq Hnin Hp.
+inversion Heq; subst; clear Heq.
+assert(Hind' := λ Γ0 Δ0 ψ Ho, Hind (elements Γ0 ++ Δ0, ψ) Ho _ _ _ eq_refl).
+clear Hind. rename Hind' into Hind.
+dependent destruction Hp;
+(* try and solve the easy case where the main formula is on the left *)
try match goal with
+| H : (?Γ0?a?b) = Γ list_to_set_disj Δ |- _ => rename H into Heq;
+      pose(Heq' := env_equiv_eq _ _ Heq); apply env_add_inv' in Heq'
+| H : ((?Γ0 ?a) = Γ list_to_set_disj Δ) |- _ => rename H into Heq;
+  assert(Hin : a (Γ list_to_set_disj Δ)) by (rewrite <- Heq; ms);
+  pose(Heq' := env_equiv_eq _ _ Heq); apply env_add_inv' in Heq';
+  try (case (decide (a Γ)); intro Hin0;
+  [split; intros; exhibit Hin0 1|
+   case (decide (a (list_to_set_disj Δ : env))); intro Hin0';
+  [|apply gmultiset_elem_of_disj_union in Hin; exfalso; tauto]])
+end; simpl.
+ +
+(* Atom *)
+- auto 2 with proof.
+- Atac'. case decide; intro; subst; [exfalso; now apply (Hnin _ Hin0)|]; auto with proof.
+- split.
+  + intro Hneq. Etac. rewrite decide_False. auto with proof. trivial.
+  + case (decide (p = p0)).
+    * intro Heqp0. Atac. do 2 rewrite decide_True by (f_equal; trivial). auto with proof.
+    * intro Hneq. Etac. Atac'. do 2 rewrite decide_False by trivial. apply Atom.
+(* ExFalso *)
+- auto 2 with proof.
+- auto 2 with proof.
+- split; Etac; auto with proof.
+(* AndR *)
+- split.
+  + intro Hocc. apply AndR; erewrite E_irr; apply Hind; auto with proof.
+  + Atac'. foldEA. apply make_conj_sound_R, AndR; erewrite E_irr;
+      (eapply Hind; [order_tac | occ | trivial]).
+(* AndL *)
+- exch 0. apply AndL. exch 1; exch 0. peapply Hind; auto with proof. occ. peapply' Hp.
+- exch 0. apply AndL. exch 1; exch 0. peapply Hind; auto with proof. occ. peapply' Hp.
+- split.
+   + Etac. foldEA. apply Hind; auto with proof. peapply' Hp.
+   + Atac. Etac. apply Hind; auto; auto with proof. peapply' Hp.
+(* OrR1 & OrR2 *)
+- split.
+  + intro Hocc. apply OrR1. erewrite E_irr; apply Hind; auto with proof.
+  + rewrite A_eq. apply make_disj_sound_R, OrR2.
+      apply make_disj_sound_R, OrR1; erewrite E_irr.
+      apply Hind; auto with proof.
+- simpl. split.
+  + intro Hocc. apply OrR2. erewrite E_irr; apply Hind; auto with proof.
+  + rewrite A_eq. apply make_disj_sound_R, OrR2.
+       apply make_disj_sound_R, OrR2; erewrite E_irr.
+       apply Hind; auto with proof.
+(* OrL *)
+- exch 0. apply OrL; exch 0.
+ + apply Hind; auto with proof. occ. peapply' Hp1.
+ + apply Hind; auto with proof. occ. peapply' Hp2.
+- exch 0. apply OrL; exch 0.
+  + apply Hind; auto with proof. occ. peapply' Hp1.
+  + apply Hind; auto with proof. occ. peapply' Hp2.
+- split.
+  + Etac. apply make_disj_sound_L, OrL; apply Hind; auto with proof.
+      * peapply' Hp1.
+      * peapply' Hp2.
+  + Atac. apply weakening. apply make_conj_sound_R,AndR, make_impl_sound_R.
+    * apply make_impl_sound_R, ImpR. apply Hind; auto with proof. peapply' Hp1.
+    * apply ImpR. apply Hind; auto with proof. peapply' Hp2.
+(* ImpR *)
+- split.
+  + intro Hocc. apply ImpR. exch 0.
+    erewrite E_irr. apply Hind; auto with proof. occ. peapply Hp.
+  + Atac'. apply weakening, make_impl_sound_R, ImpR, Hind; auto with proof. order_tac.
+      * rewrite <- Permutation_middle. order_tac.
+      * peapply Hp.
+(* ImpLVar *)
+- pose(Heq'' := Heq'); apply env_add_inv' in Heq''.
+  case (decide ((Var p0 φ) Γ)).
+  + intro Hin0.
+    assert (Hocc' := Hnin _ Hin0). simpl in Hocc'.
+    case (decide (Var p0 Γ)); intro Hin1.
+    * (* subcase 1: p0, (p0 → φ) ∈ Γ *)
+      assert (Hin2 : Var p0 Γ {[Var p0 φ]}) by (apply in_difference; trivial; discriminate).
+      clear Hin1.
+      split; [intro Hocc|]; exhibit Hin0 1; exhibit Hin2 2; exch 0; exch 1; apply ImpLVar; exch 1; exch 0;
+      (apply Hind; auto with proof; [occ | peapply' Hp]).
+    * assert(Hin0' : Var p0 (Γ0Var p0•(p0 φ))) by ms. rewrite Heq in Hin0'.
+      case (decide (Var p0 (list_to_set_disj Δ: env))); intro Hp0;
+      [|apply gmultiset_elem_of_disj_union in Hin0'; exfalso; tauto].
+      (* subcase 3: p0 ∈ Δ ; (p0 → φ) ∈ Γ *)
+      clear Heq''.
+      split; try case decide; intros; subst.
+      -- apply contraction. Etac. rewrite decide_False by tauto.
+          exhibit Hin0 2. exch 1. exch 0. apply ImpLVar. exch 0. apply weakening. exch 0.
+         apply Hind; auto with proof. occ. peapply' Hp.
+      -- apply contraction. Etac. rewrite decide_False by tauto.
+          exhibit Hin0 2. exch 1; exch 0. apply ImpLVar. exch 0. apply weakening.
+          exch 0. foldEA. apply Hind; auto with proof. occ. peapply' Hp.
+  + intro.
+    assert(Hin : (Var p0 φ) (Γ0Var p0•(p0 φ))) by ms.
+    rewrite Heq in Hin.
+    case (decide ((Var p0 φ) (list_to_set_disj Δ : env))); intro Hin0;
+    [|apply gmultiset_elem_of_disj_union in Hin; exfalso; tauto].
+    case (decide (Var p0 Γ)); intro Hin1.
+    * (* subcase 2: p0 ∈ Γ ; (p0 → φ) ∈ Δ *)
+      do 2 exhibit Hin1 1.
+      split; [intro Hocc|].
+      -- Etac. case decide; intro Hp0;[|case decide; intro; subst; [auto with *|]].
+         ++ foldEA. apply Hind; auto with proof; [order_tac; order_tac|occ | peapply' Hp].
+         ++ apply make_impl_sound_L, ImpLVar. exch 0. backward. rewrite env_add_remove.
+         apply Hind; auto with proof. peapply' Hp.
+      -- Etac. Atac. case decide; intro Hp0;[|case decide; intro; subst; [auto with *|]].
+        ++ foldEA. apply Hind; auto with proof; [order_tac; order_tac|occ | peapply' Hp].
+        ++ apply make_impl_sound_L, ImpLVar.
+               apply make_conj_sound_R, AndR; auto 2 with proof.
+               exch 0. backward. rewrite env_add_remove.
+               apply Hind; auto with proof. peapply' Hp.
+    * assert(Hin': Var p0 Γ list_to_set_disj Δ) by (rewrite <- Heq; ms).
+       apply gmultiset_elem_of_disj_union in Hin'.
+       case (decide (Var p0 (list_to_set_disj Δ: env))); intro Hin1'; [|exfalso; tauto].
+      (* subcase 4: p0,(p0 → φ) ∈ Δ *)
+      case (decide (p = p0)); intro.
+      -- (* subsubcase p = p0 *)
+        apply elem_of_list_to_set_disj in Hin1'.
+        subst. split; Etac; repeat rewrite decide_True by trivial.
+        ++ clear Heq. apply Hind; auto with proof. peapply' Hp.
+        ++ Atac. repeat rewrite decide_True by trivial. clear Heq.
+                apply Hind; auto with proof. peapply' Hp.
+      -- (* subsubcase p ≠ p0 *)
+         split; [intro Hocc|].
+         ++ apply contraction. Etac. rewrite decide_False by trivial. exch 0.
+                 assert((p0 φ) list_to_set_disj Δ) by ms. Etac.
+                 rewrite decide_True by now apply elem_of_list_to_set_disj.
+                 exch 0. apply weakening. apply Hind; auto with proof. peapply' Hp.
+         ++ apply contraction. Etac. exch 0. assert((p0 φ) list_to_set_disj Δ) by ms.
+                 Etac; Atac. rewrite decide_False by trivial.
+                 do 2 rewrite decide_True by now apply elem_of_list_to_set_disj.
+                 exch 0. apply weakening.
+                 apply Hind; auto with proof. peapply' Hp.
+(* ImpLAnd *)
+- exch 0. apply ImpLAnd. exch 0. apply Hind; auto with proof; [occ|peapply' Hp].
+- exch 0. apply ImpLAnd. exch 0. apply Hind; auto with proof; [occ|peapply' Hp].
+- split; Etac.
+  + apply Hind; auto with proof. peapply' Hp.
+  + Atac. simpl. apply Hind; auto with proof. peapply' Hp.
+(* ImpLOr *)
+- exch 0; apply ImpLOr. exch 1; exch 0. apply Hind; auto with proof. occ. peapply' Hp.
+- exch 0; apply ImpLOr. exch 1; exch 0. apply Hind; [order_tac | occ|peapply' Hp].
+- split; Etac.
+  + apply Hind; auto with proof. peapply' Hp.
+  + Atac. apply Hind; auto with proof. peapply' Hp.
+(* ImpLImp *)
+- (* subcase 1: ((φ1 → φ2) → φ3) ∈ Γ *)
+  assert Var p) by (intro; subst; simpl in *; tauto).
+  exch 0; apply ImpLImp; exch 0.
+  + erewrite E_irr. apply Hind; auto with proof. occ. peapply' Hp1.
+      simpl. apply Hnin in Hin0. simpl in *. tauto.
+  + erewrite E_irr. apply Hind; auto with proof. occ. peapply' Hp2.
+- exch 0; apply ImpLImp; exch 0.
+  + erewrite E_irr. apply Hind; auto with proof. occ. peapply' Hp1.
+       simpl. apply Hnin in Hin0. simpl in Hin0. tauto.
+  + apply Hind; auto with proof. occ. peapply' Hp2.
+- (* subcase 2: ((φ1 → φ2) → φ3) ∈ Δ *)
+  split.
+  + Etac. apply make_impl_sound_L2'. apply ImpLImp.
+    * apply weakening. apply ImpR. foldEA.
+       rewrite (E_irr φ2).
+       apply Hind; auto with proof.
+       -- order_tac. repeat rewrite Permutation_middle. order_tac.
+       -- repeat setoid_rewrite gmultiset_disj_union_assoc.
+           setoid_rewrite gmultiset_disj_union_comm.
+           repeat setoid_rewrite gmultiset_disj_union_assoc. exch 0. apply ImpR_rev.
+           peapply' Hp1.
+    * apply Hind; auto with proof. peapply' Hp2.
+  + Atac. apply make_conj_sound_R, AndR.
+    * apply weakening. apply make_impl_sound_R, ImpR. foldEA.
+       rewrite (E_irr φ2). apply Hind; auto with proof.
+       -- order_tac. repeat rewrite Permutation_middle. order_tac.
+       -- repeat setoid_rewrite gmultiset_disj_union_assoc.
+           setoid_rewrite gmultiset_disj_union_comm.
+           repeat setoid_rewrite gmultiset_disj_union_assoc. exch 0. apply ImpR_rev.
+           peapply' Hp1.
+    * Etac. simpl. apply make_impl_sound_L2', ImpLImp.
+      -- apply weakening. apply ImpR. foldEA.
+       rewrite (E_irr φ2). apply Hind; auto with proof.
+       ++ order_tac. repeat rewrite Permutation_middle. order_tac.
+       ++ repeat setoid_rewrite gmultiset_disj_union_assoc.
+               setoid_rewrite gmultiset_disj_union_comm.
+               repeat setoid_rewrite gmultiset_disj_union_assoc. exch 0. apply ImpR_rev.
+               peapply' Hp1.
+      -- apply Hind; auto with proof. peapply' Hp2.
+- (* ImpBox, external *)
+   destruct (open_boxes_case (list_to_set_disj Δ)) as [[θ ] | Hequiv].
+    + apply contraction. Etac. exch 1; exch 0; apply ImpBox.
+        * box_tac. box_tac. exch 2; exch 1; exch 0. apply weakening. foldEA.
+           erewrite E_irr with (ϕ' := φ1).
+           exch 1; exch 0. apply Hind.
+           -- order_tac. (* cannot handle it. manual proof *)
+               rewrite elements_open_boxes.
+               do 2 apply env_order_cancel_right. apply env_order_4; simpl; try lia. left.
+               apply env_order_disj_union_compat_strong_left; order_tac.
+           -- occ. intro HF. destruct (occurs_in_open_boxes _ _ _ HF Hin1) as (θ0 & Hθ0 & Hinθ).
+               apply (Hnin θ0); ms.
+           -- assert(Hθ' := In_open_boxes _ _ ).
+               assert(Heq'' : Γ0 (Γ {[ φ1 φ2]} list_to_set_disj ((θ) :: rm ( θ) Δ))). {
+               rewrite Heq'. simpl. rewrite union_difference_L by trivial.
+               rewrite (difference_singleton _ _ ).
+               rewrite list_to_set_disj_rm. ms.
+               }
+               clear Heq'. clear .
+              (erewrite proper_Provable; [| |reflexivity]); [eapply Hp1|].
+              rewrite Heq''. rewrite open_boxes_disj_union.
+              repeat rewrite <- ?list_to_set_disj_open_boxes, <- list_to_set_disj_env_add.
+              rewrite open_boxes_add. simpl. ms.
+          -- intro HF. apply (Hnin _ Hin0). simpl. tauto.
+        * exch 0. apply weakening. exch 0. apply Hind; [order_tac | occ|peapply' Hp2| trivial].
+  + assert(Heq'' : ( Γ0) ((Γ {[ φ1 φ2]}) (list_to_set_disj Δ))). {
+       rewrite Heq'. rewrite union_difference_L by trivial.
+       rewrite <- Hequiv, open_boxes_disj_union.
+       rewrite open_boxes_remove by trivial. ms. }
+       exch 0. apply ImpBox.
+      * box_tac. exch 1; exch 0. apply open_box_L.
+         erewrite E_irr with (ϕ' := φ1).
+         apply Hind.
+         -- order_tac. rewrite elements_open_boxes. repeat rewrite Permutation_middle. order_tac.
+         -- occ. intro HF. destruct (occurs_in_open_boxes _ _ _ HF Hin1) as (θ0 & Hθ0 & Hinθ).
+             apply (Hnin θ0); ms.
+         -- peapply' Hp1.
+         -- intro HF. apply (Hnin _ Hin0). simpl. tauto.
+     * exch 0. apply Hind; [order_tac|occ | | trivial].
+        (erewrite proper_Provable; [| |reflexivity]); [eapply Hp2|].
+        rewrite Heq'. rewrite union_difference_L by trivial. ms.
+- destruct (open_boxes_case (list_to_set_disj Δ)) as [[θ ] | Hequiv].
+    + apply contraction. Etac. exch 1; exch 0; apply ImpBox.
+        * box_tac. box_tac. exch 2; exch 1; exch 0. apply weakening. foldEA.
+           erewrite E_irr with (ϕ' := φ1).
+           exch 1; exch 0. apply Hind.
+         -- order_tac.
+             rewrite elements_open_boxes.
+               do 2 apply env_order_cancel_right. apply env_order_4; simpl; try lia. left.
+               apply env_order_disj_union_compat_strong_left; order_tac.
+         -- occ. intro HF. destruct (occurs_in_open_boxes _ _ _ HF Hin1) as (θ0 & Hθ0 & Hinθ).
+             apply (Hnin θ0); ms.
+           -- assert(Hθ' := In_open_boxes _ _ ).
+               assert(Heq'' : Γ0 (Γ {[ φ1 φ2]} list_to_set_disj ((θ) :: rm ( θ) Δ))). {
+               rewrite Heq'. simpl. rewrite union_difference_L by trivial.
+               rewrite (difference_singleton _ _ ).
+               rewrite list_to_set_disj_rm. ms.
+               }
+               clear Heq'. clear .
+              (erewrite proper_Provable; [| |reflexivity]); [eapply Hp1|].
+              rewrite Heq''. rewrite open_boxes_disj_union.
+              repeat rewrite <- ?list_to_set_disj_open_boxes, <- list_to_set_disj_env_add.
+              rewrite open_boxes_add. simpl. ms.
+         -- intro HF. apply (Hnin _ Hin0). simpl. tauto.
+        * exch 0. apply weakening. exch 0. apply Hind ; [order_tac|occ|peapply' Hp2].
+  + erewrite E_irr with (ϕ' := φ1).
+      exch 0. apply ImpBox.
+      * box_tac. exch 1; exch 0. apply open_box_L. apply Hind.
+         -- order_tac. rewrite elements_open_boxes. order_tac.
+         -- occ. intro HF. destruct (occurs_in_open_boxes _ _ _ HF Hin1) as (θ0 & Hθ0 & Hinθ).
+             apply (Hnin θ0); ms.
+         -- assert(Heq'' : ( Γ0) ((Γ {[ φ1 φ2]}) (list_to_set_disj Δ))). {
+                 rewrite Heq'. rewrite union_difference_L by trivial.
+                 rewrite <- Hequiv, open_boxes_disj_union.
+                 rewrite open_boxes_remove by trivial. ms. }
+                 peapply Hp1.
+         -- intro HF. apply (Hnin _ Hin0). simpl. tauto.
+      * erewrite E_irr with (ϕ' := ψ).
+          exch 0. apply Hind. order_tac. occ. clear Hequiv. peapply' Hp2.
+- split; Etac.
+  + foldEA. apply make_impl_sound_L, ImpBox.
+        -- do 2 apply weakening. apply make_impl_sound_R, ImpR.
+            erewrite E_irr with (ϕ' := φ1) by ms.
+            apply Hind.
+             ++ order_tac. rewrite elements_open_boxes.
+                     do 2 apply env_order_cancel_right.
+                     repeat rewrite Permutation_middle.
+                     apply env_order_disj_union_compat_strong_left; order_tac.
+            ++ intros φ0 Hin1 HF. destruct (occurs_in_open_boxes _ _ _ HF Hin1) as (θ0 & Hθ0 & Hinθ).
+                    apply (Hnin θ0); ms.
+            ++ assert(Heq'' : ( Γ0) ((Γ) list_to_set_disj (map open_box (rm ( φ1 φ2) Δ)))). {
+                    rewrite Heq'.
+                    repeat rewrite open_boxes_remove by ms. simpl.
+                    rewrite <- list_to_set_disj_open_boxes, <- list_to_set_disj_rm, open_boxes_disj_union. trivial.
+                    simpl. rewrite union_difference_R by auto with proof. rewrite open_boxes_remove by ms. ms.
+                    }
+                    peapply Hp1.
+        -- apply Hind. order_tac. occ. peapply' Hp2. trivial.
+  + assert(Heq'' : ( Γ0) ((Γ) list_to_set_disj (map open_box (rm ( φ1 φ2) Δ)))). {
+          rewrite Heq'.
+          repeat rewrite open_boxes_remove by ms. simpl.
+          rewrite <- list_to_set_disj_open_boxes, <- list_to_set_disj_rm, open_boxes_disj_union. trivial.
+          simpl. rewrite union_difference_R by auto with proof. rewrite open_boxes_remove by ms. ms.
+        }
+  foldEA. Atac. apply AndR.
+     * apply make_impl_sound_L, ImpBox.
+        -- do 2 apply weakening. apply make_impl_sound_R, ImpR.
+            erewrite E_irr with (ϕ' := φ1).
+            apply Hind.
+             ++ order_tac. rewrite elements_open_boxes.
+                     do 2 apply env_order_cancel_right.
+                     repeat rewrite Permutation_middle.
+                     apply env_order_disj_union_compat_strong_left; order_tac.
+            ++ intros φ0 Hin1 HF. destruct (occurs_in_open_boxes _ _ _ HF Hin1) as (θ0 & Hθ0 & Hinθ).
+                    apply (Hnin θ0); ms.
+            ++ peapply Hp1.
+       -- apply BoxR. box_tac. do 2 apply weakening. apply make_impl_sound_R, ImpR. foldEA.
+           erewrite E_irr with (ϕ' := φ1) by ms.
+           apply Hind.
+             ++ order_tac. rewrite elements_open_boxes.
+                     do 2 apply env_order_cancel_right.
+                     repeat rewrite Permutation_middle.
+                     apply env_order_disj_union_compat_strong_left; order_tac.
+            ++ intros φ0 Hin1 HF. destruct (occurs_in_open_boxes _ _ _ HF Hin1) as (θ0 & Hθ0 & Hinθ).
+                    apply (Hnin θ0); ms.
+            ++ peapply Hp1.
+     * foldEA. apply make_impl_sound_L, ImpBox.
+        -- do 2 apply weakening. apply make_impl_sound_R, ImpR.
+               erewrite E_irr with (ϕ' := φ1).
+               apply Hind.
+             ++ order_tac. rewrite elements_open_boxes.
+                     do 2 apply env_order_cancel_right.
+                     repeat rewrite Permutation_middle.
+                     apply env_order_disj_union_compat_strong_left; order_tac.
+               ++ intros φ0 Hφ0 HF. destruct (occurs_in_open_boxes _ _ _ HF Hφ0) as (θ0 & Hθ0 & Hinθ).
+                     apply (Hnin θ0); ms.
+               ++ peapply Hp1.
+        -- clear Heq''. apply Hind; [order_tac|occ|peapply' Hp2].
+- split.
+  + intro Hocc. destruct (open_boxes_case (list_to_set_disj Δ)) as [[θ ] | Hequiv].
+      * Etac. foldEA. apply BoxR. box_tac. exch 0.
+        erewrite E_irr with (ϕ' := φ); apply Hind.
+        -- order_tac.
+            rewrite elements_open_boxes.
+            repeat rewrite Permutation_middle.
+            apply env_order_disj_union_compat_strong_left. order_tac.
+            apply env_order_2. simpl; lia. simpl; lia.
+            apply env_order_eq_add. left. order_tac.
+        -- intros φ0 Hφ0 HF. apply gmultiset_elem_of_disj_union in Hφ0.
+            destruct Hφ0 as [Hφ0|]; [|ms].
+            destruct (occurs_in_open_boxes _ _ _ HF Hφ0) as (θ0 & Hθ0 & Hinθ). apply (Hnin θ0); ms.
+        -- (erewrite proper_Provable; [| |reflexivity]); [eapply Hp|].
+            rewrite open_boxes_disj_union.
+            rewrite <- list_to_set_disj_env_add.
+            rewrite <- list_to_set_disj_open_boxes, <- list_to_set_disj_rm.
+            rewrite open_boxes_remove by ms.
+            rewrite <- difference_singleton by auto with proof. ms.
+        -- trivial.
+      * apply BoxR. box_tac. exch 0. apply open_box_L.
+         erewrite E_irr with (ϕ' := φ).
+         apply Hind.
+         -- order_tac.
+             rewrite elements_open_boxes.
+            repeat rewrite Permutation_middle.
+            apply env_order_disj_union_compat_strong_left. order_tac.
+            apply env_order_2. simpl; lia. simpl; lia. now right.
+         -- intros φ0 Hφ0 HF. apply gmultiset_elem_of_disj_union in Hφ0.
+            destruct Hφ0 as [Hφ0|]; [|ms].
+            destruct (occurs_in_open_boxes _ _ _ HF Hφ0) as (θ0 & Hθ0 & Hinθ). apply (Hnin θ0); ms.
+         -- (erewrite proper_Provable; [| |reflexivity]); [eapply Hp|].
+              rewrite open_boxes_disj_union, <- Hequiv. ms.
+         -- trivial.
+  + Atac'. foldEA. apply BoxR. box_tac. apply weakening. erewrite E_irr with (ϕ' := φ).
+       apply weakening. apply make_impl_sound_R, ImpR.
+       apply Hind.
+       * order_tac.
+          rewrite elements_open_boxes.
+          repeat rewrite Permutation_middle.
+          order_tac.
+       * intros φ0 Hφ0 HF. destruct (occurs_in_open_boxes _ _ _ HF Hφ0) as (θ0 & Hθ0 & Hinθ).
+          apply (Hnin θ0); ms.
+       * (erewrite proper_Provable; [| |reflexivity]); [eapply Hp|].
+            rewrite open_boxes_disj_union.
+            rewrite <- list_to_set_disj_env_add.
+            rewrite <- list_to_set_disj_open_boxes. ms.
+Qed.
+ +
+End PropQuantCorrect.
+ +
+End Correctness.
+ +
+End UniformInterpolation.
+ +
+
+ +
+

Main uniform interpolation Theorem

+ +
+
+ +
+Open Scope type_scope.
+ +
+Lemma E_of_empty p φ : E p ([], φ) = (Implies Bot Bot).
+Proof.
+  rewrite E_eq. rewrite in_map_empty. now unfold conjunction, nodup, foldl.
+Qed.
+ +
+Definition vars_incl φ l := forall x, occurs_in x φ -> In x l.
+ +
+
+ +
+ The overall correctness result is summarized here. +
+
+ +
+Theorem iSL_uniform_interpolation p V: p V ->
+   φ, vars_incl φ (p :: V) ->
+    (vars_incl (Ef p φ) V)
+  * ({[φ]} (Ef p φ))
+  * ( ψ, vars_incl ψ V -> {[φ]} ψ -> {[Ef p φ]} ψ)
+  * (vars_incl (Af p φ) V)
+  * ({[Af p φ]} φ)
+  * ( θ, vars_incl θ V -> {[θ]} φ -> {[θ]} Af p φ).
+Proof.
+intros Hp φ Hvarsφ; repeat split.
+  + intros x Hx. apply (EA_vars p _ x) in Hx.
+      destruct Hx as [Hneq [θ [ Hocc]]]. apply elem_of_list_singleton in . subst.
+      apply Hvarsφ in Hocc. destruct Hocc; subst; tauto.
+  + replace {[φ]} with (list_to_set_disj [φ] : env). apply entail_correct. simpl. ms.
+  + intros ψ Hψ Hyp. rewrite elem_of_list_In in Hp. unfold Ef. rewrite E_irr with (ϕ' := ψ).
+      * peapply (pq_correct p [φ] ψ).
+         -- intros θ Hin. inversion Hin.
+         -- peapply Hyp.
+         -- intro HF. apply Hψ in HF. tauto.
+  + intros x Hx. apply (EA_vars p φ x) in Hx.
+      destruct Hx as [Hneq [Hin | [θ [ Hocc]]]].
+      * apply Hvarsφ in Hin. destruct Hin; subst; tauto.
+      * inversion .
+  + peapply (entail_correct p []).
+  + intros ψ Hψ Hyp. rewrite elem_of_list_In in Hp.
+      apply (TopL_rev _ ). peapply (pq_correct p {[ψ]} [] φ).
+      * intros φ0 Hφ0. apply gmultiset_elem_of_singleton in Hφ0. subst. auto with *.
+      * peapply Hyp.
+      * now rewrite E_of_empty.
+Qed.
+
+
+ +
+ + + diff --git a/ISL.SequentProps.html b/ISL.SequentProps.html new file mode 100644 index 0000000..7cd49f9 --- /dev/null +++ b/ISL.SequentProps.html @@ -0,0 +1,1019 @@ + + + + + + + + + + + + + +
+
+

ISL.SequentProps

+ +
+Require Import ISL.Sequents.
+ +
+(* Required for dependent induction. *)
+Require Import Coq.Program.Equality.
+ +
+
+ +
+

Overview: admissible rules in G4ip sequent calculus

+ + +
+ +This file contains important properties of the sequent calculus G4ip, defined in +Sequents.v, namely the admissibility of various inversion rules, weakening and +contraction. We draw various consequences from this that are used extensively in +the proof of correctness of propositional quantifiers. The first part of this +file closely follows proof in the paper: + +
+ +(Dyckhoff and Negri 2000). R. Dyckhoff and S. Negri, Admissibility of Structural +Rules for Contraction-Free Systems of Intuitionistic Logic, Journal of Symbolic +Logic (65):4. + +
+ +

Weakening

+ +
+ + We prove the admissibility of the weakening rule. +
+
+ +
+Theorem weakening φ' Γ φ : Γ φ -> Γφ' φ.
+Proof with (auto with proof).
+intro H. revert φ'. induction H; intro φ'; auto with proof; try (exch 0; auto with proof).
+- constructor 4. exch 1; exch 0...
+- constructor 7; exch 0...
+- constructor 8; exch 0...
+- exch 1; constructor 9; exch 1; exch 0...
+- constructor 10; exch 0...
+- constructor 11. exch 1; exch 0...
+- constructor 12; exch 0...
+- apply ImpBox; box_tac.
+  + peapply (IHProvable1 (open_box φ')).
+  + exch 0...
+- apply BoxR. box_tac; exch 0...
+Qed.
+ +
+Global Hint Resolve weakening : proof.
+ +
+Theorem generalised_weakeningL (Γ Γ' : env) φ: Γ φ -> Γ' Γ φ.
+Proof.
+intro Hp.
+induction Γ' as [| x Γ' IHΓ'] using gmultiset_rec.
+- peapply Hp.
+- peapply (weakening x). exact IHΓ'. ms.
+Qed.
+ +
+Theorem generalised_weakeningR (Γ Γ' : env) φ: Γ' φ -> Γ' Γ φ.
+Proof.
+intro Hp.
+induction Γ as [| x Γ IHΓ] using gmultiset_rec.
+- peapply Hp.
+- peapply (weakening x). exact IHΓ. ms.
+Qed.
+ +
+Global Hint Extern 5 (?a <= ?b) => simpl in *; lia : proof.
+ +
+
+ +
+

Inversion rules

+ +
+ + We prove that the following rules are invertible: implication right, and + left, or left, top left (i.e., the appliction of weakening for the formula + top), the four implication left rules, the and right rule and the application of the or right rule with bottom. +
+
+ +
+Lemma ImpR_rev Γ φ ψ :
+  (Γ (φ ψ))
+    -> Γφ ψ.
+Proof with (auto with proof).
+intro Hp. dependent induction Hp; auto with proof; try exch 0.
+- constructor 4. exch 1; exch 0...
+- constructor 7; exch 0...
+- exch 1; constructor 9; exch 1; exch 0...
+- constructor 10; exch 0...
+- constructor 11. exch 1; exch 0...
+- constructor 12; exch 0...
+- constructor 13; box_tac...
+  + exch 1; exch 0...
+  + exch 0. auto with proof.
+Qed.
+ +
+Global Hint Resolve ImpR_rev : proof.
+ +
+Theorem generalised_axiom Γ φ : Γφ φ.
+Proof with (auto with proof).
+remember (weight φ) as w.
+assert(Hle : weight φ w) by lia.
+clear Heqw. revert Γ φ Hle.
+induction w; intros Γ φ Hle.
+- assert (Hφ := weight_pos φ). lia.
+- destruct φ; simpl in Hle...
+  destruct φ1 as [v| | θ1 θ2 | θ1 θ2 | θ1 θ2 | θ].
+  + constructor 8. exch 0...
+  + auto with proof.
+  + apply ImpR, AndL. exch 1; exch 0. apply ImpLAnd.
+    exch 0. apply ImpR_rev. exch 0...
+  + apply ImpR. exch 0. apply ImpLOr.
+    exch 1; exch 0...
+  + apply ImpR. exch 0...
+  + apply ImpR. exch 0. apply ImpBox; box_tac...
+  + apply BoxR; box_tac...
+Qed.
+ +
+Global Hint Resolve generalised_axiom : proof.
+ +
+Lemma open_box_L Γ φ ψ : Γ φ ψ -> Γ φ ψ.
+Proof.
+intro Hp.
+remember (Γφ) as Γ' eqn:HH.
+assert (Heq: Γ Γ' {[ φ ]}) by ms.
+assert(Hin : φ Γ')by ms.
+rw Heq 1. clear Γ HH Heq. revert φ Hin.
+dependent induction Hp generalizing Γ' Hp; intros φ0 Hin.
+- case (decide (φ0 = Var p)).
+  + intro; subst. simpl. auto with proof.
+  + intro. forward. auto with proof.
+- case (decide (φ0 = )).
+  + intro; subst. simpl. auto with proof.
+  + intro. forward. auto with proof.
+- apply AndR; auto.
+- case (decide (φ0 = (φ ψ))).
+  + intro; subst. simpl. apply AndL. peapply Hp.
+  + intro. forward. apply AndL. do 2 backward. peapply (IHHp φ0). ms.
+- apply OrR1; auto.
+- apply OrR2; auto.
+- case (decide (φ0 = (φ ψ))).
+  + intro; subst. simpl. apply OrL.
+      * peapply Hp1.
+      * peapply Hp2.
+  + intro. forward. apply OrL.
+      * backward. peapply (IHHp1 φ0). ms.
+      * backward. peapply (IHHp2 φ0). ms.
+- apply ImpR. backward. apply IHHp. ms.
+- case (decide (φ0 = Var p)).
+  + intro; subst; simpl. forward. apply ImpLVar. peapply Hp.
+  + intro. case (decide (φ0 = (Var p φ))).
+      * intro; subst; simpl. peapply ImpLVar. exact Hp. ms.
+      * intro. do 2 forward. exch 0. apply ImpLVar. exch 0. do 2 backward.
+         apply IHHp. ms.
+- case (decide (φ0 = (φ1 φ2 φ3))).
+  + intro; subst; simpl. apply ImpLAnd. peapply Hp.
+  + intro. forward. apply ImpLAnd. backward. apply IHHp. ms.
+- case (decide (φ0 = (φ1 φ2 φ3))).
+  + intro; subst; simpl. apply ImpLOr. peapply Hp.
+  + intro. forward. apply ImpLOr. exch 0. do 2 backward. apply IHHp. ms.
+- case (decide (φ0 = ((φ1 φ2) φ3))).
+  + intro; subst; simpl. apply ImpLImp. peapply Hp1. peapply Hp2.
+  + intro. forward. apply ImpLImp.
+      * backward. apply IHHp1. ms.
+      * backward. apply IHHp2. ms.
+- case (decide (φ0 = ( φ1 φ2))).
+  + intro; subst; simpl. apply ImpBox.
+      * peapply Hp1; autorewrite with proof; ms.
+      * peapply Hp2; autorewrite with proof.
+  + intro. forward.
+      case (decide (open_box φ0 = φ1)).
+      * intro Heq. repeat rewrite Heq. apply ImpBox; box_tac.
+        -- exch 1; exch 0. apply generalised_axiom.
+        -- backward. rewrite <- Heq. apply IHHp2. auto with *.
+      * intro Hneq. case (decide (open_box φ0 = φ2)).
+          -- intro Heq. subst φ2. apply ImpBox; box_tac.
+              ++ peapply (IHHp1 ( φ0)); [ms|].
+                      autorewrite with proof; [|ms]. repeat rewrite env_replace.
+                     ** ms.
+                     ** auto with proof.
+                     ** apply env_in_add. right. auto with proof; ms.
+              ++ box_tac. backward. apply (IHHp2 φ0). auto with *.
+          -- intro Hneq'. apply ImpBox; repeat box_tac.
+            ++ exch 0. box_tac. backward. backward. apply (IHHp1 ( φ0)).
+                    apply env_in_add. now right.
+            ++ backward. apply IHHp2. apply env_in_add. now right.
+- case (decide (open_box φ0 = φ)).
+  + intro Heq; rewrite Heq. apply generalised_axiom.
+  + intro. backward. apply BoxR. box_tac.
+      case (decide (open_box φ0 = open_box (open_box φ0))).
+      * intro Heq. peapply Hp. autorewrite with proof. rewrite <- Heq. ms. ms.
+      * intro. assert( open_box φ0 open_boxes Γ) by (now apply In_open_boxes).
+        peapply (IHHp (open_box φ0)).
+        -- ms.
+        -- autorewrite with proof. repeat rewrite env_replace; ms. ms.
+Qed.
+ +
+Local Hint Resolve env_in_add : proof.
+ +
+Lemma open_boxes_R (Γ : env) (φ ψ : form): (Γ φ) ψ ((Γ) φ) ψ.
+Proof.
+revert ψ.
+induction Γ using gmultiset_rec; intro ψ.
+- rewrite open_boxes_empty. trivial.
+- intro HP. peapply (open_box_L ( Γ φ) x ψ).
+  + apply ImpR_rev, IHΓ, ImpR. peapply HP.
+  + rewrite open_boxes_disj_union, open_boxes_singleton; ms.
+Qed.
+Lemma AndL_rev Γ φ ψ θ: (Γφ ψ) θ (Γφψ) θ.
+Proof.
+intro Hp.
+remember (Γφ ψ) as Γ' eqn:HH.
+assert (Heq: Γ Γ' {[ φ ψ ]}) by ms.
+assert(Hin : (φ ψ) Γ')by ms.
+rw Heq 2. clear Γ HH Heq. revert φ ψ Hin.
+(* we massaged the goal so that the environment of the derivation on which we do
+   the induction is not composite anymore *)

+induction Hp; intros φ0 ψ0 Hin; try forward.
+(* auto takes care of the right rules easily *)
+- auto with proof.
+- auto with proof.
+- auto with proof.
+(* the main case *)
+- case(decide ((φ ψ) = (φ0 ψ0))); intro Heq0.
+  + inversion Heq0; subst. peapply Hp.
+  + forward. constructor 4. exch 0. backward. backward. apply IHHp. ms.
+(* only left rules remain. Now it's all a matter of putting the right principal
+   formula at the front, apply the rule; and put back the front formula at the back
+   before applying the induction hypothesis *)

+- auto with proof.
+- auto with proof.
+- constructor 7; backward; [apply IHHp1 | apply IHHp2]; ms.
+- constructor 8. backward. apply IHHp. ms.
+- forward. exch 0. constructor 9. exch 0. do 2 backward. apply IHHp. ms.
+- constructor 10. backward. apply IHHp. ms.
+- constructor 11. exch 0. do 2 backward. apply IHHp. ms.
+- constructor 12; backward.
+  + apply IHHp1. ms.
+  + apply IHHp2. ms.
+- constructor 13; repeat box_tac.
+  + exch 0. box_tac.
+      apply In_open_boxes in Hin0. backward. backward. apply open_box_L. exch 0. apply open_box_L. exch 0.
+      apply IHHp1. ms.
+  + backward. apply IHHp2. ms.
+- constructor 14. repeat box_tac.
+  exch 0. apply open_box_L.
+  exch 1; exch 0. apply open_box_L.
+  peapply (IHHp φ0 ψ0).
+  + apply env_in_add. right. apply In_open_boxes in Hin. auto with proof.
+  + autorewrite with proof. simpl. rewrite <- env_replace. ms.
+      apply In_open_boxes in Hin. auto with proof.
+Qed.
+ +
+Lemma OrL_rev Γ φ ψ θ: (Γφ ψ) θ (Γφ θ) * (Γψ θ).
+Proof.
+intro Hp.
+remember (Γφ ψ) as Γ' eqn:HH.
+assert (Heq: Γ Γ' {[ φ ψ ]}) by ms.
+assert(Hin : (φ ψ) Γ')by ms.
+assert(Heq' : ((Γ' {[φ ψ]}φ) θ) * ((Γ' {[φ ψ]}ψ) θ));
+[| split; rw Heq 1; tauto].
+clear Γ HH Heq.
+induction Hp.
+- split; forward; auto with proof.
+- split; forward; auto with proof.
+- split; constructor 3; intuition.
+- split; forward; constructor 4; exch 0; do 2 backward; apply IHHp; ms.
+- split; constructor 5; intuition.
+- split; apply OrR2; intuition.
+- case (decide ((φ0 ψ0) = (φ ψ))); intro Heq0.
+  + inversion Heq0; subst. split; [peapply Hp1| peapply Hp2].
+  + split; forward; constructor 7; backward; (apply IHHp1||apply IHHp2); ms.
+- split; constructor 8; backward; apply IHHp; ms.
+- split; do 2 forward; exch 0; constructor 9; exch 0; do 2 backward; apply IHHp; ms.
+- split; forward; constructor 10; backward; apply IHHp; ms.
+- split; forward; constructor 11; exch 0; do 2 backward; apply IHHp; ms.
+- split; forward; constructor 12; backward; (apply IHHp1 || apply IHHp2); ms.
+- split; forward; assert(Hin' : (φ ψ) ( Γ φ1 φ2))
+  by (apply env_in_add; right; apply env_in_add; right; auto with proof);
+  assert((φ ψ) Γ) by auto with proof;
+  (constructor 13; repeat box_tac; exch 0;
+    [do 2 backward; apply open_box_L; apply IHHp1|exch 0; backward; apply IHHp2];ms).
+- assert (Hin' : (φ ψ) ( Γ φ0)) by (apply env_in_add; right; auto with proof).
+    split; constructor 14; repeat box_tac; backward; apply open_box_L; now apply IHHp.
+Qed.
+ +
+Lemma TopL_rev Γ φ θ: Γ•( φ) θ -> Γ θ.
+Proof.
+remember (Γ•( φ)) as Γ' eqn:HH.
+assert (Heq: Γ Γ' {[ φ ]}) by ms.
+assert(Hin : ( φ) Γ')by ms. clear HH.
+intro Hp. rw Heq 0. clear Γ Heq. induction Hp;
+try forward.
+- auto with proof.
+- auto with proof.
+- auto with proof.
+- constructor 4. exch 0. do 2 backward. apply IHHp. ms.
+- auto with proof.
+- auto with proof.
+- constructor 7; backward; [apply IHHp1 | apply IHHp2]; ms.
+- constructor 8. backward. apply IHHp. ms.
+- forward. exch 0. constructor 9. exch 0. do 2 backward. apply IHHp. ms.
+- constructor 10. backward. apply IHHp. ms.
+- constructor 11. exch 0. do 2 backward. apply IHHp. ms.
+- constructor 12; backward; [apply IHHp1 | apply IHHp2]; ms.
+- constructor 13; box_tac.
+  + exch 0. do 2 backward. apply IHHp1. ms.
+  + backward. apply IHHp2. ms.
+- constructor 14. box_tac. backward. apply IHHp. ms.
+Qed.
+ +
+Local Hint Immediate TopL_rev : proof.
+ +
+Lemma ImpLVar_rev Γ p φ ψ: (ΓVar p•(p φ)) ψ (ΓVar pφ) ψ.
+Proof.
+intro Hp.
+remember (ΓVar p•(p φ)) as Γ' eqn:HH.
+assert (Heq: (ΓVar p) Γ' {[Var p φ]}) by ms.
+assert(Hin : (p φ) Γ')by ms.
+rw Heq 1. clear Γ HH Heq.
+induction Hp; try forward.
+- auto with proof.
+- auto with proof.
+- auto with proof.
+- apply AndL. exch 0. do 2 backward. apply IHHp. ms.
+- auto with proof.
+- auto with proof.
+- apply OrL; backward; apply IHHp1 || apply IHHp2; ms.
+- apply ImpR. backward. apply IHHp. ms.
+- case (decide ((Var p0 φ0) = (Var p φ))); intro Heq0.
+  + inversion Heq0; subst. peapply Hp.
+  + do 2 forward. exch 0. apply ImpLVar. exch 0; do 2 backward. apply IHHp. ms.
+- apply ImpLAnd. backward. apply IHHp. ms.
+- apply ImpLOr. exch 0; do 2 backward. apply IHHp. ms.
+- apply ImpLImp; backward; (apply IHHp1 || apply IHHp2); ms.
+- apply ImpBox; repeat box_tac.
+   + exch 0; do 2 backward. apply open_box_L. apply IHHp1. ms.
+   + backward. apply IHHp2. ms.
+- apply BoxR. repeat box_tac. backward. apply open_box_L. apply IHHp. ms.
+Qed.
+ +
+(* inversion for ImpLImp is only partial *)
+Lemma ImpLImp_prev Γ φ1 φ2 φ3 ψ: (Γ•((φ1 φ2) φ3)) ψ -> (Γφ3) ψ.
+Proof.
+intro Hp.
+remember (Γ •((φ1 φ2) φ3)) as Γ' eqn:HH.
+assert (Heq: Γ Γ' {[ ((φ1 φ2) φ3) ]}) by ms.
+assert(Hin :((φ1 φ2) φ3) Γ')by ms.
+rw Heq 1. clear Γ HH Heq.
+induction Hp; try forward.
+- auto with proof.
+- auto with proof.
+- auto with proof.
+- apply AndL. exch 0; do 2 backward. apply IHHp. ms.
+- auto with proof.
+- auto with proof.
+- apply OrL; backward; [apply IHHp1 | apply IHHp2]; ms.
+- apply ImpR. backward. apply IHHp. ms.
+- forward. exch 0. apply ImpLVar. exch 0. do 2 backward. apply IHHp. ms.
+- apply ImpLAnd. backward. apply IHHp. ms.
+- apply ImpLOr. exch 0. do 2 backward. apply IHHp. ms.
+- case (decide (((φ0 φ4) φ5) = ((φ1 φ2) φ3))); intro Heq0.
+  + inversion Heq0; subst. peapply Hp2.
+  + forward. apply ImpLImp; backward; (apply IHHp1 || apply IHHp2); ms.
+- apply ImpBox; repeat box_tac.
+  + exch 0; do 2 backward. apply open_box_L. apply IHHp1. ms.
+  + backward. apply IHHp2. ms.
+- apply BoxR. repeat box_tac. backward. apply open_box_L. apply IHHp. ms.
+Qed.
+ +
+(* inversion for ImpLbox is only partial too *)
+Lemma ImpLBox_prev Γ φ1 φ2 ψ: (Γ•((φ1) φ2)) ψ -> (Γφ2) ψ.
+Proof.
+intro Hp.
+remember (Γ •((φ1) φ2)) as Γ' eqn:HH.
+assert (Heq: Γ Γ' {[ ((φ1) φ2) ]}) by ms.
+assert(Hin :((φ1) φ2) Γ')by ms.
+rw Heq 1. clear Γ HH Heq.
+induction Hp; try forward.
+- auto with proof.
+- auto with proof.
+- auto with proof.
+- apply AndL. exch 0; do 2 backward. apply IHHp. ms.
+- auto with proof.
+- auto with proof.
+- apply OrL; backward; [apply IHHp1 | apply IHHp2]; ms.
+- apply ImpR. backward. apply IHHp. ms.
+- forward. exch 0. apply ImpLVar. exch 0. do 2 backward. apply IHHp. ms.
+- apply ImpLAnd. backward. apply IHHp. ms.
+- apply ImpLOr. exch 0. do 2 backward. apply IHHp. ms.
+- apply ImpLImp; backward; (apply IHHp1 || apply IHHp2); ms.
+- case (decide((φ0 φ3) = (φ1 φ2))).
+  + intro Heq; inversion Heq; subst. peapply Hp2.
+  + intro Hneq. forward. apply ImpBox; repeat box_tac.
+     * exch 0; do 2 backward. apply open_box_L; apply IHHp1. ms.
+     * backward. apply IHHp2. ms.
+- apply BoxR. repeat box_tac. backward. apply open_box_L. apply IHHp. ms.
+Qed.
+ +
+Lemma ImpLOr_rev Γ φ1 φ2 φ3 ψ: Γ•((φ1 φ2) φ3) ψ -> Γ•(φ1 φ3)•(φ2 φ3) ψ.
+Proof.
+intro Hp.
+remember (Γ •((φ1 φ2) φ3)) as Γ' eqn:HH.
+assert (Heq: Γ Γ' {[ ((φ1 φ2) φ3) ]}) by ms.
+assert(Hin :((φ1 φ2) φ3) Γ')by ms.
+rw Heq 2. clear Γ HH Heq.
+induction Hp; try forward.
+- auto with proof.
+- auto with proof.
+- auto with proof.
+- constructor 4. exch 0; do 2 backward. apply IHHp. ms.
+- auto with proof.
+- auto with proof.
+- constructor 7; backward; [apply IHHp1 | apply IHHp2]; ms.
+- constructor 8. backward. apply IHHp. ms.
+- forward. exch 0. constructor 9. exch 0. do 2 backward. apply IHHp. ms.
+- constructor 10. backward. apply IHHp. ms.
+- case (decide (((φ0 φ4) φ5) = ((φ1 φ2) φ3))); intro Heq0.
+  + inversion Heq0; subst. peapply Hp.
+  + forward. constructor 11; exch 0; do 2 backward; apply IHHp; ms.
+- constructor 12; backward; (apply IHHp1 || apply IHHp2); ms.
+- apply ImpBox; repeat box_tac.
+  + exch 0; do 2 backward. apply IHHp1. ms.
+  + backward. apply IHHp2. ms.
+- apply BoxR. repeat box_tac. backward. apply IHHp. ms.
+Qed.
+ +
+Lemma ImpLAnd_rev Γ φ1 φ2 φ3 ψ: (Γ•(φ1 φ2 φ3)) ψ -> (Γ•(φ1 φ2 φ3)) ψ .
+Proof.
+intro Hp.
+remember (Γ •((φ1 φ2) φ3)) as Γ' eqn:HH.
+assert (Heq: Γ Γ' {[ ((φ1 φ2) φ3) ]}) by ms.
+assert(Hin :((φ1 φ2) φ3) Γ')by ms.
+rw Heq 1. clear Γ HH Heq.
+induction Hp; try forward.
+- auto with proof.
+- auto with proof.
+- auto with proof.
+- constructor 4. exch 0; do 2 backward. apply IHHp. ms.
+- auto with proof.
+- auto with proof.
+- constructor 7; backward; [apply IHHp1 | apply IHHp2]; ms.
+- constructor 8. backward. apply IHHp. ms.
+- forward. exch 0. constructor 9. exch 0. do 2 backward. apply IHHp. ms.
+- case (decide (((φ0 φ4) φ5) = ((φ1 φ2) φ3))); intro Heq0.
+  + inversion Heq0; subst. peapply Hp.
+  + forward. constructor 10. backward. apply IHHp. ms.
+- constructor 11; exch 0; do 2 backward; apply IHHp; ms.
+- constructor 12; backward; (apply IHHp1 || apply IHHp2); ms.
+- apply ImpBox; repeat box_tac.
+  + exch 0; do 2 backward. apply IHHp1. ms.
+  + backward. apply IHHp2. ms.
+- apply BoxR. repeat box_tac. backward. apply IHHp. ms.
+Qed.
+ +
+Global Hint Resolve AndL_rev : proof.
+Global Hint Resolve OrL_rev : proof.
+Global Hint Resolve ImpLVar_rev : proof.
+Global Hint Resolve ImpLOr_rev : proof.
+Global Hint Resolve ImpLAnd_rev : proof.
+Global Hint Resolve ImpLBox_prev : proof.
+ +
+Lemma exfalso Γ φ: Γ -> Γ φ.
+Proof.
+intro Hp. dependent induction Hp; try tauto; auto with proof; tauto.
+Qed.
+ +
+Global Hint Immediate exfalso : proof.
+ +
+Lemma AndR_rev {Γ φ1 φ2} : Γ φ1 φ2 -> (Γ φ1) * (Γ φ2).
+Proof. intro Hp. dependent induction Hp generalizing φ1 φ2 Hp; intuition; auto with proof. Qed.
+ +
+
+ +
+A general inversion rule for disjunction is not admissible. However, inversion holds if one of the formulas is ⊥. +
+
+ +
+Lemma OrR1Bot_rev Γ φ : Γ φ -> Γ φ.
+Proof. intro Hd. dependent induction Hd; auto with proof. Qed.
+Lemma OrR2Bot_rev Γ φ : Γ φ -> Γ φ.
+Proof. intro Hd. dependent induction Hd; auto with proof. Qed.
+ +
+
+ +
+We prove Lemma 4.1 of (Dyckhoff & Negri 2000). This lemma shows that a + weaker version of the ImpL rule of Gentzen's original calculus LJ is still + admissible in G4ip. The proof is simple, but requires the inversion lemmas + proved above. + +
+
+ +
+Lemma weak_ImpL Γ φ ψ θ :Γ φ -> Γψ θ -> Γ•(φ ψ) θ.
+Proof with (auto with proof).
+intro Hp. revert ψ θ. induction Hp; intros ψ0 θ0 Hp'.
+- auto with proof.
+- auto with proof.
+- auto with proof.
+- exch 0; constructor 4; exch 1; exch 0...
+- auto with proof.
+- apply ImpLOr. exch 0...
+- exch 0; constructor 7; exch 0...
+  + apply IHHp1. exch 0. eapply fst, OrL_rev. exch 0. exact Hp'.
+  + apply IHHp2. exch 0. eapply snd, OrL_rev. exch 0. exact Hp'.
+- auto with proof.
+- exch 0; exch 1. constructor 9. exch 1; exch 0...
+- exch 0. apply ImpLAnd. exch 0...
+- exch 0. apply ImpLOr. exch 1; exch 0...
+- exch 0. apply ImpLImp; exch 0... apply IHHp2. exch 0...
+  eapply ImpLImp_prev. exch 0. eassumption.
+- exch 0. apply ImpBox; box_tac.
+  + exch 1; exch 0...
+  + exch 0. apply IHHp2. exch 0. apply ImpLBox_prev with φ1. exch 0. exact Hp'.
+- auto with proof.
+Qed.
+ +
+Global Hint Resolve weak_ImpL : proof.
+ +
+
+ +
+

Contraction

+ + +
+ + The aim of this section is to prove that the contraction rule is admissible in + G4ip. +
+ + An auxiliary definition of **height** of a proof, measured along the leftmost branch. +
+
+Fixpoint height {Γ φ} (Hp : Γ φ) := match Hp with
+| Atom _ _ => 1
+| ExFalso _ _ => 1
+| AndR Γ φ ψ H1 H2 => 1 + height H1 + height H2
+| AndL Γ φ ψ θ H => 1 + height H
+| OrR1 Γ φ ψ H => 1 + height H
+| OrR2 Γ φ ψ H => 1 + height H
+| OrL Γ φ ψ θ H1 H2 => 1 + height H1 + height H2
+| ImpR Γ φ ψ H => 1 + height H
+| ImpLVar Γ p φ ψ H => 1 + height H
+| ImpLAnd Γ φ1 φ2 φ3 ψ H => 1 + height H
+| ImpLOr Γ φ1 φ2 φ3 ψ H => 1 + height H
+| ImpLImp Γ φ1 φ2 φ3 ψ H1 H2 => 1 + height H1 + height H2
+| ImpBox Γ φ1 φ2 ψ H1 H2 => 1 + height H1 + height H2
+| BoxR Γ φ H => 1 + height H
+end.
+ +
+Lemma height_0 {Γ φ} (Hp : Γ φ) : height Hp <> 0.
+Proof. destruct Hp; simpl; lia. Qed.
+ +
+
+ +
+Lemma 4.2 in (Dyckhoff & Negri 2000), showing that a "duplication" in the context of the implication-case of the implication-left rule is admissible. +
+
+ +
+Lemma ImpLImp_dup Γ φ1 φ2 φ3 θ:
+  Γ•((φ1 φ2) φ3) θ ->
+    Γφ1 •(φ2 φ3) •(φ2 φ3) θ.
+Proof.
+intro Hp.
+remember (Γ•((φ1 φ2) φ3)) as Γ0 eqn:Heq0.
+assert(HeqΓ : Γ Γ0 {[((φ1 φ2) φ3)]}) by ms.
+rw HeqΓ 3.
+assert(Hin : ((φ1 φ2) φ3) Γ0) by (subst Γ0; ms).
+clear Γ HeqΓ Heq0.
+(* by induction on the height of the derivation *)
+remember (height Hp) as h.
+assert(Hleh : height Hp h) by lia. clear Heqh.
+revert Γ0 θ Hp Hleh Hin. induction h as [|h]; intros Γ θ Hp Hleh Hin;
+[pose (height_0 Hp); lia|].
+destruct Hp; simpl in Hleh.
+- forward. auto with proof.
+- forward. auto with proof.
+- apply AndR.
+  + apply IHh with Hp1. lia. ms.
+  + apply IHh with Hp2. lia. ms.
+- forward. apply AndL. exch 0. do 2 backward. apply IHh with Hp. lia. ms.
+- apply OrR1. apply IHh with Hp. lia. ms.
+- apply OrR2. apply IHh with Hp. lia. ms.
+- forward. apply OrL; backward.
+  + apply IHh with Hp1. lia. ms.
+  + apply IHh with Hp2. lia. ms.
+- apply ImpR. backward. apply IHh with Hp. lia. ms.
+- do 2 forward. exch 0. apply ImpLVar. exch 0. do 2 backward.
+  apply IHh with Hp. lia. ms.
+- forward. apply ImpLAnd. backward. apply IHh with Hp. lia. ms.
+- forward. apply ImpLOr. exch 0. do 2 backward. apply IHh with Hp. lia. ms.
+- case (decide (((φ0 φ4) φ5) = ((φ1 φ2) φ3))); intro Heq.
+  + inversion Heq; subst.
+    apply weak_ImpL.
+    * exch 0. apply ImpR_rev. peapply Hp1.
+    * do 2 (exch 0; apply weakening). peapply Hp2.
+  + forward. apply ImpLImp; backward.
+    * apply IHh with Hp1. lia. ms.
+    * apply IHh with Hp2. lia. ms.
+- forward. apply ImpBox; repeat box_tac.
+  + exch 0. do 2 backward.
+      exch 1; exch 0. apply open_box_L; exch 0; exch 1.
+      apply IHh with Hp1. lia. ms.
+  + backward. apply IHh with Hp2. lia. ms.
+- apply BoxR. repeat box_tac. backward.
+  exch 1; exch 0; apply open_box_L; exch 0; exch 1.
+  apply IHh with Hp. lia. ms.
+Qed.
+ +
+Lemma ImpBox_dup Γ φ1 φ2 θ:
+  Γ•(φ1 φ2) θ ->
+    Γ φ1 φ1 φ2 θ.
+Proof.
+intro Hp.
+remember (Γ ( φ1 φ2)) as Γ0 eqn:Heq0.
+assert(HeqΓ : Γ Γ0 {[( φ1 φ2)]}) by ms.
+rw HeqΓ 3.
+assert(Hin : ( φ1 φ2) Γ0) by (subst Γ0; ms).
+clear Γ HeqΓ Heq0.
+(* by induction on the height of the derivation *)
+remember (height Hp) as h.
+assert(Hleh : height Hp h) by lia. clear Heqh.
+revert Γ0 θ Hp Hleh Hin. induction h as [|h]; intros Γ θ Hp Hleh Hin;
+[pose (height_0 Hp); lia|].
+destruct Hp; simpl in Hleh.
+- forward. auto with proof.
+- forward. auto with proof.
+- apply AndR.
+  + apply IHh with Hp1. lia. ms.
+  + apply IHh with Hp2. lia. ms.
+- forward. apply AndL. exch 0. do 2 backward. apply IHh with Hp. lia. ms.
+- apply OrR1. apply IHh with Hp. lia. ms.
+- apply OrR2. apply IHh with Hp. lia. ms.
+- forward. apply OrL; backward.
+  + apply IHh with Hp1. lia. ms.
+  + apply IHh with Hp2. lia. ms.
+- apply ImpR. backward. apply IHh with Hp. lia. ms.
+- do 2 forward. exch 0. apply ImpLVar. exch 0. do 2 backward.
+  apply IHh with Hp. lia. ms.
+- forward. apply ImpLAnd. backward. apply IHh with Hp. lia. ms.
+- forward. apply ImpLOr. exch 0. do 2 backward. apply IHh with Hp. lia. ms.
+- forward. apply ImpLImp.
+  + backward. apply IHh with Hp1. lia. ms.
+  + backward. apply IHh with Hp2. lia. ms.
+  (*
+case (decide (((φ0 → φ4) → φ5) = ((φ1 → φ2) → φ3))); intro Heq.
+  + inversion Heq; subst.
+    apply weak_ImpL.
+    * exch 0. apply ImpR_rev. peapply Hp1.
+    * do 2 (exch 0; apply weakening). peapply Hp2.
+  + forward. apply ImpLImp; backward.
+    * apply IHh with Hp1. lia. ms.
+    * apply IHh with Hp2. lia. ms. *)

+- case (decide (( φ0 φ3) = φ1 φ2)); intro Heq.
+  + inversion Heq; subst.
+      exch 0. apply weakening. exch 0. apply weakening. peapply Hp2.
+  + forward. apply ImpBox; repeat box_tac.
+      * exch 0. do 2 backward.
+         replace (φ1) with ( ( φ1)) by trivial.
+         apply open_box_L; exch 0. apply open_box_L; exch 1; exch 0. apply open_box_L.
+         exch 1; exch 0. simpl.
+         apply IHh with Hp1. lia. ms.
+      * backward. apply IHh with Hp2. lia. ms.
+- apply BoxR. repeat box_tac. backward.
+   replace (φ1) with ( ( φ1)) by trivial.
+   apply open_box_L; exch 0. apply open_box_L; exch 1; exch 0. apply open_box_L.
+   exch 1; exch 0. simpl.
+  apply IHh with Hp. lia. ms.
+Qed.
+ +
+(* technical lemma for contraction *)
+Local Lemma p_contr Γ φ θ:
+  (Γφφ) {[φ]} θ ->
+  ((Γφ) θ).
+Proof. intros * Hd; peapply Hd. Qed.
+ +
+Lemma is_box_weight_open_box φ : is_box φ = true -> weight ( φ) = weight φ -1.
+Proof. destruct φ; simpl; lia. Qed.
+ +
+Lemma weight_open_box φ : weight ( φ) weight φ.
+Proof. destruct φ; simpl; lia. Qed.
+ +
+
+ +
+Admissibility of contraction in G4ip. +
+
+Lemma contraction Γ ψ θ : Γψψ θ -> Γψ θ.
+Proof.
+remember (Γψψ) as Γ0 eqn:Heq0.
+assert(HeqΓ : (Γψ) Γ0 {[ψ]}) by ms.
+intro Hp. rw HeqΓ 0.
+assert(Hin : ψ Γ0) by (subst Γ0; ms).
+assert(Hin' : ψ Γ0 {[ψ]}) by(rewrite <- HeqΓ; ms).
+clear Γ HeqΓ Heq0. revert Hp.
+(* by induction on the weight of ψ *)
+remember (weight ψ) as w.
+assert(Hle : weight ψ w) by lia.
+clear Heqw. revert Γ0 ψ θ Hle Hin Hin'.
+induction w; intros Γ ψ θ Hle Hin Hin' Hp; [destruct ψ; simpl in Hle; lia|].
+(* by induction on the height of the premise *)
+remember (height Hp) as h.
+assert(Hleh : height Hp h) by lia. clear Heqh.
+revert Γ θ Hp Hleh Hin Hin'. revert ψ Hle; induction h as [|h]; intros ψ Hle Γ θ Hp Hleh Hin Hin';
+[pose (height_0 Hp); lia|].
+destruct Hp; simpl in Hleh, Hle.
+- case(decide= Var p)).
+  + intro; subst. exhibit Hin' 0. apply Atom.
+  + intro Hneq. forward. apply Atom.
+- case(decide= )).
+  + intro; subst. exhibit Hin' 0. apply ExFalso.
+  + intro. forward. apply ExFalso.
+- apply AndR.
+  + apply (IHh ψ Hle) with Hp1. lia. ms. ms.
+  + apply (IHh ψ Hle) with Hp2. lia. ms. ms.
+- case (decide= (φ ψ0))); intro Heq.
+  + subst. exhibit Hin' 0. apply AndL.
+    apply p_contr. simpl in Hle. apply IHw. lia. ms. rewrite union_difference_R; ms.
+    exch 1. exch 0. apply p_contr. apply IHw. lia. ms. rewrite union_difference_R; ms.
+    exch 1. exch 0. apply AndL_rev. exch 0. exch 1. peapply Hp.
+    rewrite <- (difference_singleton _ _ Hin'). ms.
+  + rewrite union_difference_L in Hin' by ms.
+    forward. apply AndL. exch 0. do 2 backward. apply (IHh ψ Hle) with Hp. lia. ms. ms.
+- apply OrR1. apply (IHh ψ Hle) with Hp. lia. ms. ms.
+- apply OrR2. apply (IHh ψ Hle) with Hp. lia. ms. ms.
+- case (decide= (φ ψ0))); intro Heq.
+  + subst. exhibit Hin' 0.
+    apply OrL.
+    * apply p_contr. simpl in Hle. apply IHw. lia. ms. rewrite union_difference_R; ms.
+      refine (fst (OrL_rev _ φ ψ0 _ _)). exch 0. peapply Hp1.
+      rewrite <- env_replace; ms.
+    * apply p_contr. simpl in Hle. apply IHw. lia. ms. rewrite union_difference_R; ms.
+      refine (snd (OrL_rev _ φ ψ0 _ _)). exch 0. peapply Hp2.
+      rewrite <- env_replace; ms.
+  + rewrite union_difference_L in Hin' by ms.
+    forward. apply OrL; backward.
+    * apply (IHh ψ Hle) with Hp1. lia. ms. ms.
+    * apply (IHh ψ Hle) with Hp2. lia. ms. ms.
+- apply ImpR. backward. apply (IHh ψ Hle) with Hp. lia. ms. ms.
+- case (decide= (p φ))); intro Heq.
+  + subst. exhibit Hin' 0. rewrite union_difference_R in Hin' by ms.
+    assert(Hcut : (((ΓVar p) {[Var p φ]}•(Var p φ)) ψ0)); [|peapply Hcut].
+    forward. exch 0. apply ImpLVar, p_contr.
+    apply IHw. simpl in Hle; lia. ms. rewrite union_difference_L; ms.
+    exch 1. apply ImpLVar_rev. exch 0; exch 1. peapply Hp.
+    rewrite <- env_replace; ms.
+  + rewrite union_difference_L in Hin' by ms.
+      forward. case (decide= Var p)).
+      * intro; subst. forward. exch 0. apply ImpLVar. exch 0.
+         do 2 backward. apply (IHh (Var p) Hle) with Hp. lia. ms. ms.
+      * intro. forward. exch 0. apply ImpLVar; exch 0; do 2 backward.
+         apply (IHh ψ Hle) with Hp. lia. ms. ms.
+- case (decide= (φ1 φ2 φ3))); intro Heq.
+  + subst. exhibit Hin' 0. rewrite union_difference_R in Hin' by ms.
+    apply ImpLAnd. apply p_contr.
+    apply IHw. simpl in *; lia. ms. rewrite union_difference_L; ms.
+    apply ImpLAnd_rev. exch 0. peapply Hp.
+    rewrite <- env_replace; ms.
+  + rewrite union_difference_L in Hin' by ms.
+    forward. apply ImpLAnd. backward. apply (IHh ψ Hle) with Hp. lia. ms. ms.
+- case (decide= (φ1 φ2 φ3))); intro Heq.
+  + subst. exhibit Hin' 0. rewrite union_difference_R in Hin' by ms.
+    apply ImpLOr. apply p_contr.
+    apply IHw. simpl in *; lia. ms. rewrite union_difference_L; ms.
+    exch 1; exch 0. apply p_contr.
+    apply IHw. simpl in *. lia. ms. rewrite union_difference_L; ms.
+    exch 1; exch 0. apply ImpLOr_rev. exch 0. exch 1. peapply Hp.
+    rewrite <- env_replace; ms.
+  + rewrite union_difference_L in Hin' by ms.
+    forward. apply ImpLOr. exch 0. do 2 backward. apply (IHh ψ Hle) with Hp. lia. ms. ms.
+- case (decide= ((φ1 φ2) φ3))); intro Heq.
+  + subst. exhibit Hin' 0. rewrite union_difference_R in Hin' by ms.
+    apply ImpLImp.
+    * apply ImpR.
+      do 3 (exch 0; apply p_contr; apply IHw; [simpl in *; lia|ms|rewrite union_difference_L; ms|exch 1]).
+      exch 1; apply ImpLImp_dup. (* key lemma *)
+      exch 0; exch 1. apply ImpR_rev.
+      peapply Hp1. rewrite <- env_replace; ms.
+    * apply p_contr; apply IHw; [simpl in *; lia|ms|rewrite union_difference_L; ms|].
+      apply (ImpLImp_prev _ φ1 φ2 φ3). exch 0.
+      peapply Hp2. rewrite <- env_replace; ms.
+  + rewrite union_difference_L in Hin' by ms.
+    forward. apply ImpLImp; backward.
+    * apply (IHh ψ Hle) with Hp1. lia. ms. ms.
+    * apply (IHh ψ Hle) with Hp2. lia. ms. ms.
+- case (decide= ( φ1 φ2))); intro Heq.
+  + subst. exhibit Hin' 0.
+    apply ImpBox.
+    * assert (Hr := open_boxes_remove _ _ Hin'). simpl in Hr. box_tac. symmetry in Hr. rw Hr 2.
+        clear Hr.
+        do 3 (exch 0; apply p_contr; apply IHw; [simpl in *; lia|ms|rewrite union_difference_L; ms|exch 1]).
+       exch 0.
+       assert(Heq : ( (Γ ( φ1 φ2)) {[ φ1 φ2]} {[ φ1 φ2]}) ( (Γ {[ φ1 φ2]})))
+       by (autorewrite with proof; simpl; ms).
+       rw Heq 5. clear Heq.
+       apply ImpBox_dup. exch 0; exch 1. peapply Hp1. rewrite open_boxes_remove; [|ms]. simpl.
+       rewrite <- difference_singleton. ms. apply open_boxes_spec'. left. simpl; split; trivial. ms.
+      * apply p_contr; apply IHw; [simpl in *; lia|ms|rewrite union_difference_L; ms|].
+         apply (ImpLBox_prev _ φ1 φ2). exch 0.
+         peapply Hp2. rewrite <- env_replace; ms.
+  + rewrite union_difference_L in Hin' by ms.
+      assert(Hinψ : ψ (Γ {[ψ]})) by ms. apply In_open_boxes in Hinψ.
+      forward. apply ImpBox. box_tac. exch 0; do 2 backward.
+      * rewrite open_boxes_remove in Hinψ by trivial.
+         case_eq (is_box ψ); intro Hψ.
+       -- apply is_box_weight_open_box in Hψ.
+          assert (Hle' : weight(ψ) S w) by lia.
+          apply (IHh ( ψ) Hle') with Hp1. lia. ms. ms.
+      -- apply is_not_box_open_box in Hψ. rewrite Hψ. apply IHh with Hp1.
+          trivial. lia. rewrite <- Hψ. ms. trivial. rewrite <- Hψ. ms.
+      * backward. apply (IHh ψ Hle) with Hp2. lia. ms. ms.
+- assert(Hinψ : ψ (Γ {[ψ]})) by ms. apply In_open_boxes in Hinψ.
+   rewrite open_boxes_remove in Hinψ by trivial.
+  apply BoxR. box_tac. backward. apply IHh with Hp.
+    etransitivity. apply weight_open_box. trivial.
+    lia.
+    ms.
+    ms.
+Qed.
+ +
+Global Hint Resolve contraction : proof.
+ +
+Theorem generalised_contraction (Γ Γ' : env) φ: Γ' Γ' Γ φ -> Γ' Γ φ.
+Proof.
+revert Γ.
+induction Γ' as [| x Γ' IHΓ'] using gmultiset_rec; intros Γ Hp.
+- peapply Hp.
+- peapply (contraction (Γ' Γ) x). peapply (IHΓ' (Γxx)). peapply Hp.
+Qed.
+ +
+
+ +
+

Admissibility of LJ's implication left rule

+ +
+ + We show that the general implication left rule of LJ is admissible in G4ip. + This is Proposition 5.2 in (Dyckhoff Negri 2000). +
+
+ +
+Lemma ImpL Γ φ ψ θ: Γ•(φ ψ) φ -> Γψ θ -> Γ•(φ ψ) θ.
+Proof. intros H1 H2. apply contraction, weak_ImpL; auto with proof. Qed.
+ +
+(* Lemma 5.3 (Dyckhoff Negri 2000) shows that an implication on the left may be
+   weakened. *)

+ +
+Lemma imp_cut φ Γ ψ θ: Γ•(φ ψ) θ -> Γψ θ.
+Proof.
+intro Hp.
+remember (Γ•(φ ψ)) as Γ0 eqn:HH.
+assert (Heq: Γ Γ0 {[(φ ψ)]}) by ms.
+assert(Hin : (φ ψ) Γ0) by ms. clear HH.
+rw Heq 1. clear Heq Γ.
+remember (weight φ) as w.
+assert(Hle : weight φ w) by lia.
+clear Heqw. revert Γ0 φ ψ θ Hle Hin Hp.
+induction w; intros Γ φ ψ θ Hle Hin Hp;
+ [destruct φ; simpl in Hle; lia|].
+induction Hp.
+- forward. auto with proof.
+- forward. auto with proof.
+-apply AndR; intuition.
+- forward; apply AndL. exch 0. do 2 backward. apply IHHp. ms.
+- apply OrR1; intuition.
+- apply OrR2; intuition.
+- forward. apply OrL; backward; [apply IHHp1 | apply IHHp2]; ms.
+- apply ImpR. backward. apply IHHp. ms.
+- case (decide ((p φ0) = (φ ψ))); intro Heq0.
+  + inversion Heq0; subst. peapply Hp.
+  + do 2 forward. exch 0. apply ImpLVar. exch 0. do 2 backward. apply IHHp; ms.
+- case (decide ((φ1 φ2 φ3) = (φ ψ))); intro Heq0.
+  + inversion Heq0; subst.
+    assert(Heq1 : ((Γ•(φ1 φ2 ψ)) {[φ1 φ2 ψ]}) Γ) by ms;
+    rw Heq1 1; clear Heq1. simpl in Hle.
+    peapply (IHw (Γ•(φ2 ψ)) φ2 ψ ψ0); [lia|ms|].
+    peapply (IHw (Γ•(φ1 φ2 ψ)) φ1 (φ2 ψ) ψ0); [lia|ms|trivial].
+  + forward. apply ImpLAnd. backward. apply IHHp. ms.
+- case (decide ((φ1 φ2 φ3) = (φ ψ))); intro Heq0.
+  + inversion Heq0. subst. clear Heq0.
+    apply contraction. simpl in Hle.
+    peapply (IHw (Γψ•(φ1 ψ)) φ1 ψ); [lia|ms|].
+    exch 0.
+    peapply (IHw (Γ•(φ1 ψ)•(φ2 ψ)) φ2 ψ); trivial; [lia|ms].
+  + forward. apply ImpLOr; exch 0; do 2 backward; apply IHHp; ms.
+- case (decide (((φ1 φ2) φ3) = (φ ψ))); intro Heq0.
+  + inversion Heq0. subst. clear Heq0. peapply Hp2.
+  + forward. apply ImpLImp; backward; (apply IHHp1 || apply IHHp2); ms.
+- case (decide((φ1 φ2) = (φ ψ))).
+  + intro Heq. inversion Heq. subst. clear Heq. peapply Hp2.
+  + intro Hneq. forward. apply ImpBox; repeat box_tac.
+      * exch 0. do 2 backward. apply open_box_L. apply IHHp1. ms.
+      * backward. apply IHHp2. ms.
+- apply BoxR. repeat box_tac. backward. apply open_box_L, IHHp.
+  apply env_in_add. right. auto with proof.
+Qed.
+ +
+Global Hint Resolve imp_cut : proof.
+ +
+Lemma open_boxes_case Δ : {φ | ( φ) Δ} + {Δ Δ}.
+Proof.
+unfold open_boxes.
+induction Δ as [|ψ Δ IH] using gmultiset_rec.
+- right. ms.
+- case_eq(is_box ψ); intro Hbox.
+  + left. exists (ψ).
+      destruct ψ; try discriminate Hbox. ms.
+  + destruct IH as [[φ Hφ]| Heq].
+     * left. exists φ. ms.
+     * right. symmetry. etransitivity.
+        -- apply env_equiv_eq, list_to_set_disj_perm, Permutation_map.
+            apply gmultiset_elements_disj_union.
+        -- rewrite map_app, list_to_set_disj_app. rewrite <- Heq. apply env_equiv_eq.
+            f_equal.
+            unfold elements. apply is_not_box_open_box in Hbox. rewrite <- Hbox at 2.
+            transitivity (list_to_set_disj (map open_box (id [ψ])) : env).
+            ++ apply list_to_set_disj_perm, Permutation_map.
+                    apply Permutation_refl', gmultiset_elements_singleton.
+            ++ simpl. ms.
+Qed.
+
+
+ +
+ + + diff --git a/ISL.Sequents.html b/ISL.Sequents.html new file mode 100644 index 0000000..d0e67c6 --- /dev/null +++ b/ISL.Sequents.html @@ -0,0 +1,303 @@ + + + + + + + + + + + + + +
+
+

ISL.Sequents

+ +
+Require Export ISL.Environments.
+ +
+Open Scope stdpp_scope.
+ +
+
+ +
+

Overview: Sequent calculus G4ip

+ +
+ + We implement the sequent calculus G4ip, a contraction-free + refinement of the usual Gentzen sequent calculus LJ for intuitionistic + propositional logic, which was developed by the Soviet school of proof theory + (Vorob'ev 1970) and introduced in the West by (Hudelmaier 1989) and (Dyckhoff + 1990). This calculus is also referred to as "LJT" in the literature, but we this name has also been used in the literature for other, unrelated calculi, so we prefer to use "G4ip" to avoid ambiguity. + +
+ + The calculus G4ip is important because it allows for a terminating proof + search, and in our proof of Pitts' theorem, it therefore lets us perform + well-founded induction on proofs. Technically, this is thanks to the absence of + a contraction rule. The left implication rule is refined into four separate + proof rules. +
+ +

Definition of provability in G4iSL

+ +
+
+Reserved Notation "Γ ⊢ φ" (at level 90).
+Inductive Provable : env -> form -> Type :=
+| Atom : Γ p, Γ (Var p) (Var p)
+| ExFalso : Γ φ, Γ φ
+| AndR : Γ φ ψ,
+    Γ φ -> Γ ψ ->
+      Γ (φ ψ)
+| AndL : Γ φ ψ θ,
+    Γ φ ψ θ ->
+      Γ (φ ψ) θ
+| OrR1 : Γ φ ψ,
+    Γ φ ->
+      Γ (φ ψ)
+| OrR2 : Γ φ ψ,
+    Γ ψ ->
+      Γ (φ ψ)
+| OrL : Γ φ ψ θ,
+    Γ φ θ -> Γ ψ θ ->
+      Γ (φ ψ) θ
+| ImpR : Γ φ ψ,
+    Γ φ ψ ->
+      Γ (φ ψ)
+| ImpLVar : Γ p φ ψ,
+    Γ Var p φ ψ ->
+      Γ Var p (Var p φ) ψ
+| ImpLAnd : Γ φ1 φ2 φ3 ψ,
+    Γ (φ1 (φ2 φ3)) ψ ->
+      Γ ((φ1 φ2) φ3) ψ
+| ImpLOr : Γ φ1 φ2 φ3 ψ,
+    Γ (φ1 φ3) (φ2 φ3) ψ ->
+      Γ ((φ1 φ2) φ3) ψ
+| ImpLImp : Γ φ1 φ2 φ3 ψ,
+    Γ (φ2 φ3) (φ1 φ2) ->Γ φ3 ψ ->
+      Γ ((φ1 φ2) φ3) ψ
+| ImpBox : Γ φ1 φ2 ψ,
+    ( Γ) φ1 φ2 φ1 ->
+    Γ φ2 ψ ->
+      Γ (( φ1) φ2) ψ
+| BoxR : Γ φ, open_boxes Γ φ φ -> Γ φ
+where "Γ ⊢ φ" := (Provable Γ φ).
+ +
+Global Hint Constructors Provable : proof.
+ +
+
+ +
+We show that equivalent multisets prove the same things. +
+
+Global Instance proper_Provable : Proper ((≡@{env}) ==> (=) ==> (=)) Provable.
+Proof. intros Γ Γ' Heq φ φ' Heq'. ms. Qed.
+ +
+
+ +
+We introduce a tactic "peapply" which allows for application of a G4ip rule + even in case the environment needs to be reordered +
+
+Ltac peapply th :=
+  (erewrite proper_Provable; [| |reflexivity]); [eapply th|try ms].
+ +
+
+ +
+

Tactics

+ +
+ + We introduce a few tactics that we will need to prove the admissibility of + the weakening and exchange rules in the proof calculus. +
+ + The tactic "exch" swaps the nth pair of formulas of a sequent, counting from the right. +
+
+ +
+Ltac exch n := match n with
+| O => rewrite (proper_Provable _ _ (env_add_comm _ _ _) _ _ eq_refl)
+| S O => rewrite (proper_Provable _ _ (equiv_disj_union_compat_r (env_add_comm _ _ _)) _ _ eq_refl)
+| S (S O) => rewrite (proper_Provable _ _ (equiv_disj_union_compat_r(equiv_disj_union_compat_r (env_add_comm _ _ _))) _ _ eq_refl)
+| S (S (S O)) => rewrite (proper_Provable _ _ (equiv_disj_union_compat_r(equiv_disj_union_compat_r(equiv_disj_union_compat_r (env_add_comm _ _ _)))) _ _ eq_refl)
+end.
+ +
+
+ +
+The tactic "exhibit" exhibits an element that is in the environment. +
+
+Ltac exhibit Hin n := match n with
+| 0 => rewrite (proper_Provable _ _ (difference_singleton _ _ Hin) _ _ eq_refl)
+| 1 => rewrite (proper_Provable _ _ (equiv_disj_union_compat_r (difference_singleton _ _ Hin)) _ _ eq_refl)
+| 2 => rewrite (proper_Provable _ _ (equiv_disj_union_compat_r (equiv_disj_union_compat_r (difference_singleton _ _ Hin))) _ _ eq_refl)
+| 3 => rewrite (proper_Provable _ _ (equiv_disj_union_compat_r(equiv_disj_union_compat_r (equiv_disj_union_compat_r (difference_singleton _ _ Hin)))) _ _ eq_refl)
+end.
+ +
+
+ +
+The tactic "forward" tries to change a goal of the form : + +
+ +((Γ•φ ∖ {ψ}•…) ⊢ … + +
+ +into + +
+ +((Γ ∖ {ψ}•…•φ) ⊢ … , + +
+ +by first proving that ψ ∈ Γ. +
+
+ +
+Ltac forward := match goal with
+| |- (?Γ) {[]} _ =>
+  let Hin := fresh "Hin" in
+  assert(Hin : ψ Γ) by ms;
+  rewrite (proper_Provable _ _ (env_replace φ Hin) _ _ eq_refl)
+| |- (?Γ) {[]}_ _ =>
+  let Hin := fresh "Hin" in
+  assert(Hin : ψ Γ) by ms;
+  rewrite (proper_Provable _ _ (equiv_disj_union_compat_r (env_replace φ Hin)) _ _ eq_refl);
+  exch 0
+| |- (?Γ) {[]}__ _ =>
+  let Hin := fresh "Hin" in
+  assert(Hin : ψ Γ) by ms;
+  rewrite (proper_Provable _ _ (equiv_disj_union_compat_r(equiv_disj_union_compat_r (env_replace φ Hin))) _ _ eq_refl);
+  exch 1; exch 0
+| |- (?Γ) {[]}___ _ =>
+  let Hin := fresh "Hin" in
+  assert(Hin : ψ Γ) by ms;
+  rewrite (proper_Provable _ _ (equiv_disj_union_compat_r(equiv_disj_union_compat_r(equiv_disj_union_compat_r (env_replace φ Hin)))) _ _ eq_refl);
+  exch 2; exch 1; exch 0
+| |- (?Γ) {[]}____ _ =>
+  let Hin := fresh "Hin" in
+  assert(Hin : ψ Γ) by ms;
+  rewrite (proper_Provable _ _ (equiv_disj_union_compat_r(equiv_disj_union_compat_r(equiv_disj_union_compat_r(equiv_disj_union_compat_r (env_replace φ Hin))))) _ _ eq_refl);
+  exch 3; exch 2; exch 1; exch 0
+end.
+ +
+
+ +
+The tactic "backward" changes a goal of the form : + +
+ +((Γ ∖ {ψ}•…•φ) ⊢ … + +
+ +into + +
+ +((Γ•φ ∖ {ψ}•…) ⊢ …, + +
+ +by first proving that ψ ∈ Γ. + +
+ + +
+
+ +
+Ltac backward := match goal with
+| |- ?Γ {[]} _ =>
+  let Hin := fresh "Hin" in
+  assert(Hin : ψ Γ) by (ms || auto with proof);
+  rewrite (proper_Provable _ _ (symmetry(env_replace _ Hin)) _ _ eq_refl)
+| |- ?Γ {[]}_ _ =>
+  let Hin := fresh "Hin" in
+  assert(Hin : ψ Γ) by (ms || auto with proof); try exch 0;
+  rewrite (proper_Provable _ _ (symmetry(equiv_disj_union_compat_r (env_replace _ Hin))) _ _ eq_refl)
+| |- ?Γ {[]}__ _ =>
+  let Hin := fresh "Hin" in
+  assert(Hin : ψ Γ) by (ms || auto with proof); exch 0; exch 1;
+  rewrite (proper_Provable _ _ (symmetry(equiv_disj_union_compat_r(equiv_disj_union_compat_r (env_replace φ Hin)))) _ _ eq_refl)
+| |- ?Γ {[]}___ _ =>
+  let Hin := fresh "Hin" in
+  assert(Hin : ψ Γ) by (ms || auto with proof); exch 0; exch 1; exch 2;
+  rewrite (proper_Provable _ _ (symmetry(equiv_disj_union_compat_r(equiv_disj_union_compat_r(equiv_disj_union_compat_r (env_replace φ Hin))))) _ _ eq_refl)
+| |- ?Γ {[]}____ _ =>
+  let Hin := fresh "Hin" in
+  assert(Hin : ψ Γ) by (ms || auto with proof); exch 0; exch 1; exch 2; exch 3;
+  rewrite (proper_Provable _ _ (symmetry(equiv_disj_union_compat_r(equiv_disj_union_compat_r(equiv_disj_union_compat_r(equiv_disj_union_compat_r (env_replace φ Hin)))))) _ _ eq_refl)
+end.
+ +
+
+ +
+The tactic "rw" rewrites the environment equivalence Heq under the nth formula in the premise. +
+
+Ltac rw Heq n := match n with
+| 0 => erewrite (proper_Provable _ _ Heq _ _ eq_refl)
+| 1 => erewrite (proper_Provable _ _ (equiv_disj_union_compat_r Heq) _ _ eq_refl)
+| 2 => erewrite (proper_Provable _ _ (equiv_disj_union_compat_r(equiv_disj_union_compat_r Heq)) _ _ eq_refl)
+| 3 => erewrite (proper_Provable _ _ (equiv_disj_union_compat_r(equiv_disj_union_compat_r(equiv_disj_union_compat_r Heq))) _ _ eq_refl)
+| 4 => erewrite (proper_Provable _ _ (equiv_disj_union_compat_r(equiv_disj_union_compat_r(equiv_disj_union_compat_r (equiv_disj_union_compat_r Heq)))) _ _ eq_refl)
+| 5 => erewrite (proper_Provable _ _ (equiv_disj_union_compat_r(equiv_disj_union_compat_r(equiv_disj_union_compat_r(equiv_disj_union_compat_r (equiv_disj_union_compat_r Heq))))) _ _ eq_refl)
+end.
+ +
+Ltac box_tac :=
+       let rec box_tac_aux Δ n := lazymatch Δ with
+  |⊗(?Δ' ) => rewrite (open_boxes_add Δ' φ)
+  |⊗(?Γ {[]}) => match goal with |H: ψ Γ |- _ => rw (open_boxes_remove Γ ψ H) n end
+  | ?Δ' ?φ => box_tac_aux Δ' (S n) end
+  in
+    try match goal with | |- ?Δ _ => box_tac_aux Δ 0 end; simpl.
+
+
+ +
+ + + diff --git a/ISL.Simp.html b/ISL.Simp.html new file mode 100644 index 0000000..6df470b --- /dev/null +++ b/ISL.Simp.html @@ -0,0 +1,856 @@ + + + + + + + + + + + + + +
+
+

ISL.Simp

+ +
+Require Import ISL.Environments ISL.Sequents ISL.SequentProps ISL.Cut ISL.Optimizations.
+ +
+(* Normalises a large disjunctions flattening them to the right. It assumes
+that there are no disjuctions on the left of any of the input formulas, i.e.
+φ and ψ cannot be of the form ((... ∨ ... ) ∨ ...). Since this function is called 
+with the inputs previously simplified (see `simp`) this invariant is assured. *)

+Fixpoint simp_ors φ ψ :=
+match (φ,ψ) with
+  |(φ1 φ2, ψ1 ψ2) => φ1 (ψ1 (simp_ors φ2 ψ2))
+  |(φ1 φ2, ψ) => ψ (φ1 φ2)
+  |(φ, ψ1 ψ2) => φ (ψ1 ψ2)
+  |(φ, ψ) => φ ψ
+end.
+ +
+(* Same as `simp_ors` but for large conjunctions. *)
+Fixpoint simp_ands φ ψ :=
+match (φ,ψ) with
+  |(φ1 φ2, ψ1 ψ2) => φ1 (ψ1 (simp_ands φ2 ψ2))
+  |(φ1 φ2, ψ) => ψ (φ1 φ2)
+  |(φ, ψ1 ψ2) => φ (ψ1 ψ2)
+  |(φ, ψ) => φ ψ
+end.
+ +
+Definition simp_imp φ ψ :=
+  if decide (obviously_smaller φ ψ = Lt) then
+  else if decide (obviously_smaller φ = Lt) then
+  else if decide (obviously_smaller ψ = Gt) then
+  else if decide (obviously_smaller φ = Gt) then ψ
+  else if decide (obviously_smaller ψ = Lt) then ¬φ
+  else φ ψ.
+ +
+(* Same as `simp_ors` but for nested implications. *)
+Fixpoint simp_imps φ ψ :=
+match (φ,ψ) with
+  |(φ1, ψ1 ψ2) => simp_imps (simp_ands φ1 ψ1) ψ2
+  |(φ, ψ) => simp_imp φ ψ
+end.
+Fixpoint simp φ :=
+match φ with
+  | φ ψ => simp_ors (simp φ) (simp ψ)
+  | φ ψ => simp_ands (simp φ) (simp ψ)
+  | φ ψ => simp_imps (simp φ) (simp ψ)
+  | φ => (simp φ)
+  | _ => φ
+end.
+ +
+Lemma or_comm φ ψ: φ ψ ψ φ.
+Proof.
+apply OrL; [apply OrR2 | apply OrR1]; apply generalised_axiom.
+Qed.
+ +
+Lemma or_comm_ctx_L φ ψ ϴ: (φ ψ ϴ) -> ψ φ ϴ.
+Proof.
+intro H.
+eapply weak_cut; [apply or_comm | assumption].
+Qed.
+ +
+Lemma or_comm_ctx_R φ ψ ϴ: (ϴ φ ψ ) -> ϴ ψ φ.
+Proof.
+intro H.
+eapply weak_cut; [apply H | apply or_comm].
+Qed.
+ +
+Lemma or_assoc_R φ ψ ϴ : ((φ ψ) ϴ φ (ψ ϴ)).
+Proof.
+  apply OrL.
+  - apply OrL.
+    + apply OrR1; apply generalised_axiom.
+    + apply OrR2; apply OrR1; apply generalised_axiom.
+  - apply OrR2; apply OrR2; apply generalised_axiom.
+Qed.
+ +
+Lemma or_assoc_L φ ψ ϴ : (φ (ψ ϴ) (φ ψ) ϴ).
+Proof.
+  apply OrL.
+  - apply OrR1; apply OrR1; apply generalised_axiom.
+  - apply OrL.
+    + apply OrR1; apply OrR2; apply generalised_axiom.
+    + apply OrR2; apply generalised_axiom.
+Qed.
+ +
+Lemma or_assoc_ctx_L_R φ ψ ϴ a:
+  (φ (ψ ϴ) a) -> ((φ ψ) ϴ) a.
+Proof.
+intro H.
+eapply weak_cut; [apply or_assoc_R | assumption].
+Qed.
+ +
+Lemma or_assoc_ctx_R_L φ ψ ϴ a:
+  (a (φ ψ) ϴ) ->a φ (ψ ϴ).
+Proof.
+intro H.
+eapply weak_cut; [apply H | apply or_assoc_R].
+Qed.
+ +
+Lemma or_assoc_ctx_R_R φ ψ ϴ a:
+  (a φ (ψ ϴ)) ->a (φ ψ) ϴ.
+Proof.
+intro H.
+eapply weak_cut; [apply H | apply or_assoc_L].
+Qed.
+ +
+Lemma make_disj_comm φ ψ :
+  (φ ψ) (ψ φ).
+Proof.
+apply (weak_cut _ ψ) _).
+- apply make_disj_equiv_R; apply generalised_axiom.
+- apply (weak_cut _ φ) _).
+  + apply or_comm.
+  + apply make_disj_equiv_L; apply generalised_axiom.
+Qed.
+ +
+Lemma make_disj_comm_ctx_R a φ ψ :
+  (a φ ψ) -> a ψ φ.
+Proof.
+intro H.
+eapply weak_cut; [apply H | apply make_disj_comm].
+Qed.
+ +
+Lemma make_disj_comm_ctx_L a φ ψ :
+  (φ ψ a) -> ψ φ a.
+Proof.
+intro H.
+eapply weak_cut; [apply make_disj_comm | apply H].
+Qed.
+ +
+Lemma simp_ors_self_equiv_L φ ψ:
+  (φ ψ) simp_ors φ ψ.
+Proof.
+generalize ψ.
+induction φ;
+intro ψ0;
+destruct ψ0; unfold simp_ors; try (eapply make_disj_equiv_L; apply generalised_axiom);
+try (apply make_disj_comm_ctx_R; apply make_disj_equiv_L; apply generalised_axiom).
+assert (H: φ1 ψ0_1 φ2 ψ0_2 φ1 (ψ0_1 simp_ors φ2 ψ0_2)).
+- apply make_disj_equiv_L.
+  + apply generalised_axiom.
+  + apply make_disj_equiv_L.
+    * apply generalised_axiom.
+    * apply IHφ2.
+- eapply weak_cut.
+  + apply or_assoc_ctx_L_R.
+    apply OrL.
+    * apply OrR1. apply generalised_axiom.
+    * apply OrR2. apply or_comm_ctx_L.
+      apply OrL.
+      -- apply or_assoc_ctx_R_L. apply or_comm_ctx_L.
+        apply or_comm_ctx_L.
+        apply or_comm_ctx_R.
+        apply or_assoc_ctx_R_L.
+        apply OrR1.
+        apply or_comm.
+      -- apply OrR2; apply OrR1; apply generalised_axiom.
+  + assumption.
+Qed.
+ +
+Lemma simp_equiv_or_L φ ψ :
+  (φ simp φ) -> (ψ simp ψ) ->
+  (φ ψ) simp (φ ψ).
+Proof.
+intros Hφ Hψ.
+eapply weak_cut; [apply or_congruence; [apply Hφ | apply Hψ] | apply simp_ors_self_equiv_L].
+Qed.
+ +
+Lemma simp_ors_self_equiv_R φ ψ:
+  simp_ors φ ψ φ ψ.
+Proof.
+generalize ψ.
+induction φ;
+intro ψ0;
+destruct ψ0; unfold simp_ors;
+try (eapply make_disj_equiv_R; apply generalised_axiom);
+try (apply make_disj_comm_ctx_L; apply make_disj_equiv_R; apply generalised_axiom).
+assert (H: φ1 (ψ0_1 simp_ors φ2 ψ0_2) φ1 ψ0_1 φ2 ψ0_2).
+- apply make_disj_equiv_R.
+  + apply generalised_axiom.
+  + apply make_disj_equiv_R.
+    * apply generalised_axiom.
+    * apply IHφ2.
+- apply or_assoc_ctx_R_R.
+  eapply weak_cut.
+  + apply H.
+  + apply OrL.
+    * apply OrR1; apply generalised_axiom.
+    * apply OrR2. apply or_comm_ctx_R. apply or_assoc_ctx_R_R.
+      apply OrL.
+      -- apply OrR1; apply generalised_axiom.
+      -- apply OrR2; apply or_comm.
+Qed.
+ +
+Lemma simp_equiv_or_R φ ψ:
+  (simp φ φ) -> (simp ψ ψ) ->
+  simp (φ ψ) (φ ψ).
+Proof.
+intros Hφ Hψ.
+eapply weak_cut; [ apply simp_ors_self_equiv_R | apply or_congruence; [apply Hφ | apply Hψ]].
+Qed.
+ +
+Lemma simp_equiv_or φ ψ:
+  (φ simp φ) * (simp φ φ) ->
+  (ψ simp ψ) * (simp ψ ψ) ->
+  ((φ ψ) simp (φ ψ)) * (simp (φ ψ) (φ ψ)).
+Proof.
+intros IHφ IHψ.
+split; [ apply simp_equiv_or_L | apply simp_equiv_or_R]; try apply IHφ ; try apply IHψ.
+Qed.
+ +
+Lemma and_comm φ ψ:
+  φ ψ ψ φ.
+Proof.
+apply AndL; apply AndR; [exch 0|]; apply weakening; apply generalised_axiom.
+Qed.
+ +
+Lemma and_comm_ctx_L φ ψ ϴ:
+  (φ ψ ϴ) -> ψ φ ϴ.
+Proof.
+intro H.
+eapply weak_cut; [apply and_comm | assumption].
+Qed.
+ +
+Lemma and_assoc_R φ ψ ϴ :
+  ((φ ψ) ϴ φ (ψ ϴ)).
+Proof.
+  apply AndL; exch 0; apply AndL.
+  apply AndR.
+  - exch 0. apply generalised_axiom.
+  - apply AndR.
+    + apply generalised_axiom.
+    + exch 1. exch 0. apply generalised_axiom.
+Qed.
+ +
+Lemma and_assoc_L φ ψ ϴ :
+  (φ (ψ ϴ) (φ ψ) ϴ).
+Proof.
+  apply AndL; apply AndL.
+  apply AndR.
+  - apply AndR.
+    + exch 1. exch 0. apply generalised_axiom.
+    + exch 0. apply generalised_axiom.
+  - apply generalised_axiom.
+Qed.
+ +
+Lemma and_assoc_ctx_L_R φ ψ ϴ a:
+  (φ (ψ ϴ) a) -> ((φ ψ) ϴ) a.
+Proof.
+intro H.
+eapply weak_cut; [apply and_assoc_R | assumption].
+Qed.
+ +
+Lemma and_assoc_ctx_R_L φ ψ ϴ a:
+  (a (φ ψ) ϴ) -> a φ (ψ ϴ).
+Proof.
+intro H.
+eapply weak_cut; [apply H | apply and_assoc_R].
+Qed.
+ +
+Lemma and_assoc_ctx_R_R φ ψ ϴ a:
+  (a φ (ψ ϴ)) -> a (φ ψ) ϴ.
+Proof.
+intro H.
+eapply weak_cut; [apply H | apply and_assoc_L].
+Qed.
+ +
+Lemma make_conj_comm φ ψ :
+  (φ ψ) (ψ φ).
+Proof.
+apply (weak_cut _ ψ) _).
+- apply make_conj_equiv_R; apply generalised_axiom.
+- apply (weak_cut _ φ) _).
+  + apply and_comm.
+  + apply make_conj_equiv_L; apply generalised_axiom.
+Qed.
+ +
+Lemma make_conj_comm_ctx_R a φ ψ :
+  (a φ ψ) -> a ψ φ.
+Proof.
+intro H.
+eapply weak_cut; [apply H | apply make_conj_comm].
+Qed.
+ +
+Lemma make_conj_comm_ctx_L a φ ψ :
+  (φ ψ a) -> ψ φ a.
+Proof.
+intro H.
+eapply weak_cut; [apply make_conj_comm | apply H].
+Qed.
+ +
+Lemma simp_ands_self_equiv_L φ ψ:
+  (φ ψ) simp_ands φ ψ.
+Proof.
+generalize ψ.
+induction φ;
+intro ψ0; unfold simp_ands;
+destruct ψ0; try (eapply make_conj_equiv_L; apply generalised_axiom);
+try (apply make_conj_comm_ctx_R; apply make_conj_equiv_L; apply generalised_axiom).
+assert (H: φ1 ψ0_1 φ2 ψ0_2 φ1 (ψ0_1 simp_ands φ2 ψ0_2)).
+- apply make_conj_equiv_L.
+  + apply generalised_axiom.
+  + apply make_conj_equiv_L.
+    * apply generalised_axiom.
+    * apply IHφ2.
+- eapply weak_cut.
+  + apply and_assoc_ctx_L_R.
+    do 3 (apply AndL).
+    apply AndR.
+    * exch 2. exch 1. exch 0. apply generalised_axiom.
+    * apply AndR.
+      -- exch 0. apply generalised_axiom.
+      -- apply AndR.
+         ++ exch 1. exch 0. apply generalised_axiom.
+         ++ apply generalised_axiom.
+  + assumption.
+Qed.
+ +
+Lemma simp_ands_self_equiv_R φ ψ:
+  simp_ands φ ψ φ ψ.
+Proof.
+generalize ψ.
+induction φ;
+intro ψ0;
+destruct ψ0;
+try (eapply make_conj_equiv_R; apply generalised_axiom);
+try (apply make_conj_comm_ctx_L; apply make_conj_equiv_R; apply generalised_axiom).
+assert (H: φ1 (ψ0_1 simp_ands φ2 ψ0_2) φ1 ψ0_1 φ2 ψ0_2).
+- apply make_conj_equiv_R.
+  + apply generalised_axiom.
+  + apply make_conj_equiv_R.
+    * apply generalised_axiom.
+    * apply IHφ2.
+- apply and_assoc_ctx_R_R.
+  eapply weak_cut.
+  + apply H.
+  + do 3 (apply AndL).
+    apply AndR.
+    * exch 2. exch 1. exch 0. apply generalised_axiom.
+    * apply AndR.
+      -- exch 0. apply generalised_axiom.
+      -- apply AndR.
+         ++ exch 1. exch 0. apply generalised_axiom.
+         ++ apply generalised_axiom.
+Qed.
+ +
+Lemma simp_equiv_and_L φ ψ :
+  (φ simp φ) -> (ψ simp ψ) -> (φ ψ) simp (φ ψ).
+Proof.
+intros Hφ Hψ.
+eapply weak_cut; [apply and_congruence; [apply Hφ | apply Hψ] | apply simp_ands_self_equiv_L].
+Qed.
+ +
+Lemma simp_equiv_and_R φ ψ :
+  (simp φ φ) -> (simp ψ ψ) -> simp (φ ψ) φ ψ.
+Proof.
+intros Hφ Hψ.
+eapply weak_cut; [apply simp_ands_self_equiv_R | apply and_congruence; [apply Hφ | apply Hψ]].
+Qed.
+ +
+Lemma simp_equiv_and φ ψ:
+  (φ simp φ) * (simp φ φ) ->
+  (ψ simp ψ) * (simp ψ ψ) ->
+  ((φ ψ) simp (φ ψ)) * (simp (φ ψ) (φ ψ)).
+Proof.
+intros IHφ IHψ.
+split; [ apply simp_equiv_and_L | apply simp_equiv_and_R]; try apply IHφ ; try apply IHψ.
+Qed.
+ +
+Lemma simp_imp_self_equiv_L φ ψ:
+  (φ ψ) simp_imp φ ψ.
+Proof.
+unfold simp_imp.
+case decide as [Heq |]; [apply top_provable|].
+case decide as [HφBot |]; [apply top_provable|].
+case decide as [HψTop |]; [apply top_provable|].
+case decide as [HφTop |].
+- apply weak_ImpL.
+  + eapply additive_cut.
+      * apply top_provable.
+      * eapply additive_cut.
+       -- apply obviously_smaller_compatible_GT; apply HφTop.
+       -- apply generalised_axiom.
+  + apply generalised_axiom.
+- case decide as [HψBot |].
+  + apply ImpR. exch 0. apply ImpL.
+      * apply weakening. apply generalised_axiom.
+      * eapply additive_cut with .
+       -- exch 0. apply weakening, obviously_smaller_compatible_LT, HψBot.
+       -- do 2 (exch 0; apply weakening). now apply obviously_smaller_compatible_LT.
+  + apply ImpR. exch 0. apply ImpL.
+      * apply weakening, generalised_axiom.
+      * exch 0. apply weakening, generalised_axiom.
+Qed.
+ +
+Lemma simp_imp_self_equiv_R φ ψ:
+  simp_imp φ ψ φ ψ.
+Proof.
+unfold simp_imp.
+case decide as [Heq |].
+  - apply weakening, ImpR, obviously_smaller_compatible_LT, Heq.
+  - case decide as [HφBot |].
+    + apply weakening.
+      apply ImpR.
+      eapply weak_cut with .
+      * apply obviously_smaller_compatible_LT, HφBot.
+      * apply ExFalso.
+    + case decide as [HψTop |].
+      * apply weakening.
+        apply ImpR.
+        eapply weak_cut.
+        -- apply top_provable.
+        -- apply obviously_smaller_compatible_GT, HψTop.
+      * case decide as [HφTop |].
+        -- apply ImpR. apply weakening, generalised_axiom.
+        -- case decide as [HψBot |].
+           ++ apply ImpR.
+              eapply additive_cut with ψ.
+              ** exch 0. apply weak_ImpL.
+                 --- apply generalised_axiom.
+                 --- apply ExFalso.
+              ** apply generalised_axiom.
+           ++ apply ImpR. exch 0. apply ImpL.
+              ** apply weakening, generalised_axiom.
+              ** exch 0. apply weakening, generalised_axiom.
+Qed.
+ +
+Lemma simp_imps_self_equiv_L φ ψ:
+  (φ ψ) simp_imps φ ψ.
+Proof.
+revert φ; induction ψ; intro φ; unfold simp_imps;
+auto using simp_imp_self_equiv_L.
+fold simp_imps. apply ImpLAnd_rev.
+eapply weak_cut; [| apply IHψ2].
+apply ImpR. exch 0. apply ImpL.
+- apply weakening, simp_ands_self_equiv_R.
+- apply generalised_axiom.
+Qed.
+ +
+Lemma simp_imps_self_equiv_R φ ψ:
+  simp_imps φ ψ (φ ψ).
+Proof.
+revert φ; induction ψ; intro φ; unfold simp_imps;
+auto using simp_imp_self_equiv_R.
+fold simp_imps. apply ImpR, ImpR, AndL_rev, ImpR_rev.
+eapply weak_cut; [apply IHψ2|].
+apply ImpR. exch 0. apply ImpL.
+- apply weakening, simp_ands_self_equiv_L.
+- apply generalised_axiom.
+Qed.
+ +
+Lemma simp_equiv_imp_L φ ψ :
+  (simp φ φ) -> (ψ simp ψ) ->
+  (φ ψ) simp (φ ψ).
+Proof.
+intros HφR HψL.
+simpl.
+eapply weak_cut; [| apply simp_imps_self_equiv_L]. apply ImpR. exch 0.
+apply ImpL.
+- apply weakening. apply HφR.
+- exch 0. apply weakening. apply HψL.
+Qed.
+ +
+Lemma simp_equiv_imp_R φ ψ :
+  (φ simp φ) -> (simp ψ ψ) ->
+  simp (φ ψ) (φ ψ).
+Proof.
+intros HφR HψL.
+simpl.
+eapply weak_cut with (simp φ simp ψ).
+- apply simp_imps_self_equiv_R.
+- apply ImpR. exch 0. apply ImpL.
+  + apply weakening, HφR.
+  + exch 0. apply weakening, HψL.
+Qed.
+ +
+Lemma simp_equiv_imp φ ψ:
+  (φ simp φ) * (simp φ φ) ->
+  (ψ simp ψ) * (simp ψ ψ) ->
+  ((φ ψ) simp (φ ψ)) * (simp (φ ψ) (φ ψ)).
+Proof.
+intros IHφ IHψ.
+split; [ apply simp_equiv_imp_L | apply simp_equiv_imp_R]; try apply IHφ ; try apply IHψ.
+Qed.
+ +
+Lemma box_congr φ ψ:
+  (φ ψ) -> φ ψ.
+Proof.
+intro H.
+apply BoxR.
+box_tac. apply weakening.
+ms.
+Qed.
+ +
+Lemma simp_equiv_box φ:
+  (φ simp φ) * (simp φ φ) ->
+  ( φ (simp φ)) * ( (simp φ) φ).
+Proof.
+intro IHφ.
+split; apply box_congr; apply IHφ.
+Qed.
+ +
+Theorem simp_equiv φ :
+  (φ (simp φ)) * ((simp φ) φ).
+Proof.
+remember (weight φ) as w.
+assert(Hle : weight φ w) by lia.
+clear Heqw. revert φ Hle.
+induction w; intros φ Hle; [destruct φ ; simpl in Hle; lia|];
+destruct φ; simpl; try (split ; apply generalised_axiom);
+[eapply (simp_equiv_and φ1 φ2)|
eapply (simp_equiv_or φ1 φ2)|
eapply (simp_equiv_imp φ1 φ2)|
eapply simp_equiv_box];
apply IHw;
+match goal with
+  | Hle : weight (?connector ?f1 ?f2) S ?w |- weight ?f1 ?w => simpl in Hle; lia
+  | Hle : weight (?connector ?f1 ?f2) S ?w |- weight ?f2 ?w => simpl in Hle; lia
+  | Hle : weight ( ?f1) S ?w |- weight ?f1 ?w => simpl in Hle; lia
+end.
+Qed.
+ +
+Require Import ISL.PropQuantifiers.
+ +
+Definition E_simplified (p: variable) (ψ: form) := simp (E p ([ψ], )).
+Definition A_simplified (p: variable) (ψ: form) := simp (Af p (ψ)).
+ +
+(*
+Lemma bot_vars_incl V: vars_incl ⊥ V.
+Proof.
+  intros x H; unfold In; induction V; auto.
+Qed.
+
+Lemma top_vars_incl V: vars_incl ⊤ V.
+Proof.
+intros x H; unfold In; induction V; simpl in H; tauto | auto.
+Qed.
+
+
+(* Solves simple variable inclusion goals *)
+Ltac vars_incl_tac :=
+repeat match goal with
+| |- vars_incl ⊥ ?V => apply bot_vars_incl
+| |- vars_incl ⊤ ?V => apply top_vars_incl
+
+| H : vars_incl (?connector ?f1 ?f2) ?l |- vars_incl ?f1 ?l * vars_incl ?f2 ?l =>
+        split; intros x H1; apply H; simpl; auto
+| H : vars_incl (?connector ?f1 ?f2) ?l |- vars_incl ?f1 ?l =>
+        intros x H1; apply H; simpl; auto
+| H : vars_incl (?connector ?f1 ?f2) ?l |- vars_incl ?f2 ?l =>
+        intros x H1; apply H; simpl; auto
+
+| H: vars_incl ?f ?l |- vars_incl (_ ?f Bot) ?l =>  unfold vars_incl; simpl; intuition
+| |- (vars_incl ?f1 ?l → vars_incl ?f2 ?l → vars_incl (?connector ?f1 ?f2) ?l) => 
+        unfold vars_incl; simpl; intuition
+| H1: vars_incl ?f1 ?l, H2: vars_incl ?f2 ?l |- vars_incl (?connector ?f1 ?f2) ?l => 
+        unfold vars_incl; simpl; intuition
+
+| |- _ * _  => split; intro| intros
+end.
+
+Lemma or_vars_incl φ ψ V:
+  (vars_incl (Or φ ψ) V -> vars_incl φ V * vars_incl ψ V) *
+  ( vars_incl φ V -> vars_incl ψ V -> vars_incl (Or φ ψ) V).
+Proof. vars_incl_tac. Qed.
+
+
+Lemma vars_incl_choose_disj φ ψ V:
+  vars_incl (Or φ ψ) V -> vars_incl (choose_disj φ ψ) V.
+Proof.
+intros H.
+unfold choose_disj.
+destruct (obviously_smaller φ ψ); vars_incl_tac.
+destruct (obviously_smaller ψ φ); vars_incl_tac. assumption.
+Qed.
+
+Lemma vars_incl_make_disj_equiv_disj φ ψ V:
+  vars_incl (Or φ ψ) V -> vars_incl (φ ⊻ ψ) V.
+Proof.
+intros H.
+unfold make_disj.
+destruct ψ; try (now apply vars_incl_choose_disj);
+repeat case decide; intros; try assumption; vars_incl_tac.
+- now apply vars_incl_choose_disj.
+- apply or_vars_incl in H.  case obviously_smaller; vars_tac; firstorder.
+Qed.
+
+Lemma vars_incl_simp_ors φ ψ V :
+  vars_incl φ V -> vars_incl ψ V -> vars_incl (simp_ors φ ψ) V.
+Proof.
+generalize ψ.
+induction φ; intro ψ0; destruct ψ0; intros Hφ Hψ;
+try ( apply vars_incl_make_disj_equiv_disj; apply or_vars_incl; assumption).
+simpl.
+apply vars_incl_make_disj_equiv_disj.
+apply or_vars_incl.
+- now apply (or_vars_incl _ φ2 _). 
+- apply vars_incl_make_disj_equiv_disj.
+  apply or_vars_incl.
+  + now apply (or_vars_incl _ ψ0_2 _). 
+  +  apply IHφ2.
+    * now apply (or_vars_incl  φ1 _ _). 
+    * now apply (or_vars_incl  ψ0_1 _ _). 
+Qed.
+
+
+Lemma and_vars_incl φ ψ V:
+  (vars_incl (And φ ψ) V -> vars_incl φ V * vars_incl ψ V) *
+  (vars_incl φ V -> vars_incl ψ V -> vars_incl (And φ ψ) V).
+Proof. vars_incl_tac. Qed.
+
+
+Lemma vars_incl_choose_conj φ ψ V:
+  vars_incl (And φ ψ) V -> vars_incl (choose_conj φ ψ) V.
+Proof.
+intros H.
+unfold choose_conj. 
+destruct (obviously_smaller φ ψ); vars_incl_tac; assumption.
+Qed.
+
+
+Lemma vars_incl_make_conj_equiv_conj φ ψ V:
+  vars_incl (And φ ψ) V -> vars_incl (φ ⊼ ψ) V.
+Proof.
+intros H.
+unfold make_conj.
+destruct ψ; try (now apply vars_incl_choose_conj);
+match goal with |- vars_incl match ?a with _ => _ end _ => destruct a end;
+repeat case decide; intros; try discriminate; try assumption; vars_incl_tac;
+try apply vars_incl_choose_conj; apply and_vars_incl;
+vars_incl_tac; apply and_vars_incl in H; vars_tac; vars_incl_tac.
+Qed.
+
+Lemma vars_incl_simp_ands φ ψ V :
+  vars_incl φ V -> vars_incl ψ V -> vars_incl (simp_ands φ ψ) V.
+Proof.
+generalize ψ.
+induction φ; intro ψ0; destruct ψ0; intros Hφ Hψ;
+try (apply vars_incl_make_conj_equiv_conj; apply and_vars_incl; assumption).
+simpl.
+apply vars_incl_make_conj_equiv_conj.
+apply and_vars_incl.
+- vars_incl_tac.
+- apply vars_incl_make_conj_equiv_conj. 
+  apply and_vars_incl.
+  + vars_incl_tac.
+  + apply IHφ2; vars_incl_tac.
+Qed.
+
+Lemma vars_incl_simp_imp φ ψ V :
+  vars_incl φ V -> vars_incl ψ V -> vars_incl (simp_imp φ ψ) V.
+Proof.
+intros Hφ Hψ.
+simpl. unfold simp_imp. 
+case decide as .
+  + vars_incl_tac.
+  + case decide as .
+    * vars_incl_tac.
+    * case decide as .
+      -- vars_incl_tac.
+      -- case decide as .
+         ++ assumption.
+         ++ case decide as ; vars_incl_tac.
+Qed.
+
+Lemma vars_incl_simp_imps φ ψ V :
+  vars_incl φ V -> vars_incl ψ V -> vars_incl (simp_imps φ ψ) V.
+Proof.
+revert φ; induction ψ; intros φ Hφ Hψ; simpl;
+try apply vars_incl_simp_imp; trivial.
+apply IHψ2.
+- apply vars_incl_simp_ands; trivial.
+  intros ? ?; apply Hψ; simpl; tauto.
+-   intros ? ?; apply Hψ; simpl; tauto.
+Qed.
+
+Lemma vars_incl_simp φ V :
+  vars_incl φ V -> vars_incl (simp φ) V.
+Proof.
+intro H.
+induction φ; auto; simpl;
+ apply vars_incl_simp_ands; [apply IHφ1| apply IHφ2]| + apply vars_incl_simp_ors; [apply IHφ1| apply IHφ2]| + apply vars_incl_simp_imps; [apply IHφ1| apply IHφ2] +; vars_incl_tac.
+Qed.
+
+
+Lemma preorder_singleton  φ ψ:
+  {φ} ⊢ ψ -> (φ ≼ ψ).
+Proof.
+intro H.
+assert (H': ∅ • φ ⊢ ψ ) by peapply H.
+apply H'.
+Qed.
+
+Theorem iSL_uniform_interpolation_simp p V: p ∉ V ->
+  ∀ φ, vars_incl φ (p :: V) ->
+  (vars_incl (E_simplified p φ) V)
+  * (φ ≼ E_simplified p φ)
+  * (∀ ψ, vars_incl ψ V -> (φ ≼ ψ) -> E_simplified p φ ≼ ψ)
+  * (vars_incl (A_simplified p φ) V)
+  * (A_simplified p φ ≼ φ)
+  * (∀ θ, vars_incl θ V -> (θ ≼ φ) -> (θ ≼ A_simplified p φ)).
+Proof.
+intros Hp φ Hvarsφ.
+assert (Hislφ : 
+    (vars_incl (Ef p φ) V)
+  * ({φ} ⊢ (Ef p φ))
+  * (∀ ψ, vars_incl ψ V -> {φ} ⊢ ψ -> {Ef p φ} ⊢ ψ)
+  * (vars_incl (Af p φ) V)
+  * ({Af p φ} ⊢ φ)
+  * (∀ θ, vars_incl θ V -> {θ} ⊢ φ -> {θ} ⊢ Af p φ)) by 
+    (apply iSL_uniform_interpolation; apply Hp | apply Hvarsφ).
+repeat split.
+  + intros Hx.
+    eapply vars_incl_simp.
+    apply Hislφ.
+  + eapply weak_cut.
+    * assert (Hef: ({φ} ⊢ Ef p φ)) by apply Hislφ.
+      apply preorder_singleton.
+      apply Hef.
+    * apply (simp_equiv  (Ef p φ)).
+  + intros ψ Hψ Hyp.
+    eapply weak_cut.
+    * apply (simp_equiv  (Ef p φ)).
+    * assert (Hef: ({Ef p φ} ⊢ ψ)) by (apply Hislφ; apply Hψ | peapply Hyp).
+      apply preorder_singleton.
+      apply Hef.
+  + intros Hx.
+    eapply vars_incl_simp.
+    apply Hislφ.
+  + eapply weak_cut.
+    * apply (simp_equiv  (Af p φ)).
+    * apply preorder_singleton.
+      apply Hislφ.
+  + intros ψ Hψ Hyp.
+    eapply weak_cut.
+    * assert (Hef: ({ψ} ⊢ Af p φ)) by (apply Hislφ; apply Hψ | peapply Hyp).
+      apply preorder_singleton.
+      apply Hef.
+    * apply (simp_equiv  (Af p φ)).
+Qed.
+*)

+ +
+Require Import String.
+Local Open Scope string_scope.
+ +
+Example ex1: simp (Implies (Var "a") (And (Var "b") (Var "b" ))) = Implies (Var "a") (Var "b").
+Proof. reflexivity. Qed.
+ +
+Example ex2: simp (Implies (Var "a") (Or (Var "b") (Var "b" ))) = Implies (Var "a") (Var "b").
+Proof. reflexivity. Qed.
+ +
+Example ex3: simp (Implies (Var "a") (Var "a")) = Implies Bot Bot.
+Proof. reflexivity. Qed.
+ +
+Example ex4: simp (Or (Implies (Var "a") (Var "a")) (Implies (Var "a") (Var "a"))) = Implies Bot Bot.
+Proof. reflexivity. Qed.
+ +
+Example ex5: simp (And (Implies (Var "a") (Var "a")) (Implies (Var "a") (Var "a"))) = Implies Bot Bot.
+Proof. reflexivity. Qed.
+ +
+Example ex6: simp (Or (And (Var "a") (Var "b")))= (And (Var "a") (Var "b")).
+Proof. reflexivity. Qed.
+
+
+ +
+ + + diff --git a/K.Interpolation.K_Craig_Interp.html b/K.Interpolation.K_Craig_Interp.html new file mode 100644 index 0000000..d5967ff --- /dev/null +++ b/K.Interpolation.K_Craig_Interp.html @@ -0,0 +1,644 @@ + + + + + + + + + + + + + +
+
+

K.Interpolation.K_Craig_Interp

+ +
+(* It took me a day and a half of work to write the file below
+    (14-15/11/2022). *)

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat Arith.
+Require Import Lia.
+ +
+Require Import KS_export.
+Require Import general_export.
+ +
+Set Implicit Arguments.
+ +
+(* Material to define Craig interpolants. *)
+ +
+Fixpoint propvar_subform (φ : MPropF) : list MPropF :=
+match φ with
+  | Var p => (Var p) :: nil
+  | Bot => nil
+  | Imp ψ χ => (propvar_subform ψ) ++ ( propvar_subform χ)
+  | Box ψ => ( propvar_subform ψ)
+end.
+ +
+Fixpoint propvar_subform_list (l : list MPropF) : list MPropF :=
+match l with
+  | nil => nil
+  | φ :: t => (propvar_subform φ) ++ (propvar_subform_list t)
+end.
+ +
+(* Lemmas about propvar_subform_list. *)
+ +
+Lemma propvar_subform_list_app: forall l0 l1,
+      propvar_subform_list (l0 ++ l1) = (propvar_subform_list l0) ++ (propvar_subform_list l1).
+Proof.
+induction l0.
+- simpl. auto.
+- intros. simpl. rewrite (IHl0). rewrite <- app_assoc ; auto.
+Qed.
+ +
+Lemma propvar_subform_list_unboxed_list : forall l A, In A (propvar_subform_list (unboxed_list l)) -> In A (propvar_subform_list l).
+Proof.
+induction l.
+- auto.
+- simpl. intros. apply in_app_or in H. destruct H. apply in_or_app ; left. destruct a ; auto.
+  apply in_or_app ; auto.
+Qed.
+ +
+Lemma propvar_subform_list_nobox_gen_ext : forall l0 l1, nobox_gen_ext l0 l1 ->
+          (forall A, In A (propvar_subform_list l0) -> In A (propvar_subform_list l1)).
+Proof.
+intros l0 l1 H. induction H ; auto.
+- simpl ; intros. apply in_or_app. apply in_app_or in H0 ; destruct H0 ; auto.
+- simpl ; intros. apply in_or_app ; auto.
+Qed.
+ +
+Lemma InT_var_provar : forall P Γ, InT # P Γ -> InT # P (propvar_subform_list Γ).
+Proof.
+induction Γ ; auto. intro. simpl. inversion H ; subst ; simpl. apply InT_eq.
+apply InT_or_app ; right. auto.
+Qed.
+ +
+(* Craig interpolation theorem. *)
+ +
+Theorem Craig_Interpolation : forall Γ0 Γ1 Δ0 Δ1,
+    KS_prv (Γ0 ++ Γ1, Δ0 ++ Δ1) ->
+    (existsT2 (I : MPropF), (forall p, In (Var p) (propvar_subform I) -> In (Var p) (propvar_subform_list (Γ0 ++ Δ0)) *
+                                                                                                            In (Var p) (propvar_subform_list (Γ1 ++ Δ1))) *
+                                   (KS_prv (Γ0, I :: Δ0)) *
+                                   (KS_prv (I :: Γ1, Δ1))).
+Proof.
+(* Setting the statement right. *)
+intros. remember (Γ0 ++ Γ1, Δ0 ++ Δ1) as s. revert Heqs.
+generalize dependent Γ0. generalize dependent Γ1. generalize dependent Δ0. generalize dependent Δ1.
+remember (derrec_height X) as n. revert Heqn. generalize dependent X. generalize dependent s.
+generalize dependent n.
+(* Using strong induction. *)
+pose ((well_founded_induction_type lt_wf) (fun (x:nat) => forall (s : list MPropF * list MPropF) (X : KS_prv s),
+x = derrec_height X ->
+forall Δ1 Δ0 Γ1 Γ0 : list MPropF,
+s = (Γ0 ++ Γ1, Δ0 ++ Δ1) ->
+existsT2 I : MPropF,
+  (forall p, In # p (propvar_subform I) -> In (Var p) (propvar_subform_list (Γ0 ++ Δ0)) *
+                                                                                                            In (Var p) (propvar_subform_list (Γ1 ++ Δ1))) * KS_prv (Γ0, I :: Δ0) *
+  KS_prv (I :: Γ1, Δ1))).
+apply s. clear s.
+(* Start of the intuitive proof. *)
+unfold KS_prv. intros n IHn s D. subst. remember D as D'. destruct D ; intros.
+(* D0 is a leaf *)
+- inversion f.
+(* D0 ends with an application of rule *)
+- inversion k.
+  (* IdP *)
+  * inversion H1. subst. inversion H5 ; subst. assert (J: InT (# P) (Γ0 ++ Γ1)). rewrite <- H0.
+    apply InT_or_app ; right ; apply InT_eq. apply InT_app_or in J. destruct J.
+    + assert (J: InT (# P) (Δ0 ++ Δ1)). rewrite <- H2.
+       apply InT_or_app ; right ; apply InT_eq. apply InT_app_or in J. destruct J.
+       -- exists (Bot). repeat split. intros. 1,2: inversion H.
+           apply derI with (ps:=[]). 2: apply dersrec_nil. apply IdP.
+           apply InT_split in i. destruct i. destruct s. subst.
+           assert (J: InT # P (Bot :: Δ0)). apply InT_cons. auto.
+           apply InT_split in J. destruct J. destruct s. rewrite e. apply IdPRule_I.
+           apply derI with (ps:=[]). 2: apply dersrec_nil. apply BotL. apply (BotLRule_I []).
+       -- exists (# P). repeat split. intros. 1,2: simpl in H ; destruct H ; auto ; try rewrite <- H. 2, 4: inversion H.
+           1-2: repeat rewrite propvar_subform_list_app ; apply in_or_app. left ; apply InT_In ; apply InT_var_provar ; auto.
+           right ; apply InT_In ; apply InT_var_provar ; auto.
+           apply derI with (ps:=[]). 2: apply dersrec_nil. apply IdP.
+           apply InT_split in i. destruct i. destruct s. subst.
+           assert (J: # P :: Δ0 = [] ++ # P :: Δ0). auto. rewrite J. clear J. apply IdPRule_I.
+           apply derI with (ps:=[]). 2: apply dersrec_nil. apply IdP.
+           apply InT_split in i0. destruct i0. destruct s. subst.
+           assert (J: # P :: Γ1 = [] ++ # P :: Γ1). auto. rewrite J. clear J. apply IdPRule_I.
+    + assert (J: InT (# P) (Δ0 ++ Δ1)). rewrite <- H2.
+       apply InT_or_app ; right ; apply InT_eq. apply InT_app_or in J. destruct J.
+       -- exists (# P --> Bot). repeat split.
+           1,2: simpl in H ; destruct H ; auto ; try rewrite <- H. 2, 4: inversion H.
+           1-2: repeat rewrite propvar_subform_list_app ; apply in_or_app. right ; apply InT_In ; apply InT_var_provar ; auto.
+           left ; apply InT_In ; apply InT_var_provar ; auto.
+           apply derI with (ps:=[([] ++ # P :: Γ0, [] ++ Bot :: Δ0)]). apply ImpR.
+           assert (J: (Γ0, # P --> Bot :: Δ0) = ([] ++ Γ0, [] ++ # P --> Bot :: Δ0)). auto. rewrite J. clear J. apply ImpRRule_I.
+           apply dlCons. 2: apply dlNil. apply derI with (ps:=[]). 2: apply dersrec_nil. apply IdP.
+           assert (J: InT # P ([] ++ Bot :: Δ0)). apply InT_cons. auto. apply InT_split in J. destruct J. destruct s.
+           rewrite e. apply IdPRule_I.
+           apply derI with (ps:=[([] ++ Γ1, [] ++ # P :: Δ1);([] ++ Bot :: Γ1, [] ++ Δ1)]). apply ImpL.
+           assert (J: (# P --> Bot :: Γ1, Δ1) = ([] ++ # P --> Bot :: Γ1, [] ++ Δ1)). auto. rewrite J. clear J. apply ImpLRule_I.
+           apply dlCons. apply derI with (ps:=[]). 2: apply dlNil. apply IdP.
+           assert (J: InT # P ([] ++ Γ1)). simpl ; auto. apply InT_split in J. destruct J. destruct s.
+           rewrite e. apply IdPRule_I. apply dlCons. 2: apply dlNil. apply derI with (ps:=[]). 2: apply dlNil. apply BotL.
+           apply BotLRule_I.
+       -- exists (Bot --> Bot). repeat split. intros. 1,2: inversion H.
+           apply derI with (ps:=[([] ++ Bot :: Γ0, [] ++ Bot :: Δ0)]). apply ImpR.
+           assert ((Γ0, Bot --> Bot :: Δ0) = ([] ++ Γ0, [] ++ Bot --> Bot :: Δ0)). auto. rewrite H. clear H.
+           apply ImpRRule_I. apply dlCons. 2: apply dlNil. apply derI with (ps:=[]). apply BotL.
+           apply BotLRule_I. apply dlNil.
+           apply derI with (ps:=[]). 2: apply dersrec_nil. apply IdP.
+           assert (J: InT # P (Bot --> Bot :: Γ1)). apply InT_cons. auto.
+           apply InT_split in J. destruct J. destruct s. rewrite e.
+           apply InT_split in i0. destruct i0. destruct s. subst. apply IdPRule_I.
+  (* BotL *)
+  * inversion H1. subst. assert (J: InT Bot (Γ0 ++ Γ1)). inversion H5 ; subst.
+    apply InT_or_app ; right ; apply InT_eq. apply InT_app_or in J. destruct J.
+    + exists Bot. repeat split. intros. 1,2: inversion H.
+       apply derI with (ps:=[]). apply BotL. 2: apply dlNil.
+       apply InT_split in i. destruct i. destruct s. subst. apply BotLRule_I.
+       apply derI with (ps:=[]). apply BotL. 2: apply dlNil.
+       assert (J: (Bot :: Γ1, Δ1) = ([] ++ Bot :: Γ1, Δ1)). auto. rewrite J. apply BotLRule_I.
+    + exists (Bot --> Bot). repeat split. intros. 1,2: inversion H.
+       apply derI with (ps:=[([] ++ Bot :: Γ0, [] ++ Bot :: Δ0)]). apply ImpR.
+       assert ((Γ0, Bot --> Bot :: Δ0) = ([] ++ Γ0, [] ++ Bot --> Bot :: Δ0)). auto. rewrite H. clear H.
+       apply ImpRRule_I. apply dlCons. 2: apply dlNil. apply derI with (ps:=[]). apply BotL.
+       apply BotLRule_I. apply dlNil.
+       apply derI with (ps:=[]). apply BotL. 2: apply dlNil.
+       assert (J: InT Bot (Bot --> Bot :: Γ1)). apply InT_cons ; auto.
+       apply InT_split in J. destruct J. destruct s. rewrite e. apply BotLRule_I.
+  (* ImpR *)
+  * inversion H1. subst. inversion H5 ; subst. simpl in IHn.
+    assert (J: dersrec_height d = dersrec_height d). auto. apply dersrec_derrec_height in J.
+    destruct J.
+    assert (J1: derrec_height x = derrec_height x). auto.
+    assert (J3: list_exch_L (Γ2 ++ A :: Γ3, Δ2 ++ B :: Δ3) (A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3)).
+    rewrite <- H0. assert (Γ2 ++ A :: Γ3 = [] ++ [] ++ Γ2 ++ [A] ++ Γ3). auto. rewrite H.
+    assert (A :: Γ2 ++ Γ3 = [] ++ [A] ++ Γ2 ++ [] ++ Γ3). auto. rewrite H3. apply list_exch_LI.
+    pose (KS_hpadm_list_exch_L _ x _ J3). destruct s.
+    assert (J5: derrec_height x0 = derrec_height x0). auto.
+    assert (J4: list_exch_L (A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3) (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ3)).
+    assert (Γ0 ++ A :: Γ1 = [] ++ [] ++ Γ0 ++ [A] ++ Γ1). auto. rewrite H.
+    assert (A :: Γ0 ++ Γ1 = [] ++ [A] ++ Γ0 ++ [] ++ Γ1). auto. rewrite H3. apply list_exch_LI.
+    pose (KS_hpadm_list_exch_L _ x0 _ J4). destruct s.
+    assert (J0: derrec_height x1 < S (dersrec_height d)). rewrite <- e. apply PeanoNat.le_lt_n_Sm.
+    apply (Nat.le_trans _ _ _ l0 l).
+    assert (J6: derrec_height x1 = derrec_height x1). auto.
+    pose (IHn _ J0 _ _ J6).
+    apply app2_find_hole in H2. destruct H2. repeat destruct s0 ; destruct p ; subst.
+    + assert (J2: (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ3) = (Γ0 ++ (A :: Γ1), Δ2 ++ (B :: Δ3))). auto.
+        apply s in J2. destruct J2. destruct p. destruct p. exists x3. repeat split ; auto.
+        intros. apply p in H. repeat rewrite propvar_subform_list_app in H. simpl in H.
+        repeat rewrite propvar_subform_list_app. repeat rewrite <- app_assoc in H. simpl. destruct H.
+        apply in_app_or in i. destruct i. apply in_or_app ; auto. apply in_or_app ; auto.
+        apply p in H. repeat rewrite propvar_subform_list_app in H. simpl in H.
+        repeat rewrite propvar_subform_list_app. repeat rewrite <- app_assoc in H. simpl. destruct H.
+        apply in_app_or in i0. destruct i0. apply in_or_app ; right ; apply in_or_app ; left ; apply in_or_app ; auto.
+        apply in_app_or in H. destruct H. apply in_or_app ; auto.
+        apply in_app_or in H. destruct H. apply in_or_app ; right ; apply in_or_app ; left ; apply in_or_app ; auto.
+        apply in_or_app ; right ; apply in_or_app ; auto.
+        apply derI with (ps:=[(x3 :: A :: Γ1, B :: Δ3)]). apply ImpR.
+        assert ((x3 :: Γ1, A --> B :: Δ3) = ([x3] ++ Γ1, [] ++ A --> B :: Δ3)). auto. rewrite H.
+        assert ((x3 :: A :: Γ1, B :: Δ3) = ([x3] ++ A :: Γ1, [] ++ B :: Δ3)). auto. rewrite H2. apply ImpRRule_I.
+        apply dlCons ; auto. apply dlNil.
+    + destruct x2 ; subst.
+        -- simpl in e1. subst. rewrite app_nil_r.
+            assert (J2: (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ3) = (Γ0 ++ (A :: Γ1), Δ2 ++ (B :: Δ3))). auto.
+            apply s in J2. destruct J2. destruct p. destruct p. exists x2. repeat split ; auto.
+            intros. apply p in H. repeat rewrite propvar_subform_list_app in H. simpl in H. repeat rewrite <- app_assoc in H.
+            repeat rewrite propvar_subform_list_app. simpl. destruct H. auto.
+            apply p in H. repeat rewrite propvar_subform_list_app in H. simpl in H. repeat rewrite <- app_assoc in H.
+            repeat rewrite propvar_subform_list_app. simpl. destruct H.
+            apply in_app_or in i0. destruct i0. apply in_or_app ; right ; apply in_or_app ; left ; apply in_or_app ; auto.
+            apply in_app_or in H ; destruct H. apply in_or_app ; auto. apply in_app_or in H ; destruct H.
+            apply in_or_app ; right ; apply in_or_app ; left ; apply in_or_app ; auto.
+            apply in_or_app ; right ; apply in_or_app ; right ; auto.
+            apply derI with (ps:=[(x2 :: A :: Γ1, B :: Δ3)]). apply ImpR.
+            assert ((x2 :: Γ1, A --> B :: Δ3) = ([x2] ++ Γ1, [] ++ A --> B :: Δ3)). auto. rewrite H.
+            assert ((x2 :: A :: Γ1, B :: Δ3) = ([x2] ++ A :: Γ1, [] ++ B :: Δ3)). auto. rewrite H2. apply ImpRRule_I.
+            apply dlCons ; auto. apply dlNil.
+        -- inversion e1. subst.
+            assert (J2: (Γ0 ++ A :: Γ1, Δ2 ++ B :: x2 ++ Δ1) = ((Γ0 ++ [A]) ++ Γ1, (Δ2 ++ B :: x2) ++ Δ1)).
+            repeat rewrite <- app_assoc ; auto.
+            apply s in J2. destruct J2. destruct p. destruct p. exists x3. repeat split ; auto.
+            intros. apply p in H. simpl in H. repeat rewrite <- app_assoc in H ; simpl in H.
+            repeat rewrite propvar_subform_list_app in H. simpl in H. repeat rewrite propvar_subform_list_app in H. simpl in H.
+            destruct H.
+            repeat rewrite propvar_subform_list_app. simpl. repeat rewrite propvar_subform_list_app. simpl.
+            apply in_app_or in i. destruct i. apply in_or_app ; auto. apply in_app_or in H ; destruct H.
+            apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; left ; apply in_or_app ; auto.
+            apply in_app_or in H ; destruct H. apply in_or_app ; right ; apply in_or_app ; auto.
+            apply in_app_or in H ; destruct H. apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; left ; apply in_or_app ; auto.
+            apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+            intros. apply p in H. simpl in H. repeat rewrite <- app_assoc in H ; simpl in H.
+            repeat rewrite propvar_subform_list_app in H. simpl in H. repeat rewrite propvar_subform_list_app in H. simpl in H.
+            destruct H. repeat rewrite propvar_subform_list_app.
+            apply in_app_or in i0. destruct i0. 1-2: apply in_or_app ; auto.
+            apply derI with (ps:=[(Γ0 ++ A :: [], (x3 :: Δ2) ++ B :: x2)]). apply ImpR.
+            assert ((Γ0, x3 :: Δ2 ++ A --> B :: x2) = (Γ0 ++ [], (x3 :: Δ2) ++ A --> B :: x2)). rewrite app_nil_r. auto.
+            rewrite H. apply ImpRRule_I. apply dlCons ; auto. apply dlNil.
+    + assert (J2: (Γ0 ++ A :: Γ1, (Δ0 ++ x2) ++ B :: Δ3) = (Γ0 ++ (A :: Γ1), Δ0 ++ (x2)++ B :: Δ3)). repeat rewrite <- app_assoc. auto.
+        apply s in J2. destruct J2. destruct p. destruct p. exists x3. repeat split ; auto.
+        intros. 1,2: apply p in H ; simpl in H ; repeat rewrite <- app_assoc in H ; simpl in H ;
+        repeat rewrite propvar_subform_list_app in H ; simpl in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ;
+        destruct H ; repeat rewrite propvar_subform_list_app ; simpl ; repeat rewrite propvar_subform_list_app ; simpl.
+        apply in_app_or in i. destruct i. 1,2: apply in_or_app ; auto.
+        apply in_app_or in i0. destruct i0. apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; left ; apply in_or_app ; auto.
+        apply in_app_or in H ; destruct H. apply in_or_app ; auto. apply in_app_or in H ; destruct H.
+        apply in_or_app ; right ; apply in_or_app ; auto. apply in_app_or in H ; destruct H.
+        apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; left ; apply in_or_app ; auto.
+        apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; right ; auto.
+        apply derI with (ps:=[(x3 :: A :: Γ1, x2 ++ B :: Δ3)]). apply ImpR.
+        assert ((x3 :: Γ1, x2 ++ A --> B :: Δ3) = ([x3] ++ Γ1, x2 ++ A --> B :: Δ3)). auto. rewrite H.
+        assert ((x3 :: A :: Γ1, x2 ++ B :: Δ3) = ([x3] ++ A :: Γ1, x2 ++ B :: Δ3)). auto. rewrite H2. apply ImpRRule_I.
+        apply dlCons ; auto. apply dlNil.
+  (* ImpL *)
+  * inversion H1. subst. inversion H5 ; subst. simpl in IHn.
+    assert (J: dersrec_height d = dersrec_height d). auto. apply dersrec_derrec2_height in J.
+    destruct J. destruct s.
+    assert (J1: derrec_height x = derrec_height x). auto.
+    assert (J3: list_exch_R (Γ2 ++ Γ3, Δ2 ++ A :: Δ3) (Γ2 ++ Γ3, A :: Δ0 ++ Δ1)).
+    rewrite <- H2. assert (Δ2 ++ A :: Δ3 = [] ++ [] ++ Δ2 ++ [A] ++ Δ3). auto. rewrite H.
+    assert (A :: Δ2 ++ Δ3 = [] ++ [A] ++ Δ2 ++ [] ++ Δ3). auto. rewrite H3. apply list_exch_RI.
+    pose (KS_hpadm_list_exch_R _ x _ J3). destruct s.
+    assert (J5: derrec_height x1 = derrec_height x1). auto.
+    assert (J4: list_exch_R (Γ2 ++ Γ3, A :: Δ0 ++ Δ1) (Γ2 ++ Γ3, Δ0 ++ A :: Δ1)).
+    assert (Δ0 ++ A :: Δ1 = [] ++ [] ++ Δ0 ++ [A] ++ Δ1). auto. rewrite H.
+    assert (A :: Δ0 ++ Δ1 = [] ++ [A] ++ Δ0 ++ [] ++ Δ1). auto. rewrite H3. apply list_exch_RI.
+    pose (KS_hpadm_list_exch_R _ x1 _ J4). destruct s.
+    assert (existsT2 (x3 : derrec KS_rules (fun _ : Seq => False) (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)), derrec_height x3 <= dersrec_height d).
+    rewrite <- H2. exists x0 ; auto. rewrite e. apply Nat.le_max_r. destruct X.
+    apply app2_find_hole in H0. destruct H0. repeat destruct s ; destruct p ; subst.
+    + assert (J11: derrec_height x2 < S (dersrec_height d)). rewrite e. apply PeanoNat.le_lt_n_Sm.
+        apply Nat.max_le_iff. left. apply (Nat.le_trans _ _ _ l0 l).
+        assert (J12: derrec_height x2 = derrec_height x2). auto.
+        pose (IHn _ J11 _ _ J12).
+        assert (J2: (Γ2 ++ Γ3, Δ0 ++ A :: Δ1) = (Γ2 ++ Γ3, Δ0 ++ A :: Δ1)). auto.
+        apply s in J2. destruct J2. destruct p. destruct p.
+        assert (J13: derrec_height x3 < S (dersrec_height d)). lia.
+        assert (J14: derrec_height x3 = derrec_height x3). auto.
+        pose (IHn _ J13 _ _ J14).
+        assert (J2: (Γ2 ++ B :: Γ3, Δ0 ++ Δ1) = (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)). auto.
+        apply s0 in J2. destruct J2. destruct p0. destruct p0.
+        exists ((x5 --> (x6 --> Bot)) --> Bot). repeat split.
+        intros. 1,2: simpl in H ; repeat rewrite app_nil_r in H ; repeat rewrite propvar_subform_list_app ; simpl ;
+        repeat rewrite <- app_assoc ; apply in_app_or in H ; destruct H.
+        apply p in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; destruct H ; auto.
+        apply p0 in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; repeat rewrite <- app_assoc in H ; destruct H ; auto.
+        apply p in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; destruct H ; auto.
+        apply in_app_or in i0 ; destruct i0. apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+        apply in_app_or in H ; destruct H. apply in_or_app ; auto.
+        apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; right ; auto.
+        apply p0 in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; repeat rewrite <- app_assoc in H ; destruct H ; auto.
+        apply in_app_or in i0 ; destruct i0. apply in_or_app ; right ; apply in_or_app ; auto.
+        apply in_app_or in H ; destruct H. 1,2: apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+        apply derI with (ps:=[([] ++ (x5 --> x6 --> Bot) :: Γ2, [] ++ Bot :: Δ0)]). apply ImpR.
+        assert ((Γ2, (x5 --> x6 --> Bot) --> Bot :: Δ0) = ([] ++ Γ2, [] ++ (x5 --> x6 --> Bot) --> Bot :: Δ0)). auto. rewrite H. apply ImpRRule_I.
+        apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[([] ++ Γ2, [] ++ x5 :: Bot :: Δ0);([] ++ x6 --> Bot :: Γ2, [] ++ Bot :: Δ0)]). apply ImpL. apply ImpLRule_I.
+        apply dlCons. simpl.
+        assert (J15: derrec_height d1 = derrec_height d1). auto.
+        assert (J16: wkn_R Bot (Γ2, [x5] ++ Δ0) (Γ2, [x5] ++ Bot :: Δ0)). apply wkn_RI. simpl in J16.
+        pose (KS_wkn_R _ _ d1 J15 _ _ J16). destruct s1 ; auto. apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[([] ++ Γ2, [] ++ x6 :: Bot :: Δ0);([] ++ Bot :: Γ2, [] ++ Bot :: Δ0)]). apply ImpL. apply ImpLRule_I.
+        apply dlCons. simpl.
+        assert (J15: derrec_height d3 = derrec_height d3). auto.
+        assert (J16: wkn_R Bot (Γ2, [x6] ++ Δ0) (Γ2, [x6] ++ Bot :: Δ0)). apply wkn_RI. simpl in J16.
+        pose (KS_wkn_R _ _ d3 J15 _ _ J16). destruct s1 ; auto.
+        apply dlCons. 2: apply dlNil. apply derI with (ps:=[]). apply BotL. apply BotLRule_I. apply dlNil.
+        apply derI with (ps:=[([] ++ A --> B :: Γ3, [] ++ (x5 --> x6 --> Bot) :: Δ1);([] ++ Bot :: A --> B :: Γ3, [] ++ Δ1)]).
+        assert (((x5 --> x6 --> Bot) --> Bot :: A --> B :: Γ3, Δ1) = ([] ++ (x5 --> x6 --> Bot) --> Bot :: A --> B :: Γ3, [] ++ Δ1)). auto.
+        rewrite H. apply ImpL. apply ImpLRule_I. apply dlCons.
+        apply derI with (ps:=[([] ++ x5 :: A --> B :: Γ3, [] ++ x6 --> Bot :: Δ1)]). apply ImpR. apply ImpRRule_I. apply dlCons.
+        apply derI with (ps:=[([x5] ++ Γ3, [] ++ A :: x6 --> Bot :: Δ1);([x5] ++ B :: Γ3, [] ++ x6 --> Bot :: Δ1)]).
+        assert (([] ++ x5 :: A --> B :: Γ3, [] ++ x6 --> Bot :: Δ1) = ([x5] ++ A --> B :: Γ3, [] ++ x6 --> Bot :: Δ1)). auto.
+        rewrite H. apply ImpL. apply ImpLRule_I. apply dlCons. 3: apply dlNil.
+        assert (J15: derrec_height d0 = derrec_height d0). auto. simpl.
+        assert (J16: wkn_R (x6 --> Bot) (x5 :: Γ3, [A]++ Δ1) (x5 :: Γ3, [A] ++ x6 --> Bot :: Δ1)). apply wkn_RI. simpl in J16.
+        pose (KS_wkn_R _ _ d0 J15 _ _ J16). destruct s1 ; auto. apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[([x5] ++ x6 :: B :: Γ3, [] ++ Bot :: Δ1)]). apply ImpR. apply ImpRRule_I. apply dlCons.
+        assert (J15: derrec_height d2 = derrec_height d2). auto. simpl.
+        assert (J16: wkn_R Bot (x6 :: B :: Γ3, [] ++ Δ1) (x6 :: B :: Γ3, [] ++ Bot :: Δ1)). apply wkn_RI. simpl in J16.
+        pose (KS_wkn_R _ _ d2 J15 _ _ J16). destruct s1.
+        assert (J17: derrec_height x7 = derrec_height x7). auto. simpl.
+        assert (J18: wkn_L x5 ([] ++ x6 :: B :: Γ3, Bot :: Δ1) ([] ++ x5 :: x6 :: B :: Γ3, Bot :: Δ1)). apply wkn_LI. simpl in J18.
+        pose (KS_wkn_L _ _ x7 J17 _ _ J18). destruct s1. auto. apply dlNil. apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[]). apply BotL. apply BotLRule_I. apply dlNil.
+    + destruct x4.
+      -- simpl. repeat rewrite app_nil_r. simpl in e1. subst.
+          assert (J11: derrec_height x2 < S (dersrec_height d)). rewrite e. apply PeanoNat.le_lt_n_Sm.
+          apply Nat.max_le_iff. left. apply (Nat.le_trans _ _ _ l0 l).
+          assert (J12: derrec_height x2 = derrec_height x2). auto.
+          pose (IHn _ J11 _ _ J12).
+          assert (J2: (Γ2 ++ Γ3, Δ0 ++ A :: Δ1) = (Γ2 ++ Γ3, Δ0 ++ A :: Δ1)). auto.
+          apply s in J2. destruct J2. destruct p. destruct p.
+          assert (J13: derrec_height x3 < S (dersrec_height d)). lia.
+          assert (J14: derrec_height x3 = derrec_height x3). auto.
+          pose (IHn _ J13 _ _ J14).
+          assert (J2: (Γ2 ++ B :: Γ3, Δ0 ++ Δ1) = (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)). auto.
+          apply s0 in J2. destruct J2. destruct p0. destruct p0.
+          exists ((x4 --> (x5 --> Bot)) --> Bot). repeat split.
+          intros. 1,2: simpl in H ; repeat rewrite app_nil_r in H ; repeat rewrite propvar_subform_list_app ; simpl ;
+          repeat rewrite <- app_assoc ; apply in_app_or in H ; destruct H.
+          apply p in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; destruct H ; auto.
+          apply p0 in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; repeat rewrite <- app_assoc in H ; destruct H ; auto.
+          apply p in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; destruct H ; auto.
+          apply in_app_or in i0 ; destruct i0. apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+          apply in_app_or in H ; destruct H. apply in_or_app ; auto.
+          apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; right ; auto.
+          apply p0 in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; repeat rewrite <- app_assoc in H ; destruct H ; auto.
+          apply in_app_or in i0 ; destruct i0. apply in_or_app ; right ; apply in_or_app ; auto.
+          apply in_app_or in H ; destruct H. 1,2: apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+          apply derI with (ps:=[([] ++ (x4 --> x5 --> Bot) :: Γ2, [] ++ Bot :: Δ0)]). apply ImpR.
+          assert ((Γ2, (x4 --> x5 --> Bot) --> Bot :: Δ0) = ([] ++ Γ2, [] ++ (x4 --> x5 --> Bot) --> Bot :: Δ0)). auto. rewrite H. apply ImpRRule_I.
+          apply dlCons. 2: apply dlNil.
+          apply derI with (ps:=[([] ++ Γ2, [] ++ x4 :: Bot :: Δ0);([] ++ x5 --> Bot :: Γ2, [] ++ Bot :: Δ0)]). apply ImpL. apply ImpLRule_I.
+          apply dlCons. simpl.
+          assert (J15: derrec_height d1 = derrec_height d1). auto.
+          assert (J16: wkn_R Bot (Γ2, [x4] ++ Δ0) (Γ2, [x4] ++ Bot :: Δ0)). apply wkn_RI. simpl in J16.
+          pose (KS_wkn_R _ _ d1 J15 _ _ J16). destruct s1 ; auto. apply dlCons. 2: apply dlNil.
+          apply derI with (ps:=[([] ++ Γ2, [] ++ x5 :: Bot :: Δ0);([] ++ Bot :: Γ2, [] ++ Bot :: Δ0)]). apply ImpL. apply ImpLRule_I.
+          apply dlCons. simpl.
+          assert (J15: derrec_height d3 = derrec_height d3). auto.
+          assert (J16: wkn_R Bot (Γ2, [x5] ++ Δ0) (Γ2, [x5] ++ Bot :: Δ0)). apply wkn_RI. simpl in J16.
+          pose (KS_wkn_R _ _ d3 J15 _ _ J16). destruct s1 ; auto.
+          apply dlCons. 2: apply dlNil. apply derI with (ps:=[]). apply BotL. apply BotLRule_I. apply dlNil.
+          apply derI with (ps:=[([] ++ A --> B :: Γ3, [] ++ (x4 --> x5 --> Bot) :: Δ1);([] ++ Bot :: A --> B :: Γ3, [] ++ Δ1)]).
+          assert (((x4 --> x5 --> Bot) --> Bot :: A --> B :: Γ3, Δ1) = ([] ++ (x4 --> x5 --> Bot) --> Bot :: A --> B :: Γ3, [] ++ Δ1)). auto.
+          rewrite H. apply ImpL. apply ImpLRule_I. apply dlCons.
+          apply derI with (ps:=[([] ++ x4 :: A --> B :: Γ3, [] ++ x5 --> Bot :: Δ1)]). apply ImpR. apply ImpRRule_I. apply dlCons.
+          apply derI with (ps:=[([x4] ++ Γ3, [] ++ A :: x5 --> Bot :: Δ1);([x4] ++ B :: Γ3, [] ++ x5 --> Bot :: Δ1)]).
+          assert (([] ++ x4 :: A --> B :: Γ3, [] ++ x5 --> Bot :: Δ1) = ([x4] ++ A --> B :: Γ3, [] ++ x5 --> Bot :: Δ1)). auto.
+          rewrite H. apply ImpL. apply ImpLRule_I. apply dlCons. 3: apply dlNil.
+          assert (J15: derrec_height d0 = derrec_height d0). auto. simpl.
+          assert (J16: wkn_R (x5 --> Bot) (x4 :: Γ3, [A]++ Δ1) (x4 :: Γ3, [A] ++ x5 --> Bot :: Δ1)). apply wkn_RI. simpl in J16.
+          pose (KS_wkn_R _ _ d0 J15 _ _ J16). destruct s1 ; auto. apply dlCons. 2: apply dlNil.
+          apply derI with (ps:=[([x4] ++ x5 :: B :: Γ3, [] ++ Bot :: Δ1)]). apply ImpR. apply ImpRRule_I. apply dlCons.
+          assert (J15: derrec_height d2 = derrec_height d2). auto. simpl.
+          assert (J16: wkn_R Bot (x5 :: B :: Γ3, [] ++ Δ1) (x5 :: B :: Γ3, [] ++ Bot :: Δ1)). apply wkn_RI. simpl in J16.
+          pose (KS_wkn_R _ _ d2 J15 _ _ J16). destruct s1.
+          assert (J17: derrec_height x6 = derrec_height x6). auto. simpl.
+          assert (J18: wkn_L x4 ([] ++ x5 :: B :: Γ3, Bot :: Δ1) ([] ++ x4 :: x5 :: B :: Γ3, Bot :: Δ1)). apply wkn_LI. simpl in J18.
+          pose (KS_wkn_L _ _ x6 J17 _ _ J18). destruct s1. auto. apply dlNil. apply dlCons. 2: apply dlNil.
+          apply derI with (ps:=[]). apply BotL. apply BotLRule_I. apply dlNil.
+      -- repeat rewrite <- app_assoc. simpl. simpl in e1. inversion e1. subst.
+          assert (J13: derrec_height x3 < S (dersrec_height d)). lia.
+          assert (J14: derrec_height x3 = derrec_height x3). auto.
+          pose (IHn _ J13 _ _ J14).
+          assert (J2: (Γ2 ++ B :: x4 ++ Γ1, Δ0 ++ Δ1) = ((Γ2 ++ B :: x4) ++ Γ1, Δ0 ++ Δ1)). repeat rewrite <- app_assoc. auto.
+          apply s in J2. destruct J2. destruct p. destruct p.
+          assert (J7: derrec_height x2 = derrec_height x2). auto.
+          assert (J8: list_exch_R (Γ2 ++ x4 ++ Γ1, Δ0 ++ A :: Δ1) (Γ2 ++ x4 ++ Γ1, Δ1 ++ A :: Δ0)).
+          assert (Δ0 ++ A :: Δ1 = [] ++ Δ0 ++ [A] ++ Δ1 ++ []). rewrite app_nil_r. auto. rewrite H.
+          assert (Δ1 ++ A :: Δ0 = [] ++ Δ1 ++ [A] ++ Δ0 ++ []). rewrite app_nil_r. auto. rewrite H0. apply list_exch_RI.
+          pose (KS_hpadm_list_exch_R _ x2 _ J8). destruct s0.
+          assert (J9: derrec_height x6 = derrec_height x6). auto.
+          assert (J10: list_exch_L (Γ2 ++ x4 ++ Γ1, Δ1 ++ A :: Δ0) (Γ1 ++ x4 ++ Γ2, Δ1 ++ A :: Δ0)).
+          assert (Γ2 ++ x4 ++ Γ1 = [] ++ Γ2 ++ x4 ++ Γ1 ++ []). rewrite app_nil_r. auto. rewrite H.
+          assert (Γ1 ++ x4 ++ Γ2 = [] ++ Γ1 ++ x4 ++ Γ2 ++ []). rewrite app_nil_r. auto. rewrite H0. apply list_exch_LI.
+          pose (KS_hpadm_list_exch_L _ x6 _ J10). destruct s0.
+          assert (J11: derrec_height x7 < S (dersrec_height d)). rewrite e. apply PeanoNat.le_lt_n_Sm.
+          apply Nat.max_le_iff. left. pose (Nat.le_trans _ _ _ l0 l). pose (Nat.le_trans _ _ _ l2 l4). apply (Nat.le_trans _ _ _ l3 l5).
+          assert (J12: derrec_height x7 = derrec_height x7). auto.
+          pose (IHn _ J11 _ _ J12).
+          assert (J2: (Γ1 ++ x4 ++ Γ2, Δ1 ++ A :: Δ0) = (Γ1 ++ x4 ++ Γ2, Δ1 ++ A :: Δ0)). auto.
+          apply s0 in J2. destruct J2. destruct p0. destruct p0.
+          exists (x8 --> x5). repeat split.
+          intros. 1,2: simpl in H ; repeat rewrite app_nil_r in H ; repeat rewrite propvar_subform_list_app ; simpl ;
+          repeat rewrite propvar_subform_list_app ; simpl ;repeat rewrite <- app_assoc ; apply in_app_or in H ; destruct H.
+          apply p0 in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; repeat rewrite <- app_assoc in H ; destruct H ; auto.
+          apply in_app_or in i0 ; destruct i0. apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+          apply in_app_or in H ; destruct H. apply in_or_app ; auto. apply in_app_or in H ; destruct H.
+          apply in_or_app ; right ; apply in_or_app ; auto. apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+          apply p in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; destruct H ; repeat rewrite <- app_assoc in i.
+          apply in_app_or in i ; destruct i. apply in_or_app ; auto. apply in_app_or in H ; destruct H.
+          apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto. apply in_app_or in H ; destruct H.
+          apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+          apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+          apply p0 in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; repeat rewrite <- app_assoc in H ; destruct H ; auto.
+          apply p in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; destruct H ; auto.
+          apply derI with (ps:=[(Γ2 ++ x8 :: A --> B :: x4, [] ++ x5 :: Δ0)]). apply ImpR.
+          assert ((Γ2 ++ A --> B :: x4, x8 --> x5 :: Δ0) = (Γ2 ++ A --> B :: x4, [] ++ x8 --> x5 :: Δ0)). auto. rewrite H. apply ImpRRule_I.
+          apply dlCons. 2: apply dlNil.
+          apply derI with (ps:=[((Γ2 ++ [x8]) ++ x4, [] ++ A :: x5 :: Δ0);((Γ2 ++ [x8]) ++ B :: x4, [] ++ x5 :: Δ0)]). apply ImpL.
+          assert ((Γ2 ++ x8 :: A --> B :: x4, [] ++ x5 :: Δ0) = ((Γ2 ++ [x8]) ++ A --> B :: x4, [] ++ x5 :: Δ0)). repeat rewrite <- app_assoc. auto.
+          rewrite H. apply ImpLRule_I. apply dlCons. repeat rewrite <- app_assoc. simpl.
+          assert (J15: derrec_height d2 = derrec_height d2). auto.
+          pose (@KS_list_wkn_R (derrec_height d2) (x8 :: x4 ++ Γ2) [A] Δ0). simpl in s1.
+          pose (s1 d2 J15 [x5]). simpl in s2. destruct s2.
+          assert (J16: derrec_height x9 = derrec_height x9). auto.
+          assert (J17: list_exch_L (x8 :: x4 ++ Γ2, A :: x5 :: Δ0) (Γ2 ++ x8 :: x4, A :: x5 :: Δ0)).
+          assert (x8 :: x4 ++ Γ2 = [] ++ (x8 :: x4) ++ [] ++ Γ2 ++ []). rewrite app_nil_r. auto. rewrite H.
+          assert (Γ2 ++ x8 :: x4 = [] ++ Γ2 ++ [] ++ (x8 :: x4) ++ []). rewrite app_nil_r. auto. rewrite H0. apply list_exch_LI.
+          pose (KS_hpadm_list_exch_L _ x9 _ J17). destruct s2. auto.
+          simpl. repeat rewrite <- app_assoc. simpl.
+          assert (J17: derrec_height d1 = derrec_height d1). auto. simpl. apply dlCons. 2: apply dlNil.
+          assert (J18: wkn_L x8 (Γ2 ++ B :: x4, x5 :: Δ0) (Γ2 ++ x8 :: B :: x4, x5 :: Δ0)). apply wkn_LI.
+          pose (KS_wkn_L _ _ d1 J17 _ _ J18). destruct s1. auto.
+          apply derI with (ps:=[([] ++ Γ1, [] ++ x8 :: Δ1);([] ++ x5 :: Γ1, [] ++ Δ1)]).
+          assert ((x8 --> x5 :: Γ1, Δ1) = ([] ++ x8 --> x5 :: Γ1, [] ++ Δ1)). auto. rewrite H. apply ImpL. apply ImpLRule_I.
+          apply dlCons. simpl ; auto. apply dlCons. simpl ; auto. apply dlNil.
+    + assert (J11: derrec_height x2 < S (dersrec_height d)). rewrite e. apply PeanoNat.le_lt_n_Sm.
+        apply Nat.max_le_iff. left. apply (Nat.le_trans _ _ _ l0 l).
+        assert (J12: derrec_height x2 = derrec_height x2). auto.
+        pose (IHn _ J11 _ _ J12).
+        assert (J2: ((Γ0 ++ x4) ++ Γ3, Δ0 ++ A :: Δ1) = (Γ0 ++ x4 ++ Γ3, Δ0 ++ A :: Δ1)). repeat rewrite <- app_assoc. auto.
+        apply s in J2. destruct J2. destruct p. destruct p.
+        assert (J13: derrec_height x3 < S (dersrec_height d)). lia.
+        assert (J14: derrec_height x3 = derrec_height x3). auto.
+        pose (IHn _ J13 _ _ J14).
+        assert (J2: ((Γ0 ++ x4) ++ B :: Γ3, Δ0 ++ Δ1) = (Γ0 ++ x4 ++ B :: Γ3, Δ0 ++ Δ1)). repeat rewrite <- app_assoc. auto.
+        apply s0 in J2. destruct J2. destruct p0. destruct p0.
+        exists ((x5 --> (x6 --> Bot)) --> Bot). repeat split.
+        intros. 1,2: simpl in H ; repeat rewrite app_nil_r in H ; repeat rewrite propvar_subform_list_app ; simpl ;
+        repeat rewrite propvar_subform_list_app ; simpl ;repeat rewrite <- app_assoc ; apply in_app_or in H ; destruct H.
+        apply p in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; destruct H ; auto.
+        apply p0 in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; repeat rewrite <- app_assoc in H ; destruct H ; auto.
+        apply p in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; destruct H ; repeat rewrite <- app_assoc in i0.
+        apply in_app_or in i0 ; destruct i0. apply in_or_app ; auto. apply in_app_or in H ; destruct H.
+        apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto. apply in_app_or in H ; destruct H.
+        apply in_or_app ; right ; apply in_or_app ; auto.
+        apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+        apply p0 in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; repeat rewrite <- app_assoc in H ; destruct H ; auto.
+        apply in_app_or in i0 ; destruct i0. apply in_or_app ; auto. apply in_app_or in H ; destruct H.
+        apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto. apply in_app_or in H ; destruct H.
+        apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+        apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+        apply derI with (ps:=[([] ++ (x5 --> x6 --> Bot) :: Γ0, [] ++ Bot :: Δ0)]). apply ImpR.
+        assert ((Γ0, (x5 --> x6 --> Bot) --> Bot :: Δ0) = ([] ++ Γ0, [] ++ (x5 --> x6 --> Bot) --> Bot :: Δ0)). auto. rewrite H. apply ImpRRule_I.
+        apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[([] ++ Γ0, [] ++ x5 :: Bot :: Δ0);([] ++ x6 --> Bot :: Γ0, [] ++ Bot :: Δ0)]). apply ImpL. apply ImpLRule_I.
+        apply dlCons. simpl.
+        assert (J15: derrec_height d1 = derrec_height d1). auto.
+        assert (J16: wkn_R Bot (Γ0, [x5] ++ Δ0) (Γ0, [x5] ++ Bot :: Δ0)). apply wkn_RI. simpl in J16.
+        pose (KS_wkn_R _ _ d1 J15 _ _ J16). destruct s1 ; auto. apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[([] ++ Γ0, [] ++ x6 :: Bot :: Δ0);([] ++ Bot :: Γ0, [] ++ Bot :: Δ0)]). apply ImpL. apply ImpLRule_I.
+        apply dlCons. simpl.
+        assert (J15: derrec_height d3 = derrec_height d3). auto.
+        assert (J16: wkn_R Bot (Γ0, [x6] ++ Δ0) (Γ0, [x6] ++ Bot :: Δ0)). apply wkn_RI. simpl in J16.
+        pose (KS_wkn_R _ _ d3 J15 _ _ J16). destruct s1 ; auto.
+        apply dlCons. 2: apply dlNil. apply derI with (ps:=[]). apply BotL. apply BotLRule_I. apply dlNil.
+        apply derI with (ps:=[([] ++ x4 ++ A --> B :: Γ3, [] ++ (x5 --> x6 --> Bot) :: Δ1);([] ++ Bot :: x4 ++ A --> B :: Γ3, [] ++ Δ1)]).
+        assert (((x5 --> x6 --> Bot) --> Bot :: x4 ++ A --> B :: Γ3, Δ1) = ([] ++ (x5 --> x6 --> Bot) --> Bot :: x4 ++ A --> B :: Γ3, [] ++ Δ1)). auto.
+        rewrite H. apply ImpL. apply ImpLRule_I. apply dlCons.
+        apply derI with (ps:=[([] ++ x5 :: x4 ++ A --> B :: Γ3, [] ++ x6 --> Bot :: Δ1)]). apply ImpR. apply ImpRRule_I. apply dlCons.
+        apply derI with (ps:=[((x5 :: x4) ++ Γ3, [] ++ A :: x6 --> Bot :: Δ1);((x5 :: x4) ++ B :: Γ3, [] ++ x6 --> Bot :: Δ1)]).
+        assert (([] ++ x5 :: x4 ++ A --> B :: Γ3, [] ++ x6 --> Bot :: Δ1) = ((x5 :: x4) ++ A --> B :: Γ3, [] ++ x6 --> Bot :: Δ1)). auto.
+        rewrite H. apply ImpL. apply ImpLRule_I. apply dlCons. 3: apply dlNil.
+        assert (J15: derrec_height d0 = derrec_height d0). auto. simpl.
+        assert (J16: wkn_R (x6 --> Bot) (x5 :: x4 ++ Γ3, [A]++ Δ1) (x5 :: x4 ++ Γ3, [A] ++ x6 --> Bot :: Δ1)). apply wkn_RI. simpl in J16.
+        pose (KS_wkn_R _ _ d0 J15 _ _ J16). destruct s1 ; auto. apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[((x5 :: x4) ++ x6 :: B :: Γ3, [] ++ Bot :: Δ1)]). apply ImpR. apply ImpRRule_I. apply dlCons.
+          assert (J19: derrec_height d2 = derrec_height d2). auto.
+          assert (J20: list_exch_L (x6 :: x4 ++ B :: Γ3, Δ1) (x4 ++ x6 :: B :: Γ3, Δ1)).
+          assert (x6 :: x4 ++ B :: Γ3 = [] ++ [x6] ++ [] ++ x4 ++ (B :: Γ3)). auto. rewrite H.
+          assert (x4 ++ x6 :: B :: Γ3 = [] ++ x4 ++ [] ++ [x6] ++ (B :: Γ3)). auto. rewrite H0. apply list_exch_LI.
+          pose (KS_hpadm_list_exch_L _ d2 _ J20). destruct s1. auto.
+        assert (J15: derrec_height x7 = derrec_height x7). auto. simpl.
+        assert (J16: wkn_R Bot (x4 ++ x6 :: B :: Γ3, [] ++ Δ1) (x4 ++ x6 :: B :: Γ3, [] ++ Bot :: Δ1)). apply wkn_RI. simpl in J16.
+        pose (KS_wkn_R _ _ x7 J15 _ _ J16). destruct s1.
+        assert (J17: derrec_height x8 = derrec_height x8). auto. simpl.
+        assert (J18: wkn_L x5 ([] ++ x4 ++ x6 :: B :: Γ3, Bot :: Δ1) ([] ++ x5 :: x4 ++ x6 :: B :: Γ3, Bot :: Δ1)). apply wkn_LI. simpl in J18.
+        pose (KS_wkn_L _ _ x8 J17 _ _ J18). destruct s1. auto. apply dlNil. apply dlCons. 2: apply dlNil.
+        apply derI with (ps:=[]). apply BotL. apply BotLRule_I. apply dlNil.
+  (* KR *)
+  * inversion X. subst. inversion H5. subst. pose (univ_gen_ext_splitR _ _ X0). destruct s.
+    destruct s. destruct p. subst. destruct p.
+    assert (J: dersrec_height d = dersrec_height d). auto. apply dersrec_derrec_height in J. destruct J.
+    apply app2_find_hole in H1. destruct H1. simpl in IHn. repeat destruct s ; destruct p ; subst.
+    + assert (J1: derrec_height x1 < S (dersrec_height d)). lia.
+       assert (J2: derrec_height x1 = derrec_height x1). auto.
+       assert (J3: (unboxed_list (x ++ x0), [A]) = ((unboxed_list x) ++ (unboxed_list x0), [] ++ [A])).
+       rewrite unbox_app_distrib. repeat rewrite <- app_assoc. auto.
+       pose (IHn _ J1 _ _ J2 _ _ _ _ J3). destruct s. destruct p. destruct p.
+       exists (Box x3). simpl. simpl in p. repeat split.
+       intros. 1,2: simpl in H ; repeat rewrite app_nil_r in H ; repeat rewrite propvar_subform_list_app ; simpl ;
+       repeat rewrite propvar_subform_list_app ; simpl ;repeat rewrite <- app_assoc ;
+       apply p in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; repeat rewrite app_nil_r in H ; destruct H.
+       apply propvar_subform_list_unboxed_list in i. apply in_or_app ; left. apply (propvar_subform_list_nobox_gen_ext u) ; auto.
+       repeat rewrite <- app_assoc in i0. apply in_app_or in i0. destruct i0.
+       apply in_or_app ; left. apply propvar_subform_list_unboxed_list in H. apply (propvar_subform_list_nobox_gen_ext u0) ; auto.
+       apply in_or_app ; right ; apply in_or_app ; auto.
+       apply derI with (ps:=[(unboxed_list x, [x3])]). apply KR.
+       assert ((Γ0, Box x3 :: Δ2) = (Γ0, [] ++ Box x3 :: Δ2)). auto. rewrite H. apply KRRule_I ; auto.
+       intro. intros. apply H3. apply in_or_app ; auto. apply dlCons. 2: apply dlNil. auto.
+       apply derI with (ps:=[(unboxed_list (Box x3 :: x0), [A])]). apply KR.
+       assert ((Box x3 :: Γ1, Box A :: Δ3) = (Box x3 :: Γ1, [] ++ Box A :: Δ3)). auto. rewrite H. apply KRRule_I ; auto.
+       intro. intros. inversion H0. exists x3 ; subst ; auto. apply H3. apply in_or_app ; auto.
+       apply univ_gen_ext_cons ; auto. apply dlCons. 2: apply dlNil. simpl. auto.
+    + destruct x2.
+       -- repeat rewrite app_nil_r. simpl in e1. subst. assert (J1: derrec_height x1 < S (dersrec_height d)). lia.
+           assert (J2: derrec_height x1 = derrec_height x1). auto.
+           assert (J3: (unboxed_list (x ++ x0), [A]) = ((unboxed_list x) ++ (unboxed_list x0), [] ++ [A])).
+           rewrite unbox_app_distrib. repeat rewrite <- app_assoc. auto.
+           pose (IHn _ J1 _ _ J2 _ _ _ _ J3). destruct s. destruct p. destruct p.
+           exists (Box x2). simpl. repeat rewrite app_nil_r in p. repeat split.
+           intros. 1,2: simpl in H ; repeat rewrite app_nil_r in H ; repeat rewrite propvar_subform_list_app ; simpl ;
+           repeat rewrite propvar_subform_list_app ; simpl ;repeat rewrite <- app_assoc ;
+           apply p in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; repeat rewrite app_nil_r in H ;
+           destruct H ; repeat rewrite <- app_assoc in i0.
+           apply propvar_subform_list_unboxed_list in i. apply in_or_app ; left. apply (propvar_subform_list_nobox_gen_ext u) ; auto.
+           repeat rewrite <- app_assoc in i0. apply in_app_or in i0. destruct i0.
+           apply in_or_app ; left. apply propvar_subform_list_unboxed_list in H. apply (propvar_subform_list_nobox_gen_ext u0) ; auto.
+           apply in_or_app ; right ; apply in_or_app ; auto.
+           apply derI with (ps:=[(unboxed_list x, [x2])]). apply KR.
+           assert ((Γ0, Box x2 :: Δ2) = (Γ0, [] ++ Box x2 :: Δ2)). auto. rewrite H. apply KRRule_I ; auto.
+           intro. intros. apply H3. apply in_or_app ; auto. apply dlCons. 2: apply dlNil. auto.
+           apply derI with (ps:=[(unboxed_list (Box x2 :: x0), [A])]). apply KR.
+           assert ((Box x2 :: Γ1, Box A :: Δ3) = (Box x2 :: Γ1, [] ++ Box A :: Δ3)). auto. rewrite H. apply KRRule_I ; auto.
+           intro. intros. inversion H0. exists x2 ; subst ; auto. apply H3. apply in_or_app ; auto.
+           apply univ_gen_ext_cons ; auto. apply dlCons. 2: apply dlNil. simpl. auto.
+       -- simpl in e1. inversion e1 ; subst.
+              assert (J19: derrec_height x1 = derrec_height x1). auto.
+              assert (J20: list_exch_L (unboxed_list (x ++ x0), [A]) (unboxed_list x0 ++ unboxed_list x, [A])).
+              assert (unboxed_list (x ++ x0) = [] ++ (unboxed_list x) ++ [] ++ (unboxed_list x0) ++ []).
+              rewrite unbox_app_distrib. simpl. rewrite app_nil_r. auto. rewrite H.
+              assert (unboxed_list x0 ++ unboxed_list x = [] ++ (unboxed_list x0) ++ [] ++ (unboxed_list x) ++ []).
+              simpl. rewrite app_nil_r. auto. rewrite H0. apply list_exch_LI.
+               pose (KS_hpadm_list_exch_L _ x1 _ J20). destruct s.
+               assert (J1: derrec_height x3 < S (dersrec_height d)). rewrite <- e. apply PeanoNat.le_lt_n_Sm. auto.
+               assert (J2: derrec_height x3 = derrec_height x3). auto.
+               assert (J3: (unboxed_list x0 ++ unboxed_list x, [A]) = (unboxed_list x0 ++ unboxed_list x, [] ++ [A])).
+               repeat rewrite <- app_assoc. auto.
+               pose (IHn _ J1 _ _ J2 _ _ _ _ J3). destruct s. destruct p. destruct p.
+               exists ((Box x4) --> Bot). simpl. repeat rewrite app_nil_r in p. repeat rewrite app_nil_r. repeat split.
+               intros. 1,2: simpl in H ; repeat rewrite app_nil_r in H ; repeat rewrite propvar_subform_list_app ; simpl ;
+               repeat rewrite propvar_subform_list_app ; simpl ;repeat rewrite <- app_assoc ;
+               apply p in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; repeat rewrite app_nil_r in H ;
+               destruct H ; repeat rewrite <- app_assoc in i0. apply in_app_or in i0. destruct i0.
+             apply in_or_app ; left. apply propvar_subform_list_unboxed_list in H. apply (propvar_subform_list_nobox_gen_ext u) ; auto.
+             apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+             apply propvar_subform_list_unboxed_list in i. apply in_or_app ; left.
+             apply (propvar_subform_list_nobox_gen_ext u0) ; auto.
+             apply derI with (ps:=[([] ++ Box x4 :: Γ0, [] ++ Bot :: Δ2 ++ Box A :: x2)]). apply ImpR.
+             assert ((Γ0, Box x4 --> Bot :: Δ2 ++ Box A :: x2) = ([] ++ Γ0, [] ++ Box x4 --> Bot :: Δ2 ++ Box A :: x2)). auto. rewrite H. apply ImpRRule_I.
+             apply dlCons. 2: apply dlNil. simpl.
+             pose (dlCons d0 (dlNil _ _)). apply derI with (concl:=(Box x4 :: Γ0, (Bot :: Δ2) ++ Box A :: x2)) in d2 ; auto.
+             apply KR. assert (x4 :: unboxed_list x = unboxed_list (Box x4 :: x)).
+             simpl. auto. rewrite H. apply KRRule_I ; auto. intro. intros. inversion H0. exists x4 ; subst ; auto.
+             apply H3. apply in_or_app ; auto. apply univ_gen_ext_cons ; auto.
+             apply derI with (ps:=[([] ++ Γ1, [] ++ Box x4 :: Δ1);([] ++ Bot :: Γ1, [] ++ Δ1)]). apply ImpL.
+             assert ((Box x4 --> Bot :: Γ1, Δ1) = ([] ++ Box x4 --> Bot :: Γ1, [] ++ Δ1)). auto. rewrite H. apply ImpLRule_I.
+             apply dlCons. apply derI with (ps:=[(unboxed_list x0, [x4])]). apply KR. apply KRRule_I ; auto.
+             intro. intros. apply H3. apply in_or_app ; auto. apply dlCons.
+             assert (J4: derrec_height d1 = derrec_height d1). auto. 2: apply dlNil. auto.
+             apply dlCons. 2: apply dlNil. apply derI with (ps:=[]). apply BotL. 2: apply dlNil. apply BotLRule_I.
+    + assert (J1: derrec_height x1 < S (dersrec_height d)). lia.
+       assert (J2: derrec_height x1 = derrec_height x1). auto.
+       assert (J3: (unboxed_list (x ++ x0), [A]) = ((unboxed_list x) ++ (unboxed_list x0), [] ++ [A])).
+       rewrite unbox_app_distrib. repeat rewrite <- app_assoc. auto.
+       pose (IHn _ J1 _ _ J2 _ _ _ _ J3). destruct s. destruct p. destruct p.
+       exists (Box x3). simpl. repeat rewrite app_nil_r in p. repeat split.
+       intros. 1,2: simpl in H ; repeat rewrite app_nil_r in H ; repeat rewrite propvar_subform_list_app ; simpl ;
+       repeat rewrite propvar_subform_list_app ; simpl ;repeat rewrite <- app_assoc ;
+       apply p in H ; repeat rewrite propvar_subform_list_app in H ; simpl in H ; repeat rewrite app_nil_r in H ;
+       destruct H ; repeat rewrite <- app_assoc in i0.
+       apply propvar_subform_list_unboxed_list in i. apply in_or_app ; left.
+       apply (propvar_subform_list_nobox_gen_ext u) ; auto.
+       apply in_app_or in i0. destruct i0.
+       apply in_or_app ; left. apply propvar_subform_list_unboxed_list in H. apply (propvar_subform_list_nobox_gen_ext u0) ; auto.
+       apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+       apply derI with (ps:=[(unboxed_list x, [x3])]). apply KR.
+       assert ((Γ0, Box x3 :: Δ0) = (Γ0, [] ++ Box x3 :: Δ0)). auto. rewrite H. apply KRRule_I ; auto.
+       intro. intros. apply H3. apply in_or_app ; auto. apply dlCons. 2: apply dlNil. auto.
+       apply derI with (ps:=[(unboxed_list (Box x3 :: x0), [A])]). apply KR. apply KRRule_I ; auto.
+       intro. intros. inversion H. exists x3 ; subst ; auto. apply H3. apply in_or_app ; auto.
+       apply univ_gen_ext_cons ; auto. apply dlCons. 2: apply dlNil. simpl. auto.
+Qed.
+
+
+ +
+ + + diff --git a/K.Interpolation.UIK_Canopy.html b/K.Interpolation.UIK_Canopy.html new file mode 100644 index 0000000..a51bf96 --- /dev/null +++ b/K.Interpolation.UIK_Canopy.html @@ -0,0 +1,623 @@ + + + + + + + + + + + + + +
+
+

K.Interpolation.UIK_Canopy

+ +
+  (* Canopy of the invertible proof search of sequents *)
+ +
+  Require Import List.
+  Export ListNotations.
+  Require Import Lia.
+ +
+  Require Import Coq.Init.Wf.
+ +
+  Require Import KS_export.
+  Require Import UIK_Def_measure.
+ +
+  Require Import UIK_irred_short UIK_irred_high_level.
+ +
+  Require Import general_export.
+ +
+  (* Defining the premises of a sequent via Imp rules. *)
+ +
+  Lemma finite_ImpRules_premises_of_S : forall (s : Seq), existsT2 listImpRulesprems,
+                (forall prems, (((ImpRRule prems s) + (ImpLRule prems s)) -> (InT prems listImpRulesprems)) *
+                               ((InT prems listImpRulesprems) -> ((ImpRRule prems s) + (ImpLRule prems s)))).
+  Proof.
+  intros.
+  pose (finite_ImpR_premises_of_S s). destruct s0.
+  pose (finite_ImpL_premises_of_S s). destruct s0.
+  exists (x ++ x0). intros. split ; intro.
+  - destruct H.
+    + inversion i. subst. apply InT_or_app. left. apply p. apply ImpRRule_I.
+    + inversion i. subst. apply InT_or_app. right. apply p0. apply ImpLRule_I.
+  - apply InT_app_or in H. destruct H.
+    + left. apply p ; auto.
+    + right. apply p0 ; auto.
+  Defined.
+ +
+  Definition inv_prems (s : Seq) := flatten_list (proj1_sigT2 (finite_ImpRules_premises_of_S s)).
+ +
+  (* The number of implication symbols in a sequent gives a measure
+      which has a well-founded order.*)

+ +
+Fixpoint n_imp_subformF (A : MPropF) : nat :=
+match A with
+ | # P => 0
+ | Bot => 0
+ | Imp B C => 1 + (n_imp_subformF B) + (n_imp_subformF C)
+ | Box B => (n_imp_subformF B)
+end.
+ +
+(* With this definition in hand, we can then straightforwardly define the number
+   of implications in a list of formulae. *)

+ +
+Fixpoint n_imp_subformLF (l : list MPropF) : nat :=
+match l with
+  | [] => 0
+  | h :: t => (n_imp_subformF h) + (n_imp_subformLF t)
+end.
+ +
+(* Then the definition we were initially looking for can be reached: *)
+ +
+Definition n_imp_subformS (s : Seq) : nat :=
+    (n_imp_subformLF (fst s)) + (n_imp_subformLF (snd s)).
+ +
+(* It is clear that n_imp_subformS counts the occurrences of implications in a
+   sequent s. As a consequence, if that number is 0 we know for sure that the
+   rules for implication on the left or right cannot be applied upwards on s.
+   This is the meaning of the lemma n_imp_subformS_is_0. 
+
+   But first we need a preliminary lemma which claims that if an implication is
+   in a list, then n_imp_subformLF of that list is higher than one.*)

+ +
+Lemma In_n_imp_subformLF_is_non_0 (l : list MPropF) :
+    forall A B, (In (Imp A B) l) -> (le 1 (n_imp_subformLF l)).
+Proof.
+intros A B Hin. induction l.
+- inversion Hin.
+- inversion Hin.
+  * subst. simpl. lia.
+  * pose (IHl H). simpl. destruct l0 ; lia.
+Qed.
+ +
+Theorem n_imp_subformS_is_0 (s : Seq) :
+    (n_imp_subformS s) = 0 -> (existsT2 ps, (ImpRRule ps s) + (ImpLRule ps s)) -> False.
+Proof.
+intros is0 RA. destruct RA. destruct s0.
+- inversion i. subst. unfold n_imp_subformS in is0. simpl in is0.
+  assert (n_imp_subformLF (Δ0 ++ A --> B :: Δ1) = 0). lia.
+  assert (In (A --> B) (Δ0 ++ A --> B :: Δ1)). apply in_or_app. right. apply in_eq.
+  pose (In_n_imp_subformLF_is_non_0 (Δ0 ++ A --> B :: Δ1) A B H0). lia.
+- inversion i. subst.
+  assert (In (A --> B) (Γ0 ++ A --> B :: Γ1)). apply in_or_app. right. apply in_eq.
+  pose (In_n_imp_subformLF_is_non_0 (Γ0 ++ A --> B :: Γ1) A B H). unfold n_imp_subformS in is0.
+  simpl in is0. assert (n_imp_subformLF (Δ0 ++ Δ1) = 0). lia. lia.
+Qed.
+ +
+Lemma n_imp_subformLF_dist_app : forall l1 l2, n_imp_subformLF (l1 ++ l2) =
+                                               plus (n_imp_subformLF l1) (n_imp_subformLF l2).
+Proof.
+induction l1.
+- intros. auto.
+- intros. simpl. rewrite IHl1. lia.
+Qed.
+ +
+Lemma n_imp_nobox_gen_ext : forall l1 l2, nobox_gen_ext l1 l2 ->
+                                               (n_imp_subformLF l1 <= n_imp_subformLF l2).
+Proof.
+intros. induction X.
+- simpl. lia.
+- simpl. lia.
+- simpl. lia.
+Qed.
+ +
+Lemma n_imp_unboxed : forall l, (n_imp_subformLF (unboxed_list l) <= n_imp_subformLF l).
+Proof.
+induction l.
+- simpl. lia.
+- simpl. destruct a ; simpl ; lia.
+Qed.
+ +
+  Definition less_imp (s0 s1 : Seq) := (n_imp_subformS s0) < (n_imp_subformS s1).
+ +
+  Lemma Acc_less_imp : well_founded less_imp.
+  Proof.
+  intros s ; induction on s as IHm with measure (n_imp_subformS s).
+  apply Acc_intro. auto.
+  Defined.
+ +
+  Definition invprem (s0 s1 : Seq) := In s0 (inv_prems s1).
+ +
+  Lemma InT_In_inv_prems : forall s0 s1, (InT s0 (inv_prems s1) -> In s0 (inv_prems s1)) *
+                                                                   (In s0 (inv_prems s1) -> InT s0 (inv_prems s1)).
+  Proof.
+  intros. split ; intros.
+  - apply InT_In ; auto.
+  - unfold inv_prems. unfold inv_prems in H. destruct (finite_ImpRules_premises_of_S s1).
+    simpl. simpl in H. apply In_InT_seqs. auto.
+Qed.
+ +
+  Lemma Acc_invprem : well_founded invprem.
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  apply Acc_intro. intros. apply IHs. unfold invprem in H.
+  apply InT_In_inv_prems in H. unfold inv_prems in H.
+  destruct (finite_ImpRules_premises_of_S s) in H. simpl in H.
+  apply InT_flatten_list_InT_elem in H. destruct H. destruct p0.
+  apply p in i0. destruct i0.
+  inversion i0. subst. inversion i. subst.
+  unfold n_imp_subformS ; simpl. repeat rewrite n_imp_subformLF_dist_app.
+  simpl. lia. subst. inversion H0.
+  inversion i0. subst. inversion i. subst.
+  unfold n_imp_subformS ; simpl. repeat rewrite n_imp_subformLF_dist_app.
+  simpl. lia. subst.
+  inversion H0. subst.
+  unfold n_imp_subformS ; simpl. repeat rewrite n_imp_subformLF_dist_app.
+  simpl. lia. subst. inversion H1.
+  Defined.
+ +
+  (* The closure of a sequent is the list of all sequents which can be
+      reach via chains of backward applications of invertible rules. *)

+ +
+  Definition Canopy := irred Acc_invprem.
+ +
+  (* Critical sequents are sequents on which no invertible (Imp)
+      rule is backward applicable. *)

+ +
+  Definition critical_Seq (s : Seq) := is_Prime ((fst s) ++ (snd s)).
+ +
+  Definition is_Prime_dec : forall l, (is_Prime l) + (is_Prime l -> False).
+  Proof.
+  unfold is_Prime. induction l ; simpl ; auto.
+  left. intros. inversion H. destruct IHl. destruct a as [n| | |].
+  1,2,4: left ; intros ; destruct H ; auto. right. left ; exists n ; auto.
+  left ; exists a ; auto. right. intro.
+  assert ((Imp a1 a2 = Imp a1 a2) \/ In (Imp a1 a2) l). left ; auto. apply H in H0.
+  destruct H0. destruct H0. inversion H0. destruct H0. destruct H0 ; inversion H0.
+  inversion H0. right. intros. apply f. intros. apply H. auto.
+  Defined.
+ +
+  Definition critical_Seq_dec (s : Seq) : (critical_Seq s) + (critical_Seq s -> False).
+  Proof.
+  unfold critical_Seq. destruct s ; simpl. apply is_Prime_dec.
+  Defined.
+ +
+  (* We show that all sequents in Canopy are critical. *)
+ +
+  Lemma inv_prems_id_critical : forall s, inv_prems s = [] -> critical_Seq s.
+  Proof.
+  intros. destruct s. unfold critical_Seq. intros A H0. destruct A as [n| | |].
+  right ; left ; exists n ; auto. right ; auto.
+  2: left ; exists A ; auto. exfalso. simpl in H0.
+  apply in_app_or in H0 ; destruct H0.
+  apply in_split in H0. destruct H0. destruct H0. subst.
+  assert (In (x ++ A2 :: x0, l0) (inv_prems (x ++ A1 --> A2 :: x0, l0))).
+  unfold inv_prems. apply InT_In.
+  apply InT_trans_flatten_list with (bs:=[(x ++ x0, [] ++ A1 :: l0);(x ++ A2 :: x0, [] ++ l0)]).
+  apply InT_cons ; apply InT_eq.
+  destruct (finite_ImpRules_premises_of_S (x ++ A1 --> A2 :: x0, l0)).
+  apply p. right. assert ((x ++ A1 --> A2 :: x0, l0) = (x ++ A1 --> A2 :: x0, [] ++ l0)). auto.
+  rewrite H0. apply ImpLRule_I.
+  rewrite H in H0. inversion H0.
+  apply in_split in H0. destruct H0. destruct H0. subst.
+  assert (In (l ++ A1 :: [], x ++ A2 :: x0) (inv_prems (l ++ [] , x ++ A1 --> A2 :: x0))).
+  unfold inv_prems. apply InT_In.
+  apply InT_trans_flatten_list with (bs:=[(l ++ [A1], x ++ A2 :: x0)]). apply InT_eq.
+  destruct (finite_ImpRules_premises_of_S (l ++ [], x ++ A1 --> A2 :: x0)).
+  apply p. left. apply ImpRRule_I. rewrite app_nil_r in H0.
+  rewrite H in H0. inversion H0.
+  Qed.
+ +
+  Lemma Canopy_critical : forall s leaf, InT leaf (Canopy s) -> (critical_Seq leaf).
+  Proof.
+  unfold Canopy.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros. remember (inv_prems s) as prems. destruct prems.
+  - symmetry in Heqprems ; pose (irred_nil _ _ Acc_invprem s Heqprems).
+    rewrite e in H. pose (inv_prems_id_critical _ Heqprems). inversion H ; subst ; auto.
+    inversion H1.
+  - assert (J1: inv_prems s <> []%list). rewrite <- Heqprems. intro.
+    inversion H0. pose (irred_not _ _ Acc_invprem s J1). rewrite e in H.
+    pose (InT_In H). apply in_flat_map in i. destruct i. destruct H0.
+    apply In_InT_seqs in H1. apply IHs with (y:=x) ; auto.
+    apply InT_In_inv_prems in H0. unfold inv_prems in H0.
+    destruct (finite_ImpRules_premises_of_S s) in H0. simpl in H0.
+    apply InT_flatten_list_InT_elem in H0. destruct H0. destruct p0.
+    apply p in i0. destruct i0.
+    inversion i0. subst. inversion i. subst.
+    unfold n_imp_subformS ; simpl. repeat rewrite n_imp_subformLF_dist_app.
+    simpl. lia. subst. inversion H2.
+    inversion i0. subst. inversion i. subst.
+    unfold n_imp_subformS ; simpl. repeat rewrite n_imp_subformLF_dist_app.
+    simpl. lia. subst.
+    inversion H2. subst.
+    unfold n_imp_subformS ; simpl. repeat rewrite n_imp_subformLF_dist_app.
+    simpl. lia. subst. inversion H3.
+  Qed.
+ +
+  (* We show the equiprovability between a sequent and its Canopy. *)
+ +
+  Lemma ImpRule_Canopy : forall s prems, ((ImpRRule prems s) + (ImpLRule prems s)) ->
+                (forall prem, InT prem prems -> (forall leaf, InT leaf (Canopy prem) -> InT leaf (Canopy s))).
+  Proof.
+  intros. unfold Canopy. rewrite irred_not. apply In_InT_seqs.
+  apply in_flat_map. exists prem ; split ; auto. 2: apply InT_In ; auto.
+  unfold inv_prems. apply InT_In. apply InT_trans_flatten_list with (bs:=prems) ; auto.
+  destruct (finite_ImpRules_premises_of_S s) ; simpl. apply p ; auto.
+  intro. unfold inv_prems in H2. destruct (finite_ImpRules_premises_of_S s) ; simpl.
+  simpl in H2. apply p in H. assert (InT prem (flatten_list x)).
+  apply InT_trans_flatten_list with (bs:=prems) ; auto. rewrite H2 in H3. inversion H3.
+  Qed.
+ +
+  (* Move the lemma below to a more general location. *)
+ +
+  Lemma InT_flat_map: forall (f : Seq -> list Seq) (l : list Seq) (y : Seq), (InT y (flat_map f l) -> (existsT2 x : Seq, InT x l * InT y (f x))) *
+                                                                                                                ( (existsT2 x : Seq, InT x l * InT y (f x)) -> InT y (flat_map f l)).
+  Proof.
+  intros f. induction l.
+  - intros ; split ; intros. simpl in H. inversion H. simpl. destruct H. destruct p. inversion i.
+  - intros ; simpl ; split ; intros. apply InT_app_or in H. destruct H. exists a ; split ; auto. apply InT_eq.
+    apply IHl in i. destruct i. destruct p. exists x ; split ; auto. apply InT_cons ; auto.
+    apply InT_or_app. destruct H. destruct p. inversion i ; subst ; auto. right.
+    apply IHl. exists x ; split ; auto.
+  Qed.
+ +
+  Lemma fold_Canopy : forall s leaf, InT leaf (Canopy s) ->
+                  (leaf = s) + (existsT2 prem, InT prem (inv_prems s) * InT leaf (Canopy prem)).
+  Proof.
+  intros. remember (finite_ImpRules_premises_of_S s) as J.
+  destruct J. destruct x.
+  - assert (Canopy s = [s]). apply irred_nil. unfold inv_prems. rewrite <- HeqJ.
+    simpl. auto. rewrite H0 in H. inversion H ; subst ; auto. inversion H2.
+  - right. unfold Canopy in H. rewrite irred_not in H. apply InT_flat_map in H. destruct H.
+    destruct p0. exists x0 ; split ; auto. intro. unfold inv_prems in H0. rewrite <- HeqJ in H0.
+    assert (InT l (l :: x)). apply InT_eq. apply p in H1. destruct H1 ; inversion i ; subst ;
+    simpl in H0 ; inversion H0.
+  Qed.
+ +
+  Lemma Canopy_equiprv : forall s,
+    ((forall leaf, InT leaf (Canopy s) -> KS_prv leaf) -> (KS_prv s)) *
+    ((KS_prv s) -> (forall leaf, InT leaf (Canopy s) -> KS_prv leaf)).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros ; split ; intros.
+  - remember (finite_ImpRules_premises_of_S s) as H.
+    destruct H. destruct x.
+    + assert (Canopy s = [s]). apply irred_nil. unfold inv_prems. rewrite <- HeqH.
+       simpl. auto. rewrite H in X. apply X. apply InT_eq.
+    + assert (J1: InT l (l :: x)). apply InT_eq. apply p in J1. destruct J1 ; unfold KS_prv ; apply derI with (ps:=l).
+       apply ImpR ; auto. 2: apply ImpL ; auto. all: inversion i ; subst ; apply dlCons. 4: apply dlCons. 2,5: apply dlNil.
+       all: apply IHs. 1,3,5: unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       all: intros ; apply X. apply ImpRule_Canopy with (prems:=[(Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)]) (prem:=(Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)) ; auto.
+       apply InT_eq. apply ImpRule_Canopy with (prems:=[(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+       (prem:=(Γ0 ++ Γ1, Δ0 ++ A :: Δ1)) ; auto. apply InT_eq.
+        apply ImpRule_Canopy with (prems:=[(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+       (prem:=(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto. apply InT_cons ; apply InT_eq.
+  - apply fold_Canopy in H. destruct H ; subst ; auto. destruct s0. destruct p.
+    unfold inv_prems in i ; apply InT_flatten_list_InT_elem in i ; destruct i ; destruct p ; destruct (finite_ImpRules_premises_of_S s) ;
+    simpl in i1. apply p in i1. destruct i1 ; inversion i1 ; subst.
+    + inversion i ; subst. 2: inversion H0. apply IHs with (y:=(Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpR_inv with (concl:=(Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)) ; auto.
+    + inversion i ; subst. apply IHs with (y:=(Γ0 ++ Γ1, Δ0 ++ A :: Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpL_inv with (concl:=(Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)) (prem2:= (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto.
+       inversion H0 ; subst. 2: inversion H1. apply IHs with (y:=(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpL_inv with (concl:=(Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)) (prem1:= (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)) ; auto.
+  Qed.
+ +
+  Lemma Canopy_equiprv_genL : forall s A,
+    ((forall leaf, InT leaf (Canopy s) -> KS_prv (A :: fst leaf, snd leaf)) -> (KS_prv (A :: fst s, snd s))) *
+    ((KS_prv (A :: fst s, snd s)) -> (forall leaf, InT leaf (Canopy s) -> KS_prv (A :: fst leaf, snd leaf))).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros ; split ; intros.
+  - remember (finite_ImpRules_premises_of_S s) as H0.
+    destruct H0. destruct x.
+    + assert (Canopy s = [s]). apply irred_nil. unfold inv_prems. rewrite <- HeqH0.
+       simpl. auto. rewrite H in X. apply X. apply InT_eq.
+    + assert (J1: InT l (l :: x)). apply InT_eq. apply p in J1. destruct J1 ; unfold KS_prv ; inversion i ; subst ; simpl.
+       apply derI with (ps:=[(A :: Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1)]).
+       apply ImpR ; auto. assert ((A :: Γ0 ++ A0 :: Γ1) = ((A :: Γ0) ++ A0 :: Γ1)). auto. rewrite H.
+       assert (A :: Γ0 ++ Γ1 = (A :: Γ0) ++ Γ1). auto. rewrite H0. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+       2: apply derI with (ps:=[(A :: Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1);(A :: Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]).
+       2: apply ImpL ; auto. 2: assert (A :: Γ0 ++ Γ1 = ((A :: Γ0) ++ Γ1)) ; auto ; rewrite H.
+       2: assert (A :: Γ0 ++ B :: Γ1 = (A :: Γ0) ++ B :: Γ1) ; auto ; rewrite H0. 2: apply ImpLRule_I. 2: apply dlCons.
+       3: apply dlCons. 4: apply dlNil.
+       assert (J2: n_imp_subformS (Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1) < n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A0 --> B :: Δ1)).
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply IHs with (A:=A) in J2. simpl in J2. destruct J2. apply k. intros. apply X.
+       apply ImpRule_Canopy with (prems:=[(Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1)]) (prem:=(Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1)) ; auto.
+       apply InT_eq.
+       assert (J2: n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1) < n_imp_subformS (Γ0 ++ A0 --> B :: Γ1, Δ0 ++ Δ1)).
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply IHs with (A:=A) in J2. simpl in J2. destruct J2. apply k. intros. apply X.
+       apply ImpRule_Canopy with (prems:=[(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+       (prem:=(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1)) ; auto. apply InT_eq.
+       assert (J2: n_imp_subformS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) < n_imp_subformS (Γ0 ++ A0 --> B :: Γ1, Δ0 ++ Δ1)).
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply IHs with (A:=A) in J2. simpl in J2. destruct J2. apply k. intros. apply X.
+       apply ImpRule_Canopy with (prems:=[(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+       (prem:=(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto. apply InT_cons. apply InT_eq.
+  - apply fold_Canopy in H. destruct H ; subst ; auto. destruct s0. destruct p.
+    unfold inv_prems in i ; apply InT_flatten_list_InT_elem in i ; destruct i ; destruct p ; destruct (finite_ImpRules_premises_of_S s) ;
+    simpl in i1. apply p in i1. destruct i1 ; inversion i1 ; subst.
+    + inversion i ; subst. 2: inversion H0. apply IHs with (y:=(Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpR_inv with (concl:=(A :: Γ0 ++ Γ1, Δ0 ++ A0 --> B :: Δ1)) ; auto. simpl.
+       assert (A :: Γ0 ++ A0 :: Γ1 = (A :: Γ0) ++ A0 :: Γ1). auto. rewrite H.
+       assert (A :: Γ0 ++ Γ1 = (A :: Γ0) ++ Γ1). auto. rewrite H0. apply ImpRRule_I.
+    + inversion i ; subst. apply IHs with (y:=(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpL_inv with (concl:=(A :: Γ0 ++ A0 --> B :: Γ1, Δ0 ++ Δ1)) (prem2:= (A :: Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto. simpl.
+       assert (A :: Γ0 ++ B :: Γ1 = (A :: Γ0) ++ B :: Γ1). auto. rewrite H.
+       assert (A :: Γ0 ++ Γ1 = (A :: Γ0) ++ Γ1). auto. rewrite H0. apply ImpLRule_I.
+       inversion H0 ; subst. 2: inversion H1. apply IHs with (y:=(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpL_inv with (concl:=(A :: Γ0 ++ A0 --> B :: Γ1, Δ0 ++ Δ1)) (prem1:= (A :: Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1)) ; auto. simpl.
+       assert (A :: Γ0 ++ B :: Γ1 = (A :: Γ0) ++ B :: Γ1). auto. rewrite H.
+       assert (A :: Γ0 ++ Γ1 = (A :: Γ0) ++ Γ1). auto. rewrite H1. apply ImpLRule_I.
+  Qed.
+ +
+  Lemma Canopy_equiprv_genR : forall s A,
+    ((forall leaf, InT leaf (Canopy s) -> KS_prv (fst leaf, A :: snd leaf)) -> (KS_prv (fst s, A :: snd s))) *
+    ((KS_prv (fst s, A :: snd s)) -> (forall leaf, InT leaf (Canopy s) -> KS_prv (fst leaf, A :: snd leaf))).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros ; split ; intros.
+  - remember (finite_ImpRules_premises_of_S s) as H0.
+    destruct H0. destruct x.
+    + assert (Canopy s = [s]). apply irred_nil. unfold inv_prems. rewrite <- HeqH0.
+       simpl. auto. rewrite H in X. apply X. apply InT_eq.
+    + assert (J1: InT l (l :: x)). apply InT_eq. apply p in J1. destruct J1 ; unfold KS_prv ; inversion i ; subst ; simpl.
+       apply derI with (ps:=[(Γ0 ++ A0 :: Γ1, A :: Δ0 ++ B :: Δ1)]).
+       apply ImpR ; auto. assert ((A :: Δ0 ++ B :: Δ1) = ((A :: Δ0) ++ B :: Δ1)). auto. rewrite H.
+       assert (A :: Δ0 ++ A0 --> B :: Δ1 = (A :: Δ0) ++ A0 --> B :: Δ1). auto. rewrite H0. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+       2: apply derI with (ps:=[(Γ0 ++ Γ1, A :: Δ0 ++ A0 :: Δ1);(Γ0 ++ B :: Γ1, A :: Δ0 ++ Δ1)]).
+       2: apply ImpL ; auto. 2: assert (A :: Δ0 ++ Δ1 = ((A :: Δ0) ++ Δ1)) ; auto ; rewrite H.
+       2: assert (A :: Δ0 ++ A0 :: Δ1 = (A :: Δ0) ++ A0 :: Δ1) ; auto ; rewrite H0. 2: apply ImpLRule_I. 2: apply dlCons.
+       3: apply dlCons. 4: apply dlNil.
+       assert (J2: n_imp_subformS (Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1) < n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A0 --> B :: Δ1)).
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply IHs with (A:=A) in J2. simpl in J2. destruct J2. apply k. intros. apply X.
+       apply ImpRule_Canopy with (prems:=[(Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1)]) (prem:=(Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1)) ; auto.
+       apply InT_eq.
+       assert (J2: n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1) < n_imp_subformS (Γ0 ++ A0 --> B :: Γ1, Δ0 ++ Δ1)).
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply IHs with (A:=A) in J2. simpl in J2. destruct J2. apply k. intros. apply X.
+       apply ImpRule_Canopy with (prems:=[(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+       (prem:=(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1)) ; auto. apply InT_eq.
+       assert (J2: n_imp_subformS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) < n_imp_subformS (Γ0 ++ A0 --> B :: Γ1, Δ0 ++ Δ1)).
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply IHs with (A:=A) in J2. simpl in J2. destruct J2. apply k. intros. apply X.
+       apply ImpRule_Canopy with (prems:=[(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+       (prem:=(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto. apply InT_cons. apply InT_eq.
+  - apply fold_Canopy in H. destruct H ; subst ; auto. destruct s0. destruct p.
+    unfold inv_prems in i ; apply InT_flatten_list_InT_elem in i ; destruct i ; destruct p ; destruct (finite_ImpRules_premises_of_S s) ;
+    simpl in i1. apply p in i1. destruct i1 ; inversion i1 ; subst.
+    + inversion i ; subst. 2: inversion H0. apply IHs with (y:=(Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpR_inv with (concl:=(Γ0 ++ Γ1, A :: Δ0 ++ A0 --> B :: Δ1)) ; auto. simpl.
+       assert (A :: Δ0 ++ B :: Δ1 = (A :: Δ0) ++ B :: Δ1). auto. rewrite H.
+       assert (A :: Δ0 ++ A0 --> B :: Δ1 = (A :: Δ0) ++ A0 --> B :: Δ1). auto. rewrite H0. apply ImpRRule_I.
+    + inversion i ; subst. apply IHs with (y:=(Γ0 ++ Γ1, Δ0 ++ A0 :: Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpL_inv with (concl:=(Γ0 ++ A0 --> B :: Γ1, A :: Δ0 ++ Δ1)) (prem2:= (Γ0 ++ B :: Γ1, A :: Δ0 ++ Δ1)) ; auto. simpl.
+       assert (A :: Δ0 ++ A0 :: Δ1 = (A :: Δ0) ++ A0 :: Δ1). auto. rewrite H.
+       assert (A :: Δ0 ++ Δ1 = (A :: Δ0) ++ Δ1). auto. rewrite H0. apply ImpLRule_I.
+       inversion H0 ; subst. 2: inversion H1. apply IHs with (y:=(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) ; auto.
+       unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+       apply ImpL_inv with (concl:=(Γ0 ++ A0 --> B :: Γ1, A :: Δ0 ++ Δ1)) (prem1:= (Γ0 ++ Γ1, A :: Δ0 ++ A0 :: Δ1)) ; auto. simpl.
+       assert (A :: Δ0 ++ A0 :: Δ1 = (A :: Δ0) ++ A0 :: Δ1). auto. rewrite H.
+       assert (A :: Δ0 ++ Δ1 = (A :: Δ0) ++ Δ1). auto. rewrite H1. apply ImpLRule_I.
+  Qed.
+ +
+  Lemma Canopy_hp_inv_ctx : forall s k scomp (D0 : KS_prv scomp) X0 Y0,
+        k = (derrec_height D0) ->
+        scomp = (fst s ++ X0, snd s ++ Y0) ->
+        (forall leaf, InT leaf (Canopy s) -> existsT2 (D1: KS_prv (fst leaf ++ X0, snd leaf ++ Y0)),
+                                                                                derrec_height D1 <= k).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros. apply fold_Canopy in H1. destruct H1.
+  - subst. exists D0 ; auto.
+  - destruct s0 ; destruct p. unfold inv_prems in i. apply InT_flatten_list_InT_elem in i. destruct i.
+    destruct p. destruct (finite_ImpRules_premises_of_S s). simpl in i1. subst.
+    assert (J0: derrec_height D0 = derrec_height D0). auto.
+    pose (ImpR_ImpL_hpinv _ _ D0 J0). destruct p0. apply p in i1. destruct i1.
+    + inversion i1 ; subst. simpl in s0.
+       assert (J1: ImpRRule [(Γ0 ++ A :: (Γ1 ++ X0), Δ0 ++ B :: (Δ1 ++ Y0))] ((Γ0 ++ Γ1) ++ X0, (Δ0 ++ A --> B :: Δ1) ++ Y0)).
+       repeat rewrite <- app_assoc ; apply ImpRRule_I. apply s0 in J1. destruct J1. inversion i ; subst.
+       assert (J2: n_imp_subformS (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) < n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)).
+       unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+       lia.
+       assert (J3: derrec_height x0 = derrec_height x0). auto.
+       assert (J4: (Γ0 ++ A :: Γ1 ++ X0, Δ0 ++ B :: Δ1 ++ Y0) = (fst (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) ++ X0, snd (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) ++ Y0)).
+       simpl ; repeat rewrite <- app_assoc ; auto.
+       pose (IHs _ J2 _ _ x0 X0 Y0 J3 J4 _ i0). destruct s. exists x. apply PeanoNat.Nat.le_trans with (m:=derrec_height x0) ; auto.
+       inversion H0.
+    + inversion i1 ; subst. simpl in s1. clear s0.
+       assert (J1: ImpLRule [(Γ0 ++ Γ1 ++ X0, Δ0 ++ A :: Δ1 ++ Y0); (Γ0 ++ B :: Γ1 ++ X0, Δ0 ++ Δ1 ++ Y0)] ((Γ0 ++ A --> B :: Γ1) ++ X0, (Δ0 ++ Δ1) ++ Y0)).
+       repeat rewrite <- app_assoc ; apply ImpLRule_I. apply s1 in J1. destruct J1. destruct s. destruct p0. inversion i ; subst.
+       assert (J2: n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+       unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+       lia.
+       assert (J3: derrec_height x0 = derrec_height x0). auto.
+       assert (J4: (Γ0 ++ Γ1 ++ X0, Δ0 ++ A :: Δ1 ++ Y0) = (fst (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) ++ X0, snd (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) ++ Y0)).
+       simpl ; repeat rewrite <- app_assoc ; auto.
+       pose (IHs _ J2 _ _ x0 X0 Y0 J3 J4 _ i0). destruct s. exists x. apply PeanoNat.Nat.le_trans with (m:=derrec_height x0) ; auto.
+       inversion H0 ; subst.
+       assert (J2: n_imp_subformS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+       unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+       lia.
+       assert (J3: derrec_height x2 = derrec_height x2). auto.
+       assert (J4: (Γ0 ++ B :: Γ1 ++ X0, Δ0 ++ Δ1 ++ Y0) = (fst (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) ++ X0, snd (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) ++ Y0)).
+       simpl ; repeat rewrite <- app_assoc ; auto.
+       pose (IHs _ J2 _ _ x2 X0 Y0 J3 J4 _ i0). destruct s. exists x. apply PeanoNat.Nat.le_trans with (m:=derrec_height x2) ; auto.
+       inversion H1.
+  Qed.
+ +
+  Lemma Canopy_neg_var : forall s q, InT (# q) (fst s) -> (forall leaf, InT leaf (Canopy s) -> InT (# q) (fst leaf)).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros. apply fold_Canopy in H0. destruct H0 ; subst ; auto.
+  destruct s0 ; destruct p. unfold inv_prems in i. apply InT_flatten_list_InT_elem in i. destruct i.
+  destruct p. destruct (finite_ImpRules_premises_of_S s). simpl in i1. subst.
+  apply p in i1. destruct i1.
+  - inversion i1 ; subst. inversion i ; subst. 2: inversion H1.
+    assert (J0: n_imp_subformS (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) < n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)).
+     unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+     lia.
+    apply IHs with (q:= q) (leaf:=leaf) in J0 ; auto. simpl. apply InT_or_app. simpl in H. apply InT_app_or in H ; destruct H ; auto.
+    right ; apply InT_cons ; auto.
+  - inversion i1 ; subst. inversion i ; subst. 2: inversion H1. 3: inversion H2.
+    assert (J0: n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+     unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+     lia.
+    apply IHs with (q:= q) (leaf:=leaf) in J0 ; auto. simpl. apply InT_or_app. simpl in H. apply InT_app_or in H ; destruct H ; auto.
+    inversion i2 ; subst. inversion H0. auto. subst.
+    assert (J0: n_imp_subformS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+     unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+     lia.
+    apply IHs with (q:= q) (leaf:=leaf) in J0 ; auto. simpl. apply InT_or_app. simpl in H. apply InT_app_or in H ; destruct H ; auto.
+    inversion i2 ; subst. inversion H0. right ; apply InT_cons ; auto.
+  Qed.
+ +
+  Lemma Canopy_pos_var : forall s q, InT (# q) (snd s) -> (forall leaf, InT leaf (Canopy s) -> InT (# q) (snd leaf)).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros. apply fold_Canopy in H0. destruct H0 ; subst ; auto.
+  destruct s0 ; destruct p. unfold inv_prems in i. apply InT_flatten_list_InT_elem in i. destruct i.
+  destruct p. destruct (finite_ImpRules_premises_of_S s). simpl in i1. subst.
+  apply p in i1. destruct i1.
+  - inversion i1 ; subst. inversion i ; subst. 2: inversion H1.
+    assert (J0: n_imp_subformS (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) < n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)).
+     unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+     lia.
+    apply IHs with (q:= q) (leaf:=leaf) in J0 ; auto. simpl. apply InT_or_app. simpl in H. apply InT_app_or in H ; destruct H ; auto.
+    inversion i2 ; subst. inversion H0. right ; apply InT_cons ; auto.
+  - inversion i1 ; subst. inversion i ; subst. 2: inversion H1. 3: inversion H2.
+    assert (J0: n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+     unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+     lia.
+    apply IHs with (q:= q) (leaf:=leaf) in J0 ; auto. simpl. apply InT_or_app. simpl in H. apply InT_app_or in H ; destruct H ; auto.
+    right ; apply InT_cons ; auto. subst.
+    assert (J0: n_imp_subformS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+     unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+     lia.
+    apply IHs with (q:= q) (leaf:=leaf) in J0 ; auto.
+  Qed.
+ +
+  Lemma Id_InT_Canopy : forall s, InT s (Canopy s) -> Canopy s = [s].
+  Proof.
+  intros. destruct (critical_Seq_dec s).
+  - remember (finite_ImpRules_premises_of_S s) as J.
+    destruct J. destruct x.
+    + apply irred_nil. unfold inv_prems. rewrite <- HeqJ.
+       simpl. auto.
+    + exfalso. assert (J1: InT l (l :: x)). apply InT_eq. apply p in J1. unfold critical_Seq in c.
+       destruct J1 ; inversion i ; subst ; simpl in c.
+       assert (In (A --> B) ((Γ0 ++ Γ1) ++ Δ0 ++ A --> B :: Δ1)). apply in_or_app ; right ; apply in_or_app ; right ; apply in_eq.
+       apply c in H0. destruct H0. destruct H0. inversion H0. destruct H0. destruct H0 ; inversion H0. inversion H0.
+       assert (In (A --> B) ((Γ0 ++ A --> B :: Γ1) ++ Δ0 ++ Δ1)). apply in_or_app ; left ; apply in_or_app ; right ; apply in_eq.
+       apply c in H0. destruct H0. destruct H0. inversion H0. destruct H0. destruct H0 ; inversion H0. inversion H0.
+  - exfalso. apply Canopy_critical in H. auto.
+  Qed.
+ +
+  Lemma critical_Seq_InT_Canopy : forall s, critical_Seq s -> InT s (Canopy s).
+  Proof.
+  intros. remember (finite_ImpRules_premises_of_S s) as J.
+  destruct J. destruct x.
+  + pose irred_nil. unfold Canopy. rewrite e. apply InT_eq. unfold inv_prems. rewrite <- HeqJ.
+     simpl. auto.
+  + exfalso. assert (J1: InT l (l :: x)). apply InT_eq. apply p in J1. unfold critical_Seq in H.
+     destruct J1 ; inversion i ; subst ; simpl in H.
+     assert (In (A --> B) ((Γ0 ++ Γ1) ++ Δ0 ++ A --> B :: Δ1)). apply in_or_app ; right ; apply in_or_app ; right ; apply in_eq.
+     apply H in H0. destruct H0. destruct H0. inversion H0. destruct H0. destruct H0 ; inversion H0. inversion H0.
+     assert (In (A --> B) ((Γ0 ++ A --> B :: Γ1) ++ Δ0 ++ Δ1)). apply in_or_app ; left ; apply in_or_app ; right ; apply in_eq.
+     apply H in H0. destruct H0. destruct H0. inversion H0. destruct H0. destruct H0 ; inversion H0. inversion H0.
+  Qed.
+
+
+ +
+ + + diff --git a/K.Interpolation.UIK_Def_measure.html b/K.Interpolation.UIK_Def_measure.html new file mode 100644 index 0000000..00c0f5e --- /dev/null +++ b/K.Interpolation.UIK_Def_measure.html @@ -0,0 +1,163 @@ + + + + + + + + + + + + + +
+
+

K.Interpolation.UIK_Def_measure

+ +
+(* Modification of the following file. *)
+ +
+(**************************************************************)
+(*   Copyright Dominique Larchey-Wendling *                 *)
+(*                                                            *)
+(*                             * Affiliation LORIA -- CNRS  *)
+(**************************************************************)
+(*      This file is distributed under the terms of the       *)
+(*         CeCILL v2 FREER SOFTWARE LICENSE AGREEMENT         *)
+(**************************************************************)
+ +
+Require Import List Arith Wellfounded.
+Import ListNotations.
+ +
+Set Implicit Arguments.
+ +
+Section measure_rect.
+ +
+  Variable (X : Type) (m : X -> nat) (P : X -> Type).
+ +
+  Hypothesis F : forall x, (forall y, m y < m x -> P y) -> P x.
+ +
+  Definition measure_rect x : P x.
+  Proof.
+    cut (Acc (fun x y => m x < m y) x); [ revert x | ].
+    + refine (
+        fix loop x Dx := @F x (fun y Dy => loop y _)
+      ).
+      apply (Acc_inv Dx), Dy.
+    + apply wf_inverse_image with (f := m), lt_wf.
+  Qed.
+ +
+End measure_rect.
+ +
+Tactic Notation "induction" "on" hyp(x) "as" ident(IH) "with" "measure" uconstr(f) :=
+  pattern x; revert x; apply measure_rect with (m := fun x => f); intros x IH.
+ +
+Section lex_wf.
+ +
+  Variable (X : Type) (R : X -> X -> Prop) (Rwf : well_founded R).
+ +
+  Reserved Notation "l '<lex' m" (at level 70). (* for lexicographic product *)
+ +
+  Inductive lex : list X -> list X -> Prop :=
+    | lex_skip x l m : l <lex m -> x::l <lex x::m
+    | lex_cons x y l m : length l = length m -> R x y -> x::l <lex y::m
+  where "l <lex m" := (lex l m).
+ +
+  Fact lex_length l m : l <lex m -> length l = length m.
+  Proof. induction 1; simpl; auto. Qed.
+ +
+  Fact lex_cons_inv l m :
+          l <lex m
+       -> match m with
+            | [] => False
+            | y::m =>
+            match l with
+              | [] => False
+              | x::l => x = y /\ lex l m
+                     \/ R x y /\ length l = length m
+            end
+          end.
+  Proof. inversion 1; auto. Qed.
+ +
+  Theorem lex_wf : well_founded lex.
+  Proof.
+    intros m; induction on m as IHm with measure (length m).
+    destruct m as [ | y m ].
+    + constructor; intros l Hl; apply lex_cons_inv in Hl; easy.
+    + revert m IHm.
+      induction y as [ y IHy' ] using (well_founded_induction Rwf).
+      intros m IHm.
+      assert (Acc lex m) as Hm.
+      1: apply IHm; simpl; auto.
+      assert (forall x l, R x y -> length l = length m -> Acc lex (x::l)) as IHy.
+      1: { intros x l Hx Hl; apply IHy'; auto.
+           intros; apply IHm.
+           simpl in *; rewrite <- Hl; auto. }
+      clear IHy' IHm.
+      revert Hm IHy.
+      induction 1 as [ m Hm IHm ]; intros IHy.
+      constructor; intros l Hl; apply lex_cons_inv in Hl.
+      destruct l as [ | x l ]; try tauto.
+      destruct Hl as [ (-> & Hl) | (Hx & Hl) ].
+      * apply IHm; auto.
+        apply lex_length in Hl as ->; auto.
+      * apply IHy; auto.
+  Qed.
+ +
+  Section lex_rect.
+ +
+    Variable (P : list X -> Type) (HP : forall m, (forall l, lex l m -> P l) -> P m).
+ +
+    Corollary lex_rect m : P m.
+    Proof.
+      induction m as [ m IHm ] using (well_founded_induction_type lex_wf).
+      apply HP; intros; apply IHm. auto.
+    Qed.
+ +
+  End lex_rect.
+ +
+End lex_wf.
+
+
+ +
+ + + diff --git a/K.Interpolation.UIK_UIOne.html b/K.Interpolation.UIK_UIOne.html new file mode 100644 index 0000000..9d2bbf9 --- /dev/null +++ b/K.Interpolation.UIK_UIOne.html @@ -0,0 +1,166 @@ + + + + + + + + + + + + + +
+
+

K.Interpolation.UIK_UIOne

+ +
+(* First property of uniform interpolation *)
+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat Arith.
+Require Import Lia.
+Require Import String.
+ +
+Require Import general_export.
+ +
+Require Import KS_export.
+ +
+Require Import UIK_Def_measure.
+Require Import UIK_Canopy.
+Require Import UIK_irred_short.
+Require Import UIK_braga.
+Require Import UIK_UI_prelims.
+ +
+  Section UIPOne.
+ +
+  (* The formula defined by the function UI satisfies all the properties of
+      uniform interpolation. *)

+ +
+  Theorem UI_One : forall s p q, In (# q) (propvar_subform (UI p (fst s, snd s))) ->
+                                                      ((q <> p) * (In (# q) (propvar_subform_list (fst s ++ snd s)))).
+  Proof.
+  intro s. remember (measure s) as n. revert Heqn. revert s. revert n.
+  induction n as [n IH] using (well_founded_induction_type lt_wf).
+  intros s Heqn p q H0. rewrite propvar_subform_list_app.
+  destruct (empty_seq_dec s).
+  (* s is the empty sequent. *)
+  { subst ; simpl in *. assert (H : GUI p ([],[]) Bot) by (apply GUI_empty_seq ; auto). apply UI_GUI in H.
+    rewrite H in *. simpl in H0. inversion H0. }
+  (* s is not the empty sequent. *)
+  { destruct (critical_Seq_dec s).
+  (* s is a critical sequent *)
+  - destruct (dec_KS_init_rules s).
+    (* s is an initial sequent *)
+    + assert (is_init s) ; auto.
+       assert (H1 : GUI p s Top) by (apply GUI_critic_init ; auto). apply UI_GUI in H1.
+       destruct s. simpl in H0. rewrite H1 in H0. simpl in H0. inversion H0.
+    (* s is not an initial sequent *)
+    + remember (fst s) as LHS.
+       assert (H1 : GUI p s
+       (Or (list_disj (restr_list_prop p (snd s)))
+       (Or (list_disj (map Neg (restr_list_prop p (fst s))))
+       (Or (list_disj (map Box (map (UI p) (KR_prems s))))
+       (Diam (UI p (unboxed_list (top_boxes (fst s)), []%list))))))).
+       apply GUI_critic_not_init ; auto. apply Gimap_map ; intros. 1-2: apply UI_GUI ; auto.
+       destruct s. simpl in *. apply UI_GUI in H1. simpl in HeqLHS. subst. rewrite H1 in H0. simpl in H0.
+       repeat rewrite app_nil_r in H0. clear H1.
+       apply in_app_or in H0. destruct H0 as [H0 | H0].
+ +
+       apply propvar_subform_list_disj in H0.
+       apply propvar_subform_list_restr_list_prop in H0. destruct H0 ; split ; auto. apply in_or_app ; auto.
+ +
+       apply in_app_or in H0 ; destruct H0 as [H0 | H0]. apply propvar_subform_list_disj in H0. apply propvar_subform_list_witness in H0.
+       destruct H0. destruct H. apply in_map_iff in H. destruct H. destruct H ; subst. simpl in H0.
+       rewrite app_nil_r in H0. unfold restr_list_prop in H1. apply in_remove in H1. destruct H1.
+       pose (In_list_prop_LF _ _ H). destruct p0. destruct s. subst. simpl in H0. destruct H0. inversion H0. subst.
+       destruct (string_dec q p). exfalso ; apply H1 ; subst ; auto. split ; auto. apply in_or_app ; left.
+       apply list_prop_LF_propvar_subform_list in H ; auto. inversion H0.
+ +
+       apply in_app_or in H0 ; destruct H0. apply propvar_subform_list_disj in H. apply propvar_subform_list_witness in H.
+       destruct H. destruct H. apply in_map_iff in H. destruct H. destruct H ; subst. simpl in H0.
+       apply in_map_iff in H1. destruct H1. destruct H ; subst. assert (In # q (propvar_subform (UI p (fst x, snd x)))).
+       destruct x ; auto.
+       unfold KR_prems in H1. destruct (finite_KR_premises_of_S (l, l0)). simpl in H1.
+       apply In_InT_seqs in H1. apply InT_flatten_list_InT_elem in H1. destruct H1. destruct p1.
+       apply p0 in i0. inversion i0 ; subst. inversion i ; subst. 2: inversion X0. simpl in H. repeat rewrite propvar_subform_list_app.
+       simpl ; repeat rewrite propvar_subform_list_app.
+       assert (J0: measure (unboxed_list , [A]) < measure (l, Δ0 ++ Box A :: Δ1)).
+       unfold measure. simpl. repeat rewrite size_LF_dist_app. simpl.
+       pose (size_nobox_gen_ext _ _ X). simpl in l.
+       pose (size_unboxed ). lia.
+       assert (J1: measure (unboxed_list , [A]) = measure (unboxed_list , [A])). auto.
+       pose (IH _ J0 _ J1 _ _ H0). destruct p1. split ; auto. simpl in i1.
+       rewrite propvar_subform_list_app in i1. apply in_app_or in i1. destruct i1.
+       apply in_or_app ; left. apply propvar_subform_list_unboxed_list in H1.
+       pose (propvar_subform_list_nobox_gen_ext _ _ X). simpl in i1. apply i1 ; auto.
+       simpl in H1. rewrite app_nil_r in H1.
+       apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+ +
+       destruct l ; subst ; simpl in *.
+       { assert (GUI p ([],[]) Bot). apply GUI_empty_seq ; auto. apply UI_GUI in H0.
+         rewrite H0 in *. simpl in H. inversion H. }
+       { assert (J0: measure (unboxed_list (top_boxes (m :: l)), []%list) < measure (m :: l, l0)).
+         unfold measure. simpl. destruct m ; simpl.
+         1-4: pose (size_unboxed (top_boxes l)) ; pose (size_top_boxes l) ; lia.
+         assert (J1: measure (unboxed_list (top_boxes (m :: l)), []%list) = measure (unboxed_list (top_boxes (m :: l)), []%list)). auto.
+         pose (IH _ J0 _ J1). simpl in p0. pose (p0 _ _ H). destruct p1. split ; auto. simpl in i. clear p0.
+         rewrite propvar_subform_list_app in i. apply in_app_or in i. destruct i.
+         apply in_or_app ; left. apply propvar_subform_list_unboxed_list in H0.
+         apply in_or_app. destruct m ; simpl in H0 ; auto.
+         1-3: right ; apply propvar_subform_list_top_boxes ; auto. simpl.
+         apply in_app_or in H0 ; destruct H0 ; auto. right. apply propvar_subform_list_top_boxes ; auto.
+         simpl in H0. inversion H0. }
+  (* s is not a critical sequent *)
+  - assert (H1 : GUI p s (list_conj (map (UI p) (Canopy s)))). apply GUI_not_critic ; auto.
+    apply Gimap_map ; intros ; apply UI_GUI ; auto. apply UI_GUI in H1. destruct s.
+    simpl in H0. rewrite H1 in H0. apply propvar_subform_list_conj in H0.
+    apply propvar_subform_list_witness in H0. destruct H0 as [s [H0 H3]].
+    apply in_map_iff in H0.
+    destruct H0 as [x0 H0]. destruct H0 as [H0 Hc]; subst. simpl.
+    assert (H2 : In # q (propvar_subform (UI p (fst x0, snd x0)))) by (destruct x0 ; auto).
+    pose (i := In_InT_seqs _ _ Hc). apply Canopy_measure in i. destruct i ; subst.
+    simpl in *. exfalso. apply f. apply In_InT_seqs in Hc ; apply Canopy_critical in Hc ; auto.
+    assert (measure x0 = measure x0) ; auto.
+    pose (IH _ l1 _ H _ _ H2). destruct p0 ; split ; auto.
+    apply propvar_subform_list_Canopy with (A:=# q) in Hc ; auto.
+    simpl in H3 ; rewrite propvar_subform_list_app in Hc ; auto. }
+  Qed.
+ +
+  End UIPOne.
+
+
+ +
+ + + diff --git a/K.Interpolation.UIK_UIThree.html b/K.Interpolation.UIK_UIThree.html new file mode 100644 index 0000000..4ba853f --- /dev/null +++ b/K.Interpolation.UIK_UIThree.html @@ -0,0 +1,709 @@ + + + + + + + + + + + + + +
+
+

K.Interpolation.UIK_UIThree

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat Arith.
+Require Import Lia.
+ +
+Require Import general_export.
+ +
+Require Import KS_export.
+ +
+Require Import UIK_Def_measure.
+Require Import UIK_Canopy.
+Require Import UIK_irred_short.
+Require Import UIK_braga.
+Require Import UIK_UI_prelims.
+ +
+  Section UIPThree.
+ +
+  Theorem UI_Three : forall s p X0 Y0,
+                                    (In (Var p) (propvar_subform_list (X0 ++ Y0)) -> False) ->
+                                    KS_prv (fst s ++ X0, snd s ++ Y0) ->
+                                    KS_prv (X0, (UI p s) :: Y0).
+  Proof.
+  (* Setting up the strong induction on the height of the derivation (PIH) and
+      on the measure of the sequent using LexSeq (SIH). *)

+  intros s p X0 Y0 NotVar D. generalize dependent NotVar. remember (fst s ++ X0, snd s ++ Y0) as scomp.
+  generalize dependent Heqscomp. remember (derrec_height D) as n. generalize dependent Heqn.
+  generalize dependent Y0. generalize dependent X0. generalize dependent D.
+  generalize dependent scomp. generalize dependent s. generalize dependent n.
+  induction n as [n PIH] using (well_founded_induction_type lt_wf).
+  intro s. remember (measure s) as m. revert Heqm. revert s. revert m.
+  induction m as [m SIH] using (well_founded_induction_type lt_wf).
+  intros k Heqm.
+ +
+  (* Now we do the actual proof-theoretical work. *)
+  intros s0 D0. remember D0 as D0'. destruct D0.
+  (* D0 is a leaf *)
+  - inversion f.
+  (* D0 ends with an application of rule *)
+  - intros X0 Y0 hei idseq propvar. destruct (empty_seq_dec k) as [ EE | NE].
+    { subst ; simpl in *.
+       assert (J1: KS_prv (X0, Y0)). apply derI with ps ; auto.
+       pose (KS_hpadm_wkn_R _ J1 (X0, UI p ([], []) :: Y0) (UI p ([],[]))). destruct s ; auto.
+       apply (wkn_RI _ _ []). }
+    { inversion k0 ; subst.
+    (* IdP *)
+    * inversion H ; subst.
+      assert (InT (# P) (fst k ++ X0)). rewrite <- H2. apply InT_or_app ; right ; apply InT_eq.
+      apply InT_app_or in H0.
+      assert (InT (# P) (snd k ++ Y0)). rewrite <- H3. apply InT_or_app ; right ; apply InT_eq.
+      apply InT_app_or in H1. destruct H0 ; destruct H1.
+      + assert ((X0, UI p k :: Y0) = (X0, [] ++ UI p k :: Y0)). auto. rewrite H0. apply is_init_UI.
+         left. destruct k. simpl in i ; simpl in i0. apply InT_split in i. destruct i. destruct s ; subst.
+         apply InT_split in i0. destruct i0. destruct s ; subst. apply IdPRule_I.
+      + destruct (critical_Seq_dec k).
+         -- destruct (dec_KS_init_rules k).
+            ** assert (is_init k) ; auto. assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+                pose (@GUI_inv_critic_init p k _ J0 c X). rewrite <- e.
+                assert ((X0, Top :: Y0) = (X0, [] ++ Top :: Y0)). auto. rewrite H0. apply TopR.
+            ** assert ((is_init k) -> False) ; auto. assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+                assert (J1: Gimap (GUI p) (KR_prems k) (map (UI p) (KR_prems k))). apply Gimap_map. intros.
+                apply UI_GUI ; auto.
+                assert (k <> ([],[])). intro. rewrite H1 in i. inversion i.
+                assert (J2: GUI p (unboxed_list (top_boxes (fst k)), []) (UI p (unboxed_list (top_boxes (fst k)), []))). apply UI_GUI ; auto.
+                pose (@GUI_inv_critic_not_init p k _ _ _ J0 c H1 H0 J1 J2). rewrite <- e.
+                pose (OrR (X0,Y0)). simpl in k1. apply k1.
+                apply (@KS_adm_list_exch_R (X0,
+                Or (list_disj (map Neg (restr_list_prop p (fst k))))
+                   (Or (list_disj (map Box (map (UI p) (KR_prems k))))
+                      (Diam (UI p (unboxed_list (top_boxes (fst k)), []%list))))
+                 :: list_disj (restr_list_prop p (snd k)) :: Y0)).
+                2: epose (list_exch_RI _ [] [Or (list_disj (map Neg (restr_list_prop p (fst k)))) (Or (list_disj (map Box (map (UI p) (KR_prems k))))
+                (Diam (UI p (unboxed_list (top_boxes (fst k)), []%list))))] [] [list_disj (restr_list_prop p (snd k))] Y0) ; simpl in l ; apply l.
+                pose (OrR (X0,list_disj (restr_list_prop p (snd k)) :: Y0)). simpl in k2. apply k2.
+                assert (J3: InT (Neg # P) (map Neg (restr_list_prop p (fst k)))). unfold restr_list_prop. apply InT_map_iff.
+                exists (# P) ; split ; auto. apply In_InT. apply in_not_touched_remove. apply In_list_In_list_prop_LF ; apply InT_In ; auto.
+                intro. apply propvar. rewrite <- H4. rewrite propvar_subform_list_app. apply in_or_app ; right.
+                apply In_list_In_propvar_subform_list ; apply InT_In ; auto.
+                remember (Or (list_disj (map Box (map (UI p) (KR_prems k)))) (Diam (UI p (unboxed_list (top_boxes (fst k)), []%list)))
+                 :: list_disj (restr_list_prop p (snd k)) :: Y0) as Y.
+                pose (list_disj_wkn_R (map Neg (restr_list_prop p (fst k))) (X0, Y) (Neg # P) J3). apply k3. simpl.
+                unfold Neg. apply derI with (ps:=[([] ++ # P :: X0, [] ++ Bot :: Y)]). apply ImpR. assert ((X0, # P --> Bot :: Y) = ([] ++ X0, [] ++ # P --> Bot :: Y)).
+                auto. rewrite H4. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+                assert (InT (# P) ([] ++ Bot :: Y)). simpl. apply InT_cons. rewrite HeqY. repeat apply InT_cons ; auto.
+                apply InT_split in H4. destruct H4. destruct s. rewrite e0. apply derI with (ps:=[]). apply IdP. apply IdPRule_I.
+                apply dlNil.
+         -- assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+            assert (J1: Gimap (GUI p) (Canopy k) (map (UI p) (Canopy k))). apply Gimap_map. intros.
+            apply UI_GUI ; auto.
+            pose (@GUI_inv_not_critic p k _ _ J0 f J1). rewrite <- e.
+            pose (list_conj_R (map (UI p) (Canopy k)) (X0,Y0)). simpl in k1. apply k1. intros.
+            apply InT_map_iff in H0. destruct H0. destruct p0. subst.
+            assert (measure x < measure k). pose (Canopy_measure _ _ i1). destruct s ; subst ; auto. exfalso.
+            apply f ; apply Canopy_critical in i1 ; auto. simpl in SIH.
+            assert (J2: KS_rules [] (fst x ++ X0, snd x ++ Y0)).
+            apply IdP. assert (InT (# P) (snd x ++ Y0)). apply InT_or_app ; auto. apply InT_split in H1.
+            destruct H1. destruct s. rewrite e0. assert (InT (# P) (fst x ++ X0)). apply InT_or_app ; left.
+            apply Canopy_neg_var with (q:=P) in i1 ; auto. apply InT_split in H1. destruct H1. destruct s. rewrite e1.
+            apply IdPRule_I. pose (derI _ J2 d).
+            assert (J3: S (dersrec_height d) = derrec_height d0). simpl. lia.
+            assert (J4: (fst x ++ X0, snd x ++ Y0) = (fst x ++ X0, snd x ++ Y0)). auto.
+            assert (J5 : measure x = measure x). auto.
+            pose (SIH _ H0 _ J5 _ _ _ _ J3 J4 propvar). auto.
+      + destruct (critical_Seq_dec k).
+         -- destruct (dec_KS_init_rules k).
+            ** assert (is_init k) ; auto. assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+                pose (@GUI_inv_critic_init p k _ J0 c X). rewrite <- e.
+                assert ((X0, Top :: Y0) = (X0, [] ++ Top :: Y0)). auto. rewrite H0. apply TopR.
+            ** assert ((is_init k) -> False) ; auto. assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+                assert (J1: Gimap (GUI p) (KR_prems k) (map (UI p) (KR_prems k))). apply Gimap_map. intros.
+                apply UI_GUI ; auto.
+                assert (J2: GUI p (unboxed_list (top_boxes (fst k)), []) (UI p (unboxed_list (top_boxes (fst k)), []))). apply UI_GUI ; auto.
+                remember (fst k) as LHS. destruct LHS.
+                ++ pose (@GUI_inv_critic_not_init p k _ (UI p (unboxed_list (top_boxes []), [])) _ J0 c NE H0 J1).
+                      simpl in e. rewrite <- HeqLHS in *. apply e in J2. rewrite <- J2. simpl in *.
+                      assert (GUI p ([],[]) Bot). apply GUI_empty_seq ; auto. apply UI_GUI in H1. rewrite H1 in *.
+                      pose (OrR (X0,Y0)). simpl in k1. apply k1.
+                      assert (J3: InT (# P) (restr_list_prop p (snd k))). unfold restr_list_prop. apply In_InT.
+                      apply in_not_touched_remove. apply In_list_In_list_prop_LF ; apply InT_In ; auto.
+                      intro. apply propvar. rewrite <- H4. rewrite propvar_subform_list_app. apply in_or_app ; left.
+                      apply In_list_In_propvar_subform_list ; apply InT_In ; auto.
+                      remember (Or (Or (list_disj (map Box (map (UI p) (KR_prems k)))) (Diam )) :: Y0) as Y.
+                      pose (list_disj_wkn_R (restr_list_prop p (snd k)) (X0, Y) (# P) J3). apply k2. simpl.
+                      apply InT_split in i. destruct i. destruct s. rewrite e0. apply derI with (ps:=[]). apply IdP. 2: apply dlNil.
+                      assert ((x ++ # P :: x0, # P :: Y) = (x ++ # P :: x0, [] ++ # P :: Y)). auto. rewrite H4 ; apply IdPRule_I.
+                ++ assert (J4 : fst k <> []). intro. rewrite H1 in HeqLHS. inversion HeqLHS. rewrite HeqLHS in J2.
+                      pose (@GUI_inv_critic_not_init p k _ _ _ J0 c NE H0 J1 J2). rewrite <- e.
+                      pose (OrR (X0,Y0)). simpl in k1. apply k1.
+                      assert (J3: InT (# P) (restr_list_prop p (snd k))). unfold restr_list_prop. apply In_InT.
+                      apply in_not_touched_remove. apply In_list_In_list_prop_LF ; apply InT_In ; auto.
+                      intro. apply propvar. rewrite <- H1. rewrite propvar_subform_list_app. apply in_or_app ; left.
+                      apply In_list_In_propvar_subform_list ; apply InT_In ; auto.
+                      remember (Or (list_disj (map Neg (restr_list_prop p (fst k)))) (Or (list_disj (map Box (map (UI p) (KR_prems k)))) (Diam
+                      (UI p (unboxed_list (top_boxes (fst k)), []%list)))) :: Y0) as Y.
+                      pose (list_disj_wkn_R (restr_list_prop p (snd k)) (X0, Y) (# P) J3). apply k2. simpl.
+                      apply InT_split in i. destruct i. destruct s. rewrite e0. apply derI with (ps:=[]). apply IdP. 2: apply dlNil.
+                      assert ((x ++ # P :: x0, # P :: Y) = (x ++ # P :: x0, [] ++ # P :: Y)). auto. rewrite H1 ; apply IdPRule_I.
+         -- assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+            assert (J1: Gimap (GUI p) (Canopy k) (map (UI p) (Canopy k))). apply Gimap_map. intros.
+            apply UI_GUI ; auto.
+            pose (@GUI_inv_not_critic p k _ _ J0 f J1). rewrite <- e.
+            pose (list_conj_R (map (UI p) (Canopy k)) (X0,Y0)). simpl in k1. apply k1. intros.
+            apply InT_map_iff in H0. destruct H0. destruct p0. subst.
+            assert (measure x < measure k). pose (Canopy_measure _ _ i1). destruct s ; subst ; auto. exfalso.
+            apply f ; apply Canopy_critical in i1 ; auto. simpl in SIH.
+            assert (J2: KS_rules [] (fst x ++ X0, snd x ++ Y0)).
+            apply IdP. assert (InT (# P) (fst x ++ X0)). apply InT_or_app ; auto. apply InT_split in H1.
+            destruct H1. destruct s. rewrite e0. assert (InT (# P) (snd x ++ Y0)). apply InT_or_app ; left.
+            apply Canopy_pos_var with (q:=P) in i1 ; auto. apply InT_split in H1. destruct H1. destruct s. rewrite e1.
+            apply IdPRule_I. pose (derI _ J2 d).
+            assert (J3: S (dersrec_height d) = derrec_height d0). simpl. lia.
+            assert (J4: (fst x ++ X0, snd x ++ Y0) = (fst x ++ X0, snd x ++ Y0)). auto.
+            assert (J5: measure x = measure x). auto.
+            pose (SIH _ H0 _ J5 _ _ _ _ J3 J4 propvar). auto.
+      + apply derI with (ps:=[]). 2: apply dlNil. apply IdP. apply InT_split in i. destruct i. destruct s ; subst.
+         apply InT_split in i0. destruct i0. destruct s ; subst. assert (UI p k :: x1 ++ # P :: x2 = (UI p k :: x1) ++ # P :: x2).
+         auto. rewrite H0. apply IdPRule_I.
+ +
+    (* BotL *)
+    * inversion H ; subst.
+      assert (InT Bot (fst k ++ X0)). rewrite <- H2. apply InT_or_app ; right ; apply InT_eq.
+      apply InT_app_or in H0. destruct H0.
+      + assert ((X0, UI p k :: Y0) = (X0, [] ++ UI p k :: Y0)). auto. rewrite H0. apply is_init_UI.
+         right. destruct k. simpl in i. apply InT_split in i. destruct i. destruct s ; subst. apply BotLRule_I.
+      + apply derI with (ps:=[]). 2: apply dlNil. apply BotL. apply InT_split in i. destruct i. destruct s ; subst.
+         apply BotLRule_I.
+ +
+    (* ImpR *)
+    * destruct (critical_Seq_dec k).
+      (* If critical, then the rule ImpR was applied on a formula in X0 or Y0.
+          So, apply PIH omn the premise and then the rule. *)

+      + inversion H ; subst. assert (J0: dersrec_height d = dersrec_height d) ; auto.
+         apply dersrec_derrec_height in J0. destruct J0.
+         assert (J1: derrec_height x = derrec_height x). auto.
+         assert (J2: list_exch_L (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) (A :: fst k ++ X0, Δ0 ++ B :: Δ1)).
+         assert ((Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) = ([] ++ [] ++ Γ0 ++ [A] ++ Γ1, Δ0 ++ B :: Δ1)). auto.
+         rewrite H0.
+         assert ((A :: fst k ++ X0, Δ0 ++ B :: Δ1) = ([] ++ [A] ++ Γ0 ++ [] ++ Γ1, Δ0 ++ B :: Δ1)).
+         simpl. rewrite H2. auto. rewrite H1. apply list_exch_LI.
+         pose (KS_hpadm_list_exch_L _ x _ J2). destruct s.
+         assert (J3: derrec_height x0 = derrec_height x0). auto.
+         assert (J4: list_exch_L (A :: fst k ++ X0, Δ0 ++ B :: Δ1) (fst k ++ A :: X0, Δ0 ++ B :: Δ1)).
+         assert ((fst k ++ A :: X0, Δ0 ++ B :: Δ1) = ([] ++ [] ++ fst k ++ [A] ++ X0, Δ0 ++ B :: Δ1)). auto.
+         rewrite H0.
+         assert ((A :: fst k ++ X0, Δ0 ++ B :: Δ1) = ([] ++ [A] ++ fst k ++ [] ++ X0, Δ0 ++ B :: Δ1)).
+         auto. rewrite H1. apply list_exch_LI.
+         pose (KS_hpadm_list_exch_L _ x0 _ J4). destruct s. simpl in PIH.
+         apply app2_find_hole in H3. destruct H3.
+         repeat destruct s ; destruct p0 ; subst.
+         assert (J5: derrec_height x1 < S (dersrec_height d)). rewrite <- e. apply PeanoNat.le_lt_n_Sm.
+         apply (Nat.le_trans _ _ _ l0 l).
+         assert (J6: derrec_height x1 = derrec_height x1). auto.
+         assert (J7: (fst k ++ A :: X0, snd k ++ B :: Δ1) = (fst k ++ A:: X0, snd k ++ B :: Δ1)). auto.
+         assert (J8: (In # p (propvar_subform_list ((A :: X0) ++ B :: Δ1)) -> False)).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc in H0.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         left ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         left ; apply in_or_app ; auto. apply in_or_app ; right ; apply in_or_app ; auto.
+         pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+         apply derI with (ps:=[([] ++ A :: X0, [UI p k] ++ B :: Δ1)]). apply ImpR.
+         assert ((X0, UI p k :: A --> B :: Δ1) = ([] ++ X0, [UI p k] ++ A --> B :: Δ1)). auto. rewrite H0.
+         apply ImpRRule_I. apply dlCons ; [ simpl ; auto | apply dlNil].
+         destruct x2 ; simpl in e1 ; subst. rewrite app_nil_r in e0 ; subst.
+         assert (J5: derrec_height x1 < S (dersrec_height d)). rewrite <- e. apply PeanoNat.le_lt_n_Sm.
+         apply (Nat.le_trans _ _ _ l0 l).
+         assert (J6: derrec_height x1 = derrec_height x1). auto.
+         assert (J7: (fst k ++ A :: X0, snd k ++ B :: Δ1) = (fst k ++ A:: X0, snd k ++ B :: Δ1)). auto.
+         assert (J8: (In # p (propvar_subform_list ((A :: X0) ++ B :: Δ1)) -> False)).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc in H0.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         left ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         left ; apply in_or_app ; auto. apply in_or_app ; right ; apply in_or_app ; auto.
+         pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+         apply derI with (ps:=[([] ++ A :: X0, [UI p k] ++ B :: Δ1)]). apply ImpR.
+         assert ((X0, UI p k :: A --> B :: Δ1) = ([] ++ X0, [UI p k] ++ A --> B :: Δ1)). auto. rewrite H0.
+         apply ImpRRule_I. apply dlCons ; [ simpl ; auto | apply dlNil].
+         exfalso. destruct k ; simpl in e0 ; subst. unfold critical_Seq in c ; unfold is_Prime in c ; simpl in c.
+         assert (In m (l1 ++ Δ0 ++ m :: x2)). apply in_or_app ; right ; apply in_or_app ; right ; apply in_eq.
+         apply c in H0. inversion e1 ; subst. destruct H0 ; destruct H0 ; inversion H0 ; inversion H1.
+         assert (J5: derrec_height x1 < S (dersrec_height d)). rewrite <- e. apply PeanoNat.le_lt_n_Sm.
+         apply (Nat.le_trans _ _ _ l0 l).
+         assert (J6: derrec_height x1 = derrec_height x1). auto.
+         assert (J7: (fst k ++ A :: X0, (snd k ++ x2) ++ B :: Δ1) = (fst k ++ A:: X0, snd k ++ x2 ++ B :: Δ1)).
+         repeat rewrite <- app_assoc. auto.
+         assert (J8: (In # p (propvar_subform_list ((A :: X0) ++ (x2 ++ B :: Δ1))) -> False)).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc in H0.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; left ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; left ; apply in_or_app ; auto.
+         apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+         pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+         apply derI with (ps:=[([] ++ A :: X0, (UI p k :: x2) ++ B :: Δ1)]). apply ImpR.
+         assert ((X0, UI p k :: x2 ++ A --> B :: Δ1) = ([] ++ X0, (UI p k :: x2) ++ A --> B :: Δ1)). auto. rewrite H0.
+         apply ImpRRule_I. apply dlCons ; [ simpl ; auto | apply dlNil].
+      (*  If not critical, consider the conjunction that UI p k is. *)
+      + assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+         assert (J1: Gimap (GUI p) (Canopy k) (map (UI p) (Canopy k))). apply Gimap_map. intros.
+         apply UI_GUI ; auto.
+         pose (@GUI_inv_not_critic p k (UI p k) (map (UI p) (Canopy k)) J0 f J1). rewrite <- e.
+ +
+         assert (J2: forall s1, InT s1 (Canopy k) -> KS_prv (X0, UI p s1 :: Y0)).
+         intros. pose (fold_Canopy _ _ H0). destruct s ; subst.
+         exfalso. apply f. apply Canopy_critical in H0 ; auto. destruct s. destruct p0. unfold inv_prems in i.
+         apply InT_flatten_list_InT_elem in i. destruct i. destruct p0. simpl in PIH. simpl in SIH.
+         pose (derI _ k0 d). assert (J2: derrec_height d0 = derrec_height d0). auto.
+         assert (J3: (fst k ++ X0, snd k ++ Y0) = (fst k ++ X0, snd k ++ Y0)). auto.
+         pose (Canopy_hp_inv_ctx k _ _ d0 X0 Y0 J2 J3 _ H0). destruct s.
+         assert (derrec_height d0 = S (dersrec_height d)). auto. rewrite H1 in l.
+         destruct (lt_decT (derrec_height x1) (S (dersrec_height d))).
+         (* Use PIH. *)
+         pose (fold_Canopy _ _ H0). destruct s ; subst.
+         exfalso. apply f. apply Canopy_critical in H0 ; auto. destruct s. destruct p0. unfold inv_prems in i2.
+         apply InT_flatten_list_InT_elem in i2. destruct i2. destruct p0.
+         assert (J4: derrec_height x1 = derrec_height x1). auto.
+         assert (J5: (fst s1 ++ X0, snd s1 ++ Y0) = (fst s1 ++ X0, snd s1 ++ Y0)). auto.
+         pose (PIH _ l0 s1 _ x1 X0 Y0 J4 J5). apply k1 ; auto.
+         (* Use SIH. *)
+         assert (derrec_height x1 = S (dersrec_height d)). lia.
+         assert (J4: measure s1 < measure k). pose (Canopy_measure _ _ H0).
+         destruct s ; subst ; auto. exfalso. apply f. apply Canopy_critical in H0 ; auto. symmetry in H2.
+         assert (J5: (fst s1 ++ X0, snd s1 ++ Y0) = (fst s1 ++ X0, snd s1 ++ Y0)). auto.
+         assert (J6: measure s1 = measure s1). auto.
+         pose (SIH _ J4 _ J6 _ _ _ _ H2 J5 propvar). auto.
+         assert (J3: (forall A : MPropF, InT A (map (UI p) (Canopy k)) -> KS_prv (fst (X0, Y0), A :: snd (X0, Y0)))).
+         intros. simpl. apply InT_map_iff in H0. destruct H0. destruct p0 ; subst. apply J2 in i ; auto.
+         pose (list_conj_R _ _ J3). simpl in k1. auto.
+ +
+    (* ImpL *)
+    * destruct (critical_Seq_dec k).
+      (* If critical, then the rule ImpL was applied on a formula in X0 or Y0.
+          So, apply PIH on the premises and then the rule. *)

+      + inversion H ; subst. assert (J0: dersrec_height d = dersrec_height d) ; auto.
+         apply dersrec_derrec2_height in J0. destruct J0. destruct s. simpl in PIH.
+         assert (J1: derrec_height x = derrec_height x). auto.
+         assert (J2: list_exch_R (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) (Γ0 ++ Γ1, A :: snd k ++ Y0)).
+         assert ((Γ0 ++ Γ1, Δ0 ++ A :: Δ1) = (Γ0 ++ Γ1, [] ++ [] ++ Δ0 ++ [A] ++ Δ1)). auto.
+         rewrite H0.
+         assert ((Γ0 ++ Γ1, A :: snd k ++ Y0) = (Γ0 ++ Γ1, [] ++ [A] ++ Δ0 ++ [] ++ Δ1)).
+         simpl. rewrite H3. auto. rewrite H1. apply list_exch_RI.
+         pose (KS_hpadm_list_exch_R _ x _ J2). destruct s.
+         assert (J3: derrec_height x1 = derrec_height x1). auto.
+         assert (J4: list_exch_R (Γ0 ++ Γ1, A :: snd k ++ Y0) (Γ0 ++ Γ1, snd k ++ A :: Y0)).
+         assert ((Γ0 ++ Γ1, snd k ++ A :: Y0) = (Γ0 ++ Γ1, [] ++ [] ++ snd k ++ [A] ++ Y0)). auto.
+         rewrite H0.
+         assert ((Γ0 ++ Γ1, A :: snd k ++ Y0) = (Γ0 ++ Γ1, [] ++ [A] ++ snd k ++ [] ++ Y0)).
+         auto. rewrite H1. apply list_exch_RI.
+         pose (KS_hpadm_list_exch_R _ x1 _ J4). destruct s.
+         apply app2_find_hole in H2. destruct H2.
+         repeat destruct s ; destruct p0 ; subst.
+         assert (J5: derrec_height x2 < S (dersrec_height d)). rewrite e. apply PeanoNat.le_lt_n_Sm.
+         apply Nat.max_le_iff. left ; apply (Nat.le_trans _ _ _ l0 l).
+         assert (J6: derrec_height x2 = derrec_height x2). auto.
+         assert (J7: (fst k ++ Γ1, snd k ++ A :: Y0) = (fst k ++ Γ1, snd k ++ A :: Y0)). auto.
+         assert (J8: In # p (propvar_subform_list (Γ1 ++ A :: Y0)) -> False).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; auto. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto.
+         pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+         assert (J9: derrec_height x0 < S (dersrec_height d)). lia.
+         assert (J10: derrec_height x0 = derrec_height x0). auto.
+         assert (J11: (fst k ++ B :: Γ1, Δ0 ++ Δ1) = (fst k ++ B :: Γ1, snd k ++ Y0)). rewrite H3 ; auto.
+         assert (J12: In # p (propvar_subform_list ((B :: Γ1) ++ Y0)) -> False).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc. repeat rewrite <- app_assoc in H0.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto.
+         pose (PIH _ J9 _ _ _ _ _ J10 J11 J12).
+         apply derI with (ps:=[([] ++ Γ1, [UI p k] ++ A :: Y0);([] ++ B :: Γ1, [UI p k] ++ Y0)]). apply ImpL.
+         assert ((A --> B :: Γ1, UI p k :: Y0) = ([] ++ A --> B :: Γ1, [UI p k] ++ Y0)). auto. rewrite H0.
+         apply ImpLRule_I. apply dlCons. auto. apply dlCons. auto. apply dlNil.
+         destruct x3 ; simpl in e1 ; subst. rewrite app_nil_r in e0 ; subst.
+         assert (J5: derrec_height x2 < S (dersrec_height d)). rewrite e. apply PeanoNat.le_lt_n_Sm.
+         apply Nat.max_le_iff. left ; apply (Nat.le_trans _ _ _ l0 l).
+         assert (J6: derrec_height x2 = derrec_height x2). auto.
+         assert (J7: (fst k ++ Γ1, snd k ++ A :: Y0) = (fst k ++ Γ1, snd k ++ A :: Y0)). auto.
+         assert (J8: In # p (propvar_subform_list (Γ1 ++ A :: Y0)) -> False).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; auto. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto.
+         pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+         assert (J9: derrec_height x0 < S (dersrec_height d)). lia.
+         assert (J10: derrec_height x0 = derrec_height x0). auto.
+         assert (J11: (fst k ++ B :: Γ1, Δ0 ++ Δ1) = (fst k ++ B :: Γ1, snd k ++ Y0)). rewrite H3 ; auto.
+         assert (J12: In # p (propvar_subform_list ((B :: Γ1) ++ Y0)) -> False).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc. repeat rewrite <- app_assoc in H0.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto. apply in_or_app ; right ; apply in_or_app ;
+         right ; apply in_or_app ; auto.
+         pose (PIH _ J9 _ _ _ _ _ J10 J11 J12).
+         apply derI with (ps:=[([] ++ Γ1, [UI p k] ++ A :: Y0);([] ++ B :: Γ1, [UI p k] ++ Y0)]). apply ImpL.
+         assert ((A --> B :: Γ1, UI p k :: Y0) = ([] ++ A --> B :: Γ1, [UI p k] ++ Y0)). auto. rewrite H0.
+         apply ImpLRule_I. apply dlCons. auto. apply dlCons. auto. apply dlNil.
+         exfalso. destruct k ; simpl in e0 ; subst. unfold critical_Seq in c ; unfold is_Prime in c ; simpl in c.
+         assert (In m ((Γ0 ++ m :: x3) ++ l2)). repeat rewrite <- app_assoc. apply in_or_app ; right ; apply in_or_app ; left ; apply in_eq.
+         apply c in H0. inversion e1 ; subst. destruct H0 ; destruct H0 ; inversion H0 ; inversion H1.
+         assert (J5: derrec_height x2 < S (dersrec_height d)). rewrite e. apply PeanoNat.le_lt_n_Sm.
+         apply Nat.max_le_iff. left ; apply (Nat.le_trans _ _ _ l0 l).
+         assert (J6: derrec_height x2 = derrec_height x2). auto.
+         assert (J7: ((fst k ++ x3) ++ Γ1, snd k ++ A :: Y0) = (fst k ++ x3 ++ Γ1, snd k ++ A :: Y0)).
+         rewrite <- app_assoc ; auto.
+         assert (J8: In # p (propvar_subform_list ((x3 ++ Γ1) ++ A :: Y0)) -> False).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc. repeat rewrite <- app_assoc in H0.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; auto. apply in_app_or in H0 ; destruct H0.
+         apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; right ; apply in_or_app ; auto.
+         apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+         pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+         assert (J9: derrec_height x0 < S (dersrec_height d)). lia.
+         assert (J10: derrec_height x0 = derrec_height x0). auto.
+         assert (J11: ((fst k ++ x3) ++ B :: Γ1, Δ0 ++ Δ1) = (fst k ++ x3 ++ B :: Γ1, snd k ++ Y0)).
+         rewrite H3 ; rewrite <- app_assoc ; auto.
+         assert (J12: In # p (propvar_subform_list ((x3 ++ B :: Γ1) ++ Y0)) -> False).
+         intro. apply propvar. repeat rewrite propvar_subform_list_app.
+         repeat rewrite propvar_subform_list_app in H0. simpl in H0. simpl.
+         repeat rewrite <- app_assoc. repeat rewrite <- app_assoc in H0.
+         apply in_app_or in H0 ; destruct H0. apply in_or_app ; auto. apply in_or_app ; right ; apply in_or_app ; auto.
+         pose (PIH _ J9 _ _ _ _ _ J10 J11 J12).
+         apply derI with (ps:=[(x3 ++ Γ1, [UI p k] ++ A :: Y0);(x3 ++ B :: Γ1, [UI p k] ++ Y0)]). apply ImpL.
+         assert ((x3 ++ A --> B :: Γ1, UI p k :: Y0) = (x3 ++ A --> B :: Γ1, [UI p k] ++ Y0)). auto. rewrite H0.
+         apply ImpLRule_I. apply dlCons. auto. apply dlCons. auto. apply dlNil.
+      (*  If not critical, consider the conjunction that UI p k is. *)
+      + assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+         assert (J1: Gimap (GUI p) (Canopy k) (map (UI p) (Canopy k))). apply Gimap_map. intros.
+         apply UI_GUI ; auto.
+         pose (@GUI_inv_not_critic p k (UI p k) (map (UI p) (Canopy k)) J0 f J1). rewrite <- e.
+ +
+         assert (J2: forall s1, InT s1 (Canopy k) -> KS_prv (X0, UI p s1 :: Y0)).
+         intros. pose (fold_Canopy _ _ H0). destruct s ; subst.
+         exfalso. apply f. apply Canopy_critical in H0 ; auto. destruct s. destruct p0. unfold inv_prems in i.
+         apply InT_flatten_list_InT_elem in i. destruct i. destruct p0. simpl in PIH. simpl in SIH.
+         pose (derI _ k0 d). assert (J2: derrec_height d0 = derrec_height d0). auto.
+         assert (J3: (fst k ++ X0, snd k ++ Y0) = (fst k ++ X0, snd k ++ Y0)). auto.
+         pose (Canopy_hp_inv_ctx k _ _ d0 X0 Y0 J2 J3 _ H0). destruct s.
+         assert (derrec_height d0 = S (dersrec_height d)). auto. rewrite H1 in l.
+         destruct (lt_decT (derrec_height x1) (S (dersrec_height d))).
+         (* Use PIH. *)
+         pose (fold_Canopy _ _ H0). destruct s ; subst.
+         exfalso. apply f. apply Canopy_critical in H0 ; auto. destruct s. destruct p0. unfold inv_prems in i2.
+         apply InT_flatten_list_InT_elem in i2. destruct i2. destruct p0.
+         assert (J4: derrec_height x1 = derrec_height x1). auto.
+         assert (J5: (fst s1 ++ X0, snd s1 ++ Y0) = (fst s1 ++ X0, snd s1 ++ Y0)). auto.
+         pose (PIH _ l0 s1 _ x1 X0 Y0 J4 J5). apply k1 ; auto.
+         (* Use SIH. *)
+         assert (derrec_height x1 = S (dersrec_height d)). lia.
+         assert (J4: measure s1 < measure k). pose (Canopy_measure _ _ H0).
+         destruct s ; subst ; auto. exfalso. apply f. apply Canopy_critical in H0 ; auto. symmetry in H2.
+         assert (J5: (fst s1 ++ X0, snd s1 ++ Y0) = (fst s1 ++ X0, snd s1 ++ Y0)). auto.
+         assert (J6: measure s1 = measure s1). auto.
+         pose (SIH _ J4 _ J6 _ _ _ _ H2 J5 propvar). auto.
+         assert (J3: (forall A : MPropF, InT A (map (UI p) (Canopy k)) -> KS_prv (fst (X0, Y0), A :: snd (X0, Y0)))).
+         intros. simpl. apply InT_map_iff in H0. destruct H0. destruct p0 ; subst. apply J2 in i ; auto.
+         pose (list_conj_R _ _ J3). simpl in k1. auto.
+ +
+    (* KR *)
+    * destruct (critical_Seq_dec k).
+      (* If critical. *)
+      + inversion X ; subst.
+         assert (J0: dersrec_height d = dersrec_height d) ; auto.
+         apply dersrec_derrec_height in J0. destruct J0. simpl in PIH. simpl in SIH.
+         destruct (dec_KS_init_rules k).
+         (* If initial. *)
+        ** assert (is_init k) ; auto. assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+         pose (@GUI_inv_critic_init p k _ J0 c X2). rewrite <- e0.
+         assert ((X0, Top :: Y0) = (X0, [] ++ Top :: Y0)). auto. rewrite H. apply TopR.
+         (* If not initial. *)
+        ** apply univ_gen_ext_splitR in X1. destruct X1. destruct s. destruct p0. destruct p0.
+           apply app2_find_hole in H2. destruct H2.
+           assert ((is_init k) -> False) ; auto.
+           assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+           assert (J1: Gimap (GUI p) (KR_prems k) (map (UI p) (KR_prems k))). apply Gimap_map. intros.
+           apply UI_GUI ; auto.
+           assert (J2: GUI p (unboxed_list (top_boxes (fst k)), []) (UI p (unboxed_list (top_boxes (fst k)), []))). apply UI_GUI ; auto.
+ +
+           pose (@GUI_inv_critic_not_init p k _ _ _ J0 c NE H J1 J2).
+           rewrite <- e1. clear e1.
+           repeat destruct s ; destruct p0 ; subst.
+           (* If Box A is in Y0. *)
+           -- pose (OrR (X0,Box A :: Δ1)). simpl in k1. apply k1. clear k1.
+              apply KS_hpadm_wkn_R with (A:=list_disj (restr_list_prop p (snd k))) (s:=(X0,
+              Or (list_disj (map Neg (restr_list_prop p (fst k))))(Or (list_disj (map Box (map (UI p) (KR_prems k)))) (Diam
+              (UI p (unboxed_list (top_boxes (fst k)), []%list)))) :: Box A :: Δ1)).
+              2: epose (wkn_RI (list_disj (restr_list_prop p (snd k))) _ [] _) ; simpl in w ; apply w.
+              pose (OrR (X0,Box A :: Δ1)). simpl in k1. apply k1. clear k1.
+              apply KS_hpadm_wkn_R with (A:=list_disj (map Neg (restr_list_prop p (fst k)))) (s:=(X0,
+              Or (list_disj (map Box (map (UI p) (KR_prems k)))) (Diam (UI p (unboxed_list (top_boxes (fst k)), []%list)))
+              :: Box A :: Δ1)).
+              2: epose (wkn_RI (list_disj (map Neg (restr_list_prop p (fst k)))) _ [] _) ; simpl in w ; apply w.
+              pose (OrR (X0,Box A :: Δ1)). simpl in k1. apply k1. clear k1.
+              apply KS_hpadm_wkn_R with (A:=list_disj (map Box (map (UI p) (KR_prems k)))) (s:=(X0,
+              (Diam (UI p (unboxed_list (top_boxes (fst k)), []%list))) :: Box A :: Δ1)).
+              2: epose (wkn_RI (list_disj (map Box (map (UI p) (KR_prems k)))) _ [] _) ; simpl in w ; apply w.
+              assert (J5: derrec_height x < S (dersrec_height d)). lia.
+              assert (J6: derrec_height x = derrec_height x). auto.
+              assert (J7: (unboxed_list (x0 ++ x1), [A]) = (fst (unboxed_list x0, @nil MPropF) ++ unboxed_list x1, snd (unboxed_list x0, []) ++ [A])).
+              simpl ; rewrite unbox_app_distrib. repeat rewrite <- app_assoc ; auto.
+              assert (J8: (In # p (propvar_subform_list ((unboxed_list x1) ++ [A])) -> False)).
+              intro. apply propvar. repeat rewrite propvar_subform_list_app.
+              repeat rewrite propvar_subform_list_app in H0. simpl in H0. repeat rewrite app_nil_r in H0. simpl.
+              repeat rewrite <- app_assoc in H0. apply in_app_or in H0 ; destruct H0.
+              apply in_or_app ; left. apply propvar_subform_list_unboxed_list in H0.
+              apply propvar_subform_list_nobox_gen_ext with (l0:=x1); auto.
+              apply in_or_app ; right ; apply in_or_app ; left. auto.
+              pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+              apply derI with (ps:=[(X0 ++ Box (Neg (UI p (unboxed_list (top_boxes (fst k)), []%list))) :: [], [] ++ Bot :: Box A :: Δ1)]).
+              apply ImpR. assert ((X0, Diam (UI p (unboxed_list (top_boxes (fst k)), []%list)) :: Box A :: Δ1) =
+              (X0 ++ [], [] ++ Diam (UI p (unboxed_list (top_boxes (fst k)), []%list)) :: Box A :: Δ1)). rewrite app_nil_r. auto. rewrite H0.
+              apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+              apply derI with (ps:=[(unboxed_list (x1 ++ [Box (Neg (UI p (unboxed_list (top_boxes (fst k)), []%list)))]) , [A])]).
+              apply KR. assert (([] ++ Bot :: Box A :: Δ1) = [Bot] ++ Box A :: Δ1). auto. rewrite H0. apply KRRule_I ; auto.
+              intro. intros. apply in_app_or in H2 ; destruct H2. apply H1 ; apply in_or_app ; auto. exists (Neg (UI p (unboxed_list (top_boxes (fst k)), []%list))).
+              inversion H2 ; subst ; auto. inversion H3. apply univ_gen_ext_combine ; auto. apply univ_gen_ext_cons. apply univ_gen_ext_nil.
+              apply dlCons. 2: apply dlNil. rewrite unbox_app_distrib. simpl. repeat rewrite <- app_assoc. simpl.
+              apply derI with (ps:=[(unboxed_list x1, [] ++ (UI p (unboxed_list (top_boxes (fst k)), []%list)) :: [A]);
+              (unboxed_list x1 ++ Bot :: [], [] ++ [A])]). apply ImpL.
+              pose (ImpLRule_I (UI p (unboxed_list (top_boxes (fst k)), []%list)) Bot (unboxed_list x1) [] [] [A]). simpl ; simpl in i.
+              rewrite app_nil_r in i. auto. apply dlCons. 2: apply dlCons.
+              3: apply dlNil. 2: apply derI with (ps:=[]) ; [apply BotL ; apply BotLRule_I | apply dlNil].
+              simpl. assert ((top_boxes (fst k)) = x0). symmetry. apply nobox_gen_ext_top_boxes_identity ; auto.
+              intro. intros. apply H1 ; apply in_or_app ; auto. rewrite H0. auto.
+          -- destruct x2 ; simpl in e2 ; subst.
+              (* If Box A is in Y0 (bis). *)
+              +++ rewrite app_nil_r in e1 ; subst.
+                  pose (OrR (X0,Box A :: Δ1)). simpl in k1. apply k1. clear k1.
+                  apply KS_hpadm_wkn_R with (A:=list_disj (restr_list_prop p (snd k))) (s:=(X0,
+                  Or (list_disj (map Neg (restr_list_prop p (fst k))))(Or (list_disj (map Box (map (UI p) (KR_prems k)))) (Diam (UI p (unboxed_list (top_boxes (fst k)), []%list))))
+                  :: Box A :: Δ1)).
+                  2: epose (wkn_RI (list_disj (restr_list_prop p (snd k))) _ [] _) ; simpl in w ; apply w.
+                  pose (OrR (X0,Box A :: Δ1)). simpl in k1. apply k1. clear k1.
+                  apply KS_hpadm_wkn_R with (A:=list_disj (map Neg (restr_list_prop p (fst k)))) (s:=(X0,
+                  Or (list_disj (map Box (map (UI p) (KR_prems k)))) (Diam (UI p (unboxed_list (top_boxes (fst k)), []%list)))
+                  :: Box A :: Δ1)).
+                  2: epose (wkn_RI (list_disj (map Neg (restr_list_prop p (fst k)))) _ [] _) ; simpl in w ; apply w.
+                  pose (OrR (X0,Box A :: Δ1)). simpl in k1. apply k1. clear k1.
+                  apply KS_hpadm_wkn_R with (A:=list_disj (map Box (map (UI p) (KR_prems k)))) (s:=(X0,
+                  (Diam (UI p (unboxed_list (top_boxes (fst k)), []%list)))
+                  :: Box A :: Δ1)).
+                  2: epose (wkn_RI (list_disj (map Box (map (UI p) (KR_prems k)))) _ [] _) ; simpl in w ; apply w.
+                  assert (J5: derrec_height x < S (dersrec_height d)). lia.
+                  assert (J6: derrec_height x = derrec_height x). auto.
+                  assert (J7: (unboxed_list (x0 ++ x1), [A]) = (fst (unboxed_list x0, @nil MPropF) ++ unboxed_list x1, snd (unboxed_list x0, []) ++ [A])).
+                  simpl ; rewrite unbox_app_distrib. repeat rewrite <- app_assoc ; auto.
+                  assert (J8: (In # p (propvar_subform_list (unboxed_list x1 ++ [A])) -> False)).
+                  intro. apply propvar. repeat rewrite propvar_subform_list_app.
+                  repeat rewrite propvar_subform_list_app in H0. simpl in H0. repeat rewrite app_nil_r in H0. simpl.
+                  repeat rewrite <- app_assoc in H0. apply in_app_or in H0 ; destruct H0.
+                  apply in_or_app ; left. apply propvar_subform_list_unboxed_list in H0.
+                  apply propvar_subform_list_nobox_gen_ext with (l0:=x1); auto.
+                  apply in_or_app ; right ; apply in_or_app ; left. auto.
+                  pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+                  apply derI with (ps:=[(X0 ++ Box (Neg (UI p (unboxed_list (top_boxes (fst k)), []%list))) :: [], [] ++ Bot :: Box A :: Δ1)]).
+                  apply ImpR. assert ((X0, Diam (UI p (unboxed_list (top_boxes (fst k)), []%list)) :: Box A :: Δ1) =
+                  (X0 ++ [], [] ++ Diam (UI p (unboxed_list (top_boxes (fst k)), []%list)) :: Box A :: Δ1)). rewrite app_nil_r. auto. rewrite H0.
+                  apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+                  apply derI with (ps:=[(unboxed_list (x1 ++ [Box (Neg (UI p (unboxed_list (top_boxes (fst k)), []%list)))]), [A])]).
+                  apply KR. assert (([] ++ Bot :: Box A :: Δ1) = [Bot] ++ Box A :: Δ1). auto. rewrite H0. apply KRRule_I ; auto.
+                  intro. intros. apply in_app_or in H2 ; destruct H2. apply H1 ; apply in_or_app ; auto. exists (Neg (UI p (unboxed_list (top_boxes (fst k)), []%list))).
+                  inversion H2 ; subst ; auto. inversion H3. apply univ_gen_ext_combine ; auto. apply univ_gen_ext_cons. apply univ_gen_ext_nil.
+                  apply dlCons. 2: apply dlNil. rewrite unbox_app_distrib. simpl. repeat rewrite <- app_assoc. simpl.
+                  apply derI with (ps:=[(unboxed_list x1, [] ++ (UI p (unboxed_list (top_boxes (fst k)), []%list)) :: [A]);
+                  (unboxed_list x1 ++ Bot :: [], [] ++ [A])]). apply ImpL.
+                  pose (ImpLRule_I (UI p (unboxed_list (top_boxes (fst k)), []%list)) Bot (unboxed_list x1) [] [] [A]). simpl ; simpl in i.
+                  rewrite app_nil_r in i. auto. apply dlCons. 2: apply dlCons.
+                  3: apply dlNil. 2: apply derI with (ps:=[]) ; [apply BotL ; apply BotLRule_I | apply dlNil].
+                  simpl. assert ((top_boxes (fst k)) = x0). symmetry. apply nobox_gen_ext_top_boxes_identity ; auto.
+                  intro. intros. apply H1 ; apply in_or_app ; auto. rewrite H0. auto.
+             (* If Box A is in (snd k). *)
+             +++ inversion e2 ; subst.
+                  assert (J10:derrec_height x = derrec_height x) ; auto.
+                  assert (J5: derrec_height x < S (dersrec_height d)). lia.
+                  assert (J6: derrec_height x = derrec_height x). auto.
+                  assert (J7: (unboxed_list (x0 ++ x1), [A]) = (fst (unboxed_list x0, [A]) ++ unboxed_list x1, snd (unboxed_list x0, [A]) ++ [])).
+                  simpl. rewrite unbox_app_distrib. repeat rewrite <- app_assoc ; auto.
+                  assert (J8: (In # p (propvar_subform_list ((unboxed_list x1 ++ [])))) -> False).
+                  intro. apply propvar. repeat rewrite propvar_subform_list_app.
+                  repeat rewrite propvar_subform_list_app in H0. simpl in H0. repeat rewrite app_nil_r in H0. simpl.
+                  repeat rewrite <- app_assoc in H0. apply in_or_app ; left. apply propvar_subform_list_unboxed_list in H0.
+                  apply propvar_subform_list_nobox_gen_ext with (l0:=x1); auto.
+                  pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+                  assert (J20: KS_rules [(unboxed_list x1, [UI p (unboxed_list x0, [A])])]
+                  (X0, Box (UI p (unboxed_list x0, [A])) :: Y0)). apply KR.
+                  assert (Box (UI p (unboxed_list x0, [A])) :: Y0 = [] ++ Box (UI p (unboxed_list x0, [A])) :: Y0).
+                  auto. rewrite H0. apply KRRule_I ;auto. intro. intros. apply H1. apply in_or_app ;auto.
+                  pose (dlNil KS_rules (fun _ : Seq => False)).
+                  pose (dlCons k1 d0). pose (derI _ J20 d1).
+                  pose (OrR (X0,Y0)). simpl in k2. apply k2. clear k2.
+                  apply KS_hpadm_wkn_R with (A:=list_disj (restr_list_prop p (snd k))) (s:=(X0,
+                  Or (list_disj (map Neg (restr_list_prop p (fst k))))(Or (list_disj (map Box (map (UI p) (KR_prems k)))) (Diam (UI p (unboxed_list (top_boxes (fst k)), []%list))))
+                  :: Y0)).
+                  2: epose (wkn_RI (list_disj (restr_list_prop p (snd k))) _ [] _) ; simpl in w ; apply w.
+                  pose (OrR (X0,Y0)). simpl in k2. apply k2. clear k2.
+                  apply KS_hpadm_wkn_R with (A:=list_disj (map Neg (restr_list_prop p (fst k)))) (s:=(X0,
+                  Or (list_disj (map Box (map (UI p) (KR_prems k)))) (Diam (UI p (unboxed_list (top_boxes (fst k)), []%list)))
+                  :: Y0)).
+                  2: epose (wkn_RI (list_disj (map Neg (restr_list_prop p (fst k)))) _ [] _) ; simpl in w ; apply w.
+                  pose (OrR (X0,Y0)). simpl in k2. apply k2. clear k2.
+                  pose (list_disj_wkn_R (map Box (map (UI p) (KR_prems k))) (X0, Diam (UI p (unboxed_list (top_boxes (fst k)), []%list)) :: Y0)).
+                  apply k2 with (A:=Box (UI p (unboxed_list x0, [A]))) ; clear k2 ; simpl ; auto.
+                  apply InT_map_iff. exists (UI p (unboxed_list x0, [A])) ; split ; auto. apply InT_map_iff.
+                  exists (unboxed_list x0, [A]) ; split ; auto. unfold KR_prems.
+                  apply InT_trans_flatten_list with (bs:=[(unboxed_list x0, [A])]) ; auto. apply InT_eq.
+                  destruct (finite_KR_premises_of_S k) ; subst. simpl. apply p0. assert (k = (fst k,Δ0 ++ Box A :: x2)).
+                  rewrite <- e1. destruct k ; auto. rewrite H0. apply KRRule_I ; auto. intro. intros. apply H1 ; apply in_or_app ; auto.
+                  apply KS_hpadm_wkn_R with (A:=Diam (UI p (unboxed_list (top_boxes (fst k)), []%list)))
+                  (s:=(X0, Box (UI p (unboxed_list x0, [A])) :: Y0)) ; auto.
+                  assert ((X0, Box (UI p (unboxed_list x0, [A])) :: Y0) = (X0, [Box (UI p (unboxed_list x0, [A]))] ++ Y0)).
+                  repeat rewrite <- app_assoc ; auto. rewrite H0. apply wkn_RI.
+           (* If Box A is in Y0 (ter). *)
+           -- pose (OrR (X0,x2 ++ Box A :: Δ1)). simpl in k1. apply k1. clear k1.
+              apply KS_hpadm_wkn_R with (A:=list_disj (restr_list_prop p (snd k))) (s:=(X0,
+              Or (list_disj (map Neg (restr_list_prop p (fst k))))(Or (list_disj (map Box (map (UI p) (KR_prems k)))) (Diam
+              (UI p (unboxed_list (top_boxes (fst k)), []%list)))) :: x2 ++ Box A :: Δ1)).
+              2: epose (wkn_RI (list_disj (restr_list_prop p (snd k))) _ [] _) ; simpl in w ; apply w.
+              pose (OrR (X0,x2 ++ Box A :: Δ1)). simpl in k1. apply k1. clear k1.
+              apply KS_hpadm_wkn_R with (A:=list_disj (map Neg (restr_list_prop p (fst k)))) (s:=(X0,
+              Or (list_disj (map Box (map (UI p) (KR_prems k)))) (Diam
+              (UI p (unboxed_list (top_boxes (fst k)), []%list)))
+              :: x2 ++ Box A :: Δ1)).
+              2: epose (wkn_RI (list_disj (map Neg (restr_list_prop p (fst k)))) _ [] _) ; simpl in w ; apply w.
+              pose (OrR (X0,x2 ++ Box A :: Δ1)). simpl in k1. apply k1. clear k1.
+              apply KS_hpadm_wkn_R with (A:=list_disj (map Box (map (UI p) (KR_prems k)))) (s:=(X0,
+              (Diam (UI p (unboxed_list (top_boxes (fst k)), []%list)))
+              :: x2 ++ Box A :: Δ1)).
+              2: epose (wkn_RI (list_disj (map Box (map (UI p) (KR_prems k)))) _ [] _) ; simpl in w ; apply w.
+              assert (J5: derrec_height x < S (dersrec_height d)). lia.
+              assert (J6: derrec_height x = derrec_height x). auto.
+              assert (J7: (unboxed_list (x0 ++ x1), [A]) = (fst (unboxed_list x0, @nil MPropF) ++ unboxed_list x1, snd (unboxed_list x0, []) ++ [A])).
+              simpl ; rewrite unbox_app_distrib. repeat rewrite <- app_assoc ; auto.
+              assert (J8: (In # p (propvar_subform_list ((unboxed_list x1) ++ [A])) -> False)).
+              intro. apply propvar. repeat rewrite propvar_subform_list_app.
+              repeat rewrite propvar_subform_list_app in H0. simpl in H0. repeat rewrite app_nil_r in H0. simpl.
+              repeat rewrite <- app_assoc in H0. apply in_app_or in H0 ; destruct H0.
+              apply in_or_app ; left. apply propvar_subform_list_unboxed_list in H0.
+              apply propvar_subform_list_nobox_gen_ext with (l0:=x1); auto.
+              apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; left. auto.
+              pose (PIH _ J5 _ _ _ _ _ J6 J7 J8).
+              apply derI with (ps:=[(X0 ++ Box (Neg (UI p (unboxed_list (top_boxes (fst k)), []%list))) :: [], [] ++ Bot :: x2 ++ Box A :: Δ1)]).
+              apply ImpR. assert ((X0, Diam (UI p (unboxed_list (top_boxes (fst k)), []%list)) :: x2 ++ Box A :: Δ1) =
+              (X0 ++ [], [] ++ Diam (UI p (unboxed_list (top_boxes (fst k)), []%list)) :: x2 ++ Box A :: Δ1)). rewrite app_nil_r. auto. rewrite H0.
+              apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+              apply derI with (ps:=[(unboxed_list (x1 ++ [Box (Neg (UI p (unboxed_list (top_boxes (fst k)), []%list)))]), [A])]).
+              apply KR. assert (([] ++ Bot :: x2 ++ Box A :: Δ1) = (Bot :: x2) ++ Box A :: Δ1). auto. rewrite H0. apply KRRule_I ; auto.
+              intro. intros. apply in_app_or in H2 ; destruct H2. apply H1 ; apply in_or_app ; auto. exists (Neg (UI p (unboxed_list (top_boxes (fst k)), []%list))).
+              inversion H2 ; subst ; auto. inversion H3. apply univ_gen_ext_combine ; auto. apply univ_gen_ext_cons. apply univ_gen_ext_nil.
+              apply dlCons. 2: apply dlNil. rewrite unbox_app_distrib. simpl. repeat rewrite <- app_assoc. simpl.
+              apply derI with (ps:=[(unboxed_list x1, [] ++ (UI p (unboxed_list (top_boxes (fst k)), []%list)) :: [A]);
+              (unboxed_list x1 ++ Bot :: [], [] ++ [A])]). apply ImpL.
+              pose (ImpLRule_I (UI p (unboxed_list (top_boxes (fst k)), []%list)) Bot (unboxed_list x1) [] [] [A]). simpl ; simpl in i.
+              rewrite app_nil_r in i. auto. apply dlCons. 2: apply dlCons.
+              3: apply dlNil. 2: apply derI with (ps:=[]) ; [apply BotL ; apply BotLRule_I | apply dlNil].
+              simpl. assert ((top_boxes (fst k)) = x0). symmetry. apply nobox_gen_ext_top_boxes_identity ; auto.
+              intro. intros. apply H1 ; apply in_or_app ; auto. rewrite H0. auto.
+      (*  If not critical, consider the conjunction that UI p k is. *)
+      + assert (J0: GUI p k (UI p k)). apply UI_GUI ; auto.
+         assert (J1: Gimap (GUI p) (Canopy k) (map (UI p) (Canopy k))). apply Gimap_map. intros.
+         apply UI_GUI ; auto.
+         pose (@GUI_inv_not_critic p k (UI p k) (map (UI p) (Canopy k)) J0 f J1). rewrite <- e.
+ +
+         assert (J2: forall s1, InT s1 (Canopy k) -> KS_prv (X0, UI p s1 :: Y0)).
+         intros. pose (fold_Canopy _ _ H). destruct s ; subst.
+         exfalso. apply f. apply Canopy_critical in H ; auto. destruct s. destruct p0. unfold inv_prems in i.
+         apply InT_flatten_list_InT_elem in i. destruct i. destruct p0. simpl in PIH. simpl in SIH.
+         pose (derI _ k0 d). assert (J2: derrec_height d0 = derrec_height d0). auto.
+         assert (J3: (fst k ++ X0, snd k ++ Y0) = (fst k ++ X0, snd k ++ Y0)). auto.
+         pose (Canopy_hp_inv_ctx k _ _ d0 X0 Y0 J2 J3 _ H). destruct s.
+         assert (derrec_height d0 = S (dersrec_height d)). auto. rewrite H0 in l.
+         destruct (lt_decT (derrec_height x1) (S (dersrec_height d))).
+         (* Use PIH. *)
+         pose (fold_Canopy _ _ H). destruct s ; subst.
+         exfalso. apply f. apply Canopy_critical in H ; auto. destruct s. destruct p0. unfold inv_prems in i2.
+         apply InT_flatten_list_InT_elem in i2. destruct i2. destruct p0.
+         assert (J4: derrec_height x1 = derrec_height x1). auto.
+         assert (J5: (fst s1 ++ X0, snd s1 ++ Y0) = (fst s1 ++ X0, snd s1 ++ Y0)). auto.
+         pose (PIH _ l0 s1 _ x1 X0 Y0 J4 J5). apply k1 ; auto.
+         (* Use SIH. *)
+         assert (derrec_height x1 = S (dersrec_height d)). lia.
+         assert (J4: measure s1 < measure k). pose (Canopy_measure _ _ H).
+         destruct s ; subst ; auto. exfalso. apply f. apply Canopy_critical in H ; auto. symmetry in H1.
+         assert (J5: (fst s1 ++ X0, snd s1 ++ Y0) = (fst s1 ++ X0, snd s1 ++ Y0)). auto.
+         assert (J6: measure s1 = measure s1). auto.
+         pose (SIH _ J4 _ J6 _ _ _ _ H1 J5 propvar). auto.
+         assert (J3: (forall A : MPropF, InT A (map (UI p) (Canopy k)) -> KS_prv (fst (X0, Y0), A :: snd (X0, Y0)))).
+         intros. simpl. apply InT_map_iff in H. destruct H. destruct p0 ; subst. apply J2 in i ; auto.
+         pose (list_conj_R _ _ J3). simpl in k1. auto. }
+  Qed.
+ +
+  End UIPThree.
+
+
+ +
+ + + diff --git a/K.Interpolation.UIK_UITwo.html b/K.Interpolation.UIK_UITwo.html new file mode 100644 index 0000000..17fa5de --- /dev/null +++ b/K.Interpolation.UIK_UITwo.html @@ -0,0 +1,153 @@ + + + + + + + + + + + + + +
+
+

K.Interpolation.UIK_UITwo

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat Arith.
+Require Import Lia.
+ +
+Require Import general_export.
+ +
+Require Import KS_export.
+ +
+Require Import UIK_Def_measure.
+Require Import UIK_Canopy.
+Require Import UIK_irred_short.
+Require Import UIK_braga.
+Require Import UIK_UI_prelims.
+ +
+  Section UIPTwo.
+ +
+  Theorem UI_Two : forall (s : Seq), forall p, KS_prv ((UI p s) :: fst s, snd s).
+  Proof.
+  intro s. remember (measure s) as n. revert Heqn. revert s. revert n.
+  induction n as [n IH] using (well_founded_induction_type lt_wf).
+  intros.
+  destruct (empty_seq_dec s).
+  (* s is the empty sequent. *)
+  { subst ; simpl in *. assert (GUI p ([],[]) Bot). apply GUI_empty_seq ; auto. apply UI_GUI in H.
+    rewrite H in *. apply derI with []. apply BotL ; apply (BotLRule_I [] []). apply dlNil. }
+  (* s is not the empty sequent. *)
+  { destruct (critical_Seq_dec s).
+  (* s is a critical sequent *)
+  - destruct (dec_KS_init_rules s).
+    (* s is an initial sequent *)
+    + assert (KS_prv (fst s, snd s)). destruct s0. destruct s.
+      1,2: apply derI with (ps:=[]) ; try apply dlNil.
+      apply IdP ; auto. destruct s ; apply BotL ; auto.
+      destruct s. simpl. simpl in X.
+      assert (J0: derrec_height X = derrec_height X). auto.
+      assert (J1: wkn_L (UI p (l, l0)) (l, l0) (UI p (l, l0) :: l, l0)).
+      replace (l, l0) with ([] ++ l, l0) by auto.
+      replace (UI p ([] ++ l, l0) :: l, l0) with ([] ++ UI p ([] ++ l, l0) :: l, l0) by auto.
+      apply wkn_LI.
+      pose (KS_wkn_L _ _ X J0 _ _ J1). destruct s. auto.
+    (* s is not an initial sequent *)
+    + assert (P1: KS_prv (list_disj (map Neg (restr_list_prop p (fst s))) :: fst s, snd s)).
+        apply list_disj_L. intros A H0. apply InT_map_iff in H0. destruct H0. destruct p0. subst. unfold Neg.
+        apply derI with (ps:=[([] ++ fst s, [] ++ x :: snd s);([] ++ Bot :: fst s, [] ++ snd s)]).
+        assert ((x --> Bot :: fst s, snd s) = ([] ++ x --> Bot :: fst s, [] ++ snd s)). auto. rewrite H. apply ImpL. apply ImpLRule_I.
+        apply dlCons. 2: apply dlCons. 3: apply dlNil. unfold restr_list_prop in i.
+        apply InT_In in i. apply In_remove_In_list in i. apply In_list_prop_LF in i. destruct i. apply In_InT in i.
+        apply InT_split in i. destruct i. destruct s1. destruct s. rewrite e. assert ([] ++ x0 ++ x :: x1 = x0 ++ x :: x1). auto.
+        rewrite H. apply Id_all_form. apply derI with (ps:=[]). apply BotL. apply BotLRule_I. apply dlNil.
+ +
+         assert (P2: KS_prv (list_disj (restr_list_prop p (snd s)) :: fst s, snd s)).
+         apply list_disj_L. intros A H0. unfold restr_list_prop in H0. apply InT_In in H0. apply In_remove_In_list in H0.
+         apply In_list_prop_LF in H0. destruct H0 as [s0 i]. apply In_InT in i. apply InT_split in i. destruct i. destruct s1.
+         rewrite e. replace (A :: fst s) with ([] ++ A :: fst s) by auto. apply Id_all_form.
+ +
+         assert (P3: KS_prv (list_disj (map Box (map (UI p) (KR_prems s))) :: fst s, snd s)).
+         apply list_disj_L. intros A H0. apply InT_map_iff in H0. destruct H0. destruct p0. subst. apply InT_map_iff in i.
+         destruct i. destruct p0 ; subst. unfold KR_prems in i. destruct (finite_KR_premises_of_S s).
+         simpl in i. apply InT_flatten_list_InT_elem in i. destruct i. destruct p1. apply p0 in i0.
+         inversion i0 ; subst. inversion i ; subst. simpl. remember (UI p (unboxed_list , [A])) as Interp.
+         apply derI with (ps:=[(unboxed_list (Box Interp :: ), [A])]). apply KR. apply KRRule_I.
+         intro. intros. inversion H0 ; simpl. exists Interp ; auto. apply H ; auto. apply univ_gen_ext_cons ; auto.
+         apply dlCons. 2: apply dlNil. simpl.
+         assert (J0: measure (unboxed_list , [A]) < measure (Γ0, Δ0 ++ Box A :: Δ1)).
+         unfold measure. simpl. repeat rewrite size_LF_dist_app. simpl.
+         pose (size_nobox_gen_ext _ _ X). simpl in l.
+         pose (size_unboxed ). lia.
+         assert (J30: measure (unboxed_list , [A]) = measure (unboxed_list , [A])) ; auto.
+         pose (IH _ J0 _ J30 p). simpl in k. rewrite <- HeqInterp in k. auto. inversion H1.
+ +
+         assert (P4: KS_prv (Diam (UI p (unboxed_list (top_boxes (fst s)), [])) :: fst s, snd s)).
+         { destruct s. destruct l ; subst.
+           - assert (GUI p ([],[]) Bot). apply GUI_empty_seq ; auto. apply UI_GUI in H. simpl in *. rewrite H in *.
+             apply DiamL_lim with (:=[]). intros A HA ; inversion HA. apply univ_gen_ext_nil. apply derI with [].
+             apply BotL. apply (BotLRule_I []). apply dlNil.
+           - apply DiamL_lim with (:=top_boxes (m :: l)). apply is_Boxed_list_top_boxes. apply nobox_top_boxes.
+             assert (J0: measure (unboxed_list (top_boxes (m :: l)), []%list) < measure (m :: l, l0)).
+             unfold measure. simpl. simpl in * ; simpl. subst ; simpl.
+             destruct m ; simpl ; subst ; pose (size_unboxed (top_boxes l)) ; pose (size_top_boxes l) ; lia.
+             assert (J30: measure (unboxed_list (top_boxes (m :: l)), []%list) = measure (unboxed_list (top_boxes (m :: l)), []%list)) ; auto.
+             subst. pose (IH _ J0 _ J30 p). simpl in k. auto. }
+
+         assert (H0: GUI p s
+         (Or (list_disj (restr_list_prop p (snd s)))
+         (Or (list_disj (map Neg (restr_list_prop p (fst s))))
+         (Or (list_disj (map Box (map (UI p) (KR_prems s))))
+         (Diam (UI p (unboxed_list (top_boxes (fst s)), []%list))))))).
+         apply GUI_critic_not_init ; auto. apply Gimap_map ; intros. 1-2: apply UI_GUI ; auto.
+         apply (UI_GUI p s) in H0. rewrite H0. repeat apply OrL ; auto.
+  (* s is not a critical sequent *)
+  - assert (J0: GUI p s (UI p s)). apply UI_GUI ; auto.
+    assert (J1: Gimap (GUI p) (Canopy s) (map (UI p) (Canopy s))). apply Gimap_map. intros.
+    apply UI_GUI ; auto.
+    pose (@GUI_inv_not_critic p s (UI p s) (map (UI p) (Canopy s)) J0 f J1). rewrite <- e.
+    assert (J2: forall s1, InT s1 (Canopy s) -> KS_prv (UI p s1 :: fst s1, snd s1)).
+    intros s1 H0. apply IH with (y:= measure s1) ; auto. pose (Canopy_measure _ _ H0). destruct s0 ; subst ; auto. exfalso.
+    apply f. apply Canopy_critical in H0 ; auto.
+    assert (J3 : forall s1 : Seq, InT s1 (Canopy s) -> KS_prv (list_conj (map (UI p) (Canopy s)) :: fst s1, snd s1)).
+    intros. apply list_conj_wkn_L with (A:=UI p s1) ; auto. apply InT_mapI. exists s1 ; auto.
+    apply Canopy_equiprv_genL ; auto. }
+  Qed.
+ +
+  End UIPTwo.
+
+
+ +
+ + + diff --git a/K.Interpolation.UIK_UI_prelims.html b/K.Interpolation.UIK_UI_prelims.html new file mode 100644 index 0000000..babb6d1 --- /dev/null +++ b/K.Interpolation.UIK_UI_prelims.html @@ -0,0 +1,623 @@ + + + + + + + + + + + + + +
+
+

K.Interpolation.UIK_UI_prelims

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+Require Import String.
+ +
+Require Import general_export.
+ +
+Require Import KS_export.
+ +
+Require Import UIK_Def_measure.
+Require Import UIK_Canopy.
+Require Import UIK_irred_short.
+Require Import UIK_basics.
+Require Import UIK_braga.
+ +
+  Section Prop_Subform.
+ +
+  (* This is copied from the Craig interpolation file. Make a syntax file for interpolations. *)
+ +
+  Fixpoint propvar_subform (A : MPropF) : list MPropF :=
+  match A with
+    | Var p => (Var p) :: nil
+    | Bot => nil
+    | Imp B C => (propvar_subform B) ++ ( propvar_subform C)
+    | Box B => ( propvar_subform B)
+  end.
+ +
+  Fixpoint propvar_subform_list (l : list MPropF) : list MPropF :=
+  match l with
+    | nil => nil
+    | A :: t => (propvar_subform A) ++ (propvar_subform_list t)
+  end.
+ +
+  (* Lemmas about propvar_subform_list. *)
+ +
+  Lemma propvar_subform_list_app: forall l0 l1,
+        propvar_subform_list (l0 ++ l1) = (propvar_subform_list l0) ++ (propvar_subform_list l1).
+  Proof.
+  induction l0.
+  - simpl. auto.
+  - intros. simpl. rewrite (IHl0). rewrite <- app_assoc ; auto.
+  Qed.
+ +
+  Lemma propvar_subform_list_unboxed_list : forall l A, In A (propvar_subform_list (unboxed_list l)) -> In A (propvar_subform_list l).
+  Proof.
+  induction l.
+  - auto.
+  - simpl. intros. apply in_app_or in H. destruct H. apply in_or_app ; left. destruct a ; auto.
+    apply in_or_app ; auto.
+  Qed.
+ +
+  Lemma propvar_subform_list_nobox_gen_ext : forall l0 l1, nobox_gen_ext l0 l1 ->
+            (forall A, In A (propvar_subform_list l0) -> In A (propvar_subform_list l1)).
+  Proof.
+  intros l0 l1 H. induction H ; auto.
+  - simpl ; intros. apply in_or_app. apply in_app_or in H0 ; destruct H0 ; auto.
+  - simpl ; intros. apply in_or_app ; auto.
+  Qed.
+ +
+  Lemma propvar_subform_list_top_boxes : forall l A, In A (propvar_subform_list (top_boxes l)) -> In A (propvar_subform_list l).
+  Proof.
+  induction l ; simpl ; intros ; auto. destruct a ; simpl in H ; auto. 1-2: apply in_or_app ; apply IHl in H ; auto.
+  apply in_or_app ; apply in_app_or in H ; destruct H ; simpl ; auto.
+  Qed.
+ +
+  Lemma propvar_subform_list_conj : forall l A,
+            In A (propvar_subform (list_conj l)) -> In A (propvar_subform_list l).
+  Proof.
+  induction l ; simpl ; intros ; auto. repeat rewrite app_nil_r in H.
+  apply in_app_or in H. apply in_or_app. destruct H ; auto.
+  Qed.
+ +
+  Lemma propvar_subform_list_disj : forall l A,
+            In A (propvar_subform (list_disj l)) -> In A (propvar_subform_list l).
+  Proof.
+  induction l ; simpl ; intros ; auto. repeat rewrite app_nil_r in H.
+  apply in_app_or in H. apply in_or_app. destruct H ; auto.
+  Qed.
+ +
+  Lemma propvar_subform_list_witness : forall l A,
+            In A (propvar_subform_list l) -> (exists B, In B l /\ In A (propvar_subform B)).
+  Proof.
+  induction l ; simpl ; intros ; auto. inversion H. apply in_app_or in H. destruct H.
+  exists a ; auto. apply IHl in H. destruct H. exists x ; firstorder.
+  Qed.
+ +
+  Lemma propvar_subform_list_witnessT : forall l A,
+            InT A (propvar_subform_list l) -> (existsT2 B, (InT B l) * (InT A (propvar_subform B))).
+  Proof.
+  induction l ; simpl ; intros ; auto. inversion H. apply InT_app_or in H. destruct H.
+  exists a ; auto. split ; auto. apply InT_eq. apply IHl in i. destruct i. exists x ; firstorder. apply InT_cons ; auto.
+  Qed.
+ +
+  Lemma propvar_subform_list_Canopy : forall s ir A,
+            In ir (Canopy s) ->
+            In A (propvar_subform_list (fst ir ++ snd ir)) ->
+            In A (propvar_subform_list (fst s ++ snd s)).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros. remember (finite_ImpRules_premises_of_S s) as H1.
+  destruct H1. destruct x.
+  - assert (Canopy s = [s]). apply irred_nil. unfold inv_prems. rewrite <- HeqH1.
+    simpl. auto. rewrite H1 in H. inversion H. subst. auto. inversion H2.
+  - apply In_InT_seqs in H. apply fold_Canopy in H. destruct H ; subst ; auto.
+    destruct s0. destruct p0. unfold inv_prems in i. destruct (finite_ImpRules_premises_of_S s).
+    simpl in i. apply InT_flatten_list_InT_elem in i. destruct i. destruct p1. apply p0 in i1.
+    apply IHs with (y:=x0) in H0. 3: apply InT_In ; auto.
+    destruct i1. inversion i1 ; subst. simpl. inversion i ; subst. 2: inversion H1. simpl in H0.
+    repeat rewrite <- app_assoc in H0. repeat rewrite <- app_assoc.
+    repeat rewrite propvar_subform_list_app in H0. repeat rewrite propvar_subform_list_app.
+    simpl in H0. simpl. repeat rewrite <- app_assoc in H0. repeat rewrite <- app_assoc.
+    apply in_or_app. apply in_app_or in H0 ; destruct H0 ; auto. right. apply in_or_app.
+    apply in_app_or in H ; destruct H ; auto. right ; apply in_or_app ; right ; apply in_or_app ; auto.
+    apply in_app_or in H ; destruct H ; auto. right. apply in_or_app ; apply in_app_or in H ; destruct H ; auto.
+    right ; apply in_or_app ; right ; auto.
+    inversion i1 ; subst. simpl. inversion i ; subst. simpl in H0.
+    repeat rewrite <- app_assoc in H0. repeat rewrite <- app_assoc.
+    repeat rewrite propvar_subform_list_app in H0. repeat rewrite propvar_subform_list_app.
+    simpl in H0. simpl. repeat rewrite <- app_assoc in H0. repeat rewrite <- app_assoc.
+    apply in_or_app. apply in_app_or in H0 ; destruct H0 ; auto. right. apply in_or_app.
+    apply in_app_or in H ; destruct H ; auto. right ; apply in_or_app ; right ; apply in_or_app ; auto.
+    apply in_app_or in H ; destruct H ; auto. right. apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+    apply in_app_or in H ; destruct H ; auto. right ; apply in_or_app ; right ; apply in_or_app ; right ; apply in_or_app ; auto.
+    inversion H1 ; subst. 2: inversion H2. simpl in H0.
+    repeat rewrite <- app_assoc in H0. repeat rewrite <- app_assoc.
+    repeat rewrite propvar_subform_list_app in H0. repeat rewrite propvar_subform_list_app.
+    simpl in H0. simpl. repeat rewrite <- app_assoc in H0. repeat rewrite <- app_assoc.
+    apply in_or_app. apply in_app_or in H0 ; destruct H0 ; auto. right. apply in_or_app.
+    apply in_app_or in H ; destruct H ; auto. right ; apply in_or_app ; auto.
+    apply in_app_or in H ; destruct H ; auto. right. apply in_or_app ; right ; apply in_or_app ; auto.
+    right ; apply in_or_app ; right ; apply in_or_app ; right ; auto.
+    destruct i1. inversion i1 ; subst. simpl. inversion i ; subst. 2: inversion H1. unfold n_imp_subformS ; simpl.
+    repeat rewrite n_imp_subformLF_dist_app ; simpl ; repeat rewrite n_imp_subformLF_dist_app. lia.
+    inversion i1. subst. inversion i ; subst. unfold n_imp_subformS ; simpl.
+    repeat rewrite n_imp_subformLF_dist_app ; simpl ; repeat rewrite n_imp_subformLF_dist_app. lia.
+    inversion H1. subst. 2: inversion H2. unfold n_imp_subformS ; simpl.
+    repeat rewrite n_imp_subformLF_dist_app ; simpl ; repeat rewrite n_imp_subformLF_dist_app. lia.
+  Qed.
+ +
+  Lemma propvar_subform_list_restr_list_prop : forall l p q, In # q (propvar_subform_list (restr_list_prop p l)) ->
+                        ((q <> p) * (In # q (propvar_subform_list l))).
+  Proof.
+  induction l ; simpl ; intros ; auto. unfold restr_list_prop in H. destruct a as [n | | |]; simpl ; simpl in H ; auto.
+  destruct (eq_dec_form (# p) (# n)) ; subst. apply IHl in H. destruct H ; auto.
+  simpl in H. destruct H ; subst ; auto. split ; auto. rewrite H in n0. destruct (string_dec p q) ; subst; auto.
+  all: apply IHl in H ; destruct H ; auto.
+  all: split ; auto. all: apply in_or_app ; auto.
Qed.
+ +
+  Lemma In_list_prop_LF: forall l A, In A (list_prop_LF l) -> ((existsT2 q, A = # q) * In A l).
+  Proof.
+  induction l ; simpl ; intros ; auto. inversion H. apply In_InT in H. apply InT_app_or in H.
+  destruct H. destruct a as [n | | |]; simpl in i ; inversion i ; subst ; auto. split ; [exists n ; auto | auto]. inversion H0.
+  apply InT_In in i ; apply IHl in i ; auto. destruct i ; split ; auto.
+  Qed.
+ +
+  Lemma list_prop_LF_propvar_subform_list : forall l q, In # q (list_prop_LF l) -> In # q (propvar_subform_list l).
+  Proof.
+  induction l ; simpl ; intros ; auto. apply in_app_or in H ; destruct H ; auto. apply in_or_app ; left. destruct a ; simpl ; simpl in H ; try firstorder.
+  apply in_or_app ; right ; apply IHl in H ; auto.
+  Qed.
+ +
+  Lemma In_list_In_list_prop_LF : forall l P, In # P l -> In # P (list_prop_LF l).
+  Proof.
+  induction l ; simpl ; subst ; auto. intros. destruct H. subst ; simpl ; auto. apply in_or_app; right ; auto.
+  Qed.
+ +
+  Lemma In_list_In_propvar_subform_list : forall l P, In # P l -> In # P (propvar_subform_list l).
+  Proof.
+  induction l ; simpl ; subst ; auto. intros. destruct H. subst ; simpl ; auto. apply in_or_app; right ; auto.
+  Qed.
+ +
+  End Prop_Subform.
+ +
+  Section Diam_help.
+ +
+  Lemma In_unboxed_list : forall l A, In A (unboxed_list (top_boxes l)) -> (exists B, In B (top_boxes l) /\ B = Box A).
+  Proof.
+  induction l ; intros ; auto. simpl in H. exfalso ; auto. destruct a ; simpl ; simpl in H ; auto.
+  destruct H ; subst. exists (Box A) ; auto.
+  apply IHl in H. destruct H. firstorder.
+  Qed.
+ +
+  Lemma unboxed_list_In : forall l A, In (Box A) (top_boxes l) -> In A (unboxed_list (top_boxes l)).
+  Proof.
+  induction l ; simpl ; intros ; auto. destruct a ; simpl ; simpl in H ; auto. destruct H. inversion H ; subst. auto.
+  apply IHl in H ; auto.
+  Qed.
+ +
+  Lemma unboxed_list_In_unfold : forall l A, (exists B, In B (top_boxes l) /\ B = Box A) -> In A (unboxed_list (top_boxes l)).
+  Proof.
+  induction l ; simpl ; intros ; auto. destruct H. destruct H ; auto.
+  destruct a ; simpl ; simpl in H ; auto. destruct H. destruct H. subst. destruct H.
+  inversion H ; subst ; auto. right. apply unboxed_list_In ; auto.
+  Qed.
+ +
+  Lemma remove_list_decr_in: forall [l2 l1 l3 l4: list MPropF], NoDup l4 -> NoDup l3 ->
+    incl l1 l2 -> incl l3 l4 -> length (remove_list l2 l4) < length (remove_list l1 l3) ->
+    (exists A : MPropF, In A l2 /\ (In A l1 -> False)).
+  Proof.
+  induction l2 ; simpl.
+  - intros. destruct l1. simpl. simpl in H3. exfalso. pose (NoDup_incl_length H0 H2). simpl in l. lia.
+    exfalso. pose (H1 m). simpl in i ; apply i ; auto.
+  - intros. destruct (In_dec l2 a).
+    + assert (incl l1 l2). intro. intros. apply H1 in H4. inversion H4 ; subst ; auto.
+       pose (In_remove_list_remove_redund _ l4 _ i). rewrite e in H3.
+       pose (IHl2 _ _ _ H H0 H4 H2 H3). destruct e0. destruct H5. exists x ; split ; auto.
+    + destruct (In_dec l1 a).
+        * destruct (In_dec l4 a).
+          -- destruct (In_dec l3 a).
+            ++ assert (incl (remove eq_dec_form a l1) l2). intro. intros. apply in_remove in H4. destruct H4.
+                 apply H1 in H4. inversion H4 ; subst ; auto. exfalso ; apply H5 ; auto.
+                 assert ((remove_list l1 l3) = (remove_list (remove eq_dec_form a l1) (remove eq_dec_form a l3))).
+                 rewrite <- In_remove_list_remove_redund with (a:=a). rewrite permut_remove_remove_list.
+                 pose (permut_remove_remove_list a (remove eq_dec_form a l1) l3). rewrite <- e.
+                 pose (redund_remove_remove_list a l1 l3). rewrite e0. rewrite permut_remove_remove_list. auto. auto.
+                 assert (J0: NoDup (remove eq_dec_form a l4)). apply remove_preserv_NoDup ; auto.
+                 assert (J1: NoDup (remove eq_dec_form a l3)). apply remove_preserv_NoDup ; auto.
+                 assert (J2: incl (remove eq_dec_form a l3) (remove eq_dec_form a l4)). intro. intros.
+                 apply in_remove in H6. destruct H6. apply in_in_remove ; auto.
+                 rewrite H5 in H3. rewrite permut_remove_remove_list in H3.
+                 pose (IHl2 (remove eq_dec_form a l1) _ _ J0 J1 H4 J2 H3). destruct e. destruct H6.
+                 exists x ; split ; auto. intro. apply H7. apply in_in_remove ; auto. intro ; subst. auto.
+            ++ assert (incl (remove eq_dec_form a l1) l2). intro. intros. apply in_remove in H4. destruct H4.
+                 apply H1 in H4. inversion H4 ; subst ; auto. exfalso ; apply H5 ; auto.
+                 rewrite permut_remove_remove_list in H3.
+                 assert (J0: NoDup (remove eq_dec_form a l4)). apply remove_preserv_NoDup ; auto.
+                 assert (J1: incl l3 (remove eq_dec_form a l4)). intro. intros. apply in_in_remove ; auto.
+                 intro ; subst ; auto.
+                 assert (J:length (remove_list l2 (remove eq_dec_form a l4)) < length (remove_list (remove eq_dec_form a l1) l3)).
+                 assert ((remove_list l1 l3) = (remove_list (remove eq_dec_form a l1) l3)).
+                 pose (redund_remove_remove_list a l1 l3). rewrite notin_remove in e.
+                 symmetry in e. rewrite notin_remove in e. auto.
+                 1-2: intro ; apply In_remove_list_In_list in H5 ; auto. rewrite H5 in H3. auto.
+                 pose (IHl2 (remove eq_dec_form a l1) _ _ J0 H0 H4 J1 J). destruct e. destruct H5.
+                 exists x ; split ; auto. intro. apply H6. apply in_in_remove ; auto. intro ; subst. auto.
+          -- assert (In a l3 -> False). intro. apply n0 ; auto. rewrite permut_remove_remove_list in H3.
+              rewrite notin_remove in H3 ; auto.
+              assert (incl (remove eq_dec_form a l1) l2). intro. intros. apply in_remove in H5. destruct H5.
+              apply H1 in H5. inversion H5 ; subst ; auto. exfalso ; apply H6 ; auto.
+              assert (length (remove_list l2 l4) < length (remove_list (remove eq_dec_form a l1) l3)).
+              pose (redund_remove_remove_list a l1 l3). rewrite notin_remove in e. rewrite e. rewrite notin_remove ; auto.
+              intro. apply In_remove_list_In_list in H6 ; auto. intro. apply In_remove_list_In_list in H6 ; auto.
+              pose (IHl2 (remove eq_dec_form a l1) _ _ H H0 H5 H2 H6). destruct e. destruct H7.
+              exists x ; split ; auto. intro. apply H8. apply in_in_remove ; auto. intro ; subst. auto.
+        * exists a ; split ; auto.
+  Qed.
+ +
+  End Diam_help.
+ +
+  Section list_conj_disj_properties.
+ +
+  Lemma AndL : forall s A B, KS_prv (A :: B :: fst s, snd s) -> KS_prv (And A B :: fst s, snd s).
+  Proof.
+  intros. unfold And. unfold Neg.
+  apply derI with (ps:=[([] ++ fst s, [] ++ (A --> B --> Bot) :: snd s); ([] ++ Bot :: fst s, [] ++ snd s)]).
+  apply ImpL. assert (((A --> B --> Bot) --> Bot :: fst s, snd s) = ([] ++ (A --> B --> Bot) --> Bot :: fst s, snd s)). auto.
+  rewrite H. apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+  apply derI with (ps:=[([] ++ A :: fst s, [] ++ B --> Bot :: snd s)]). apply ImpR. apply ImpRRule_I.
+  apply dlCons. 2: apply dlNil. apply derI with (ps:=[([A] ++ B :: fst s, [] ++ Bot :: snd s)]).
+  assert (([] ++ A :: fst s, [] ++ B --> Bot :: snd s) = ([A] ++ fst s, [] ++ B --> Bot :: snd s)). auto. rewrite H.
+  apply ImpR. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+  assert (J0: derrec_height X = derrec_height X). auto.
+  assert (J1: wkn_R Bot ([A] ++ B :: fst s, [] ++ snd s) ([A] ++ B :: fst s, [] ++ Bot :: snd s)). apply wkn_RI.
+  pose (KS_wkn_R _ _ X J0 _ _ J1). destruct s0. auto. apply derI with (ps:=[]). apply BotL. apply BotLRule_I.
+  apply dlNil.
+  Qed.
+ +
+  Lemma AndR : forall s A B, KS_prv (fst s, A :: snd s) -> KS_prv (fst s, B :: snd s) -> KS_prv (fst s, And A B :: snd s).
+  Proof.
+  intros. unfold And. unfold Neg.
+  apply derI with (ps:=[([] ++ A --> B --> Bot :: fst s, [] ++ Bot :: snd s)]).
+  apply ImpR. assert ((fst s, (A --> B --> Bot) --> Bot :: snd s) = ([] ++ fst s, [] ++ (A --> B --> Bot) --> Bot :: snd s)). auto.
+  rewrite H. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+  apply derI with (ps:=[([] ++ fst s, [] ++ A :: Bot :: snd s);([] ++ B --> Bot :: fst s, [] ++ Bot :: snd s)]). apply ImpL.
+  apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+  assert (J0: derrec_height X = derrec_height X). auto.
+  assert (J1: wkn_R Bot ([] ++ fst s, [A] ++ snd s) ([] ++ fst s, [A] ++ Bot :: snd s)). apply wkn_RI.
+  pose (KS_wkn_R _ _ X J0 _ _ J1). destruct s0. auto.
+  apply derI with (ps:=[([] ++ fst s, [] ++ B :: Bot :: snd s);([] ++ Bot :: fst s, [] ++ Bot :: snd s)]). apply ImpL.
+  apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+  assert (J0: derrec_height X0 = derrec_height X0). auto.
+  assert (J1: wkn_R Bot ([] ++ fst s, [B] ++ snd s) ([] ++ fst s, [B] ++ Bot :: snd s)). apply wkn_RI.
+  pose (KS_wkn_R _ _ X0 J0 _ _ J1). destruct s0. auto. apply derI with (ps:=[]). apply BotL. apply BotLRule_I.
+  apply dlNil.
+  Qed.
+ +
+  Lemma list_conj_wkn_L : forall l s A, InT A l -> KS_prv (A :: fst s, snd s) -> KS_prv (list_conj l :: fst s, snd s).
+  Proof.
+  induction l.
+  - intros. inversion H.
+  - intros. inversion H ; subst.
+    * simpl. apply AndL.
+      assert (J0: derrec_height X = derrec_height X). auto.
+      assert (J1: wkn_L (list_conj l) (A :: fst s, snd s) (A :: list_conj l :: fst s, snd s)).
+      assert (A :: fst s = [A] ++ fst s). auto. rewrite H0.
+      assert (A :: list_conj l :: fst s = [A] ++ list_conj l :: fst s). auto. rewrite H1. apply wkn_LI.
+      pose (KS_wkn_L _ _ X J0 _ _ J1). destruct s0. auto.
+    * simpl. apply IHl in X ; auto.
+      assert (J0: derrec_height X = derrec_height X). auto.
+      assert (J1: wkn_L a (list_conj l :: fst s, snd s) (a :: list_conj l :: fst s, snd s)).
+      assert (a :: list_conj l :: fst s = [] ++ a :: list_conj l :: fst s). auto. rewrite H0.
+      assert ((list_conj l :: fst s,snd s) = ([] ++ list_conj l :: fst s,snd s)). auto. rewrite H2. apply wkn_LI.
+      pose (KS_wkn_L _ _ X J0 _ _ J1). destruct s0. apply AndL ; auto.
+  Qed.
+ +
+  Lemma list_conj_R : forall l s, (forall A, InT A l -> KS_prv (fst s, A :: snd s)) -> KS_prv (fst s, list_conj l :: snd s).
+  Proof.
+  induction l.
+  - intros. simpl. unfold Top.
+    apply derI with (ps:=[([] ++ Bot :: fst s, [] ++ Bot :: snd s)]).
+    apply ImpR. assert ((fst s, Bot --> Bot :: snd s) = ([] ++ fst s, [] ++ Bot --> Bot :: snd s)). auto.
+    rewrite H. apply ImpRRule_I. apply dlCons. 2: apply dlNil. apply derI with (ps:=[]). apply BotL.
+    apply BotLRule_I. apply dlNil.
+  - intros. simpl. apply AndR.
+    * apply X. apply InT_eq.
+    * simpl. apply IHl. intros. apply X. apply InT_cons ; auto.
+  Qed.
+ +
+  Lemma OrL : forall s A B, KS_prv (A :: fst s, snd s) -> KS_prv (B :: fst s, snd s) -> KS_prv (Or A B :: fst s, snd s).
+  Proof.
+  intros. unfold Or. unfold Neg.
+  apply derI with (ps:=[([] ++ fst s, [] ++ (A --> Bot) :: snd s); ([] ++ B :: fst s, [] ++ snd s)]).
+  apply ImpL. assert (((A --> Bot) --> B :: fst s, snd s) = ([] ++ (A --> Bot) --> B :: fst s, snd s)). auto.
+  rewrite H. apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+  apply derI with (ps:=[([] ++ A :: fst s, [] ++ Bot :: snd s)]). apply ImpR. apply ImpRRule_I.
+  apply dlCons. 2: apply dlNil.
+  assert (J0: derrec_height X = derrec_height X). auto.
+  assert (J1: wkn_R Bot (A :: fst s, [] ++ snd s) (A :: fst s, [] ++ Bot :: snd s)). apply wkn_RI.
+  pose (KS_wkn_R _ _ X J0 _ _ J1). destruct s0. auto. auto.
+  Qed.
+ +
+  Lemma OrR : forall s A B, KS_prv (fst s, A :: B :: snd s) -> KS_prv (fst s, Or A B :: snd s).
+  Proof.
+  intros. unfold Or. unfold Neg.
+  apply derI with (ps:=[([] ++ (A --> Bot) :: fst s, [] ++ B :: snd s)]).
+  apply ImpR. assert ((fst s, (A --> Bot) --> B :: snd s) = (fst s, [] ++ (A --> Bot) --> B :: snd s)). auto.
+  rewrite H. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+  apply derI with (ps:=[([] ++ fst s, [] ++ A :: B :: snd s);([] ++ Bot :: fst s, [] ++ B :: snd s)]).
+  apply ImpL. apply ImpLRule_I.
+  apply dlCons. 2: apply dlCons. 3: apply dlNil. simpl ; auto.
+  apply derI with (ps:=[]). apply BotL. apply BotLRule_I. apply dlNil.
+  Qed.
+ +
+  Lemma list_disj_L : forall l s, (forall A, InT A l -> KS_prv (A :: fst s, snd s)) -> KS_prv (list_disj l :: fst s, snd s).
+  Proof.
+  induction l.
+  - intros. simpl. apply derI with (ps:=[]). apply BotL. assert ((Bot :: fst s, snd s) = ([] ++ Bot :: fst s, snd s)). auto.
+    rewrite H. apply BotLRule_I. apply dlNil.
+  - intros. simpl. apply OrL.
+    * apply X. apply InT_eq.
+    * simpl. apply IHl. intros. apply X. apply InT_cons ; auto.
+  Qed.
+ +
+  Lemma list_disj_wkn_R : forall l s A, InT A l -> KS_prv (fst s, A :: snd s) -> KS_prv (fst s, list_disj l :: snd s).
+  Proof.
+  induction l.
+  - intros. inversion H.
+  - intros. inversion H ; subst.
+    * simpl. apply OrR.
+      assert (J0: derrec_height X = derrec_height X). auto.
+      assert (J1: wkn_R (list_disj l) (fst s, A :: snd s) (fst s, A :: list_disj l :: snd s)).
+      assert (A :: snd s = [A] ++ snd s). auto. rewrite H0.
+      assert (A :: list_disj l :: snd s = [A] ++ list_disj l :: snd s). auto. rewrite H1. apply wkn_RI.
+      pose (KS_wkn_R _ _ X J0 _ _ J1). destruct s0. auto.
+    * simpl. apply IHl in X ; auto.
+      assert (J0: derrec_height X = derrec_height X). auto.
+      assert (J1: wkn_R a (fst s, list_disj l :: snd s) (fst s, a :: list_disj l :: snd s)).
+      assert (a :: list_disj l :: snd s = [] ++ a :: list_disj l :: snd s). auto. rewrite H0.
+      assert ((fst s, list_disj l :: snd s) = (fst s, [] ++ list_disj l :: snd s)). auto. rewrite H2. apply wkn_RI.
+      pose (KS_wkn_R _ _ X J0 _ _ J1). destruct s0. apply OrR ; auto.
+  Qed.
+ +
+  Lemma DiamL_lim : forall A Γ0 Δ, (is_Boxed_list ) ->
+                                                                      (nobox_gen_ext Γ0) ->
+                                                                      (KS_prv (A :: unboxed_list , [])) ->
+                                                                      (KS_prv (Diam A :: Γ0, Δ)).
+  Proof.
+  intros. unfold Diam. unfold Neg.
+  apply derI with (ps:=[([] ++ Γ0, [] ++ Box (A --> Bot) :: Δ);([] ++ Bot :: Γ0, [] ++ Δ)]).
+  apply ImpL. assert ((Box (A --> Bot) --> Bot :: Γ0, Δ) = ([] ++ Box (A --> Bot) --> Bot :: Γ0, [] ++ Δ)). auto.
+  rewrite H0. apply ImpLRule_I. apply dlCons. 2: apply dlCons. 3: apply dlNil.
+  2: apply derI with (ps:=[]) ; try apply dlNil ; try apply BotL ; apply BotLRule_I.
+  apply derI with (ps:=[(unboxed_list , [A --> Bot])]).
+  apply KR. apply KRRule_I ; auto. apply dlCons. 2: apply dlNil.
+  apply derI with (ps:=[([] ++ A :: unboxed_list , [] ++ Bot :: [])]).
+  apply ImpR. assert ((unboxed_list , [A --> Bot]) = ([] ++ unboxed_list , [] ++ A --> Bot :: [])). auto.
+  rewrite H0. apply ImpRRule_I. apply dlCons. 2: apply dlNil.
+  assert (J0: derrec_height X0 = derrec_height X0) ; auto.
+  assert (J3: wkn_R Bot (A :: unboxed_list , []%list) (A :: unboxed_list , [Bot])).
+  assert ((A :: unboxed_list , @nil MPropF) = (A :: unboxed_list , [] ++ [])).
+  rewrite app_nil_r. auto. rewrite H0.
+  assert ((A :: unboxed_list , [Bot]) = (A :: unboxed_list , [] ++ Bot :: [])). auto. rewrite H1.
+  apply wkn_RI. pose (KS_wkn_R _ _ X0 J0 _ _ J3). destruct s. simpl. auto.
+  Qed.
+ +
+  Lemma nobox_top_boxes : forall l, nobox_gen_ext (top_boxes l) l.
+  Proof.
+  induction l ; simpl ; auto. apply univ_gen_ext_nil. destruct a.
+  1-3: apply univ_gen_ext_extra ; auto ; intro ; inversion X ; inversion H.
+  apply univ_gen_ext_cons ; auto.
+  Qed.
+ +
+  Lemma is_init_Canopy : forall s, is_init s -> (forall leaf, InT leaf (Canopy s) -> is_init leaf).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros. apply fold_Canopy in H. destruct H ; subst ; auto.
+  destruct s0 ; destruct p. unfold inv_prems in i. apply InT_flatten_list_InT_elem in i. destruct i.
+  destruct p. destruct (finite_ImpRules_premises_of_S s). simpl in i1. subst.
+  apply p in i1. destruct i1.
+  - inversion i1 ; subst. inversion i ; subst. 2: inversion H0.
+    assert (J0: n_imp_subformS (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) < n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)).
+    unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+    lia. apply IHs with (leaf:=leaf) in J0 ; auto.
+    unfold is_init. destruct X.
+    left. inversion i2 ; subst. assert (InT (# P) (Γ0 ++ A :: Γ1)). apply InT_or_app.
+    assert (InT (# P) (Γ0 ++ Γ1)). rewrite <- H. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. right ; apply InT_cons ; auto. apply InT_split in H0. destruct H0. destruct s. rewrite e.
+    assert (InT (# P) (Δ0 ++ B :: Δ1)). apply InT_or_app.
+    assert (InT (# P) (Δ0 ++ A --> B :: Δ1)). rewrite <- H1. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. inversion i3 ; subst. inversion H2. right ; apply InT_cons ; auto. apply InT_split in H0. destruct H0. destruct s.
+    rewrite e0. apply IdPRule_I.
+    right. inversion b ; subst. assert (InT (Bot) (Γ0 ++ A :: Γ1)). apply InT_or_app.
+    assert (InT (Bot) (Γ0 ++ Γ1)). rewrite <- H. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. right ; apply InT_cons ; auto. apply InT_split in H0. destruct H0. destruct s. rewrite e. apply BotLRule_I.
+  - inversion i1 ; subst. inversion i ; subst. 2: inversion H0. 3: inversion H1.
+    assert (J0: n_imp_subformS (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+    unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+    lia. apply IHs with (leaf:=leaf) in J0 ; auto.
+    unfold is_init. destruct X.
+    left. inversion i2 ; subst. assert (InT (# P) (Γ0 ++ Γ1)). apply InT_or_app.
+    assert (InT (# P) (Γ0 ++ A --> B :: Γ1)). rewrite <- H. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. inversion i3 ; subst. inversion H2. auto. apply InT_split in H0. destruct H0. destruct s. rewrite e.
+    assert (InT (# P) (Δ0 ++ A :: Δ1)). apply InT_or_app.
+    assert (InT (# P) (Δ0 ++ Δ1)). rewrite <- H1. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. right ; apply InT_cons ; auto. apply InT_split in H0. destruct H0. destruct s.
+    rewrite e0. apply IdPRule_I.
+    right. inversion b ; subst. assert (InT (Bot) (Γ0 ++ Γ1)). apply InT_or_app.
+    assert (InT (Bot) (Γ0 ++ A --> B :: Γ1)). rewrite <- H. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H0.
+    destruct H0 ; auto. inversion i2 ; subst. inversion H1. auto. apply InT_split in H0. destruct H0. destruct s. rewrite e. apply BotLRule_I.
+    assert (J0: n_imp_subformS (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) < n_imp_subformS (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+    unfold n_imp_subformS. simpl. repeat rewrite n_imp_subformLF_dist_app. simpl ; repeat rewrite n_imp_subformLF_dist_app.
+    lia. subst. apply IHs with (leaf:=leaf) in J0 ; auto.
+    unfold is_init. destruct X.
+    left. inversion i2 ; subst. assert (InT (# P) (Γ0 ++ B :: Γ1)). apply InT_or_app.
+    assert (InT (# P) (Γ0 ++ A --> B :: Γ1)). rewrite <- H. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H1.
+    destruct H1 ; auto. inversion i3 ; subst. inversion H3. right ; apply InT_cons ; auto. apply InT_split in H1. destruct H1. destruct s. rewrite e.
+    apply IdPRule_I.
+    right. inversion b ; subst. assert (InT (Bot) (Γ0 ++ B :: Γ1)). apply InT_or_app.
+    assert (InT (Bot) (Γ0 ++ A --> B :: Γ1)). rewrite <- H. apply InT_or_app ; right ;apply InT_eq. apply InT_app_or in H1.
+    destruct H1 ; auto. inversion i2 ; subst. inversion H2. right ; apply InT_cons ; auto. apply InT_split in H1. destruct H1. destruct s. rewrite e. apply BotLRule_I.
+  Qed.
+ +
+  Lemma TopR : forall X Y0 Y1, KS_prv (X, Y0 ++ Top :: Y1).
+  Proof.
+  intros. unfold Top. apply derI with (ps:=[([] ++ Bot :: X, Y0 ++ Bot :: Y1)]).
+  apply ImpR. assert ((X, Y0 ++ Bot --> Bot :: Y1) = ([] ++ X, Y0 ++ Bot --> Bot :: Y1)). auto.
+  rewrite H. apply ImpRRule_I. apply dlCons. 2: apply dlNil. apply derI with (ps:=[]).
+  apply BotL. apply BotLRule_I. apply dlNil.
+  Qed.
+ +
+  Lemma TopL_remove : forall Y X0 X1, KS_prv (X0 ++ Top :: X1, Y) -> KS_prv (X0 ++ X1, Y).
+  Proof.
+  intros. assert (Y= [] ++ Y). auto. rewrite H. rewrite H in X. apply KS_cut_adm with (A:=Top) ; auto.
+  apply TopR.
+  Qed.
+ +
+  Theorem is_init_UI_equiv_Top : forall s, is_init s -> forall p X Y0 Y1, KS_prv (X, Y0 ++ Top --> (UI p s) :: Y1).
+  Proof.
+  intros. destruct (critical_Seq_dec s).
+  - assert (J0: GUI p s (UI p s)). apply UI_GUI ; auto.
+    pose (@GUI_inv_critic_init p s (UI p s) J0 c X). rewrite <- e.
+    apply derI with (ps:=[([] ++ Top :: X0, Y0 ++ Top :: Y1)]).
+    apply ImpR. epose (ImpRRule_I _ _ []). simpl in i ; apply i.
+    apply dlCons. 2: apply dlNil. apply TopR.
+  - assert (J0: GUI p s (UI p s)). apply UI_GUI ; auto.
+    assert (J1: Gimap (GUI p) (Canopy s) (map (UI p) (Canopy s))). apply Gimap_map. intros.
+    apply UI_GUI ; auto.
+    pose (@GUI_inv_not_critic p s (UI p s) (map (UI p) (Canopy s)) J0 f J1). rewrite <- e.
+    apply derI with (ps:=[([] ++ Top :: X0, Y0 ++ list_conj (map (UI p) (Canopy s)) :: Y1)]).
+    apply ImpR. epose (ImpRRule_I _ _ []). simpl in i ; apply i. apply dlCons. 2: apply dlNil. simpl.
+    apply KS_adm_list_exch_R with (s:=(Top :: X0, list_conj (map (UI p) (Canopy s)) :: Y0 ++ Y1)).
+    pose (list_conj_R (map (UI p) (Canopy s)) (Top :: X0, Y0 ++ Y1)). apply k. clear k.
+    intros. simpl. apply InT_map_iff in H. destruct H. destruct p0. subst.
+    assert (J2: GUI p x (UI p x)). apply UI_GUI ; auto.
+    assert (J3: critical_Seq x). apply Canopy_critical in i ; auto.
+    assert (J4: is_init x). apply is_init_Canopy in i ; auto.
+    pose (@GUI_inv_critic_init p x (UI p x) J2 J3 J4). rewrite <- e0. epose (TopR _ [] _). simpl in k ; apply k.
+    epose (list_exch_RI _ [] [_] Y0 [] _). simpl in l. apply l.
+  Qed.
+ +
+  Theorem is_init_UI : forall s, is_init s -> forall p X Y0 Y1, KS_prv (X, Y0 ++ UI p s :: Y1).
+  Proof.
+  intros. eapply is_init_UI_equiv_Top in X. apply ImpR_inv with (prem:=([] ++ Top :: X0, Y0 ++ UI p s :: Y1)) in X.
+  apply TopL_remove in X. simpl in X ; auto. assert ((X0, Y0 ++ Top --> UI p s :: Y1) = ([] ++ X0, Y0 ++ Top --> UI p s :: Y1)).
+  auto. rewrite H. apply ImpRRule_I.
+  Qed.
+ +
+  End list_conj_disj_properties.
+ +
+Section Canopy_lems.
+ +
+  Lemma inv_prems_measure : forall s0 s1, InT s1 (inv_prems s0) -> (measure s1 < measure s0).
+  Proof.
+  intros. unfold inv_prems in H. apply InT_flatten_list_InT_elem in H.
+  destruct H. destruct p. destruct (finite_ImpRules_premises_of_S s0). simpl in i0.
+  apply p in i0. destruct i0 ; inversion i0 ; subst. inversion i ; subst. unfold measure ; simpl.
+  repeat rewrite size_LF_dist_app ; simpl ; lia. inversion H0. inversion i ; subst.
+  unfold measure ; simpl ; repeat rewrite size_LF_dist_app ; simpl ; lia.
+  inversion H0 ; subst. unfold measure ; simpl ; repeat rewrite size_LF_dist_app ; simpl ; lia.
+  inversion H1.
+  Qed.
+ +
+  Lemma Canopy_measure: forall s0 s1, InT s1 (Canopy s0) -> ((s0 = s1) + (measure s1 < measure s0)).
+  Proof.
+  intros s ; induction on s as IHs with measure (measure s).
+  intros. remember (finite_ImpRules_premises_of_S s) as H0. destruct H0. destruct x.
+  - left. assert (Canopy s = [s]). apply irred_nil. unfold inv_prems ; rewrite <- HeqH0 ; auto.
+    rewrite H0 in H. inversion H ; subst ; auto. inversion H2.
+  - apply fold_Canopy in H. destruct H ; auto. right. destruct s0. destruct p0. apply IHs in i0.
+    destruct i0 ; subst ; auto. apply inv_prems_measure in i ; auto. apply inv_prems_measure in i. lia.
+    unfold inv_prems in i. apply InT_flatten_list_InT_elem in i.
+    destruct i. destruct p0. rewrite <- HeqH0 in i1. simpl in i1. apply p in i1. destruct i1 ; inversion i1 ; subst.
+    inversion i. subst. unfold measure ; simpl ; repeat rewrite size_LF_dist_app ; simpl ; lia.
+    inversion H0. inversion i ; subst. unfold measure ; simpl ; repeat rewrite size_LF_dist_app ; simpl ; lia.
+    inversion H0 ; subst. unfold measure ; simpl ; repeat rewrite size_LF_dist_app ; simpl ; lia.
+    inversion H1.
+  Qed.
+ +
+End Canopy_lems.
+ +
+
+
+ +
+ + + diff --git a/K.Interpolation.UIK_basics.html b/K.Interpolation.UIK_basics.html new file mode 100644 index 0000000..b3553b8 --- /dev/null +++ b/K.Interpolation.UIK_basics.html @@ -0,0 +1,293 @@ + + + + + + + + + + + + + +
+
+

K.Interpolation.UIK_basics

+ +
+  Require Import List Extraction.
+  Require Import Lia.
+ +
+  Require Import KS_export.
+ +
+Require Import UIK_Def_measure.
+Require Import UIK_Canopy.
+Require Import UIK_irred_short.
+ +
+Section Arithmetic.
+ +
+  Lemma lt_decT : forall m n, (m < n) + ((m < n) -> False).
+  Proof.
+  induction m ; destruct n. 1,3: right ; intro ; lia. left ; lia.
+  destruct (IHm n). left ; lia. right ; intro ; lia.
+  Qed.
+ +
+  End Arithmetic.
+ +
+  Section Logic_Abrv.
+ +
+  (* Conjunction of a list of formulas. *)
+ +
+  Fixpoint list_conj (l : list MPropF) : MPropF :=
+  match l with
+   | nil => Top
+   | h :: t => And h (list_conj t)
+  end.
+ +
+  (* Disjunction of a list of formulas. *)
+ +
+  Fixpoint list_disj (l : list MPropF) : MPropF :=
+  match l with
+   | nil => Bot
+   | h :: t => Or h (list_disj t)
+  end.
+ +
+  (* List of propositional variables in a formula. *)
+ +
+  Definition list_prop_F (A : MPropF) : list MPropF :=
+  match A with
+   | # P => [# P]
+   | _ => []
+  end.
+ +
+  (* List of propositional variables in a list of formula. *)
+ +
+  Fixpoint list_prop_LF (l : list MPropF) : list MPropF :=
+  match l with
+   | nil => []
+   | h :: t => (list_prop_F h) ++ (list_prop_LF t)
+  end.
+ +
+  Lemma list_prop_LF_In : forall l A, In A l -> (existsT2 p, A = # p) -> In A (list_prop_LF l).
+  Proof.
+  induction l ; auto. intros. simpl. destruct H0 ; subst. simpl in H. destruct H ; subst.
+  apply in_or_app ; left ; apply in_eq. apply in_or_app ; right. apply IHl ; auto. eexists ; auto.
+  Qed.
+ +
+  Lemma In_list_prop_LF : forall l A, In A (list_prop_LF l) -> In A l.
+  Proof.
+  induction l ; auto. intros. simpl. simpl in H. apply in_app_or in H ; destruct H.
+  left. destruct a ; simpl in H ; subst. destruct H ; auto ; try inversion H.
+  inversion H. 1,2: inversion H. right. apply IHl ; auto.
+  Qed.
+ +
+  Lemma In_list_prop_LF_bis : forall l A, In A (list_prop_LF l) -> ((In A l) * (existsT2 p, A = # p)).
+  Proof.
+  induction l ; auto ; intros. inversion H. simpl in H. split. apply In_list_prop_LF ; auto.
+  apply In_InT in H. apply InT_app_or in H ; destruct H.
+  destruct a ; simpl in i ; inversion i ; subst. eexists ; auto. inversion H0.
+  apply InT_In in i ; apply IHl in i ; destruct i ; auto.
+  Qed.
+ +
+  (* Restricted list of propositional variables. *)
+ +
+  Definition restr_list_prop p l : list MPropF := remove eq_dec_form (# p) (list_prop_LF l).
+ +
+  (* List of all premises through the KR rule for a sequent s.
+      Note that KR is not invertible. *)

+ +
+  Definition KR_prems (s : Seq) := flatten_list (proj1_sigT2 (finite_KR_premises_of_S s)).
+ +
+  (* Property of being an initial sequent. *)
+ +
+  Definition is_init s : Type := (IdPRule [] s) + (BotLRule [] s).
+ +
+  End Logic_Abrv.
+ +
+  Section Random.
+ +
+  Lemma InT_In_Seq: forall (s: Seq) l, (InT s l -> In s l) * (In s l -> InT s l).
+  Proof.
+  intros. split ; intros.
+  - apply InT_In ; auto.
+  - destruct s. apply In_InT_seqs ; auto.
+  Qed.
+ +
+  Lemma size_LF_nil_unbox_top_box : forall l, l <> nil ->
+      size_LF (unboxed_list (top_boxes l)) < size_LF l.
+  Proof.
+  induction l ; simpl ; auto ; intros.
+  - exfalso ; auto.
+  - destruct l.
+    + destruct a ; simpl ; lia.
+    + assert (m :: l <> []). intro H0 ; inversion H0. apply IHl in H0.
+       destruct a ; destruct m ; simpl in * ; try lia.
+  Qed.
+ +
+  End Random.
+ +
+  Section LtSeq_ind.
+ +
+  Definition LtSeq := fun s0 s1 => (lt (measure s0) (measure s1)).
+ +
+  Lemma wf_LtSeq : well_founded LtSeq.
+  Proof.
+  unfold LtSeq. apply Inverse_Image.wf_inverse_image.
+  apply Wf_nat.lt_wf.
+  Qed.
+ +
+  Variable (P : Seq -> Type).
+ +
+  Definition LtSeq_ind : (forall s0, (forall s1, LtSeq s1 s0 -> P s1) -> P s0) -> (forall s, P s).
+  Proof.
+  intros. induction s as [ s0 IHs0 ] using (well_founded_induction_type wf_LtSeq).
+  apply X; intros; apply IHs0 ; auto.
+  Defined.
+ +
+  End LtSeq_ind.
+ +
+  Section LtSeq_properties.
+ +
+  Theorem LtSeq_trans : forall x y z, LtSeq x y -> LtSeq y z -> LtSeq x z.
+  Proof.
+  unfold LtSeq. intros. lia.
+  Qed.
+ +
+  Lemma inv_prems_LtSeq : forall s0 s1, InT s1 (inv_prems s0) -> LtSeq s1 s0.
+  Proof.
+  intros. unfold inv_prems in H. apply InT_flatten_list_InT_elem in H.
+  destruct H. destruct p. destruct (finite_ImpRules_premises_of_S s0). simpl in i0.
+  apply p in i0. destruct i0 ; inversion i0 ; subst.
+  - inversion i ; subst. unfold LtSeq. unfold measure. simpl. repeat rewrite size_LF_dist_app ; simpl ; lia.
+    inversion H0.
+  - inversion i ; subst. unfold LtSeq. unfold measure. simpl. repeat rewrite size_LF_dist_app ; simpl ; lia.
+    inversion H0 ; subst. unfold LtSeq. unfold measure. simpl. repeat rewrite size_LF_dist_app ; simpl ; lia.
+    inversion H1.
+  Qed.
+ +
+  Lemma KR_prems_LtSeq : forall s0 s1, InT s1 (KR_prems s0) -> LtSeq s1 s0.
+  Proof.
+  intros s0 s1 H. unfold KR_prems in H. apply InT_flatten_list_InT_elem in H.
+  destruct H. destruct p. destruct (finite_KR_premises_of_S s0). simpl in i0.
+  apply p in i0. inversion i0 ; subst. unfold LtSeq.
+  unfold measure. inversion i ; subst. simpl. pose (nobox_gen_ext_top_boxes_identity X H).
+  rewrite e in *. pose (size_unboxed (top_boxes Γ0)). pose (size_top_boxes Γ0).
+  repeat rewrite size_LF_dist_app ; simpl. lia.
+  inversion H1.
+  Qed.
+ +
+  Lemma Canopy_nil : forall s0, (inv_prems s0 = []) -> (forall s1, InT s1 (Canopy s0) -> s1 = s0).
+  Proof.
+  intros. assert (Canopy s0 = [s0]). apply irred_nil. unfold inv_prems. unfold inv_prems in H. auto.
+  rewrite H1 in H0. inversion H0. subst. auto. inversion H3.
+  Qed.
+ +
+  Lemma Canopy_LtSeq: forall s0 s1, InT s1 (Canopy s0) -> ((s0 = s1) + (LtSeq s1 s0)).
+  Proof.
+  intros s ; induction on s as IHs with measure (n_imp_subformS s).
+  intros. remember (finite_ImpRules_premises_of_S s) as H0. destruct H0. destruct x.
+  - left. assert (Canopy s = [s]). apply irred_nil. unfold inv_prems ; rewrite <- HeqH0 ; auto.
+    rewrite H0 in H. inversion H ; subst ; auto. inversion H2.
+  - apply fold_Canopy in H. destruct H ; auto. right. destruct s0. destruct p0. apply IHs in i0.
+    destruct i0 ; subst ; auto. apply inv_prems_LtSeq in i ; auto. apply inv_prems_LtSeq in i.
+    apply (LtSeq_trans _ _ _ l0 i). unfold inv_prems in i. apply InT_flatten_list_InT_elem in i.
+    destruct i. destruct p0. rewrite <- HeqH0 in i1. simpl in i1. apply p in i1. destruct i1 ; inversion i1 ; subst.
+    inversion i. subst. unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+    inversion H0. inversion i ; subst. unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+    inversion H0 ; subst. unfold n_imp_subformS ; simpl ; repeat rewrite n_imp_subformLF_dist_app ; simpl ; lia.
+    inversion H1.
+  Qed.
+ +
+  End LtSeq_properties.
+ +
+  Section empty_seq.
+ +
+  Definition empty_seq_dec : forall (s: Seq), (s = ([],[])) + (s <> ([],[])).
+  Proof.
+  intros. destruct s. destruct l ; destruct l0 ; auto.
+  all: right ; intro H ; inversion H.
+  Defined.
+ +
+  Lemma not_init_empty_set : is_init ([],[]) -> False.
+  Proof.
+  intro. destruct X. inversion i. destruct Γ0 ; inversion H.
+  inversion b ; subst. destruct Γ0 ; inversion H.
+  Qed.
+ +
+  Lemma critical_empty_set : critical_Seq ([],[]).
+  Proof.
+  intros A HA ; simpl in *. inversion HA.
+  Qed.
+ +
+  End empty_seq.
+ +
+
+
+ +
+ + + diff --git a/K.Interpolation.UIK_braga.html b/K.Interpolation.UIK_braga.html new file mode 100644 index 0000000..3974311 --- /dev/null +++ b/K.Interpolation.UIK_braga.html @@ -0,0 +1,335 @@ + + + + + + + + + + + + + +
+
+

K.Interpolation.UIK_braga

+ +
+(**************************************************************)
+(*   Copyright Ian Shillito *                 *)
+(*                                                            *)
+(*                             * Affiliation ANU  *)
+(**************************************************************)
+(*      This file is distributed under the terms of the       *)
+(*         CeCILL v2.1 FREE SOFTWARE LICENSE AGREEMENT        *)
+(**************************************************************)
+ +
+
+ +
+Certification of uniform interpolant function (define below) + +
+ + +
+
+ +
+  Require Import List Extraction.
+  Require Import Lia.
+  Require Import String.
+ +
+  Require Import KS_export.
+ +
+  Require Import UIK_Def_measure.
+  Require Import UIK_Canopy.
+  Require Export UIK_basics.
+ +
+  Import ListNotations.
+ +
+  #[local] Infix "∈" := (@In _) (at level 70, no associativity).
+ +
+  Section imap.
+ +
+  Variables (X Y : Type)
+            (F : X -> Y -> Prop) (* We will instantiate F with GUI (to have mutal recursion). *)
+            (Ffun : forall x l m, F x l -> F x m -> l = m) (*Require that F is a function. *)
+            (D : X -> Prop) (* Domain of F *)
+            (f : forall x, D x -> sig (F x)). (* F is defined on the domain. *)
+ +
+  (* Proceed similarly as Dominique did with flatmap. *)
+ +
+  Inductive Gimap : list X -> list Y -> Prop :=
+    | Gim_nil : Gimap [] []
+    | Gim_cons {x y l m} : F x y
+                         -> Gimap l m
+                         -> Gimap (x::l) (y::m).
+ +
+  Hint Constructors Gimap : core.
+ +
+  Fact Gimap_inv_left l m :
+        Gimap l m
+      -> match l with
+        | [] => [] = m
+        | x::l => exists y m', F x y /\ Gimap l m' /\ m = y :: m'
+        end.
+  Proof. destruct 1; eauto. Qed.
+ +
+  Fact Gimap_inv_sg_left x m : Gimap [x] [m] -> F x m.
+  Proof.
+    intros. apply Gimap_inv_left in H. destruct H. destruct H. destruct H.
+    destruct H0. inversion H1. subst. auto.
+  Qed.
+ +
+  Fact Gimap_app_inv_left l1 l2 m :
+        Gimap (l1++l2) m
+      -> exists m1 m2, Gimap l1 m1 /\ Gimap l2 m2 /\ m = m1++m2.
+  Proof.
+    induction l1 as [ | x l1 IH1 ] in m |- *; simpl.
+    + exists [], m; auto.
+    + intros (y & m' & H1 & (m1 & m2 & H2 & H3 & ->)%IH1 & ->)%Gimap_inv_left.
+      exists (y::m1), m2. repeat split ; auto.
+  Qed.
+ +
+  Fixpoint imap l : (forall x, x l -> D x) -> sig (Gimap l).
+  Proof.
+    refine (match l with
+    | [] => fun _ => exist _ [] Gim_nil
+    | x::l => fun dl => let (y,hy) := f x _ in
+                    let (m,hm) := imap l _ in
+                    exist _ (y::m) (Gim_cons hy hm)
+    end); auto.
+    apply dl ; apply in_eq. intros. apply dl ; apply in_cons ; auto.
+  Defined.
+ +
+  Variables (g : X -> Y) (Hg : forall x, F x (g x)).
+ +
+  Fact Gimap_map l : Gimap l (map g l).
+  Proof. induction l; simpl; now constructor. Qed.
+ +
+  Fact Gimap_fun l0 : forall l1 l2, Gimap l0 l1 -> Gimap l0 l2 -> l1 = l2.
+  Proof. induction l0. intros. apply Gimap_inv_left in H. subst.
+             apply Gimap_inv_left in H0. auto. intros.
+             apply Gimap_inv_left in H. apply Gimap_inv_left in H0.
+             destruct H. destruct H. destruct H. destruct H1. destruct H0.
+             destruct H0. destruct H0. destruct H3. subst. pose (Ffun _ _ _ H H0).
+             rewrite e. pose (IHl0 _ _ H1 H3). rewrite e0. auto. Qed.
+ +
+  End imap.
+ +
+Arguments Gimap {X} {Y} _.
+Arguments imap {X} {Y} _ {D} _ {l}.
+ +
+  Section Gimap_cont.
+ +
+  Variables (X Y : Type)
+            (F : X -> Y -> Prop) (* We will instantiate F with GUI (to have mutal recursion). *)
+            (D : X -> Prop) (* Domain of F *)
+            (f : forall x, D x -> sig (F x)). (* F is defined on the domain. *)
+ +
+  Fact Gimap_fun_rest l0 : forall l1 l2, (forall x, InT x l0 -> forall y0 y1, F x y0 -> F x y1 -> y0 = y1) -> Gimap F l0 l1 -> Gimap F l0 l2 -> l1 = l2.
+  Proof. induction l0. intros l1 l2 Dom H H0. apply Gimap_inv_left in H. subst.
+             apply Gimap_inv_left in H0. auto. intros l1 l2 Dom H H0.
+             apply Gimap_inv_left in H. apply Gimap_inv_left in H0.
+             destruct H. destruct H. destruct H. destruct H1. destruct H0.
+             destruct H0. destruct H0. destruct H3. subst.
+             assert (J0: InT a (a :: l0)). apply InT_eq.
+             pose (Dom _ J0 _ _ H H0). rewrite e.
+             assert (J1: forall x : X, InT x l0 -> forall y0 y1 : Y, F x y0 -> F x y1 -> y0 = y1).
+             intros. apply Dom with (x:=x3) ; auto. apply InT_cons ; auto.
+             pose (IHl0 _ _ J1 H1 H3). rewrite e0. auto. Qed.
+ +
+  End Gimap_cont.
+ +
+  Section UI.
+ +
+  (* I define the graph of the function UI. *)
+ +
+  Variables (p : string). (* The variable we exclude from the interpolant. *)
+ +
+  Unset Elimination Schemes.
+ +
+  Inductive GUI : Seq -> MPropF -> Prop :=
+    | GUI_empty_seq {s} : (s = ([],[])) -> (* If the sequent is empty, output Bot. *)
+                                      GUI s Bot
+    | GUI_critic_init {s} : critical_Seq s -> (* If critical and initial, output Top. *)
+                                      is_init s ->
+                                      GUI s Top
+    | GUI_not_critic {s l} : ((critical_Seq s) -> False) -> (* If not critical, output conjunction of recursive calls of GUI on Canopy. *)
+                                      (Gimap GUI (Canopy s) l) ->
+                                      GUI s (list_conj l)
+    | GUI_critic_not_init {s l A} : critical_Seq s -> (* If critical but not initial, store the propositional variables, recursively call on
+                                                                                                               the KR premises of the sequent, and consider the diamond jump. *)

+                                           (s <> ([],[])) ->
+                                           (is_init s -> False) ->
+                                           (Gimap GUI (KR_prems s) l) ->
+                                           (GUI (unboxed_list (top_boxes (fst s)), []) A) ->
+                                           GUI s (Or (list_disj (restr_list_prop p (snd s)))
+                                                     (Or (list_disj (map Neg (restr_list_prop p (fst s))))
+                                                     (Or (list_disj (map Box l))
+                                                     (Diam A)))).
+ +
Set Elimination Schemes.
+ +
+  Lemma GUI_fun : forall x l m, GUI x l -> GUI x m -> l = m.
+  Proof.
+  apply (LtSeq_ind (fun x => forall l m, GUI x l -> GUI x m -> l = m)).
+  intros s IH l m H H0. subst. inversion H ; inversion H0 ; subst ; auto ; simpl in *. 1-8: exfalso ; auto.
+  6-9: exfalso ; auto. 1,3: apply not_init_empty_set ; auto. apply H4 ; apply critical_empty_set.
+  apply H1 ; apply critical_empty_set.
+  - assert (J0: (forall x : Seq, InT x (Canopy s) -> forall y0 y1 : MPropF, GUI x y0 -> GUI x y1 -> y0 = y1)).
+    intros. apply IH with (s1:=x) ; auto. destruct (Canopy_LtSeq s x H3) ; subst ; auto.
+    exfalso. apply H1. apply Canopy_critical with (s:=x) ; subst ; auto.
+    pose (Gimap_fun_rest _ _ GUI (Canopy s) l0 l1 J0). rewrite e ; auto.
+  - assert (J0: list_disj (map Box l0) = list_disj (map Box l1)).
+    assert (J00: (forall x : Seq, InT x (KR_prems s) -> forall y0 y1 : MPropF, GUI x y0 -> GUI x y1 -> y0 = y1)).
+    intros. apply IH with (s1:=x) ; auto. apply KR_prems_LtSeq ; auto.
+    pose (Gimap_fun_rest _ _ GUI (KR_prems s) l0 l1 J00). rewrite e ; auto.
+    assert (J1: A = A0).
+    { destruct (eq_dec_listsF (fst s) []) ; subst.
+       - rewrite e in * ; simpl in *. inversion H12 ; inversion H5 ; subst ; auto.
+         1-14: exfalso ; auto. 1,3: apply not_init_empty_set ; auto.
+         1-3: pose critical_empty_set ; auto.
+       - apply IH with (s1:=(unboxed_list (top_boxes (fst s)), [])) ; auto.
+         unfold LtSeq. unfold measure ; simpl.
+         pose (size_LF_nil_unbox_top_box _ n). lia. }
+    subst. rewrite J0. auto.
+  Qed.
+ +
+  Definition GUI_tot : forall s : Seq, {A : MPropF | GUI s A}.
+  Proof.
+  apply (LtSeq_ind (fun x => existsT A : MPropF, GUI x A)).
+  intros s IH. destruct (empty_seq_dec s).
+  - subst. exists Bot. apply GUI_empty_seq ; auto.
+  - destruct (critical_Seq_dec s).
+    -- destruct (dec_KS_init_rules s).
+      * assert (is_init s) ; auto. exists Top. apply GUI_critic_init ; auto.
+      * assert (is_init s -> False) ; auto.
+        assert ((forall x : Seq, In x (KR_prems s) -> {x0 : MPropF | GUI x x0})).
+        intros. apply IH with (s1:=x) ; auto. apply KR_prems_LtSeq ; auto. apply InT_In_Seq ; auto.
+        epose (@imap _ _ GUI (fun (x : Seq) => In x (KR_prems s)) H0 (KR_prems s)). simpl in s0. destruct s0 ; auto.
+        destruct (eq_dec_listsF (fst s) []).
+        + exists (Or (list_disj (restr_list_prop p (snd s))) (Or (list_disj (map Neg (restr_list_prop p (fst s))))
+           (Or (list_disj (map Box x)) (Diam Bot)))). apply GUI_critic_not_init ; auto. rewrite e ; simpl.
+           apply GUI_empty_seq ; auto.
+        + assert (J10: existsT A : MPropF, GUI (unboxed_list (top_boxes (fst s)), []%list) A). apply IH.
+           unfold LtSeq. unfold measure. simpl. pose (size_LF_nil_unbox_top_box (fst s) n0). lia. destruct J10.
+           exists (Or (list_disj (restr_list_prop p (snd s))) (Or (list_disj (map Neg (restr_list_prop p (fst s))))
+           (Or (list_disj (map Box x)) (Diam x0)))). apply GUI_critic_not_init ; auto.
+    -- assert ((forall x : Seq, In x (Canopy s) -> {x0 : MPropF | GUI x x0})).
+      intros. apply IH with (s1:=x) ; auto. destruct (Canopy_LtSeq s x) ; auto.
+      apply InT_In_Seq ; auto. subst. exfalso. apply f. apply InT_In_Seq in H ; apply Canopy_critical in H ; auto.
+      epose (@imap _ _ GUI (fun (x : Seq) => In x (Canopy s)) H (Canopy s)). simpl in s0. destruct s0 ; auto.
+      exists (list_conj x). apply GUI_not_critic ; auto.
+  Defined.
+ +
+  Fact GUI_inv_empty_seq {s A} : GUI s A -> s = ([],[]) -> Bot = A.
+  Proof. intros. pose (GUI_empty_seq H0). apply (GUI_fun _ _ _ g H). Qed.
+ +
+  Fact GUI_inv_critic_init {s A} : GUI s A -> critical_Seq s -> is_init s -> Top = A.
+  Proof. intros. pose (GUI_critic_init H0 X). apply (GUI_fun _ _ _ g H). Qed.
+ +
+  Fact GUI_inv_not_critic {s A l} : GUI s A -> (critical_Seq s -> False) ->
+                           (Gimap GUI (Canopy s) l) ->
+                           ((list_conj l) = A).
+  Proof.
+  intros. pose (GUI_not_critic H0 H1). apply (GUI_fun _ _ _ g H).
+  Qed.
+ +
+  Fact GUI_inv_critic_not_init {s A B l0 } : GUI s A -> critical_Seq s ->
+                           (s <> ([],[])) ->
+                           (is_init s -> False) ->
+                           (Gimap GUI (KR_prems s) l0) ->
+                           (GUI (unboxed_list (top_boxes (fst s)), []) B) ->
+                           ((Or (list_disj (restr_list_prop p (snd s)))
+                                                     (Or (list_disj (map Neg (restr_list_prop p (fst s))))
+                                                     (Or (list_disj (map Box l0))
+                                                     (Diam B)))) = A).
+  Proof.
+  intros. pose (GUI_critic_not_init H0 H1 H2 H3 H4). apply (GUI_fun _ _ _ g H).
+  Qed.
+ +
+  Let UI_pwc : forall x, sig (GUI x).
+  Proof.
+  apply GUI_tot.
+  Qed.
+ +
+  Definition UI x := proj1_sig (UI_pwc x).
+ +
+  Fact UI_spec x : GUI x (UI x).
+  Proof. apply (proj2_sig _). Qed.
+ +
+  Lemma UI_GUI : forall x A, UI x = A <-> GUI x A.
+  Proof.
+  intros. split ; intro ; subst.
+  apply UI_spec. unfold UI. destruct UI_pwc. simpl.
+  apply GUI_fun with (x:=x) ; auto.
+  Qed.
+ +
+  End UI.
+ +
+
+
+ +
+ + + diff --git a/K.Interpolation.UIK_irred_high_level.html b/K.Interpolation.UIK_irred_high_level.html new file mode 100644 index 0000000..d961971 --- /dev/null +++ b/K.Interpolation.UIK_irred_high_level.html @@ -0,0 +1,144 @@ + + + + + + + + + + + + + +
+
+

K.Interpolation.UIK_irred_high_level

+ +
+(**************************************************************)
+(*   Copyright Dominique Larchey-Wendling *                 *)
+(*                                                            *)
+(*                             * Affiliation LORIA -- CNRS  *)
+(**************************************************************)
+(*      This file is distributed under the terms of the       *)
+(*         CeCILL v2.1 FREE SOFTWARE LICENSE AGREEMENT        *)
+(**************************************************************)
+ +
+Require Import List Relations Utf8.
+ +
+Import ListNotations.
+ +
+#[local] Infix "∈" := (@In _) (at level 70, no associativity).
+ +
+Definition list_is_nil {X} (l : list X) : { l = [] } + { l [] }.
+Proof. now destruct l; [ left | right ]. Qed.
+ +
+Section irred_high_level.
+ +
+  Variables (X : Type)
+            (f : X list X)
+            (f_wf : well_founded (λ u v, u f v))
+            (irred : X list X)
+            (irred_nil : x, f x = [] irred x = [x])
+            (irred_not : x, f x [] irred x = flat_map irred (f x))
+            .
+ +
+  Fact irred_max x y : y irred x f y = [].
+  Proof.
+    induction (f_wf x) as [ x _ IHx ] in y.
+    destruct (list_is_nil (f x)) as [ H | H ].
+    + rewrite irred_nil; auto.
+      now intros [ <- | [] ].
+    + rewrite irred_not, in_flat_map; auto.
+      intros (z & ? & ?); eauto.
+  Qed.
+ +
+  Fact irred_reach x y : y irred x clos_refl_trans _ (λ u v, u f v) y x.
+  Proof.
+    induction (f_wf x) as [ x _ IHx ] in y.
+    destruct (list_is_nil (f x)) as [ H | H ].
+    + rewrite irred_nil; auto.
+      intros [ <- | [] ]; constructor 2.
+    + rewrite irred_not, in_flat_map; auto.
+      intros (z & Hz1 & Hz2).
+      constructor 3 with z; auto.
+      now constructor 1.
+  Qed.
+ +
+  Hint Resolve in_eq : core.
+ +
+  Theorem irred_high_level_spec x y : y irred x f y = [] clos_refl_trans _ (λ u v, u f v) y x.
+  Proof.
+    split.
+    + split.
+      * now apply irred_max with x.
+      * now apply irred_reach.
+    + intros (H1 & H2); revert H2 H1.
+      rewrite clos_rt_rtn1_iff.
+      induction 1 as [ | x z H1 H2 IH2 ]; intros H.
+      * rewrite irred_nil; auto.
+      * rewrite irred_not, in_flat_map.
+        - exists x; auto.
+        - now intros e; rewrite e in H1.
+  Qed.
+ +
+  Section provability.
+ +
+    Variables (P : X Prop)
+              (HP : x, f x [] P x Forall P (f x)).
+ +
+    Theorem irred_provability x : P x Forall P (irred x).
+    Proof.
+      induction (f_wf x) as [ x _ IHx ].
+      destruct (list_is_nil (f x)) as [ H | H ].
+      + rewrite irred_nil; auto.
+        split.
+        * repeat (constructor; auto).
+        * now inversion 1.
+      + rewrite irred_not; auto.
+        rewrite Forall_flat_map, HP; auto.
+        rewrite !Forall_forall.
+        split; firstorder.
+    Qed.
+ +
+  End provability.
+ +
+End irred_high_level.
+
+
+ +
+ + + diff --git a/K.Interpolation.UIK_irred_short.html b/K.Interpolation.UIK_irred_short.html new file mode 100644 index 0000000..9de8983 --- /dev/null +++ b/K.Interpolation.UIK_irred_short.html @@ -0,0 +1,332 @@ + + + + + + + + + + + + + +
+
+

K.Interpolation.UIK_irred_short

+ +
+(**************************************************************)
+(*   Copyright Dominique Larchey-Wendling *                 *)
+(*                                                            *)
+(*                             * Affiliation LORIA -- CNRS  *)
+(**************************************************************)
+(*      This file is distributed under the terms of the       *)
+(*         CeCILL v2.1 FREE SOFTWARE LICENSE AGREEMENT        *)
+(**************************************************************)
+ +
+
+ +
+Certification of + +
+ + let rec flatmap f = function + | -> + | x::l -> f x ++ flatmap f l + +
+ + let rec irred f x = + match f x with + | -> x + | _ -> flatmap (irred f) (f x) + +
+ + by extraction. + +
+ + Following a question by Ian Schillito + Also look at the following PR + +
+ + https://github.com/DmxLarchey/Kruskal-Trees/pull/5 + +
+ + +
+
+ +
+(* 
+   This is a standalone file, directly compile with
+
+      coqc irred.v 
+ *)

+ +
+Require Import List Utf8 Extraction.
+Import ListNotations.
+ +
+#[local] Infix "∈" := (@In _) (at level 70, no associativity).
+#[local] Hint Resolve in_eq in_cons : core.
+ +
+Definition list_is_nil {X} (l : list X) : { l = [] } + { l [] }.
+Proof. now destruct l; [ left | right ]. Defined.
+ +
+
+ +
+Directly via Fix_F after cleaning up from Braga using + the domain Dirred := Acc (λ u v, u ∈ f v) directly +
+
+Section flatmap.
+ +
+  Variables (X : Type)
+            (F : X list X Prop)
+            (D : X Prop)
+            (f : x, D x sig (F x)).
+ +
+  Implicit Type (l : list X).
+ +
+  Inductive Gflatmap : list X list X Prop :=
+    | Gfm_nil : Gflatmap [] []
+    | Gfm_cons {x y l m} : F x y
+                          Gflatmap l m
+                          Gflatmap (x::l) (y++m).
+ +
+  Hint Constructors Gflatmap : core.
+ +
+  Fact Gflatmap_inv_left l m :
+        Gflatmap l m
+       match l with
+        | [] => [] = m
+        | x::l => y m', F x y Gflatmap l m' m = y++m'
+        end.
+  Proof. destruct 1; eauto. Qed.
+ +
+  Fact Gflatmap_inv_sg_left x m : Gflatmap [x] m F x m.
+  Proof.
+    intros (y & ? & ? & <-%Gflatmap_inv_left & ->)%Gflatmap_inv_left.
+    now rewrite app_nil_r.
+  Qed.
+ +
+  Fact Gflatmap_app_inv_left l1 l2 m :
+        Gflatmap (l1++l2) m
+       m1 m2, Gflatmap l1 m1 Gflatmap l2 m2 m = m1++m2.
+  Proof.
+    induction l1 as [ | x l1 IH1 ] in m |- *; simpl.
+    + exists [], m; auto.
+    + intros (y & m' & H1 & (m1 & m2 & H2 & H3 & ->)%IH1 & ->)%Gflatmap_inv_left.
+      exists (y++m1), m2; rewrite app_assoc; auto.
+  Qed.
+ +
+  Fixpoint flatmap l : (x, x l D x) sig (Gflatmap l).
+  Proof.
+    refine (match l with
+    | [] => λ _ , exist _ [] Gfm_nil
+    | x::l => λ dl, let (y,hy) := f x _ in
+                    let (m,hm) := flatmap l _ in
+                    exist _ (y++m) (Gfm_cons hy hm)
+    end); auto.
+  Defined.
+ +
+  Variables (g : X list X) (Hg : x, F x (g x)).
+ +
+  Fact Gflatmap_flat_map l : Gflatmap l (flat_map g l).
+  Proof. induction l; simpl; now constructor. Qed.
+ +
+End flatmap.
+ +
+Arguments Gflatmap {X} _.
+Arguments flatmap {X} _ {D} _ {l}.
+ +
+Section irred.
+ +
+  Variables (X : Type) (f : X list X).
+ +
+  Implicit Type l : list X.
+ +
+  Unset Elimination Schemes.
+ +
+
+ +
+Because of nesting, induction principles are too weak, + see below for better ones +
+
+ +
+  Inductive Girred : X list X Prop :=
+    | Girred_nil {x} : f x = []
+                        Girred x [x]
+    | Girred_not {x l} : f x []
+                        Gflatmap Girred (f x) l
+                        Girred x l.
+ +
+  Set Elimination Schemes.
+ +
+  Fact Girred_inv_nil {x l} : Girred x l f x = [] [x] = l.
+  Proof. destruct 1 as [ | ? ? Hx ]; intros; trivial; now destruct Hx. Qed.
+ +
+  Fact Girred_inv_not {x l} : Girred x l f x [] Gflatmap Girred (f x) l.
+  Proof. destruct 1; intros G; trivial; now destruct G. Defined.
+ +
+  Hint Constructors Gflatmap Girred : core.
+  Hint Resolve Girred_inv_nil Girred_inv_not : core.
+ +
+  Section Girred_ind.
+ +
+    Variables (P : list X list X Prop)
+              (Q : X list X Prop)
+
+              (HP0 : P [] [])
+              (HP1 : x y l m, Girred x y Q x y Gflatmap Girred l m P l m P (x::l) (y++m))
+
+              (HQ0 : x, f x = [] Q x [x])
+              (HQ1 : x m, f x [] Gflatmap Girred (f x) m P (f x) m Q x m).
+ +
+    Fixpoint Girred_ind x m (dxm : Girred x m) { struct dxm } : Q x m.
+    Proof.
+      destruct (list_is_nil (f x)) as [ H | H ].
+      + destruct (Girred_inv_nil dxm H); auto.
+      + apply HQ1; auto.
+        generalize (Girred_inv_not dxm H).
+        clear dxm H.
+        induction 1; eauto.
+    Qed.
+ +
+  End Girred_ind.
+ +
+  Lemma Girred_fun : x l, Girred x l (λ x l, m, Girred x m l = m) x l.
+  Proof.
+    (* the property which is proved for (Gflatmap Girred) cannot be guessed by unification *)
+    apply Girred_ind with (P := fun l m1 => m2, Gflatmap Girred l m2 m1 = m2); eauto.
+    + now intros ? ?%Gflatmap_inv_left.
+    + intros ? ? ? ? ? ? ? ? ? (y' & m' & ? & ? & ->)%Gflatmap_inv_left; f_equal; eauto.
+  Qed.
+ +
+
+ +
+We build irred packed with conformity to Girred by Fix_F + induction over Acc (λ u v, u ∈ f v) x directly +
+
+  Let irred_pwc : x (dx : Acc (λ u v, u f v) x), sig (Girred x).
+  Proof.
+    refine (Fix_F _ (λ x irred_pwc,
+      match list_is_nil (f x) with
+      | left Hxf => exist _ [x] _
+      | right Hxf => let (m,hm) := flatmap Girred irred_pwc (λ _ h, h) in
+                     exist _ m _
+      end)); auto.
+  Defined.
+ +
+
+ +
+Now we can instanciate for _ ∈ f _ is well founded + and define irred as a total function +
+
+ +
+  Hypothesis hf : well_founded (λ u v, u f v).
+ +
+  Definition irred x := proj1_sig (irred_pwc x (hf x)).
+ +
+  Fact irred_spec x : Girred x (irred x).
+  Proof. apply (proj2_sig _). Qed.
+ +
+  Hint Resolve irred_spec : core.
+ +
+
+ +
+We conclude with fixpoint equations +
+
+ +
+  Fact irred_nil x : f x = [] irred x = [x].
+  Proof. intros; eapply Girred_fun; eauto. Qed.
+ +
+  Hint Resolve Gflatmap_flat_map : core.
+ +
+  Fact irred_not x : f x [] irred x = flat_map irred (f x).
+  Proof. intros; eapply Girred_fun; eauto. Qed.
+ +
+End irred.
+ +
+Arguments Girred {X}.
+Arguments irred {X f}.
+
+
+ +
+ + + diff --git a/K.KS.KS_additive_cut.html b/K.KS.KS_additive_cut.html new file mode 100644 index 0000000..c436e3a --- /dev/null +++ b/K.KS.KS_additive_cut.html @@ -0,0 +1,668 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_additive_cut

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat Arith.
+ +
+Require Import KS_calc.
+Require Import KS_termination_measure.
+Require Import KS_termination.
+Require Import KS_exch.
+Require Import KS_ctr.
+Require Import KS_wkn.
+Require Import KS_dec.
+Require Import KS_inv_ImpR_ImpL.
+ +
+Theorem KS_cut_adm_main : forall n k A s Γ0 Γ1 Δ0 Δ1,
+                      (n = size A) ->
+                      (k = mhd s) ->
+                      (s = (Γ0 ++ Γ1, Δ0 ++ Δ1)) ->
+                      (KS_prv (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)) ->
+                      (KS_prv (Γ0 ++ A :: Γ1, Δ0 ++ Δ1)) ->
+                      (KS_prv s).
+Proof.
+induction n as [n PIH] using (well_founded_induction_type lt_wf).
+induction k as [k SIH] using (well_founded_induction_type lt_wf).
+assert (DersNilF: dersrec KS_rules (fun _ : Seq => False) []).
+apply dersrec_nil.
+assert (DersNilT: dersrec KS_rules (fun _ : Seq => True) []).
+apply dersrec_nil.
+ +
+intros A s Γ0 Γ1 Δ0 Δ1 size MHD E D0 D1. inversion D0. inversion H.
+inversion D1. inversion H0.
+ +
+inversion X ; subst.
+ +
+(* Left rule is IdP *)
+- inversion H1. subst. apply list_split_form in H3. destruct H3.
+  * destruct s.
+    + repeat destruct p. subst. inversion X1.
+    (* Right rule is IdP *)
+    { inversion H. subst. assert (J0 : InT (# P0) (Γ0 ++ # P :: Γ1)). rewrite <- H6. apply InT_or_app.
+      right. apply InT_eq. apply InT_app_or in J0. destruct J0.
+      - apply InT_split in i. destruct i. destruct s. subst. rewrite H2. repeat rewrite <- app_assoc.
+        assert (IdPRule [] (x ++ (# P0 :: x0) ++ Γ1, Δ2 ++ # P0 :: Δ3)). apply IdPRule_I. apply IdP in H0.
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (x ++ (# P0 :: x0) ++ Γ1, Δ2 ++ # P0 :: Δ3) H0 DersNilF). assumption.
+      - inversion i.
+        + inversion H3. subst.
+          assert (IdPRule [] (Γ2 ++ # P0 :: Γ3, Δ2 ++ # P0 :: Δ3)). apply IdPRule_I. apply IdP in H0.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) (Γ2 ++ # P0 :: Γ3, Δ2 ++ # P0 :: Δ3) H0 DersNilF). assumption.
+        + apply InT_split in H3. destruct H3. destruct s. subst.
+          assert (J0 : InT (# P0) (Γ2 ++ # P :: Γ3)). rewrite H2. apply InT_or_app.
+          right. apply InT_or_app. right. apply InT_eq. apply InT_split in J0. destruct J0. destruct s.
+          rewrite e. assert (IdPRule [] (x1 ++ # P0 :: x2, Δ2 ++ # P0 :: Δ3)).
+          apply IdPRule_I. apply IdP in H0.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) (x1 ++ # P0 :: x2, Δ2 ++ # P0 :: Δ3) H0 DersNilF). assumption. }
+    (* Right rule is BotL *)
+    { inversion H. subst. assert (J0 : InT (Bot) (Γ0 ++ # P :: Γ1)). rewrite <- H6. apply InT_or_app.
+      right. apply InT_eq. apply InT_app_or in J0. destruct J0.
+      - apply InT_split in i. destruct i. destruct s. subst. rewrite H2. rewrite <- app_assoc.
+        assert (BotLRule [] (x ++ (Bot :: x0) ++ Γ1, Δ0 ++ Δ1)). apply BotLRule_I. apply BotL in H0.
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (x ++ (Bot :: x0) ++ Γ1, Δ0 ++ Δ1) H0 DersNilF). assumption.
+      - inversion i.
+        + inversion H3.
+        + apply InT_split in H3. destruct H3. destruct s. subst. rewrite H2. rewrite app_assoc.
+          assert (BotLRule [] ((Γ0 ++ x) ++ Bot :: x0, Δ0 ++ Δ1)). apply BotLRule_I. apply BotL in H0.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ0 ++ x) ++ Bot :: x0, Δ0 ++ Δ1) H0 DersNilF). assumption. }
+    (* Right rule is ImpR *)
+    { inversion H. subst. assert (InT # P (Γ0 ++ Γ1)). rewrite <- H2. apply InT_or_app.
+      right. apply InT_eq. apply InT_app_or in H0. destruct H0.
+      - apply InT_split in i. destruct i.
+        destruct s. subst. repeat rewrite <- app_assoc in D1. simpl in D1.
+        assert (E0: derrec_height D1 = derrec_height D1). reflexivity.
+        assert (J0 : ctr_L # P (x ++ # P :: x0 ++ # P :: Γ1, Δ0 ++ Δ1)
+        (x ++ # P :: x0 ++ Γ1, Δ0 ++ Δ1)). apply ctr_LI.
+        pose (@KS_hpadm_ctr_L (derrec_height D1) (x ++ # P :: x0 ++ # P :: Γ1, Δ0 ++ Δ1)
+        D1 E0 (x ++ # P :: x0 ++ Γ1, Δ0 ++ Δ1) (# P) J0). destruct s. clear l. rewrite H2.
+        rewrite <- app_assoc. rewrite H7. assumption.
+      - apply InT_split in i. destruct i. destruct s. subst.
+        assert (E0: derrec_height D1 = derrec_height D1). reflexivity.
+        assert (J0 : ctr_L # P (Γ0 ++ # P :: x ++ # P :: x0, Δ0 ++ Δ1)
+        (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1)). apply ctr_LI.
+        pose (@KS_hpadm_ctr_L (derrec_height D1) (Γ0 ++ # P :: x ++ # P :: x0, Δ0 ++ Δ1)
+        D1 E0 (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1) (# P) J0). destruct s. clear l. rewrite H2.
+        assert (J5 : list_exch_L (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1) (Γ0 ++ x ++ # P :: x0, Δ0 ++ Δ1)).
+        assert (Γ0 ++ # P :: x ++ x0 = Γ0 ++ [# P] ++ x ++ [] ++ x0). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ x ++ # P :: x0 = Γ0 ++ [] ++ x ++ [# P] ++ x0). reflexivity. rewrite H0. clear H0.
+        apply list_exch_LI. pose (KS_adm_list_exch_L _ x1 _ J5). rewrite H7. assumption. }
+    (* Right rule is ImpL *)
+    { inversion H. subst. assert (InT # P (Γ0 ++ Γ1)). rewrite <- H2. apply InT_or_app.
+      right. apply InT_eq. apply InT_app_or in H0. destruct H0.
+      - apply InT_split in i. destruct i.
+        destruct s. subst. repeat rewrite <- app_assoc in D1. simpl in D1.
+        assert (E0: derrec_height D1 = derrec_height D1). reflexivity.
+        assert (J0 : ctr_L # P (x ++ # P :: x0 ++ # P :: Γ1, Δ0 ++ Δ1)
+        (x ++ # P :: x0 ++ Γ1, Δ0 ++ Δ1)). apply ctr_LI.
+        pose (@KS_hpadm_ctr_L (derrec_height D1) (x ++ # P :: x0 ++ # P :: Γ1, Δ0 ++ Δ1)
+        D1 E0 (x ++ # P :: x0 ++ Γ1, Δ0 ++ Δ1) (# P) J0). destruct s. clear l. rewrite H2.
+        rewrite <- app_assoc. rewrite H7. assumption.
+      - apply InT_split in i. destruct i. destruct s. subst.
+        assert (E0: derrec_height D1 = derrec_height D1). reflexivity.
+        assert (J0 : ctr_L # P (Γ0 ++ # P :: x ++ # P :: x0, Δ0 ++ Δ1)
+        (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1)). apply ctr_LI.
+        pose (@KS_hpadm_ctr_L (derrec_height D1) (Γ0 ++ # P :: x ++ # P :: x0, Δ0 ++ Δ1)
+        D1 E0 (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1) (# P) J0). destruct s. clear l. rewrite H2.
+        assert (J5 : list_exch_L (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1) (Γ0 ++ x ++ # P :: x0, Δ0 ++ Δ1)).
+        assert (Γ0 ++ # P :: x ++ x0 = Γ0 ++ [# P] ++ x ++ [] ++ x0). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ x ++ # P :: x0 = Γ0 ++ [] ++ x ++ [# P] ++ x0). reflexivity. rewrite H0. clear H0.
+        apply list_exch_LI. pose (KS_adm_list_exch_L _ x1 _ J5). rewrite H7. assumption. }
+    (* Right rule is KR *)
+    { inversion X3. subst. assert (InT # P (Γ0 ++ Γ1)). rewrite <- H2. apply InT_or_app.
+      right. apply InT_eq. apply InT_app_or in H. destruct H.
+      - apply InT_split in i. destruct i.
+        destruct s. subst. repeat rewrite <- app_assoc in D1. simpl in D1.
+        assert (E0: derrec_height D1 = derrec_height D1). reflexivity.
+        assert (J0 : ctr_L # P (x ++ # P :: x0 ++ # P :: Γ1, Δ0 ++ Δ1)
+        (x ++ # P :: x0 ++ Γ1, Δ0 ++ Δ1)). apply ctr_LI.
+        pose (@KS_hpadm_ctr_L (derrec_height D1) (x ++ # P :: x0 ++ # P :: Γ1, Δ0 ++ Δ1)
+        D1 E0 (x ++ # P :: x0 ++ Γ1, Δ0 ++ Δ1) (# P) J0). destruct s. clear l. rewrite H2.
+        rewrite <- app_assoc. rewrite H6. assumption.
+      - apply InT_split in i. destruct i. destruct s. subst.
+        assert (E0: derrec_height D1 = derrec_height D1). reflexivity.
+        assert (J0 : ctr_L # P (Γ0 ++ # P :: x ++ # P :: x0, Δ0 ++ Δ1)
+        (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1)). apply ctr_LI.
+        pose (@KS_hpadm_ctr_L (derrec_height D1) (Γ0 ++ # P :: x ++ # P :: x0, Δ0 ++ Δ1)
+        D1 E0 (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1) (# P) J0). destruct s. clear l. rewrite H2.
+        assert (J5 : list_exch_L (Γ0 ++ # P :: x ++ x0, Δ0 ++ Δ1) (Γ0 ++ x ++ # P :: x0, Δ0 ++ Δ1)).
+        assert (Γ0 ++ # P :: x ++ x0 = Γ0 ++ [# P] ++ x ++ [] ++ x0). reflexivity. rewrite H. clear H.
+        assert (Γ0 ++ x ++ # P :: x0 = Γ0 ++ [] ++ x ++ [# P] ++ x0). reflexivity. rewrite H. clear H.
+        apply list_exch_LI. pose (KS_adm_list_exch_L _ x1 _ J5). rewrite H6. assumption. }
+    + repeat destruct s. repeat destruct p. subst. assert (IdPRule [] (Γ2 ++ # P :: Γ3, (Δ0 ++ x0) ++ # P :: Δ3)).
+      apply IdPRule_I. rewrite <- app_assoc in H. apply IdP in H.
+      pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[]) (Γ2 ++ # P :: Γ3, Δ0 ++ x0 ++ # P :: Δ3) H DersNilF). assumption.
+  * repeat destruct s. repeat destruct p. subst. assert (IdPRule [] (Γ2 ++ # P :: Γ3, Δ2 ++ # P :: x ++ Δ1)).
+    apply IdPRule_I. apply IdP in H. rewrite <- app_assoc.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (Γ2 ++ # P :: Γ3, Δ2 ++ (# P :: x) ++ Δ1) H DersNilF). assumption.
+ +
+(* Left rule is BotL *)
+- inversion H1. subst. assert (BotLRule [] (Γ2 ++ Bot :: Γ3, Δ0 ++ Δ1)).
+  apply BotLRule_I. apply BotL in H.
+  pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+  (ps:=[]) (Γ2 ++ Bot :: Γ3, Δ0 ++ Δ1) H DersNilF).
+  assumption.
+ +
+(* Left rule is ImpR *)
+- inversion H1. subst. apply list_split_form in H3. destruct H3.
+  * destruct s.
+    + repeat destruct p. subst. inversion X1.
+      (* Right rule is IdP *)
+      { inversion H. subst. assert (J0 : InT (# P) (Γ0 ++ (A0 --> B) :: Γ1)). rewrite <- H6. apply InT_or_app.
+        right. apply InT_eq. apply InT_app_or in J0. destruct J0.
+        - apply InT_split in i. destruct i. destruct s. subst. rewrite H2. rewrite <- app_assoc.
+          assert (IdPRule [] (x ++ (# P :: x0) ++ Γ1, Δ2 ++ # P :: Δ3)). apply IdPRule_I. apply IdP in H0.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) (x ++ (# P :: x0) ++ Γ1, Δ2 ++ # P :: Δ3) H0 DersNilF). assumption.
+        - inversion i.
+          * inversion H3.
+          * apply InT_split in H3. destruct H3. destruct s. subst. rewrite H2. rewrite app_assoc.
+            assert (IdPRule [] ((Γ0 ++ x) ++ # P :: x0, Δ2 ++ # P :: Δ3)). apply IdPRule_I. apply IdP in H0.
+            pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) ((Γ0 ++ x) ++ # P :: x0, Δ2 ++ # P :: Δ3) H0 DersNilF). assumption. }
+      (* Right rule is BotL *)
+      { inversion H. subst. rewrite H2. assert (J0 : InT (Bot) (Γ0 ++ (A0 --> B) :: Γ1)). rewrite <- H6. apply InT_or_app.
+        right. apply InT_eq. apply InT_app_or in J0. destruct J0.
+        - apply InT_split in i. destruct i. destruct s. subst. rewrite <- app_assoc.
+          assert (BotLRule [] (x ++ (Bot :: x0) ++ Γ1, Δ0 ++ Δ1)). apply BotLRule_I. apply BotL in H0.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) (x ++ (Bot :: x0) ++ Γ1, Δ0 ++ Δ1) H0 DersNilF). assumption.
+        - inversion i.
+          * inversion H3.
+          * apply InT_split in H3. destruct H3. destruct s. subst. rewrite app_assoc.
+            assert (BotLRule [] ((Γ0 ++ x) ++ Bot :: x0, Δ0 ++ Δ1)). apply BotLRule_I. apply BotL in H0.
+            pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) ((Γ0 ++ x) ++ Bot :: x0, Δ0 ++ Δ1) H0 DersNilF). assumption. }
+      (* Right rule is ImpR *)
+      { inversion H. subst. inversion X0. inversion X2. subst. clear X4. clear X6. rewrite <- H7 in D1.
+        assert (J1 : list_exch_L (Γ4 ++ A :: Γ5, Δ2 ++ B0 :: Δ3) (A :: Γ0 ++ A0 --> B :: Γ1, Δ2 ++ B0 :: Δ3)).
+        assert (Γ4 ++ A :: Γ5 = [] ++ [] ++ Γ4 ++ [A] ++ Γ5). reflexivity. rewrite H0. clear H0.
+        assert (A :: Γ0 ++ A0 --> B :: Γ1 = [] ++ [A] ++ Γ4 ++ [] ++ Γ5). rewrite <- H6. reflexivity.
+        rewrite H0. clear H0. apply list_exch_LI. pose (d:=KS_adm_list_exch_L _ X5 _ J1). rewrite H2.
+        assert (ImpRRule [([] ++ A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3)] ([] ++ Γ0 ++ Γ1, Δ2 ++ A --> B0 :: Δ3)). apply ImpRRule_I.
+        simpl in H0.
+        assert (J3: KS_rules [(A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3)] (Γ0 ++ Γ1, Δ2 ++ A --> B0 :: Δ3)).
+        apply ImpR ; try intro ; try apply f ; try rewrite <- H7 ; try auto ; try assumption.
+        assert (J31: KS_rules [(A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3)] (Γ0 ++ Γ1, Δ2 ++ A --> B0 :: Δ3)).
+        apply ImpR ; try assumption.
+        assert (J21: In (A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3) [(A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3)]). apply in_eq.
+        pose (RA_mhd_decreases _ _ J3 _ J21). rewrite <- H7 in SIH.
+        assert (J5: size (A0 --> B) = size (A0 --> B)). reflexivity.
+        assert (J6: mhd (A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3) = mhd (A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3)). reflexivity.
+        assert (J7 : (A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3) = ((A :: Γ0) ++ Γ1, [] ++ Δ2 ++ B0 :: Δ3)). reflexivity.
+        pose (d0:=@SIH (mhd (A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3)) l (A0 --> B) (A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3)
+        (A :: Γ0) Γ1 [] (Δ2 ++ B0 :: Δ3) J5 J6 J7). simpl in d0.
+        assert (J8 : list_exch_R (Γ0 ++ Γ1, Δ0 ++ A0 --> B :: Δ1) (Γ0 ++ Γ1, A0 --> B :: Δ2 ++ A --> B0 :: Δ3)).
+        assert (Δ0 ++ A0 --> B :: Δ1 = [] ++ [] ++ Δ0 ++ [A0 --> B] ++ Δ1). reflexivity. rewrite H3. clear H3.
+        assert (A0 --> B :: Δ2 ++ A --> B0 :: Δ3 = [] ++ [A0 --> B] ++ Δ0 ++ [] ++ Δ1). rewrite H7.
+        reflexivity. rewrite H3. clear H3. apply list_exch_RI. pose (d1:=KS_adm_list_exch_R _ D0 _ J8).
+        assert (ImpRRule [([] ++ A :: Γ0 ++ Γ1, (A0 --> B :: Δ2) ++ B0 :: Δ3)] ([] ++ Γ0 ++ Γ1, (A0 --> B :: Δ2) ++ A --> B0 :: Δ3)).
+        apply ImpRRule_I. simpl in H3. pose (d2:=ImpR_inv _ _ d1 H3). pose (d3:=d0 d2 d). pose (dlCons d3 DersNilF).
+        apply ImpR in H0 ; try intro ; try apply f ; try rewrite <- H7 ; try auto ; try assumption.
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(A :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3)]) (Γ0 ++ Γ1, Δ2 ++ A --> B0 :: Δ3) H0 d4). assumption. }
+      (* Right rule is ImpL *)
+      { inversion H. subst. inversion X0. inversion X2. subst. clear X4. inversion X6. subst. clear X7.
+        clear X6. apply list_split_form in H6. destruct H6.
+        - destruct s.
+          * repeat destruct p. inversion e0. subst. rewrite H2.
+            assert (J1 : list_exch_L (Γ2 ++ A0 :: Γ3, Δ0 ++ B :: Δ1) (A0 :: Γ0 ++ Γ1, Δ0 ++ B :: Δ1)).
+            assert (Γ2 ++ A0 :: Γ3 = [] ++ [] ++ Γ2 ++ [A0] ++ Γ3). reflexivity. rewrite H0. clear H0.
+            assert (A0 :: Γ0 ++ Γ1 = [] ++ [A0] ++ Γ2 ++ [] ++ Γ3). rewrite <- H2. reflexivity.
+            rewrite H0. clear H0. apply list_exch_LI. pose (d:=KS_adm_list_exch_L _ X3 _ J1).
+            assert (J2 : list_exch_R (A0 :: Γ0 ++ Γ1, Δ0 ++ B :: Δ1) (A0 :: Γ0 ++ Γ1, B :: Δ2 ++ Δ3)).
+            assert (Δ0 ++ B :: Δ1 = [] ++ [] ++ Δ0 ++ [B] ++ Δ1). reflexivity. rewrite H0. clear H0.
+            assert (B :: Δ2 ++ Δ3 = [] ++ [B] ++ Δ0 ++ [] ++ Δ1). rewrite H7. reflexivity. rewrite H0. clear H0.
+            apply list_exch_RI. pose (d0:=KS_adm_list_exch_R _ d _ J2).
+            assert (J3: size A0 < size (A0 --> B)). simpl. lia.
+            assert (J4: size A0 = size A0). reflexivity.
+            assert (J5: mhd (Γ2 ++ Γ3, B :: Δ2 ++ Δ3) = mhd (Γ2 ++ Γ3, B :: Δ2 ++ Δ3)). reflexivity.
+            assert (J6: (Γ2 ++ Γ3, B :: Δ2 ++ Δ3) = ([] ++ Γ2 ++ Γ3, (B :: Δ2) ++ Δ3)). reflexivity.
+            pose (d1:=PIH _ J3 (mhd (Γ2 ++ Γ3, B :: Δ2 ++ Δ3)) A0 (Γ2 ++ Γ3, B :: Δ2 ++ Δ3) [] (Γ2 ++ Γ3)
+            (B :: Δ2) Δ3 J4 J5 J6). simpl in d1.
+            assert (J7 : wkn_R B (Γ2 ++ Γ3, Δ2 ++ A0 :: Δ3) (Γ2 ++ Γ3, B :: Δ2 ++ A0 :: Δ3)).
+            assert ((Γ2 ++ Γ3, Δ2 ++ A0 :: Δ3) = (Γ2 ++ Γ3, [] ++ Δ2 ++ A0 :: Δ3)). reflexivity. rewrite H0. clear H0.
+            assert ((Γ2 ++ Γ3, B :: Δ2 ++ A0 :: Δ3) = (Γ2 ++ Γ3, [] ++ B :: Δ2 ++ A0 :: Δ3)).
+            reflexivity. rewrite H0. clear H0. apply wkn_RI. rewrite <- H2 in X5.
+            assert (J8 : derrec_height X5 = derrec_height X5).
+            reflexivity. pose (KS_wkn_R _ _ X5 J8 _ _ J7). destruct s. rewrite <- H2 in d0. pose (d2:=d1 x d0).
+            assert (J9: size B < size (A0 --> B)). simpl. lia.
+            assert (J10: size B = size B). reflexivity.
+            assert (J11: mhd (Γ2 ++ Γ3, Δ2 ++ Δ3) = mhd (Γ2 ++ Γ3, Δ2 ++ Δ3)). reflexivity.
+            assert (J12: (Γ2 ++ Γ3, Δ2 ++ Δ3) = (Γ2 ++ Γ3, [] ++ Δ2 ++ Δ3)). reflexivity.
+            pose (d3:=PIH _ J9 (mhd (Γ2 ++ Γ3, Δ2 ++ Δ3)) B (Γ2 ++ Γ3, Δ2 ++ Δ3) Γ2 Γ3
+            [] (Δ2 ++ Δ3) J10 J11 J12). simpl in d3.
+            assert (J30 : list_exch_L (Γ0 ++ B :: Γ1, Δ2 ++ Δ3) (B :: Γ2 ++ Γ3, Δ2 ++ Δ3)).
+            assert (Γ0 ++ B :: Γ1 = [] ++ [] ++ Γ0 ++ [B] ++ Γ1). reflexivity. rewrite H0. clear H0.
+            assert (B :: Γ2 ++ Γ3 = [] ++ [B] ++ Γ0 ++ [] ++ Γ1). rewrite H2. reflexivity.
+            rewrite H0. clear H0. apply list_exch_LI. pose (d4:=KS_adm_list_exch_L _ X4 _ J30).
+            assert (J40 : list_exch_L (B :: Γ2 ++ Γ3, Δ2 ++ Δ3) (Γ2 ++ B :: Γ3, Δ2 ++ Δ3)).
+            assert (Γ2 ++ B :: Γ3 = [] ++ [] ++ Γ2 ++ [B] ++ Γ3). reflexivity. rewrite H0. clear H0.
+            assert (B :: Γ2 ++ Γ3 = [] ++ [B] ++ Γ2 ++ [] ++ Γ3). reflexivity. rewrite H0. clear H0.
+            apply list_exch_LI. pose (d5:=KS_adm_list_exch_L _ d4 _ J40). pose (d3 d2 d5). rewrite <- H2. assumption.
+          * repeat destruct s. repeat destruct p. subst. rewrite H2. repeat rewrite <- app_assoc in X5. repeat rewrite <- app_assoc in X4.
+            simpl in X4. simpl in X5.
+            assert (J1 : list_exch_R (Γ0 ++ x0 ++ A --> B0 :: Γ5, Δ0 ++ A0 --> B :: Δ1) (Γ0 ++ x0 ++ A --> B0 :: Γ5, A0 --> B :: Δ2 ++ Δ3)).
+            assert (Δ0 ++ A0 --> B :: Δ1 = [] ++ [] ++ Δ0 ++ [A0 --> B] ++ Δ1). reflexivity. rewrite H0. clear H0.
+            assert (A0 --> B :: Δ2 ++ Δ3 = [] ++ [A0 --> B] ++ Δ0 ++ [] ++ Δ1). rewrite H7. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+            pose (d:=KS_adm_list_exch_R _ D0 _ J1).
+            assert (ImpLRule [((Γ0 ++ x0) ++ Γ5, Δ2 ++ A :: Δ3); ((Γ0 ++ x0) ++ B0 :: Γ5, Δ2 ++ Δ3)] ((Γ0 ++ x0) ++ A --> B0 :: Γ5, Δ2 ++ Δ3)).
+            apply ImpLRule_I. simpl in H0. repeat rewrite <- app_assoc in H0.
+            assert (J3: KS_rules [(Γ0 ++ x0 ++ Γ5, Δ2 ++ A :: Δ3); (Γ0 ++ x0 ++ B0 :: Γ5, Δ2 ++ Δ3)] (Γ0 ++ x0 ++ A --> B0 :: Γ5, Δ2 ++ Δ3)).
+            apply ImpL ; try intro ; try apply f ; try rewrite <- H7 ; try repeat rewrite <- app_assoc ; try auto ; try assumption.
+            assert (J21: In (Γ0 ++ x0 ++ Γ5, Δ2 ++ A :: Δ3) [(Γ0 ++ x0 ++ Γ5, Δ2 ++ A :: Δ3); (Γ0 ++ x0 ++ B0 :: Γ5, Δ2 ++ Δ3)]). apply in_eq.
+            pose (RA_mhd_decreases _ _ J3 _ J21). rewrite <- H7 in SIH.
+            assert (J5: size (A0 --> B) = size (A0 --> B)). reflexivity.
+            assert (J6: mhd (Γ0 ++ x0 ++ Γ5, Δ2 ++ A :: Δ3) = mhd (Γ0 ++ x0 ++ Γ5, Δ2 ++ A :: Δ3)). reflexivity.
+            assert (J7 : (Γ0 ++ x0 ++ Γ5, Δ2 ++ A :: Δ3) = (Γ0 ++ x0 ++ Γ5, [] ++ Δ2 ++ A :: Δ3)). reflexivity.
+            pose (d0:=@SIH (mhd (Γ0 ++ x0 ++ Γ5, Δ2 ++ A :: Δ3)) l (A0 --> B) (Γ0 ++ x0 ++ Γ5, Δ2 ++ A :: Δ3)
+            Γ0 (x0 ++ Γ5) [] (Δ2 ++ A :: Δ3) J5 J6 J7). simpl in d0.
+            assert (J22: In (Γ0 ++ x0 ++ B0 :: Γ5, Δ2 ++ Δ3) [(Γ0 ++ x0 ++ Γ5, Δ2 ++ A :: Δ3); (Γ0 ++ x0 ++ B0 :: Γ5, Δ2 ++ Δ3)]).
+            apply in_cons. apply in_eq. pose (RA_mhd_decreases _ _ J3 _ J22).
+            assert (J8: size (A0 --> B) = size (A0 --> B)). reflexivity.
+            assert (J9: mhd (Γ0 ++ x0 ++ B0 :: Γ5, Δ2 ++ Δ3) = mhd (Γ0 ++ x0 ++ B0 :: Γ5, Δ2 ++ Δ3)). reflexivity.
+            assert (J10: (Γ0 ++ x0 ++ B0 :: Γ5, Δ2 ++ Δ3) = (Γ0 ++ x0 ++ B0 :: Γ5, [] ++ Δ2 ++ Δ3)). reflexivity.
+            pose (d1:=@SIH (mhd (Γ0 ++ x0 ++ B0 :: Γ5, Δ2 ++ Δ3)) l0 (A0 --> B) (Γ0 ++ x0 ++ B0 :: Γ5, Δ2 ++ Δ3)
+            Γ0 (x0 ++ B0 :: Γ5) [] (Δ2 ++ Δ3) J8 J9 J10). simpl in d1.
+            assert (ImpLRule [((Γ0 ++ x0) ++ Γ5, (A0 --> B :: Δ2) ++ A :: Δ3); ((Γ0 ++ x0) ++ B0 :: Γ5, (A0 --> B :: Δ2) ++ Δ3)] ((Γ0 ++ x0) ++ A --> B0 :: Γ5, (A0 --> B :: Δ2) ++ Δ3)).
+            apply ImpLRule_I. repeat rewrite <- app_assoc in H3. pose (ImpL_inv _ _ _ d H3). destruct p as [d2 d3].
+            pose (d4:=d0 d2 X5). pose (d5:=d1 d3 X4). apply ImpL in H0 ; try intro ; try apply f ; try repeat rewrite <- app_assoc ; try rewrite <- H7 ;
+            try repeat rewrite app_nil_r ; try auto ; try assumption. pose (dlCons d5 DersNilF). pose (dlCons d4 d6).
+            pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[(Γ0 ++ x0 ++ Γ5, Δ2 ++ A :: Δ3); (Γ0 ++ x0 ++ B0 :: Γ5, Δ2 ++ Δ3)]) (Γ0 ++ x0 ++ A --> B0 :: Γ5, Δ2 ++ Δ3) H0 d7).
+            assumption.
+        - repeat destruct s. repeat destruct p. subst. rewrite H2. rewrite <- app_assoc. rewrite <- app_assoc in D0.
+          assert (J1 : list_exch_R (Γ4 ++ (A --> B0 :: x) ++ Γ1, Δ0 ++ A0 --> B :: Δ1) (Γ4 ++ (A --> B0 :: x) ++ Γ1, A0 --> B :: Δ2 ++ Δ3)).
+          assert (Δ0 ++ A0 --> B :: Δ1 = [] ++ [] ++ Δ0 ++ [A0 --> B] ++ Δ1). reflexivity. rewrite H0. clear H0.
+          assert (A0 --> B :: Δ2 ++ Δ3 = [] ++ [A0 --> B] ++ Δ0 ++ [] ++ Δ1). rewrite H7. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+          pose (d:=KS_adm_list_exch_R _ D0 _ J1).
+          assert (ImpLRule [(Γ4 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ4 ++ (B0 :: x) ++ Γ1, Δ2 ++ Δ3)] (Γ4 ++ (A --> B0 :: x) ++ Γ1, Δ2 ++ Δ3)).
+          apply ImpLRule_I. simpl in H0.
+          assert (J3: KS_rules [(Γ4 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ4 ++ B0 :: x ++ Γ1, Δ2 ++ Δ3)] (Γ4 ++ A --> B0 :: x ++ Γ1, Δ2 ++ Δ3)).
+          apply ImpL ; try intro ; try apply f ; try rewrite <- H7 ; try repeat rewrite <- app_assoc ; try auto ; try assumption.
+          assert (J21: In (Γ4 ++ x ++ Γ1, Δ2 ++ A :: Δ3) [(Γ4 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ4 ++ B0 :: x ++ Γ1, Δ2 ++ Δ3)]). apply in_eq.
+          pose (RA_mhd_decreases _ _ J3 _ J21). rewrite <- H7 in SIH. rewrite <- app_assoc in SIH.
+          assert (J5: size (A0 --> B) = size (A0 --> B)). reflexivity.
+          assert (J6: mhd (Γ4 ++ x ++ Γ1, Δ2 ++ A :: Δ3) = mhd (Γ4 ++ x ++ Γ1, Δ2 ++ A :: Δ3)). reflexivity.
+          assert (J7 : (Γ4 ++ x ++ Γ1, Δ2 ++ A :: Δ3) = ((Γ4 ++ x) ++ Γ1, [] ++ Δ2 ++ A :: Δ3)). rewrite <- app_assoc. reflexivity.
+          pose (d0:=@SIH (mhd (Γ4 ++ x ++ Γ1, Δ2 ++ A :: Δ3)) l (A0 --> B) (Γ4 ++ x ++ Γ1, Δ2 ++ A :: Δ3)
+          (Γ4 ++ x) Γ1 [] (Δ2 ++ A :: Δ3) J5 J6 J7). simpl in d0. repeat rewrite <- app_assoc in d0.
+          assert (J22: In (Γ4 ++ B0 :: x ++ Γ1, Δ2 ++ Δ3) [(Γ4 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ4 ++ B0 :: x ++ Γ1, Δ2 ++ Δ3)]).
+          apply in_cons. apply in_eq. pose (RA_mhd_decreases _ _ J3 _ J22).
+          assert (J8: size (A0 --> B) = size (A0 --> B)). reflexivity.
+          assert (J9: mhd (Γ4 ++ B0 :: x ++ Γ1, Δ2 ++ Δ3) = mhd (Γ4 ++ B0 :: x ++ Γ1, Δ2 ++ Δ3)). reflexivity.
+          assert (J10: (Γ4 ++ B0 :: x ++ Γ1, Δ2 ++ Δ3) = ((Γ4 ++ B0 :: x) ++ Γ1, [] ++ Δ2 ++ Δ3)). rewrite <- app_assoc. reflexivity.
+          pose (d1:=@SIH (mhd (Γ4 ++ B0 :: x ++ Γ1, Δ2 ++ Δ3)) l0 (A0 --> B) (Γ4 ++ B0 :: x ++ Γ1, Δ2 ++ Δ3)
+          (Γ4 ++ B0 :: x) Γ1 [] (Δ2 ++ Δ3) J8 J9 J10). simpl in d1.
+          assert (ImpLRule [(Γ4 ++ x ++ Γ1, (A0 --> B :: Δ2) ++ A :: Δ3); (Γ4 ++ (B0 :: x) ++ Γ1, (A0 --> B :: Δ2) ++ Δ3)] (Γ4 ++ (A --> B0 :: x) ++ Γ1, (A0 --> B :: Δ2) ++ Δ3)).
+          apply ImpLRule_I. repeat rewrite <- app_assoc in H3. pose (ImpL_inv _ _ _ d H3). destruct p as [d2 d3].
+          pose (d4:=d0 d2 X5). repeat rewrite <- app_assoc in d1. pose (d5:=d1 d3 X4). apply ImpL in H0 ; try intro ; try apply f ; try repeat rewrite <- app_assoc ; try rewrite <- H7 ;
+          try repeat rewrite app_nil_r ; try auto ; try assumption. pose (dlCons d5 DersNilF). pose (dlCons d4 d6).
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[(Γ4 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ4 ++ B0 :: x ++ Γ1, Δ2 ++ Δ3)]) (Γ4 ++ (A --> B0 :: x) ++ Γ1, Δ2 ++ Δ3) H0 d7).
+          assumption. }
+      (* Right rule is KR *)
+      { inversion X3. subst. rewrite H2.
+        assert (KRRule [(unboxed_list , [A])] (Γ0 ++ Γ1, Δ2 ++ Box A :: Δ3)).
+        apply KRRule_I ; try assumption.
+        apply univ_gen_ext_splitR in X4. destruct X4. destruct s. repeat destruct p. subst.
+        apply univ_gen_ext_combine. assumption. apply univ_gen_ext_not_In_delete in u0. assumption.
+        intro. assert (In (A0 --> B) (x ++ x0)). apply in_or_app. auto. apply H5 in H0. destruct H0.
+        inversion H0. apply KR in X5.
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(unboxed_list , [A])]) (Γ0 ++ Γ1, Δ2 ++ Box A :: Δ3) X5 X2).
+        assumption. }
+    + repeat destruct s. repeat destruct p. subst.
+      assert (J5 : list_exch_L (Γ0 ++ A :: Γ1, Δ0 ++ x0 ++ A0 --> B :: Δ3) (A :: Γ2 ++ Γ3, Δ0 ++ x0 ++ A0 --> B :: Δ3)).
+      rewrite H2. assert (Γ0 ++ A :: Γ1 = [] ++ [] ++ Γ0 ++ [A] ++ Γ1). reflexivity. rewrite H. clear H.
+      assert (A :: Γ0 ++ Γ1 = [] ++ [A] ++ Γ0 ++ [] ++ Γ1). reflexivity. rewrite H. clear H.
+      apply list_exch_LI. pose (d:=KS_adm_list_exch_L _ D1 _ J5).
+      assert (ImpRRule [((A :: Γ2) ++ A0 :: Γ3, (Δ0 ++ x0) ++ B :: Δ3)] ((A :: Γ2) ++ Γ3, (Δ0 ++ x0) ++ A0 --> B :: Δ3)).
+      apply ImpRRule_I. repeat rewrite <- app_assoc in H. pose (d0:=ImpR_inv _ _ d H).
+      assert (ImpRRule [(Γ2 ++ A0 :: Γ3, (Δ0 ++ x0) ++ B :: Δ3)] (Γ2 ++ Γ3, (Δ0 ++ x0) ++ A0 --> B :: Δ3)).
+      apply ImpRRule_I. repeat rewrite <- app_assoc in H0.
+      assert (KS_rules [(Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3)] (Γ2 ++ Γ3, Δ0 ++ x0 ++ A0 --> B :: Δ3)).
+      apply ImpR ; try intro ; try apply f ; try rewrite <- H2 ; try rewrite <- app_assoc ; try auto ; try assumption.
+      assert (KS_rules [(Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3)] (Γ2 ++ Γ3, Δ0 ++ x0 ++ A0 --> B :: Δ3)).
+      apply ImpR. assumption.
+      assert (J21: In (Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3) [(Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3)]). apply in_eq.
+      pose (RA_mhd_decreases _ _ X3 (Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3) J21).
+      assert (J2 : mhd (Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3) = mhd (Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3)). reflexivity.
+      assert (J3 : size A = size A). reflexivity.
+      assert (J4 : (Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3) = ([] ++ Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3)).
+      repeat rewrite <- app_assoc. reflexivity. rewrite <- H2 in SIH.
+      pose (d1:=@SIH (mhd (Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3)) l A (Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3)
+      [] (Γ2 ++ A0 :: Γ3) Δ0 (x0 ++ B :: Δ3) J3 J2 J4). repeat rewrite <- app_assoc in d1. simpl in d1.
+      inversion X0. subst. clear X6. repeat rewrite <- app_assoc in X5. pose (d2:=d1 X5 d0). pose (dlCons d2 DersNilF).
+      pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[(Γ2 ++ A0 :: Γ3, Δ0 ++ x0 ++ B :: Δ3)]) (Γ2 ++ Γ3, Δ0 ++ x0 ++ A0 --> B :: Δ3) X4 d3). assumption.
+  * repeat destruct s. repeat destruct p. subst. repeat rewrite <- app_assoc. repeat rewrite <- app_assoc in D1.
+    assert (J5 : list_exch_L (Γ0 ++ A :: Γ1, Δ2 ++ (A0 --> B :: x) ++ Δ1) (A :: Γ2 ++ Γ3, Δ2 ++ (A0 --> B :: x) ++ Δ1)).
+    assert (Γ0 ++ A :: Γ1 = [] ++ [] ++ Γ0 ++ [A] ++ Γ1). reflexivity. rewrite H. clear H.
+    assert (A :: Γ2 ++ Γ3 = [] ++ [A] ++ Γ0 ++ [] ++ Γ1). rewrite H2. reflexivity. rewrite H. clear H.
+    apply list_exch_LI. pose (d:=KS_adm_list_exch_L _ D1 _ J5).
+    assert (ImpRRule [((A :: Γ2) ++ A0 :: Γ3, Δ2 ++ B :: x ++ Δ1)] ((A :: Γ2) ++ Γ3, Δ2 ++ (A0 --> B :: x) ++ Δ1)).
+    apply ImpRRule_I. repeat rewrite <- app_assoc in H. pose (d0:=ImpR_inv _ _ d H).
+    assert (ImpRRule [(Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1)] (Γ2 ++ Γ3, Δ2 ++ (A0 --> B :: x) ++ Δ1)).
+    apply ImpRRule_I.
+    assert (KS_rules [(Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1)] (Γ2 ++ Γ3, Δ2 ++ (A0 --> B :: x) ++ Δ1)).
+    apply ImpR ; try intro ; try apply f ; try repeat rewrite <- app_assoc ; try rewrite <- H2 ; try auto ; try assumption.
+    assert (KS_rules [(Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1)] (Γ2 ++ Γ3, Δ2 ++ (A0 --> B :: x) ++ Δ1)).
+    apply ImpR ; try assumption.
+    assert (J21: In (Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1) [(Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1)]). apply in_eq.
+    pose (RA_mhd_decreases _ _ X3 (Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1) J21). rewrite <- H2 in SIH.
+    assert (J2 : mhd (Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1) = mhd (Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1)).
+    repeat rewrite <- app_assoc. reflexivity.
+    assert (J3 : size A = size A). reflexivity.
+    assert (J4 : (Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1) = ([] ++ Γ2 ++ A0 :: Γ3, (Δ2 ++ B :: x) ++ Δ1)).
+    repeat rewrite <- app_assoc. reflexivity. repeat rewrite <- app_assoc in SIH.
+    pose (d1:=@SIH (mhd (Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1)) l A (Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1)
+    [] (Γ2 ++ A0 :: Γ3) (Δ2 ++ (B :: x)) Δ1 J3 J2 J4). simpl in d1. repeat rewrite <- app_assoc in d1.
+    inversion X0. subst. pose (d2:=d1 X5 d0). pose (dlCons d2 DersNilF).
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[(Γ2 ++ A0 :: Γ3, Δ2 ++ (B :: x) ++ Δ1)]) (Γ2 ++ Γ3, Δ2 ++ (A0 --> B :: x) ++ Δ1) X4 d3). assumption.
+ +
+(* Left rule is ImpL *)
+- inversion H1. subst. inversion X0. inversion X4. subst. clear X6. clear X4.
+  assert (J5 : list_exch_L (Γ0 ++ A :: Γ1, Δ0 ++ Δ1) (A :: Γ2 ++ A0 --> B :: Γ3, Δ0 ++ Δ1)).
+  rewrite H2. assert (Γ0 ++ A :: Γ1 = [] ++ [] ++ Γ0 ++ [A] ++ Γ1).
+  reflexivity. rewrite H. clear H.
+  assert (A :: Γ0 ++ Γ1 = [] ++ [A] ++ Γ0 ++ [] ++ Γ1). reflexivity. rewrite H. clear H.
+  apply list_exch_LI. pose (d:=KS_adm_list_exch_L _ D1 _ J5). rewrite H3 in X5.
+  assert (J40 : list_exch_R (Γ2 ++ Γ3, Δ2 ++ A0 :: Δ3) (Γ2 ++ Γ3, A0 :: Δ0 ++ A :: Δ1)).
+  rewrite <- H3. assert (Δ2 ++ A0 :: Δ3 = [] ++ [] ++ Δ2 ++ [A0] ++ Δ3).
+  reflexivity. rewrite H. clear H.
+  assert (A0 :: Δ2 ++ Δ3 = [] ++ [A0] ++ Δ2 ++ [] ++ Δ3). reflexivity. rewrite H. clear H.
+  apply list_exch_RI. pose (d0:=KS_adm_list_exch_R _ X3 _ J40).
+  assert (ImpLRule [(A :: Γ2 ++ Γ3, [] ++ A0 :: Δ0 ++ Δ1); (A :: Γ2 ++ B :: Γ3, [] ++ Δ0 ++ Δ1)] (A :: Γ2 ++ A0 --> B :: Γ3, [] ++ Δ0 ++ Δ1)).
+  assert ((A :: Γ2 ++ A0 --> B :: Γ3, [] ++ Δ0 ++ Δ1) = ((A :: Γ2) ++ A0 --> B :: Γ3, [] ++ Δ0 ++ Δ1)). reflexivity.
+  rewrite H. clear H.
+  assert ((A :: Γ2 ++ Γ3, [] ++ A0 :: Δ0 ++ Δ1) = ((A :: Γ2) ++ Γ3, [] ++ A0 :: Δ0 ++ Δ1)). reflexivity.
+  rewrite H. clear H.
+  assert ((A :: Γ2 ++ B :: Γ3, [] ++ Δ0 ++ Δ1) = ((A :: Γ2) ++ B :: Γ3, [] ++ Δ0 ++ Δ1)). reflexivity.
+  rewrite H. clear H. apply ImpLRule_I. simpl in H. pose (ImpL_inv _ _ _ d H). destruct p as [d1 d2].
+  assert (ImpLRule [(Γ2 ++ Γ3, [] ++ A0 :: Δ0 ++ Δ1); (Γ2 ++ B :: Γ3, [] ++ Δ0 ++ Δ1)] (Γ2 ++ A0 --> B :: Γ3, [] ++ Δ0 ++ Δ1)).
+  apply ImpLRule_I. simpl in H0.
+  assert (KS_rules [(Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1); (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)] (Γ2 ++ A0 --> B :: Γ3, Δ0 ++ Δ1)).
+  apply ImpL ; try intro ; try apply f ; try rewrite <- H2 ; try rewrite <- app_assoc ; try auto ; try assumption.
+  assert (KS_rules [(Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1); (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)] (Γ2 ++ A0 --> B :: Γ3, Δ0 ++ Δ1)).
+  apply ImpL. assumption.
+  assert (J21: In (Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1) [(Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1); (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)]).
+  apply in_eq. pose (RA_mhd_decreases _ _ X4 (Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1) J21).
+  assert (J2 : mhd (Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1) = mhd (Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1)). reflexivity.
+  assert (J3 : size A = size A). reflexivity.
+  assert (J4 : (Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1) = ([] ++ Γ2 ++ Γ3, (A0 :: Δ0) ++ Δ1)).
+  repeat rewrite <- app_assoc. reflexivity. rewrite <- H2 in SIH.
+  pose (d3:=@SIH (mhd (Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1)) l A (Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1)
+  [] (Γ2 ++ Γ3) (A0 :: Δ0) Δ1 J3 J2 J4). repeat rewrite <- app_assoc in d3. simpl in d3.
+  pose (d4:=d3 d0 d1).
+  assert (J31: In (Γ2 ++ B :: Γ3, Δ0 ++ Δ1) [(Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1); (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)]).
+  apply in_cons. apply in_eq. pose (RA_mhd_decreases _ _ X4 (Γ2 ++ B :: Γ3, Δ0 ++ Δ1) J31).
+  assert (J32 : mhd (Γ2 ++ B :: Γ3, Δ0 ++ Δ1) = mhd (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)). reflexivity.
+  assert (J33 : size A = size A). reflexivity.
+  assert (J34 : (Γ2 ++ B :: Γ3, Δ0 ++ Δ1) = ([] ++ Γ2 ++ B :: Γ3, Δ0 ++ Δ1)).
+  repeat rewrite <- app_assoc. reflexivity.
+  pose (d5:=@SIH (mhd (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)) l0 A (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)
+  [] (Γ2 ++ B :: Γ3) Δ0 Δ1 J33 J32 J34). repeat rewrite <- app_assoc in d5. simpl in d5.
+  pose (d6:=d5 X5 d2). pose (dlCons d6 DersNilF). pose (dlCons d4 d7).
+  pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+  (ps:=[(Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1); (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)]) (Γ2 ++ A0 --> B :: Γ3, Δ0 ++ Δ1) X6 d8). assumption.
+ +
+(* Left rule is KR *)
+- inversion X3. subst. apply list_split_form in H2. destruct H2.
+  * destruct s.
+    + repeat destruct p. subst. inversion X1.
+      (* Right rule is IdP *)
+      { inversion H. subst. assert (J0 : InT (# P) (Γ0 ++ Box A0 :: Γ1)). rewrite <- H5. apply InT_or_app.
+        right. apply InT_eq. apply InT_app_or in J0. destruct J0.
+        - apply InT_split in i. destruct i. destruct s. subst. rewrite <- app_assoc.
+          assert (IdPRule [] (x ++ (# P :: x0) ++ Γ1, Δ2 ++ # P :: Δ3)). apply IdPRule_I. apply IdP in H0.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) (x ++ (# P :: x0) ++ Γ1, Δ2 ++ # P :: Δ3) H0 DersNilF). assumption.
+        - inversion i.
+          * inversion H2.
+          * apply InT_split in H2. destruct H2. destruct s. subst. rewrite app_assoc.
+            assert (IdPRule [] ((Γ0 ++ x) ++ # P :: x0, Δ2 ++ # P :: Δ3)). apply IdPRule_I. apply IdP in H0.
+            pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) ((Γ0 ++ x) ++ # P :: x0, Δ2 ++ # P :: Δ3) H0 DersNilF). assumption. }
+      (* Right rule is BotL *)
+      { inversion H. subst. assert (J0 : InT (Bot) (Γ0 ++ Box A0 :: Γ1)). rewrite <- H5. apply InT_or_app.
+        right. apply InT_eq. apply InT_app_or in J0. destruct J0.
+        - apply InT_split in i. destruct i. destruct s. subst. rewrite <- app_assoc.
+          assert (BotLRule [] (x ++ (Bot :: x0) ++ Γ1, Δ0 ++ Δ1)). apply BotLRule_I. apply BotL in H0.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) (x ++ (Bot :: x0) ++ Γ1, Δ0 ++ Δ1) H0 DersNilF). assumption.
+        - inversion i.
+          * inversion H2.
+          * apply InT_split in H2. destruct H2. destruct s. subst. rewrite app_assoc.
+            assert (BotLRule [] ((Γ0 ++ x) ++ Bot :: x0, Δ0 ++ Δ1)). apply BotLRule_I. apply BotL in H0.
+            pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) ((Γ0 ++ x) ++ Bot :: x0, Δ0 ++ Δ1) H0 DersNilF). assumption. }
+      (* Right rule is ImpR *)
+      { inversion H. subst. inversion X2. subst. clear X6. rewrite <- H6 in D1.
+        assert (J1 : list_exch_L (Γ2 ++ A :: Γ3, Δ2 ++ B :: Δ3) (A :: Γ0 ++ Box A0 :: Γ1, Δ2 ++ B :: Δ3)).
+        assert (Γ2 ++ A :: Γ3 = [] ++ [] ++ Γ2 ++ [A] ++ Γ3). reflexivity. rewrite H0. clear H0.
+        assert (A :: Γ0 ++ Box A0 :: Γ1 = [] ++ [A] ++ Γ2 ++ [] ++ Γ3). rewrite <- H5. reflexivity.
+        rewrite H0. clear H0. apply list_exch_LI. pose (d:=KS_adm_list_exch_L _ X5 _ J1).
+        assert (ImpRRule [([] ++ A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3)] ([] ++ Γ0 ++ Γ1, Δ2 ++ A --> B :: Δ3)). apply ImpRRule_I.
+        simpl in H0.
+        assert (J3: KS_rules [(A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3)] (Γ0 ++ Γ1, Δ2 ++ A --> B :: Δ3)).
+        apply ImpR ; try intro ; try apply f ; try rewrite <- H6 ; try auto ; try assumption.
+        assert (J31: KS_rules [(A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3)] (Γ0 ++ Γ1, Δ2 ++ A --> B :: Δ3)).
+        apply ImpR ; try assumption.
+        assert (J21: In (A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3) [(A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3)]). apply in_eq.
+        pose (RA_mhd_decreases _ _ J3 _ J21). rewrite <- H6 in SIH.
+        assert (J5: size (Box A0) = size (Box A0)). reflexivity.
+        assert (J6: mhd (A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3) = mhd (A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3)). reflexivity.
+        assert (J7 : (A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3) = ((A :: Γ0) ++ Γ1, [] ++ Δ2 ++ B :: Δ3)). reflexivity.
+        pose (d0:=@SIH (mhd (A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3)) l (Box A0) (A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3)
+        (A :: Γ0) Γ1 [] (Δ2 ++ B :: Δ3) J5 J6 J7). simpl in d0.
+        assert (J8 : list_exch_R (Γ0 ++ Γ1, Δ0 ++ Box A0 :: Δ1) (Γ0 ++ Γ1, Box A0 :: Δ2 ++ A --> B :: Δ3)).
+        assert (Δ0 ++ Box A0 :: Δ1 = [] ++ [] ++ Δ0 ++ [Box A0] ++ Δ1). reflexivity. rewrite H2. clear H2.
+        assert (Box A0 :: Δ2 ++ A --> B :: Δ3 = [] ++ [Box A0] ++ Δ0 ++ [] ++ Δ1). rewrite H6.
+        reflexivity. rewrite H2. clear H2. apply list_exch_RI. pose (d1:=KS_adm_list_exch_R _ D0 _ J8).
+        assert (ImpRRule [([] ++ A ::Γ0 ++ Γ1, (Box A0 :: Δ2) ++ B :: Δ3)] ([] ++ Γ0 ++ Γ1, (Box A0 :: Δ2) ++ A --> B :: Δ3)).
+        apply ImpRRule_I. simpl in H2. pose (d2:=ImpR_inv _ _ d1 H2). pose (d3:=d0 d2 d). pose (dlCons d3 DersNilF).
+        apply ImpR in H0 ; try intro ; try apply f ; try rewrite <- H7 ; try auto ; try assumption.
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ3)]) (Γ0 ++ Γ1, Δ2 ++ A --> B :: Δ3) H0 d4). assumption. }
+      (* Right rule is ImpL *)
+      { inversion H. subst. apply list_split_form in H5. destruct H5.
+        - destruct s.
+          + repeat destruct p. inversion e0.
+          + repeat destruct s. repeat destruct p. subst. repeat rewrite <- app_assoc in H. repeat rewrite <- app_assoc in X2.
+            assert (J2: list_exch_R (Γ0 ++ x0 ++ A --> B :: Γ3, Δ0 ++ Box A0 :: Δ1) (Γ0 ++ x0 ++ A --> B :: Γ3, Box A0 :: Δ2 ++ Δ3)).
+            assert (Δ0 ++ Box A0 :: Δ1 = [] ++ [] ++ Δ0 ++ [Box A0] ++ Δ1). reflexivity. rewrite H0. clear H0.
+            assert (Box A0 :: Δ2 ++ Δ3 = [] ++ [Box A0] ++ Δ0 ++ [] ++ Δ1). rewrite H6. reflexivity. rewrite H0. clear H0.
+            apply list_exch_RI. pose (d:=KS_adm_list_exch_R _ D0 _ J2).
+            assert (ImpLRule [((Γ0 ++ x0) ++ Γ3, (Box A0 :: Δ2) ++ A :: Δ3); ((Γ0 ++ x0) ++ B :: Γ3, (Box A0 :: Δ2) ++ Δ3)]
+            ((Γ0 ++ x0) ++ A --> B :: Γ3, (Box A0 :: Δ2) ++ Δ3)). apply ImpLRule_I. simpl in H.
+            repeat rewrite <- app_assoc in H0. pose (ImpL_inv _ _ _ d H0). destruct p as [d0 d1].
+            assert (ImpLRule [((Γ0 ++ x0) ++ Γ3, Δ2 ++ A :: Δ3); ((Γ0 ++ x0) ++ B :: Γ3, Δ2 ++ Δ3)]
+            ((Γ0 ++ x0) ++ A --> B :: Γ3, Δ2 ++ Δ3)). apply ImpLRule_I. repeat rewrite <- app_assoc in H0.
+            repeat rewrite <- app_assoc in H2.
+            assert (J3: KS_rules [(Γ0 ++ x0 ++ Γ3, Δ2 ++ A :: Δ3); (Γ0 ++ x0 ++ B :: Γ3, Δ2 ++ Δ3)]
+            (Γ0 ++ x0 ++ A --> B :: Γ3, Δ2 ++ Δ3)).
+            apply ImpL ; try intro ; try apply f ; try rewrite <- app_assoc ;
+            try rewrite <- H6 ; try auto ; try assumption.
+            assert (J30: KS_rules [(Γ0 ++ x0 ++ Γ3, Δ2 ++ A :: Δ3); (Γ0 ++ x0 ++ B :: Γ3, Δ2 ++ Δ3)]
+            (Γ0 ++ x0 ++ A --> B :: Γ3, Δ2 ++ Δ3)). apply ImpL ; try assumption.
+            assert (J5: In (Γ0 ++ x0 ++ Γ3, Δ2 ++ A :: Δ3) [(Γ0 ++ x0 ++ Γ3, Δ2 ++ A :: Δ3); (Γ0 ++ x0 ++ B :: Γ3, Δ2 ++ Δ3)]).
+            apply in_eq.
+            assert (J9: In (Γ0 ++ x0 ++ B :: Γ3, Δ2 ++ Δ3) [(Γ0 ++ x0 ++ Γ3, Δ2 ++ A :: Δ3); (Γ0 ++ x0 ++ B :: Γ3, Δ2 ++ Δ3)]).
+            apply in_cons. apply in_eq.
+            pose (RA_mhd_decreases _ _ J3 _ J5). pose (RA_mhd_decreases _ _ J3 _ J9). repeat rewrite <- app_assoc in SIH. rewrite <- H6 in SIH.
+            assert (J6: size (Box A0) = size (Box A0)). reflexivity.
+            assert (J7: mhd (Γ0 ++ x0 ++ Γ3, Δ2 ++ A :: Δ3) = mhd (Γ0 ++ x0 ++ Γ3, Δ2 ++ A :: Δ3)). reflexivity.
+            assert (J8: (Γ0 ++ x0 ++ Γ3, Δ2 ++ A :: Δ3) = (Γ0 ++ x0 ++ Γ3, [] ++ Δ2 ++ A :: Δ3)). reflexivity.
+            pose (d2:=@SIH (mhd (Γ0 ++ x0 ++ Γ3, Δ2 ++ A :: Δ3)) l (Box A0) (Γ0 ++ x0 ++ Γ3, Δ2 ++ A :: Δ3)
+            Γ0 (x0 ++ Γ3) [] (Δ2 ++ A :: Δ3) J6 J7 J8). simpl in d2. inversion X2. subst. inversion X6. clear X6.
+            clear X8. subst. pose (d3:=d2 d0 X5).
+            assert (J10: mhd (Γ0 ++ x0 ++ B :: Γ3, Δ2 ++ Δ3) = mhd (Γ0 ++ x0 ++ B :: Γ3, Δ2 ++ Δ3)). reflexivity.
+            assert (J11: (Γ0 ++ x0 ++ B :: Γ3, Δ2 ++ Δ3) = (Γ0 ++ x0 ++ B :: Γ3, [] ++ Δ2 ++ Δ3)). reflexivity.
+            pose (d4:=@SIH (mhd (Γ0 ++ x0 ++ B :: Γ3, Δ2 ++ Δ3)) l0 (Box A0) (Γ0 ++ x0 ++ B :: Γ3, Δ2 ++ Δ3)
+            Γ0 (x0 ++ B :: Γ3) [] (Δ2 ++ Δ3) J6 J10 J11). simpl in d4. pose (d5:=d4 d1 X7).
+            pose (dlCons d5 DersNilF). pose (dlCons d3 d6).
+            pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[(Γ0 ++ x0 ++ Γ3, Δ2 ++ A :: Δ3); (Γ0 ++ x0 ++ B :: Γ3, Δ2 ++ Δ3)]) (Γ0 ++ x0 ++ A --> B :: Γ3, Δ2 ++ Δ3) J30 d7).
+            assumption.
+        - repeat destruct s. repeat destruct p. subst. rewrite <- app_assoc in D0.
+          assert (J2: list_exch_R (Γ2 ++ (A --> B :: x) ++ Γ1, Δ0 ++ Box A0 :: Δ1) (Γ2 ++ (A --> B :: x) ++ Γ1, Box A0 :: Δ2 ++ Δ3)).
+          assert (Δ0 ++ Box A0 :: Δ1 = [] ++ [] ++ Δ0 ++ [Box A0] ++ Δ1). reflexivity. rewrite H0. clear H0.
+          assert (Box A0 :: Δ2 ++ Δ3 = [] ++ [Box A0] ++ Δ0 ++ [] ++ Δ1). rewrite H6. reflexivity. rewrite H0. clear H0.
+          apply list_exch_RI. pose (d:=KS_adm_list_exch_R _ D0 _ J2).
+          assert (ImpLRule [(Γ2 ++ x ++ Γ1, (Box A0 :: Δ2) ++ A :: Δ3); (Γ2 ++ B :: x ++ Γ1, (Box A0 :: Δ2) ++ Δ3)]
+          (Γ2 ++ (A --> B :: x) ++ Γ1, (Box A0 :: Δ2) ++ Δ3)). apply ImpLRule_I. repeat rewrite <- app_assoc in H0.
+          pose (ImpL_inv _ _ _ d H0). destruct p as [d0 d1]. rewrite <- app_assoc.
+          assert (ImpLRule [(Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3)]
+          (Γ2 ++ (A --> B :: x) ++ Γ1, Δ2 ++ Δ3)). apply ImpLRule_I.
+          assert (J3: KS_rules [(Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3)]
+          (Γ2 ++ (A --> B :: x) ++ Γ1, Δ2 ++ Δ3)).
+          apply ImpL ; try intro ; try apply f ; try rewrite <- app_assoc ;
+          try rewrite <- H6 ; try auto ; try assumption.
+          assert (J30: KS_rules [(Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3)]
+          (Γ2 ++ (A --> B :: x) ++ Γ1, Δ2 ++ Δ3)). apply ImpL ; try assumption.
+          assert (J5: In (Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3) [(Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3)]).
+          apply in_eq.
+          assert (J9: In (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3) [(Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3)]).
+          apply in_cons. apply in_eq.
+          pose (RA_mhd_decreases _ _ J3 _ J5). pose (RA_mhd_decreases _ _ J3 _ J9). repeat rewrite <- app_assoc in SIH. rewrite <- H6 in SIH.
+          assert (J6: size (Box A0) = size (Box A0)). reflexivity.
+          assert (J7: mhd (Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3) = mhd (Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3)). reflexivity.
+          assert (J8: (Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3) = ((Γ2 ++ x) ++ Γ1, [] ++ Δ2 ++ A :: Δ3)). rewrite <- app_assoc. reflexivity.
+          pose (d2:=@SIH (mhd (Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3)) l (Box A0) (Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3)
+          (Γ2 ++ x) Γ1 [] (Δ2 ++ A :: Δ3) J6 J7 J8). simpl in d2. inversion X2. subst. inversion X6. clear X6.
+          clear X8. subst. repeat rewrite <- app_assoc in d2. pose (d3:=d2 d0 X5).
+          assert (J10: mhd (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3) = mhd (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3)). reflexivity.
+          assert (J11: (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3) = ((Γ2 ++ B :: x) ++ Γ1, [] ++ Δ2 ++ Δ3)). rewrite <- app_assoc. reflexivity.
+          pose (d4:=@SIH (mhd (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3)) l0 (Box A0) (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3)
+          (Γ2 ++ B :: x) Γ1 [] (Δ2 ++ Δ3) J6 J10 J11). simpl in d4. repeat rewrite <- app_assoc in d4. pose (d5:=d4 d1 X7).
+          pose (dlCons d5 DersNilF). pose (dlCons d3 d6).
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[(Γ2 ++ x ++ Γ1, Δ2 ++ A :: Δ3); (Γ2 ++ B :: x ++ Γ1, Δ2 ++ Δ3)]) (Γ2 ++ (A --> B :: x) ++ Γ1, Δ2 ++ Δ3) J30 d7).
+          assumption. }
+      (* Right rule is KR *)
+      { inversion X5. subst. inversion X0. subst. clear X8. inversion X2. subst. clear X9.
+        pose (univ_gen_ext_splitR _ _ X4). repeat destruct s. repeat destruct p.
+        pose (univ_gen_ext_splitR _ _ X6). repeat destruct s. repeat destruct p. subst. inversion u2.
+        - subst.
+          assert (wkn_R A (unboxed_list (x ++ x0), [] ++ [A0]) (unboxed_list (x ++ x0), [] ++ A :: [A0])).
+          apply wkn_RI. assert (J10: derrec_height X7 = derrec_height X7). reflexivity.
+          pose (KS_wkn_R _ _ _ J10 _ _ H). destruct s. clear J10. clear H. clear l0.
+          rewrite unbox_app_distrib in X8. simpl in X8.
+          assert (J5: list_exch_L (unboxed_list x1 ++ [A0] ++ [] ++ unboxed_list l ++ [], [A])
+          (unboxed_list x1 ++ unboxed_list l ++ [] ++ [A0] ++ [], [A])).
+          apply list_exch_LI.
+          assert (J20: unboxed_list x1 ++ A0 :: unboxed_list l =
+          unboxed_list x1 ++ [A0] ++ [] ++ unboxed_list l ++ []). simpl. rewrite app_nil_r ; auto.
+          rewrite J20 in X8. clear J20.
+          pose (d:=KS_adm_list_exch_L _ X8 _ J5). simpl in d. assert (x1 ++ l = x ++ x0).
+          apply nobox_gen_ext_injective with (l:=(Γ0 ++ Γ1)) ; try assumption.
+          intro. intros. apply H4. apply in_or_app. apply in_app_or in H. destruct H.
+          auto. right. apply in_cons. assumption. apply univ_gen_ext_combine ; assumption.
+          rewrite app_assoc in d. rewrite <- unbox_app_distrib in d.
+          rewrite H in d. clear J5. clear X8.
+          assert (unboxed_list (x ++ x0) = unboxed_list (x ++ x0) ++ []). rewrite app_nil_r.
+          auto. rewrite H0 in x2. clear H0.
+          assert (J6: size A0 < size (Box A0)). simpl. lia.
+          assert (J7: size A0 = size A0). reflexivity.
+          assert (J8: mhd (unboxed_list (x ++ x0), [A]) =
+          mhd (unboxed_list (x ++ x0), [A])). reflexivity.
+          assert (J9: (unboxed_list (x ++ x0) , [A]) =
+          (unboxed_list (x ++ x0) ++ [], [A] ++ [])). rewrite app_nil_r. reflexivity.
+          pose (d0:=@PIH (size A0) J6 (mhd (unboxed_list (x ++ x0), [A]))
+          A0 (unboxed_list (x ++ x0), [A]) (unboxed_list (x ++ x0)) []
+          [A] [] J7 J8 J9). repeat rewrite app_nil_r in d0. simpl in x2. rewrite app_nil_r in x2. pose (d1:=d0 x2 d).
+          assert (KRRule [(unboxed_list (x ++ x0), [A])] (Γ0 ++ Γ1, Δ2 ++ Box A :: Δ3)).
+          apply KRRule_I.
+          assumption. apply univ_gen_ext_combine ; auto.
+          assert (KS_rules [(unboxed_list (x ++ x0), [A])] (Γ0 ++ Γ1, Δ2 ++ Box A :: Δ3)).
+          apply KR. assumption.
+          pose (dlCons d1 DersNilF).
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[(unboxed_list (x ++ x0), [A])]) (Γ0 ++ Γ1, Δ2 ++ Box A :: Δ3) X10 d2). auto.
+        - exfalso. apply H2. exists A0. reflexivity. }
+    + repeat destruct s. repeat destruct p. subst.
+      assert (KRRule [(unboxed_list , [A0])] (Γ0 ++ Γ1, (Δ0 ++ x0) ++ Box A0 :: Δ3)).
+      apply KRRule_I ; try assumption. repeat rewrite <- app_assoc in X5.
+      assert (KS_rules [(unboxed_list , [A0])] (Γ0 ++ Γ1, Δ0 ++ x0 ++ Box A0 :: Δ3)).
+      apply KR. assumption.
+      pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[(unboxed_list , [A0])]) (Γ0 ++ Γ1, Δ0 ++ x0 ++ Box A0 :: Δ3) X6 X0). assumption.
+  * repeat destruct s. repeat destruct p. subst. rewrite <- app_assoc.
+    assert (KRRule [(unboxed_list , [A0])] (Γ0 ++ Γ1, Δ2 ++ (Box A0 :: x) ++ Δ1)).
+    apply KRRule_I ; try assumption.
+    assert (KS_rules [(unboxed_list , [A0])] (Γ0 ++ Γ1, Δ2 ++ (Box A0 :: x) ++ Δ1)).
+    apply KR. assumption.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[(unboxed_list , [A0])]) (Γ0 ++ Γ1, Δ2 ++ (Box A0 :: x) ++ Δ1) X6 X0). assumption.
+Qed.
+ +
+Theorem KS_cut_adm : forall A Γ0 Γ1 Δ0 Δ1,
+                      (KS_prv (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)) ->
+                      (KS_prv (Γ0 ++ A :: Γ1, Δ0 ++ Δ1)) ->
+                      (KS_prv (Γ0 ++ Γ1, Δ0 ++ Δ1)).
+Proof.
+intros.
+assert (J1: size A = size A). reflexivity.
+assert (J2: mhd (Γ0 ++ Γ1, Δ0 ++ Δ1) = mhd (Γ0 ++ Γ1, Δ0 ++ Δ1)). reflexivity.
+assert (J3: (Γ0 ++ Γ1, Δ0 ++ Δ1) = (Γ0 ++ Γ1, Δ0 ++ Δ1)). reflexivity.
+pose (@KS_cut_adm_main (size A) (mhd (Γ0 ++ Γ1, Δ0 ++ Δ1)) A
+(Γ0 ++ Γ1, Δ0 ++ Δ1) Γ0 Γ1 Δ0 Δ1 J1 J2 J3). auto.
+Qed.
+ +
+
+
+ +
+ + + diff --git a/K.KS.KS_calc.html b/K.KS.KS_calc.html new file mode 100644 index 0000000..e9e42b0 --- /dev/null +++ b/K.KS.KS_calc.html @@ -0,0 +1,150 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_calc

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+ +
+Require Export general_export.
+Require Export Syntax_export.
+ +
+(* We use a macro for sequents *)
+ +
+Definition Seq := (prod (list MPropF) (list MPropF)).
+ +
+(* ---------------------------------------------------------------------------------------------------------------------------------- *)
+ +
+(* Finally, we can define the rules which constitute our calculus. We gather
+   it in caclulus in a definition appearing later. *)

+ +
+Inductive IdPRule : rlsT Seq :=
+  | IdPRule_I : forall P (Γ0 Γ1 Δ0 Δ1 : list MPropF),
+          IdPRule [] (Γ0 ++ # P :: Γ1 , Δ0 ++ # P :: Δ1)
+.
+ +
+Inductive BotLRule : rlsT Seq :=
+  | BotLRule_I : forall Γ0 Γ1 Δ,
+          BotLRule [] (Γ0 ++ Bot :: Γ1 , Δ)
+.
+ +
+Inductive ImpRRule : rlsT Seq :=
+  | ImpRRule_I : forall A B Γ0 Γ1 Δ0 Δ1,
+          ImpRRule [(Γ0 ++ A :: Γ1 , Δ0 ++ B :: Δ1)]
+                    (Γ0 ++ Γ1 , Δ0 ++ (A --> B) :: Δ1).
+ +
+Inductive ImpLRule : rlsT Seq :=
+  | ImpLRule_I : forall A B Γ0 Γ1 Δ0 Δ1,
+          ImpLRule [(Γ0 ++ Γ1 , Δ0 ++ A :: Δ1) ;
+                     (Γ0 ++ B :: Γ1 , Δ0 ++ Δ1)]
+                    (Γ0 ++ (A --> B) :: Γ1 , Δ0 ++ Δ1)
+.
+ +
+Inductive KRRule : rlsT Seq :=
+  | KRRule_I : forall A Γ0 Δ0 Δ1,
+          (is_Boxed_list ) ->
+          (nobox_gen_ext Γ0) ->
+         KRRule [(unboxed_list , [A])] (Γ0 , Δ0 ++ Box A :: Δ1).
+ +
+(* At last we can define our calculus KS. *)
+ +
+Inductive KS_rules : rlsT Seq :=
+  | IdP : forall ps c, IdPRule ps c -> KS_rules ps c
+  | BotL : forall ps c, BotLRule ps c -> KS_rules ps c
+  | ImpR : forall ps c, ImpRRule ps c -> KS_rules ps c
+  | ImpL : forall ps c, ImpLRule ps c -> KS_rules ps c
+  | KR : forall ps c, KRRule ps c -> KS_rules ps c
+.
+ +
+(* We can show that all identities are provable in KS. *)
+ +
+Lemma Id_all_form : forall (A : MPropF) l0 l1 l2 l3,
+          derrec KS_rules (fun _ => False) (l0 ++ A :: l1, l2 ++ A :: l3).
+Proof.
+assert (DersNilF: dersrec KS_rules (fun _ : rel (list (MPropF)) => False) []).
+apply dersrec_nil.
+ +
+induction A as [n| | |].
+- intros. assert (IdPRule [] (l0 ++ # n :: l1, l2 ++ # n :: l3)). apply IdPRule_I. apply IdP in H.
+  pose (derI (rules:=KS_rules) (prems:=fun _ : rel (list (MPropF)) => False) (ps:=[])
+  (l0 ++ # n :: l1, l2 ++ # n :: l3) H DersNilF). assumption.
+- intros. assert (BotLRule [] (l0 ++ Bot :: l1, l2 ++ Bot :: l3)). apply BotLRule_I. apply BotL in H.
+  pose (derI (rules:=KS_rules) (prems:=fun _ : rel (list (MPropF)) => False) (ps:=[])
+  (l0 ++ Bot :: l1, l2 ++ Bot :: l3) H DersNilF). assumption.
+- intros. assert (ImpRRule [(l0 ++ A1 :: A1 --> A2 :: l1, l2 ++ A2 :: l3)] (l0 ++ A1 --> A2 :: l1, l2 ++ A1 --> A2 :: l3)).
+  apply ImpRRule_I. apply ImpR in H.
+  assert (ImpLRule [((l0 ++ [A1]) ++ l1, l2 ++ A1 :: A2 :: l3); ((l0 ++ [A1]) ++ A2 :: l1, l2 ++ A2 :: l3)] ((l0 ++ [A1]) ++ A1 --> A2 :: l1, l2 ++ A2 :: l3)).
+  apply ImpLRule_I. repeat rewrite <- app_assoc in H0. simpl in H0. apply ImpL in H0.
+  pose (IHA1 l0 l1 l2 (A2 :: l3)). pose (IHA2 (l0 ++ [A1]) l1 l2 l3). repeat rewrite <- app_assoc in d0. simpl in d0.
+  pose (dlCons d0 DersNilF). pose (dlCons d d1).
+  pose (derI (rules:=KS_rules) (prems:=fun _ : rel (list (MPropF)) => False) (ps:=[(l0 ++ A1 :: l1, l2 ++ A1 :: A2 :: l3); (l0 ++ A1 :: A2 :: l1, l2 ++ A2 :: l3)])
+  (l0 ++ A1 :: A1 --> A2 :: l1, l2 ++ A2 :: l3) H0 d2). pose (dlCons d3 DersNilF).
+  pose (derI (rules:=KS_rules) (prems:=fun _ : rel (list (MPropF)) => False) (ps:=[(l0 ++ A1 :: A1 --> A2 :: l1, l2 ++ A2 :: l3)])
+  (l0 ++ A1 --> A2 :: l1, l2 ++ A1 --> A2 :: l3) H d4). assumption.
+- intros. assert (KRRule [(unboxed_list (top_boxes (l0 ++ Box A :: l1)), [A])] (l0 ++ Box A :: l1, l2 ++ Box A :: l3)).
+  apply KRRule_I. apply is_Boxed_list_top_boxes. rewrite top_boxes_distr_app. simpl. apply univ_gen_ext_combine.
+  apply nobox_gen_ext_top_boxes. apply univ_gen_ext_cons. apply nobox_gen_ext_top_boxes.
+  rewrite top_boxes_distr_app in X. simpl in X. rewrite unbox_app_distrib in X. simpl in X.
+  repeat rewrite <- app_assoc in X. simpl in X.
+  pose (IHA (unboxed_list (top_boxes l0)) (unboxed_list (top_boxes l1)) [] []).
+  simpl in d. pose (dlCons d DersNilF). apply KR in X.
+  pose (derI (rules:=KS_rules) (prems:=fun _ : rel (list (MPropF)) => False) (ps:=[(unboxed_list (top_boxes l0) ++ A :: unboxed_list (top_boxes l1), [A])])
+  (l0 ++ Box A :: l1, l2 ++ Box A :: l3) X d0). assumption.
+Qed.
+ +
+Definition KS_prv s := derrec KS_rules (fun _ => False) s.
+Definition KS_drv s := derrec KS_rules (fun _ => True) s.
+ +
+
+
+ +
+ + + diff --git a/K.KS.KS_ctr.html b/K.KS.KS_ctr.html new file mode 100644 index 0000000..ad0bfb8 --- /dev/null +++ b/K.KS.KS_ctr.html @@ -0,0 +1,955 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_ctr

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat Arith.
+ +
+Require Import KS_calc.
+Require Import KS_inv_ImpR_ImpL.
+ +
+(* Next are the definitions for contraction of one formula on the left, and
+on the right. Note that while the leftmost occurrence of the formula is kept,
+if we have exchange for our calculus it amounts to the same to keep the rightmost
+formula. *)

+ +
+Inductive ctr_L (fml : MPropF) : relationT Seq :=
+  | ctr_LI Γ0 Γ1 Γ2 Δ : ctr_L fml
+        (Γ0 ++ fml :: Γ1 ++ fml :: Γ2, Δ) (Γ0 ++ fml :: Γ1 ++ Γ2, Δ).
+ +
+Inductive ctr_R (fml : MPropF) : relationT Seq :=
+  | ctr_RI Γ Δ0 Δ1 Δ2 : ctr_R fml
+        (Γ, Δ0 ++ fml :: Δ1 ++ fml :: Δ2) (Γ, Δ0 ++ fml :: Δ1 ++ Δ2).
+ +
+(* The following lemmas make sure that if a rule is applied on a sequent s with
+premises ps, then the same rule is applicable on a sequent sc which is a contracted
+version of s, with some premises psc that are such that they are either the same premises
+(in case the contracted formula was weakened) or contracted versions of ps. *)

+ +
+Lemma ImpR_app_ctr_L : forall s sc A ps,
+  (@ctr_L A s sc) ->
+  (ImpRRule [ps] s) ->
+  (existsT2 psc, (ImpRRule [psc] sc) * (@ctr_L A ps psc)).
+Proof.
+intros s sc A ps ctr RA. inversion RA. inversion ctr. subst.
+inversion H. subst. apply app2_find_hole in H1. destruct H1. destruct s.
+- destruct s.
+  + destruct p. subst. exists (Γ2 ++ A0 :: A :: Γ3 ++ Γ4, Δ0 ++ B :: Δ1).
+    split. apply ImpRRule_I.
+    assert (E1: Γ2 ++ A0 :: A :: Γ3 ++ A :: Γ4 = (Γ2 ++ [A0]) ++ A :: Γ3 ++ A :: Γ4).
+    repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+    assert (E2: Γ2 ++ A0 :: A :: Γ3 ++ Γ4 = (Γ2 ++ [A0]) ++ A :: Γ3 ++ Γ4).
+    repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E2.
+    apply ctr_LI.
+  + destruct p. subst. destruct x.
+    * simpl in e0. subst. repeat rewrite app_nil_r.
+      exists (Γ2 ++ A0 :: A :: Γ3 ++ Γ4, Δ0 ++ B :: Δ1). split. apply ImpRRule_I.
+      assert (E1: Γ2 ++ A0 :: A :: Γ3 ++ A :: Γ4 = (Γ2 ++ [A0]) ++ A :: Γ3 ++ A :: Γ4).
+      repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+      assert (E2: Γ2 ++ A0 :: A :: Γ3 ++ Γ4 = (Γ2 ++ [A0]) ++ A :: Γ3 ++ Γ4).
+      repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E2.
+      apply ctr_LI.
+    * inversion e0. subst. apply app2_find_hole in H2. destruct H2. destruct s.
+      { destruct s.
+        - destruct p. subst. exists ((Γ2 ++ m :: Γ3) ++ A0 :: Γ4, Δ0 ++ B :: Δ1).
+          split.
+          assert (E: Γ2 ++ m :: Γ3 ++ Γ4 = (Γ2 ++ m :: Γ3) ++ Γ4).
+          rewrite <- app_assoc. reflexivity. rewrite E. apply ImpRRule_I.
+          assert (E1: (Γ2 ++ m :: Γ3) ++ A0 :: m :: Γ4 = Γ2 ++ m :: (Γ3 ++ [A0]) ++ m :: Γ4).
+          repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+          assert (E2: (Γ2 ++ m :: Γ3) ++ A0 :: Γ4 = Γ2 ++ m :: (Γ3 ++ [A0]) ++ Γ4).
+          repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E2.
+          apply ctr_LI.
+        - destruct p. subst. destruct x0.
+          + simpl in e1. subst. repeat rewrite app_nil_r.
+            exists ((Γ2 ++ m :: Γ3) ++ A0 :: Γ4, Δ0 ++ B :: Δ1). split.
+            assert (E: Γ2 ++ m :: Γ3 ++ Γ4 = (Γ2 ++ m :: Γ3) ++ Γ4).
+            rewrite <- app_assoc. reflexivity. rewrite E.
+            apply ImpRRule_I.
+            assert (E1: (Γ2 ++ m :: Γ3) ++ A0 :: m :: Γ4 = Γ2 ++ m :: (Γ3 ++ [A0]) ++ m :: Γ4).
+            repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+            assert (E2: (Γ2 ++ m :: Γ3) ++ A0 :: Γ4 = Γ2 ++ m :: (Γ3 ++ [A0]) ++ Γ4).
+            repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E2.
+            apply ctr_LI.
+          + inversion e1. subst.
+            exists ((Γ2 ++ m0 :: Γ3 ++ x0) ++ A0 :: Γ1, Δ0 ++ B :: Δ1). split.
+            assert (E: Γ2 ++ m0 :: Γ3 ++ x0 ++ Γ1 = (Γ2 ++ m0 :: Γ3 ++ x0) ++ Γ1).
+            repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E.
+            apply ImpRRule_I.
+            repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. apply ctr_LI. }
+      { destruct p. subst. exists ((Γ2 ++ m :: x) ++ A0 :: x0 ++ Γ4,Δ0 ++ B :: Δ1).
+        split. assert (E: Γ2 ++ m :: (x ++ x0) ++ Γ4 = (Γ2 ++ m :: x) ++ x0 ++ Γ4).
+        repeat rewrite <- app_assoc. reflexivity. rewrite E. apply ImpRRule_I.
+        assert (E1: (Γ2 ++ m :: x) ++ A0 :: x0 ++ m :: Γ4 = Γ2 ++ m :: (x ++ A0 :: x0) ++ m :: Γ4).
+        repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+        assert (E2: (Γ2 ++ m :: x) ++ A0 :: x0 ++ Γ4 = Γ2 ++ m :: (x ++ A0 :: x0) ++ Γ4).
+        repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E2.
+        apply ctr_LI. }
+- destruct p. subst. exists (Γ0 ++ A0 :: x ++ A :: Γ3 ++ Γ4, Δ0 ++ B :: Δ1).
+  split. rewrite <- app_assoc. apply ImpRRule_I.
+  assert (E1: Γ0 ++ A0 :: x ++ A :: Γ3 ++ A :: Γ4 = (Γ0 ++ A0 :: x) ++ A :: Γ3 ++ A :: Γ4).
+  repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+  assert (E2: Γ0 ++ A0 :: x ++ A :: Γ3 ++ Γ4 = (Γ0 ++ A0 :: x) ++ A :: Γ3 ++ Γ4).
+  repeat rewrite cons_single. repeat rewrite <- app_assoc. reflexivity. rewrite E2.
+  apply ctr_LI.
+Qed.
+ +
+Lemma ImpL_app_ctr_L : forall s sc A ps1 ps2,
+  (@ctr_L A s sc) ->
+  (ImpLRule [ps1;ps2] s) ->
+  ((existsT2 psc1 psc2, (ImpLRule [psc1;psc2] sc) *
+                       (@ctr_L A ps1 psc1) *
+                       (@ctr_L A ps2 psc2))
+  +
+  (existsT2 B C invps11 invps12 invps21 invps22 invpsc11 invpsc22,
+                       (A = Imp B C) *
+                       (ImpLRule [invps11;invps12] ps1) *
+                       (ImpLRule [invps21;invps22] ps2) *
+                       (@ctr_R B invps11 invpsc11) *
+                       (@ctr_L C invps22 invpsc22) *
+                       (ImpLRule [invpsc11;invpsc22] sc))).
+Proof.
+intros s sc A ps1 ps2 ctr RA. inversion RA. inversion ctr. subst. inversion H.
+subst. apply app2_find_hole in H1. destruct H1. repeat destruct s ; destruct p ; subst.
+- inversion e0. subst. right. exists A0. exists B.
+  exists (Γ2 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: A0 :: Δ1). exists (Γ2 ++ Γ3 ++ B :: Γ4, Δ0 ++ A0 :: Δ1).
+  exists (Γ2 ++ B :: Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ B :: Γ4, Δ0 ++ Δ1).
+  exists (Γ2 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ Γ4, Δ0 ++ Δ1). repeat split.
+  assert (Γ2 ++ Γ3 ++ Γ4 = (Γ2 ++ Γ3) ++ Γ4). rewrite <- app_assoc. reflexivity. rewrite H0.
+  clear H0. assert (Γ2 ++ Γ3 ++ B :: Γ4 = (Γ2 ++ Γ3) ++ B :: Γ4). rewrite <- app_assoc. reflexivity.
+  rewrite H0. clear H0. assert (Γ2 ++ Γ3 ++ A0 --> B :: Γ4 = (Γ2 ++ Γ3) ++ A0 --> B :: Γ4). rewrite <- app_assoc.
+  reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+  assert (Γ2 ++ B :: Γ3 ++ Γ4 = (Γ2 ++ B :: Γ3) ++ Γ4). rewrite <- app_assoc. reflexivity. rewrite H0.
+  clear H0. assert (Γ2 ++ B :: Γ3 ++ B :: Γ4 = (Γ2 ++ B :: Γ3) ++ B :: Γ4). rewrite <- app_assoc. reflexivity.
+  rewrite H0. clear H0. assert (Γ2 ++ B :: Γ3 ++ A0 --> B :: Γ4 = (Γ2 ++ B :: Γ3) ++ A0 --> B :: Γ4). rewrite <- app_assoc.
+  reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+  assert (Δ0 ++ A0 :: A0 :: Δ1 = Δ0 ++ A0 :: [] ++ A0 :: Δ1). reflexivity. rewrite H0. clear H0.
+  assert (Δ0 ++ A0 :: Δ1 = Δ0 ++ A0 :: [] ++ Δ1). reflexivity. rewrite H0. clear H0.
+  apply ctr_RI.
+- destruct x.
+  * simpl in e0. inversion e0. subst. right. exists A0. exists B.
+    exists (Γ2 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: A0 :: Δ1). exists (Γ2 ++ Γ3 ++ B :: Γ4, Δ0 ++ A0 :: Δ1).
+    exists (Γ2 ++ B :: Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ B :: Γ4, Δ0 ++ Δ1).
+    exists (Γ2 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ Γ4, Δ0 ++ Δ1). repeat split.
+    assert (Γ2 ++ Γ3 ++ Γ4 = (Γ2 ++ Γ3) ++ Γ4). repeat rewrite <- app_assoc. reflexivity. rewrite H0.
+    clear H0. assert (Γ2 ++ Γ3 ++ B :: Γ4 = (Γ2 ++ Γ3) ++ B :: Γ4). rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. assert ((Γ2 ++ []) ++ Γ3 ++ A0 --> B :: Γ4 = (Γ2 ++ Γ3) ++ A0 --> B :: Γ4).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+    assert (Γ2 ++ B :: Γ3 ++ Γ4 = (Γ2 ++ B :: Γ3) ++ Γ4). rewrite <- app_assoc. reflexivity. rewrite H0.
+    clear H0. assert (Γ2 ++ B :: Γ3 ++ B :: Γ4 = (Γ2 ++ B :: Γ3) ++ B :: Γ4). rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. assert ((Γ2 ++ []) ++ B :: Γ3 ++ A0 --> B :: Γ4 = (Γ2 ++ B :: Γ3) ++ A0 --> B :: Γ4).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+    assert (Δ0 ++ A0 :: A0 :: Δ1 = Δ0 ++ A0 :: [] ++ A0 :: Δ1). reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ A0 :: Δ1 = Δ0 ++ A0 :: [] ++ Δ1). reflexivity. rewrite H0. clear H0.
+    apply ctr_RI.
+  * inversion e0. subst. apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+    + inversion e1. subst. right. exists A0. exists B.
+      exists (Γ2 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1).
+      exists (Γ2 ++ Γ3 ++ B :: Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ B :: Γ4, Δ0 ++ Δ1).
+      exists (Γ2 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ Γ4, Δ0 ++ Δ1). repeat split.
+      repeat rewrite <- app_assoc. apply ImpLRule_I. repeat rewrite <- app_assoc. apply ImpLRule_I.
+      assert (Δ0 ++ A0 :: A0 :: Δ1 = Δ0 ++ A0 :: [] ++ A0 :: Δ1). reflexivity. rewrite H0. clear H0.
+      assert (Δ0 ++ A0 :: Δ1 = Δ0 ++ A0 :: [] ++ Δ1). reflexivity. rewrite H0. clear H0.
+      apply ctr_RI.
+    + destruct x0.
+      { simpl in e1. inversion e1. subst. right. exists A0. exists B.
+        exists (Γ2 ++ Γ3 ++ Γ1, Δ0 ++ A0 :: A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ Γ1, Δ0 ++ A0 :: Δ1).
+        exists (Γ2 ++ Γ3 ++ B :: Γ1, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ B :: Γ1, Δ0 ++ Δ1).
+        exists (Γ2 ++ Γ3 ++ Γ1, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: Γ3 ++ Γ1, Δ0 ++ Δ1). repeat split.
+        repeat rewrite <- app_assoc. simpl. rewrite app_nil_r. apply ImpLRule_I. repeat rewrite <- app_assoc.
+        rewrite app_nil_r. apply ImpLRule_I.
+        assert (Δ0 ++ A0 :: A0 :: Δ1 = Δ0 ++ A0 :: [] ++ A0 :: Δ1). reflexivity. rewrite H0. clear H0.
+        assert (Δ0 ++ A0 :: Δ1 = Δ0 ++ A0 :: [] ++ Δ1). reflexivity. rewrite H0. clear H0.
+        apply ctr_RI. }
+      { inversion e1. subst. left. exists (Γ2 ++ m0 :: Γ3 ++ x0 ++ Γ1, Δ0 ++ A0 :: Δ1).
+        exists (Γ2 ++ m0 :: Γ3 ++ x0 ++ B :: Γ1, Δ0 ++ Δ1). repeat split.
+        assert (Γ2 ++ m0 :: Γ3 ++ x0 ++ Γ1 = (Γ2 ++ m0 :: Γ3 ++ x0) ++ Γ1). repeat rewrite <- app_assoc.
+        simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ m0 :: Γ3 ++ x0 ++ A0 --> B :: Γ1 = (Γ2 ++ m0 :: Γ3 ++ x0) ++ A0 --> B :: Γ1). repeat rewrite <- app_assoc.
+        simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ m0 :: Γ3 ++ x0 ++ B :: Γ1 = (Γ2 ++ m0 :: Γ3 ++ x0) ++ B :: Γ1). repeat rewrite <- app_assoc.
+        simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. apply ctr_LI.
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. apply ctr_LI. }
+    + destruct x0.
+      { simpl in e1. inversion e1. subst. right. exists A0. exists B.
+        exists (Γ2 ++ x ++ Γ4, Δ0 ++ A0 :: A0 :: Δ1). exists (Γ2 ++ B :: x ++ Γ4, Δ0 ++ A0 :: Δ1).
+        exists (Γ2 ++ x ++ B :: Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: x ++ B :: Γ4, Δ0 ++ Δ1).
+        exists (Γ2 ++ x ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ B :: x ++ Γ4, Δ0 ++ Δ1). repeat split.
+        repeat rewrite <- app_assoc. apply ImpLRule_I. repeat rewrite <- app_assoc. apply ImpLRule_I.
+        assert (Δ0 ++ A0 :: A0 :: Δ1 = Δ0 ++ A0 :: [] ++ A0 :: Δ1). reflexivity. rewrite H0. clear H0.
+        assert (Δ0 ++ A0 :: Δ1 = Δ0 ++ A0 :: [] ++ Δ1). reflexivity. rewrite H0. clear H0.
+        apply ctr_RI. rewrite <- app_assoc. simpl. apply ImpLRule_I. }
+      { inversion e1. subst. left. exists (Γ2 ++ m :: x ++ x0 ++ Γ4, Δ0 ++ A0 :: Δ1).
+        exists (Γ2 ++ m :: x ++ B :: x0 ++ Γ4, Δ0 ++ Δ1). repeat split.
+        assert (Γ2 ++ m :: x ++ x0 ++ Γ4 = (Γ2 ++ m :: x) ++ x0 ++ Γ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ m :: x ++ B :: x0 ++ Γ4 = (Γ2 ++ m :: x) ++ B :: x0 ++ Γ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ m :: (x ++ A0 --> B :: x0) ++ Γ4 = (Γ2 ++ m :: x) ++ A0 --> B :: x0 ++ Γ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        assert ((Γ2 ++ m :: x) ++ x0 ++ m :: Γ4 = Γ2 ++ m :: (x ++ x0) ++ m :: Γ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ m :: x ++ x0 ++ Γ4 = Γ2 ++ m :: (x ++ x0) ++ Γ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ctr_LI.
+        assert ((Γ2 ++ m :: x) ++ B :: x0 ++ m :: Γ4 = Γ2 ++ m :: (x ++ B :: x0) ++ m :: Γ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ m :: x ++ B :: x0 ++ Γ4 = Γ2 ++ m :: (x ++ B :: x0) ++ Γ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ctr_LI. }
+- destruct x.
+  + simpl in e0. inversion e0. subst. right. exists A0. exists B.
+    exists (Γ0 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: A0 :: Δ1). exists (Γ0 ++ Γ3 ++ B :: Γ4, Δ0 ++ A0 :: Δ1).
+    exists (Γ0 ++ B :: Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ0 ++ B :: Γ3 ++ B :: Γ4, Δ0 ++ Δ1).
+    exists (Γ0 ++ Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1). exists (Γ0 ++ B :: Γ3 ++ Γ4, Δ0 ++ Δ1) . repeat split.
+    assert (Γ0 ++ Γ3 ++ Γ4 = (Γ0 ++ Γ3) ++ Γ4). repeat rewrite <- app_assoc. reflexivity. rewrite H0.
+    clear H0. assert (Γ0 ++ Γ3 ++ B :: Γ4 = (Γ0 ++ Γ3) ++ B :: Γ4). rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. assert (Γ0 ++ Γ3 ++ A0 --> B :: Γ4 = (Γ0 ++ Γ3) ++ A0 --> B :: Γ4).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+    assert (Γ0 ++ B :: Γ3 ++ Γ4 = (Γ0 ++ B :: Γ3) ++ Γ4). rewrite <- app_assoc. reflexivity. rewrite H0.
+    clear H0. assert (Γ0 ++ B :: Γ3 ++ B :: Γ4 = (Γ0 ++ B :: Γ3) ++ B :: Γ4). rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. assert (Γ0 ++ B :: Γ3 ++ A0 --> B :: Γ4 = (Γ0 ++ B :: Γ3) ++ A0 --> B :: Γ4).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+    assert (Δ0 ++ A0 :: A0 :: Δ1 = Δ0 ++ A0 :: [] ++ A0 :: Δ1). reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ A0 :: Δ1 = Δ0 ++ A0 :: [] ++ Δ1). reflexivity. rewrite H0. clear H0.
+    apply ctr_RI. repeat rewrite <- app_assoc. simpl. apply ImpLRule_I.
+  + inversion e0. subst. left. exists (Γ0 ++ x ++ A :: Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1).
+    exists (Γ0 ++ B :: x ++ A :: Γ3 ++ Γ4, Δ0 ++ Δ1). repeat split. repeat rewrite <- app_assoc.
+    apply ImpLRule_I.
+    assert (Γ0 ++ x ++ A :: Γ3 ++ A :: Γ4 = (Γ0 ++ x) ++ A :: Γ3 ++ A :: Γ4). repeat rewrite <- app_assoc.
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ x ++ A :: Γ3 ++ Γ4 = (Γ0 ++ x) ++ A :: Γ3 ++ Γ4). repeat rewrite <- app_assoc.
+    reflexivity. rewrite H0. clear H0. apply ctr_LI.
+    assert (Γ0 ++ B :: x ++ A :: Γ3 ++ A :: Γ4 = (Γ0 ++ B :: x) ++ A :: Γ3 ++ A :: Γ4). repeat rewrite <- app_assoc.
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ B :: x ++ A :: Γ3 ++ Γ4 = (Γ0 ++ B :: x) ++ A :: Γ3 ++ Γ4). repeat rewrite <- app_assoc.
+    reflexivity. rewrite H0. clear H0. apply ctr_LI.
+Qed.
+ +
+Lemma KR_app_ctr_L : forall s sc A ps,
+  (@ctr_L A s sc) ->
+  (KRRule [ps] s) ->
+    ((KRRule [ps] sc) +
+     (existsT2 psc, (KRRule [psc] sc) * (@ctr_L (unBox_formula A) ps psc))).
+Proof.
+intros s sc A ps ctr RA. inversion RA. inversion ctr. rewrite <- H1 in H2.
+inversion H2. subst. apply univ_gen_ext_elem_deep with (l3:=Γ1) (l4:=Γ2 ++ A :: Γ3) (a:=A) in X.
+destruct X. 3: reflexivity.
+- destruct p. apply univ_gen_ext_elem_deep with (l3:=Γ1 ++ Γ2) (l4:=Γ3) (a:=A) in u. destruct u. destruct p.
+3: rewrite <- app_assoc. 3: reflexivity.
+  * left. apply KRRule_I.
+    assumption.
+    apply univ_gen_ext_add_elem_deep. rewrite app_assoc. assumption. assumption.
+  * exfalso. apply f. repeat destruct s. repeat destruct p. subst. apply is_box_is_in_boxed_list with (A:=A) in H0 .
+    unfold is_boxedT. destruct H0. exists x1. auto. apply in_or_app. right. apply in_eq.
+- repeat destruct s. repeat destruct p. apply univ_gen_ext_elem_deep with (l3:=Γ2) (l4:=Γ3) (a:=A) in u0.
+  destruct u0. 3: reflexivity.
+  * destruct p. exfalso. subst. apply is_box_is_in_boxed_list with (A:=A) in H0. apply f. unfold is_boxedT.
+    destruct H0. exists x1. auto. apply in_or_app. right. apply in_eq.
+  * repeat destruct s. repeat destruct p. right. subst.
+    exists (unboxed_list (x ++ A :: x1 ++ x2), [A0]). split.
+      { apply KRRule_I.
+        intro. intros. apply H0. apply in_app_or in H. destruct H. apply in_or_app. left. assumption.
+        inversion H. subst. apply in_or_app. right. apply in_eq. apply in_app_or in H1. destruct H1.
+        apply in_or_app. right. apply in_cons. apply in_or_app. left. assumption.
+        apply in_or_app. right. apply in_cons. apply in_or_app. right. apply in_cons.
+        assumption.
+        apply univ_gen_ext_combine. assumption. apply univ_gen_ext_cons. apply univ_gen_ext_combine.
+        assumption. assumption. }
+      { repeat rewrite cons_single. repeat rewrite unbox_app_distrib. simpl. apply ctr_LI. }
+Qed.
+ +
+Lemma ImpR_app_ctr_R : forall s sc A ps,
+  (@ctr_R A s sc) ->
+  (ImpRRule [ps] s) ->
+  ((existsT2 psc, (ImpRRule [psc] sc) * (@ctr_R A ps psc))
+  +
+  (existsT2 B C invps invpsc0 invpsc, (A = Imp B C) * (ImpRRule [invps] ps) * (ImpRRule [invpsc] sc) *
+                                      (@ctr_L B invps invpsc0) * (@ctr_R C invpsc0 invpsc))).
+Proof.
+intros s sc A ps ctr RA. inversion RA. inversion ctr. subst.
+inversion H. subst. apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+- inversion e0. right. exists A0. exists B. exists (Γ0 ++ A0 :: A0 :: Γ1, Δ2 ++ B :: Δ3 ++ B :: Δ4).
+  exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3 ++ B :: Δ4). exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3 ++ Δ4).
+  repeat split. assert (Δ2 ++ B :: Δ3 ++ B :: Δ4 = (Δ2 ++ B :: Δ3) ++ B :: Δ4). rewrite <- app_assoc. reflexivity.
+  rewrite H0. clear H0. assert (Δ2 ++ B :: Δ3 ++ A0 --> B :: Δ4 = (Δ2 ++ B :: Δ3) ++ A0 --> B :: Δ4). rewrite <- app_assoc. reflexivity.
+  rewrite H0. clear H0. apply ImpRRule_I.
+  assert (Γ0 ++ A0 :: A0 :: Γ1 = Γ0 ++ A0 :: [] ++ A0 :: Γ1). reflexivity. rewrite H0. clear H0.
+  assert (Γ0 ++ A0 :: Γ1 = Γ0 ++ A0 :: [] ++ Γ1). reflexivity. rewrite H0. clear H0.
+  apply ctr_LI.
+- destruct x.
+  * simpl in e0. inversion e0. subst. right. exists A0. exists B.
+    exists (Γ0 ++ A0 :: A0 :: Γ1, (Δ2 ++ []) ++ B :: Δ3 ++ B :: Δ4).
+    exists (Γ0 ++ A0 :: Γ1, (Δ2 ++ []) ++ B :: Δ3 ++ B :: Δ4). exists (Γ0 ++ A0 :: Γ1, (Δ2 ++ []) ++ B :: Δ3 ++ Δ4).
+    repeat split. assert ((Δ2 ++ []) ++ B :: Δ3 ++ B :: Δ4 = (Δ2 ++ B :: Δ3) ++ B :: Δ4). repeat rewrite <- app_assoc.
+    reflexivity. rewrite H0. clear H0. assert ((Δ2 ++ []) ++ B :: Δ3 ++ A0 --> B :: Δ4 = (Δ2 ++ B :: Δ3) ++ A0 --> B :: Δ4).
+    rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpRRule_I. repeat rewrite <- app_assoc. simpl. apply ImpRRule_I.
+    assert (Γ0 ++ A0 :: A0 :: Γ1 = Γ0 ++ A0 :: [] ++ A0 :: Γ1). reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ A0 :: Γ1 = Γ0 ++ A0 :: [] ++ Γ1). reflexivity. rewrite H0. clear H0.
+    apply ctr_LI.
+  * inversion e0. subst. apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+    + inversion e1. subst. right. exists A0. exists B.
+      exists (Γ0 ++ A0 :: A0 :: Γ1, Δ2 ++ B :: Δ3 ++ B :: Δ4). exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3 ++ B :: Δ4).
+      exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3 ++ Δ4). repeat split.
+      repeat rewrite <- app_assoc. apply ImpRRule_I.
+      assert (Γ0 ++ A0 :: A0 :: Γ1 = Γ0 ++ A0 :: [] ++ A0 :: Γ1). reflexivity. rewrite H0. clear H0.
+      assert (Γ0 ++ A0 :: Γ1 = Γ0 ++ A0 :: [] ++ Γ1). reflexivity. rewrite H0. clear H0.
+      apply ctr_LI.
+    + destruct x0.
+      { simpl in e1. inversion e1. subst. right. exists A0. exists B.
+        exists (Γ0 ++ A0 :: A0 :: Γ1, Δ2 ++ B :: Δ3 ++ B :: Δ1). exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3 ++ B :: Δ1).
+        exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3 ++ Δ1). repeat split.
+        repeat rewrite <- app_assoc. simpl. rewrite app_nil_r. apply ImpRRule_I.
+        assert (Γ0 ++ A0 :: A0 :: Γ1 = Γ0 ++ A0 :: [] ++ A0 :: Γ1). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ A0 :: Γ1 = Γ0 ++ A0 :: [] ++ Γ1). reflexivity. rewrite H0. clear H0.
+        apply ctr_LI. }
+      { inversion e1. subst. left. exists (Γ0 ++ A0 :: Γ1, Δ2 ++ m0 :: Δ3 ++ x0 ++ B :: Δ1).
+        repeat split. assert (Δ2 ++ m0 :: Δ3 ++ x0 ++ B :: Δ1 = (Δ2 ++ m0 :: Δ3 ++ x0) ++ B :: Δ1).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ m0 :: Δ3 ++ x0 ++ A0 --> B :: Δ1 = (Δ2 ++ m0 :: Δ3 ++ x0) ++ A0 --> B :: Δ1). repeat rewrite <- app_assoc.
+        simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. apply ctr_RI. }
+    + destruct x0.
+      { simpl in e1. inversion e1. subst. right. exists A0. exists B.
+        exists (Γ0 ++ A0 :: A0 :: Γ1, Δ2 ++ B :: x ++ B :: Δ4). exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: x ++ B :: Δ4).
+        exists (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: x ++ Δ4). repeat split.
+        repeat rewrite <- app_assoc. apply ImpRRule_I. repeat rewrite <- app_assoc. apply ImpRRule_I.
+        assert (Γ0 ++ A0 :: A0 :: Γ1 = Γ0 ++ A0 :: [] ++ A0 :: Γ1). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ A0 :: Γ1 = Γ0 ++ A0 :: [] ++ Γ1). reflexivity. rewrite H0. clear H0.
+        apply ctr_LI. }
+      { inversion e1. subst. left. exists (Γ0 ++ A0 :: Γ1, Δ2 ++ m :: x ++ B :: x0 ++ Δ4).
+        repeat split.
+        assert (Δ2 ++ m :: x ++ B :: x0 ++ Δ4 = (Δ2 ++ m :: x) ++ B :: x0 ++ Δ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ m :: (x ++ A0 --> B :: x0) ++ Δ4 = (Δ2 ++ m :: x) ++ A0 --> B :: x0 ++ Δ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        assert ((Δ2 ++ m :: x) ++ B :: x0 ++ m :: Δ4 = Δ2 ++ m :: (x ++ B :: x0) ++ m :: Δ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ m :: x ++ B :: x0 ++ Δ4 = Δ2 ++ m :: (x ++ B :: x0) ++ Δ4). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ctr_RI. }
+- destruct x.
+  + simpl in e0. inversion e0. subst. right. exists A0. exists B.
+    exists (Γ0 ++ A0 :: A0 :: Γ1, Δ0 ++ B :: Δ3 ++ B :: Δ4). exists (Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ3 ++ B :: Δ4).
+    exists (Γ0 ++ A0 :: Γ1, Δ0 ++ B :: Δ3 ++ Δ4). repeat split.
+    assert (Δ0 ++ B :: Δ3 ++ A0 --> B :: Δ4 = (Δ0 ++ B :: Δ3) ++ A0 --> B :: Δ4). repeat rewrite <- app_assoc. reflexivity. rewrite H0.
+    clear H0. assert (Δ0 ++ B :: Δ3 ++ B :: Δ4 = (Δ0 ++ B :: Δ3) ++ B :: Δ4). rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply ImpRRule_I. repeat rewrite <- app_assoc. simpl. apply ImpRRule_I.
+    assert (Γ0 ++ A0 :: A0 :: Γ1 = Γ0 ++ A0 :: [] ++ A0 :: Γ1). reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ A0 :: Γ1 = Γ0 ++ A0 :: [] ++ Γ1). reflexivity. rewrite H0. clear H0.
+    apply ctr_LI.
+  + inversion e0. subst. left. exists (Γ0 ++ A0 :: Γ1, Δ0 ++ B :: x ++ A :: Δ3 ++ Δ4).
+    repeat split. repeat rewrite <- app_assoc. apply ImpRRule_I.
+    assert (Δ0 ++ B :: x ++ A :: Δ3 ++ A :: Δ4 = (Δ0 ++ B :: x) ++ A :: Δ3 ++ A :: Δ4). repeat rewrite <- app_assoc.
+    reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ B :: x ++ A :: Δ3 ++ Δ4 = (Δ0 ++ B :: x) ++ A :: Δ3 ++ Δ4). repeat rewrite <- app_assoc.
+    reflexivity. rewrite H0. clear H0. apply ctr_RI.
+Qed.
+ +
+Lemma ImpL_app_ctr_R : forall s sc A ps1 ps2,
+  (@ctr_R A s sc) ->
+  (ImpLRule [ps1;ps2] s) ->
+  (existsT2 psc1 psc2, (ImpLRule [psc1;psc2] sc) * (@ctr_R A ps1 psc1) * (@ctr_R A ps2 psc2)).
+Proof.
+intros s sc A ps1 ps2 ctr RA. inversion RA. inversion ctr. subst.
+inversion H. subst. apply app2_find_hole in H2. destruct H2. destruct s.
+- destruct s.
+  + destruct p. subst. exists (Γ0 ++ Γ1, Δ2 ++ A0 :: A :: Δ3 ++ Δ4). exists (Γ0 ++ B :: Γ1, Δ2 ++ A :: Δ3 ++ Δ4).
+    split. split.
+    apply ImpLRule_I.
+    assert (E1: Δ2 ++ A0 :: A :: Δ3 ++ A :: Δ4 = (Δ2 ++ [A0]) ++ A :: Δ3 ++ A :: Δ4).
+    repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E1.
+    assert (E2: Δ2 ++ A0 :: A :: Δ3 ++ Δ4 = (Δ2 ++ [A0]) ++ A :: Δ3 ++ Δ4).
+    repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E2. apply ctr_RI.
+    apply ctr_RI.
+  + destruct p. destruct x.
+    * rewrite app_nil_r in e. rewrite app_nil_l in e0. subst.
+      exists (Γ0 ++ Γ1, Δ2 ++ A0 :: A :: Δ3 ++ Δ4). exists (Γ0 ++ B :: Γ1, Δ2 ++ A :: Δ3 ++ Δ4).
+      split. split.
+      apply ImpLRule_I.
+      assert (E1: Δ2 ++ A0 :: A :: Δ3 ++ A :: Δ4 = (Δ2 ++ [A0]) ++ A :: Δ3 ++ A :: Δ4).
+      repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E1.
+      assert (E2: Δ2 ++ A0 :: A :: Δ3 ++ Δ4 = (Δ2 ++ [A0]) ++ A :: Δ3 ++ Δ4).
+      repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E2. apply ctr_RI.
+      apply ctr_RI.
+    * inversion e0. subst. apply app2_find_hole in H2. destruct H2. destruct s.
+      { destruct s.
+        - destruct p. subst. exists (Γ0 ++ Γ1, (Δ2 ++ m :: Δ3) ++ A0 :: Δ4).
+          exists (Γ0 ++ B :: Γ1, (Δ2 ++ m :: Δ3) ++ Δ4). split. split.
+          assert (E: Δ2 ++ m :: Δ3 ++ Δ4 = (Δ2 ++ m :: Δ3) ++ Δ4).
+          rewrite <- app_assoc. reflexivity. rewrite E.
+          apply ImpLRule_I.
+          assert (E1: (Δ2 ++ m :: Δ3) ++ A0 :: m :: Δ4 = Δ2 ++ m :: (Δ3 ++ [A0]) ++ m :: Δ4).
+          repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E1.
+          assert (E2: (Δ2 ++ m :: Δ3) ++ A0 :: Δ4 = Δ2 ++ m :: (Δ3 ++ [A0]) ++ Δ4).
+          repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E2. apply ctr_RI.
+          rewrite <- app_assoc. simpl. apply ctr_RI.
+        - destruct p. subst. destruct x0.
+          + rewrite app_nil_l in e1. rewrite app_nil_r in e0. subst.
+            exists (Γ0 ++ Γ1,(Δ2 ++ m :: Δ3) ++ A0 :: Δ4). exists (Γ0 ++ B :: Γ1, (Δ2 ++ m :: Δ3) ++ Δ4).
+            split. split.
+            assert (E: Δ2 ++ m :: Δ3 ++ Δ4 = (Δ2 ++ m :: Δ3) ++ Δ4).
+            rewrite <- app_assoc. reflexivity. rewrite E.
+            apply ImpLRule_I.
+            assert (E1: (Δ2 ++ m :: Δ3 ++ []) ++ A0 :: m :: Δ4 = Δ2 ++ m :: (Δ3 ++ [A0]) ++ m :: Δ4).
+            rewrite app_nil_r. repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E1.
+            assert (E2: (Δ2 ++ m :: Δ3) ++ A0 :: Δ4 = Δ2 ++ m :: (Δ3 ++ [A0]) ++ Δ4).
+            repeat rewrite <- app_assoc. rewrite cons_single. reflexivity. rewrite E2. apply ctr_RI.
+            rewrite <- app_assoc. simpl. apply ctr_RI.
+          + inversion e1. subst. exists (Γ0 ++ Γ1,(Δ2 ++ m0 :: Δ3 ++ x0) ++ A0 :: Δ1).
+            exists (Γ0 ++ B :: Γ1,(Δ2 ++ m0 :: Δ3 ++ x0) ++ Δ1). split. split.
+            assert (E: Δ2 ++ m0 :: Δ3 ++ x0 ++ Δ1 = (Δ2 ++ m0 :: Δ3 ++ x0) ++ Δ1).
+            rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E.
+            apply ImpLRule_I.
+            assert (E1: (Δ2 ++ m0 :: Δ3 ++ m0 :: x0) ++ A0 :: Δ1 = Δ2 ++ m0 :: Δ3 ++ m0 :: x0 ++ A0 :: Δ1).
+            repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+            assert (E2: (Δ2 ++ m0 :: Δ3 ++ x0) ++ A0 :: Δ1 = Δ2 ++ m0 :: Δ3 ++ x0 ++ A0 :: Δ1).
+            repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E2. apply ctr_RI.
+            rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. apply ctr_RI. }
+      { destruct p. subst. exists (Γ0 ++ Γ1,(Δ2 ++ m :: x) ++ A0 :: x0 ++ Δ4).
+        exists (Γ0 ++ B :: Γ1, (Δ2 ++ m :: x) ++ x0 ++ Δ4). split. split.
+        assert (E: Δ2 ++ m :: (x ++ x0) ++ Δ4 = (Δ2 ++ m :: x) ++ x0 ++ Δ4).
+        rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E.
+        apply ImpLRule_I.
+        assert (E1: (Δ2 ++ m :: x) ++ A0 :: x0 ++ m :: Δ4 = Δ2 ++ m :: (x ++ A0 :: x0) ++ m :: Δ4).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+        assert (E2: (Δ2 ++ m :: x) ++ A0 :: x0 ++ Δ4 = Δ2 ++ m :: (x ++ A0 :: x0) ++ Δ4).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E2. apply ctr_RI.
+        assert (E1: (Δ2 ++ m :: x) ++ x0 ++ Δ4 = Δ2 ++ m :: (x ++ x0) ++ Δ4).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E1. apply ctr_RI. }
+- destruct p. subst. exists (Γ0 ++ Γ1, Δ0 ++ A0 :: x ++ A :: Δ3 ++ Δ4).
+  exists (Γ0 ++ B :: Γ1, Δ0 ++ x ++ A :: Δ3 ++ Δ4). split. split.
+  rewrite <- app_assoc. apply ImpLRule_I.
+  assert (E1: Δ0 ++ A0 :: x ++ A :: Δ3 ++ A :: Δ4 = (Δ0 ++ A0 :: x) ++ A :: Δ3 ++ A :: Δ4).
+  repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E1.
+  assert (E2: Δ0 ++ A0 :: x ++ A :: Δ3 ++ Δ4 = (Δ0 ++ A0 :: x) ++ A :: Δ3 ++ Δ4).
+  repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E2. apply ctr_RI.
+  rewrite app_assoc. apply ctr_RI.
+Qed.
+ +
+Lemma KR_app_ctr_R : forall s sc A ps,
+  (@ctr_R A s sc) -> (KRRule [ps] s) -> (KRRule [ps] sc).
+Proof.
+intros s sc A ps ctr RA. inversion RA. inversion ctr. rewrite <- H1 in H2.
+inversion H2. apply app2_find_hole in H6. destruct H6. destruct s0.
+  + destruct s0.
+    * destruct p. inversion e0. apply KRRule_I. assumption. assumption.
+    * destruct p. subst. destruct x.
+      { rewrite app_nil_l in e0. inversion e0. subst. apply KRRule_I.
+        assumption. assumption. }
+      { inversion e0. subst. apply app2_find_hole in H3. destruct H3. destruct s.
+        - destruct s.
+          + destruct p. inversion e1. apply KRRule_I. assumption. assumption.
+          + destruct p. subst. destruct x0.
+            * rewrite app_nil_l in e1. inversion e1. subst. apply KRRule_I. assumption.
+              assumption.
+            * inversion e1. subst. assert (E: Δ2 ++ m0 :: Δ3 ++ x0 ++ Box A0 :: Δ1 = (Δ2 ++ m0 :: Δ3 ++ x0) ++ Box A0 :: Δ1).
+              repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite E. apply KRRule_I. assumption.
+              assumption.
+        - destruct p. subst. destruct x0.
+          * rewrite app_nil_l in e1. inversion e1. subst. apply KRRule_I. assumption. assumption.
+          * inversion e1. subst. assert (E: Δ2 ++ m :: (x ++ Box A0 :: x0) ++ Δ4 = (Δ2 ++ m :: x) ++ Box A0 :: x0 ++ Δ4).
+            repeat rewrite <- app_assoc. reflexivity. rewrite E. apply KRRule_I. assumption. assumption. }
+  + destruct p. subst. destruct x.
+    * rewrite app_nil_l in e0. rewrite app_nil_r. inversion e0. subst. apply KRRule_I. assumption. assumption.
+    * inversion e0. rewrite <- app_assoc. simpl. apply KRRule_I. assumption. assumption.
+Qed.
+ +
+(* Now we can prove that contraction rules are height-preserving admissible. *)
+ +
+Theorem KS_hpadm_ctr_LR0 : forall (k : nat) s
+        (D0 : KS_prv s),
+        k = (derrec_height D0) ->
+          (forall sc A, (((@ctr_L A s sc) + (@ctr_R A s sc)) ->
+          existsT2 (D1 : KS_prv sc),
+          derrec_height D1 <= k)).
+Proof.
+induction k as [n IH] using (well_founded_induction_type lt_wf).
+intros s D0. remember D0 as D0'. destruct D0.
+(* D0 ip a leaf *)
+- intros hei sc A ctr. inversion f.
+(* D0 is ends with an application of rule *)
+- intros hei sc A ctr. destruct ctr as [ctr | ctr].
+{ inversion ctr. assert (DersNil: dersrec KS_rules (fun _ : Seq => False) []).
+  apply dersrec_nil. inversion k.
+  (* IdP *)
+  * inversion H1. rewrite <- H in H5. inversion H5.
+    apply app2_find_hole in H7. destruct H7. destruct s.
+    + destruct s.
+      { destruct p. inversion e0. subst. pose (IdPRule_I P Γ3 (Γ1 ++ Γ2) Δ0 Δ1). apply IdP in i. simpl in i.
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ3 ++ # P :: Γ1 ++ Γ2, Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+        left. reflexivity. reflexivity. }
+      { destruct p. destruct x.
+        - rewrite app_nil_l in e0. inversion e0.
+          subst. pose (IdPRule_I P (Γ3 ++ []) (Γ1 ++ Γ2) Δ0 Δ1). apply IdP in i. simpl in i.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ3 ++ []) ++ # P :: Γ1 ++ Γ2,Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+          repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+        - inversion e0. subst.
+          pose (IdPRule_I P Γ3 (x ++ A :: Γ1 ++ Γ2) Δ0 Δ1). apply IdP in i. simpl in i.
+          assert (E: Γ3 ++ # P :: x ++ A :: Γ1 ++ Γ2 = (Γ3 ++ # P :: x) ++ A :: Γ1 ++ Γ2). repeat rewrite <- app_assoc. reflexivity.
+          rewrite E in i. clear E.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ3 ++ # P :: x) ++ A :: Γ1 ++ Γ2,Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+          repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+    + destruct p. destruct x.
+      { rewrite app_nil_l in e0. inversion e0. subst.
+        pose (IdPRule_I P Γ0 (Γ1 ++ Γ2) Δ0 Δ1). apply IdP in i. simpl in i.
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ0 ++ # P :: Γ1 ++ Γ2, Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+        repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+      { inversion e0. subst. apply app2_find_hole in H9. destruct H9. destruct s.
+        - destruct s.
+          + destruct p. inversion e1. subst.
+            pose (IdPRule_I P Γ0 (Γ1 ++ Γ2) Δ0 Δ1). apply IdP in i. simpl in i.
+            pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ # P :: Γ1 ++ Γ2, Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+          + destruct p. destruct x0.
+            * rewrite app_nil_l in e1. inversion e1. subst.
+              pose (IdPRule_I P Γ0 (Γ1 ++ Γ4) Δ0 Δ1). apply IdP in i. simpl in i.
+              pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+              (ps:=[]) (Γ0 ++ # P :: Γ1 ++ Γ4, Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+              repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+            * inversion e1. subst.
+              pose (IdPRule_I P (Γ0 ++ m0 :: Γ1 ++ x0) Γ4 Δ0 Δ1). apply IdP in i. simpl in i.
+              repeat rewrite <- app_assoc in i. simpl in i. repeat rewrite <- app_assoc in i.
+              pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+              (ps:=[]) (Γ0 ++ m0 :: Γ1 ++ x0 ++ # P :: Γ4,Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+              repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+        - destruct p. destruct x0.
+          + rewrite app_nil_l in e1. inversion e1. subst.
+            pose (IdPRule_I P Γ0 ((x ++ []) ++ Γ2) Δ0 Δ1). apply IdP in i. simpl in i.
+            pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ # P :: (x ++ []) ++ Γ2, Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+          + inversion e1. subst.
+            pose (IdPRule_I P (Γ0 ++ m :: x) (x0 ++ Γ2) Δ0 Δ1). apply IdP in i. simpl in i.
+            assert (E: (Γ0 ++ m :: x) ++ # P :: x0 ++ Γ2 = Γ0 ++ m :: (x ++ # P :: x0) ++ Γ2). repeat rewrite <- app_assoc. reflexivity.
+            rewrite E in i. clear E.
+            pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ m :: (x ++ # P :: x0) ++ Γ2,Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+  (* BotL *)
+  * inversion H1. rewrite <- H in H5. inversion H5.
+    apply app2_find_hole in H7. destruct H7. destruct s.
+    + destruct s.
+      { destruct p. inversion e0. subst. pose (BotLRule_I Γ3 (Γ1 ++ Γ2) Δ). apply BotL in b.
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ3 ++ Bot :: Γ1 ++ Γ2, Δ) b DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+        left. reflexivity. reflexivity. }
+      { destruct p. destruct x.
+        - rewrite app_nil_l in e0. inversion e0.
+          subst. pose (BotLRule_I (Γ3 ++ []) (Γ1 ++ Γ2) Δ). apply BotL in b. simpl in b.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ3 ++ []) ++ Bot :: Γ1 ++ Γ2, Δ) b DersNil). exists d0. simpl.
+          repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+        - inversion e0. subst.
+          pose (BotLRule_I Γ3 (x ++ A :: Γ1 ++ Γ2) Δ). apply BotL in b. simpl in b.
+          assert (E: Γ3 ++ Bot :: x ++ A :: Γ1 ++ Γ2 = (Γ3 ++ Bot :: x) ++ A :: Γ1 ++ Γ2). repeat rewrite <- app_assoc. reflexivity.
+          rewrite E in b. clear E.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ3 ++ Bot :: x) ++ A :: Γ1 ++ Γ2, Δ) b DersNil). exists d0. simpl.
+          repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+    + destruct p. destruct x.
+      { rewrite app_nil_l in e0. inversion e0. subst.
+        pose (BotLRule_I Γ0 (Γ1 ++ Γ2) Δ). apply BotL in b. simpl in b.
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ0 ++ Bot :: Γ1 ++ Γ2, Δ) b DersNil). exists d0. simpl.
+        repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+      { inversion e0. subst. apply app2_find_hole in H9. destruct H9. destruct s.
+        - destruct s.
+          + destruct p. inversion e1. subst.
+            pose (BotLRule_I Γ0 (Γ1 ++ Γ2) Δ). apply BotL in b. simpl in b.
+            pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ Bot :: Γ1 ++ Γ2, Δ) b DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+          + destruct p. destruct x0.
+            * rewrite app_nil_l in e1. inversion e1. subst.
+              pose (BotLRule_I Γ0 (Γ1 ++ Γ4) Δ). apply BotL in b. simpl in b.
+              pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+              (ps:=[]) (Γ0 ++ Bot :: Γ1 ++ Γ4, Δ) b DersNil). exists d0. simpl.
+              repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+            * inversion e1. subst.
+              pose (BotLRule_I (Γ0 ++ m0 :: Γ1 ++ x0) Γ4 Δ). apply BotL in b. simpl in b.
+              repeat rewrite <- app_assoc in b. simpl in b. repeat rewrite <- app_assoc in b.
+              pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+              (ps:=[]) (Γ0 ++ m0 :: Γ1 ++ x0 ++ Bot :: Γ4, Δ) b DersNil). exists d0. simpl.
+              repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+        - destruct p. destruct x0.
+          + rewrite app_nil_l in e1. inversion e1. subst.
+            pose (BotLRule_I Γ0 ((x ++ []) ++ Γ2) Δ). apply BotL in b. simpl in b.
+            pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ Bot :: (x ++ []) ++ Γ2, Δ) b DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+          + inversion e1. subst.
+            pose (BotLRule_I (Γ0 ++ m :: x) (x0 ++ Γ2) Δ). apply BotL in b. simpl in b.
+            assert (E: (Γ0 ++ m :: x) ++ Bot :: x0 ++ Γ2 = Γ0 ++ m :: (x ++ Bot :: x0) ++ Γ2). repeat rewrite <- app_assoc. reflexivity.
+            rewrite E in b. clear E.
+            pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ m :: (x ++ Bot :: x0) ++ Γ2, Δ) b DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+  (* ImpR *)
+  * inversion H1. subst. inversion H5. subst. pose (ImpR_app_ctr_L _ _ _ _ ctr H1). destruct s. destruct p.
+    apply ImpR in i.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x]) (Γ0 ++ A :: Γ1 ++ Γ2, Δ0 ++ A0 --> B :: Δ1) i). subst. simpl.
+    remember [(Γ3 ++ A0 :: Γ4, Δ0 ++ B :: Δ1)] as ps'. destruct d. inversion Heqps'.
+    inversion Heqps'. subst. simpl. rewrite dersrec_height_nil. simpl in IH.
+    rewrite dersrec_height_nil in IH. rewrite Nat.max_0_r. rewrite Nat.max_0_r in IH.
+    assert (E: derrec_height d < S (derrec_height d)). auto.
+    assert (E1: derrec_height d = derrec_height d). auto.
+    assert ((ctr_L A (Γ3 ++ A0 :: Γ4, Δ0 ++ B :: Δ1) x) + (ctr_R A (Γ3 ++ A0 :: Γ4, Δ0 ++ B :: Δ1) x)).
+    left. auto.
+    pose (IH (derrec_height d) E (Γ3 ++ A0 :: Γ4, Δ0 ++ B :: Δ1) d E1 x A H).
+    destruct s.
+    pose (dlCons x0 d1). pose (d0 d2). exists d3. simpl. rewrite dersrec_height_nil.
+    rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. assumption. reflexivity. reflexivity. reflexivity.
+  (* ImpL *)
+  * inversion H1. subst. inversion H5. subst. pose (ImpL_app_ctr_L _ _ _ _ _ ctr H1). destruct s.
+    { repeat destruct s. repeat destruct p. apply ImpL in i.
+      pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[x;x0]) (Γ0 ++ A :: Γ1 ++ Γ2, Δ0 ++ Δ1) i). subst. simpl.
+      remember [(Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1);(Γ3 ++ B :: Γ4, Δ0 ++ Δ1)] as ps'. destruct d.
+      inversion Heqps'. inversion Heqps'. subst.
+      remember [(Γ3 ++ B :: Γ4, Δ0 ++ Δ1)] as ps''. destruct d1. inversion Heqps''.
+      inversion Heqps''. simpl. subst. rewrite dersrec_height_nil. simpl in IH.
+      rewrite dersrec_height_nil in IH. rewrite Nat.max_0_r. rewrite Nat.max_0_r in IH.
+      assert (E1: derrec_height d < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+      apply Nat.lt_succ_r. apply Nat.le_max_l.
+      assert (E2: derrec_height d = derrec_height d). auto.
+      assert ((ctr_L A (Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1) x) + (ctr_R A (Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1) x)).
+      auto.
+      pose (IH (derrec_height d) E1 (Γ3 ++ Γ4, Δ0 ++ A0 :: Δ1) d E2 x A H).
+      destruct s.
+      assert (E3: derrec_height d1 < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+      apply Nat.lt_succ_r. apply Nat.le_max_r.
+      assert (E4: derrec_height d1 = derrec_height d1). auto.
+      assert ((ctr_L A (Γ3 ++ B :: Γ4, Δ0 ++ Δ1) x0) + (ctr_R A (Γ3 ++ B :: Γ4, Δ0 ++ Δ1) x0)).
+      auto.
+      pose (IH (derrec_height d1) E3 (Γ3 ++ B :: Γ4, Δ0 ++ Δ1) d1 E4 x0 A H2).
+      destruct s.
+      pose (dlCons x1 (dlCons x2 d2)). pose (d0 d3). exists d4. simpl. rewrite dersrec_height_nil.
+      rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. apply Nat.max_le_compat.
+      assumption. assumption. reflexivity. reflexivity. reflexivity. }
+    { simpl. repeat destruct s. repeat destruct p. subst. apply ImpL in i.
+      assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+      pose (@dersrec_derrec2_height (dersrec_height d) _ _ _ _ _ d J30). repeat destruct s.
+      assert (J1: derrec_height x7 = derrec_height x7). reflexivity.
+      pose (ImpR_ImpL_hpinv _ _ _ J1). destruct p. clear s. pose (s0 _ _ i1). repeat destruct s.
+      clear s0. destruct p. simpl in IH.
+      assert (J2: derrec_height x9 < S (dersrec_height d)). lia.
+      assert (J3: derrec_height x9 = derrec_height x9). reflexivity.
+      assert (J4: (ctr_L x x1 x5) + (ctr_R x x1 x5)). auto.
+      pose (IH _ J2 _ _ J3 _ _ J4). destruct s.
+      assert (J5: derrec_height x8 = derrec_height x8). reflexivity.
+      pose (ImpR_ImpL_hpinv _ _ _ J5). destruct p. clear s. pose (s0 _ _ i0). repeat destruct s.
+      clear s0. destruct p.
+      assert (J6: derrec_height x13 < S (dersrec_height d)). lia.
+      assert (J7: derrec_height x13 = derrec_height x13). reflexivity.
+      assert (J8: (ctr_L x0 x4 x6) + (ctr_R x0 x4 x6)). auto.
+      pose (IH _ J6 _ _ J7 _ _ J8). destruct s. pose (dlCons x14 DersNil). pose (dlCons x11 d0).
+      pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[x5;x6]) (Γ0 ++ x --> x0 :: Γ1 ++ Γ2, Δ0 ++ Δ1) i d1). exists d2. simpl.
+      rewrite dersrec_height_nil. lia. reflexivity. }
+  (* KR *)
+  * inversion X. rewrite <- H4 in X. pose (KR_app_ctr_L _ _ _ _ ctr X). destruct s.
+    { apply KR in k0. pose (derI (rules:=KS_rules)
+      (prems:=fun _ : Seq => False) (ps:=[(unboxed_list , [A0])])
+      sc k0). subst. pose (d0 d). exists d1. simpl. reflexivity. }
+    { repeat destruct s. repeat destruct p. apply KR in k0.
+      remember [(unboxed_list , [A0])] as ps'. destruct d. subst. inversion H4.
+      rewrite Heqps' in H4. inversion H4. subst. simpl. simpl in IH.
+      assert (E1: derrec_height d < S (Init.Nat.max (derrec_height d) (dersrec_height d0))).
+      rewrite dersrec_height_nil. rewrite Nat.max_0_r. apply Nat.lt_succ_r. left. reflexivity.
+      assert (E2: derrec_height d = derrec_height d). auto.
+      assert ((ctr_L (unBox_formula A) (unboxed_list , [A0]) x) +
+      (ctr_R (unBox_formula A) (unboxed_list , [A0]) x)). auto.
+      pose (IH (derrec_height d) E1 ((unboxed_list , [A0])) d E2 x (unBox_formula A) H).
+      destruct s.
+      pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[x]) (Γ0 ++ A :: Γ1 ++ Γ2, Δ) k0). subst. simpl.
+      pose (dlCons x0 d0). pose (d1 d2). exists d3. simpl. rewrite dersrec_height_nil.
+      repeat rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. lia. auto. }}
+
+{ inversion ctr. assert (DersNil: dersrec KS_rules (fun _ : Seq => False) []).
+  apply dersrec_nil. inversion k.
+  (* IdP *)
+  * inversion H1. rewrite <- H in H5. inversion H5.
+    apply app2_find_hole in H8. destruct H8. destruct s.
+    + destruct s.
+      { destruct p. inversion e0. subst. pose (IdPRule_I P Γ0 Γ1 Δ3 (Δ1 ++ Δ2)). apply IdP in i. simpl in i.
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ0 ++ # P :: Γ1, Δ3 ++ # P :: Δ1 ++ Δ2) i DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+        left. reflexivity. reflexivity. }
+      { destruct p. destruct x.
+        - rewrite app_nil_l in e0. inversion e0.
+          subst. pose (IdPRule_I P Γ0 Γ1 (Δ3 ++ []) (Δ1 ++ Δ2)). apply IdP in i. simpl in i.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) (Γ0 ++ # P :: Γ1, (Δ3 ++ []) ++ # P :: Δ1 ++ Δ2) i DersNil). exists d0. simpl.
+          repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+        - inversion e0. subst.
+          pose (IdPRule_I P Γ0 Γ1 Δ3 (x ++ A :: Δ1 ++ Δ2)). apply IdP in i. simpl in i.
+          assert (E: Δ3 ++ # P :: x ++ A :: Δ1 ++ Δ2 = (Δ3 ++ # P :: x) ++ A :: Δ1 ++ Δ2). repeat rewrite <- app_assoc. reflexivity.
+          rewrite E in i. clear E.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) (Γ0 ++ # P :: Γ1, (Δ3 ++ # P :: x) ++ A :: Δ1 ++ Δ2) i DersNil). exists d0. simpl.
+          repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+    + destruct p. destruct x.
+      { rewrite app_nil_l in e0. inversion e0. subst.
+        pose (IdPRule_I P Γ0 Γ1 Δ0 (Δ1 ++ Δ2)). apply IdP in i. simpl in i.
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ0 ++ # P :: Γ1, Δ0 ++ # P :: Δ1 ++ Δ2) i DersNil). exists d0. simpl.
+        repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+      { inversion e0. subst. apply app2_find_hole in H9. destruct H9. destruct s.
+        - destruct s.
+          + destruct p. inversion e1. subst.
+            pose (IdPRule_I P Γ0 Γ1 Δ0 (Δ1 ++ Δ2)). apply IdP in i. simpl in i.
+            pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ # P :: Γ1, Δ0 ++ # P :: Δ1 ++ Δ2) i DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+          + destruct p. destruct x0.
+            * rewrite app_nil_l in e1. inversion e1. subst.
+              pose (IdPRule_I P Γ0 Γ1 Δ0 (Δ1 ++ Δ4)). apply IdP in i. simpl in i.
+              pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+              (ps:=[]) (Γ0 ++ # P :: Γ1, Δ0 ++ # P :: Δ1 ++ Δ4) i DersNil). exists d0. simpl.
+              repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+            * inversion e1. subst.
+              pose (IdPRule_I P Γ0 Γ1 (Δ0 ++ m0 :: Δ1 ++ x0) Δ4). apply IdP in i. simpl in i.
+              repeat rewrite <- app_assoc in i. simpl in i. repeat rewrite <- app_assoc in i.
+              pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+              (ps:=[]) (Γ0 ++ # P :: Γ1, Δ0 ++ m0 :: Δ1 ++ x0 ++ # P :: Δ4) i DersNil). exists d0. simpl.
+              repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+        - destruct p. destruct x0.
+          + rewrite app_nil_l in e1. inversion e1. subst.
+            pose (IdPRule_I P Γ0 Γ1 Δ0 ((x ++ []) ++ Δ2)). apply IdP in i. simpl in i.
+            pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ # P :: Γ1, Δ0 ++ # P :: (x ++ []) ++ Δ2) i DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+          + inversion e1. subst.
+            pose (IdPRule_I P Γ0 Γ1 (Δ0 ++ m :: x) (x0 ++ Δ2)). apply IdP in i. simpl in i.
+            assert (E: (Δ0 ++ m :: x) ++ # P :: x0 ++ Δ2 = Δ0 ++ m :: (x ++ # P :: x0) ++ Δ2). repeat rewrite <- app_assoc. reflexivity.
+            rewrite E in i. clear E.
+            pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+            (ps:=[]) (Γ0 ++ # P :: Γ1, Δ0 ++ m :: (x ++ # P :: x0) ++ Δ2) i DersNil). exists d0. simpl.
+            repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity. }
+  (* BotL *)
+  * inversion H1. rewrite <- H in H5. inversion H5.
+    pose (BotLRule_I Γ0 Γ1 (Δ0 ++ A :: Δ1 ++ Δ2)). apply BotL in b.
+    pose (derI (rules:=KS_rules)
+    (prems:=fun _ : Seq => False)
+    (ps:=[]) (Γ0 ++ Bot :: Γ1, Δ0 ++ A :: Δ1 ++ Δ2) b DersNil). subst. exists d0. simpl.
+    repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+  (* ImpR *)
+  * inversion H1. subst. inversion H5. subst. pose (ImpR_app_ctr_R _ _ _ _ ctr H1). destruct s.
+    { destruct s. destruct p. apply ImpR in i.
+      pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[x]) (Γ0 ++ Γ1, Δ0 ++ A :: Δ1 ++ Δ2) i). subst. simpl.
+      remember [(Γ0 ++ A0 :: Γ1, Δ3 ++ B :: Δ4)] as ps'. destruct d. inversion Heqps'.
+      inversion Heqps'. subst. simpl. rewrite dersrec_height_nil. simpl in IH.
+      rewrite dersrec_height_nil in IH. rewrite Nat.max_0_r. rewrite Nat.max_0_r in IH.
+      assert (E: derrec_height d < S (derrec_height d)). auto.
+      assert (E1: derrec_height d = derrec_height d). auto.
+      assert ((ctr_L A (Γ0 ++ A0 :: Γ1, Δ3 ++ B :: Δ4) x) + (ctr_R A (Γ0 ++ A0 :: Γ1, Δ3 ++ B :: Δ4) x)).
+      auto.
+      pose (IH (derrec_height d) E (Γ0 ++ A0 :: Γ1, Δ3 ++ B :: Δ4) d E1 x A H).
+      destruct s.
+      pose (dlCons x0 d1). pose (d0 d2). exists d3. simpl. rewrite dersrec_height_nil.
+      rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. assumption. reflexivity. reflexivity. reflexivity. }
+    { repeat destruct s. repeat destruct p. subst. apply ImpR in i.
+      assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+      pose (dersrec_derrec_height d J30). destruct s.
+      assert (J1: derrec_height x4 = derrec_height x4). reflexivity.
+      pose (ImpR_ImpL_hpinv _ _ _ J1). destruct p. clear s0. pose (s _ i0). repeat destruct s0.
+      clear s. simpl in IH.
+      assert (J2: derrec_height x5 < S (dersrec_height d)). lia.
+      assert (J3: derrec_height x5 = derrec_height x5). reflexivity.
+      assert (J4: (ctr_L x x1 x2) + (ctr_R x x1 x2)). auto.
+      pose (IH _ J2 _ _ J3 _ _ J4). destruct s.
+      assert (J5: derrec_height x6 = derrec_height x6). reflexivity.
+      assert (J6: derrec_height x6 < S (dersrec_height d)). lia.
+      assert (J8: (ctr_L x0 x2 x3) + (ctr_R x0 x2 x3)). auto.
+      pose (IH _ J6 _ _ J5 _ _ J8). destruct s. pose (dlCons x7 DersNil).
+      pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[x3]) (Γ0 ++ Γ1, Δ0 ++ x --> x0 :: Δ1 ++ Δ2) i d0). simpl. exists d1. simpl. rewrite dersrec_height_nil.
+      lia. reflexivity. }
+  (* ImpL *)
+  * inversion H1. subst. inversion H5. subst. pose (ImpL_app_ctr_R _ _ _ _ _ ctr H1). destruct s.
+    repeat destruct s. repeat destruct p. apply ImpL in i.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x;x0]) (Γ0 ++ A0 --> B :: Γ1, Δ0 ++ A :: Δ1 ++ Δ2) i). subst. simpl.
+    remember [(Γ0 ++ Γ1, Δ3 ++ A0 :: Δ4);(Γ0 ++ B :: Γ1, Δ3 ++ Δ4)] as ps'. destruct d.
+    inversion Heqps'. inversion Heqps'. subst.
+    remember [(Γ0 ++ B :: Γ1, Δ3 ++ Δ4)] as ps''. destruct d1. inversion Heqps''.
+    inversion Heqps''. simpl. subst. rewrite dersrec_height_nil. simpl in IH.
+    rewrite dersrec_height_nil in IH. rewrite Nat.max_0_r. rewrite Nat.max_0_r in IH.
+    assert (E1: derrec_height d < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+    apply Nat.lt_succ_r. apply Nat.le_max_l.
+    assert (E2: derrec_height d = derrec_height d). auto.
+    assert ((ctr_L A (Γ0 ++ Γ1, Δ3 ++ A0 :: Δ4) x) + (ctr_R A (Γ0 ++ Γ1, Δ3 ++ A0 :: Δ4) x)).
+    auto.
+    pose (IH (derrec_height d) E1 (Γ0 ++ Γ1, Δ3 ++ A0 :: Δ4) d E2 x A H).
+    destruct s.
+    assert (E3: derrec_height d1 < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+    apply Nat.lt_succ_r. apply Nat.le_max_r.
+    assert (E4: derrec_height d1 = derrec_height d1). auto.
+    assert ((ctr_L A (Γ0 ++ B :: Γ1, Δ3 ++ Δ4) x0) + (ctr_R A (Γ0 ++ B :: Γ1, Δ3 ++ Δ4) x0)).
+    auto.
+    pose (IH (derrec_height d1) E3 (Γ0 ++ B :: Γ1, Δ3 ++ Δ4) d1 E4 x0 A H0).
+    destruct s.
+    pose (dlCons x1 (dlCons x2 d2)). pose (d0 d3). exists d4. simpl. rewrite dersrec_height_nil.
+    rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. apply Nat.max_le_compat.
+    assumption. assumption. reflexivity. reflexivity. reflexivity.
+  (* KR *)
+  * inversion X. rewrite <- H4 in X. pose (KR_app_ctr_R _ _ _ _ ctr X).
+    apply KR in k0.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[(unboxed_list , [A0])]) sc k0). subst. simpl. pose (d0 d). exists d1.
+    simpl. rewrite <- Nat.succ_le_mono. left. }
+Qed.
+ +
+Theorem KS_hpadm_ctr_LR : forall s (D0 : KS_prv s),
+          (forall sc A, ((ctr_L A s sc) + (ctr_R A s sc)) ->
+          existsT2 (D1 : KS_prv sc),
+          derrec_height D1 <= derrec_height D0).
+Proof.
+intros.
+assert (J0: derrec_height D0 = derrec_height D0). auto.
+pose (@KS_hpadm_ctr_LR0 (derrec_height D0) _ D0 J0 _ _ H).
+auto.
+Qed.
+ +
+Theorem KS_hpadm_ctr_L : forall (k : nat) s
+        (D0 : KS_prv s),
+        k = (derrec_height D0) ->
+          (forall sc A, ((@ctr_L A s sc) ->
+          existsT2 (D1 : KS_prv sc),
+          derrec_height D1 <= k)).
+Proof.
+intros. intros. assert (H1: derrec_height D0 = derrec_height D0). reflexivity.
+assert (H3 : (ctr_L A s sc) + (ctr_R A s sc)). auto.
+pose (@KS_hpadm_ctr_LR0 (derrec_height D0) s
+D0 H1 sc A H3). destruct s0. exists x. lia.
+Qed.
+ +
+Theorem KS_hpadm_ctr_R : forall (k : nat) s
+        (D0 : KS_prv s),
+        k = (derrec_height D0) ->
+          (forall sc A, ((@ctr_R A s sc) ->
+          existsT2 (D1 : KS_prv sc),
+          derrec_height D1 <= k)).
+Proof.
+intros. intros. assert (H1: derrec_height D0 = derrec_height D0). reflexivity.
+assert (H3 : (ctr_L A s sc) + (ctr_R A s sc)). auto.
+pose (@KS_hpadm_ctr_LR0 (derrec_height D0) s
+D0 H1 sc A H3). destruct s0. exists x. lia.
+Qed.
+ +
+(* We can now prove that contraction of lists is also admissible. *)
+ +
+Theorem KS_hpadm_list_ctr_L : forall Γ1 (k : nat) Γ0 Γ2 Γ3 Δ
+        (D0 : KS_prv (Γ0 ++ Γ1 ++ Γ2 ++ Γ1 ++ Γ3,Δ)),
+        k = (derrec_height D0) ->
+          existsT2 (D1 : KS_prv (Γ0 ++ Γ1 ++ Γ2 ++ Γ3,Δ)),
+          derrec_height D1 <= k.
+Proof.
+induction Γ1.
+- intros. exists D0. rewrite H. auto.
+- intros. assert (H0: derrec_height D0 = derrec_height D0). reflexivity.
+  assert (H1 : ctr_L a (Γ0 ++ (a :: Γ1) ++ Γ2 ++ (a :: Γ1) ++ Γ3, Δ) ((Γ0 ++ [a]) ++ Γ1 ++ Γ2 ++ Γ1 ++ Γ3, Δ)).
+  simpl. assert (Γ0 ++ a :: Γ1 ++ Γ2 ++ a :: Γ1 ++ Γ3 = Γ0 ++ a :: (Γ1 ++ Γ2) ++ a :: (Γ1 ++ Γ3)).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H1.
+  assert ((Γ0 ++ [a]) ++ Γ1 ++ Γ2 ++ Γ1 ++ Γ3 = Γ0 ++ a :: (Γ1 ++ Γ2) ++ Γ1 ++ Γ3). repeat rewrite <- app_assoc.
+  reflexivity. rewrite H2. apply ctr_LI.
+  assert ((ctr_L a (Γ0 ++ (a :: Γ1) ++ Γ2 ++ (a :: Γ1) ++ Γ3, Δ) ((Γ0 ++ [a]) ++ Γ1 ++ Γ2 ++ Γ1 ++ Γ3, Δ)) +
+  (ctr_R a (Γ0 ++ (a :: Γ1) ++ Γ2 ++ (a :: Γ1) ++ Γ3, Δ) ((Γ0 ++ [a]) ++ Γ1 ++ Γ2 ++ Γ1 ++ Γ3, Δ))). auto.
+  pose (@KS_hpadm_ctr_LR0 (derrec_height D0) (Γ0 ++ (a :: Γ1) ++ Γ2 ++ (a :: Γ1) ++ Γ3, Δ)
+  D0 H0 ((Γ0 ++ [a]) ++ Γ1 ++ Γ2 ++ Γ1 ++ Γ3, Δ) a H2). destruct s.
+  assert (H3: derrec_height x = derrec_height x). reflexivity.
+  pose (IHΓ1 (derrec_height x) (Γ0 ++ [a]) Γ2 Γ3 Δ x H3). destruct s.
+  assert (Γ0 ++ (a :: Γ1) ++ Γ2 ++ Γ3 = (Γ0 ++ [a]) ++ Γ1 ++ Γ2 ++ Γ3). repeat rewrite <- app_assoc. auto.
+  rewrite H4. exists x0. lia.
+Qed.
+ +
+Theorem KS_hpadm_list_ctr_R : forall Δ1 (k : nat) Γ Δ0 Δ2 Δ3
+        (D0 : KS_prv (Γ,Δ0 ++ Δ1 ++ Δ2 ++ Δ1 ++ Δ3)),
+        k = (derrec_height D0) ->
+          existsT2 (D1 : KS_prv (Γ,Δ0 ++ Δ1 ++ Δ2 ++ Δ3)),
+          derrec_height D1 <= k.
+Proof.
+induction Δ1.
+- intros. exists D0. rewrite H. auto.
+- intros. assert (H0: derrec_height D0 = derrec_height D0). reflexivity.
+  assert (H1 : ctr_R a (Γ, Δ0 ++ (a :: Δ1) ++ Δ2 ++ (a :: Δ1) ++ Δ3) (Γ, (Δ0 ++ [a]) ++ Δ1 ++ Δ2 ++ Δ1 ++ Δ3)).
+  simpl. assert (Δ0 ++ a :: Δ1 ++ Δ2 ++ a :: Δ1 ++ Δ3 = Δ0 ++ a :: (Δ1 ++ Δ2) ++ a :: (Δ1 ++ Δ3)).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H1.
+  assert ((Δ0 ++ [a]) ++ Δ1 ++ Δ2 ++ Δ1 ++ Δ3 = Δ0 ++ a :: (Δ1 ++ Δ2) ++ Δ1 ++ Δ3). repeat rewrite <- app_assoc.
+  reflexivity. rewrite H2. apply ctr_RI.
+  assert ((ctr_L a (Γ, Δ0 ++ (a :: Δ1) ++ Δ2 ++ (a :: Δ1) ++ Δ3) (Γ, (Δ0 ++ [a]) ++ Δ1 ++ Δ2 ++ Δ1 ++ Δ3)) +
+  (ctr_R a (Γ, Δ0 ++ (a :: Δ1) ++ Δ2 ++ (a :: Δ1) ++ Δ3) (Γ, (Δ0 ++ [a]) ++ Δ1 ++ Δ2 ++ Δ1 ++ Δ3))). auto.
+  pose (@KS_hpadm_ctr_LR0 (derrec_height D0) (Γ, Δ0 ++ (a :: Δ1) ++ Δ2 ++ (a :: Δ1) ++ Δ3)
+  D0 H0 (Γ, (Δ0 ++ [a]) ++ Δ1 ++ Δ2 ++ Δ1 ++ Δ3) a H2). destruct s.
+  assert (H3: derrec_height x = derrec_height x). reflexivity.
+  pose (IHΔ1 (derrec_height x) Γ (Δ0 ++ [a]) Δ2 Δ3 x H3). destruct s.
+  assert (Δ0 ++ (a :: Δ1) ++ Δ2 ++ Δ3 = (Δ0 ++ [a]) ++ Δ1 ++ Δ2 ++ Δ3). repeat rewrite <- app_assoc. auto.
+  rewrite H4. exists x0. lia.
+Qed.
+ +
+
+
+ +
+ + + diff --git a/K.KS.KS_cut_elim.html b/K.KS.KS_cut_elim.html new file mode 100644 index 0000000..d928368 --- /dev/null +++ b/K.KS.KS_cut_elim.html @@ -0,0 +1,87 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_cut_elim

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat.
+ +
+Require Import KS_calc.
+Require Import KS_termination_measure.
+Require Import KS_termination.
+Require Import KS_exch.
+Require Import KS_ctr.
+Require Import KS_wkn.
+Require Import KS_dec.
+Require Import KS_inv_ImpR_ImpL.
+Require Import KS_additive_cut.
+ +
+Inductive CutRule : rlsT Seq :=
+  | CutRule_I : forall A Γ0 Γ1 Δ0 Δ1,
+          CutRule [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1) ; (Γ0 ++ A :: Γ1, Δ0 ++ Δ1)]
+                    (Γ0 ++ Γ1, Δ0 ++ Δ1)
+.
+ +
+Inductive KS_cut_rules : rlsT Seq :=
+  | KS_woc : forall ps c, KS_rules ps c -> KS_cut_rules ps c
+  | KS_cut : forall ps c, CutRule ps c -> KS_cut_rules ps c
+.
+ +
+Definition KS_cut_prv s := derrec KS_cut_rules (fun _ => False) s.
+Definition KS_cut_drv s := derrec KS_cut_rules (fun _ => True) s.
+ +
+Theorem KS_cut_elimination : forall s, (KS_cut_prv s) -> (KS_prv s).
+Proof.
+intros s D.
+apply derrec_all_rect with
+(Q:= fun x => (KS_prv x))
+in D ; auto.
+- intros. inversion H.
+- intros ps concl rule ders IH. inversion rule.
+  * subst. apply derI with (ps:=ps) ; auto. apply dersrec_forall. intros. pose (ForallTD_forall IH H) ; auto.
+  * subst. inversion H. subst. apply KS_cut_adm with (A:=A).
+    pose (ForallTD_forall IH). apply k ; apply InT_eq.
+    pose (ForallTD_forall IH). apply k ; apply InT_cons ; apply InT_eq.
+Defined.
+
+
+ +
+ + + diff --git a/K.KS.KS_dec.html b/K.KS.KS_dec.html new file mode 100644 index 0000000..abb9de7 --- /dev/null +++ b/K.KS.KS_dec.html @@ -0,0 +1,296 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_dec

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat.
+ +
+Require Import KS_calc.
+ +
+(* In this file we show that the applicability of the rules in KS is decidable. *)
+ +
+Lemma top_boxes_incl_list : forall l, incl (top_boxes l) l.
+Proof.
+induction l.
+- simpl. unfold incl. intros. inversion H.
+- unfold incl. intros. destruct a.
+  * simpl in H. apply in_cons. apply IHl. assumption.
+  * simpl in H. apply in_cons. apply IHl. assumption.
+  * simpl in H. apply in_cons. apply IHl. assumption.
+  * simpl in H. destruct H.
+    + subst. apply in_eq.
+    + apply in_cons. apply IHl. assumption.
+Qed.
+ +
+Definition in_top_boxes : forall l A, (In A (top_boxes l)) -> (existsT2 B l1 l2, (A = Box B) * (l = l1 ++ A :: l2)).
+Proof.
+induction l.
+- intros. simpl in H. inversion H.
+- intros. destruct a as [n| | |].
+  * simpl in H. apply IHl in H. destruct H. destruct s. destruct s. destruct p. subst.
+    exists x. exists ([# n] ++ x0). exists x1. auto.
+  * simpl in H. apply IHl in H. destruct H. destruct s. destruct s. destruct p. subst.
+    exists x. exists ([Bot] ++ x0). exists x1. auto.
+  * simpl in H. apply IHl in H. destruct H. destruct s. destruct s. destruct p. subst.
+    exists x. exists ([a1 --> a2] ++ x0). exists x1. auto.
+  * simpl (top_boxes (Box a :: l)) in H. destruct (eq_dec_form (Box a) A).
+    + subst. exists a. exists []. exists l. auto.
+    + subst. assert (H0 : In A (top_boxes l)). inversion H. exfalso. apply n. assumption.
+      assumption. apply IHl in H0. destruct H0. destruct s. destruct s. destruct p.
+      subst. exists x. exists ([Box a] ++ x0). exists x1. auto.
+Defined.
+ +
+Definition dec_is_PropVar : forall (A : MPropF), (existsT2 P, A = # P) + ((existsT2 P, A = # P) -> False).
+Proof.
+induction A as [n| | |].
+- left. exists n. reflexivity.
+- right. intro. inversion H. inversion H0.
+- right. intro. inversion H. inversion H0.
+- right. intro. inversion H. inversion H0.
+Defined.
+ +
+Definition dec_prop_var_in : forall s, (existsT2 P, (In (# P) (fst s)) /\ (In (# P) (snd s))) +
+                                      ((existsT2 P, (In (# P) (fst s)) /\ (In (# P) (snd s))) -> False).
+Proof.
+intro. destruct s.
+induction l.
+- right. intro. destruct H. destruct a. simpl in H. inversion H.
+- destruct IHl.
+  * destruct s. simpl in a0. destruct a0. left. exists x. simpl. split. auto. assumption.
+  * destruct (dec_is_PropVar a) ; simpl.
+    + destruct (In_dec l0 a).
+      { left. subst. destruct s. exists x. simpl. split. auto. subst. assumption. }
+      { right. simpl. intro. destruct H. destruct a0. destruct H.
+        - subst. apply n. assumption.
+        - apply f. simpl. exists x. firstorder. }
+    + right. intro. simpl in H. destruct H. destruct a0. destruct H.
+      { subst. apply f0. exists x. reflexivity. }
+      { apply f. firstorder. }
+Defined.
+ +
+Definition dec_is_boxedT : forall (A : MPropF), (is_boxedT A) + ((is_boxedT A) -> False).
+Proof.
+induction A.
+- right. intro. inversion X. inversion H.
+- right. intro. inversion X. inversion H.
+- right. intro. inversion X. inversion H.
+- left. exists A. reflexivity.
+Defined.
+ +
+Definition dec_is_box : forall (A : MPropF), (existsT2 B, A = Box B) + ((existsT2 B, A = Box B ) -> False).
+Proof.
+destruct A.
+- right. intro. destruct H. inversion e.
+- right. intro. destruct H. inversion e.
+- right. intro. destruct H. inversion e.
+- left. exists A. reflexivity.
+Defined.
+ +
+Definition dec_box_in : forall s, (existsT2 (A : MPropF), (In (Box A) (fst s)) /\ (In (Box A) (snd s))) +
+                             ((existsT2 (A : MPropF), (In (Box A) (fst s)) /\ (In (Box A) (snd s))) -> False).
+Proof.
+intro. destruct s.
+induction l.
+- right. intro. destruct H. destruct a. simpl in H. inversion H.
+- destruct IHl.
+  * destruct s. simpl in a0. destruct a0. left. exists x. simpl. split. auto. assumption.
+  * destruct (dec_is_box a).
+    + destruct (In_dec l0 a).
+      { left. destruct s. subst. simpl. exists x. split. auto. assumption. }
+      { right. simpl. intro. destruct H. destruct a0. destruct H.
+        - subst. apply n. assumption.
+        - apply f. simpl. exists x. firstorder. }
+    + right. intro. simpl in H. destruct H. destruct a0. destruct H.
+      { subst. apply f0. exists x. reflexivity. }
+      { apply f. firstorder. }
+Defined.
+ +
+Definition dec_KS_init_rules : forall (s :Seq) ,
+          ((IdPRule [] s) + (BotLRule [] s)) +
+          (((IdPRule [] s) + (BotLRule [] s)) -> False).
+Proof.
+intro s. destruct s. destruct (dec_prop_var_in (pair l l0)).
+- destruct s. destruct a. left. left. simpl in H. simpl in H0.
+  apply in_splitT in H. destruct H. destruct s. apply in_splitT in H0. destruct H0. destruct s.
+  subst. apply IdPRule_I.
+- destruct (In_dec l (Bot)).
+  + left. apply in_splitT in i. destruct i. destruct s. subst. right. apply BotLRule_I.
+  + right. intro. destruct H.
+    * inversion i. subst. simpl in f. apply f. exists P. split ; apply in_or_app ; right ; apply in_eq.
+    * inversion b. subst. apply n. apply in_or_app. right. apply in_eq.
+Defined.
+ +
+Definition dec_IdP_rule : forall (s :Seq) ,
+          (IdPRule [] s) +
+          ((IdPRule [] s) -> False).
+Proof.
+intro s. destruct s. destruct (dec_prop_var_in (pair l l0)).
+- destruct s. destruct a. left. simpl in H. simpl in H0.
+  apply in_splitT in H. destruct H. destruct s. apply in_splitT in H0. destruct H0. destruct s.
+  subst. apply IdPRule_I.
+- right. intro. destruct H. apply f. exists P. split ; apply in_or_app ; right ; apply in_eq.
+Defined.
+ +
+Definition dec_BotL_rule : forall (s :Seq) ,
+          (BotLRule [] s) +
+          ((BotLRule [] s) -> False).
+Proof.
+intro s. destruct s. destruct (In_dec l (Bot)).
+- left. apply in_splitT in i. destruct i. destruct s. subst. apply BotLRule_I.
+- right. intro. inversion H. apply n. subst. apply in_or_app. right. apply in_eq.
+Defined.
+ +
+Definition dec_is_imp : forall (A : MPropF), (existsT2 B C, A = Imp B C) + ((existsT2 B C, A = Imp B C) -> False).
+Proof.
+destruct A as [n| | |].
+- right. intro. destruct H. destruct s. inversion e.
+- right. intro. destruct H. destruct s. inversion e.
+- left. exists A1. exists A2. reflexivity.
+- right. intro. destruct H. destruct s. inversion e.
+Defined.
+ +
+Definition dec_imp_in : forall (l : list MPropF), (existsT2 A B, In (Imp A B) l) + ((existsT2 A B, In (Imp A B) l) -> False).
+Proof.
+induction l.
+- right. intro. destruct H. destruct s. inversion i.
+- destruct IHl.
+  * repeat destruct s. left. exists x. exists x0. apply in_cons. assumption.
+  * destruct (dec_is_imp a).
+    + repeat destruct s. subst. left. exists x. exists x0. apply in_eq.
+    + right. intro. destruct H. destruct s. inversion i.
+      { subst. apply f0. exists x. exists x0. reflexivity. }
+      { apply f. exists x. exists x0. assumption. }
+Defined.
+ +
+Definition dec_ImpR_rule : forall (concl :Seq),
+          (existsT2 prem, ImpRRule [prem] concl) + ((existsT2 prem, ImpRRule [prem] concl) -> False).
+Proof.
+intros concl. destruct concl. destruct (dec_imp_in l0).
+- left. repeat destruct s. apply in_splitT in i. destruct i. destruct s. subst.
+  exists ([] ++ x :: l, x1 ++ x0 :: x2). assert ((l, x1 ++ x --> x0 :: x2) = ([] ++ l, x1 ++ x --> x0 :: x2)).
+  reflexivity. apply ImpRRule_I.
+- right. intro. destruct H. inversion i. subst. apply f. exists A. exists B. apply in_or_app.
+  right. apply in_eq.
+Defined.
+ +
+Definition dec_ImpL_rule : forall (concl :Seq),
+          (existsT2 prem1 prem2, ImpLRule [prem1 ; prem2] concl) + ((existsT2 prem1 prem2, ImpLRule [prem1 ; prem2] concl) -> False).
+Proof.
+intro concl. destruct concl. destruct (dec_imp_in l).
+- left. repeat destruct s. apply in_splitT in i. destruct i. destruct s. subst.
+  exists (x1 ++ x2, [] ++ x :: l0). exists (x1 ++ x0 :: x2, [] ++ l0).
+  assert ((x1 ++ x --> x0 :: x2, l0) = (x1 ++ x --> x0 :: x2, [] ++ l0)). reflexivity.
+  rewrite H. apply ImpLRule_I.
+- right. intro. destruct H. destruct s. inversion i. subst. apply f. exists A. exists B.
+  apply in_or_app. right. apply in_eq.
+Defined.
+ +
+Definition dec_box_in_list : forall l, (existsT2 (A : MPropF), In (Box A) l) +
+                             ((existsT2 (A : MPropF), In (Box A) l) -> False).
+Proof.
+induction l.
+- simpl. right. intro. destruct H. assumption.
+- destruct (dec_is_box a).
+  * destruct s. subst. left. exists x. apply in_eq.
+  * destruct IHl.
+    + left. destruct s. exists x. apply in_cons. assumption.
+    + right. intro. destruct H. inversion i. subst. apply f. exists x. reflexivity. apply f0.
+      exists x. assumption.
+Defined.
+ +
+Definition dec_KR_rule : forall (concl :Seq),
+          (existsT2 prem, KRRule [prem] concl) + ((existsT2 prem, KRRule [prem] concl) -> False).
+Proof.
+intro concl. destruct concl. destruct (dec_box_in_list l0).
+- left. destruct s. exists ((unboxed_list (top_boxes l)), [x]).
+  apply in_splitT in i. destruct i. destruct s. subst. apply KRRule_I.
+  + unfold is_Boxed_list. intros. apply in_top_boxes in H. destruct H. destruct s. destruct s.
+    destruct p. exists x2. assumption.
+  + induction l. simpl. apply univ_gen_ext_nil. destruct a.
+    * simpl. apply univ_gen_ext_extra. intro. destruct X. inversion H. assumption.
+    * simpl. apply univ_gen_ext_extra. intro. destruct X. inversion H. assumption.
+    * simpl. apply univ_gen_ext_extra. intro. destruct X. inversion H. assumption.
+    * simpl. apply univ_gen_ext_cons. apply IHl.
+- right. intro. destruct X. inversion k. subst. apply f. exists A. apply in_or_app. right. apply in_eq.
+Defined.
+ +
+Definition dec_KS_rules : forall (concl :Seq) ,
+          ((existsT2 prems, KS_rules prems concl) -> False) + (existsT2 prems, KS_rules prems concl).
+Proof.
+intro concl. destruct (dec_KS_init_rules concl).
+- right. repeat destruct s.
+  * exists nil. apply IdP. assumption.
+  * exists nil. apply BotL. assumption.
+- destruct (dec_ImpR_rule concl).
+  * right. destruct s. exists [x]. apply ImpR. assumption.
+  * destruct (dec_ImpL_rule concl).
+    + right. repeat destruct s. exists [x; x0]. apply ImpL. assumption.
+    + destruct (dec_KR_rule concl).
+      { right. repeat destruct s. exists [x]. apply KR. assumption. }
+      { left. intro. destruct X. inversion k.
+        - inversion H. subst. apply f. auto.
+        - inversion H. subst. apply f. auto.
+        - inversion H. subst. apply f0. exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1). assumption.
+        - inversion H. subst. apply f1. exists (Γ0 ++ Γ1, Δ0 ++ A :: Δ1). exists (Γ0 ++ B :: Γ1, Δ0 ++ Δ1).
+          assumption.
+        - inversion X. subst. apply f2. exists (unboxed_list , [A]). assumption. }
+Defined.
+ +
+
+
+ +
+ + + diff --git a/K.KS.KS_exch.html b/K.KS.KS_exch.html new file mode 100644 index 0000000..8968b66 --- /dev/null +++ b/K.KS.KS_exch.html @@ -0,0 +1,495 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_exch

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat Arith.
+ +
+Require Import KS_calc.
+Require Export KS_exch_prelims.
+Require Export KS_exch_ImpR.
+Require Export KS_exch_ImpL.
+Require Export KS_exch_KR.
+ +
+(* We can now prove the admissibility of list_exchange on the left. *)
+ +
+Theorem KS_adm_list_exch_L : forall s,
+        (KS_prv s) ->
+        (forall se, (@list_exch_L s se) ->
+        (KS_prv se)).
+Proof.
+intros s D. apply derrec_all_rect with
+(Q:= fun x => forall (se : Seq),
+list_exch_L x se ->
+derrec KS_rules (fun _ : Seq => False)
+  se)
+in D.
+- exact D.
+- intros concl F. inversion F.
+- intros ps concl rule. induction rule.
+  (* IdP *)
+  * intros ders IH se exch. inversion i. apply derI with (ps:=[]).
+    apply IdP.
+    + assert (Permstose: existsT2 eΓ0 eΓ1, se = (eΓ0 ++ # P :: eΓ1, Δ0 ++ # P :: Δ1)).
+      { pose (list_exch_L_permLR _ _ exch). subst. destruct s0 with (Γ0:=Γ0) (Γ1:=Γ1) (Δ0:=Δ0) (Δ1:=Δ1)
+      (C:=# P) (D:=# P). auto. exists x. assumption. }
+      destruct Permstose. repeat destruct s0. subst. apply IdPRule_I.
+    + apply dersrec_all in ders. apply dersrec_all. subst. assumption.
+  (* BotL *)
+  * intros ders IH se exch. apply derI with (ps:=ps).
+    + apply BotL. inversion b. symmetry in H0.
+      assert (Permstose: existsT2 eΓ0 eΓ1, se = ((eΓ0 ++ Bot :: eΓ1), Δ)).
+      { apply list_exch_L_permL with (s:=c) (Γ0:=Γ0) (Γ1:=Γ1) (Δ:=Δ). assumption.
+        assumption. }
+      destruct Permstose. destruct s0. subst. apply BotLRule_I.
+    + apply dersrec_all in ders. apply dersrec_all. assumption.
+  (* ImpR *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpR_app_list_exchL _ _ _ exch i).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply ImpR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+  (* ImpL *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpL_app_list_exchL _ _ _ _ exch i).
+    destruct s0. destruct s0. destruct p. destruct p. apply derI with (ps:=[x;x0]).
+    + apply ImpL. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_cons_inv in IH. destruct IH.
+      apply ForallT_inv in f. apply ForallT_cons.
+      { apply d. subst. assumption. }
+      { apply ForallT_cons. apply f. subst. assumption. apply ForallT_nil. }
+  (* KR *)
+  * intros ders IH se exch. inversion k. subst. pose (KR_app_list_exchL _ _ _ exch k).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply KR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion k0.
+      inversion k. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+Qed.
+ +
+Theorem KS_adm_list_exch_R : forall s,
+        (KS_prv s) ->
+        (forall se, (@list_exch_R s se) ->
+        (KS_prv se)).
+Proof.
+intros s D. apply derrec_all_rect with
+(Q:= fun x => forall (se : Seq),
+list_exch_R x se ->
+derrec KS_rules (fun _ : Seq => False)
+  se)
+in D.
+- exact D.
+- intros concl F. inversion F.
+- intros ps concl rule. induction rule.
+  (* IdP *)
+  * intros ders IH se exch. inversion i. apply derI with (ps:=[]).
+    apply IdP.
+    + assert (Permstose: existsT2 eΔ0 eΔ1, se = (Γ0 ++ # P :: Γ1, eΔ0 ++ # P :: eΔ1)).
+      { pose (list_exch_R_permLR _ _ exch). subst. destruct s0 with (Γ0:=Γ0) (Γ1:=Γ1) (Δ0:=Δ0) (Δ1:=Δ1)
+      (C:=# P) (D:=# P). auto. exists x. assumption. }
+      destruct Permstose. repeat destruct s0. subst. apply IdPRule_I.
+    + apply dersrec_all in ders. apply dersrec_all. subst. assumption.
+  (* BotL *)
+  * intros ders IH se exch. apply derI with (ps:=ps).
+    + apply BotL. inversion b. symmetry in H0.
+      assert (Permstose: existsT2 , se = ((Γ0 ++ Bot :: Γ1), )).
+      { apply list_exch_R_permL with (s:=c) (Γ0:=Γ0) (Γ1:=Γ1) (Δ:=Δ). assumption.
+        assumption. }
+      destruct Permstose. subst. apply BotLRule_I.
+    + apply dersrec_all in ders. apply dersrec_all. assumption.
+  (* ImpR *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpR_app_list_exchR _ _ _ exch i).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply ImpR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+  (* ImpL *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpL_app_list_exchR _ _ _ _ exch i).
+    destruct s0. destruct s0. destruct p. destruct p. apply derI with (ps:=[x;x0]).
+    + apply ImpL. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_cons_inv in IH. destruct IH.
+      apply ForallT_inv in f. apply ForallT_cons.
+      { apply d. subst. assumption. }
+      { apply ForallT_cons. apply f. subst. assumption. apply ForallT_nil. }
+  (* KR *)
+  * intros ders IH se exch. inversion k. subst. pose (KR_app_list_exchR _ _ _ exch k).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply KR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion k0.
+      inversion k. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+Qed.
+ +
+(* Now we can turn to the derivability of list_exchange. *)
+ +
+Inductive Closure {X: Type} (F : X -> Type) (P : X -> X -> Type) : X -> Type :=
+  | InitClo : forall x, F x -> Closure F P x
+  | IndClo : forall x y, Closure F P y -> (P y x) -> Closure F P x.
+ +
+Inductive ExcClosure (hyps : Seq -> Type) : Seq -> Type :=
+  | InitLExch : forall x, Closure hyps list_exch_L x -> ExcClosure hyps x
+  | InitRExch : forall x, Closure hyps list_exch_R x -> ExcClosure hyps x
+  | IndLExch : forall x y, ExcClosure hyps x -> list_exch_L x y -> ExcClosure hyps y
+  | IndRExch : forall x y, ExcClosure hyps x -> list_exch_R x y -> ExcClosure hyps y.
+ +
+Theorem KS_der_list_exch_L : forall hyps s,
+        (derrec KS_rules hyps s) ->
+        (forall se, (@list_exch_L s se) ->
+        (derrec KS_rules (ExcClosure hyps) se)).
+Proof.
+intros hyps s D. apply derrec_all_rect with
+(Q:= fun x => forall (se : Seq),
+list_exch_L x se ->
+derrec KS_rules (ExcClosure hyps) se) in D.
+- exact D.
+- intros concl H1 se exch. apply dpI. apply InitLExch. apply IndClo with (y:=concl).
+  apply InitClo. assumption. assumption.
+- intros ps concl rule. induction rule.
+  (* IdP *)
+  * intros ders IH se exch. inversion i. apply derI with (ps:=[]).
+    apply IdP.
+    + assert (Permstose: existsT2 eΓ0 eΓ1, se = (eΓ0 ++ # P :: eΓ1, Δ0 ++ # P :: Δ1)).
+      { pose (list_exch_L_permLR _ _ exch). subst. destruct s0 with (Γ0:=Γ0) (Γ1:=Γ1) (Δ0:=Δ0) (Δ1:=Δ1)
+      (C:=# P) (D:=# P). auto. exists x. assumption. }
+      destruct Permstose. repeat destruct s0. subst. apply IdPRule_I.
+    + apply dersrec_all in ders. apply dersrec_nil.
+  (* BotL *)
+  * intros ders IH se exch. apply derI with (ps:=ps).
+    + apply BotL. inversion b. symmetry in H0.
+      assert (Permstose: existsT2 eΓ0 eΓ1, se = ((eΓ0 ++ Bot :: eΓ1), Δ)).
+      { apply list_exch_L_permL with (s:=c) (Γ0:=Γ0) (Γ1:=Γ1) (Δ:=Δ). assumption.
+        assumption. }
+      destruct Permstose. repeat destruct s0. subst. apply BotLRule_I.
+    + apply dersrec_all in ders. inversion b. apply dersrec_nil.
+  (* ImpR *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpR_app_list_exchL _ _ _ exch i).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply ImpR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+  (* ImpL *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpL_app_list_exchL _ _ _ _ exch i).
+    destruct s0. destruct s0. destruct p. destruct p. apply derI with (ps:=[x;x0]).
+    + apply ImpL. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_cons_inv in IH. destruct IH.
+      apply ForallT_inv in f. apply ForallT_cons.
+      { apply d. subst. assumption. }
+      { apply ForallT_cons. apply f. subst. assumption. apply ForallT_nil. }
+  (* KR *)
+  * intros ders IH se exch. inversion k. subst. pose (KR_app_list_exchL _ _ _ exch k).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply KR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion k0.
+      inversion k. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+Qed.
+ +
+Theorem KS_der_list_exch_R : forall hyps s,
+        (derrec KS_rules hyps s) ->
+        (forall se, (@list_exch_R s se) ->
+        (derrec KS_rules (ExcClosure hyps) se)).
+Proof.
+intros hyps s D. apply derrec_all_rect with
+(Q:= fun x => forall (se : Seq),
+list_exch_R x se ->
+derrec KS_rules (ExcClosure hyps) se) in D.
+- exact D.
+- intros concl H1 se exch. apply dpI. apply InitRExch. apply IndClo with (y:=concl).
+  apply InitClo. assumption. assumption.
+- intros ps concl rule. induction rule.
+  (* IdP *)
+  * intros ders IH se exch. inversion i. apply derI with (ps:=[]).
+    apply IdP.
+    + assert (Permstose: existsT2 eΔ0 eΔ1, se = (Γ0 ++ # P :: Γ1, eΔ0 ++ # P :: eΔ1)).
+      { pose (list_exch_R_permLR _ _ exch). subst. destruct s0 with (Γ0:=Γ0) (Γ1:=Γ1) (Δ0:=Δ0) (Δ1:=Δ1)
+      (C:=# P) (D:=# P). auto. exists x. assumption. }
+      destruct Permstose. repeat destruct s0. subst. apply IdPRule_I.
+    + apply dersrec_all in ders. apply dersrec_nil.
+  (* BotL *)
+  * intros ders IH se exch. apply derI with (ps:=ps).
+    + apply BotL. inversion b. symmetry in H0.
+      assert (Permstose: existsT2 , se = ((Γ0 ++ Bot :: Γ1), )).
+      { apply list_exch_R_permL with (s:=c) (Γ0:=Γ0) (Γ1:=Γ1) (Δ:=Δ). assumption.
+        assumption. }
+      destruct Permstose. subst. apply BotLRule_I.
+    + apply dersrec_all in ders. inversion b. apply dersrec_nil.
+  (* ImpR *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpR_app_list_exchR _ _ _ exch i).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply ImpR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+  (* ImpL *)
+  * intros ders IH se exch. inversion i. subst. pose (ImpL_app_list_exchR _ _ _ _ exch i).
+    destruct s0. destruct s0. destruct p. destruct p. apply derI with (ps:=[x;x0]).
+    + apply ImpL. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion i0.
+      inversion i. apply ForallT_cons_inv in IH. destruct IH.
+      apply ForallT_inv in f. apply ForallT_cons.
+      { apply d. subst. assumption. }
+      { apply ForallT_cons. apply f. subst. assumption. apply ForallT_nil. }
+  (* KR *)
+  * intros ders IH se exch. inversion k. subst. pose (KR_app_list_exchR _ _ _ exch k).
+    destruct s0. destruct p. apply derI with (ps:=[x]).
+    + apply KR. assumption.
+    + apply dersrec_all. apply dersrec_all in ders. inversion k0.
+      inversion k. apply ForallT_inv in IH. apply ForallT_cons.
+      { apply IH. subst. assumption. }
+      { apply ForallT_nil. }
+Qed.
+ +
+(* In fact, we can prove that exchange is height-preserving admissible. *)
+ +
+Theorem KS_hpadm_list_exch_R0 : forall (k : nat) s
+                                  (D0: KS_prv s),
+        k = (derrec_height D0) ->
+        (forall se, (list_exch_R s se) ->
+        (existsT2 (D1 : KS_prv se),
+          derrec_height D1 <=k)).
+Proof.
+induction k as [n IH] using (well_founded_induction_type lt_wf).
+(* Now we do the actual proof-theoretical work. *)
+intros s0 D0. remember D0 as D0'. destruct D0.
+(* D0 ip a leaf *)
+- inversion f.
+(* D0 is ends with an application of rule *)
+- intros hei se exch. inversion exch.
+  assert (DersNil: dersrec KS_rules (fun _ : Seq => False) []).
+  apply dersrec_nil. inversion k.
+  (* IdP *)
+  * inversion H1. subst. inversion H5. subst. simpl.
+    assert (In # P (Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4)). assert (In # P (Δ0 ++ Δ1 ++ Δ2 ++ Δ3 ++ Δ4)).
+    rewrite <- H2. apply in_or_app. right. apply in_eq. apply in_app_or in H. apply in_or_app.
+    destruct H. auto. apply in_app_or in H. right. apply in_or_app. destruct H. right. apply in_or_app.
+    right. apply in_or_app. auto. apply in_app_or in H. destruct H. right. apply in_or_app. auto.
+    apply in_app_or in H. destruct H. auto. right. apply in_or_app. right. apply in_or_app. auto.
+    apply in_splitT in H. destruct H. destruct s. rewrite e.
+    assert (IdPRule [] (Γ0 ++ # P :: Γ1, x ++ # P :: x0)). apply IdPRule_I. apply IdP in H.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (Γ0 ++ # P :: Γ1, x ++ # P :: x0) H DersNil). exists d0. simpl. rewrite dersrec_height_nil.
+    lia. reflexivity.
+  (* BotL *)
+  * inversion H1. subst. inversion H5. subst. simpl.
+    assert (BotLRule [] (Γ0 ++ Bot :: Γ1, Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4)). apply BotLRule_I. apply BotL in H.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (Γ0 ++ Bot :: Γ1, Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4) H DersNil). exists d0. simpl. rewrite dersrec_height_nil.
+    lia. reflexivity.
+  (* ImpR *)
+  * inversion H1. subst. inversion H5. subst. simpl. simpl in IH.
+    pose (ImpR_app_list_exchR _ _ _ exch H1). destruct s. destruct p.
+    apply ImpR in i. assert (J0: dersrec_height d = dersrec_height d). reflexivity.
+    pose (dersrec_derrec_height d J0). destruct s.
+    assert (E: derrec_height x0 < S (dersrec_height d)). lia.
+    assert (E1: derrec_height x0 = derrec_height x0). auto.
+    pose (IH (derrec_height x0) E (Γ0 ++ A :: Γ1, Δ5 ++ B :: Δ6) x0 E1 x l).
+    destruct s. pose (dlCons x1 DersNil).
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x]) (Γ0 ++ Γ1, Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4) i d0). exists d1. simpl.
+    rewrite dersrec_height_nil. rewrite Nat.max_0_r. lia. reflexivity.
+  (* ImpL *)
+  * inversion H1. subst. inversion H5. subst. simpl. simpl in IH.
+    pose (ImpL_app_list_exchR _ _ _ _ exch H1). repeat destruct s. repeat destruct p.
+    apply ImpL in i. assert (J0: dersrec_height d = dersrec_height d). reflexivity.
+    pose (dersrec_derrec2_height d J0). repeat destruct s.
+    assert (E: derrec_height x1 < S (dersrec_height d)). lia.
+    assert (E1: derrec_height x1 = derrec_height x1). auto.
+    pose (IH (derrec_height x1) E (Γ0 ++ Γ1, Δ5 ++ A :: Δ6) x1 E1 x l0).
+    destruct s.
+    assert (E2: derrec_height x2 < S (dersrec_height d)). lia.
+    assert (E3: derrec_height x2 = derrec_height x2). auto.
+    pose (IH (derrec_height x2) E2 (Γ0 ++ B :: Γ1, Δ5 ++ Δ6) x2 E3 x0 l).
+    destruct s. pose (dlCons x4 DersNil). pose (dlCons x3 d0).
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x; x0]) (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4) i d1). exists d2. simpl.
+    rewrite dersrec_height_nil. rewrite Nat.max_0_r. lia. reflexivity.
+  (* KR *)
+  * inversion X. subst. inversion H5. subst. simpl. simpl in IH.
+    pose (KR_app_list_exchR _ _ _ exch X). destruct s. destruct p.
+    apply KR in k0. assert (J0: dersrec_height d = dersrec_height d). reflexivity.
+    pose (dersrec_derrec_height d J0). destruct s.
+    assert (E: derrec_height x0 < S (dersrec_height d)). lia.
+    assert (E1: derrec_height x0 = derrec_height x0). auto.
+    pose (IH (derrec_height x0) E (unboxed_list , [A]) x0 E1 x l).
+    destruct s. pose (dlCons x1 DersNil).
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x]) (Γ, Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4) k0 d0). exists d1. simpl.
+    rewrite dersrec_height_nil. rewrite Nat.max_0_r. lia. reflexivity.
+Qed.
+ +
+Theorem KS_hpadm_list_exch_L0 : forall (k : nat) s
+                                  (D0: KS_prv s),
+        k = (derrec_height D0) ->
+        (forall se, (list_exch_L s se) ->
+        (existsT2 (D1 : KS_prv se),
+          derrec_height D1 <=k)).
+Proof.
+induction k as [n IH] using (well_founded_induction_type lt_wf).
+intros s0 D0. remember D0 as D0'. destruct D0.
+(* D0 ip a leaf *)
+- inversion f.
+(* D0 is ends with an application of rule *)
+- intros hei se exch. inversion exch.
+  assert (DersNil: dersrec KS_rules (fun _ : Seq => False) []).
+  apply dersrec_nil. inversion k.
+  (* IdP *)
+  * inversion H1. subst. inversion H5. subst. simpl.
+    assert (In # P (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4)). assert (In # P (Γ0 ++ Γ1 ++ Γ2 ++ Γ3 ++ Γ4)).
+    rewrite <- H0. apply in_or_app. right. apply in_eq. apply in_app_or in H. apply in_or_app.
+    destruct H. auto. apply in_app_or in H. right. apply in_or_app. destruct H. right. apply in_or_app.
+    right. apply in_or_app. auto. apply in_app_or in H. destruct H. right. apply in_or_app. auto.
+    apply in_app_or in H. destruct H. auto. right. apply in_or_app. right. apply in_or_app. auto.
+    apply in_splitT in H. destruct H. destruct s. rewrite e.
+    assert (IdPRule [] (x ++ # P :: x0, Δ0 ++ # P :: Δ1)). apply IdPRule_I. apply IdP in H.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x ++ # P :: x0, Δ0 ++ # P :: Δ1) H DersNil). exists d0. simpl. rewrite dersrec_height_nil.
+    lia. reflexivity.
+  (* BotL *)
+  * inversion H1. subst. inversion H5. subst. simpl.
+    assert (In (Bot) (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4)). assert (In (Bot) (Γ0 ++ Γ1 ++ Γ2 ++ Γ3 ++ Γ4)).
+    rewrite <- H0. apply in_or_app. right. apply in_eq. apply in_app_or in H. apply in_or_app.
+    destruct H. auto. apply in_app_or in H. right. apply in_or_app. destruct H. right. apply in_or_app.
+    right. apply in_or_app. auto. apply in_app_or in H. destruct H. right. apply in_or_app. auto.
+    apply in_app_or in H. destruct H. auto. right. apply in_or_app. right. apply in_or_app. auto.
+    apply in_splitT in H. destruct H. destruct s. rewrite e.
+    assert (BotLRule [] (x ++ Bot :: x0, Δ)). apply BotLRule_I. apply BotL in H.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x ++ Bot :: x0, Δ) H DersNil). exists d0. simpl. rewrite dersrec_height_nil.
+    lia. reflexivity.
+  (* ImpR *)
+  * inversion H1. subst. inversion H5. subst. simpl. simpl in IH.
+    pose (ImpR_app_list_exchL _ _ _ exch H1). destruct s. destruct p.
+    apply ImpR in i. assert (J0: dersrec_height d = dersrec_height d). reflexivity.
+    pose (dersrec_derrec_height d J0). destruct s.
+    assert (E: derrec_height x0 < S (dersrec_height d)). lia.
+    assert (E1: derrec_height x0 = derrec_height x0). auto.
+    pose (IH (derrec_height x0) E (Γ5 ++ A :: Γ6, Δ0 ++ B :: Δ1) x0 E1 x l).
+    destruct s. pose (dlCons x1 DersNil).
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x]) (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4, Δ0 ++ A --> B :: Δ1) i d0). exists d1. simpl.
+    rewrite dersrec_height_nil. rewrite Nat.max_0_r. lia. reflexivity.
+  (* ImpL *)
+  * inversion H1. subst. inversion H5. subst. simpl. simpl in IH.
+    pose (ImpL_app_list_exchL _ _ _ _ exch H1). repeat destruct s. repeat destruct p.
+    apply ImpL in i. assert (J0: dersrec_height d = dersrec_height d). reflexivity.
+    pose (dersrec_derrec2_height d J0). repeat destruct s.
+    assert (E: derrec_height x1 < S (dersrec_height d)). lia.
+    assert (E1: derrec_height x1 = derrec_height x1). auto.
+    pose (IH (derrec_height x1) E (Γ5 ++ Γ6, Δ0 ++ A :: Δ1) x1 E1 x l0).
+    destruct s.
+    assert (E2: derrec_height x2 < S (dersrec_height d)). lia.
+    assert (E3: derrec_height x2 = derrec_height x2). auto.
+    pose (IH (derrec_height x2) E2 (Γ5 ++ B :: Γ6, Δ0 ++ Δ1) x2 E3 x0 l).
+    destruct s. pose (dlCons x4 DersNil). pose (dlCons x3 d0).
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x; x0]) (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4, Δ0 ++ Δ1) i d1). exists d2. simpl.
+    rewrite dersrec_height_nil. rewrite Nat.max_0_r. lia. reflexivity.
+  (* KR *)
+  * inversion X. subst. inversion H5. subst. simpl. simpl in IH.
+    pose (KR_app_list_exchL _ _ _ exch X). destruct s. destruct p.
+    apply KR in k0. assert (J0: dersrec_height d = dersrec_height d). reflexivity.
+    pose (dersrec_derrec_height d J0). destruct s.
+    assert (E: derrec_height x0 < S (dersrec_height d)). lia.
+    assert (E1: derrec_height x0 = derrec_height x0). auto.
+    pose (IH (derrec_height x0) E (unboxed_list , [A]) x0 E1 x l).
+    destruct s. pose (dlCons x1 DersNil).
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x]) (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4, Δ0 ++ Box A :: Δ1) k0 d0). exists d1. simpl.
+    rewrite dersrec_height_nil. rewrite Nat.max_0_r. lia. reflexivity.
+Qed.
+ +
+Theorem KS_hpadm_list_exch_L : forall s (D0: KS_prv s),
+        (forall se, (list_exch_L s se) ->
+        (existsT2 (D1 : KS_prv se),
+          derrec_height D1 <= derrec_height D0)).
+Proof.
+intros.
+pose (@KS_hpadm_list_exch_L0 (derrec_height D0) _ D0).
+apply s0 ; auto.
+Qed.
+ +
+Theorem KS_hpadm_list_exch_R : forall s (D0: KS_prv s),
+        (forall se, (list_exch_R s se) ->
+        (existsT2 (D1 : KS_prv se),
+          derrec_height D1 <= derrec_height D0)).
+Proof.
+intros.
+pose (@KS_hpadm_list_exch_R0 (derrec_height D0) _ D0).
+apply s0 ; auto.
+Qed.
+ +
+Theorem KS_adm_list_exch_LR : forall s (D0: KS_prv s),
+        (forall se, ((list_exch_L s se) -> (KS_prv se)) *
+                        ((list_exch_R s se) -> (KS_prv se))).
+Proof.
+intros. assert (J1: derrec_height D0 = derrec_height D0). auto. split ; intro.
+- pose (@KS_hpadm_list_exch_L0 (derrec_height D0) s D0 J1 se H). destruct s0 ; auto.
+- pose (@KS_hpadm_list_exch_R0 (derrec_height D0) s D0 J1 se H). destruct s0 ; auto.
+Qed.
+ +
+
+
+ +
+ + + diff --git a/K.KS.KS_exch_ImpL.html b/K.KS.KS_exch_ImpL.html new file mode 100644 index 0000000..d5231da --- /dev/null +++ b/K.KS.KS_exch_ImpL.html @@ -0,0 +1,589 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_exch_ImpL

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat.
+ +
+Require Import KS_calc.
+Require Import KS_exch_prelims.
+ +
+Lemma ImpL_app_list_exchL : forall s se ps1 ps2,
+  (@list_exch_L s se) ->
+  (ImpLRule [ps1;ps2] s) ->
+  (existsT2 pse1 pse2,
+    (ImpLRule [pse1;pse2] se) *
+    (@list_exch_L ps1 pse1) *
+    (@list_exch_L ps2 pse2)).
+Proof.
+intros s se ps1 ps2 exch. intro RA. inversion RA. inversion exch. subst.
+inversion H. apply app2_find_hole in H1. destruct H1. repeat destruct s ; destruct p ; subst.
+- destruct Γ3 ; destruct Γ4 ; destruct Γ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+  + exists (Γ2 ++ Γ1, Δ0 ++ A :: Δ1). exists (Γ2 ++ B :: Γ1, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  + exists (Γ2 ++ Γ5 ++ Γ6, Δ0 ++ A :: Δ1). exists (Γ2 ++ B :: Γ5 ++ Γ6, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  + exists (Γ2 ++ Γ4 ++ Γ6, Δ0 ++ A :: Δ1). exists (Γ2 ++ B :: Γ4 ++ Γ6, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  + exists (Γ2 ++ (m0 :: Γ5) ++ Γ4 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ2 ++ (m0 :: Γ5) ++ B :: Γ4 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ2 ++ (m0 :: Γ5) ++ B :: Γ4 ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ B :: Γ4 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m0 :: Γ5 ++ A --> B :: Γ4 ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ A --> B :: Γ4 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ (m0 :: Γ5) ++ Γ4 ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ Γ4 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpLRule_I.
+    assert (Γ2 ++ Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ [] ++ Γ4 ++ (m0 :: Γ5) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ (m0 :: Γ5) ++ Γ4 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ Γ4 ++ [] ++ Γ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ2 ++ B :: Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ [] ++ (B :: Γ4) ++ (m0 :: Γ5) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ (m0 :: Γ5) ++ B :: Γ4 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ (B :: Γ4) ++ [] ++ Γ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+  + exists (Γ2 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1). exists (Γ2 ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  + exists (Γ2 ++ (m0 :: Γ5) ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ2 ++ (m0 :: Γ5) ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ2 ++ m0 :: Γ5 ++ A --> B :: Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ A --> B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ (m0 :: Γ5) ++ B :: Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ (m0 :: Γ5) ++ Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpLRule_I.
+    assert (Γ2 ++ Γ3 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ (m0 :: Γ5) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ (m0 :: Γ5) ++ Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ [] ++ Γ3 ++ Γ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ2 ++ B :: Γ3 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ (B :: Γ3) ++ [] ++ (m0 :: Γ5) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ (m0 :: Γ5) ++ B :: Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ [] ++ (B :: Γ3) ++ Γ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+  + exists (Γ2 ++ m0 :: Γ4 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ2 ++ m0 :: Γ4 ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ2 ++ m0 :: Γ4 ++ A --> B :: Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ4) ++ A --> B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m0 :: Γ4 ++ B :: Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ4) ++ B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m0 :: Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ4) ++ Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+    assert (Γ2 ++ Γ3 ++ m0 :: Γ4 ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ (m0 :: Γ4) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m0 :: Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ4) ++ [] ++ Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ2 ++ B :: Γ3 ++ m0 :: Γ4 ++ Γ6 = Γ2 ++ (B :: Γ3) ++ [] ++ (m0 :: Γ4) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m0 :: Γ4 ++ B :: Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ4) ++ [] ++ (B :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+  + exists (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ A --> B :: Γ3 ++ Γ6 = (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ A --> B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ B :: Γ3 ++ Γ6 = (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpLRule_I.
+    assert (Γ2 ++ Γ3 ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ (m0 :: Γ4) ++ (m1 :: Γ5) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (m1 :: Γ5) ++ (m0 :: Γ4) ++ Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ2 ++ B :: Γ3 ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = Γ2 ++ (B :: Γ3) ++ (m0 :: Γ4) ++ (m1 :: Γ5) ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ B :: Γ3 ++ Γ6 = Γ2 ++ (m1 :: Γ5) ++ (m0 :: Γ4) ++ (B :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+- apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+  + destruct Γ4 ; destruct Γ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+    * rewrite app_assoc. exists ((Γ2 ++ Γ3) ++ Γ1, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ Γ3) ++ B :: Γ1, Δ0 ++ Δ1). split. split ; try assumption. apply list_exch_L_id.
+      apply list_exch_L_id.
+    * exists (Γ2 ++ Γ5 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+      exists (Γ2 ++ B :: Γ5 ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split. apply ImpLRule_I.
+      assert ((Γ2 ++ Γ3) ++ Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ Γ5 ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ Γ5 ++ Γ3 ++ Γ6 = Γ2 ++ Γ5 ++ [] ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ Γ3) ++ B :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ (B :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ B :: Γ5 ++ Γ3 ++ Γ6 = Γ2 ++ (B :: Γ5) ++ [] ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    * exists (Γ2 ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+      exists (Γ2 ++ B :: Γ4 ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split. apply ImpLRule_I.
+      assert ((Γ2 ++ Γ3) ++ Γ4 ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ Γ4 ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ Γ4 ++ [] ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ Γ3) ++ B :: Γ4 ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ (B :: Γ4) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ B :: Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (B :: Γ4) ++ [] ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    * exists ((Γ2 ++ m0 :: Γ5) ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ m0 :: Γ5) ++ B :: Γ4 ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+      assert (Γ2 ++ m0 :: Γ5 ++ A --> B :: Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ A --> B :: Γ4 ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+      assert ((Γ2 ++ Γ3) ++ Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ Γ4 ++ (m0 :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ5) ++ Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ Γ4 ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ Γ3) ++ B :: Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ (B :: Γ4) ++ (m0 :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ5) ++ B :: Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ (B :: Γ4) ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+  + apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+    * destruct Γ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+      { exists ((Γ2 ++ Γ4 ++ Γ3) ++ Γ1, Δ0 ++ A :: Δ1).
+        exists ((Γ2 ++ Γ4 ++ Γ3) ++ B :: Γ1, Δ0 ++ Δ1). split. split.
+        assert (Γ2 ++ Γ4 ++ Γ3 ++ A --> B :: Γ1 = (Γ2 ++ Γ4 ++ Γ3) ++ A --> B :: Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+        assert ((Γ2 ++ Γ3 ++ Γ4) ++ Γ1 = Γ2 ++ Γ3 ++ [] ++ Γ4 ++ Γ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ Γ4 ++ Γ3) ++ Γ1 = Γ2 ++ Γ4 ++ [] ++ Γ3 ++ Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+        assert ((Γ2 ++ Γ3 ++ Γ4) ++ B :: Γ1 = Γ2 ++ Γ3 ++ [] ++ Γ4 ++ B :: Γ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ Γ4 ++ Γ3) ++ B :: Γ1 = Γ2 ++ Γ4 ++ [] ++ Γ3 ++ B :: Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI. }
+      { exists (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+        exists (Γ2 ++ B :: Γ5 ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split. apply ImpLRule_I.
+        repeat rewrite <- app_assoc. apply list_exch_LI.
+        assert ((Γ2 ++ Γ3 ++ Γ4) ++ B :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ Γ4 ++ (B :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ B :: Γ5 ++ Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (B :: Γ5) ++ Γ4 ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI. }
+    * apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+      { exists ((Γ2 ++ Γ5 ++ Γ4 ++ Γ3) ++ Γ1, Δ0 ++ A :: Δ1).
+        exists ((Γ2 ++ Γ5 ++ Γ4 ++ Γ3) ++ B :: Γ1, Δ0 ++ Δ1). split. split.
+        assert (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ A --> B :: Γ1 = (Γ2 ++ Γ5 ++ Γ4 ++ Γ3) ++ A --> B :: Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+        repeat rewrite <- app_assoc. apply list_exch_LI. repeat rewrite <- app_assoc. apply list_exch_LI. }
+      { exists ((Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ x0) ++ Γ1, Δ0 ++ A :: Δ1).
+        exists ((Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ x0) ++ B :: Γ1, Δ0 ++ Δ1). split. split.
+        assert (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ x0 ++ A --> B :: Γ1 = (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ x0) ++ A --> B :: Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+        repeat rewrite <- app_assoc. apply list_exch_LI. repeat rewrite <- app_assoc. apply list_exch_LI. }
+      { destruct x0.
+        - simpl in e0. subst. rewrite app_nil_r.
+          exists ((Γ2 ++ x ++ Γ4 ++ Γ3) ++ Γ1, Δ0 ++ A :: Δ1).
+          exists ((Γ2 ++ x ++ Γ4 ++ Γ3) ++ B :: Γ1, Δ0 ++ Δ1). split. split.
+          assert (Γ2 ++ x ++ Γ4 ++ Γ3 ++ A --> B :: Γ1 = (Γ2 ++ x ++ Γ4 ++ Γ3) ++ A --> B :: Γ1).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+          repeat rewrite <- app_assoc. apply list_exch_LI. repeat rewrite <- app_assoc. apply list_exch_LI.
+        - inversion e0. subst.
+          exists ((Γ2 ++ x) ++ x0 ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+          exists ((Γ2 ++ x) ++ B :: x0 ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+          assert (Γ2 ++ (x ++ A --> B :: x0) ++ Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ x) ++ A --> B :: x0 ++ Γ4 ++ Γ3 ++ Γ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+          assert ((Γ2 ++ Γ3 ++ Γ4 ++ x) ++ x0 ++ Γ6 = Γ2 ++ Γ3 ++ Γ4 ++ (x ++ x0) ++ Γ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+          assert ((Γ2 ++ x) ++ x0 ++ Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (x ++ x0) ++ Γ4 ++ Γ3 ++ Γ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+          apply list_exch_LI.
+          assert ((Γ2 ++ Γ3 ++ Γ4 ++ x) ++ B :: x0 ++ Γ6 = Γ2 ++ Γ3 ++ Γ4 ++ (x ++ B :: x0) ++ Γ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+          assert ((Γ2 ++ x) ++ B :: x0 ++ Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ (x ++ B :: x0) ++ Γ4 ++ Γ3 ++ Γ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+          apply list_exch_LI. }
+    * destruct x ; destruct Γ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+      { rewrite app_nil_r. exists ((Γ2 ++ x0 ++ Γ3) ++ Γ1, Δ0 ++ A :: Δ1).
+        exists ((Γ2 ++ x0 ++ Γ3) ++ B :: Γ1, Δ0 ++ Δ1). split. split.
+        assert (Γ2 ++ x0 ++ Γ3 ++ A --> B :: Γ1 = (Γ2 ++ x0 ++ Γ3) ++ A --> B :: Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        assert ((Γ2 ++ Γ3 ++ x0) ++ Γ1 = Γ2 ++ Γ3 ++ [] ++ x0 ++ Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ x0 ++ Γ3) ++ Γ1 = Γ2 ++ x0 ++ [] ++ Γ3 ++ Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+        assert ((Γ2 ++ Γ3 ++ x0) ++ B :: Γ1 = Γ2 ++ Γ3 ++ [] ++ x0 ++ B :: Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ x0 ++ Γ3) ++ B :: Γ1 = Γ2 ++ x0 ++ [] ++ Γ3 ++ B :: Γ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI. }
+      { rewrite app_nil_r. exists (Γ2 ++ Γ5 ++ x0 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+        exists (Γ2 ++ B :: Γ5 ++ x0 ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+        apply ImpLRule_I. repeat rewrite <- app_assoc. apply list_exch_LI.
+        assert ((Γ2 ++ Γ3 ++ x0) ++ B :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ x0 ++ (B :: Γ5) ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ B :: Γ5 ++ x0 ++ Γ3 ++ Γ6 = Γ2 ++ (B :: Γ5) ++ x0 ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI. }
+      { exists ((Γ2 ++ x0) ++ x ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+        exists ((Γ2 ++ x0) ++ B :: x ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+        assert (Γ2 ++ (x0 ++ A --> B :: x) ++ Γ3 ++ Γ6 = (Γ2 ++ x0) ++ A --> B :: x ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        assert ((Γ2 ++ Γ3 ++ x0) ++ x ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ (x0 ++ x) ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ x0) ++ x ++ Γ3 ++ Γ6 = Γ2 ++ (x0 ++ x) ++ [] ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+        assert ((Γ2 ++ Γ3 ++ x0) ++ B :: x ++ Γ6 = Γ2 ++ Γ3 ++ [] ++ (x0 ++ B :: x) ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ x0) ++ B :: x ++ Γ3 ++ Γ6 = Γ2 ++ (x0 ++ B :: x) ++ [] ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI. }
+      { exists ((Γ2 ++ m0 :: Γ5 ++ x0) ++ x ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+        exists ((Γ2 ++ m0 :: Γ5 ++ x0) ++ B :: x ++ Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+        assert (Γ2 ++ m0 :: Γ5 ++ (x0 ++ A --> B :: x) ++ Γ3 ++ Γ6 = (Γ2 ++ m0 :: Γ5 ++ x0) ++ A --> B :: x ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        assert ((Γ2 ++ Γ3 ++ x0) ++ x ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ (x0 ++ x) ++ (m0 :: Γ5) ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ m0 :: Γ5 ++ x0) ++ x ++ Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ (x0 ++ x) ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        apply list_exch_LI.
+        assert ((Γ2 ++ Γ3 ++ x0) ++ B :: x ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ (x0 ++ B :: x) ++ (m0 :: Γ5) ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Γ2 ++ m0 :: Γ5 ++ x0) ++ B :: x ++ Γ3 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ (x0 ++ B :: x) ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        apply list_exch_LI. }
+  + destruct x0 ; destruct Γ4 ; destruct Γ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+    * rewrite app_nil_r. rewrite app_assoc. exists ((Γ2 ++ x) ++ Γ1, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ x) ++ B :: Γ1, Δ0 ++ Δ1). split. split ; try assumption. apply list_exch_L_id. apply list_exch_L_id.
+    * rewrite app_nil_r. exists (Γ2 ++ Γ5 ++ x ++ Γ6, Δ0 ++ A :: Δ1).
+      exists (Γ2 ++ B :: Γ5 ++ x ++ Γ6, Δ0 ++ Δ1). split. split. apply ImpLRule_I.
+      assert ((Γ2 ++ x) ++ Γ5 ++ Γ6 = Γ2 ++ x ++ [] ++ Γ5 ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ Γ5 ++ x ++ Γ6 = Γ2 ++ Γ5 ++ [] ++ x ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ x) ++ B :: Γ5 ++ Γ6 = Γ2 ++ x ++ [] ++ (B :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ B :: Γ5 ++ x ++ Γ6 = Γ2 ++ (B :: Γ5) ++ [] ++ x ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    * rewrite app_nil_r. exists (Γ2 ++ Γ4 ++ x ++ Γ6, Δ0 ++ A :: Δ1).
+      exists (Γ2 ++ B :: Γ4 ++ x ++ Γ6, Δ0 ++ Δ1). split. split. apply ImpLRule_I.
+      assert ((Γ2 ++ x) ++ Γ4 ++ Γ6 = Γ2 ++ x ++ [] ++ Γ4 ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ Γ4 ++ x ++ Γ6 = Γ2 ++ Γ4 ++ [] ++ x ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ x) ++ B :: Γ4 ++ Γ6 = Γ2 ++ x ++ [] ++ (B :: Γ4) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ B :: Γ4 ++ x ++ Γ6 = Γ2 ++ (B :: Γ4) ++ [] ++ x ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    * rewrite app_nil_r. exists ((Γ2 ++ m0 :: Γ5) ++ Γ4 ++ x ++ Γ6, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ m0 :: Γ5) ++ B :: Γ4 ++ x ++ Γ6, Δ0 ++ Δ1). split. split.
+      assert (Γ2 ++ m0 :: Γ5 ++ A --> B :: Γ4 ++ x ++ Γ6 = (Γ2 ++ m0 :: Γ5) ++ A --> B :: Γ4 ++ x ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+      assert ((Γ2 ++ x) ++ Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ x ++ Γ4 ++ (m0 :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ5) ++ Γ4 ++ x ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ Γ4 ++ x ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ x) ++ B :: Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ x ++ (B :: Γ4) ++ (m0 :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ5) ++ B :: Γ4 ++ x ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ (B :: Γ4) ++ x ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    * exists ((Γ2 ++ x) ++ x0 ++ Γ6, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ x) ++ B :: x0 ++ Γ6, Δ0 ++ Δ1). split. split.
+      assert (Γ2 ++ (x ++ A --> B :: x0) ++ Γ6 = (Γ2 ++ x) ++ A --> B :: x0 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+      apply list_exch_L_id. apply list_exch_L_id.
+    * exists ((Γ2 ++ m0 :: Γ5 ++ x) ++ x0 ++ Γ6, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ m0 :: Γ5 ++ x) ++ B :: x0 ++ Γ6, Δ0 ++ Δ1). split. split.
+      assert (Γ2 ++ m0 :: Γ5 ++ (x ++ A --> B :: x0) ++ Γ6 = (Γ2 ++ m0 :: Γ5 ++ x) ++ A --> B :: x0 ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+      assert ((Γ2 ++ x) ++ x0 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ [] ++ (x ++ x0) ++ (m0 :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ5 ++ x) ++ x0 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ (x ++ x0) ++ [] ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ x) ++ B :: x0 ++ m0 :: Γ5 ++ Γ6 = Γ2 ++ [] ++ (x ++ B :: x0) ++ (m0 :: Γ5) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ5 ++ x) ++ B :: x0 ++ Γ6 = Γ2 ++ (m0 :: Γ5) ++ (x ++ B :: x0) ++ [] ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_LI.
+    * exists ((Γ2 ++ m0 :: Γ4 ++ x) ++ x0 ++ Γ6, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ m0 :: Γ4 ++ x) ++ B :: x0 ++ Γ6, Δ0 ++ Δ1). split. split.
+      assert (Γ2 ++ m0 :: Γ4 ++ (x ++ A --> B :: x0) ++ Γ6 = (Γ2 ++ m0 :: Γ4 ++ x) ++ A --> B :: x0 ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+      assert ((Γ2 ++ x) ++ x0 ++ m0 :: Γ4 ++ Γ6 = Γ2 ++ [] ++ (x ++ x0) ++ (m0 :: Γ4) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ4 ++ x) ++ x0 ++ Γ6 = Γ2 ++ (m0 :: Γ4) ++ (x ++ x0) ++ [] ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ x) ++ B :: x0 ++ m0 :: Γ4 ++ Γ6 = Γ2 ++ [] ++ (x ++ B :: x0) ++ (m0 :: Γ4) ++ Γ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m0 :: Γ4 ++ x) ++ B :: x0 ++ Γ6 = Γ2 ++ (m0 :: Γ4) ++ (x ++ B :: x0) ++ [] ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_LI.
+    * exists ((Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ x) ++ x0 ++ Γ6, Δ0 ++ A :: Δ1).
+      exists ((Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ x) ++ B :: x0 ++ Γ6, Δ0 ++ Δ1). split. split.
+      assert (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ (x ++ A --> B :: x0) ++ Γ6 = (Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ x) ++ A --> B :: x0 ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. simpl.
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+      assert ((Γ2 ++ x) ++ x0 ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = Γ2 ++ (x ++ x0) ++ (m0 :: Γ4) ++ (m1 :: Γ5) ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ x) ++ x0 ++ Γ6 = Γ2 ++ (m1 :: Γ5) ++ (m0 :: Γ4) ++ (x ++ x0) ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_LI.
+      assert ((Γ2 ++ x) ++ B :: x0 ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = Γ2 ++ (x ++ B :: x0) ++ (m0 :: Γ4) ++ (m1 :: Γ5) ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert ((Γ2 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ x) ++ B :: x0 ++ Γ6 = Γ2 ++ (m1 :: Γ5) ++ (m0 :: Γ4) ++ (x ++ B :: x0) ++ Γ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_LI.
+- destruct x ; destruct Γ3 ; destruct Γ4 ; destruct Γ5 ; simpl ; simpl in e0 ; simpl in exch ;
+  subst ; try inversion e0 ; subst.
+  * rewrite app_nil_r. exists (Γ0 ++ Γ1, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: Γ1, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * rewrite app_nil_r. exists (Γ0 ++ Γ5 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: Γ5 ++ Γ6, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * rewrite app_nil_r. exists (Γ0 ++ Γ4 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: Γ4 ++ Γ6, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * rewrite app_nil_r. exists ((Γ0 ++ m0 :: Γ5) ++ Γ4 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists ((Γ0 ++ m0 :: Γ5) ++ B :: Γ4 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ0 ++ m0 :: Γ5 ++ A --> B :: Γ4 ++ Γ6 = (Γ0 ++ m0 :: Γ5) ++ A --> B :: Γ4 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+    assert (Γ0 ++ Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ0 ++ [] ++ Γ4 ++ (m0 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Γ0 ++ m0 :: Γ5) ++ Γ4 ++ Γ6 = Γ0 ++ (m0 :: Γ5) ++ Γ4 ++ [] ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ0 ++ B :: Γ4 ++ m0 :: Γ5 ++ Γ6 = Γ0 ++ [] ++ (B :: Γ4) ++ (m0 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Γ0 ++ m0 :: Γ5) ++ B :: Γ4 ++ Γ6 = Γ0 ++ (m0 :: Γ5) ++ (B :: Γ4) ++ [] ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+  * rewrite app_nil_r. exists (Γ0 ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split ; try assumption.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * rewrite app_nil_r. exists ((Γ0 ++ m0 :: Γ5) ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists ((Γ0 ++ m0 :: Γ5) ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ0 ++ m0 :: Γ5 ++ A --> B :: Γ3 ++ Γ6 = (Γ0 ++ m0 :: Γ5) ++ A --> B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+    assert (Γ0 ++ Γ3 ++ m0 :: Γ5 ++ Γ6 = Γ0 ++ [] ++ Γ3 ++ (m0 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Γ0 ++ m0 :: Γ5) ++ Γ3 ++ Γ6 = Γ0 ++ (m0 :: Γ5) ++ Γ3 ++ [] ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ0 ++ B :: Γ3 ++ m0 :: Γ5 ++ Γ6 = Γ0 ++ [] ++ (B :: Γ3) ++ (m0 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Γ0 ++ m0 :: Γ5) ++ B :: Γ3 ++ Γ6 = Γ0 ++ (m0 :: Γ5) ++ (B :: Γ3) ++ [] ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+  * rewrite app_nil_r. exists ((Γ0 ++ m0 :: Γ4) ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists ((Γ0 ++ m0 :: Γ4) ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ0 ++ m0 :: Γ4 ++ A --> B :: Γ3 ++ Γ6 = (Γ0 ++ m0 :: Γ4) ++ A --> B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+    assert ((Γ0 ++ m0 :: Γ4) ++ Γ3 ++ Γ6 = Γ0 ++ (m0 :: Γ4) ++ Γ3 ++ [] ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ Γ3 ++ m0 :: Γ4 ++ Γ6 = Γ0 ++ [] ++ Γ3 ++ (m0 :: Γ4) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert ((Γ0 ++ m0 :: Γ4) ++ B :: Γ3 ++ Γ6 = Γ0 ++ (m0 :: Γ4) ++ (B :: Γ3) ++ [] ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ B :: Γ3 ++ m0 :: Γ4 ++ Γ6 = Γ0 ++ [] ++ (B :: Γ3) ++ (m0 :: Γ4) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+  * rewrite app_nil_r. exists ((Γ0 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists ((Γ0 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ B :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    assert (Γ0 ++ m1 :: Γ5 ++ m0 :: Γ4 ++ A --> B :: Γ3 ++ Γ6 = (Γ0 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ A --> B :: Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpLRule_I.
+    assert (Γ0 ++ Γ3 ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = Γ0 ++ Γ3 ++ (m0 :: Γ4) ++ (m1 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Γ0 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ Γ3 ++ Γ6 = Γ0 ++ (m1 :: Γ5) ++ (m0 :: Γ4) ++ Γ3 ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ0 ++ B :: Γ3 ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = Γ0 ++ (B :: Γ3) ++ (m0 :: Γ4) ++ (m1 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Γ0 ++ m1 :: Γ5 ++ m0 :: Γ4) ++ B :: Γ3 ++ Γ6 = Γ0 ++ (m1 :: Γ5) ++ (m0 :: Γ4) ++ (B :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+  * exists (Γ0 ++ x ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ Γ6, Δ0 ++ Δ1). split. split. repeat rewrite <- app_assoc. apply ImpLRule_I.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * exists (Γ0 ++ x ++ m0 :: Γ5 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ m0 :: Γ5 ++ Γ6, Δ0 ++ Δ1). split. split. repeat rewrite <- app_assoc. apply ImpLRule_I.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * exists (Γ0 ++ x ++ m0 :: Γ4 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ m0 :: Γ4 ++ Γ6, Δ0 ++ Δ1). split. split. repeat rewrite <- app_assoc. apply ImpLRule_I.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * exists (Γ0 ++ x ++ m1 :: Γ5 ++ m0 :: Γ4 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ m1 :: Γ5 ++ m0 :: Γ4 ++ Γ6, Δ0 ++ Δ1). split. split.
+    repeat rewrite <- app_assoc. apply ImpLRule_I.
+    assert (Γ0 ++ x ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = (Γ0 ++ x) ++ (m0 :: Γ4) ++ [] ++ (m1 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ x ++ m1 :: Γ5 ++ m0 :: Γ4 ++ Γ6 = (Γ0 ++ x) ++ (m1 :: Γ5) ++ [] ++ (m0 :: Γ4) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ0 ++ B :: x ++ m0 :: Γ4 ++ m1 :: Γ5 ++ Γ6 = (Γ0 ++ B :: x) ++ (m0 :: Γ4) ++ [] ++ (m1 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ B :: x ++ m1 :: Γ5 ++ m0 :: Γ4 ++ Γ6 = (Γ0 ++ B :: x) ++ (m1 :: Γ5) ++ [] ++ (m0 :: Γ4) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+  * exists (Γ0 ++ x ++ m0 :: Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ m0 :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split. repeat rewrite <- app_assoc. apply ImpLRule_I.
+    apply list_exch_L_id. apply list_exch_L_id.
+  * exists (Γ0 ++ x ++ m1 :: Γ5 ++ m0 :: Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ m1 :: Γ5 ++ m0 :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    repeat rewrite <- app_assoc. apply ImpLRule_I.
+    assert (Γ0 ++ x ++ m0 :: Γ3 ++ m1 :: Γ5 ++ Γ6 = (Γ0 ++ x) ++ (m0 :: Γ3) ++ [] ++ (m1 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ x ++ m1 :: Γ5 ++ m0 :: Γ3 ++ Γ6 = (Γ0 ++ x) ++ (m1 :: Γ5) ++ [] ++ (m0 :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ0 ++ B :: x ++ m0 :: Γ3 ++ m1 :: Γ5 ++ Γ6 = (Γ0 ++ B :: x) ++ (m0 :: Γ3) ++ [] ++ (m1 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ B :: x ++ m1 :: Γ5 ++ m0 :: Γ3 ++ Γ6 = (Γ0 ++ B :: x) ++ (m1 :: Γ5) ++ [] ++ (m0 :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+  * exists (Γ0 ++ x ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    repeat rewrite <- app_assoc. apply ImpLRule_I.
+    assert (Γ0 ++ x ++ m0 :: Γ3 ++ m1 :: Γ4 ++ Γ6 = (Γ0 ++ x) ++ (m0 :: Γ3) ++ [] ++ (m1 :: Γ4) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ x ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6 = (Γ0 ++ x) ++ (m1 :: Γ4) ++ [] ++ (m0 :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ0 ++ B :: x ++ m0 :: Γ3 ++ m1 :: Γ4 ++ Γ6 = (Γ0 ++ B :: x) ++ (m0 :: Γ3) ++ [] ++ (m1 :: Γ4) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ B :: x ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6 = (Γ0 ++ B :: x) ++ (m1 :: Γ4) ++ [] ++ (m0 :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+  * exists (Γ0 ++ x ++ m2 :: Γ5 ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6, Δ0 ++ A :: Δ1).
+    exists (Γ0 ++ B :: x ++ m2 :: Γ5 ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6, Δ0 ++ Δ1). split. split.
+    repeat rewrite <- app_assoc. apply ImpLRule_I.
+    assert (Γ0 ++ x ++ m0 :: Γ3 ++ m1 :: Γ4 ++ m2 :: Γ5 ++ Γ6 = (Γ0 ++ x) ++ (m0 :: Γ3) ++ (m1 :: Γ4) ++ (m2 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ x ++ m2 :: Γ5 ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6 = (Γ0 ++ x) ++ (m2 :: Γ5) ++ (m1 :: Γ4) ++ (m0 :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+    assert (Γ0 ++ B :: x ++ m0 :: Γ3 ++ m1 :: Γ4 ++ m2 :: Γ5 ++ Γ6 = (Γ0 ++ B :: x) ++ (m0 :: Γ3) ++ (m1 :: Γ4) ++ (m2 :: Γ5) ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ0 ++ B :: x ++ m2 :: Γ5 ++ m1 :: Γ4 ++ m0 :: Γ3 ++ Γ6 = (Γ0 ++ B :: x) ++ (m2 :: Γ5) ++ (m1 :: Γ4) ++ (m0 :: Γ3) ++ Γ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_LI.
+Qed.
+ +
+Lemma ImpL_app_list_exchR : forall s se ps1 ps2,
+  (@list_exch_R s se) ->
+  (ImpLRule [ps1;ps2] s) ->
+  (existsT2 pse1 pse2,
+    (ImpLRule [pse1;pse2] se) *
+    (@list_exch_R ps1 pse1) *
+    (@list_exch_R ps2 pse2)).
+Proof.
+intros s se ps1 ps2 exch. intro RA. inversion RA. inversion exch. subst.
+inversion H. apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+- exists (Γ0 ++ Γ1, Δ2 ++ A :: Δ5 ++ Δ4 ++ Δ3 ++ Δ6).
+  exists (Γ0 ++ B :: Γ1, Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6). split. split. apply ImpLRule_I.
+  assert (Δ2 ++ A :: Δ3 ++ Δ4 ++ Δ5 ++ Δ6 = (Δ2 ++ [A]) ++ Δ3 ++ Δ4 ++ Δ5 ++ Δ6).
+  rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+  assert (Δ2 ++ A :: Δ5 ++ Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ [A]) ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6).
+  rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+  apply list_exch_RI.
+- apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+  + exists (Γ0 ++ Γ1, (Δ2 ++ Δ5) ++ A :: Δ4 ++ Δ3 ++ Δ6).
+    exists (Γ0 ++ B :: Γ1, Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6).
+    split. split.
+    assert (Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ Δ5) ++ Δ4 ++ Δ3 ++ Δ6). rewrite app_assoc.
+    reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+    repeat rewrite <- app_assoc.
+    assert (Δ2 ++ Δ3 ++ A :: Δ4 ++ Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ (A :: Δ4) ++ Δ5 ++ Δ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Δ2 ++ Δ5 ++ A :: Δ4 ++ Δ3 ++ Δ6 = Δ2 ++ Δ5 ++ (A :: Δ4) ++ Δ3 ++ Δ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_RI. apply list_exch_RI.
+  + apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+    * exists (Γ0 ++ Γ1, (Δ2 ++ Δ5 ++ Δ4) ++ A :: Δ3 ++ Δ6).
+      exists (Γ0 ++ B :: Γ1, Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6). split. split.
+      assert (Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ Δ5 ++ Δ4) ++ Δ3 ++ Δ6). repeat rewrite app_assoc.
+      reflexivity. rewrite H0. clear H0. apply ImpLRule_I. repeat rewrite <- app_assoc.
+      assert (Δ2 ++ Δ3 ++ Δ4 ++ A :: Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ (Δ4 ++ [A]) ++ Δ5 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert (Δ2 ++ Δ5 ++ Δ4 ++ A :: Δ3 ++ Δ6 = Δ2 ++ Δ5 ++ (Δ4 ++ [A]) ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI. apply list_exch_RI.
+    * apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+      { repeat rewrite <- app_assoc. exists (Γ0 ++ Γ1, Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ A :: Δ6).
+        exists (Γ0 ++ B :: Γ1, Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6).
+        split. split. repeat rewrite app_assoc. apply ImpLRule_I. apply list_exch_RI.
+        apply list_exch_RI. }
+      { repeat rewrite <- app_assoc. exists (Γ0 ++ Γ1, Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ x0 ++ A :: Δ1).
+        exists (Γ0 ++ B :: Γ1, Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ x0 ++ Δ1). split. split. repeat rewrite app_assoc.
+        apply ImpLRule_I. apply list_exch_RI. apply list_exch_RI. }
+      { repeat rewrite <- app_assoc. exists (Γ0 ++ Γ1, Δ2 ++ (x ++ A :: x0) ++ Δ4 ++ Δ3 ++ Δ6).
+        exists (Γ0 ++ B :: Γ1, Δ2 ++ x ++ x0 ++ Δ4 ++ Δ3 ++ Δ6). split. split.
+        assert (Δ2 ++ (x ++ A :: x0) ++ Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ x) ++ A :: x0 ++ Δ4 ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ x ++ x0 ++ Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ x) ++ x0 ++ Δ4 ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        apply ImpLRule_I.
+        assert (Δ2 ++ Δ3 ++ Δ4 ++ x ++ A :: x0 ++ Δ6 = Δ2 ++ Δ3 ++ Δ4 ++ (x ++ A :: x0) ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_RI.
+        assert (Δ2 ++ Δ3 ++ Δ4 ++ x ++ x0 ++ Δ6 = Δ2 ++ Δ3 ++ Δ4 ++ (x ++ x0) ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ x ++ x0 ++ Δ4 ++ Δ3 ++ Δ6 = Δ2 ++ (x ++ x0) ++ Δ4 ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_RI. }
+    * repeat rewrite <- app_assoc. exists (Γ0 ++ Γ1, Δ2 ++ Δ5 ++ (x0 ++ A :: x) ++ Δ3 ++ Δ6).
+      exists (Γ0 ++ B :: Γ1, Δ2 ++ Δ5 ++ (x0 ++ x) ++ Δ3 ++ Δ6). split. split.
+      assert (Δ2 ++ Δ5 ++ (x0 ++ A :: x) ++ Δ3 ++ Δ6 = (Δ2 ++ Δ5 ++ x0) ++ A :: x ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert (Δ2 ++ Δ5 ++ x0 ++ x ++ Δ3 ++ Δ6 = (Δ2 ++ Δ5 ++ x0) ++ x ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert (Δ2 ++ Δ5 ++ (x0 ++ x) ++ Δ3 ++ Δ6 = (Δ2 ++ Δ5 ++ x0) ++ x ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      apply ImpLRule_I.
+      assert (Δ2 ++ Δ3 ++ x0 ++ A :: x ++ Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ (x0 ++ A :: x) ++ Δ5 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_RI.
+      assert (Δ2 ++ Δ3 ++ x0 ++ x ++ Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ (x0 ++ x) ++ Δ5 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_RI.
+  + repeat rewrite <- app_assoc. exists (Γ0 ++ Γ1, Δ2 ++ Δ5 ++ Δ4 ++ (x ++ A :: x0) ++ Δ6).
+    exists (Γ0 ++ B :: Γ1, Δ2 ++ Δ5 ++ Δ4 ++ (x ++ x0) ++ Δ6). split. split.
+    assert (Δ2 ++ Δ5 ++ Δ4 ++ (x ++ A :: x0) ++ Δ6 = (Δ2 ++ Δ5 ++ Δ4 ++ x) ++ A :: x0 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ2 ++ Δ5 ++ Δ4 ++ x ++ x0 ++ Δ6 = (Δ2 ++ Δ5 ++ Δ4 ++ x) ++ x0 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ2 ++ Δ5 ++ Δ4 ++ (x ++ x0) ++ Δ6 = (Δ2 ++ Δ5 ++ Δ4 ++ x) ++ x0 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpLRule_I.
+    assert (Δ2 ++ x ++ A :: x0 ++ Δ4 ++ Δ5 ++ Δ6 = Δ2 ++ (x ++ A :: x0) ++ Δ4 ++ Δ5 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_RI.
+    assert (Δ2 ++ x ++ x0 ++ Δ4 ++ Δ5 ++ Δ6 = Δ2 ++ (x ++ x0) ++ Δ4 ++ Δ5 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_RI.
+- repeat rewrite <- app_assoc. exists (Γ0 ++ Γ1, Δ0 ++ A :: x ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6).
+  exists (Γ0 ++ B :: Γ1, Δ0 ++ x ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6). split. split. apply ImpLRule_I.
+  assert (Δ0 ++ A :: x ++ Δ3 ++ Δ4 ++ Δ5 ++ Δ6 = (Δ0 ++ A :: x) ++ Δ3 ++ Δ4 ++ Δ5 ++ Δ6).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+  assert (Δ0 ++ A :: x ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6 = (Δ0 ++ A :: x) ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+  assert (Δ0 ++ x ++ Δ3 ++ Δ4 ++ Δ5 ++ Δ6 = (Δ0 ++ x) ++ Δ3 ++ Δ4 ++ Δ5 ++ Δ6).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+  assert (Δ0 ++ x ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6 = (Δ0 ++ x) ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+Qed.
+
+
+ +
+ + + diff --git a/K.KS.KS_exch_ImpR.html b/K.KS.KS_exch_ImpR.html new file mode 100644 index 0000000..aa2d605 --- /dev/null +++ b/K.KS.KS_exch_ImpR.html @@ -0,0 +1,385 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_exch_ImpR

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat.
+ +
+Require Import KS_calc.
+Require Import KS_exch_prelims.
+ +
+(* The following lemmas make sure that if a rule is applied on a sequent s with
+premises ps, then the same rule is applicable on a sequent se which is an exchanged
+version of s, with some premises pse that are such that they are exchanged versions
+of ps. *)

+ +
+Lemma ImpR_app_list_exchL : forall s se ps,
+  (@list_exch_L s se) ->
+  (ImpRRule [ps] s) ->
+  (existsT2 pse,
+    (ImpRRule [pse] se) *
+    (@list_exch_L ps pse)).
+Proof.
+intros s se ps exch. intro RA. inversion RA. inversion exch. subst.
+inversion H. apply app2_find_hole in H1. destruct H1. repeat destruct s ; destruct p ; subst.
+- exists (Γ2 ++ A :: Γ5 ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ B :: Δ1). split.
+  apply ImpRRule_I. assert (Γ2 ++ A :: Γ3 ++ Γ4 ++ Γ5 ++ Γ6 = (Γ2 ++ [A]) ++ Γ3 ++ Γ4 ++ Γ5 ++ Γ6).
+  rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+  assert (Γ2 ++ A :: Γ5 ++ Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ [A]) ++ Γ5 ++ Γ4 ++ Γ3 ++ Γ6).
+  rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+- apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+  + exists ((Γ2 ++ Γ5) ++ A :: Γ4 ++ Γ3 ++ Γ6, Δ0 ++ B :: Δ1). split.
+    assert (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ Γ5) ++ Γ4 ++ Γ3 ++ Γ6). rewrite app_assoc.
+    reflexivity. rewrite H0. clear H0. apply ImpRRule_I. repeat rewrite <- app_assoc.
+    assert (Γ2 ++ Γ3 ++ A :: Γ4 ++ Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ (A :: Γ4) ++ Γ5 ++ Γ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ Γ5 ++ A :: Γ4 ++ Γ3 ++ Γ6 = Γ2 ++ Γ5 ++ (A :: Γ4) ++ Γ3 ++ Γ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+  + apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+    * exists ((Γ2 ++ Γ5 ++ Γ4) ++ A :: Γ3 ++ Γ6, Δ0 ++ B :: Δ1). split.
+      assert (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ Γ5 ++ Γ4) ++ Γ3 ++ Γ6). repeat rewrite app_assoc.
+      reflexivity. rewrite H0. clear H0. apply ImpRRule_I. repeat rewrite <- app_assoc.
+      assert (Γ2 ++ Γ3 ++ Γ4 ++ A :: Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ (Γ4 ++ [A]) ++ Γ5 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ Γ5 ++ Γ4 ++ A :: Γ3 ++ Γ6 = Γ2 ++ Γ5 ++ (Γ4 ++ [A]) ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+    * apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+      { repeat rewrite <- app_assoc. exists (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ A :: Γ6, Δ0 ++ B :: Δ1).
+        split. repeat rewrite app_assoc. apply ImpRRule_I. apply list_exch_LI. }
+      { repeat rewrite <- app_assoc. exists (Γ2 ++ Γ5 ++ Γ4 ++ Γ3 ++ x0 ++ A :: Γ1, Δ0 ++ B :: Δ1).
+        split. repeat rewrite app_assoc. apply ImpRRule_I. apply list_exch_LI. }
+      { repeat rewrite <- app_assoc. exists (Γ2 ++ (x ++ A :: x0) ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ B :: Δ1).
+        split. assert (Γ2 ++ (x ++ A :: x0) ++ Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ x) ++ A :: x0 ++ Γ4 ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ x ++ x0 ++ Γ4 ++ Γ3 ++ Γ6 = (Γ2 ++ x) ++ x0 ++ Γ4 ++ Γ3 ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        apply ImpRRule_I.
+        assert (Γ2 ++ Γ3 ++ Γ4 ++ x ++ A :: x0 ++ Γ6 = Γ2 ++ Γ3 ++ Γ4 ++ (x ++ A :: x0) ++ Γ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_LI. }
+    * repeat rewrite <- app_assoc. exists (Γ2 ++ Γ5 ++ (x0 ++ A :: x) ++ Γ3 ++ Γ6, Δ0 ++ B :: Δ1).
+      split. assert (Γ2 ++ Γ5 ++ (x0 ++ A :: x) ++ Γ3 ++ Γ6 = (Γ2 ++ Γ5 ++ x0) ++ A :: x ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ Γ5 ++ x0 ++ x ++ Γ3 ++ Γ6 = (Γ2 ++ Γ5 ++ x0) ++ x ++ Γ3 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      apply ImpRRule_I.
+      assert (Γ2 ++ Γ3 ++ x0 ++ A :: x ++ Γ5 ++ Γ6 = Γ2 ++ Γ3 ++ (x0 ++ A :: x) ++ Γ5 ++ Γ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_LI.
+  + repeat rewrite <- app_assoc. exists (Γ2 ++ Γ5 ++ Γ4 ++ (x ++ A :: x0) ++ Γ6, Δ0 ++ B :: Δ1).
+    split. assert (Γ2 ++ Γ5 ++ Γ4 ++ (x ++ A :: x0) ++ Γ6 = (Γ2 ++ Γ5 ++ Γ4 ++ x) ++ A :: x0 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Γ2 ++ Γ5 ++ Γ4 ++ x ++ x0 ++ Γ6 = (Γ2 ++ Γ5 ++ Γ4 ++ x) ++ x0 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpRRule_I.
+    assert (Γ2 ++ x ++ A :: x0 ++ Γ4 ++ Γ5 ++ Γ6 = Γ2 ++ (x ++ A :: x0) ++ Γ4 ++ Γ5 ++ Γ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply list_exch_LI.
+- repeat rewrite <- app_assoc. exists (Γ0 ++ A :: x ++ Γ5 ++ Γ4 ++ Γ3 ++ Γ6, Δ0 ++ B :: Δ1).
+  split. apply ImpRRule_I.
+  assert (Γ0 ++ A :: x ++ Γ3 ++ Γ4 ++ Γ5 ++ Γ6 = (Γ0 ++ A :: x) ++ Γ3 ++ Γ4 ++ Γ5 ++ Γ6).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+  assert (Γ0 ++ A :: x ++ Γ5 ++ Γ4 ++ Γ3 ++ Γ6 = (Γ0 ++ A :: x) ++ Γ5 ++ Γ4 ++ Γ3 ++ Γ6).
+  repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_LI.
+Qed.
+ +
+Lemma ImpR_app_list_exchR : forall s se ps,
+  (@list_exch_R s se) ->
+  (ImpRRule [ps] s) ->
+  (existsT2 pse,
+    (ImpRRule [pse] se) *
+    (@list_exch_R ps pse)).
+Proof.
+intros s se ps exch. intro RA. inversion RA. inversion exch. subst.
+inversion H. apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+- destruct Δ3 ; destruct Δ4 ; destruct Δ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+  + exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ1). split ; try assumption. apply list_exch_R_id.
+  + exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ5 ++ Δ6). split ; try assumption. apply list_exch_R_id.
+  + exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ4 ++ Δ6). split ; try assumption. apply list_exch_R_id.
+  + exists (Γ0 ++ A :: Γ1, Δ2 ++ (m0 :: Δ5) ++ B :: Δ4 ++ Δ6). split.
+    assert (Δ2 ++ (m0 :: Δ5) ++ B :: Δ4 ++ Δ6 = (Δ2 ++ m0 :: Δ5) ++ B :: Δ4 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ2 ++ m0 :: Δ5 ++ A --> B :: Δ4 ++ Δ6 = (Δ2 ++ m0 :: Δ5) ++ A --> B :: Δ4 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpRRule_I. assert (Δ2 ++ B :: Δ4 ++ m0 :: Δ5 ++ Δ6 = Δ2 ++ [] ++ (B :: Δ4) ++ (m0 :: Δ5) ++ Δ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Δ2 ++ (m0 :: Δ5) ++ B :: Δ4 ++ Δ6 = Δ2 ++ (m0 :: Δ5) ++ (B :: Δ4) ++ [] ++ Δ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+  + exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ3 ++ Δ6). split ; try assumption. apply list_exch_R_id.
+  + exists (Γ0 ++ A :: Γ1, Δ2 ++ (m0 :: Δ5) ++ B :: Δ3 ++ Δ6). split.
+    assert (Δ2 ++ m0 :: Δ5 ++ A --> B :: Δ3 ++ Δ6 = (Δ2 ++ m0 :: Δ5) ++ A --> B :: Δ3 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ2 ++ (m0 :: Δ5) ++ B :: Δ3 ++ Δ6 = (Δ2 ++ m0 :: Δ5) ++ B :: Δ3 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    apply ImpRRule_I. assert (Δ2 ++ B :: Δ3 ++ m0 :: Δ5 ++ Δ6 = Δ2 ++ (B :: Δ3) ++ [] ++ (m0 :: Δ5) ++ Δ6).
+    reflexivity. rewrite H0. clear H0.
+    assert (Δ2 ++ (m0 :: Δ5) ++ B :: Δ3 ++ Δ6 = Δ2 ++ (m0 :: Δ5) ++ [] ++ (B :: Δ3) ++ Δ6).
+    reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+  + exists (Γ0 ++ A :: Γ1, (Δ2 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6). split.
+    assert (Δ2 ++ m0 :: Δ4 ++ A --> B :: Δ3 ++ Δ6 = (Δ2 ++ m0 :: Δ4) ++ A --> B :: Δ3 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+    assert (Δ2 ++ B :: Δ3 ++ m0 :: Δ4 ++ Δ6 = Δ2 ++ (B :: Δ3) ++ [] ++ (m0 :: Δ4) ++ Δ6).
+    reflexivity. rewrite H0. clear H0.
+    assert ((Δ2 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6 = Δ2 ++ (m0 :: Δ4) ++ [] ++ (B :: Δ3) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+  + exists (Γ0 ++ A :: Γ1, (Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6). split.
+    assert (Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4 ++ A --> B :: Δ3 ++ Δ6 = (Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4) ++ A --> B :: Δ3 ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+    assert (Δ2 ++ B :: Δ3 ++ m0 :: Δ4 ++ m1 :: Δ5 ++ Δ6 = Δ2 ++ (B :: Δ3) ++ (m0 :: Δ4) ++ (m1 :: Δ5) ++ Δ6).
+    reflexivity. rewrite H0. clear H0.
+    assert ((Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6 = Δ2 ++ (m1 :: Δ5) ++ (m0 :: Δ4) ++ (B :: Δ3) ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+- apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+  + destruct Δ4 ; destruct Δ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+    * rewrite app_assoc. exists (Γ0 ++ A :: Γ1, (Δ2 ++ Δ3) ++ B :: Δ1). split ; try assumption. apply list_exch_R_id.
+    * exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ5 ++ Δ3 ++ Δ6). split. apply ImpRRule_I.
+      assert ((Δ2 ++ Δ3) ++ B :: Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ [] ++ (B :: Δ5) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Δ2 ++ B :: Δ5 ++ Δ3 ++ Δ6 = Δ2 ++ (B :: Δ5) ++ [] ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+    * exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ4 ++ Δ3 ++ Δ6). split. apply ImpRRule_I.
+      assert ((Δ2 ++ Δ3) ++ B :: Δ4 ++ Δ6 = Δ2 ++ Δ3 ++ [] ++ (B :: Δ4) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Δ2 ++ B :: Δ4 ++ Δ3 ++ Δ6 = Δ2 ++ (B :: Δ4) ++ [] ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+    * exists (Γ0 ++ A :: Γ1, (Δ2 ++ m0 :: Δ5) ++ B :: Δ4 ++ Δ3 ++ Δ6). split.
+      assert (Δ2 ++ m0 :: Δ5 ++ A --> B :: Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ m0 :: Δ5) ++ A --> B :: Δ4 ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+      assert ((Δ2 ++ Δ3) ++ B :: Δ4 ++ m0 :: Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ (B :: Δ4) ++ (m0 :: Δ5) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Δ2 ++ m0 :: Δ5) ++ B :: Δ4 ++ Δ3 ++ Δ6 = Δ2 ++ (m0 :: Δ5) ++ (B :: Δ4) ++ Δ3 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+  + apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+    * destruct Δ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+      { exists (Γ0 ++ A :: Γ1, (Δ2 ++ Δ4 ++ Δ3) ++ B :: Δ1). split.
+        assert (Δ2 ++ Δ4 ++ Δ3 ++ A --> B :: Δ1 = (Δ2 ++ Δ4 ++ Δ3) ++ A --> B :: Δ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        assert ((Δ2 ++ Δ3 ++ Δ4) ++ B :: Δ1 = Δ2 ++ Δ3 ++ [] ++ Δ4 ++ B :: Δ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert ((Δ2 ++ Δ4 ++ Δ3) ++ B :: Δ1 = Δ2 ++ Δ4 ++ [] ++ Δ3 ++ B :: Δ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI. }
+      { exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ5 ++ Δ4 ++ Δ3 ++ Δ6). split. apply ImpRRule_I.
+        assert ((Δ2 ++ Δ3 ++ Δ4) ++ B :: Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ Δ4 ++ (B :: Δ5) ++ Δ6). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ B :: Δ5 ++ Δ4 ++ Δ3 ++ Δ6 = Δ2 ++ (B :: Δ5) ++ Δ4 ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI. }
+    * apply app2_find_hole in e0. destruct e0. repeat destruct s ; destruct p ; subst.
+      { exists (Γ0 ++ A :: Γ1, (Δ2 ++ Δ5 ++ Δ4 ++ Δ3) ++ B :: Δ1). split.
+        assert (Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ A --> B :: Δ1 = (Δ2 ++ Δ5 ++ Δ4 ++ Δ3) ++ A --> B :: Δ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        repeat rewrite <- app_assoc. apply list_exch_RI. }
+      { exists (Γ0 ++ A :: Γ1, (Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ x0) ++ B :: Δ1). split.
+        assert (Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ x0 ++ A --> B :: Δ1 = (Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ x0) ++ A --> B :: Δ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        repeat rewrite <- app_assoc. apply list_exch_RI. }
+      { destruct x0.
+        - simpl in e0. subst. rewrite app_nil_r.
+          exists (Γ0 ++ A :: Γ1, (Δ2 ++ x ++ Δ4 ++ Δ3) ++ B :: Δ1). split.
+          assert (Δ2 ++ x ++ Δ4 ++ Δ3 ++ A --> B :: Δ1 = (Δ2 ++ x ++ Δ4 ++ Δ3) ++ A --> B :: Δ1).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+          repeat rewrite <- app_assoc. apply list_exch_RI.
+        - inversion e0. subst.
+          exists (Γ0 ++ A :: Γ1, (Δ2 ++ x) ++ B :: x0 ++ Δ4 ++ Δ3 ++ Δ6). split.
+          assert (Δ2 ++ (x ++ A --> B :: x0) ++ Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ x) ++ A --> B :: x0 ++ Δ4 ++ Δ3 ++ Δ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+          assert ((Δ2 ++ Δ3 ++ Δ4 ++ x) ++ B :: x0 ++ Δ6 = Δ2 ++ Δ3 ++ Δ4 ++ (x ++ B :: x0) ++ Δ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+          assert ((Δ2 ++ x) ++ B :: x0 ++ Δ4 ++ Δ3 ++ Δ6 = Δ2 ++ (x ++ B :: x0) ++ Δ4 ++ Δ3 ++ Δ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+          apply list_exch_RI. }
+    * destruct x ; destruct Δ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+      { rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, (Δ2 ++ x0 ++ Δ3) ++ B :: Δ1). split.
+        assert (Δ2 ++ x0 ++ Δ3 ++ A --> B :: Δ1 = (Δ2 ++ x0 ++ Δ3) ++ A --> B :: Δ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        assert ((Δ2 ++ Δ3 ++ x0) ++ B :: Δ1 = Δ2 ++ Δ3 ++ [] ++ x0 ++ B :: Δ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Δ2 ++ x0 ++ Δ3) ++ B :: Δ1 = Δ2 ++ x0 ++ [] ++ Δ3 ++ B :: Δ1).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI. }
+      { rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ5 ++ x0 ++ Δ3 ++ Δ6). split.
+        apply ImpRRule_I.
+        assert ((Δ2 ++ Δ3 ++ x0) ++ B :: Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ x0 ++ (B :: Δ5) ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ B :: Δ5 ++ x0 ++ Δ3 ++ Δ6 = Δ2 ++ (B :: Δ5) ++ x0 ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI. }
+      { exists (Γ0 ++ A :: Γ1, (Δ2 ++ x0) ++ B :: x ++ Δ3 ++ Δ6). split.
+        assert (Δ2 ++ (x0 ++ A --> B :: x) ++ Δ3 ++ Δ6 = (Δ2 ++ x0) ++ A --> B :: x ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        assert ((Δ2 ++ Δ3 ++ x0) ++ B :: x ++ Δ6 = Δ2 ++ Δ3 ++ [] ++ (x0 ++ B :: x) ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Δ2 ++ x0) ++ B :: x ++ Δ3 ++ Δ6 = Δ2 ++ (x0 ++ B :: x) ++ [] ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI. }
+      { exists (Γ0 ++ A :: Γ1, (Δ2 ++ m0 :: Δ5 ++ x0) ++ B :: x ++ Δ3 ++ Δ6). split.
+        assert (Δ2 ++ m0 :: Δ5 ++ (x0 ++ A --> B :: x) ++ Δ3 ++ Δ6 = (Δ2 ++ m0 :: Δ5 ++ x0) ++ A --> B :: x ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        assert ((Δ2 ++ Δ3 ++ x0) ++ B :: x ++ m0 :: Δ5 ++ Δ6 = Δ2 ++ Δ3 ++ (x0 ++ B :: x) ++ (m0 :: Δ5) ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert ((Δ2 ++ m0 :: Δ5 ++ x0) ++ B :: x ++ Δ3 ++ Δ6 = Δ2 ++ (m0 :: Δ5) ++ (x0 ++ B :: x) ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        apply list_exch_RI. }
+  + destruct x0 ; destruct Δ4 ; destruct Δ5 ; simpl ; simpl in e0 ; simpl in exch ; subst ; try inversion e0 ; subst.
+    * rewrite app_nil_r. rewrite app_assoc. exists (Γ0 ++ A :: Γ1, (Δ2 ++ x) ++ B :: Δ1). split ; try assumption. apply list_exch_R_id.
+    * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ5 ++ x ++ Δ6). split. apply ImpRRule_I.
+      assert ((Δ2 ++ x) ++ B :: Δ5 ++ Δ6 = Δ2 ++ x ++ [] ++ (B :: Δ5) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Δ2 ++ B :: Δ5 ++ x ++ Δ6 = Δ2 ++ (B :: Δ5) ++ [] ++ x ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+    * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, Δ2 ++ B :: Δ4 ++ x ++ Δ6). split. apply ImpRRule_I.
+      assert ((Δ2 ++ x) ++ B :: Δ4 ++ Δ6 = Δ2 ++ x ++ [] ++ (B :: Δ4) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert (Δ2 ++ B :: Δ4 ++ x ++ Δ6 = Δ2 ++ (B :: Δ4) ++ [] ++ x ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+    * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, (Δ2 ++ m0 :: Δ5) ++ B :: Δ4 ++ x ++ Δ6). split.
+      assert (Δ2 ++ m0 :: Δ5 ++ A --> B :: Δ4 ++ x ++ Δ6 = (Δ2 ++ m0 :: Δ5) ++ A --> B :: Δ4 ++ x ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+      assert ((Δ2 ++ x) ++ B :: Δ4 ++ m0 :: Δ5 ++ Δ6 = Δ2 ++ x ++ (B :: Δ4) ++ (m0 :: Δ5) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Δ2 ++ m0 :: Δ5) ++ B :: Δ4 ++ x ++ Δ6 = Δ2 ++ (m0 :: Δ5) ++ (B :: Δ4) ++ x ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0. apply list_exch_RI.
+    * exists (Γ0 ++ A :: Γ1, (Δ2 ++ x) ++ B :: x0 ++ Δ6). split.
+      assert (Δ2 ++ (x ++ A --> B :: x0) ++ Δ6 = (Δ2 ++ x) ++ A --> B :: x0 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+      apply list_exch_R_id.
+    * exists (Γ0 ++ A :: Γ1, (Δ2 ++ m0 :: Δ5 ++ x) ++ B :: x0 ++ Δ6). split.
+      assert (Δ2 ++ m0 :: Δ5 ++ (x ++ A --> B :: x0) ++ Δ6 = (Δ2 ++ m0 :: Δ5 ++ x) ++ A --> B :: x0 ++ Δ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+      assert ((Δ2 ++ x) ++ B :: x0 ++ m0 :: Δ5 ++ Δ6 = Δ2 ++ [] ++ (x ++ B :: x0) ++ (m0 :: Δ5) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Δ2 ++ m0 :: Δ5 ++ x) ++ B :: x0 ++ Δ6 = Δ2 ++ (m0 :: Δ5) ++ (x ++ B :: x0) ++ [] ++ Δ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_RI.
+    * exists (Γ0 ++ A :: Γ1, (Δ2 ++ m0 :: Δ4 ++ x) ++ B :: x0 ++ Δ6). split.
+      assert (Δ2 ++ m0 :: Δ4 ++ (x ++ A --> B :: x0) ++ Δ6 = (Δ2 ++ m0 :: Δ4 ++ x) ++ A --> B :: x0 ++ Δ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+      assert ((Δ2 ++ x) ++ B :: x0 ++ m0 :: Δ4 ++ Δ6 = Δ2 ++ [] ++ (x ++ B :: x0) ++ (m0 :: Δ4) ++ Δ6). repeat rewrite <- app_assoc.
+      reflexivity. rewrite H0. clear H0.
+      assert ((Δ2 ++ m0 :: Δ4 ++ x) ++ B :: x0 ++ Δ6 = Δ2 ++ (m0 :: Δ4) ++ (x ++ B :: x0) ++ [] ++ Δ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_RI.
+    * exists (Γ0 ++ A :: Γ1, (Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4 ++ x) ++ B :: x0 ++ Δ6). split.
+      assert (Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4 ++ (x ++ A --> B :: x0) ++ Δ6 = (Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4 ++ x) ++ A --> B :: x0 ++ Δ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. simpl.
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+      assert ((Δ2 ++ x) ++ B :: x0 ++ m0 :: Δ4 ++ m1 :: Δ5 ++ Δ6 = Δ2 ++ (x ++ B :: x0) ++ (m0 :: Δ4) ++ (m1 :: Δ5) ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert ((Δ2 ++ m1 :: Δ5 ++ m0 :: Δ4 ++ x) ++ B :: x0 ++ Δ6 = Δ2 ++ (m1 :: Δ5) ++ (m0 :: Δ4) ++ (x ++ B :: x0) ++ Δ6).
+      repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. apply list_exch_RI.
+- destruct x ; destruct Δ3 ; destruct Δ4 ; destruct Δ5 ; simpl ; simpl in e0 ; simpl in exch ;
+  subst ; try inversion e0 ; subst.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1). split ; try assumption.
+    apply list_exch_R_id.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ5 ++ Δ6). split ; try assumption.
+    apply list_exch_R_id.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ4 ++ Δ6). split ; try assumption.
+    apply list_exch_R_id.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, (Δ0 ++ m0 :: Δ5) ++ B :: Δ4 ++ Δ6). split.
+    assert (Δ0 ++ m0 :: Δ5 ++ A --> B :: Δ4 ++ Δ6 = (Δ0 ++ m0 :: Δ5) ++ A --> B :: Δ4 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+    assert (Δ0 ++ B :: Δ4 ++ m0 :: Δ5 ++ Δ6 = Δ0 ++ [] ++ (B :: Δ4) ++ (m0 :: Δ5) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Δ0 ++ m0 :: Δ5) ++ B :: Δ4 ++ Δ6 = Δ0 ++ (m0 :: Δ5) ++ (B :: Δ4) ++ [] ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ3 ++ Δ6). split ; try assumption.
+    apply list_exch_R_id.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, (Δ0 ++ m0 :: Δ5) ++ B :: Δ3 ++ Δ6). split.
+    assert (Δ0 ++ m0 :: Δ5 ++ A --> B :: Δ3 ++ Δ6 = (Δ0 ++ m0 :: Δ5) ++ A --> B :: Δ3 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+    assert (Δ0 ++ B :: Δ3 ++ m0 :: Δ5 ++ Δ6 = Δ0 ++ [] ++ (B :: Δ3) ++ (m0 :: Δ5) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Δ0 ++ m0 :: Δ5) ++ B :: Δ3 ++ Δ6 = Δ0 ++ (m0 :: Δ5) ++ (B :: Δ3) ++ [] ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, (Δ0 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6). split.
+    assert (Δ0 ++ m0 :: Δ4 ++ A --> B :: Δ3 ++ Δ6 = (Δ0 ++ m0 :: Δ4) ++ A --> B :: Δ3 ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+    assert ((Δ0 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6 = Δ0 ++ (m0 :: Δ4) ++ (B :: Δ3) ++ [] ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ B :: Δ3 ++ m0 :: Δ4 ++ Δ6 = Δ0 ++ [] ++ (B :: Δ3) ++ (m0 :: Δ4) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+  * rewrite app_nil_r. exists (Γ0 ++ A :: Γ1, (Δ0 ++ m1 :: Δ5 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6). split.
+    assert (Δ0 ++ m1 :: Δ5 ++ m0 :: Δ4 ++ A --> B :: Δ3 ++ Δ6 = (Δ0 ++ m1 :: Δ5 ++ m0 :: Δ4) ++ A --> B :: Δ3 ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity. rewrite H0. apply ImpRRule_I.
+    assert (Δ0 ++ B :: Δ3 ++ m0 :: Δ4 ++ m1 :: Δ5 ++ Δ6 = Δ0 ++ (B :: Δ3) ++ (m0 :: Δ4) ++ (m1 :: Δ5) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert ((Δ0 ++ m1 :: Δ5 ++ m0 :: Δ4) ++ B :: Δ3 ++ Δ6 = Δ0 ++ (m1 :: Δ5) ++ (m0 :: Δ4) ++ (B :: Δ3) ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ Δ6). split. repeat rewrite <- app_assoc. apply ImpRRule_I.
+    apply list_exch_R_id.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ m0 :: Δ5 ++ Δ6). split. repeat rewrite <- app_assoc. apply ImpRRule_I.
+    apply list_exch_R_id.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ m0 :: Δ4 ++ Δ6). split. repeat rewrite <- app_assoc. apply ImpRRule_I.
+    apply list_exch_R_id.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ m1 :: Δ5 ++ m0 :: Δ4 ++ Δ6). split.
+    repeat rewrite <- app_assoc. apply ImpRRule_I.
+    assert (Δ0 ++ B :: x ++ m0 :: Δ4 ++ m1 :: Δ5 ++ Δ6 = (Δ0 ++ B :: x) ++ (m0 :: Δ4) ++ [] ++ (m1 :: Δ5) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ B :: x ++ m1 :: Δ5 ++ m0 :: Δ4 ++ Δ6 = (Δ0 ++ B :: x) ++ (m1 :: Δ5) ++ [] ++ (m0 :: Δ4) ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ m0 :: Δ3 ++ Δ6). split. repeat rewrite <- app_assoc. apply ImpRRule_I.
+    apply list_exch_R_id.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ m1 :: Δ5 ++ m0 :: Δ3 ++ Δ6). split.
+    repeat rewrite <- app_assoc. apply ImpRRule_I.
+    assert (Δ0 ++ B :: x ++ m0 :: Δ3 ++ m1 :: Δ5 ++ Δ6 = (Δ0 ++ B :: x) ++ (m0 :: Δ3) ++ [] ++ (m1 :: Δ5) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ B :: x ++ m1 :: Δ5 ++ m0 :: Δ3 ++ Δ6 = (Δ0 ++ B :: x) ++ (m1 :: Δ5) ++ [] ++ (m0 :: Δ3) ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ m1 :: Δ4 ++ m0 :: Δ3 ++ Δ6). split.
+    repeat rewrite <- app_assoc. apply ImpRRule_I.
+    assert (Δ0 ++ B :: x ++ m0 :: Δ3 ++ m1 :: Δ4 ++ Δ6 = (Δ0 ++ B :: x) ++ (m0 :: Δ3) ++ [] ++ (m1 :: Δ4) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ B :: x ++ m1 :: Δ4 ++ m0 :: Δ3 ++ Δ6 = (Δ0 ++ B :: x) ++ (m1 :: Δ4) ++ [] ++ (m0 :: Δ3) ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+  * exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ m2 :: Δ5 ++ m1 :: Δ4 ++ m0 :: Δ3 ++ Δ6). split.
+    repeat rewrite <- app_assoc. apply ImpRRule_I.
+    assert (Δ0 ++ B :: x ++ m0 :: Δ3 ++ m1 :: Δ4 ++ m2 :: Δ5 ++ Δ6 = (Δ0 ++ B :: x) ++ (m0 :: Δ3) ++ (m1 :: Δ4) ++ (m2 :: Δ5) ++ Δ6).
+    repeat rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ B :: x ++ m2 :: Δ5 ++ m1 :: Δ4 ++ m0 :: Δ3 ++ Δ6 = (Δ0 ++ B :: x) ++ (m2 :: Δ5) ++ (m1 :: Δ4) ++ (m0 :: Δ3) ++ Δ6).
+    repeat rewrite <- app_assoc. simpl. repeat rewrite <- app_assoc. reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+Qed.
+
+
+ +
+ + + diff --git a/K.KS.KS_exch_KR.html b/K.KS.KS_exch_KR.html new file mode 100644 index 0000000..dcff216 --- /dev/null +++ b/K.KS.KS_exch_KR.html @@ -0,0 +1,111 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_exch_KR

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat.
+ +
+Require Import KS_calc.
+Require Import KS_exch_prelims.
+ +
+(* The following lemmas make sure that if a rule is applied on a sequent s with
+premises ps, then the same rule is applicable on a sequent se which is an exchanged
+version of s, with some premises pse that are such that they are exchanged versions
+of ps. *)

+ +
+Lemma KR_app_list_exchL : forall s se ps,
+  (@list_exch_L s se) ->
+  (KRRule [ps] s) ->
+  (existsT2 pse,
+    (KRRule [pse] se) *
+    (@list_exch_L ps pse)).
+Proof.
+intros s se ps exch RA. inversion RA. inversion exch. rewrite <- H1 in H2.
+inversion H2. subst.
+pose (@nobox_gen_ext_exch_L (Δ0 ++ Box A :: Δ1) [A] (Γ1 ++ Γ2 ++ Γ3 ++ Γ4 ++ Γ5) (Γ1 ++ Γ4 ++ Γ3 ++ Γ2 ++ Γ5) X exch).
+destruct s. destruct p. inversion l.
+exists (unboxed_list (Γ0 ++ Γ8 ++ Γ7 ++ Γ6 ++ Γ9), [A]). split.
+- apply KRRule_I.
+  * unfold is_Boxed_list. intros. apply in_exch_list in H4. subst. apply H0 in H4.
+    assumption.
+  * subst. assumption.
+- repeat rewrite unbox_app_distrib. repeat rewrite <- app_assoc. apply list_exch_LI.
+Qed.
+ +
+Lemma KR_app_list_exchR : forall s se ps,
+  (@list_exch_R s se) ->
+  (KRRule [ps] s) ->
+  (existsT2 pse,
+    (KRRule [pse] se) *
+    (@list_exch_R ps pse)).
+Proof.
+intros s se ps exch RA. inversion RA. inversion exch. rewrite <- H1 in H2.
+inversion H2. exists (unboxed_list , [A]). split.
+- pose (partition_1_element2 Δ2 Δ3 Δ4 Δ5 Δ6 Δ0 Δ1 (Box A) H6). destruct s0.
+  + repeat destruct s0. repeat destruct p. subst. assert (E : (Δ0 ++ Box A :: x0) ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6 = Δ0 ++ Box A :: (x0 ++ Δ5 ++ Δ4 ++ Δ3 ++ Δ6)).
+    repeat rewrite <- app_assoc. reflexivity. rewrite E. apply KRRule_I.
+    * assumption.
+    * assumption.
+  + destruct s0.
+    * repeat destruct s0. repeat destruct p. subst. assert (E: Δ2 ++ Δ5 ++ Δ4 ++ (x ++ Box A :: x0) ++ Δ6 = (Δ2 ++ Δ5 ++ Δ4 ++ x) ++ Box A :: x0 ++ Δ6).
+      repeat rewrite <- app_assoc. reflexivity. rewrite E. apply KRRule_I.
+      { assumption. }
+      { assumption. }
+    * destruct s0.
+      { repeat destruct s0. repeat destruct p. subst. assert (E: Δ2 ++ Δ5 ++ (x ++ Box A :: x0) ++ Δ3 ++ Δ6 = (Δ2 ++ Δ5 ++ x) ++ Box A :: x0 ++ Δ3 ++ Δ6).
+        repeat rewrite <- app_assoc. reflexivity. rewrite E. apply KRRule_I.
+        - assumption.
+        - assumption. }
+      { destruct s0.
+        - repeat destruct s0. repeat destruct p. subst. assert (E: Δ2 ++ (x ++ Box A :: x0) ++ Δ4 ++ Δ3 ++ Δ6 = (Δ2 ++ x) ++ Box A :: x0 ++ Δ4 ++ Δ3 ++ Δ6).
+          repeat rewrite <- app_assoc. reflexivity. rewrite E. apply KRRule_I.
+          + assumption.
+          + assumption.
+        - repeat destruct s0. repeat destruct p. subst. assert (E: Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ x ++ Box A :: Δ1 = (Δ2 ++ Δ5 ++ Δ4 ++ Δ3 ++ x) ++ Box A :: Δ1).
+          repeat rewrite <- app_assoc. reflexivity. rewrite E. apply KRRule_I.
+          + assumption.
+          + assumption. }
+- apply list_exch_R_id.
+Qed.
+
+
+ +
+ + + diff --git a/K.KS.KS_exch_prelims.html b/K.KS.KS_exch_prelims.html new file mode 100644 index 0000000..8413b5d --- /dev/null +++ b/K.KS.KS_exch_prelims.html @@ -0,0 +1,538 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_exch_prelims

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat.
+ +
+Require Import KS_calc.
+ +
+(* First, as we want to mimic sequents based on multisets of formulae we need to
+obtain exchange. *)

+ +
+(* Definition of exchange with lists of formulae directly. It is more general and
+makes the proofs about exchange easier to handle. *)

+ +
+Inductive list_exch_L : relationT Seq :=
+  | list_exch_LI Γ0 Γ1 Γ2 Γ3 Γ4 Δ : list_exch_L
+      (Γ0 ++ Γ1 ++ Γ2 ++ Γ3 ++ Γ4, Δ) (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4, Δ).
+ +
+Inductive list_exch_R : relationT Seq :=
+  | list_exch_RI Γ Δ0 Δ1 Δ2 Δ3 Δ4 : list_exch_R
+        (Γ, Δ0 ++ Δ1 ++ Δ2 ++ Δ3 ++ Δ4) (Γ, Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4).
+ +
+(* Some lemmas about In and exchange. *)
+ +
+Lemma InT_list_exch_R : forall l0 l1 l2,
+            (@list_exch_R (l0,l1) (l0,l2)) ->
+            (forall x, (InT x l1 -> InT x l2) * (InT x l2 -> InT x l1)).
+Proof.
+intros l0 l1 l2 exch. inversion exch.
+intro x. split.
+- intro. apply InT_app_or in H2. destruct H2. apply InT_or_app. left. assumption.
+  apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app. right.
+  apply InT_or_app. right. apply InT_or_app. left. assumption. apply InT_app_or in i.
+  destruct i. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. left.
+  assumption. apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app.
+  left. assumption. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right.
+  assumption.
+- intro. apply InT_app_or in H2. destruct H2. apply InT_or_app. left. assumption.
+  apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app. right.
+  apply InT_or_app. right. apply InT_or_app. left. assumption. apply InT_app_or in i.
+  destruct i. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. left.
+  assumption. apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app.
+  left. assumption. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right.
+  assumption.
+Qed.
+ +
+Lemma InT_list_exch_L : forall l0 l1 l2,
+            (@list_exch_L (l1,l0) (l2,l0)) ->
+            (forall x, (InT x l1 -> InT x l2) * (InT x l2 -> InT x l1)).
+Proof.
+intros l0 l1 l2 exch. inversion exch.
+intro x. split.
+- intro. apply InT_app_or in H2. destruct H2. apply InT_or_app. left. assumption.
+  apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app. right.
+  apply InT_or_app. right. apply InT_or_app. left. assumption. apply InT_app_or in i.
+  destruct i. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. left.
+  assumption. apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app.
+  left. assumption. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right.
+  assumption.
+- intro. apply InT_app_or in H2. destruct H2. apply InT_or_app. left. assumption.
+  apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app. right.
+  apply InT_or_app. right. apply InT_or_app. left. assumption. apply InT_app_or in i.
+  destruct i. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. left.
+  assumption. apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app.
+  left. assumption. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right.
+  assumption.
+Qed.
+ +
+(* Some useful lemmas about list exchange. *)
+ +
+Lemma list_exch_R_id : forall s, (@list_exch_R s s).
+Proof.
+intros s. destruct s. pose (list_exch_RI l l0
+[] [] [] []). simpl in l1. assert (H: l0 ++ [] = l0).
+apply app_nil_r. rewrite H in l1. assumption.
+Qed.
+ +
+Lemma list_exch_L_id : forall s, (@list_exch_L s s).
+Proof.
+intros s. destruct s. pose (list_exch_LI l
+[] [] [] [] l0). simpl in l1. assert (H: l ++ [] = l).
+apply app_nil_r. rewrite H in l1. assumption.
+Qed.
+ +
+Lemma list_exch_R_same_L: forall s se,
+    (@list_exch_R s se) ->
+    (forall Γ Γe Δ Δe, (s = (Γ , Δ)) ->
+    (se = (Γe , Δe)) ->
+    (Γ = Γe)).
+Proof.
+intros s se exch. induction exch. intros Γ0 Γe Δ Δe E1 E2.
+inversion E1. inversion E2. rewrite H0 in H2. assumption.
+Qed.
+ +
+Lemma list_exch_L_same_R : forall s se,
+    (@list_exch_L s se) ->
+    (forall Γ Γe Δ Δe, (s = (Γ , Δ)) ->
+    (se = (Γe , Δe)) ->
+    (Δ = Δe)).
+Proof.
+intros s se exch. induction exch. intros Γ Γe Δ0 Δe E1 E2.
+inversion E1. inversion E2. rewrite H1 in H3. assumption.
+Qed.
+ +
+Lemma list_exch_R_permL : forall s se,
+    (@list_exch_R s se) ->
+      (forall Γ0 Γ1 Δ C, s = ((Γ0 ++ C :: Γ1), Δ) ->
+      (existsT2 , se = ((Γ0 ++ C :: Γ1), ))).
+Proof.
+intros s se exch. induction exch. intros Γ0 Γ1 Δ C E.
+inversion E. exists (Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4). reflexivity.
+Qed.
+ +
+Lemma list_exch_R_permR : forall s se,
+    (@list_exch_R s se) ->
+      (forall Γ Δ0 Δ1 C, s = (Γ, (Δ0 ++ C :: Δ1)) ->
+      (existsT2 eΔ0 eΔ1, se = (Γ, (eΔ0 ++ C :: eΔ1)))).
+Proof.
+intros s se exch. induction exch. intros Γ0 Δ5 Δ6 C E.
+inversion E. apply partition_1_element in H1. destruct H1.
++ destruct s. destruct s. rewrite e. exists x. exists (x0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4).
+  simpl.
+  assert (E1: (x ++ C :: x0) ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4 = x ++ C :: x0 ++ Δ3 ++ Δ2 ++ Δ1 ++ Δ4).
+  { symmetry. apply app_assoc with (l:=x) (m:=C :: x0) (n:=Δ3 ++ Δ2 ++ Δ1 ++ Δ4). }
+  rewrite E1. reflexivity.
++ destruct s.
+  * destruct s. destruct s. exists (Δ0 ++ Δ3 ++ Δ2 ++ x). exists (x0 ++ Δ4).
+    rewrite e. assert (E1: Δ0 ++ Δ3 ++ Δ2 ++ (x ++ C :: x0) ++ Δ4 =
+    (Δ0 ++ Δ3 ++ Δ2 ++ x) ++ C :: x0 ++ Δ4).
+    pose (app_assoc x (C :: x0) Δ4). rewrite <- e0. simpl.
+    pose (app_assoc (Δ0 ++ Δ3 ++ Δ2) x (C :: x0 ++ Δ4)).
+    pose (app_assoc (Δ0 ++ Δ3) Δ2 x).
+    pose (app_assoc Δ0 Δ3 Δ2).
+    rewrite <- e3 in e2. rewrite <- e2 in e1.
+    pose (app_assoc Δ0 Δ3 (Δ2 ++ x)). rewrite <- e4 in e1. rewrite <- e1.
+    pose (app_assoc (Δ0 ++ Δ3) Δ2 (x ++ C :: x0 ++ Δ4)).
+    rewrite <- e3 in e5. rewrite <- e5.
+    pose (app_assoc Δ0 Δ3 (Δ2 ++ x ++ C :: x0 ++ Δ4)). rewrite e6. reflexivity.
+    rewrite E1. reflexivity.
+  * destruct s.
+    - destruct s. destruct s. exists (Δ0 ++ Δ3 ++ x). exists (x0 ++ Δ1 ++ Δ4).
+      rewrite e. assert (E1: Δ0 ++ Δ3 ++ (x ++ C :: x0) ++ Δ1 ++ Δ4 =
+      (Δ0 ++ Δ3 ++ x) ++ C :: x0 ++ Δ1 ++ Δ4).
+      pose (app_assoc x (C :: x0) (Δ1 ++ Δ4)). rewrite <- e0. simpl.
+      pose (app_assoc (Δ0 ++ Δ3) x (C :: x0 ++ Δ1 ++ Δ4)).
+      pose (app_assoc Δ0 Δ3 x). rewrite <- e2 in e1. rewrite <- e1.
+      pose (app_assoc Δ0 Δ3 (x ++ C :: x0 ++ Δ1 ++ Δ4)). rewrite <- e3.
+      reflexivity. rewrite E1. reflexivity.
+    - destruct s.
+      { destruct s. destruct s. rewrite e. exists (Δ0 ++ x). exists (x0 ++ Δ2 ++ Δ1 ++ Δ4).
+        assert (E1: Δ0 ++ (x ++ C :: x0) ++ Δ2 ++ Δ1 ++ Δ4 =
+        (Δ0 ++ x) ++ C :: x0 ++ Δ2 ++ Δ1 ++ Δ4).
+        pose (app_assoc x (C :: x0) (Δ2 ++ Δ1 ++ Δ4)). rewrite <- e0. simpl.
+        pose (app_assoc Δ0 x (C :: x0 ++ Δ2 ++ Δ1 ++ Δ4)). rewrite e1.
+        reflexivity. rewrite E1. reflexivity. }
+      { destruct s. destruct s. rewrite e. exists (Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ x).
+        exists x0. assert (E1: Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ x ++ C :: x0 =
+        (Δ0 ++ Δ3 ++ Δ2 ++ Δ1 ++ x) ++ C :: x0).
+        pose (app_assoc (Δ0 ++ Δ3 ++ Δ2 ++ Δ1) x (C :: x0)).
+        pose (app_assoc (Δ0 ++ Δ3 ++ Δ2) Δ1 x).
+        pose (app_assoc (Δ0 ++ Δ3) Δ2 Δ1).
+        pose (app_assoc Δ0 Δ3 Δ2). rewrite <- e3 in e2. rewrite <- e2 in e1.
+        pose (app_assoc Δ0 Δ3 (Δ2 ++ Δ1)). rewrite <- e4 in e1. rewrite <- e1 in e0.
+        pose (app_assoc (Δ0 ++ Δ3) Δ2 (Δ1 ++ x)). rewrite <- e3 in e5.
+        rewrite <- e5 in e0.
+        pose (app_assoc Δ0 Δ3 (Δ2 ++ Δ1 ++ x)). rewrite <- e6 in e0.
+        rewrite <- e0.
+        pose (app_assoc (Δ0 ++ Δ3 ++ Δ2) Δ1 (x ++ C :: x0)).
+        rewrite <- e2 in e7. rewrite <- e4 in e7. rewrite <- e7.
+        pose (app_assoc (Δ0 ++ Δ3) Δ2 (Δ1 ++ x ++ C :: x0)).
+        rewrite <- e3 in e8. rewrite <- e8.
+        pose (app_assoc Δ0 Δ3 (Δ2 ++ Δ1 ++ x ++ C :: x0)).
+        rewrite e9. reflexivity. rewrite E1. reflexivity. }
+Qed.
+ +
+Lemma list_exch_R_permLR : forall s se,
+    (@list_exch_R s se) ->
+      (forall Γ0 Γ1 Δ0 Δ1 C D, s = ((Γ0 ++ C :: Γ1), (Δ0 ++ D :: Δ1)) ->
+      (existsT2 eΔ0 eΔ1, se = ((Γ0 ++ C :: Γ1), (eΔ0 ++ D :: eΔ1)))).
+Proof.
+intros s se exch. intros Γ0 Γ1 Δ0 Δ1 C D Eq.
+pose (list_exch_R_permL _ _ exch). pose (s0 Γ0 Γ1 (Δ0 ++ D :: Δ1) C).
+pose (s1 Eq). destruct s2.
+pose (list_exch_R_permR _ _ exch). pose (s2 (Γ0 ++ C :: Γ1) Δ0 Δ1 D).
+pose (s3 Eq). destruct s4. destruct s4. exists x0. exists x1. assumption.
+Qed.
+ +
+Lemma list_exch_L_permL : forall s se,
+    (@list_exch_L s se) ->
+      (forall Γ0 Γ1 Δ C, s = ((Γ0 ++ C :: Γ1), Δ) ->
+      (existsT2 eΓ0 eΓ1, se = ((eΓ0 ++ C :: eΓ1), Δ))).
+Proof.
+intros s se exch. induction exch. intros Γ5 Γ6 Δ0 C E.
+inversion E. apply partition_1_element in H0. destruct H0.
++ destruct s. destruct s. rewrite e. exists x. exists (x0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4).
+  simpl.
+  assert (E1: (x ++ C :: x0) ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4 = x ++ C :: x0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4).
+  { symmetry. apply app_assoc with (l:=x) (m:=C :: x0) (n:=Γ3 ++ Γ2 ++ Γ1 ++ Γ4). }
+  rewrite E1. reflexivity.
++ destruct s.
+  * destruct s. destruct s. exists (Γ0 ++ Γ3 ++ Γ2 ++ x). exists (x0 ++ Γ4).
+    rewrite e. assert (E1: Γ0 ++ Γ3 ++ Γ2 ++ (x ++ C :: x0) ++ Γ4 =
+    (Γ0 ++ Γ3 ++ Γ2 ++ x) ++ C :: x0 ++ Γ4).
+    pose (app_assoc x (C :: x0) Γ4). rewrite <- e0. simpl.
+    pose (app_assoc (Γ0 ++ Γ3 ++ Γ2) x (C :: x0 ++ Γ4)).
+    pose (app_assoc (Γ0 ++ Γ3) Γ2 x).
+    pose (app_assoc Γ0 Γ3 Γ2).
+    rewrite <- e3 in e2. rewrite <- e2 in e1.
+    pose (app_assoc Γ0 Γ3 (Γ2 ++ x)). rewrite <- e4 in e1. rewrite <- e1.
+    pose (app_assoc (Γ0 ++ Γ3) Γ2 (x ++ C :: x0 ++ Γ4)).
+    rewrite <- e3 in e5. rewrite <- e5.
+    pose (app_assoc Γ0 Γ3 (Γ2 ++ x ++ C :: x0 ++ Γ4)). rewrite e6. reflexivity.
+    rewrite E1. reflexivity.
+  * destruct s.
+    - destruct s. destruct s. exists (Γ0 ++ Γ3 ++ x). exists (x0 ++ Γ1 ++ Γ4).
+      rewrite e. assert (E1: Γ0 ++ Γ3 ++ (x ++ C :: x0) ++ Γ1 ++ Γ4 =
+      (Γ0 ++ Γ3 ++ x) ++ C :: x0 ++ Γ1 ++ Γ4).
+      pose (app_assoc x (C :: x0) (Γ1 ++ Γ4)). rewrite <- e0. simpl.
+      pose (app_assoc (Γ0 ++ Γ3) x (C :: x0 ++ Γ1 ++ Γ4)).
+      pose (app_assoc Γ0 Γ3 x). rewrite <- e2 in e1. rewrite <- e1.
+      pose (app_assoc Γ0 Γ3 (x ++ C :: x0 ++ Γ1 ++ Γ4)). rewrite <- e3.
+      reflexivity. rewrite E1. reflexivity.
+    - destruct s.
+      { destruct s. destruct s. rewrite e. exists (Γ0 ++ x). exists (x0 ++ Γ2 ++ Γ1 ++ Γ4).
+        assert (E1: Γ0 ++ (x ++ C :: x0) ++ Γ2 ++ Γ1 ++ Γ4 =
+        (Γ0 ++ x) ++ C :: x0 ++ Γ2 ++ Γ1 ++ Γ4).
+        pose (app_assoc x (C :: x0) (Γ2 ++ Γ1 ++ Γ4)). rewrite <- e0. simpl.
+        pose (app_assoc Γ0 x (C :: x0 ++ Γ2 ++ Γ1 ++ Γ4)). rewrite e1.
+        reflexivity. rewrite E1. reflexivity. }
+      { destruct s. destruct s. rewrite e. exists (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ x).
+        exists x0. assert (E1: Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ x ++ C :: x0 =
+        (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ x) ++ C :: x0).
+        pose (app_assoc (Γ0 ++ Γ3 ++ Γ2 ++ Γ1) x (C :: x0)).
+        pose (app_assoc (Γ0 ++ Γ3 ++ Γ2) Γ1 x).
+        pose (app_assoc (Γ0 ++ Γ3) Γ2 Γ1).
+        pose (app_assoc Γ0 Γ3 Γ2). rewrite <- e3 in e2. rewrite <- e2 in e1.
+        pose (app_assoc Γ0 Γ3 (Γ2 ++ Γ1)). rewrite <- e4 in e1. rewrite <- e1 in e0.
+        pose (app_assoc (Γ0 ++ Γ3) Γ2 (Γ1 ++ x)). rewrite <- e3 in e5.
+        rewrite <- e5 in e0.
+        pose (app_assoc Γ0 Γ3 (Γ2 ++ Γ1 ++ x)). rewrite <- e6 in e0.
+        rewrite <- e0.
+        pose (app_assoc (Γ0 ++ Γ3 ++ Γ2) Γ1 (x ++ C :: x0)).
+        rewrite <- e2 in e7. rewrite <- e4 in e7. rewrite <- e7.
+        pose (app_assoc (Γ0 ++ Γ3) Γ2 (Γ1 ++ x ++ C :: x0)).
+        rewrite <- e3 in e8. rewrite <- e8.
+        pose (app_assoc Γ0 Γ3 (Γ2 ++ Γ1 ++ x ++ C :: x0)).
+        rewrite e9. reflexivity. rewrite E1. reflexivity. }
+Qed.
+ +
+Lemma list_exch_L_permR : forall s se,
+    (@list_exch_L s se) ->
+      (forall Γ Δ0 Δ1 C, s = (Γ, (Δ0 ++ C :: Δ1)) ->
+      (existsT2 , se = (, (Δ0 ++ C :: Δ1)))).
+Proof.
+intros s se exch. induction exch. intros Γ Δ0 Δ1 C E.
+inversion E. exists (Γ0 ++ Γ3 ++ Γ2 ++ Γ1 ++ Γ4). reflexivity.
+Qed.
+ +
+Lemma list_exch_L_permLR : forall s se,
+    (@list_exch_L s se) ->
+      (forall Γ0 Γ1 Δ0 Δ1 C D, s = ((Γ0 ++ C :: Γ1), (Δ0 ++ D :: Δ1)) ->
+      (existsT2 eΓ0 eΓ1, se = ((eΓ0 ++ C :: eΓ1), (Δ0 ++ D :: Δ1)))).
+Proof.
+intros s se exch. intros Γ0 Γ1 Δ0 Δ1 C D Eq.
+pose (list_exch_L_permR _ _ exch). pose (s0 (Γ0 ++ C :: Γ1) Δ0 Δ1 D).
+pose (s1 Eq). destruct s2.
+pose (list_exch_L_permL _ _ exch). pose (s2 Γ0 Γ1 (Δ0 ++ D :: Δ1) C).
+pose (s3 Eq). destruct s4. destruct s4. exists x0. exists x1. assumption.
+Qed.
+ +
+(* Some lemmas about nobox_gen_ext and exchange. *)
+ +
+Lemma nobox_gen_ext_exch_R : forall Γ Γ' l0 l1 l2,
+    (nobox_gen_ext l0 l1) -> (@list_exch_R (Γ,l1) (Γ,l2)) ->
+    existsT2 l3, (nobox_gen_ext l3 l2) * (list_exch_R (Γ',l0) (Γ',l3)).
+Proof.
+intros Γ Γ' l0. induction l0.
++ intros l1 l2 gen. remember [] as l0. destruct gen.
+  - intro exch. inversion exch. apply app_eq_nil in H1. destruct H1. apply app_eq_nil in H2. destruct H2.
+    apply app_eq_nil in H3. destruct H3. apply app_eq_nil in H4. destruct H4.
+    subst. simpl. exists []. split.
+    * apply univ_gen_ext_nil.
+    * apply list_exch_R_id.
+  - intros exch. exists []. split.
+    * inversion Heql0.
+    * inversion Heql0.
+  - intro exch. subst. exists []. split. apply all_P_univ_gen_ext_nil.
+    intros. pose (InT_list_exch_R _ _ _ exch). pose (p x0). destruct p0. pose (univ_gen_ext_nil_all_P gen).
+    pose (f0 x0). apply i0 in H. inversion H. subst. apply f. assumption. subst. apply f1 in H1.
+    assumption. assumption.
+    apply list_exch_R_id.
++ intros l1 l2 gen. induction gen.
+  - intro exch. inversion exch. destruct Δ0.
+    * rewrite app_nil_l in H. rewrite app_nil_l in H1. rewrite app_nil_l. destruct Δ1.
+      { rewrite app_nil_l in H1. destruct Δ2.
+        + rewrite app_nil_l in H1. destruct Δ3.
+          - rewrite app_nil_l in H1. repeat rewrite app_nil_l in H. destruct Δ4.
+            * simpl. exists []. split. apply univ_gen_ext_nil. apply list_exch_R_id.
+            * inversion H1.
+          - inversion H1.
+        + inversion H1. }
+      { inversion H1. }
+    * inversion H1.
+  - intro exch. inversion exch. destruct Δ0.
+    * rewrite app_nil_l in H. rewrite app_nil_l in H1. rewrite app_nil_l. destruct Δ1.
+      { rewrite app_nil_l in H1. destruct Δ2.
+        + rewrite app_nil_l in H1. destruct Δ3.
+          - rewrite app_nil_l in H1. repeat rewrite app_nil_l in H. destruct Δ4.
+            * inversion H1.
+            * inversion H1. simpl. subst. exists (x :: l).
+              split. apply univ_gen_ext_cons. assumption. apply list_exch_R_id.
+          - repeat rewrite app_nil_l in H. repeat rewrite app_nil_l. simpl. simpl in H. simpl in H1.
+            inversion H1. subst. exists (x :: l). split. apply univ_gen_ext_cons. assumption. apply list_exch_R_id.
+        + rewrite app_nil_l. rewrite app_nil_l in H. inversion H1. subst.
+          pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p.
+          pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p. subst.
+          exists (x2 ++ x :: x0 ++ x3). split.
+          - apply univ_gen_ext_cons with (x:=x) in u. pose (univ_gen_ext_combine u u2).
+            pose (univ_gen_ext_combine u1 u3). assumption.
+          - pose (list_exch_RI Γ' [] [] (x :: x0) x2 x3). repeat rewrite app_nil_l in l. assumption. }
+      { inversion H1. subst. pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p.
+        pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u2).
+        repeat destruct s. repeat destruct p. subst. exists (x4 ++ x2 ++ (x :: x0) ++ x5).
+        split.
+        - apply univ_gen_ext_cons with (x:=x) in u. pose (univ_gen_ext_combine u u4).
+          pose (univ_gen_ext_combine u1 u5). pose (univ_gen_ext_combine u3 u6). assumption.
+        - pose (list_exch_RI Γ' [] (x :: x0) x2 x4 x5). rewrite app_nil_l in l. assumption. }
+    * inversion H1. subst. pose (univ_gen_ext_splitR _ _ gen).
+      repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u0).
+      repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u2).
+      repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u4).
+      repeat destruct s. repeat destruct p. subst. exists (x :: x0 ++ x6 ++ x4 ++ x2 ++ x7).
+      split.
+      { apply univ_gen_ext_cons with (x:=x) in u. pose (univ_gen_ext_combine u1 u6).
+        pose (univ_gen_ext_combine u3 u7). pose (univ_gen_ext_combine u5 u8).
+        pose (univ_gen_ext_combine u u9). assumption. }
+      { assert (E1: x :: x0 ++ x2 ++ x4 ++ x6 ++ x7 = (x :: x0) ++ x2 ++ x4 ++ x6 ++ x7).
+        reflexivity. rewrite E1.
+        assert (E2: x :: x0 ++ x6 ++ x4 ++ x2 ++ x7 = (x :: x0) ++ x6 ++ x4 ++ x2 ++ x7).
+        reflexivity. rewrite E2. apply list_exch_RI. }
+  - intro exch. inversion exch. destruct Δ0.
+    * rewrite app_nil_l in H. rewrite app_nil_l in H1. rewrite app_nil_l. destruct Δ1.
+      { rewrite app_nil_l in H1. destruct Δ2.
+        + rewrite app_nil_l in H1. destruct Δ3.
+          - rewrite app_nil_l in H1. repeat rewrite app_nil_l in H. destruct Δ4.
+            * inversion H1.
+            * inversion H1. simpl. subst. exists l.
+              split. apply univ_gen_ext_extra. assumption. assumption. apply list_exch_R_id.
+          - repeat rewrite app_nil_l in H. repeat rewrite app_nil_l. simpl. simpl in H. simpl in H1.
+            inversion H1. subst. exists l. split. apply univ_gen_ext_extra. assumption. assumption. apply list_exch_R_id.
+        + rewrite app_nil_l. rewrite app_nil_l in H. inversion H1. subst.
+          pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p0.
+          pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p0. subst.
+          exists (x2 ++ x0 ++ x3). split.
+          - apply univ_gen_ext_extra with (x:=x) in u. pose (univ_gen_ext_combine u u2).
+            pose (univ_gen_ext_combine u1 u3). assumption. assumption.
+          - pose (list_exch_RI Γ' [] [] x0 x2 x3). repeat rewrite app_nil_l in l. assumption. }
+      { inversion H1. subst. pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p0.
+        pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u2).
+        repeat destruct s. repeat destruct p0. subst. exists (x4 ++ x2 ++ x0 ++ x5).
+        split.
+        - apply univ_gen_ext_extra with (x:=x) in u. pose (univ_gen_ext_combine u u4).
+          pose (univ_gen_ext_combine u1 u5). pose (univ_gen_ext_combine u3 u6). assumption. assumption.
+        - pose (list_exch_RI Γ' [] x0 x2 x4 x5). rewrite app_nil_l in l. assumption. }
+    * inversion H1. subst. pose (univ_gen_ext_splitR _ _ gen).
+      repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u0).
+      repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u2).
+      repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u4).
+      repeat destruct s. repeat destruct p0. subst. exists (x0 ++ x6 ++ x4 ++ x2 ++ x7).
+      split.
+      { apply univ_gen_ext_extra with (x:=x) in u. pose (univ_gen_ext_combine u1 u6).
+        pose (univ_gen_ext_combine u3 u7). pose (univ_gen_ext_combine u5 u8).
+        pose (univ_gen_ext_combine u u9). assumption. assumption. }
+      { apply list_exch_RI. }
+Qed.
+ +
+Lemma nobox_gen_ext_exch_L : forall Δ Δ' l0 l1 l2,
+    (nobox_gen_ext l0 l1) -> (@list_exch_L (l1,Δ) (l2,Δ)) ->
+    existsT2 l3, (nobox_gen_ext l3 l2) * (list_exch_L (l0,Δ') (l3,Δ')).
+Proof.
+intros Δ Δ' l0. induction l0.
++ intros l1 l2 gen. inversion gen.
+  - intro exch. inversion exch. apply app_eq_nil in H1. destruct H1. apply app_eq_nil in H3. destruct H3.
+    apply app_eq_nil in H4. destruct H4. apply app_eq_nil in H5. destruct H5.
+    subst. simpl. exists []. split.
+    * apply univ_gen_ext_nil.
+    * apply list_exch_L_id.
+  - intros exch. exists []. split.
+    * subst. apply all_P_univ_gen_ext_nil. intros. pose (InT_list_exch_L _ _ _ exch).
+      pose (p x0). destruct p0. apply i0 in H0. inversion H0. subst. apply H.
+      assumption. subst. pose (univ_gen_ext_nil_all_P gen). apply f in H0.
+      assumption. assumption.
+    * apply list_exch_L_id.
++ intros l1 l2 gen. induction gen.
+  - intro exch. inversion exch. destruct Γ0.
+    * rewrite app_nil_l in H0. rewrite app_nil_l in H. rewrite app_nil_l. destruct Γ1.
+      { rewrite app_nil_l in H0. destruct Γ2.
+        + rewrite app_nil_l in H0. destruct Γ3.
+          - rewrite app_nil_l in H0. repeat rewrite app_nil_l in H. destruct Γ4.
+            * simpl. exists []. split. apply univ_gen_ext_nil. apply list_exch_L_id.
+            * inversion H0.
+          - inversion H0.
+        + inversion H0. }
+      { inversion H0. }
+    * inversion H0.
+  - intro exch. inversion exch. destruct Γ0.
+    * rewrite app_nil_l in H. rewrite app_nil_l in H0. rewrite app_nil_l. destruct Γ1.
+      { rewrite app_nil_l in H0. destruct Γ2.
+        + rewrite app_nil_l in H0. destruct Γ3.
+          - rewrite app_nil_l in H0. repeat rewrite app_nil_l in H. destruct Γ4.
+            * inversion H0.
+            * inversion H0. simpl. subst. exists (x :: l).
+              split. apply univ_gen_ext_cons. assumption. apply list_exch_L_id.
+          - repeat rewrite app_nil_l in H. repeat rewrite app_nil_l. simpl. simpl in H. simpl in H0.
+            inversion H0. subst. exists (x :: l). split. apply univ_gen_ext_cons. assumption. apply list_exch_L_id.
+        + rewrite app_nil_l. rewrite app_nil_l in H. inversion H0. subst.
+          pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p.
+          pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p. subst.
+          exists (x2 ++ x :: x0 ++ x3). split.
+          - apply univ_gen_ext_cons with (x:=x) in u. pose (univ_gen_ext_combine u u2).
+            pose (univ_gen_ext_combine u1 u3). assumption.
+          - pose (list_exch_LI [] [] (x :: x0) x2 x3 Δ'). repeat rewrite app_nil_l in l. assumption. }
+      { inversion H0. subst. pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p.
+        pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u2).
+        repeat destruct s. repeat destruct p. subst. exists (x4 ++ x2 ++ (x :: x0) ++ x5).
+        split.
+        - apply univ_gen_ext_cons with (x:=x) in u. pose (univ_gen_ext_combine u u4).
+          pose (univ_gen_ext_combine u1 u5). pose (univ_gen_ext_combine u3 u6). assumption.
+        - pose (list_exch_LI [] (x :: x0) x2 x4 x5 Δ'). rewrite app_nil_l in l. assumption. }
+    * inversion H0. subst. pose (univ_gen_ext_splitR _ _ gen).
+      repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u0).
+      repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u2).
+      repeat destruct s. repeat destruct p. pose (univ_gen_ext_splitR _ _ u4).
+      repeat destruct s. repeat destruct p. subst. exists (x :: x0 ++ x6 ++ x4 ++ x2 ++ x7).
+      split.
+      { apply univ_gen_ext_cons with (x:=x) in u. pose (univ_gen_ext_combine u1 u6).
+        pose (univ_gen_ext_combine u3 u7). pose (univ_gen_ext_combine u5 u8).
+        pose (univ_gen_ext_combine u u9). assumption. }
+      { assert (E1: x :: x0 ++ x2 ++ x4 ++ x6 ++ x7 = (x :: x0) ++ x2 ++ x4 ++ x6 ++ x7).
+        reflexivity. rewrite E1.
+        assert (E2: x :: x0 ++ x6 ++ x4 ++ x2 ++ x7 = (x :: x0) ++ x6 ++ x4 ++ x2 ++ x7).
+        reflexivity. rewrite E2. apply list_exch_LI. }
+  - intro exch. inversion exch. destruct Γ0.
+    * rewrite app_nil_l in H. rewrite app_nil_l in H0. rewrite app_nil_l. destruct Γ1.
+      { rewrite app_nil_l in H0. destruct Γ2.
+        + rewrite app_nil_l in H0. destruct Γ3.
+          - rewrite app_nil_l in H0. repeat rewrite app_nil_l in H. destruct Γ4.
+            * inversion H0.
+            * inversion H0. simpl. subst. exists l.
+              split. apply univ_gen_ext_extra. assumption. assumption. apply list_exch_L_id.
+          - repeat rewrite app_nil_l in H. repeat rewrite app_nil_l. simpl. simpl in H. simpl in H0.
+            inversion H0. subst. exists l. split. apply univ_gen_ext_extra. assumption. assumption. apply list_exch_L_id.
+        + rewrite app_nil_l. rewrite app_nil_l in H. inversion H0. subst.
+          pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p0.
+          pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p0. subst.
+          exists (x2 ++ x0 ++ x3). split.
+          - apply univ_gen_ext_extra with (x:=x) in u. pose (univ_gen_ext_combine u u2).
+            pose (univ_gen_ext_combine u1 u3). assumption. assumption.
+          - pose (list_exch_LI [] [] x0 x2 x3 Δ'). repeat rewrite app_nil_l in l. assumption. }
+      { inversion H0. subst. pose (univ_gen_ext_splitR _ _ gen). repeat destruct s. repeat destruct p0.
+        pose (univ_gen_ext_splitR _ _ u0). repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u2).
+        repeat destruct s. repeat destruct p0. subst. exists (x4 ++ x2 ++ x0 ++ x5).
+        split.
+        - apply univ_gen_ext_extra with (x:=x) in u. pose (univ_gen_ext_combine u u4).
+          pose (univ_gen_ext_combine u1 u5). pose (univ_gen_ext_combine u3 u6). assumption. assumption.
+        - pose (list_exch_LI [] x0 x2 x4 x5 Δ'). rewrite app_nil_l in l. assumption. }
+    * inversion H0. subst. pose (univ_gen_ext_splitR _ _ gen).
+      repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u0).
+      repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u2).
+      repeat destruct s. repeat destruct p0. pose (univ_gen_ext_splitR _ _ u4).
+      repeat destruct s. repeat destruct p0. subst. exists (x0 ++ x6 ++ x4 ++ x2 ++ x7).
+      split.
+      { apply univ_gen_ext_extra with (x:=x) in u. pose (univ_gen_ext_combine u1 u6).
+        pose (univ_gen_ext_combine u3 u7). pose (univ_gen_ext_combine u5 u8).
+        pose (univ_gen_ext_combine u u9). assumption. assumption. }
+      { apply list_exch_LI. }
+Qed.
+
+
+ +
+ + + diff --git a/K.KS.KS_export.html b/K.KS.KS_export.html new file mode 100644 index 0000000..41349f6 --- /dev/null +++ b/K.KS.KS_export.html @@ -0,0 +1,50 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_export

+ +
+Require Export KS_calc.
+Require Export KS_dec.
+Require Export KS_exch.
+Require Export KS_ctr.
+Require Export KS_wkn.
+Require Export KS_inv_ImpR_ImpL.
+Require Export KS_termination_measure.
+Require Export KS_termination.
+Require Export KS_additive_cut.
+Require Export KS_cut_elim.
+
+
+ +
+ + + diff --git a/K.KS.KS_inv_ImpR_ImpL.html b/K.KS.KS_inv_ImpR_ImpL.html new file mode 100644 index 0000000..3ff2cb1 --- /dev/null +++ b/K.KS.KS_inv_ImpR_ImpL.html @@ -0,0 +1,734 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_inv_ImpR_ImpL

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat Arith.
+ +
+Require Import KS_calc.
+Require Import KS_exch.
+Require Import KS_wkn.
+Require Import KS_dec.
+ +
+Lemma remove_rest_gen_ext : forall l A, rest_gen_ext [A] (remove eq_dec_form A l) l.
+Proof.
+induction l ; intros.
+- simpl. apply univ_gen_ext_nil.
+- simpl. destruct (eq_dec_form A a).
+  * subst. apply univ_gen_ext_extra. apply InT_eq. apply IHl.
+  * apply univ_gen_ext_cons. apply IHl.
+Qed.
+ +
+Theorem derrec_height_False_ge_1 : forall s, forall (D : KS_prv s), 1 <= derrec_height D.
+Proof.
+intros s D.
+induction D.
+- destruct p.
+- simpl. lia.
+Qed.
+ +
+Lemma rest_nobox_gen_ext_trans : forall (A B : MPropF) l0 l1 l2, ((In (Imp A B) l0) -> False) ->
+                                                    (nobox_gen_ext l0 l1) ->
+                                                    (rest_gen_ext [Imp A B] l2 l1) ->
+                                                    (nobox_gen_ext l0 l2).
+Proof.
+intros A B l0 l1 l2 H1 H2. generalize dependent l2.
+induction H2.
+- intros. inversion X. apply univ_gen_ext_nil.
+- intros. inversion X.
+  * subst. apply univ_gen_ext_cons. apply IHuniv_gen_ext. intro. apply H1.
+    apply in_cons. assumption. assumption.
+  * subst. inversion H3. subst. exfalso. apply H1. apply in_eq.
+    inversion H0.
+- intros. inversion X.
+  * subst. apply univ_gen_ext_extra. assumption. apply IHuniv_gen_ext ; assumption.
+  * subst. apply IHuniv_gen_ext ; assumption.
+Qed.
+ +
+(* We prove the height-preserving invertibility of ImpR and ImpL below. *)
+ +
+Theorem ImpR_ImpL_hpinv : forall (k : nat) concl
+        (D0 : KS_prv concl),
+        k = (derrec_height D0) ->
+          ((forall prem, ((ImpRRule [prem] concl) ->
+          existsT2 (D1 : KS_prv prem),
+          derrec_height D1 <= k))) *
+          ((forall prem1 prem2, ((ImpLRule [prem1; prem2] concl) ->
+          existsT2 (D1 : KS_prv prem1)
+                   (D2 : KS_prv prem2),
+          (derrec_height D1 <= k) * (derrec_height D2 <= k)))).
+Proof.
+assert (DersNilF: dersrec (KS_rules) (fun _ : Seq => False) []).
+apply dersrec_nil.
+induction k as [n IH] using (well_founded_induction_type lt_wf).
+intros s D0. remember D0 as D0'. destruct D0.
+(* D0 is a leaf *)
+- destruct f.
+(* D0 is ends with an application of rule *)
+- intros hei. split.
+{ intros prem RA. inversion RA. subst.
+  inversion k ; subst.
+  (* IdP *)
+  * inversion H. subst. assert (InT # P (Γ0 ++ Γ1)).
+    rewrite <- H2. apply InT_or_app. right. apply InT_eq. assert (InT # P (Γ0 ++ A :: Γ1)).
+    apply InT_app_or in H0. destruct H0. apply InT_or_app. auto. apply InT_or_app. right.
+    apply InT_cons. assumption. apply InT_split in H1. destruct H1. destruct s. rewrite e.
+    assert (InT # P (Δ0 ++ B :: Δ1)). assert (InT # P (Δ2 ++ # P :: Δ3)).
+    apply InT_or_app. right. apply InT_eq. rewrite H3 in H1. apply InT_app_or in H1.
+    destruct H1. apply InT_or_app. auto. inversion i. inversion H4. apply InT_or_app. right.
+    apply InT_cons. assumption. apply InT_split in H1. destruct H1. destruct s.
+    rewrite e0. assert (IdPRule [] (x ++ # P :: x0, x1 ++ # P :: x2)).
+    apply IdPRule_I. apply IdP in H1.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x ++ # P :: x0, x1 ++ # P :: x2) H1 DersNilF). exists d0.
+    simpl. rewrite dersrec_height_nil. lia. reflexivity.
+  (* BotL *)
+  * inversion H. subst. assert (InT (Bot) (Γ0 ++ Γ1)).
+    rewrite <- H2. apply InT_or_app. right. apply InT_eq. assert (InT (Bot) (Γ0 ++ A :: Γ1)).
+    apply InT_app_or in H0. destruct H0. apply InT_or_app. auto. apply InT_or_app. right.
+    apply InT_cons. assumption. apply InT_split in H1. destruct H1. destruct s. rewrite e.
+    assert (BotLRule [] (x ++ Bot :: x0, Δ0 ++ B :: Δ1)).
+    apply BotLRule_I. apply BotL in H1.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x ++ Bot :: x0, Δ0 ++ B :: Δ1) H1 DersNilF). exists d0.
+    simpl. rewrite dersrec_height_nil. lia. reflexivity.
+  (* ImpR *)
+  * inversion H. subst. apply app2_find_hole in H3. destruct H3. repeat destruct s ; destruct p ; subst.
+    + inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+      pose (@dersrec_derrec_height (dersrec_height d) _ _ _ _ d J30). destruct s.
+      assert (J1: list_exch_L (Γ2 ++ A0 :: Γ3, Δ2 ++ B0 :: Δ3) (A0 :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3)).
+      assert (Γ2 ++ A0 :: Γ3 = [] ++ [] ++ Γ2 ++ [A0] ++ Γ3). reflexivity.
+      rewrite H0. clear H0.
+      assert (A0 :: Γ0 ++ Γ1 = [] ++ [A0] ++ Γ2 ++ [] ++ Γ3). simpl. rewrite H2. reflexivity.
+      rewrite H0. clear H0. apply list_exch_LI.
+      assert (J20: derrec_height x0 = derrec_height x0). reflexivity.
+      pose (KS_hpadm_list_exch_L0 _ _ x0 J20 _ J1). destruct s.
+      assert (J2: list_exch_L (A0 :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3) (Γ0 ++ A0 :: Γ1, Δ2 ++ B0 :: Δ3)).
+      assert ((A0 :: Γ0 ++ Γ1, Δ2 ++ B0 :: Δ3) = ([] ++ [A0] ++ Γ0 ++ [] ++ Γ1, Δ2 ++ B0 :: Δ3)).
+      reflexivity. assert ((Γ0 ++ A0 :: Γ1, Δ2 ++ B0 :: Δ3) = ([] ++ [] ++ Γ0 ++ [A0] ++ Γ1, Δ2 ++ B0 :: Δ3)).
+      reflexivity. rewrite H1. rewrite H0. clear H1. clear H0. apply list_exch_LI.
+      assert (J21: derrec_height x1 = derrec_height x1). reflexivity.
+      pose (KS_hpadm_list_exch_L0 _ _ x1 J21 _ J2). destruct s. exists x2.
+      simpl. lia.
+    + destruct x.
+      { simpl in e0. inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec_height (dersrec_height d) _ _ _ _ d J30). destruct s.
+        assert (J1: list_exch_L (Γ2 ++ A :: Γ3, Δ2 ++ B :: Δ1) (A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ1)).
+        assert (Γ2 ++ A :: Γ3 = [] ++ [] ++ Γ2 ++ [A] ++ Γ3). reflexivity.
+        rewrite H0. clear H0.
+        assert (A :: Γ0 ++ Γ1 = [] ++ [A] ++ Γ2 ++ [] ++ Γ3). simpl. rewrite H2. reflexivity.
+        rewrite H0. clear H0. apply list_exch_LI.
+        assert (J20: derrec_height x = derrec_height x). reflexivity.
+        pose (KS_hpadm_list_exch_L0 _ _ x J20 _ J1). destruct s.
+        assert (J2: list_exch_L (A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ1) (Γ0 ++ A :: Γ1, (Δ2 ++ []) ++ B :: Δ1)).
+        assert ((A :: Γ0 ++ Γ1, Δ2 ++ B :: Δ1) = ([] ++ [A] ++ Γ0 ++ [] ++ Γ1, Δ2 ++ B :: Δ1)).
+        reflexivity. assert ((Γ0 ++ A :: Γ1, (Δ2 ++ []) ++ B :: Δ1) = ([] ++ [] ++ Γ0 ++ [A] ++ Γ1, Δ2 ++ B :: Δ1)).
+        rewrite app_nil_r. reflexivity. rewrite H1. rewrite H0. clear H1. clear H0. apply list_exch_LI.
+        assert (J21: derrec_height x0 = derrec_height x0). reflexivity.
+        pose (KS_hpadm_list_exch_L0 _ _ x0 J21 _ J2). destruct s. exists x1.
+        simpl. lia. }
+      { inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec_height (dersrec_height d) _ _ _ _ d J30). destruct s.
+        assert (J1: list_exch_L (Γ2 ++ A0 :: Γ3, Δ2 ++ B0 :: x ++ A --> B :: Δ1) (A0 :: Γ0 ++ Γ1, Δ2 ++ B0 :: x ++ A --> B :: Δ1)).
+        assert (Γ2 ++ A0 :: Γ3 = [] ++ [] ++ Γ2 ++ [A0] ++ Γ3). reflexivity.
+        rewrite H0. clear H0.
+        assert (A0 :: Γ0 ++ Γ1 = [] ++ [A0] ++ Γ2 ++ [] ++ Γ3). simpl. rewrite H2. reflexivity.
+        rewrite H0. clear H0. apply list_exch_LI.
+        assert (J20: derrec_height x0 = derrec_height x0). reflexivity.
+        pose (KS_hpadm_list_exch_L0 _ _ x0 J20 _ J1). destruct s. simpl in IH. simpl.
+        assert (J2: derrec_height x1 < S (dersrec_height d)). lia.
+        assert (J3: derrec_height x1 = derrec_height x1). reflexivity.
+        assert (J4: ImpRRule [(A0 :: Γ0 ++ A :: Γ1, Δ2 ++ B0 :: x ++ B :: Δ1)] (A0 :: Γ0 ++ Γ1, Δ2 ++ B0 :: x ++ A --> B :: Δ1)).
+        assert (A0 :: Γ0 ++ A :: Γ1 = (A0 :: Γ0) ++ A :: Γ1). reflexivity. rewrite H0. clear H0.
+        assert (A0 :: Γ0 ++ Γ1 = (A0 :: Γ0) ++ Γ1). reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ B0 :: x ++ B :: Δ1 = (Δ2 ++ B0 :: x) ++ B :: Δ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Δ2 ++ B0 :: x ++ A --> B :: Δ1 = (Δ2 ++ B0 :: x) ++ A --> B :: Δ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ImpRRule_I.
+        pose (IH _ J2 _ _ J3). destruct p. pose (s _ J4). clear s0. destruct s1. clear s.
+        assert (existsT2 (x3 : derrec KS_rules (fun _ : Seq => False)
+        (Γ0 ++ A :: Γ1, (Δ2 ++ A0 --> B0 :: x) ++ B :: Δ1)), derrec_height x3 <= S (dersrec_height d)).
+        assert (ImpRRule [(A0 :: Γ0 ++ A :: Γ1, Δ2 ++ B0 :: x ++ B :: Δ1)] (Γ0 ++ A :: Γ1, (Δ2 ++ A0 --> B0 :: x) ++ B :: Δ1)).
+        assert (A0 :: Γ0 ++ A :: Γ1 = [] ++ A0 :: Γ0 ++ A :: Γ1). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ A :: Γ1 = [] ++ Γ0 ++ A :: Γ1). reflexivity. rewrite H0. clear H0. repeat rewrite <- app_assoc.
+        apply ImpRRule_I. apply ImpR in H0 ; try intro ; try apply f0 ; try auto ; try assumption.
+        pose (dlCons x2 DersNilF).
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(A0 :: Γ0 ++ A :: Γ1, Δ2 ++ B0 :: x ++ B :: Δ1)]) (Γ0 ++ A :: Γ1, (Δ2 ++ A0 --> B0 :: x) ++ B :: Δ1) H0 d0).
+        exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+        destruct X. exists x3. lia. }
+    + destruct x.
+      { simpl in e0. inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec_height (dersrec_height d) _ _ _ _ d J30). destruct s.
+        assert (J1: list_exch_L (Γ2 ++ A0 :: Γ3, (Δ0 ++ []) ++ B0 :: Δ3) (A0 :: Γ0 ++ Γ1, Δ0 ++ B0 :: Δ3)).
+        rewrite app_nil_r.
+        assert (Γ2 ++ A0 :: Γ3 = [] ++ [] ++ Γ2 ++ [A0] ++ Γ3). reflexivity.
+        rewrite H0. clear H0.
+        assert (A0 :: Γ0 ++ Γ1 = [] ++ [A0] ++ Γ2 ++ [] ++ Γ3). simpl. rewrite H2. reflexivity.
+        rewrite H0. clear H0. apply list_exch_LI.
+        assert (J20: derrec_height x = derrec_height x). reflexivity.
+        pose (KS_hpadm_list_exch_L0 _ _ x J20 _ J1). destruct s.
+        assert (J2: list_exch_L (A0 :: Γ0 ++ Γ1, Δ0 ++ B0 :: Δ3) (Γ0 ++ A0 :: Γ1, Δ0 ++ B0 :: Δ3)).
+        assert ((A0 :: Γ0 ++ Γ1, Δ0 ++ B0 :: Δ3) = ([] ++ [A0] ++ Γ0 ++ [] ++ Γ1, Δ0 ++ B0 :: Δ3)).
+        reflexivity. assert ((Γ0 ++ A0 :: Γ1, Δ0 ++ B0 :: Δ3) = ([] ++ [] ++ Γ0 ++ [A0] ++ Γ1, Δ0 ++ B0 :: Δ3)).
+        reflexivity. rewrite H1. rewrite H0. clear H1. clear H0. apply list_exch_LI.
+        assert (J21: derrec_height x0 = derrec_height x0). reflexivity.
+        pose (KS_hpadm_list_exch_L0 _ _ x0 J21 _ J2). destruct s. exists x1.
+        simpl. lia. }
+      { inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec_height (dersrec_height d) _ _ _ _ d J30). destruct s. simpl.
+        assert (J1: list_exch_L (Γ2 ++ A0 :: Γ3, (Δ0 ++ A --> B :: x) ++ B0 :: Δ3) (A0 :: Γ0 ++ Γ1, Δ0 ++ A --> B :: x ++ B0 :: Δ3)).
+        repeat rewrite <- app_assoc.
+        assert (Γ2 ++ A0 :: Γ3 = [] ++ [] ++ Γ2 ++ [A0] ++ Γ3). reflexivity.
+        rewrite H0. clear H0.
+        assert (A0 :: Γ0 ++ Γ1 = [] ++ [A0] ++ Γ2 ++ [] ++ Γ3). simpl. rewrite H2. reflexivity.
+        rewrite H0. clear H0. apply list_exch_LI.
+        assert (J20: derrec_height x0 = derrec_height x0). reflexivity.
+        pose (KS_hpadm_list_exch_L0 _ _ x0 J20 _ J1). destruct s. simpl in IH. simpl.
+        assert (J2: derrec_height x1 < S (dersrec_height d)). lia.
+        assert (J3: derrec_height x1 = derrec_height x1). reflexivity.
+        assert (J4: ImpRRule [(A0 :: Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ B0 :: Δ3)] (A0 :: Γ0 ++ Γ1, Δ0 ++ A --> B :: x ++ B0 :: Δ3)).
+        assert (A0 :: Γ0 ++ A :: Γ1 = (A0 :: Γ0) ++ A :: Γ1). reflexivity. rewrite H0. clear H0.
+        assert (A0 :: Γ0 ++ Γ1 = (A0 :: Γ0) ++ Γ1). reflexivity. rewrite H0. clear H0.
+        apply ImpRRule_I.
+        pose (IH _ J2 _ _ J3). destruct p. pose (s _ J4). clear s0. destruct s1. clear s.
+        assert (ImpRRule [(A0 :: Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ B0 :: Δ3)] (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ A0 --> B0 :: Δ3)).
+        assert (A0 :: Γ0 ++ A :: Γ1 = [] ++ A0 :: Γ0 ++ A :: Γ1). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ A :: Γ1 = [] ++ Γ0 ++ A :: Γ1). reflexivity. rewrite H0. clear H0. repeat rewrite <- app_assoc.
+        assert (Δ0 ++ B :: x ++ B0 :: Δ3 = (Δ0 ++ B :: x) ++ B0 :: Δ3). rewrite <- app_assoc. reflexivity.
+        rewrite H0. clear H0.
+        assert (Δ0 ++ B :: x ++ A0 --> B0 :: Δ3 = (Δ0 ++ B :: x) ++ A0 --> B0 :: Δ3). rewrite <- app_assoc. reflexivity.
+        rewrite H0. clear H0.
+        apply ImpRRule_I. apply ImpR in H0 ; try intro ; try apply f0 ; try auto ; try assumption.
+        pose (dlCons x2 DersNilF).
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(A0 :: Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ B0 :: Δ3)]) (Γ0 ++ A :: Γ1, Δ0 ++ B :: x ++ A0 --> B0 :: Δ3) H0 d0).
+        exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity. }
+  (* ImpL *)
+  * inversion H. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+    pose (@dersrec_derrec2_height (dersrec_height d) _ _ _ _ _ d J30). repeat destruct s. simpl.
+    assert (J1: ImpRRule [(A :: Γ2 ++ B0 :: Γ3, Δ0 ++ B :: Δ1)] (Γ2 ++ B0 :: Γ3, Δ2 ++ Δ3)).
+    rewrite H3. assert (A :: Γ2 ++ B0 :: Γ3 = [] ++ A :: Γ2 ++ B0 :: Γ3). reflexivity.
+    rewrite H0. clear H0. assert (Γ2 ++ B0 :: Γ3 = [] ++ Γ2 ++ B0 :: Γ3). reflexivity.
+    rewrite H0. clear H0. apply ImpRRule_I. simpl in IH.
+    assert (J2: derrec_height x0 < S (dersrec_height d)). lia.
+    assert (J3: derrec_height x0 = derrec_height x0). reflexivity.
+    pose (IH _ J2 _ _ J3). destruct p. clear s0. pose (s _ J1). destruct s0. clear s.
+    assert (J7: list_exch_R (Γ2 ++ Γ3, Δ2 ++ A0 :: Δ3) (Γ2 ++ Γ3, A0 :: Δ0 ++ A --> B :: Δ1)).
+    rewrite <- H3. assert (Δ2 ++ A0 :: Δ3 = [] ++ [] ++ Δ2 ++ [A0] ++ Δ3). reflexivity.
+    rewrite H0. clear H0. assert (A0 :: Δ2 ++ Δ3 = [] ++ [A0] ++ Δ2 ++ [] ++ Δ3). reflexivity.
+    rewrite H0. clear H0. apply list_exch_RI.
+    assert (J8: derrec_height x = derrec_height x). reflexivity.
+    pose (KS_hpadm_list_exch_R0 _ _ x J8 _ J7). destruct s.
+    assert (J4: ImpRRule [(A :: Γ2 ++ Γ3, A0 :: Δ0 ++ B :: Δ1)] (Γ2 ++ Γ3, A0 :: Δ0 ++ A --> B :: Δ1)).
+    assert (A :: Γ2 ++ Γ3 = [] ++ A :: Γ2 ++ Γ3). reflexivity.
+    rewrite H0. clear H0. assert ((Γ2 ++ Γ3, A0 :: Δ0 ++ A --> B :: Δ1) = ([] ++ Γ2 ++ Γ3, A0 :: Δ0 ++ A --> B :: Δ1)). reflexivity.
+    rewrite H0. clear H0. assert (A0 :: Δ0 ++ B :: Δ1 = (A0 :: Δ0) ++ B :: Δ1). reflexivity.
+    rewrite H0. clear H0. assert (A0 :: Δ0 ++ A --> B :: Δ1 = (A0 :: Δ0) ++ A --> B :: Δ1). reflexivity.
+    rewrite H0. clear H0. apply ImpRRule_I. simpl in IH.
+    assert (J5: derrec_height x2 < S (dersrec_height d)). lia.
+    assert (J6: derrec_height x2 = derrec_height x2). reflexivity.
+    pose (IH _ J5 _ _ J6). destruct p. clear s0. pose (s _ J4). destruct s0. clear s.
+    assert (ImpLRule [(A :: Γ2 ++ Γ3, A0 :: Δ0 ++ B :: Δ1); (A :: Γ2 ++ B0 :: Γ3, Δ0 ++ B :: Δ1)]
+    (A :: Γ2 ++ A0 --> B0 :: Γ3, Δ0 ++ B :: Δ1)).
+    assert (A :: Γ2 ++ Γ3 = (A :: Γ2) ++ Γ3). reflexivity. rewrite H0. clear H0.
+    assert (A :: Γ2 ++ B0 :: Γ3 = (A :: Γ2) ++ B0 :: Γ3). reflexivity. rewrite H0. clear H0.
+    assert (A :: Γ2 ++ A0 --> B0 :: Γ3 = (A :: Γ2) ++ A0 --> B0 :: Γ3). reflexivity. rewrite H0. clear H0.
+    assert (Δ0 ++ B :: Δ1 = [] ++ Δ0 ++ B :: Δ1). reflexivity. rewrite H0. clear H0.
+    assert (A0 :: [] ++ Δ0 ++ B :: Δ1 = [] ++ A0 :: Δ0 ++ B :: Δ1). reflexivity. rewrite H0. clear H0.
+    apply ImpLRule_I. pose (dlCons x1 DersNilF). pose (dlCons x3 d0).
+    apply ImpL in H0.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[(A :: Γ2 ++ Γ3, A0 :: Δ0 ++ B :: Δ1); (A :: Γ2 ++ B0 :: Γ3, Δ0 ++ B :: Δ1)])
+    (A :: Γ2 ++ A0 --> B0 :: Γ3, Δ0 ++ B :: Δ1) H0 d1).
+    assert (J40: list_exch_L (A :: Γ2 ++ A0 --> B0 :: Γ3, Δ0 ++ B :: Δ1) (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)).
+    rewrite H2. assert (A :: Γ0 ++ Γ1 = [] ++ [A] ++ Γ0 ++ [] ++ Γ1). reflexivity. rewrite H1. clear H1.
+    assert (Γ0 ++ A :: Γ1 = [] ++ [] ++ Γ0 ++ [A] ++ Γ1). reflexivity. rewrite H1. clear H1.
+    apply list_exch_LI.
+    assert (J41: derrec_height d2 = derrec_height d2). reflexivity.
+    pose (KS_hpadm_list_exch_L0 _ _ d2 J41 _ J40). destruct s. exists x4. simpl in J41.
+    simpl in l2. rewrite dersrec_height_nil in l2. lia. reflexivity.
+  (* KR *)
+  * inversion X. subst.
+    assert (KRRule [(unboxed_list , [A0])] (Γ0 ++ Γ1, Δ0 ++ Δ1)).
+    assert (In (Box A0) (Δ0 ++ Δ1)).
+    assert (InT (Box A0) (Δ2 ++ Box A0 :: Δ3)). apply InT_or_app. right. apply InT_eq.
+    rewrite H2 in H. apply InT_app_or in H. apply in_or_app. destruct H. apply InT_In in i. auto.
+    inversion i. inversion H0. apply InT_In in H0. auto.
+    apply in_splitT in H. destruct H. destruct s. rewrite e. apply KRRule_I ; try assumption.
+    simpl. simpl in IH.
+    apply KR in X1.
+    assert (dersrec_height d = dersrec_height d). reflexivity.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[(unboxed_list , [A0])]) (Γ0 ++ Γ1, Δ0 ++ Δ1) X1 d).
+    assert (J1: wkn_L A (Γ0 ++ Γ1, Δ0 ++ Δ1) (Γ0 ++ A :: Γ1, Δ0 ++ Δ1)).
+    apply wkn_LI.
+    assert (J2: derrec_height d0 = derrec_height d0). reflexivity.
+    pose (KS_wkn_L _ _ d0 J2 _ _ J1). destruct s.
+    assert (J3: wkn_R B (Γ0 ++ A :: Γ1, Δ0 ++ Δ1) (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)).
+    apply wkn_RI.
+    assert (J4: derrec_height x = derrec_height x). reflexivity.
+    pose (KS_wkn_R _ _ x J4 _ _ J3). destruct s. exists x0.
+    pose (Nat.le_trans _ _ _ l0 l). simpl in l1. assumption. }
+{ intros prem1 prem2 RA. inversion RA. subst.
+  inversion k ; subst.
+  (* IdP *)
+  * inversion H. subst. assert (InT # P (Γ0 ++ Γ1)). assert (InT # P (Γ2 ++ # P :: Γ3)).
+    apply InT_or_app. right. apply InT_eq. rewrite H2 in H0. apply InT_or_app.
+    apply InT_app_or in H0. destruct H0. auto. inversion i. inversion H1.
+    auto. assert (InT # P (Γ0 ++ B :: Γ1)).
+    apply InT_app_or in H0. apply InT_or_app. destruct H0. auto. right. apply InT_cons.
+    assumption. apply InT_split in H1. destruct H1. destruct s. apply InT_split in H0. destruct H0.
+    destruct s. rewrite e0. rewrite e. assert (In # P (Δ0 ++ A :: Δ1)). assert (In # P (Δ0 ++ Δ1)).
+    rewrite <- H3. apply in_or_app. right. apply in_eq. apply in_app_or in H0. apply in_or_app.
+    destruct H0. auto. right. apply in_cons. assumption. apply in_splitT in H0. destruct H0.
+    destruct s. rewrite e1.
+    assert (IdPRule [] (x1 ++ # P :: x2, x3 ++ # P :: x4)).
+    apply IdPRule_I. apply IdP in H0.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x1 ++ # P :: x2, x3 ++ # P :: x4) H0 DersNilF). exists d0.
+    assert (IdPRule [] (x ++ # P :: x0, Δ0 ++ Δ1)). rewrite <- H3.
+    apply IdPRule_I. apply IdP in H1.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x ++ # P :: x0, Δ0 ++ Δ1) H1 DersNilF). exists d1.
+    simpl. rewrite dersrec_height_nil. split ; lia. reflexivity.
+  (* BotL *)
+  * inversion H. subst. assert (InT (Bot) (Γ0 ++ Γ1)). assert (InT (Bot) (Γ2 ++ (Bot) :: Γ3)).
+    apply InT_or_app. right. apply InT_eq. rewrite H2 in H0. apply InT_app_or in H0.
+    apply InT_or_app. destruct H0. auto. inversion i. inversion H1. auto. assert (InT (Bot) (Γ0 ++ B :: Γ1)).
+    apply InT_app_or in H0. apply InT_or_app. destruct H0. auto. right. apply InT_cons.
+    assumption. apply InT_split in H0. destruct H0. destruct s. apply InT_split in H1. destruct H1.
+    destruct s. rewrite e0. rewrite e.
+    assert (BotLRule [] (x ++ Bot :: x0, Δ0 ++ A :: Δ1)).
+    apply BotLRule_I. apply BotL in H0.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x ++ Bot :: x0, Δ0 ++ A :: Δ1) H0 DersNilF). exists d0.
+    assert (BotLRule [] (x1 ++ Bot :: x2, Δ0 ++ Δ1)).
+    apply BotLRule_I. apply BotL in H1.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[]) (x1 ++ Bot :: x2, Δ0 ++ Δ1) H1 DersNilF). exists d1.
+    simpl. rewrite dersrec_height_nil. split ; lia. reflexivity.
+  (* ImpR *)
+  * inversion H. subst. simpl in IH.
+    assert (J0: (dersrec_height d) = (dersrec_height d)). reflexivity.
+    pose (dersrec_derrec_height d J0). destruct s.
+    apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+    + assert (ImpLRule [(Γ2 ++ A0 :: Γ1, A :: Δ2 ++ B0 :: Δ3) ; (Γ2 ++ A0 :: B :: Γ1, Δ2 ++ B0 :: Δ3)]
+      (Γ2 ++ A0 :: A --> B :: Γ1, Δ2 ++ B0 :: Δ3)). assert (Γ2 ++ A0 :: Γ1 = (Γ2 ++ [A0]) ++ Γ1).
+      rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ A0 :: B :: Γ1 = (Γ2 ++ [A0]) ++ B :: Γ1). rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. assert (Γ2 ++ A0 :: A --> B :: Γ1 = (Γ2 ++ [A0]) ++ A --> B :: Γ1). rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. assert (Δ2 ++ B0 :: Δ3 = [] ++ Δ2 ++ B0 :: Δ3).
+      reflexivity. rewrite H0. clear H0. assert (A :: [] ++ Δ2 ++ B0 :: Δ3 = [] ++ A :: Δ2 ++ B0 :: Δ3).
+      reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+      assert (J1: derrec_height x < S (dersrec_height d)). lia.
+      assert (J2: derrec_height x = derrec_height x). reflexivity.
+      pose (IH (derrec_height x) J1 _ x J2). destruct p. clear s.
+      pose (s0 _ _ H0). repeat destruct s. clear s0. destruct p.
+      assert (ImpRRule [(Γ2 ++ A0 :: Γ1, A :: Δ2 ++ B0 :: Δ3)] (Γ2 ++ Γ1, A :: Δ0 ++ Δ1)).
+      rewrite <- H3. assert (A :: Δ2 ++ B0 :: Δ3 = (A :: Δ2) ++ B0 :: Δ3). reflexivity.
+      rewrite H1. clear H1. assert (A :: Δ2 ++ A0 --> B0 :: Δ3 = (A :: Δ2) ++ A0 --> B0 :: Δ3). reflexivity.
+      rewrite H1. clear H1. apply ImpRRule_I.
+      assert (existsT2 (x3: derrec KS_rules (fun _ : Seq => False)
+      (Γ2 ++ Γ1, A :: Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+      apply ImpR in H1.
+      pose (dlCons x1 DersNilF). pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[(Γ2 ++ A0 :: Γ1, A :: Δ2 ++ B0 :: Δ3)]) (Γ2 ++ Γ1, A :: Δ0 ++ Δ1) H1 d0).
+      exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+      destruct X.
+      assert (J3: derrec_height x3 = derrec_height x3). reflexivity.
+      assert (J4: list_exch_R (Γ2 ++ Γ1, A :: Δ0 ++ Δ1) (Γ2 ++ Γ1, Δ0 ++ A :: Δ1)).
+      assert (A :: Δ0 ++ Δ1 = [] ++ [A] ++ Δ0 ++ [] ++ Δ1). reflexivity. rewrite H2. clear H2.
+      assert (Δ0 ++ A :: Δ1 = [] ++ [] ++ Δ0 ++ [A] ++ Δ1). reflexivity. rewrite H2. clear H2.
+      apply list_exch_RI. pose (KS_hpadm_list_exch_R0 _ _ x3 J3 _ J4). destruct s. exists x4.
+      assert (ImpRRule [(Γ2 ++ A0 :: B :: Γ1, Δ2 ++ B0 :: Δ3)] (Γ2 ++ B :: Γ1, Δ0 ++ Δ1)).
+      rewrite <- H3. apply ImpRRule_I.
+      assert (existsT2 (x3: derrec KS_rules (fun _ : Seq => False)
+      (Γ2 ++ B :: Γ1, Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+      apply ImpR in H2.
+      pose (dlCons x2 DersNilF). pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[(Γ2 ++ A0 :: B :: Γ1, Δ2 ++ B0 :: Δ3)]) (Γ2 ++ B :: Γ1, Δ0 ++ Δ1) H2 d0).
+      exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+      destruct X. exists x5. simpl. split. lia. lia.
+    + assert (ImpLRule [(Γ2 ++ A0 :: x0 ++ Γ1, A :: Δ2 ++ B0 :: Δ3) ; (Γ2 ++ A0 :: x0 ++ B :: Γ1, Δ2 ++ B0 :: Δ3)]
+      (Γ2 ++ A0 :: x0 ++ A --> B :: Γ1, Δ2 ++ B0 :: Δ3)). assert (Γ2 ++ A0 :: x0 ++ Γ1 = (Γ2 ++ A0 :: x0) ++ Γ1).
+      rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+      assert (Γ2 ++ A0 :: x0 ++ B :: Γ1 = (Γ2 ++ A0 :: x0) ++ B :: Γ1). rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. assert (Γ2 ++ A0 :: x0 ++ A --> B :: Γ1 = (Γ2 ++ A0 :: x0) ++ A --> B :: Γ1). rewrite <- app_assoc. reflexivity.
+      rewrite H0. clear H0. assert (Δ2 ++ B0 :: Δ3 = [] ++ Δ2 ++ B0 :: Δ3).
+      reflexivity. rewrite H0. clear H0. assert (A :: [] ++ Δ2 ++ B0 :: Δ3 = [] ++ A :: Δ2 ++ B0 :: Δ3).
+      reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+      assert (J1: derrec_height x < S (dersrec_height d)). lia.
+      assert (J2: derrec_height x = derrec_height x). reflexivity.
+      pose (IH (derrec_height x) J1 _ x J2). destruct p. clear s.
+      pose (s0 _ _ H0). repeat destruct s. clear s0. destruct p.
+      assert (ImpRRule [(Γ2 ++ A0 :: x0 ++ Γ1, A :: Δ2 ++ B0 :: Δ3)] ((Γ2 ++ x0) ++ Γ1, A :: Δ0 ++ Δ1)).
+      rewrite <- H3. assert (A :: Δ2 ++ B0 :: Δ3 = (A :: Δ2) ++ B0 :: Δ3). reflexivity.
+      rewrite H1. clear H1. assert (A :: Δ2 ++ A0 --> B0 :: Δ3 = (A :: Δ2) ++ A0 --> B0 :: Δ3). reflexivity.
+      rewrite H1. clear H1. rewrite <- app_assoc. apply ImpRRule_I.
+      assert (existsT2 (x3: derrec KS_rules (fun _ : Seq => False)
+      ((Γ2 ++ x0) ++ Γ1, A :: Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+      apply ImpR in H1.
+      pose (dlCons x1 DersNilF). pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[(Γ2 ++ A0 :: x0 ++ Γ1, A :: Δ2 ++ B0 :: Δ3)]) ((Γ2 ++ x0) ++ Γ1, A :: Δ0 ++ Δ1) H1 d0).
+      exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+      destruct X.
+      assert (J3: derrec_height x3 = derrec_height x3). reflexivity.
+      assert (J4: list_exch_R ((Γ2 ++ x0) ++ Γ1, A :: Δ0 ++ Δ1) ((Γ2 ++ x0) ++ Γ1, Δ0 ++ A :: Δ1)).
+      assert (A :: Δ0 ++ Δ1 = [] ++ [A] ++ Δ0 ++ [] ++ Δ1). reflexivity. rewrite H2. clear H2.
+      assert (Δ0 ++ A :: Δ1 = [] ++ [] ++ Δ0 ++ [A] ++ Δ1). reflexivity. rewrite H2. clear H2.
+      apply list_exch_RI. pose (KS_hpadm_list_exch_R0 _ _ x3 J3 _ J4). destruct s. exists x4.
+      assert (ImpRRule [(Γ2 ++ A0 :: x0 ++ B :: Γ1, Δ2 ++ B0 :: Δ3)] ((Γ2 ++ x0) ++ B :: Γ1, Δ0 ++ Δ1)).
+      rewrite <- H3. rewrite <- app_assoc. apply ImpRRule_I.
+      assert (existsT2 (x3: derrec KS_rules (fun _ : Seq => False)
+      ((Γ2 ++ x0) ++ B :: Γ1, Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+      apply ImpR in H2.
+      pose (dlCons x2 DersNilF). pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[(Γ2 ++ A0 :: x0 ++ B :: Γ1, Δ2 ++ B0 :: Δ3)]) ((Γ2 ++ x0) ++ B :: Γ1, Δ0 ++ Δ1) H2 d0).
+      exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+      destruct X. exists x5. simpl. split. lia. lia.
+    + destruct x0.
+      { simpl in e1. subst. assert (ImpLRule [(Γ0 ++ A0 :: Γ1, A :: Δ2 ++ B0 :: Δ3) ; (Γ0 ++ A0 :: B :: Γ1, Δ2 ++ B0 :: Δ3)]
+        ((Γ0 ++ []) ++ A0 :: A --> B :: Γ1, Δ2 ++ B0 :: Δ3)). rewrite app_nil_r. assert (Γ0 ++ A0 :: Γ1 = (Γ0 ++ [A0]) ++ Γ1).
+        rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ A0 :: B :: Γ1 = (Γ0 ++ [A0]) ++ B :: Γ1). rewrite <- app_assoc. reflexivity.
+        rewrite H0. clear H0. assert (Γ0 ++ A0 :: A --> B :: Γ1 = (Γ0 ++ [A0]) ++ A --> B :: Γ1). rewrite <- app_assoc. reflexivity.
+        rewrite H0. clear H0. assert (Δ2 ++ B0 :: Δ3 = [] ++ Δ2 ++ B0 :: Δ3).
+        reflexivity. rewrite H0. clear H0. assert (A :: [] ++ Δ2 ++ B0 :: Δ3 = [] ++ A :: Δ2 ++ B0 :: Δ3).
+        reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        assert (J1: derrec_height x < S (dersrec_height d)). lia.
+        assert (J2: derrec_height x = derrec_height x). reflexivity.
+        pose (IH (derrec_height x) J1 _ x J2). destruct p. clear s.
+        pose (s0 _ _ H0). repeat destruct s. clear s0. destruct p.
+        assert (ImpRRule [(Γ0 ++ A0 :: Γ1, A :: Δ2 ++ B0 :: Δ3)] (Γ0 ++ Γ1, A :: Δ0 ++ Δ1)).
+        rewrite <- H3. assert (A :: Δ2 ++ B0 :: Δ3 = (A :: Δ2) ++ B0 :: Δ3). reflexivity.
+        rewrite H1. clear H1. assert (A :: Δ2 ++ A0 --> B0 :: Δ3 = (A :: Δ2) ++ A0 --> B0 :: Δ3). reflexivity.
+        rewrite H1. clear H1. apply ImpRRule_I.
+        assert (existsT2 (x3: derrec KS_rules (fun _ : Seq => False)
+        (Γ0 ++ Γ1, A :: Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+        apply ImpR in H1.
+        pose (dlCons x0 DersNilF). pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(Γ0 ++ A0 :: Γ1, A :: Δ2 ++ B0 :: Δ3)]) (Γ0 ++ Γ1, A :: Δ0 ++ Δ1) H1 d0).
+        exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+        destruct X.
+        assert (J3: derrec_height x2 = derrec_height x2). reflexivity.
+        assert (J4: list_exch_R (Γ0 ++ Γ1, A :: Δ0 ++ Δ1) (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)).
+        assert (A :: Δ0 ++ Δ1 = [] ++ [A] ++ Δ0 ++ [] ++ Δ1). reflexivity. rewrite H2. clear H2.
+        assert (Δ0 ++ A :: Δ1 = [] ++ [] ++ Δ0 ++ [A] ++ Δ1). reflexivity. rewrite H2. clear H2.
+        apply list_exch_RI. pose (KS_hpadm_list_exch_R0 _ _ x2 J3 _ J4). destruct s. exists x3.
+        assert (ImpRRule [(Γ0 ++ A0 :: B :: Γ1, Δ2 ++ B0 :: Δ3)] (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)).
+        rewrite <- H3. apply ImpRRule_I.
+        assert (existsT2 (x3: derrec KS_rules (fun _ : Seq => False)
+        (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+        apply ImpR in H2.
+        pose (dlCons x1 DersNilF). pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(Γ0 ++ A0 :: B :: Γ1, Δ2 ++ B0 :: Δ3)]) (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) H2 d0).
+        exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+        destruct X. exists x4. simpl. split. lia. lia. }
+        { inversion e1. subst. assert (ImpLRule [(Γ0 ++ x0 ++ A0 :: Γ3, A :: Δ2 ++ B0 :: Δ3) ; (Γ0 ++ B :: x0 ++ A0 :: Γ3, Δ2 ++ B0 :: Δ3)]
+          ((Γ0 ++ A --> B :: x0) ++ A0 :: Γ3, Δ2 ++ B0 :: Δ3)). rewrite <- app_assoc.
+          assert (Δ2 ++ B0 :: Δ3 = [] ++ Δ2 ++ B0 :: Δ3). reflexivity. rewrite H0. clear H0.
+          assert (A :: [] ++ Δ2 ++ B0 :: Δ3 = [] ++ A :: Δ2 ++ B0 :: Δ3). reflexivity. rewrite H0.
+          clear H0. apply ImpLRule_I.
+          assert (J1: derrec_height x < S (dersrec_height d)). lia.
+          assert (J2: derrec_height x = derrec_height x). reflexivity.
+          pose (IH (derrec_height x) J1 _ x J2). destruct p. clear s.
+          pose (s0 _ _ H0). repeat destruct s. clear s0. destruct p.
+          assert (ImpRRule [(Γ0 ++ x0 ++ A0 :: Γ3, A :: Δ2 ++ B0 :: Δ3)] (Γ0 ++ x0 ++ Γ3, A :: Δ0 ++ Δ1)).
+          rewrite <- H3. assert (A :: Δ2 ++ B0 :: Δ3 = (A :: Δ2) ++ B0 :: Δ3). reflexivity.
+          rewrite H1. clear H1. assert (A :: Δ2 ++ A0 --> B0 :: Δ3 = (A :: Δ2) ++ A0 --> B0 :: Δ3). reflexivity.
+          rewrite H1. clear H1. assert (Γ0 ++ x0 ++ A0 :: Γ3 = (Γ0 ++ x0) ++ A0 :: Γ3). rewrite <- app_assoc.
+          reflexivity. rewrite H1. clear H1. assert (Γ0 ++ x0 ++ Γ3 = (Γ0 ++ x0) ++ Γ3). rewrite <- app_assoc.
+          reflexivity. rewrite H1. clear H1. apply ImpRRule_I.
+          assert (existsT2 (x3: derrec KS_rules (fun _ : Seq => False)
+          (Γ0 ++ x0 ++ Γ3, A :: Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+          apply ImpR in H1.
+          pose (dlCons x1 DersNilF). pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[(Γ0 ++ x0 ++ A0 :: Γ3, A :: Δ2 ++ B0 :: Δ3)]) (Γ0 ++ x0 ++ Γ3, A :: Δ0 ++ Δ1) H1 d0).
+          exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+          destruct X.
+          assert (J3: derrec_height x3 = derrec_height x3). reflexivity.
+          assert (J4: list_exch_R (Γ0 ++ x0 ++ Γ3, A :: Δ0 ++ Δ1) (Γ0 ++ x0 ++ Γ3, Δ0 ++ A :: Δ1)).
+          assert (A :: Δ0 ++ Δ1 = [] ++ [A] ++ Δ0 ++ [] ++ Δ1). reflexivity. rewrite H2. clear H2.
+          assert (Δ0 ++ A :: Δ1 = [] ++ [] ++ Δ0 ++ [A] ++ Δ1). reflexivity. rewrite H2. clear H2.
+          apply list_exch_RI. pose (KS_hpadm_list_exch_R0 _ _ x3 J3 _ J4). destruct s. exists x4.
+          assert (ImpRRule [(Γ0 ++ B :: x0 ++ A0 :: Γ3, Δ2 ++ B0 :: Δ3)] (Γ0 ++ B :: x0 ++ Γ3, Δ0 ++ Δ1)).
+          rewrite <- H3. assert (Γ0 ++ B :: x0 ++ A0 :: Γ3 = (Γ0 ++ B :: x0) ++ A0 :: Γ3). rewrite <- app_assoc.
+          reflexivity. rewrite H2. clear H2. assert (Γ0 ++ B :: x0 ++ Γ3 = (Γ0 ++ B :: x0) ++ Γ3). rewrite <- app_assoc.
+          reflexivity. rewrite H2. clear H2. apply ImpRRule_I.
+          assert (existsT2 (x3: derrec KS_rules (fun _ : Seq => False)
+          (Γ0 ++ B :: x0 ++ Γ3, Δ0 ++ Δ1)), derrec_height x3 <= S (dersrec_height d)).
+          apply ImpR in H2.
+          pose (dlCons x2 DersNilF). pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[(Γ0 ++ B :: x0 ++ A0 :: Γ3, Δ2 ++ B0 :: Δ3)]) (Γ0 ++ B :: x0 ++ Γ3, Δ0 ++ Δ1) H2 d0).
+          exists d1. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+          destruct X. exists x5. simpl. split. lia. lia. }
+  (* ImpL *)
+  * inversion H. subst.
+    apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+    + inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+      pose (@dersrec_derrec2_height (dersrec_height d) _ _ _ _ _ d J30). repeat destruct s.
+      assert (J1: list_exch_R (Γ2 ++ Γ3, Δ2 ++ A0 :: Δ3) (Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1)).
+      assert (Δ2 ++ A0 :: Δ3 = [] ++ [] ++ Δ2 ++ [A0] ++ Δ3). reflexivity.
+      rewrite H0. clear H0.
+      assert (A0 :: Δ0 ++ Δ1 = [] ++ [A0] ++ Δ2 ++ [] ++ Δ3). simpl. rewrite H3. reflexivity.
+      rewrite H0. clear H0. apply list_exch_RI.
+      assert (J20: derrec_height x0 = derrec_height x0). reflexivity.
+      pose (KS_hpadm_list_exch_R0 _ _ x0 J20 _ J1). destruct s.
+      assert (J2: list_exch_R (Γ2 ++ Γ3, A0 :: Δ0 ++ Δ1) (Γ2 ++ Γ3, Δ0 ++ A0 :: Δ1)).
+      assert (A0 :: Δ0 ++ Δ1 = [] ++ [A0] ++ Δ0 ++ [] ++ Δ1).
+      reflexivity. assert (Δ0 ++ A0 :: Δ1 = [] ++ [] ++ Δ0 ++ [A0] ++ Δ1).
+      reflexivity. rewrite H1. rewrite H0. clear H1. clear H0. apply list_exch_RI.
+      assert (J21: derrec_height x2 = derrec_height x2). reflexivity.
+      pose (KS_hpadm_list_exch_R0 _ _ x2 J21 _ J2). destruct s. exists x3.
+      assert (existsT2 (x4: derrec KS_rules (fun _ : Seq => False) (Γ2 ++ B0 :: Γ3, Δ0 ++ Δ1)),
+      derrec_height x4 = derrec_height x1). rewrite <- H3. exists x1. reflexivity. destruct X. exists x4. split.
+       simpl. lia. simpl. lia.
+    + destruct x.
+      { simpl in e0. inversion e0. simpl. rewrite app_nil_r. subst.
+        assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec2_height (dersrec_height d) _ _ _ _ _ d J30). repeat destruct s.
+        assert (J1: list_exch_R (Γ2 ++ Γ1, Δ2 ++ A :: Δ3) (Γ2 ++ Γ1, A :: Δ0 ++ Δ1)).
+        assert (Δ2 ++ A :: Δ3 = [] ++ [] ++ Δ2 ++ [A] ++ Δ3). reflexivity.
+        rewrite H0. clear H0.
+        assert (A :: Δ0 ++ Δ1 = [] ++ [A] ++ Δ2 ++ [] ++ Δ3). simpl. rewrite H3. reflexivity.
+        rewrite H0. clear H0. apply list_exch_RI.
+        assert (J20: derrec_height x = derrec_height x). reflexivity.
+        pose (KS_hpadm_list_exch_R0 _ _ x J20 _ J1). destruct s.
+        assert (J2: list_exch_R (Γ2 ++ Γ1, A :: Δ0 ++ Δ1) (Γ2 ++ Γ1, Δ0 ++ A :: Δ1)).
+        assert (A :: Δ0 ++ Δ1 = [] ++ [A] ++ Δ0 ++ [] ++ Δ1).
+        reflexivity. assert (Δ0 ++ A :: Δ1 = [] ++ [] ++ Δ0 ++ [A] ++ Δ1).
+        reflexivity. rewrite H1. rewrite H0. clear H1. clear H0. apply list_exch_RI.
+        assert (J21: derrec_height x1 = derrec_height x1). reflexivity.
+        pose (KS_hpadm_list_exch_R0 _ _ x1 J21 _ J2). destruct s. exists x2.
+        assert (existsT2 (x3: derrec KS_rules (fun _ : Seq => False) (Γ2 ++ B :: Γ1, Δ0 ++ Δ1)),
+        derrec_height x3 = derrec_height x0). rewrite <- H3. exists x0. reflexivity. destruct X. exists x3. split.
+        simpl. lia. simpl. lia. }
+      { inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec2_height (dersrec_height d) _ _ _ _ _ d J30). repeat destruct s.
+        assert (J1: list_exch_R (Γ2 ++ x ++ A --> B :: Γ1, Δ2 ++ A0 :: Δ3) (Γ2 ++ x ++ A --> B :: Γ1, A0 :: Δ0 ++ Δ1)).
+        assert (Δ2 ++ A0 :: Δ3 = [] ++ [] ++ Δ2 ++ [A0] ++ Δ3). reflexivity.
+        rewrite H0. clear H0.
+        assert (A0 :: Δ0 ++ Δ1 = [] ++ [A0] ++ Δ2 ++ [] ++ Δ3). simpl. rewrite H3. reflexivity.
+        rewrite H0. clear H0. apply list_exch_RI.
+        assert (J20: derrec_height x0 = derrec_height x0). reflexivity.
+        pose (KS_hpadm_list_exch_R0 _ _ x0 J20 _ J1). destruct s. simpl in IH. simpl.
+        assert (J2: derrec_height x2 < S (dersrec_height d)). lia.
+        assert (J3: derrec_height x2 = derrec_height x2). reflexivity.
+        assert (J4: ImpLRule [(Γ2 ++ x ++ Γ1, A0 :: Δ0 ++ A :: Δ1); (Γ2 ++ x ++ B :: Γ1, A0 :: Δ0 ++ Δ1)]
+        (Γ2 ++ x ++ A --> B :: Γ1, A0 :: Δ0 ++ Δ1)).
+        assert (A0 :: Δ0 ++ A :: Δ1 = (A0 :: Δ0) ++ A :: Δ1). reflexivity. rewrite H0. clear H0.
+        assert (A0 :: Δ0 ++ Δ1 = (A0 :: Δ0) ++ Δ1). reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ x ++ B :: Γ1 = (Γ2 ++ x) ++ B :: Γ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ x ++ A --> B :: Γ1 = (Γ2 ++ x) ++ A --> B :: Γ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ x ++ Γ1 = (Γ2 ++ x) ++ Γ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        pose (IH _ J2 _ _ J3). destruct p. pose (s0 _ _ J4). clear s. destruct s1. clear s0. destruct s.
+        destruct p.
+        assert (J5: derrec_height x1 < S (dersrec_height d)). lia.
+        assert (J6: derrec_height x1 = derrec_height x1). reflexivity.
+        assert (J7: ImpLRule [(Γ2 ++ B0 :: x ++ Γ1, Δ0 ++ A :: Δ1); (Γ2 ++ B0 :: x ++ B :: Γ1, Δ0 ++ Δ1)]
+        (Γ2 ++ B0 :: x ++ A --> B :: Γ1, Δ2 ++ Δ3)). rewrite H3.
+        assert (Γ2 ++ B0 :: x ++ Γ1 = (Γ2 ++ B0 :: x) ++ Γ1). rewrite <- app_assoc. reflexivity.
+        rewrite H0. clear H0.
+        assert (Γ2 ++ B0 :: x ++ B :: Γ1 = (Γ2 ++ B0 :: x) ++ B :: Γ1). rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0.
+        assert (Γ2 ++ B0 :: x ++ A --> B :: Γ1 = (Γ2 ++ B0 :: x) ++ A --> B :: Γ1). repeat rewrite <- app_assoc.
+        reflexivity. rewrite H0. clear H0. apply ImpLRule_I.
+        pose (IH _ J5 _ _ J6). destruct p. pose (s0 _ _ J7). clear s. destruct s1. clear s0. destruct s.
+        destruct p.
+        assert (existsT2 (x7 : derrec KS_rules (fun _ : Seq => False)
+        ((Γ2 ++ A0 --> B0 :: x) ++ Γ1, Δ0 ++ A :: Δ1)), derrec_height x7 <= S (dersrec_height d)).
+        assert (ImpLRule [(Γ2 ++ x ++ Γ1, A0 :: Δ0 ++ A :: Δ1); (Γ2 ++ B0 :: x ++ Γ1, Δ0 ++ A :: Δ1)]
+        ((Γ2 ++ A0 --> B0 :: x) ++ Γ1, Δ0 ++ A :: Δ1)). rewrite <- app_assoc.
+        assert (A0 :: Δ0 ++ A :: Δ1 = [] ++ A0 :: Δ0 ++ A :: Δ1). reflexivity. rewrite H0. clear H0.
+        assert (Δ0 ++ A :: Δ1 = [] ++ Δ0 ++ A :: Δ1). reflexivity. rewrite H0. clear H0. repeat rewrite <- app_assoc.
+        apply ImpLRule_I. apply ImpL in H0.
+        pose (dlCons x5 DersNilF). pose (dlCons x3 d0).
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(Γ2 ++ x ++ Γ1, A0 :: Δ0 ++ A :: Δ1); (Γ2 ++ B0 :: x ++ Γ1, Δ0 ++ A :: Δ1)])
+        ((Γ2 ++ A0 --> B0 :: x) ++ Γ1, Δ0 ++ A :: Δ1) H0 d1).
+        exists d2. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+        destruct X. exists x7.
+        assert (existsT2 (x8 : derrec KS_rules (fun _ : Seq => False)
+        ((Γ2 ++ A0 --> B0 :: x) ++ B :: Γ1, Δ0 ++ Δ1)), derrec_height x8 <= S (dersrec_height d)).
+        assert (ImpLRule [(Γ2 ++ x ++ B :: Γ1, A0 :: Δ0 ++ Δ1); (Γ2 ++ B0 :: x ++ B :: Γ1, Δ0 ++ Δ1)]
+        ((Γ2 ++ A0 --> B0 :: x) ++ B :: Γ1, Δ0 ++ Δ1)). rewrite <- app_assoc.
+        assert (Δ0 ++ Δ1 = [] ++ Δ0 ++ Δ1). reflexivity. rewrite H0. clear H0.
+        assert (A0 :: [] ++ Δ0 ++ Δ1 = [] ++ A0 :: Δ0 ++ Δ1). reflexivity. rewrite H0. clear H0.
+        apply ImpLRule_I. apply ImpL in H0.
+        pose (dlCons x6 DersNilF). pose (dlCons x4 d0).
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(Γ2 ++ x ++ B :: Γ1, A0 :: Δ0 ++ Δ1); (Γ2 ++ B0 :: x ++ B :: Γ1, Δ0 ++ Δ1)])
+        ((Γ2 ++ A0 --> B0 :: x) ++ B :: Γ1, Δ0 ++ Δ1) H0 d1).
+        exists d2. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+        destruct X. exists x8. split. lia. lia. }
+    + destruct x.
+      { simpl in e0. inversion e0. simpl. subst.
+        assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec2_height (dersrec_height d) _ _ _ _ _ d J30). repeat destruct s.
+        assert (J1: list_exch_R ((Γ0 ++ []) ++ Γ3, Δ2 ++ A0 :: Δ3) (Γ0 ++ Γ3, A0 :: Δ0 ++ Δ1)).
+        rewrite app_nil_r.
+        assert (Δ2 ++ A0 :: Δ3 = [] ++ [] ++ Δ2 ++ [A0] ++ Δ3). reflexivity.
+        rewrite H0. clear H0.
+        assert (A0 :: Δ0 ++ Δ1 = [] ++ [A0] ++ Δ2 ++ [] ++ Δ3). simpl. rewrite H3. reflexivity.
+        rewrite H0. clear H0. apply list_exch_RI.
+        assert (J20: derrec_height x = derrec_height x). reflexivity.
+        pose (KS_hpadm_list_exch_R0 _ _ x J20 _ J1). destruct s.
+        assert (J2: list_exch_R (Γ0 ++ Γ3, A0 :: Δ0 ++ Δ1) (Γ0 ++ Γ3, Δ0 ++ A0 :: Δ1)).
+        assert (A0 :: Δ0 ++ Δ1 = [] ++ [A0] ++ Δ0 ++ [] ++ Δ1).
+        reflexivity. assert (Δ0 ++ A0 :: Δ1 = [] ++ [] ++ Δ0 ++ [A0] ++ Δ1).
+        reflexivity. rewrite H1. rewrite H0. clear H1. clear H0. apply list_exch_RI.
+        assert (J21: derrec_height x1 = derrec_height x1). reflexivity.
+        pose (KS_hpadm_list_exch_R0 _ _ x1 J21 _ J2). destruct s. exists x2.
+        assert (existsT2 (x3: derrec KS_rules (fun _ : Seq => False) (Γ0 ++ B0 :: Γ3, Δ0 ++ Δ1)),
+        derrec_height x3 = derrec_height x0). rewrite <- H3.
+        assert (Γ0 ++ B0 :: Γ3 = (Γ0 ++ []) ++ B0 :: Γ3). rewrite app_nil_r. reflexivity.
+        rewrite H0. exists x0. reflexivity. destruct X. exists x3. split.
+        simpl. lia. simpl. lia. }
+      { inversion e0. subst. assert (J30: dersrec_height d = dersrec_height d). reflexivity.
+        pose (@dersrec_derrec2_height (dersrec_height d) _ _ _ _ _ d J30). repeat destruct s.
+        assert (J1: list_exch_R ((Γ0 ++ A --> B :: x) ++ Γ3, Δ2 ++ A0 :: Δ3) (Γ0 ++ A --> B :: x ++ Γ3, A0 :: Δ0 ++ Δ1)).
+        assert (Δ2 ++ A0 :: Δ3 = [] ++ [] ++ Δ2 ++ [A0] ++ Δ3). reflexivity.
+        rewrite H0. clear H0. rewrite <- app_assoc.
+        assert (A0 :: Δ0 ++ Δ1 = [] ++ [A0] ++ Δ2 ++ [] ++ Δ3). simpl. rewrite H3. reflexivity.
+        rewrite H0. clear H0. apply list_exch_RI.
+        assert (J20: derrec_height x0 = derrec_height x0). reflexivity.
+        pose (KS_hpadm_list_exch_R0 _ _ x0 J20 _ J1). destruct s. simpl in IH. simpl.
+        assert (J2: derrec_height x2 < S (dersrec_height d)). lia.
+        assert (J3: derrec_height x2 = derrec_height x2). reflexivity.
+        assert (J4: ImpLRule [(Γ0 ++ x ++ Γ3, A0 :: Δ0 ++ A :: Δ1); (Γ0 ++ B :: x ++ Γ3, A0 :: Δ0 ++ Δ1)]
+        (Γ0 ++ A --> B :: x ++ Γ3, A0 :: Δ0 ++ Δ1)).
+        assert (A0 :: Δ0 ++ A :: Δ1 = (A0 :: Δ0) ++ A :: Δ1). reflexivity. rewrite H0. clear H0.
+        assert (A0 :: Δ0 ++ Δ1 = (A0 :: Δ0) ++ Δ1). reflexivity. rewrite H0. clear H0.
+        apply ImpLRule_I.
+        pose (IH _ J2 _ _ J3). destruct p. pose (s0 _ _ J4). clear s. destruct s1. clear s0. destruct s.
+        destruct p.
+        assert (J5: derrec_height x1 < S (dersrec_height d)). lia.
+        assert (J6: derrec_height x1 = derrec_height x1). reflexivity.
+        assert (J7: ImpLRule [(Γ0 ++ x ++ B0 :: Γ3, Δ0 ++ A :: Δ1); (Γ0 ++ B :: x ++ B0 :: Γ3, Δ0 ++ Δ1)]
+        ((Γ0 ++ A --> B :: x) ++ B0 :: Γ3, Δ2 ++ Δ3)). rewrite H3. rewrite <- app_assoc.
+        apply ImpLRule_I. pose (IH _ J5 _ _ J6). destruct p. pose (s0 _ _ J7). clear s.
+        destruct s1. clear s0. destruct s. destruct p.
+        assert (existsT2 (x7 : derrec KS_rules (fun _ : Seq => False)
+        (Γ0 ++ x ++ A0 --> B0 :: Γ3, Δ0 ++ A :: Δ1)), derrec_height x7 <= S (dersrec_height d)).
+        assert (ImpLRule [(Γ0 ++ x ++ Γ3, A0 :: Δ0 ++ A :: Δ1); (Γ0 ++ x ++ B0 :: Γ3, Δ0 ++ A :: Δ1)]
+        (Γ0 ++ x ++ A0 --> B0 :: Γ3, Δ0 ++ A :: Δ1)).
+        assert (A0 :: Δ0 ++ A :: Δ1 = [] ++ A0 :: Δ0 ++ A :: Δ1). reflexivity. rewrite H0. clear H0.
+        assert (Δ0 ++ A :: Δ1 = [] ++ Δ0 ++ A :: Δ1). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ x ++ Γ3 = (Γ0 ++ x) ++ Γ3). rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ x ++ B0 :: Γ3 = (Γ0 ++ x) ++ B0 :: Γ3). rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ x ++ A0 --> B0 :: Γ3 = (Γ0 ++ x) ++ A0 --> B0 :: Γ3). rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        apply ImpLRule_I. apply ImpL in H0.
+        pose (dlCons x5 DersNilF). pose (dlCons x3 d0).
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(Γ0 ++ x ++ Γ3, A0 :: Δ0 ++ A :: Δ1); (Γ0 ++ x ++ B0 :: Γ3, Δ0 ++ A :: Δ1)])
+        (Γ0 ++ x ++ A0 --> B0 :: Γ3, Δ0 ++ A :: Δ1) H0 d1).
+        exists d2. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+        destruct X. exists x7.
+        assert (existsT2 (x8 : derrec KS_rules (fun _ : Seq => False)
+        (Γ0 ++ B :: x ++ A0 --> B0 :: Γ3, Δ0 ++ Δ1)), derrec_height x8 <= S (dersrec_height d)).
+        assert (ImpLRule [(Γ0 ++ B :: x ++ Γ3, A0 :: Δ0 ++ Δ1); (Γ0 ++ B :: x ++ B0 :: Γ3, Δ0 ++ Δ1)]
+        (Γ0 ++ B :: x ++ A0 --> B0 :: Γ3, Δ0 ++ Δ1)).
+        assert (Δ0 ++ Δ1 = [] ++ Δ0 ++ Δ1). reflexivity. rewrite H0. clear H0.
+        assert (A0 :: [] ++ Δ0 ++ Δ1 = [] ++ A0 :: Δ0 ++ Δ1). reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ B :: x ++ Γ3 = (Γ0 ++ B :: x) ++ Γ3). rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ B :: x ++ B0 :: Γ3 = (Γ0 ++ B :: x) ++ B0 :: Γ3). rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        assert (Γ0 ++ B :: x ++ A0 --> B0 :: Γ3 = (Γ0 ++ B :: x) ++ A0 --> B0 :: Γ3). rewrite <- app_assoc. reflexivity. rewrite H0. clear H0.
+        apply ImpLRule_I. apply ImpL in H0.
+        pose (dlCons x6 DersNilF). pose (dlCons x4 d0).
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[(Γ0 ++ B :: x ++ Γ3, A0 :: Δ0 ++ Δ1); (Γ0 ++ B :: x ++ B0 :: Γ3, Δ0 ++ Δ1)])
+        (Γ0 ++ B :: x ++ A0 --> B0 :: Γ3, Δ0 ++ Δ1) H0 d1).
+        exists d2. simpl. rewrite dersrec_height_nil. lia. reflexivity.
+        destruct X. exists x8. split. lia. lia. }
+  (* KR *)
+  * inversion X. subst. pose (univ_gen_ext_splitR _ _ X0). repeat destruct s. repeat destruct p. subst.
+    assert (J0: dersrec_height d = dersrec_height d). reflexivity.
+    pose (dersrec_derrec_height d J0). destruct s.
+    assert (KRRule [(unboxed_list (x ++ x0), [A0])] (Γ0 ++ Γ1, Δ0 ++ Δ1)).
+    rewrite <- H2. apply KRRule_I ; try assumption. apply univ_gen_ext_combine.
+    assumption. apply univ_gen_ext_not_In_delete with (a:=A --> B). intro.
+    assert (In (A --> B) (x ++ x0)). apply in_or_app. auto. apply H1 in H0. destruct H0.
+    inversion H0. assumption.
+    assert (existsT2 (D : derrec KS_rules (fun _ : Seq => False) (Γ0 ++ Γ1, Δ0 ++ Δ1)),
+    derrec_height D <= S (dersrec_height d)).
+    apply KR in X1.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[(unboxed_list (x ++ x0), [A0])]) (Γ0 ++ Γ1, Δ0 ++ Δ1) X1 d).
+    exists d0. simpl. lia.
+    destruct X2.
+    assert (J1: derrec_height x2 = derrec_height x2). reflexivity.
+    assert (J2: wkn_L B (Γ0 ++ Γ1, Δ0 ++ Δ1) (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)). apply wkn_LI.
+    pose (KS_wkn_L _ _ x2 J1 _ _ J2). destruct s.
+    assert (J3: wkn_R A (Γ0 ++ Γ1, Δ0 ++ Δ1) (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)). apply wkn_RI.
+    pose (KS_wkn_R _ _ x2 J1 _ _ J3). destruct s. exists x4. exists x3. simpl.
+    split ; lia. }
+Qed.
+ +
+Theorem ImpR_inv : forall concl prem, (KS_prv concl) ->
+                                      (ImpRRule [prem] concl) ->
+                                      (KS_prv prem).
+Proof.
+intros.
+assert (J1: derrec_height X = derrec_height X). reflexivity.
+pose (ImpR_ImpL_hpinv _ _ X J1). destruct p. pose (s _ H). destruct s1. assumption.
+Qed.
+ +
+Theorem ImpL_inv : forall concl prem1 prem2, (KS_prv concl) ->
+                                      (ImpLRule [prem1;prem2] concl) ->
+                                      (KS_prv prem1) *
+                                      (KS_prv prem2).
+Proof.
+intros.
+assert (J1: derrec_height X = derrec_height X). reflexivity.
+pose (ImpR_ImpL_hpinv _ _ X J1). destruct p. pose (s0 _ _ H). repeat destruct s1. auto.
+Qed.
+
+
+ +
+ + + diff --git a/K.KS.KS_termination.html b/K.KS.KS_termination.html new file mode 100644 index 0000000..58cc2dc --- /dev/null +++ b/K.KS.KS_termination.html @@ -0,0 +1,579 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_termination

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat Arith.
+ +
+Require Import KS_calc.
+Require Import KS_dec.
+Require Import KS_termination_measure.
+Require Export KS_termination_prelims.
+Require Export KS_termination_init.
+Require Export KS_termination_ImpR.
+Require Export KS_termination_ImpL.
+Require Export KS_termination_KR.
+ +
+(* Now that we have the list of all premises of a sequent via all rules, we can combine
+   them all to obtain the list of all potential premises via the KS calculus. *)

+ +
+Lemma finite_premises_of_S : forall (s : Seq), existsT2 listprems,
+              (forall prems, ((KS_rules prems s) -> (InT prems listprems)) *
+                             ((InT prems listprems) -> (KS_rules prems s))).
+Proof.
+intro s.
+destruct (dec_KS_rules s).
+- exists []. intros. split. intro. exfalso. apply f. exists prems. assumption.
+  intro. inversion H.
+- pose (finite_IdP_premises_of_S s). destruct s1.
+  pose (finite_BotL_premises_of_S s). destruct s1.
+  pose (finite_ImpR_premises_of_S s). destruct s1.
+  pose (finite_ImpL_premises_of_S s). destruct s1.
+  pose (finite_KR_premises_of_S s). destruct s1.
+  exists (x ++ x0 ++ x1 ++ x2 ++ x3).
+  split.
+  * intro RA. inversion RA.
+    { inversion H. subst. pose (p []). destruct p4. apply InT_or_app. auto. }
+    { inversion H. subst. pose (p0 []). destruct p4. apply InT_or_app. right. apply InT_or_app. auto. }
+    { inversion H. subst. pose (p1 [(Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)]). destruct p4.
+      apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. left. auto. }
+    { inversion H. subst. pose (p2 [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]).
+      destruct p4. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right.
+      apply InT_or_app. left. auto. }
+    { inversion X. subst. pose (p3 [(unboxed_list , [A])]).
+      destruct p4. apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app.
+      right. apply InT_or_app. auto. }
+  * intro. apply InT_app_or in H. destruct H.
+    { apply p in i. apply IdP ; try intro ; try apply f ; try auto ; try assumption. }
+    { apply InT_app_or in i. destruct i.
+      - apply p0 in i. apply BotL ; try intro ; try apply f ; try auto ; try assumption.
+      - apply InT_app_or in i. destruct i.
+        + apply p1 in i. apply ImpR ; try intro ; try apply f ; try auto ; try assumption.
+        + apply InT_app_or in i. destruct i.
+          * apply p2 in i. apply ImpL ; try intro ; try apply f ; try auto ; try assumption.
+          * apply p3 in i. apply KR ; try intro ; try apply f ; try auto ; try assumption. }
+Qed.
+ +
+(* The next definitions "flattens" a list of lists of premises to a list of premises.*)
+ +
+Definition list_of_premises (s : Seq) : list Seq :=
+         flatten_list (proj1_sigT2 (finite_premises_of_S s)).
+ +
+Lemma InT_list_of_premises_exists_prems : forall s prem, InT prem (list_of_premises s) ->
+            existsT2 prems, (InT prem prems) * (KS_rules prems s).
+Proof.
+intros s prem X. unfold list_of_premises in X.
+apply InT_flatten_list_InT_elem in X. destruct X. destruct p.
+exists x. split. auto.
+destruct (finite_premises_of_S s). pose (p x). destruct p0. apply k. assumption.
+Qed.
+ +
+Lemma exists_prems_InT_list_of_premises : forall s prem,
+            (existsT2 prems, (InT prem prems) * (KS_rules prems s)) ->
+            InT prem (list_of_premises s).
+Proof.
+intros. destruct X. destruct p. unfold list_of_premises. destruct (finite_premises_of_S s).
+pose (p x). destruct p0. apply InT_trans_flatten_list with (bs:=x). assumption. simpl. apply i0.
+assumption.
+Qed.
+ +
+Lemma find_the_max_mhd : forall concl l
+      (Prem_mhd : forall prems : list Seq, KS_rules prems concl ->
+                  forall prem : Seq, InT prem prems ->
+                  existsT2 Dprem : derrec KS_rules (fun _ : Seq => True) prem,
+                  is_mhd Dprem)
+      (H1 : forall prem : Seq, InT prem l -> InT prem (list_of_premises concl))
+      (H2 : forall (prem : Seq) (J : InT prem l), InT prem (proj1_sigT2
+            (InT_list_of_premises_exists_prems concl _ (H1 prem J))))
+      (H3 : forall (prem : Seq) (J : InT prem l), KS_rules (proj1_sigT2
+            (InT_list_of_premises_exists_prems concl _ (H1 prem J))) concl)
+      (NotNil: l <> nil),
+
+existsT2 prem, existsT2 (J0: InT prem l), forall prem' (J1: InT prem' l),
+       (derrec_height (proj1_sigT2 (Prem_mhd
+        (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 prem' J1)))
+        (H3 prem' J1)
+        prem'
+        (H2 prem' J1))))
+       <=
+       (derrec_height (proj1_sigT2 (Prem_mhd
+        (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 prem J0)))
+        (H3 prem J0)
+        prem
+        (H2 prem J0)))).
+Proof.
+induction l ; intros.
+- exfalso. apply NotNil. reflexivity.
+- clear NotNil. destruct l as [ | r l].
+  * exists a. assert (InT a [a]). apply InT_eq. exists H. intros. inversion J1. subst.
+    destruct (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 prem' H))) (H3 prem' H) prem' (H2 prem' H)).
+    destruct (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 prem' J1))) (H3 prem' J1) prem' (H2 prem' J1)).
+    simpl. auto. inversion H4.
+  * assert (H1' : forall prem : Seq, InT prem (r :: l) -> InT prem (list_of_premises concl)).
+    { intros. apply H1. apply InT_cons. assumption. }
+    assert (Prem_mhd' : forall prems : list Seq, KS_rules prems concl -> forall prem : Seq,
+                        InT prem prems -> existsT2 Dprem : derrec KS_rules (fun _ : Seq => True)
+                        prem, is_mhd Dprem).
+    { intros. apply Prem_mhd with (prems:= prems) ; try assumption. }
+    assert (H2' : forall (prem : Seq) (J : InT prem (r :: l)), InT prem (proj1_sigT2
+                  (InT_list_of_premises_exists_prems concl _ (H1' prem J)))).
+    { intros. assert (InT prem (a :: r :: l)). apply InT_cons. assumption. pose (H2 _ H).
+      destruct (InT_list_of_premises_exists_prems concl _ (H1' prem J)).
+      simpl. destruct p. assumption. }
+    assert (H3' : forall (prem : Seq) (J : InT prem (r :: l)), KS_rules
+                (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1' prem J))) concl).
+    { intros. destruct (InT_list_of_premises_exists_prems concl _ (H1' prem J)). simpl. destruct p.
+      assumption. }
+    assert (r :: l <> []). intro. inversion H.
+    pose (IHl Prem_mhd' H1' H2' H3' H). destruct s. destruct s.
+    (* I have a max in r :: l: so I simply need to compare it with a. *)
+    assert (J2: InT a (a :: r :: l)). apply InT_eq.
+    assert (J3: InT x (a :: r :: l)). apply InT_cons. assumption.
+    (* The next assert decides on le between mhd of a and mhd of x. *)
+    pose (le_dec
+      (derrec_height (proj1_sigT2 (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 a J2)))
+      (H3 a J2) a (H2 a J2))))
+      (derrec_height
+       (proj1_sigT2
+          (Prem_mhd' (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1' x x0)))
+             (H3' x x0) x (H2' x x0))))).
+    destruct s.
+    + exists x. exists J3. intros. inversion J1. subst.
+      destruct (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 prem' J1)))
+      (H3 prem' J1) prem' (H2 prem' J1)). simpl.
+      destruct (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 prem' J2)))
+      (H3 prem' J2) prem' (H2 prem' J2)). simpl in l1. unfold is_mhd in i0.
+      pose (i0 x1).
+      destruct (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 x J3))) (H3 x J3) x (H2 x J3)).
+      simpl.
+      destruct (Prem_mhd' (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1' x x0)))
+      (H3' x x0) x (H2' x x0)). simpl in l1.
+      unfold is_mhd in i1. pose (i1 x4). lia.
+      destruct (Prem_mhd' (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1' x x0)))
+      (H3' x x0) x (H2' x x0)). simpl in l0.
+      destruct (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 x J3))) (H3 x J3) x (H2 x J3)).
+      simpl.
+      destruct (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 prem' J1)))). simpl.
+      assert (derrec_height
+     (proj1_sigT2
+        (Prem_mhd' (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1' prem' H4)))
+           (H3' prem' H4) prem' (H2' prem' H4))) <= derrec_height x1).
+      apply (l0 prem' H4). subst.
+      unfold is_mhd in i0. pose (i0 x1).
+      destruct (Prem_mhd' (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1' prem' H4)))
+           (H3' prem' H4) prem' (H2' prem' H4)). simpl in H6. unfold is_mhd in i2. pose (i2 x3). lia.
+    + exists a. exists J2. intros.
+      inversion J1.
+      { subst. destruct (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 prem' J1)))
+        (H3 prem' J1) prem' (H2 prem' J1)). simpl.
+        destruct (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 prem' J2)))
+        (H3 prem' J2) prem' (H2 prem' J2)).
+        simpl. unfold is_mhd in i0. pose (i0 x1). lia. }
+      { subst.
+        destruct (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 a J2))) (H3 a J2) a (H2 a J2)).
+        simpl.
+        destruct (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 prem' J1)))
+        (H3 prem' J1) prem' (H2 prem' J1)). simpl.
+        destruct (Prem_mhd' (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1' x x0)))
+             (H3' x x0) x (H2' x x0)). simpl in l0.
+        assert (derrec_height
+       (proj1_sigT2
+          (Prem_mhd' (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1' prem' H4)))
+             (H3' prem' H4) prem' (H2' prem' H4))) <= derrec_height x3). apply l0.
+       destruct (Prem_mhd' (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1' prem' H4)))
+             (H3' prem' H4) prem' (H2' prem' H4)). simpl in H0. unfold is_mhd in i2.
+       pose (i2 x2). simpl in *. lia. }
+Qed.
+ +
+Lemma term_IH_help : forall concl,
+     (existsT2 prems, (KS_rules prems concl) * (prems <> [])) ->
+     (forall prems, KS_rules prems concl -> (forall prem, InT prem prems -> (existsT2 Dprem, @is_mhd prem Dprem)))
+      ->
+     (existsT2 Maxprems Maxprem DMaxprem, (KS_rules Maxprems concl) * (@is_mhd Maxprem DMaxprem) * (InT Maxprem Maxprems) *
+        (forall prems prem (Dprem : KS_drv prem), KS_rules prems concl -> InT prem prems ->
+            derrec_height Dprem <= derrec_height DMaxprem)).
+Proof.
+intros concl FAH Prem_mhd.
+pose (list_of_premises concl).
+assert (H1: forall prem, InT prem l -> InT prem (list_of_premises concl)).
+intros. auto.
+assert (H2: forall prem (J: InT prem l), InT prem (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 prem J)))).
+intros. destruct (InT_list_of_premises_exists_prems concl _ (H1 prem J)). destruct p. auto.
+assert (H3: forall prem (J: InT prem l),
+KS_rules (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 prem J))) concl).
+intros. destruct (InT_list_of_premises_exists_prems concl _ (H1 prem J)). destruct p. auto.
+assert (H4: forall prem (J: InT prem l), is_mhd (proj1_sigT2 (Prem_mhd
+        (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 prem J)))
+        (H3 prem J)
+        prem
+        (H2 prem J)))).
+intros. intro. destruct (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 prem J)))
+(H3 prem J) prem (H2 prem J)). auto.
+assert (l <> []). intro. destruct FAH. destruct p. destruct k.
+- inversion i. subst. auto.
+- inversion b. subst. auto.
+- inversion i. subst. pose (@exists_prems_InT_list_of_premises (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1) (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)).
+  assert (InT (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) (list_of_premises (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1))). apply i0.
+  exists [(Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)]. split. apply InT_eq. apply ImpR ; assumption.
+  assert (InT (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) l). auto. rewrite H in H5. inversion H5.
+- inversion i. subst. pose (@exists_prems_InT_list_of_premises (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1) (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)).
+  assert (InT (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) (list_of_premises (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1))). apply i0.
+  exists [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]. split. apply InT_eq. apply ImpL ; assumption.
+  assert (InT (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) l). auto. rewrite H in H5. inversion H5.
+- inversion k. subst. pose (@exists_prems_InT_list_of_premises (Γ0, Δ0 ++ Box A :: Δ1) (unboxed_list , [A])).
+  assert (InT (unboxed_list , [A]) (list_of_premises (Γ0, Δ0 ++ Box A :: Δ1))). apply i.
+  exists [(unboxed_list , [A])]. split. apply InT_eq. apply KR ; assumption.
+  assert (InT (unboxed_list , [A]) l). auto. rewrite H in H6. inversion H6.
+ +
+- pose (find_the_max_mhd _ _ Prem_mhd H1 H2 H3 H).
+  destruct s. destruct s. exists (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 x x0))).
+  exists x. exists (proj1_sigT2 (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 x x0)))
+  (H3 x x0) x (H2 x x0))). repeat split ; try apply H3 ; try apply H4 ; try apply H2.
+  intros prems prem Dprem RA IsPrem.
+  assert (J3: InT prem l).
+  pose (@exists_prems_InT_list_of_premises concl prem). apply i. exists prems. auto.
+  assert (E1: derrec_height Dprem <= derrec_height (proj1_sigT2 (Prem_mhd (proj1_sigT2
+  (InT_list_of_premises_exists_prems concl _ (H1 prem J3))) (H3 prem J3) prem (H2 prem J3)))).
+  destruct (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 prem J3)))
+  (H3 prem J3) prem (H2 prem J3)). auto.
+  assert (E2: derrec_height (proj1_sigT2 (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl
+  _ (H1 prem J3))) (H3 prem J3) prem (H2 prem J3))) <=
+  derrec_height (proj1_sigT2 (Prem_mhd (proj1_sigT2 (InT_list_of_premises_exists_prems concl _ (H1 x x0)))
+  (H3 x x0) x (H2 x x0)))). apply l0. lia.
+Qed.
+ +
+Lemma in_drs_concl_in_allT W rules prems ps (cn : W) (drs : dersrec rules prems ps)
+  (dtn : derrec rules prems cn) : in_dersrec dtn drs -> InT cn ps.
+Proof.
+intro ind. induction ind. apply InT_eq.
+apply InT_cons. assumption.
+Qed.
+ +
+Lemma dec_non_nil_prems: forall (concl : Seq), ((existsT2 prems, (KS_rules prems concl) * (prems <> []))) +
+                                       ((existsT2 prems, (KS_rules prems concl) * (prems <> [])) -> False).
+Proof.
+intros. destruct (dec_KR_rule concl).
+  + destruct s. left. exists [x]. split. apply KR in k ; auto. intro. inversion H.
+  + destruct (dec_ImpR_rule concl).
+    * destruct s. left. exists [x]. split. apply ImpR in i. assumption. intro. inversion H.
+    * destruct (dec_ImpL_rule concl).
+      { destruct s. destruct s. left. exists [x; x0]. split. apply ImpL in i. assumption.
+        intro. inversion H. }
+      { right. intro. destruct X. destruct p. inversion k.
+        - subst. inversion H. auto.
+        - subst. inversion H. auto.
+        - subst. inversion H. subst. apply f0. exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1). assumption.
+        - subst. inversion H. subst. apply f1. exists (Γ0 ++ Γ1, Δ0 ++ A :: Δ1).
+          exists (Γ0 ++ B :: Γ1, Δ0 ++ Δ1). assumption.
+        - subst. inversion X. subst. apply f. exists (unboxed_list , [A]). assumption. }
+Qed.
+ +
+(* The next theorem claims that every sequent s has a derivation DMax of maximal height. *)
+ +
+Theorem KS_termin_base : forall n s, (n = measure s) ->
+   existsT2 (DMax : KS_drv s), (@is_mhd s DMax).
+Proof.
+induction n as [n IH] using (well_founded_induction_type lt_wf).
+assert (dersrecnil: dersrec KS_rules (fun _ => True) nil).
+apply dersrec_nil.
+intros. pose (dec_KS_rules s). destruct s0.
+- assert (forall ps : list Seq, KS_rules ps s -> False).
+  intros. apply f. exists ps. assumption. pose (@no_KS_rule_applic s H0).
+  pose (dpI KS_rules (fun _ : Seq => True) s I).
+  exists d. unfold is_mhd. intros. simpl. pose (e D1). rewrite e0. auto.
+- assert (forall prems, KS_rules prems s -> (forall prem, InT prem prems ->
+  (existsT2 Dprem, @is_mhd prem Dprem))).
+  { simpl. intros prems X prem X0. inversion X.
+    - inversion H0. subst. exfalso. inversion X0.
+    - inversion H0. subst. exfalso. inversion X0.
+    - inversion H0. subst. inversion X0. 2: inversion H1. subst.
+      assert (J0: measure (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) < measure (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)).
+      unfold measure. simpl.
+      repeat rewrite size_LF_dist_app. simpl. lia.
+      pose (IH (measure (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)) J0 (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)).
+      apply s. reflexivity.
+    - inversion H0. subst. inversion X0 ; subst.
+     + assert (J0: measure (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) < measure (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+        unfold measure. simpl. repeat rewrite size_LF_dist_app. simpl. lia.
+        pose (IH (measure (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)) J0 (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)).
+        apply s. reflexivity.
+     + inversion H1. subst.
+        assert (J0: measure (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) < measure (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+        unfold measure. simpl. repeat rewrite size_LF_dist_app. simpl. lia.
+        pose (IH (measure (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) J0 (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)).
+        apply s. reflexivity. inversion H2.
+    - inversion X1. subst. inversion X0. 2: inversion H0. subst.
+      assert (J0: measure (unboxed_list , [A]) < measure (Γ0, Δ0 ++ Box A :: Δ1)).
+      unfold measure. simpl. repeat rewrite size_LF_dist_app. simpl.
+      pose (size_nobox_gen_ext _ _ X2). pose (size_unboxed ). lia.
+      pose (IH (measure (unboxed_list , [A])) J0 (unboxed_list , [A])).
+      apply s. reflexivity. }
+    destruct (dec_non_nil_prems s).
+    + pose (@term_IH_help s s1 X). repeat destruct s2. destruct p. destruct p. destruct p.
+      inversion k.
+      (* Use PIH and SIH here, depending on the rule applied *)
+      * inversion H0. subst. inversion i.
+      * inversion H0. subst. inversion i.
+      * subst. inversion H0. subst. assert (E: x0 = (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)).
+        inversion i. auto. inversion H1. subst.
+        pose (dlCons x1 dersrecnil).
+        pose (@derI _ _ (fun _ : Seq => True) [(Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)] (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1) k d).
+        exists d0. unfold is_mhd. intros. simpl. rewrite dersrec_height_nil with (ds:=dersrecnil). rewrite Nat.max_0_r.
+        destruct D1.
+        { simpl. lia. }
+        { simpl.
+          assert (forall p (d : derrec KS_rules (fun _ : Seq => True) p),
+          in_dersrec d d1 -> derrec_height d <= (derrec_height x1)). intros.
+          pose (@in_drs_concl_in_allT _ _ _ _ _ _ _ X0). subst. pose (l ps p d2 k0 i1). assumption.
+          pose (dersrec_height_le H). lia. }
+        { reflexivity. }
+      * subst. inversion H0. subst. inversion i.
+        { subst. pose (dpI KS_rules (fun _ : Seq => True) (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) I).
+          pose (dlCons d dersrecnil). pose (dlCons x1 d0).
+          pose (@derI _ _ (fun _ : Seq => True) [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]
+          (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1) k d1).
+          exists d2. unfold is_mhd. intros. simpl. rewrite dersrec_height_nil with (ds:=dersrecnil). rewrite Nat.max_0_r.
+          destruct D1.
+          { simpl. lia. }
+          { simpl.
+            assert (forall p (d : derrec KS_rules (fun _ : Seq => True) p),
+            in_dersrec d d3 -> derrec_height d <= (derrec_height x1)). intros.
+            pose (@in_drs_concl_in_allT _ _ _ _ _ _ _ X0). subst. pose (l ps p d4 k0 i1). assumption.
+            pose (dersrec_height_le H). lia. }
+          { reflexivity. } }
+        { inversion H1. subst. pose (dpI KS_rules (fun _ : Seq => True) (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) I).
+          pose (dlCons x1 dersrecnil). pose (dlCons d d0).
+          pose (@derI _ _ (fun _ : Seq => True) [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]
+          (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1) k d1).
+          exists d2. unfold is_mhd. intros. simpl. rewrite dersrec_height_nil with (ds:=dersrecnil). rewrite Nat.max_0_r.
+          destruct D1.
+          { simpl. lia. }
+          { simpl.
+            assert (forall p (d : derrec KS_rules (fun _ : Seq => True) p),
+            in_dersrec d d3 -> derrec_height d <= (derrec_height x1)). intros.
+            pose (@in_drs_concl_in_allT _ _ _ _ _ _ _ X0). subst. pose (l ps p d4 k0 i1). assumption.
+            pose (dersrec_height_le H). lia. }
+          { reflexivity. }
+          inversion H4. }
+      * subst. inversion X0. subst. assert (E: x0 = (unboxed_list , [A])).
+        inversion i. subst. auto. inversion H1. subst.
+        pose (dlCons x1 dersrecnil).
+        pose (@derI _ _ (fun _ : Seq => True) [(unboxed_list , [A])] (Γ0, Δ0 ++ Box A :: Δ1) k d).
+        exists d0. unfold is_mhd. intros. simpl. rewrite dersrec_height_nil with (ds:=dersrecnil). rewrite Nat.max_0_r.
+        destruct D1.
+        { simpl. lia. }
+        { simpl.
+          assert (forall p (d : derrec KS_rules (fun _ : Seq => True) p),
+          in_dersrec d d1 -> derrec_height d <= (derrec_height x1)). intros.
+          pose (@in_drs_concl_in_allT _ _ _ _ _ _ _ X2). subst. pose (l ps p d2 k0 i1). assumption.
+          pose (dersrec_height_le H0). lia. }
+        { reflexivity. }
+    + destruct s0. inversion k.
+      * inversion H0. subst. pose (@derI _ _ (fun _ : Seq => True) [] (Γ0 ++ # P :: Γ1, Δ0 ++ # P :: Δ1) k dersrecnil).
+        exists d. unfold is_mhd. intros. simpl. rewrite dersrec_height_nil with (ds:=dersrecnil).
+        destruct D1.
+        { simpl. lia. }
+        { simpl. destruct k0.
+          - inversion i. subst. rewrite dersrec_height_nil with (ds:=d0). lia. reflexivity.
+          - inversion b. subst. rewrite dersrec_height_nil with (ds:=d0). lia. reflexivity.
+          - inversion i. subst. exfalso. apply f. exists [(Γ2 ++ A :: Γ3, Δ2 ++ B :: Δ3)]. split.
+            apply ImpR in i. assumption. intro. inversion H.
+          - inversion i. subst. exfalso. apply f. exists [(Γ2 ++ Γ3, Δ2 ++ A :: Δ3); (Γ2 ++ B :: Γ3, Δ2 ++ Δ3)]. split.
+            apply ImpL in i. assumption. intro. inversion H.
+          - inversion k0. subst. exfalso. apply f. exists [(unboxed_list , [A])]. split.
+            apply KR in k0. assumption. intro. inversion H1. }
+        { reflexivity. }
+      * inversion H0. subst. pose (@derI _ _ (fun _ : Seq => True) [] (Γ0 ++ Bot :: Γ1, Δ) k dersrecnil).
+        exists d. unfold is_mhd. intros. simpl. rewrite dersrec_height_nil with (ds:=dersrecnil).
+        destruct D1.
+        { simpl. lia. }
+        { simpl. destruct k0.
+          - inversion i. subst. rewrite dersrec_height_nil with (ds:=d0). lia. reflexivity.
+          - inversion b. subst. rewrite dersrec_height_nil with (ds:=d0). lia. reflexivity.
+          - inversion i. subst. exfalso. apply f. exists [(Γ2 ++ A :: Γ3, Δ0 ++ B :: Δ1)]. split.
+            apply ImpR in i. assumption. intro. inversion H.
+          - inversion i. subst. exfalso. apply f. exists [(Γ2 ++ Γ3, Δ0 ++ A :: Δ1); (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)]. split.
+            apply ImpL in i. assumption. intro. inversion H.
+          - inversion k0. subst. exfalso. apply f. exists [(unboxed_list , [A])]. split.
+            apply KR in k0. assumption. intro. inversion H1. }
+        { reflexivity. }
+      * inversion H0. subst. exfalso. apply f. exists [(Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)]. split. assumption. intro.
+        inversion H.
+      * inversion H0. subst. exfalso. apply f. exists [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]. split. assumption. intro.
+        inversion H.
+      * inversion X0. subst. exfalso. apply f. exists [(unboxed_list , [A])]. split. assumption. intro.
+        inversion H.
+Qed.
+ +
+Theorem KS_termin : forall s, existsT2 (DMax : KS_drv s), (@is_mhd s DMax).
+Proof.
+intro s. pose (@KS_termin_base (measure s)). apply s0 ; reflexivity.
+Qed.
+ +
+Theorem KS_termin1 : forall (s : Seq), exists (DMax : KS_drv s), (is_mhd DMax).
+Proof.
+intro s.
+assert (J1: measure s = measure s). reflexivity.
+pose (@KS_termin_base (measure s) s J1).
+destruct s0. exists x. assumption.
+Qed.
+ +
+Theorem KS_termin2 : forall s, exists (DMax : KS_drv s), (is_mhd DMax).
+Proof.
+intro s.
+assert (J1: measure s = measure s). reflexivity.
+pose (@KS_termin_base (measure s) s J1 ).
+destruct s0. exists x. assumption.
+Qed.
+ +
+Theorem KS_termin3 : forall (s : Seq), existsT2 (DMax : KS_drv s), (is_mhd DMax).
+Proof.
+intro s. pose (@KS_termin_base (measure s)). apply s0 ; reflexivity.
+Qed.
+ +
+(* Now we can prove that the maximal height of derivations (mhd) for sequents
+   decreases upwards in the applicability of the proofs. In other words, if a sequent s is the
+   conclusion of an instance of a rule R of KS with premises in ps, then for any element s0 of
+   ps we have that (mhd s0) < (mhd s).
+
+   To do so we first define mhd.*)

+ +
+Definition mhd (s: Seq) : nat := derrec_height (proj1_sigT2 (KS_termin s)).
+ +
+Lemma KS_termin_der_is_mhd : forall s, (@is_mhd s (proj1_sigT2 (@KS_termin s))).
+Proof.
+intro s. destruct KS_termin. auto.
+Qed.
+ +
+Theorem RA_mhd_decreases : forall prems concl, (KS_rules prems concl) ->
+                             (forall prem, (In prem prems) -> (mhd prem) < (mhd concl)).
+Proof.
+intros. inversion X.
+- inversion H0. subst. inversion H.
+- inversion H0. subst. inversion H.
+- inversion H0. subst. inversion H.
+  * subst. apply le_False_lt. intro.
+    pose (d:= proj1_sigT2 (KS_termin (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1))).
+    pose (d0:=proj1_sigT2 (KS_termin (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1))).
+    assert (dersrecnil: dersrec KS_rules (fun _ => True) nil).
+    apply dersrec_nil. pose (dlCons d0 dersrecnil).
+    pose (@derI _ _ (fun _ : Seq => True) [(Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)] (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1) X d1).
+    assert (E1: derrec_height d0 = mhd (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)).
+    unfold mhd. auto.
+    assert (E2: derrec_height d = mhd (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)).
+    unfold mhd. auto.
+    assert (@is_mhd (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1) d). apply KS_termin_der_is_mhd.
+    unfold is_mhd in H2. pose (H2 d2). simpl in l. rewrite dersrec_height_nil in l. rewrite Nat.max_0_r in l.
+    lia. reflexivity.
+  * inversion H1.
+- inversion H0. subst. inversion H.
+    * subst. apply le_False_lt. intro.
+      pose (d:=proj1_sigT2 (KS_termin (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1))).
+      pose (d0:=proj1_sigT2 (KS_termin (Γ0 ++ Γ1, Δ0 ++ A :: Δ1))).
+      assert (dersrecnil: dersrec KS_rules (fun _ => True) nil).
+      apply dersrec_nil.
+      pose (dpI KS_rules (fun _ : Seq => True) (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) I).
+      pose (dlCons d1 dersrecnil). pose (dlCons d0 d2).
+      pose (@derI _ _ (fun _ : Seq => True) [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]
+      (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1) X d3).
+      assert (E1: derrec_height d0 = mhd (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)).
+      unfold mhd. auto.
+      assert (E2: derrec_height d = mhd (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+      unfold mhd. auto.
+      assert (@is_mhd (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1) d). apply KS_termin_der_is_mhd.
+      unfold is_mhd in H2. pose (H2 d4). simpl in l. rewrite dersrec_height_nil in l. rewrite Nat.max_0_r in l.
+      lia. reflexivity.
+    * inversion H1. subst. apply le_False_lt. intro.
+      pose (d:=proj1_sigT2 (KS_termin (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1))).
+      pose (d0:=proj1_sigT2 (KS_termin (Γ0 ++ B :: Γ1, Δ0 ++ Δ1))).
+      assert (dersrecnil: dersrec KS_rules (fun _ => True) nil).
+      apply dersrec_nil.
+      pose (dpI KS_rules (fun _ : Seq => True) (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) I).
+      pose (dlCons d0 dersrecnil). pose (dlCons d1 d2).
+      pose (@derI _ _ (fun _ : Seq => True) [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]
+      (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1) X d3).
+      assert (E1: derrec_height d0 = mhd (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)).
+      unfold mhd. auto.
+      assert (E2: derrec_height d = mhd (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+      unfold mhd. auto.
+      assert (@is_mhd (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1) d). apply KS_termin_der_is_mhd.
+      unfold is_mhd in H3. pose (H3 d4). simpl in l. rewrite dersrec_height_nil in l. rewrite Nat.max_0_r in l.
+      simpl in l. lia. reflexivity. inversion H2.
+- inversion X0. subst. inversion H.
+  * subst. apply le_False_lt. intro.
+    pose (d:=proj1_sigT2 (KS_termin (Γ0, Δ0 ++ Box A :: Δ1))).
+    pose (d0:=proj1_sigT2 (KS_termin (unboxed_list , [A]))).
+    assert (dersrecnil: dersrec KS_rules (fun _ => True) nil).
+    apply dersrec_nil. pose (dlCons d0 dersrecnil).
+    pose (@derI _ _ (fun _ : Seq => True) [(unboxed_list , [A])] (Γ0, Δ0 ++ Box A :: Δ1) X d1).
+    assert (E1: derrec_height d0 = mhd (unboxed_list , [A])).
+    unfold mhd. auto.
+    assert (E2: derrec_height d = mhd (Γ0, Δ0 ++ Box A :: Δ1)).
+    unfold mhd. auto.
+    assert (@is_mhd (Γ0, Δ0 ++ Box A :: Δ1) d). apply KS_termin_der_is_mhd.
+    unfold is_mhd in H1. pose (H1 d2). simpl in l. rewrite dersrec_height_nil in l. rewrite Nat.max_0_r in l.
+    lia. reflexivity.
+  * inversion H0.
+Qed.
+ +
+
+
+ +
+ + + diff --git a/K.KS.KS_termination_ImpL.html b/K.KS.KS_termination_ImpL.html new file mode 100644 index 0000000..c9f2b05 --- /dev/null +++ b/K.KS.KS_termination_ImpL.html @@ -0,0 +1,286 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_termination_ImpL

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat.
+ +
+Require Import KS_calc.
+Require Import KS_dec.
+Require Import KS_termination_measure.
+Require Import KS_termination_prelims.
+Require Import KS_termination_ImpR.
+ +
+(* Then, we turn to the case of the ImpL rule. *)
+ +
+Fixpoint prems_Imp_L (l : list ((MPropF) * nat)) (s : Seq) : list (list Seq) :=
+match l with
+  | nil => nil
+  | (C, n) :: t => match n with
+      | 0 => prems_Imp_L t s
+      | S m => match C with
+           | Imp A B => flatten_list
+                        (map (fun y => map (fun z => [z; y])
+                        (listInsertsL_Seqs ((fst (nth_split m (remove_nth (S m) C (fst s)))) ++
+                        (snd (nth_split m (remove_nth (S m) C (fst s))))) (snd s) A))
+                        [(((fst (nth_split m (remove_nth (S m) C (fst s)))) ++
+                        B :: (snd (nth_split m (remove_nth (S m) C (fst s))))), (snd s))])
+                        ++ (prems_Imp_L t s)
+           | _ => prems_Imp_L t s
+           end
+      end
+end.
+ +
+Definition ImpL_help002 : forall Γ0 Γ1 Δ0 Δ1 A B,
+           InT [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]
+               (flatten_list (map (fun y : list MPropF * list MPropF => map
+               (fun z : list MPropF * list MPropF => [y; z]) [(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+               (listInsertsL_Seqs (Γ0 ++ Γ1) (Δ0 ++ Δ1) A)))
+              .
+Proof.
+intros.
+pose (@InT_trans_flatten_list _ (map (fun y : list MPropF * list MPropF => map
+(fun z : list MPropF * list MPropF => [y; z]) [(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+(listInsertsL_Seqs (Γ0 ++ Γ1) (Δ0 ++ Δ1) A))
+(map (fun z : list MPropF * list MPropF => [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); z])
+[(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]) [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]).
+apply i ; clear i.
+- pose (InT_map_iff (fun z : list MPropF * list MPropF => [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); z]) [(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]
+  [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]).
+  destruct p. clear s. apply i. exists (Γ0 ++ B :: Γ1, Δ0 ++ Δ1). split. reflexivity. apply InT_eq.
+- pose (InT_map_iff (fun y : list MPropF * list MPropF =>
+  map (fun z : list MPropF * list MPropF => [y; z]) [(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])
+  (listInsertsL_Seqs (Γ0 ++ Γ1) (Δ0 ++ Δ1) A) (map (fun z : list MPropF * list MPropF => [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); z])
+  [(Γ0 ++ B :: Γ1, Δ0 ++ Δ1)])).
+  destruct p. apply i. clear i. clear s. exists (Γ0 ++ Γ1, Δ0 ++ A :: Δ1). split. reflexivity.
+  unfold listInsertsL_Seqs.
+  pose (InT_map_iff (fun y : list MPropF => (Γ0 ++ Γ1, y)) (listInserts (Δ0 ++ Δ1) A) (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)).
+  destruct p. apply i. clear s. clear i. exists (Δ0 ++ A :: Δ1). split. reflexivity.
+  unfold listInserts.
+  pose (InT_map_iff (fun y : list MPropF * list MPropF => fst y ++ A :: snd y)
+  (proj1_sigT2 (list_of_splits (Δ0 ++ Δ1))) (Δ0 ++ A :: Δ1)). destruct p. clear s.
+  apply i. clear i. exists (Δ0,Δ1). simpl. split. reflexivity. destruct (list_of_splits (Δ0 ++ Δ1)).
+  simpl. pose (i Δ0 Δ1). apply In_InT_seqs. rewrite <- i0. reflexivity.
+Defined.
+ +
+Definition ImpL_help02 : forall Γ0 Γ1 Δ0 Δ1 A B l n,
+            ImpLRule [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)] (Γ0 ++ (Imp A B) :: Γ1, Δ0 ++ Δ1) ->
+            (length Γ0 = n) ->
+            (In ((Imp A B), S n) l) ->
+            InT [(Γ0 ++ Γ1, Δ0 ++ A :: Δ1); (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)] (prems_Imp_L l (Γ0 ++ (Imp A B) :: Γ1, Δ0 ++ Δ1)).
+Proof.
+induction l ; intros.
+- inversion H1.
+- destruct a. destruct m.
+  * subst. apply In_InT_pair in H1. inversion H1. subst. inversion H2. subst. apply InT_In in H2.
+    assert (J1: length Γ0 = length Γ0). reflexivity.
+    pose (IHl _ H J1 H2). simpl. destruct n0. assumption. assumption.
+  * subst. apply In_InT_pair in H1. inversion H1. subst. inversion H2. subst. apply InT_In in H2.
+    assert (J1: length Γ0 = length Γ0). reflexivity.
+    pose (IHl _ H J1 H2). simpl. destruct n0. assumption. assumption.
+  * apply In_InT_pair in H1. inversion H1.
+    + subst. inversion H3. subst.
+      pose (ImpL_help002 Γ0 Γ1 Δ0 Δ1 A B). simpl in i.
+      apply InT_or_app. left.
+      apply InT_trans_flatten_list with (bs:=(flatten_list
+      (map (fun y : list MPropF * list MPropF => [[y; (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)]])
+         (listInsertsL_Seqs (Γ0 ++ Γ1) (Δ0 ++ Δ1) A)))). assumption. apply InT_map_iff.
+      exists (Γ0 ++ B :: Γ1, Δ0 ++ Δ1). split.
+      destruct (eq_dec_form (A --> B) (A --> B)).
+      apply InT_flatten_list_InT_elem in i. destruct i. destruct p.
+      assert ((listInsertsL_Seqs (fst
+      (nth_split (length Γ0) (remove_nth (S (length Γ0)) (A --> B) (fst (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)))) ++
+      snd
+      (nth_split (length Γ0) (remove_nth (S (length Γ0)) (A --> B) (fst (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)))))
+      (snd (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)) A) = (listInsertsL_Seqs (Γ0 ++ Γ1) (Δ0 ++ Δ1) A)).
+      simpl (snd (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+      simpl (fst (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)). repeat rewrite effective_remove_nth.
+      assert (length Γ0 = length Γ0). reflexivity.
+      pose (@nth_split_length_id Γ0 Γ1 (length Γ0) H0). destruct a. rewrite H2. rewrite H4.
+      reflexivity. rewrite H0.
+      apply redundant_flatten_list. exfalso. auto.
+      destruct (eq_dec_form (A --> B) (A --> B)). simpl (snd (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)).
+      simpl (fst (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)). repeat rewrite effective_remove_nth.
+      assert (length Γ0 = length Γ0). reflexivity.
+      pose (@nth_split_length_id Γ0 Γ1 (length Γ0) H0). destruct a. rewrite H2. rewrite H4.
+      apply InT_eq. exfalso. auto.
+    + subst. assert (J1: (length Γ0) = (length Γ0)). reflexivity. apply InT_In in H3.
+      pose (IHl (length Γ0) H J1 H3). simpl. destruct n0. assumption. apply InT_or_app. auto.
+  * subst. apply In_InT_pair in H1. inversion H1. subst. inversion H2. subst. apply InT_In in H2.
+    assert (J1: length Γ0 = length Γ0). reflexivity.
+    pose (IHl _ H J1 H2). simpl. destruct n0. assumption. assumption.
+Defined.
+ +
+Definition ImpL_help2 : forall prem1 prem2 s, ImpLRule [prem1; prem2] s ->
+                      InT [prem1; prem2] (prems_Imp_L (pos_top_imps (fst s)) s).
+Proof.
+intros. inversion H. subst. simpl.
+pose (@ImpL_help02 Γ0 Γ1 Δ0 Δ1 A B (pos_top_imps (Γ0 ++ (Imp A B) :: Γ1)) (length Γ0)). apply i ; try assumption.
+reflexivity. apply Good_pos_in_pos_top_imps.
+Defined.
+ +
+Definition ImpL_help01 : forall prems s l, InT prems (prems_Imp_L l s) ->
+                  (existsT2 n prem1 prem2 A B Γ0 Γ1 Δ0 Δ1,
+                        (prems = [prem1; prem2]) /\
+                        (In ((Imp A B), S n) l) /\
+                        (prem1 = (Γ0 ++ Γ1, Δ0 ++ A :: Δ1)) /\
+                        (prem2 = (Γ0 ++ B :: Γ1, Δ0 ++ Δ1)) /\
+                        (Δ0 ++ Δ1 = snd s) /\
+                        (Γ0 = (fst (nth_split n (remove_nth (S n) (Imp A B) (fst s))))) /\
+                        (Γ1 = (snd (nth_split n (remove_nth (S n) (Imp A B) (fst s)))))).
+Proof.
+intros prems s. destruct s. induction l1 ; intros X.
+- simpl in X. inversion X.
+- simpl (fst (l, l0)). destruct a as [m n]. destruct m as [n0| | |].
+  * simpl in X. destruct n.
+    + pose (s := IHl1 X). repeat destruct s. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+      repeat split ; try tauto. apply in_cons. tauto.
+    + pose (s := IHl1 X). repeat destruct s. repeat destruct p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+      repeat split ; try tauto. apply in_cons. tauto.
+  * simpl in X. destruct n.
+    + pose (s := IHl1 X). repeat destruct s. repeat destruct p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+      repeat split ; try tauto. apply in_cons. tauto.
+    + pose (s := IHl1 X). repeat destruct s. repeat destruct p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+      repeat split ; try tauto. apply in_cons. tauto.
+  * destruct n.
+    + pose (s := IHl1 X). repeat destruct s. repeat destruct p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+      repeat split ; try tauto. apply in_cons. tauto.
+    + apply InT_app_or in X. destruct X.
+      { simpl (fst (l, l0)) in i. simpl (snd (l, l0)) in i.
+        apply InT_flatten_list_InT_elem in i. destruct i. destruct p.
+        apply InT_map_iff in i0. destruct i0. destruct p.
+        inversion i0. subst. apply InT_map_iff in i. destruct i.
+        destruct p. unfold listInsertsL_Seqs in i. apply InT_map_iff in i.
+        destruct i. destruct p. subst. unfold listInserts in i. apply InT_map_iff in i. destruct i.
+        destruct p. destruct x. subst. destruct (list_of_splits l0). simpl in i. exists n.
+        simpl (fst (l2, l3)). simpl (snd (l2, l3)).
+        exists (fst (nth_split n (remove_nth (S n) (m1 --> m2) l)) ++
+        snd (nth_split n (remove_nth (S n) (m1 --> m2) l)), l2 ++ m1 :: l3).
+        exists (fst
+          (nth_split n
+             match n with
+             | 0 =>
+                 match l with
+                 | [] => []
+                 | B0 :: tl => if eq_dec_form (m1 --> m2) B0 then tl else B0 :: tl
+                 end
+             | S _ => match l with
+                      | [] => []
+                      | B0 :: tl => B0 :: remove_nth n (m1 --> m2) tl
+                      end
+             end) ++
+        m2
+        :: snd
+             (nth_split n
+                match n with
+                | 0 =>
+                    match l with
+                    | [] => []
+                    | B0 :: tl => if eq_dec_form (m1 --> m2) B0 then tl else B0 :: tl
+                    end
+                | S _ => match l with
+                         | [] => []
+                         | B0 :: tl => B0 :: remove_nth n (m1 --> m2) tl
+                         end
+                end), l0).
+        exists m1. exists m2. exists (fst (nth_split n (remove_nth (S n) (m1 --> m2) l))).
+        exists (snd (nth_split n (remove_nth (S n) (m1 --> m2) l))).
+        exists l2. exists l3. simpl (snd (l, l0)). simpl (fst (l, l0)).
+        repeat split ; try auto. apply in_eq. simpl. assert (l2 ++ l3 = l0). rewrite i1. apply InT_In.
+        assumption. rewrite <- H. reflexivity. rewrite i1. apply InT_In. assumption. subst. inversion H0. }
+      { pose (IHl1 i). repeat destruct s. repeat destruct p. exists x. exists x0. exists x1.
+        exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+        repeat split ; try tauto. apply in_cons. tauto. }
+  * simpl in X. destruct n.
+    + pose (IHl1 X). repeat destruct s. repeat destruct p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+      repeat split ; try tauto. apply in_cons. tauto.
+    + pose (IHl1 X). repeat destruct s. repeat destruct p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. exists x6. exists x7.
+      repeat split ; try tauto. apply in_cons. tauto.
+Defined.
+ +
+Definition ImpL_help1 : forall prems s, InT prems (prems_Imp_L (pos_top_imps (fst s)) s) ->
+                                         ImpLRule prems s.
+Proof.
+intros prem s X. pose (s0 := @ImpL_help01 _ _ _ X). destruct s0 as (n&Hn&A&B&Γ0&Γ1&Δ0& Δ1&e1&Heq&i&p). destruct s as (l&l0). simpl in X.
+intuition. subst.
+apply In_pos_top_imps_split_l in i.
+simpl (fst (l, l0)). simpl in H0. subst.
simpl (fst (l, Δ1 ++ e1)) in X.
+destruct i as (l0&l1&Heq1 & Hlen & Heq2 & Heq3).
+subst.
+simpl (fst (l, Δ1 ++ e1)) in Heq1.
+simpl (fst (l, Δ1 ++ e1)) in Heq2.
+remember (fst (nth_split (length l0) (remove_nth (S (length l0)) (B --> Γ0) l))) as Γ0'.
+remember (snd (nth_split (length l0) (remove_nth (S (length l0)) (B --> Γ0) l))) as Γ1'.
+rewrite Heq1, Heq2.
+apply ImpLRule_I.
+Defined.
+ +
+Definition finite_ImpL_premises_of_S : forall (s : Seq), existsT2 listImpLprems,
+              (forall prems, ((ImpLRule prems s) -> (InT prems listImpLprems)) *
+                             ((InT prems listImpLprems) -> (ImpLRule prems s))).
+Proof.
+intros. destruct s.
+exists (prems_Imp_L (pos_top_imps l) (l,l0)).
+intros. split ; intro.
+- inversion H. subst.
+  pose (@ImpL_help2 (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) (Γ0 ++ B :: Γ1, Δ0 ++ Δ1) (Γ0 ++ A --> B :: Γ1, Δ0 ++ Δ1)). apply i.
+  assumption.
+- pose (@ImpL_help1 prems (l, l0)). apply i. assumption.
+Defined.
+ +
+
+
+ +
+ + + diff --git a/K.KS.KS_termination_ImpR.html b/K.KS.KS_termination_ImpR.html new file mode 100644 index 0000000..50994ff --- /dev/null +++ b/K.KS.KS_termination_ImpR.html @@ -0,0 +1,392 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_termination_ImpR

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat.
+ +
+Require Import KS_calc.
+Require Import KS_dec.
+Require Import KS_termination_measure.
+Require Import KS_termination_prelims.
+ +
+(* Now we can prove that a sequent has only finitely many potential premises via the ImpR rules.
+
+   The next definition simply takes a list of formulae l and a sequent s. It outputs a list of sequents.
+   These sequents are generated when there is an implication (Imp A B) encountered in l. With such an
+   implication, the function will stack the list of all insertions of A on the left of s and of B on
+   the right of s (roughly: in fact you need to destroy all such implications on the right to get an ImpRRule
+   premise), and then continues computing on the rest of l. *)

+ +
+Fixpoint prems_Imp_R (l : list ((MPropF) * nat)) (s : Seq) : list Seq :=
+match l with
+  | nil => nil
+  | (C, n) :: t => match n with
+                    | 0 => prems_Imp_R t s
+                    | S m => match C with
+                                | Imp A B => (listInsertsR_Seqs (fst s)
+                                               ((fst (nth_split m (remove_nth (S m) C (snd s)))) ++
+                                               B :: (snd (nth_split m (remove_nth (S m) C (snd s)))))
+                                               A)
+                                             ++ (prems_Imp_R t s)
+                                | _ => prems_Imp_R t s
+                                end
+                   end
+end.
+ +
+Lemma In_pos_top_imps_0_False : forall l (A : MPropF), In (A, 0) (pos_top_imps l) -> False.
+Proof.
+- induction l.
+  * intros. inversion H.
+  * intros. simpl in H. destruct a.
+    + simpl in H. apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+      destruct p. destruct x. inversion e.
+    + simpl in H. apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+      destruct p. destruct x. inversion e.
+    + simpl in H. destruct H. inversion H. apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+      destruct p. destruct x. inversion e.
+    + simpl in H. apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+      destruct p. destruct x. inversion e.
+Qed.
+ +
+Lemma In_pos_top_imps_imp : forall l (A : MPropF) n, In (A, n) (pos_top_imps l) -> (existsT2 C D, A = Imp C D).
+Proof.
+induction l ; intros.
+- simpl in H. inversion H.
+- simpl in H. destruct a ; try apply IHl in H. apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+  destruct p. inversion e. destruct x. subst. apply InT_In in i. apply IHl in i. assumption.
+  apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+  destruct p. inversion e. destruct x. subst. apply InT_In in i. apply IHl in i. assumption.
+  apply In_InT_pair in H. inversion H. subst. inversion H1. exists a1. exists a2. reflexivity.
+  subst. apply InT_map_iff in H1. destruct H1. destruct p. destruct x. simpl in e. inversion e.
+  subst. apply InT_In in i. apply IHl in i. assumption.
+  apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+  destruct p. inversion e. destruct x. subst. apply InT_In in i. apply IHl in i. assumption.
+Qed.
+ +
+Lemma In_pos_top_imps_In_l : forall l (A : MPropF) n, In (A, n) (pos_top_imps l) -> In A l.
+Proof.
+induction l.
+- intros. simpl in H. destruct H.
+- intros. simpl in H. destruct a.
+  * apply in_cons. apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+    destruct p. destruct x. inversion e. subst. apply InT_In in i. apply IHl in i.
+    assumption.
+  * apply in_cons. apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+    destruct p. destruct x. inversion e. subst. apply InT_In in i. apply IHl in i.
+    assumption.
+  * inversion H.
+    + inversion H0. subst. apply in_eq.
+    + apply in_cons. apply In_InT_pair in H0. apply InT_map_iff in H0. destruct H0.
+      destruct p. destruct x. inversion e. subst. apply InT_In in i. apply IHl in i.
+      assumption.
+  * apply In_InT_pair in H. apply InT_map_iff in H. destruct H.
+    destruct p. destruct x. inversion e. subst. apply InT_In in i. apply IHl in i.
+    apply in_cons. assumption.
+Qed.
+ +
+Definition In_pos_top_imps_split_l : forall l (A : MPropF) n, In (A, S n) (pos_top_imps l) ->
+          existsT2 l0 l1, (l = l0 ++ A :: l1) /\
+                          (length l0 = n) /\
+                          (l0 = fst (nth_split n (remove_nth (S n) A l))) /\
+                          (l1 = snd (nth_split n (remove_nth (S n) A l))).
+Proof.
+induction l.
+- intros. simpl. exfalso. simpl in H. destruct H.
+- intros. simpl in H. destruct a as [n0| | |].
+  * apply In_InT_pair in H. apply InT_map_iff in H. destruct H as ([m n1] & e & i).
+    simpl in e. inversion e. subst. destruct n. exfalso.
+    apply InT_In in i. apply In_pos_top_imps_0_False in i. assumption.
+    apply InT_In in i. pose (IHl A n i). destruct s as (x & x0 & e2 & e3 & e1 & e0).
+    subst. exists (# n0 :: x). exists x0. repeat split.
+    rewrite effective_remove_nth in e1. rewrite effective_remove_nth in e0.
+    assert (fst (# n0 :: fst (nth_split (S (length x)) (x ++ x0)), snd (nth_split (S (length x)) (x ++ x0))) =
+    # n0 :: fst (nth_split (S (length x)) (x ++ x0))). simpl. reflexivity.
+    assert (S (S (length x)) = S (length (# n0 :: x))). simpl. reflexivity.
+    rewrite H0. assert ((# n0 :: x ++ A :: x0) = ((# n0 :: x) ++ A :: x0)). simpl. reflexivity.
+    rewrite H1. clear H0. clear H1. rewrite effective_remove_nth.
+    pose (nth_split_idL (# n0 :: x) x0). simpl (length (# n0 :: x)) in e2.
+    rewrite <- e2. reflexivity.
+    rewrite effective_remove_nth in e0. rewrite effective_remove_nth in e1.
+    assert (S (S (length x)) = S (length (# n0 :: x))). simpl. reflexivity.
+    rewrite H. assert ((# n0 :: x ++ A :: x0) = ((# n0 :: x) ++ A :: x0)). simpl. reflexivity.
+    rewrite H0. clear H. clear H0. rewrite effective_remove_nth.
+    pose (nth_split_idR (# n0 :: x) x0). simpl (length (# n0 :: x)) in e2.
+    rewrite <- e2. reflexivity.
+  * apply In_InT_pair in H. apply InT_map_iff in H. destruct H as ([m n1] & e & i).
+    simpl in e. inversion e. subst. destruct n.
+    -- exfalso. apply InT_In in i. apply In_pos_top_imps_0_False in i. assumption.
+      -- apply InT_In in i. pose (IHl A n i). destruct s as (x & x0 & e2 & e3 & e1 & e0).
+      subst. exists (Bot :: x). exists x0. repeat split.
+      rewrite effective_remove_nth in e1. rewrite effective_remove_nth in e0.
+      assert (fst (Bot :: fst (nth_split (S (length x)) (x ++ x0)), snd (nth_split (S (length x)) (x ++ x0))) =
+      Bot :: fst (nth_split (S (length x)) (x ++ x0))). simpl. reflexivity.
+    assert (S (S (length x)) = S (length (Bot :: x))). simpl. reflexivity.
+    rewrite H0. assert ((Bot :: x ++ A :: x0) = ((Bot :: x) ++ A :: x0)). simpl. reflexivity.
+    rewrite H1. clear H0. clear H1. rewrite effective_remove_nth.
+    pose (nth_split_idL (Bot :: x) x0). simpl (length (Bot :: x)) in e2.
+    rewrite <- e2. reflexivity.
+    rewrite effective_remove_nth in e0. rewrite effective_remove_nth in e1.
+    assert (S (S (length x)) = S (length (Bot :: x))). simpl. reflexivity.
+    rewrite H. assert ((Bot :: x ++ A :: x0) = ((Bot :: x) ++ A :: x0)). simpl. reflexivity.
+    rewrite H0. clear H. clear H0. rewrite effective_remove_nth.
+    pose (nth_split_idR (Bot :: x) x0). simpl (length (Bot :: x)) in e2.
+    rewrite <- e2. reflexivity.
+  * apply In_InT_pair in H. inversion H.
+    + inversion H1. subst. exists []. exists l. repeat split. simpl.
+      destruct (eq_dec_form (a1 --> a2) (a1 --> a2)). reflexivity. exfalso. auto.
+    + subst. apply InT_map_iff in H1. destruct H1 as ([m n1] & e & i).
+        simpl in e. inversion e. subst. destruct n. exfalso.
+        apply InT_In in i. apply In_pos_top_imps_0_False in i. assumption.
+        apply InT_In in i. pose (IHl A n i). destruct s as (x & x0 & e2 & e3 & e1 & e0).
+        subst. exists (a1 --> a2 :: x). exists x0. repeat split.
+        rewrite effective_remove_nth in e1. rewrite effective_remove_nth in e0.
+        assert (fst (a1 --> a2 :: fst (nth_split (S (length x)) (x ++ x0)), snd (nth_split (S (length x)) (x ++ x0))) =
+        a1 --> a2 :: fst (nth_split (S (length x)) (x ++ x0))). simpl. reflexivity.
+        assert (S (S (length x)) = S (length (a1 --> a2 :: x))). simpl. reflexivity.
+        rewrite H1. assert ((a1 --> a2 :: x ++ A :: x0) = ((a1 --> a2 :: x) ++ A :: x0)). simpl. reflexivity.
+        rewrite H2. clear H2. clear H1. rewrite effective_remove_nth.
+        pose (nth_split_idL (a1 --> a2 :: x) x0). simpl (length (a1 --> a2 :: x)) in e2.
+        rewrite <- e2. reflexivity.
+        rewrite effective_remove_nth in e0. rewrite effective_remove_nth in e1.
+        assert (S (S (length x)) = S (length (a1 --> a2 :: x))). simpl. reflexivity.
+        rewrite H0. assert ((a1 --> a2 :: x ++ A :: x0) = ((a1 --> a2 :: x) ++ A :: x0)). simpl. reflexivity.
+        rewrite H1. clear H0. clear H1. rewrite effective_remove_nth.
+        pose (nth_split_idR (a1 --> a2 :: x) x0). simpl (length (a1 --> a2 :: x)) in e2.
+        rewrite <- e2. reflexivity.
+        * apply In_InT_pair in H. apply InT_map_iff in H. destruct H as ([m n1] & e & i).
+         simpl in e. inversion e. subst. destruct n. exfalso.
+        apply InT_In in i. apply In_pos_top_imps_0_False in i. assumption.
+        apply InT_In in i. pose (IHl A n i). destruct s as (x & x0 & e2 & e3 & e1 & e0).
+        subst. exists (Box a :: x). exists x0. repeat split.
+        rewrite effective_remove_nth in e1. rewrite effective_remove_nth in e0.
+        assert (fst (Box a :: fst (nth_split (S (length x)) (x ++ x0)), snd (nth_split (S (length x)) (x ++ x0))) =
+        Box a :: fst (nth_split (S (length x)) (x ++ x0))). simpl. reflexivity.
+        assert (S (S (length x)) = S (length (Box a :: x))). simpl. reflexivity.
+        rewrite H0. assert ((Box a :: x ++ A :: x0) = ((Box a :: x) ++ A :: x0)). simpl. reflexivity.
+        rewrite H1. clear H0. clear H1. rewrite effective_remove_nth.
+        pose (nth_split_idL (Box a :: x) x0). simpl (length (Box a :: x)) in e2.
+        rewrite <- e2. reflexivity.
+        rewrite effective_remove_nth in e0. rewrite effective_remove_nth in e1.
+        assert (S (S (length x)) = S (length (Box a :: x))). simpl. reflexivity.
+        rewrite H. assert ((Box a :: x ++ A :: x0) = ((Box a :: x) ++ A :: x0)). simpl. reflexivity.
+        rewrite H0. clear H. clear H0. rewrite effective_remove_nth.
+        pose (nth_split_idR (Box a :: x) x0). simpl (length (Box a :: x)) in e2.
+        rewrite <- e2. reflexivity.
+Defined.
+ +
+Lemma In_l_imp_In_pos_top_imps : forall l (A B : MPropF), In (Imp A B) l ->
+                                    existsT2 n, In ((Imp A B), n) (pos_top_imps l).
+Proof.
+induction l.
+- intros. simpl in H. destruct H.
+- intros. apply In_InT in H. inversion H.
+  * subst. exists 1. simpl. left. reflexivity.
+  * destruct a.
+    + subst. apply InT_In in H1. apply IHl in H1. destruct H1. exists (S x). simpl.
+      apply InT_In. apply InT_map_iff. exists (A --> B, x). simpl. split ; auto.
+      apply In_InT_pair. assumption.
+    + subst. apply InT_In in H1. apply IHl in H1. destruct H1. exists (S x). simpl.
+      apply InT_In. apply InT_map_iff. exists (A --> B, x). simpl. split ; auto.
+      apply In_InT_pair. assumption.
+    + subst. apply InT_In in H1. apply IHl in H1. destruct H1. exists (S x). simpl.
+      right. apply InT_In. apply InT_map_iff. exists (A --> B, x). simpl. split ; auto.
+      apply In_InT_pair. assumption.
+    + subst. apply InT_In in H1. apply IHl in H1. destruct H1. exists (S x). simpl.
+      apply InT_In. apply InT_map_iff. exists (A --> B, x). simpl. split ; auto.
+      apply In_InT_pair. assumption.
+Qed.
+ +
+Lemma Good_pos_in_pos_top_imps : forall A B Δ0 Δ1,
+              In (A --> B, S (length Δ0)) (pos_top_imps (Δ0 ++ A --> B :: Δ1)).
+Proof.
+induction Δ0.
+- intros. simpl. auto.
+- intros. destruct a.
+  * simpl. apply InT_In. apply InT_map_iff. exists (A --> B, S (length Δ0)).
+    split. simpl. reflexivity. apply In_InT_pair. apply IHΔ0.
+  * simpl. apply InT_In. apply InT_map_iff. exists (A --> B, S (length Δ0)).
+    split. simpl. reflexivity. apply In_InT_pair. apply IHΔ0.
+  * simpl. right. apply InT_In. apply InT_map_iff. exists (A --> B, S (length Δ0)).
+    split. simpl. reflexivity. apply In_InT_pair. apply IHΔ0.
+  * simpl. apply InT_In. apply InT_map_iff. exists (A --> B, S (length Δ0)).
+    split. simpl. reflexivity. apply In_InT_pair. apply IHΔ0.
+Qed.
+ +
+(* From there we can show that given a specific (Imp A B) on the right of a sequent S,
+   there is only finitely many premises via ImpR applied on this implication. But we
+   need to do it for all implications on the right of this sequent. *)

+ +
+Definition ImpR_help01 : forall prem s l, InT prem (prems_Imp_R l s) ->
+                  (existsT2 n A B Γ0 Γ1 Δ0 Δ1,
+                        (In ((Imp A B), S n) l) /\
+                        (prem = (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)) /\
+                        (Γ0 ++ Γ1 = fst s) /\
+                        (Δ0 = (fst (nth_split n (remove_nth (S n) (Imp A B) (snd s))))) /\
+                        (Δ1 = (snd (nth_split n (remove_nth (S n) (Imp A B) (snd s)))))).
+Proof.
+intros prem s. destruct s. destruct prem. induction l3 ; intros X.
+- simpl in X. inversion X.
+- destruct a as [m n]. destruct m as [n0| | |].
+  * simpl in X. destruct n.
+    + pose (IHl3 X). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p).
+        decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try auto. apply in_cons. tauto.
+    + pose (IHl3 X). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p). decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try tauto. apply in_cons. tauto.
+  * simpl in X. destruct n.
+    + pose (IHl3 X). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p). decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try tauto. apply in_cons. tauto.
+    + pose (IHl3 X). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p). decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try tauto. apply in_cons. tauto.
+  * destruct n.
+    + pose (IHl3 X). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p). decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try tauto. apply in_cons. tauto.
+    + apply InT_app_or in X. destruct X.
+      { simpl (fst (l, l0)) in i. simpl (snd (l, l0)) in i.
+        unfold listInsertsR_Seqs in i. apply InT_map_iff in i. destruct i.
+        destruct p. subst. unfold listInserts in i. apply InT_map_iff in i. destruct i.
+        destruct p. destruct x0. subst. destruct (list_of_splits l). simpl in i. exists n.
+        exists m1. exists m2. exists l4. exists l5. simpl (snd (l, l0)).
+        simpl (fst (l, l0)).
+        exists (fst (nth_split n (remove_nth (S n) (m1 --> m2) l0))).
+        exists (snd (nth_split n (remove_nth (S n) (m1 --> m2) l0))).
+        repeat split ; try auto. apply in_eq. rewrite i0. apply InT_In. assumption. }
+      { pose (IHl3 i). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p). decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try tauto. apply in_cons. tauto. }
+  * simpl in X. destruct n.
+    + pose (IHl3 X). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p). decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try tauto. apply in_cons. tauto.
+    + pose (IHl3 X). destruct s as (x & x0 & x1 & x2 & x3 & x4 & x5 & p). decompose record p. exists x. exists x0. exists x1.
+      exists x2. exists x3. exists x4. exists x5. repeat split ; try tauto. apply in_cons. tauto.
+Defined.
+ +
+Definition ImpR_help1 : forall prem s, InT prem (prems_Imp_R (pos_top_imps (snd s)) s) -> ImpRRule [prem] s.
+Proof.
+intros prem s X. pose (ImpR_help01 _ _ _ X). destruct s0. destruct s.
+destruct s0. destruct s as (B & Γ0 & Γ1 & Δ0 & Δ1 & i & e2 & e3 & e4 & e5).
+subst. simpl in i, e3. subst.
+simpl (snd (_, _)) in *.
+apply In_pos_top_imps_split_l in i. destruct i. destruct s as (x2 & H1 & H2 & H3 & H4).
+subst.
+rewrite <- H4. rewrite effective_remove_nth. rewrite <- nth_split_idL.
+apply ImpRRule_I.
+Defined.
+ +
+Definition ImpR_help002 : forall Γ0 Γ1 Δ0 Δ1 A B,
+           InT (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) (listInsertsR_Seqs (Γ0 ++ Γ1) (Δ0 ++ B :: Δ1) A).
+Proof.
+intros. unfold listInsertsR_Seqs. apply InT_map_iff. exists (Γ0 ++ A :: Γ1). split.
+reflexivity. unfold listInserts. apply InT_map_iff. exists (Γ0, Γ1). simpl. split.
+reflexivity. destruct (list_of_splits (Γ0 ++ Γ1)). simpl. pose (i Γ0 Γ1).
+apply In_InT_seqs. apply i0. reflexivity.
+Defined.
+ +
+Definition ImpR_help02 : forall Γ0 Γ1 Δ0 Δ1 A B l n,
+                                ImpRRule [(Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1)] (Γ0 ++ Γ1, Δ0 ++ (Imp A B) :: Δ1) ->
+                                (length Δ0 = n) ->
+                                (In ((Imp A B), S n) l) ->
+                                InT (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) (prems_Imp_R l (Γ0 ++ Γ1, Δ0 ++ (Imp A B) :: Δ1)).
+Proof.
+induction l ; intros.
+- inversion H1.
+- destruct a. destruct m.
+  * apply In_InT_pair in H1. inversion H1. subst. inversion H3. subst. apply InT_In in H3.
+    assert (J1: length Δ0 = length Δ0). reflexivity.
+    pose (IHl _ H J1 H3). simpl. destruct n0. assumption. assumption.
+  * apply In_InT_pair in H1. inversion H1. subst. inversion H3. subst. apply InT_In in H3.
+    assert (J1: length Δ0 = length Δ0). reflexivity.
+    pose (IHl _ H J1 H3). simpl. destruct n0. assumption. assumption.
+  * apply In_InT_pair in H1. inversion H1.
+    + subst. inversion H3. subst. destruct Δ0.
+      { simpl. pose (ImpR_help002 Γ0 Γ1 [] Δ1 A B). simpl in i. destruct (eq_dec_form (A --> B) (A --> B)).
+        apply InT_or_app. auto. exfalso. auto. }
+      { unfold prems_Imp_R. apply InT_or_app. left.
+        assert ((remove_nth (S (length (m :: Δ0))) (A --> B) (snd (Γ0 ++ Γ1, (m :: Δ0) ++ A --> B :: Δ1))) =
+        (m :: Δ0) ++ Δ1). simpl (snd (Γ0 ++ Γ1, (m :: Δ0) ++ A --> B :: Δ1)).
+        pose (effective_remove_nth (A --> B) (m :: Δ0) Δ1). assumption.
+        rewrite H0.
+        assert (fst (nth_split (length (m :: Δ0)) ((m :: Δ0) ++ Δ1)) = (m :: Δ0) /\
+        snd (nth_split (length (m :: Δ0)) ((m :: Δ0) ++ Δ1)) = Δ1). apply nth_split_length_id.
+        reflexivity. destruct H2. rewrite H2. rewrite H4. apply ImpR_help002. }
+    + subst. assert (J1: (length Δ0) = (length Δ0)). reflexivity. apply InT_In in H3.
+      pose (IHl (length Δ0) H J1 H3). simpl. destruct n0. assumption. apply InT_or_app. auto.
+  * apply In_InT_pair in H1. inversion H1. subst. inversion H3. subst. apply InT_In in H3.
+    assert (J1: length Δ0 = length Δ0). reflexivity.
+    pose (IHl _ H J1 H3). simpl. destruct n0. assumption. assumption.
+Defined.
+ +
+Definition ImpR_help2 : forall prem s, ImpRRule [prem] s -> InT prem (prems_Imp_R (pos_top_imps (snd s)) s).
+Proof.
+intros. inversion H. subst. simpl.
+pose (@ImpR_help02 Γ0 Γ1 Δ0 Δ1 A B (pos_top_imps (Δ0 ++ A --> B :: Δ1)) (length Δ0)). apply i ; try assumption.
+reflexivity. apply Good_pos_in_pos_top_imps.
+Defined.
+ +
+Definition finite_ImpR_premises_of_S : forall (s : Seq), existsT2 listImpRprems,
+              (forall prems, ((ImpRRule prems s) -> (InT prems listImpRprems)) *
+                             ((InT prems listImpRprems) -> (ImpRRule prems s))).
+Proof.
+intro s. destruct s.
+exists (map (fun y => [y]) (prems_Imp_R (pos_top_imps l0) (l,l0))).
+intros. split ; intro.
+- inversion H. subst. apply InT_map_iff.
+  exists (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1). split. reflexivity.
+  pose (@ImpR_help2 (Γ0 ++ A :: Γ1, Δ0 ++ B :: Δ1) (Γ0 ++ Γ1, Δ0 ++ A --> B :: Δ1)). simpl in i. apply i.
+  assumption.
+- apply InT_map_iff in H. destruct H. destruct p. subst. apply ImpR_help1. simpl. assumption.
+Defined.
+
+
+ +
+ + + diff --git a/K.KS.KS_termination_KR.html b/K.KS.KS_termination_KR.html new file mode 100644 index 0000000..e27d632 --- /dev/null +++ b/K.KS.KS_termination_KR.html @@ -0,0 +1,146 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_termination_KR

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat.
+ +
+Require Import KS_calc.
+Require Import KS_dec.
+Require Import KS_termination_measure.
+Require Import KS_termination_prelims.
+ +
+(* Now let us tackle the KR rule. *)
+ +
+Fixpoint prems_Box_R (l : list MPropF) (s : Seq) : list (list Seq) :=
+match l with
+  | nil => nil
+  | h :: t => match h with
+              | Box A => [((unboxed_list (top_boxes (fst s))), [A])] :: (prems_Box_R t s)
+              | _ => prems_Box_R t s
+              end
+end.
+ +
Definition KR_help01 : forall prems s (l : list MPropF), InT prems (prems_Box_R l s) ->
+                  (existsT2 (A : MPropF),
+                        (In (Box A) l) /\
+                        (prems = [(unboxed_list (top_boxes (fst s)) , [A])])).
+Proof.
+intros prems s. destruct s. induction l1 ; intros X.
+- simpl in X. inversion X.
+- simpl in X. destruct a.
+  * apply IHl1 in X. destruct X as [x p]. repeat destruct p. subst.
+     exists x. repeat split ; try auto ; try apply in_cons ; try assumption.
+  * apply IHl1 in X. destruct X as [x p]. repeat destruct p. subst.
+    exists x. repeat split ; try auto ; try apply in_cons ; try assumption.
+  * apply IHl1 in X. destruct X as [x p]. repeat destruct p. subst.
+    exists x. repeat split ; try auto ; try apply in_cons ; try assumption.
+  * inversion X.
+    + subst. exists a. repeat split ; try auto ; try apply in_eq.
+    + apply IHl1 in H0. destruct H0 as [x p]. repeat destruct p. subst.
+      exists x. repeat split ; try auto ; try apply in_cons ; try assumption.
+Defined.
+ +
+Definition KR_help1 : forall prems s, InT prems (prems_Box_R (top_boxes (snd s)) s) ->
+                                         KRRule prems s.
+Proof.
+intros prems s X. destruct (@KR_help01 _ _ _ X) as (x&Hi&Heq).
+repeat destruct s0. destruct s. simpl in X.
+repeat destruct p. subst. simpl in *. assert (In (Box x) l0). apply top_boxes_incl_list.
+assumption. apply in_splitT in H. destruct H. repeat destruct s.
+rewrite e. apply KRRule_I. intro. intros. apply in_top_boxes in H.
+destruct H. repeat destruct s. repeat destruct p. exists x2. assumption.
+simpl. apply top_boxes_nobox_gen_ext.
+Defined.
+ +
+Definition KR_help02 : forall Γ Δ0 Δ1 A l, KRRule [(unboxed_list , [A])] (Γ, Δ0 ++ Box A :: Δ1) ->
+                                             (is_Boxed_list ) ->
+                                             (nobox_gen_ext Γ) ->
+                                             (In (Box A) l) ->
+                                             InT [(unboxed_list , [A])] (prems_Box_R l (Γ, Δ0 ++ Box A :: Δ1)).
+Proof.
+induction l ; intros.
+- inversion H0.
+- simpl. destruct a as [n| | |].
+  * assert (InT (Box A) (# n :: l)). apply in_splitT in H0. destruct H0. destruct s. rewrite e.
+    apply InT_or_app. right. apply InT_eq. inversion H1. inversion H3. apply InT_In in H3.
+    pose (IHl X H X0 H3). assumption.
+  * assert (InT (Box A) (Bot :: l)). apply in_splitT in H0. destruct H0. destruct s. rewrite e.
+    apply InT_or_app. right. apply InT_eq. inversion H1. inversion H3. apply InT_In in H3.
+    pose (IHl X H X0 H3). assumption.
+  * assert (InT (Box A) (a1 --> a2 :: l)). apply in_splitT in H0. destruct H0. destruct s. rewrite e.
+    apply InT_or_app. right. apply InT_eq. inversion H1. inversion H3. apply InT_In in H3.
+    pose (IHl X H X0 H3). assumption.
+  * assert (InT (Box A) (Box a :: l)). apply in_splitT in H0. destruct H0. destruct s. rewrite e.
+    apply InT_or_app. right. apply InT_eq. inversion H1.
+    + subst. inversion H3. subst. pose (nobox_gen_ext_top_boxes_identity X0 H). rewrite e.
+      apply InT_eq.
+    + subst. apply InT_In in H3. pose (IHl X H X0 H3). apply InT_cons. assumption.
+Defined.
+ +
+Definition KR_help2 : forall prem s, KRRule [prem] s ->
+                      InT [prem] (prems_Box_R (top_boxes (snd s)) s).
+Proof.
+intros. inversion X. subst. simpl.
+pose (@KR_help02 Γ0 Δ0 Δ1 A (top_boxes (Δ0 ++ Box A :: Δ1))). apply i ; try assumption.
+rewrite top_boxes_distr_app. simpl. apply in_or_app. right. apply in_eq.
+Defined.
+ +
+Definition finite_KR_premises_of_S : forall (s : Seq), existsT2 listKRprems,
+              (forall prems, ((KRRule prems s) -> (InT prems listKRprems)) *
+                             ((InT prems listKRprems) -> (KRRule prems s))).
+Proof.
+intros. destruct s.
+exists (prems_Box_R (top_boxes l0) (l,l0)).
+intros. split ; intro.
+- inversion X. subst.
+  pose (@KR_help2 (unboxed_list , [A]) (l, Δ0 ++ Box A :: Δ1)). apply i.
+  assumption.
+- pose (@KR_help1 prems (l, l0)). apply k. assumption.
+Defined.
+
+
+ +
+ + + diff --git a/K.KS.KS_termination_init.html b/K.KS.KS_termination_init.html new file mode 100644 index 0000000..d5e56db --- /dev/null +++ b/K.KS.KS_termination_init.html @@ -0,0 +1,81 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_termination_init

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat.
+ +
+Require Import KS_calc.
+Require Import KS_dec.
+Require Import KS_termination_measure.
+Require Import KS_termination_prelims.
+ +
+(* Obviously, we can obtain the same result for initial sequents. *)
+ +
+Lemma finite_IdP_premises_of_S : forall (s : Seq), existsT2 listIdPprems,
+              (forall prems, ((IdPRule prems s) -> (InT prems listIdPprems)) *
+                             ((InT prems listIdPprems) -> (IdPRule prems s))).
+Proof.
+intros s. destruct (dec_IdP_rule s).
+- exists [[]]. intros. split ; intro.
+  * inversion H. subst. apply InT_eq.
+  * inversion H. subst. assumption. inversion H1.
+- exists []. intros. split ; intro.
+  * inversion H. subst. exfalso. apply f. assumption.
+  * inversion H.
+Qed.
+ +
+Lemma finite_BotL_premises_of_S : forall (s : Seq), existsT2 listBotLprems,
+              (forall prems, ((BotLRule prems s) -> (InT prems listBotLprems)) *
+                             ((InT prems listBotLprems) -> (BotLRule prems s))).
+Proof.
+intros. destruct (dec_BotL_rule s).
+- exists [[]]. intros. split ; intro.
+  * inversion H. subst. apply InT_eq.
+  * inversion H. subst. assumption. inversion H1.
+- exists []. intros. split ; intro.
+  * inversion H. subst. exfalso. apply f. assumption.
+  * inversion H.
+Qed.
+
+
+ +
+ + + diff --git a/K.KS.KS_termination_measure.html b/K.KS.KS_termination_measure.html new file mode 100644 index 0000000..d10462f --- /dev/null +++ b/K.KS.KS_termination_measure.html @@ -0,0 +1,171 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_termination_measure

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+ +
+Require Import KS_calc.
+ +
+Lemma NoDup_incl_lengthT : forall (l l' : list MPropF), NoDup l -> incl l l' ->
+          {length l < length l'} + {length l = length l'}.
+Proof. intros. apply Compare_dec.le_lt_eq_dec, NoDup_incl_length; assumption. Qed.
+ +
+(* Then the definition we were initially looking for can be reached: *)
+ +
+Definition measure (s : Seq) : nat :=
+    (size_LF (fst s)) + (size_LF (snd s)).
+ +
+(* It is clear that measure counts the occurrences of implications in a
+   sequent s. As a consequence, if that number is 0 we know for sure that the
+   rules for implication on the left or right cannot be applied upwards on s.
+   This is the meaning of the lemma measure_is_0. 
+
+   But first we need a preliminary lemma which claims that if an implication is
+   in a list, then size_LF of that list is higher than one.*)

+ +
+Lemma In_Imp_size_LF_is_non_0 (l : list MPropF) :
+    forall A B, (In (Imp A B) l) -> (le 1 (size_LF l)).
+Proof.
+intros A B Hin. induction l.
+- inversion Hin.
+- inversion Hin.
+  * subst. simpl. rewrite <- Nat.succ_le_mono. apply le_0_n.
+  * pose (IHl H). simpl. destruct l0.
+    + rewrite Nat.add_1_r. rewrite <- Nat.succ_le_mono. apply le_0_n.
+    + rewrite <- plus_n_Sm. rewrite <- Nat.succ_le_mono. apply le_0_n.
+Qed.
+ +
+Theorem term_meas_is_0 (s : Seq) :
+    (measure s) = 0 -> (existsT2 ps, (ImpRRule ps s) + (ImpLRule ps s)) -> False.
+Proof.
+intros is0 RA. destruct RA. destruct s0.
+- inversion i. subst. unfold measure in is0. simpl in is0.
+  assert (size_LF (Δ0 ++ A --> B :: Δ1) = 0). lia.
+  assert (In (A --> B) (Δ0 ++ A --> B :: Δ1)). apply in_or_app. right. apply in_eq.
+  pose (In_Imp_size_LF_is_non_0 (Δ0 ++ A --> B :: Δ1) A B H0). lia.
+- inversion i. subst.
+  assert (In (A --> B) (Γ0 ++ A --> B :: Γ1)). apply in_or_app. right. apply in_eq.
+  pose (In_Imp_size_LF_is_non_0 (Γ0 ++ A --> B :: Γ1) A B H). unfold measure in is0.
+  simpl in is0. assert (size_LF (Δ0 ++ Δ1) = 0). lia. lia.
+Qed.
+ +
+Lemma size_LF_dist_app : forall l1 l2, size_LF (l1 ++ l2) =
+                                               plus (size_LF l1) (size_LF l2).
+Proof.
+induction l1.
+- intros. auto.
+- intros. simpl. rewrite IHl1. lia.
+Qed.
+ +
+Lemma size_nobox_gen_ext : forall l1 l2, nobox_gen_ext l1 l2 ->
+                                               (size_LF l1 <= size_LF l2).
+Proof.
+intros. induction X.
+- simpl. lia.
+- simpl. lia.
+- simpl. lia.
+Qed.
+ +
+Lemma size_unboxed : forall l, (size_LF (unboxed_list l) <= size_LF l).
+Proof.
+induction l.
+- simpl. lia.
+- simpl. destruct a ; simpl ; lia.
+Qed.
+ +
+Lemma size_top_boxes : forall l, (size_LF (top_boxes l) <= size_LF l).
+Proof.
+induction l.
+- simpl. lia.
+- simpl. destruct a ; simpl ; lia.
+Qed.
+ +
+(* We prove some lemmas about these notions. *)
+ +
+Lemma In_Box_size_LF_is_non_0 (l : list MPropF) :
+    forall A, (In (Box A) l) -> (le 1 (size_LF l)).
+Proof.
+intros A Hin. induction l.
+- inversion Hin.
+- inversion Hin.
+  * subst. simpl. rewrite <- Nat.succ_le_mono. apply le_0_n.
+  * pose (IHl H). simpl. destruct l0.
+    + rewrite Nat.add_1_r. rewrite <- Nat.succ_le_mono. apply le_0_n.
+    + rewrite <- plus_n_Sm. rewrite <- Nat.succ_le_mono. apply le_0_n.
+Qed.
+ +
+Theorem measure_is_0 (s : Seq) :
+    (measure s) = 0 -> (existsT2 ps, (KRRule ps s)) -> False.
+Proof.
+intros is0 RA. destruct RA. inversion k. subst. unfold measure in is0.
+simpl in is0.
+assert (size_LF (Δ0 ++ Box A :: Δ1) = 0). lia.
+assert (In (Box A) (Δ0 ++ Box A :: Δ1)). apply in_or_app. right. apply in_eq.
+pose (In_Box_size_LF_is_non_0 (Δ0 ++ Box A :: Δ1) A H1). lia.
+Qed.
+ +
+(* Third, we need to prove that if no KS rule is applicable to a sequent s,
+   then its derivations have a height equal to 0. *)

+ +
+Theorem no_KS_rule_applic : forall s, (forall ps, (KS_rules ps s) -> False) ->
+                                 forall (D : KS_drv s), derrec_height D = 0.
+Proof.
+intros s noRA D. induction D.
+- auto.
+- exfalso. apply noRA with (ps:=ps). assumption.
+Qed.
+
+
+ +
+ + + diff --git a/K.KS.KS_termination_prelims.html b/K.KS.KS_termination_prelims.html new file mode 100644 index 0000000..66af4d9 --- /dev/null +++ b/K.KS.KS_termination_prelims.html @@ -0,0 +1,411 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_termination_prelims

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat.
+ +
+Require Import KS_calc.
+Require Import KS_dec.
+Require Import KS_termination_measure.
+ +
+Set Implicit Arguments.
+ +
+(* In this file we prove that each sequent Γ |- Δ has a derivation (not proof) D in
+   KS of maximal height: all derivations in KS of this sequent must have an
+   inferior or equal height to that of D.
+
+   This result can be understood as claiming that the proof search defined by KS
+   terminates. *)

+ +
+Definition proj1_sigT2 {A : Type} (P : A -> Type) (e:sigT P) := match e with
+                                    | existT _ a b => a
+                                    end.
+ +
+Definition proj2_sigT2 {A : Type} (P : A -> Type) (e : sigT P) :=
+  match e return (P (proj1_sigT2 e)) with
+  | existT _ a b => b
+  end.
+ +
+Lemma In_InT : forall (A : MPropF) l, In A l -> InT A l.
+Proof.
+intros. apply in_splitT in H. destruct H. destruct s. subst. apply InT_or_app. right.
+apply InT_eq.
+Qed.
+ +
+Definition In_InT_pair : forall (A : MPropF) (n : nat) l, In (A, n) l -> InT (A, n) l.
+Proof.
+induction l.
+- intro. inversion H.
+- intro. assert ({(A, n) = a} + {(A, n) <> a}). destruct a.
+  destruct (eq_dec_form A m). subst. destruct (Nat.eq_dec n n0). subst. auto.
+  right. intro. apply n1. inversion H0. auto. right. intro. inversion H0.
+  auto. destruct H0. subst. apply InT_eq. apply InT_cons. apply IHl.
+  inversion H. exfalso. auto. assumption.
+Defined.
+ +
+Lemma dec_le : forall n m, (n <= m) + ((n <= m) -> False).
+Proof.
+induction n.
+- intro m. left. apply le_0_n.
+- intro m. pose (IHn m). destruct s.
+  * destruct (Nat.eq_dec n m). subst. right. intro. lia. left. lia.
+  * right. intro. apply f. lia.
+Qed.
+ +
+Definition InT_map_iff : forall {A B : Type} (f : A -> B) (l : list A) (y : B),
+       (InT y (map f l) -> (existsT2 x : A, (f x = y) * InT x l)) *
+       ((existsT2 x : A, (f x = y) * InT x l) -> InT y (map f l)).
+Proof.
+induction l.
+- intros. simpl. split. intro. inversion X. intro. destruct X. destruct p. inversion i.
+- simpl. intros. split.
+  * intro. inversion X.
+    + subst. exists a. split ; [ reflexivity | apply InT_eq].
+    + subst. pose (IHl y). destruct p. apply s in X0. destruct X0. destruct p. exists x.
+      split. assumption. apply InT_cons. assumption.
+  * intro. pose (IHl y). destruct p. clear s. pose (proj2_sigT2 X).
+    destruct p. inversion i0. subst. rewrite <- e. rewrite <- H0. apply InT_eq.
+    subst. assert (existsT2 x : A, (f x = y) * InT x l). exists (proj1_sigT2 X).
+    split ; assumption. apply i in X1. apply InT_cons. assumption.
+Defined.
+ +
+Fixpoint top_imps (l : list MPropF) : list MPropF :=
+match l with
+  | nil => nil
+  | h :: t => match h with
+                | Imp A B => (Imp A B) :: top_imps t
+                | _ => top_imps t
+              end
+end.
+ +
+Fixpoint pos_top_imps (l : list MPropF) : (list ((MPropF) * nat)) :=
+match l with
+  | nil => nil
+  | h :: t => match h with
+                | Imp A B => (Imp A B, 1) :: (map (fun y => (fst y, S (snd y))) (pos_top_imps t))
+                | _ => (map (fun y => (fst y, S (snd y))) (pos_top_imps t))
+              end
+end.
+ +
+Lemma le_False_lt : forall n m, ((n <= m) -> False) -> (m < n).
+Proof.
+induction n.
+- intros. exfalso. apply H. apply le_0_n.
+- induction m.
+  * intros. lia.
+  * intros. rewrite <- Nat.succ_lt_mono. apply IHn. intro. apply H.
+    rewrite <- Nat.succ_le_mono. assumption.
+Qed.
+ +
+Definition top_boxes_nobox_gen_ext : forall l, nobox_gen_ext (top_boxes l) l.
+Proof.
+induction l.
+- simpl. apply univ_gen_ext_nil.
+- destruct a ; simpl.
+  * apply univ_gen_ext_extra. intro. inversion X. inversion H. assumption.
+  * apply univ_gen_ext_extra. intro. inversion X. inversion H. assumption.
+  * apply univ_gen_ext_extra. intro. inversion X. inversion H. assumption.
+  * apply univ_gen_ext_cons. assumption.
+Defined.
+ +
+Lemma nobox_gen_ext_top_boxes_identity : forall l0 l1, nobox_gen_ext l0 l1 ->
+                                                       is_Boxed_list l0 ->
+                                                       (l0 = top_boxes l1).
+Proof.
+intros l0 l1 X. induction X.
+- intros. reflexivity.
+- intro. simpl. destruct x as [n | | | ].
+  * exfalso. pose (H (# n)). assert (In # n (# n :: l)). apply in_eq. apply e in H0.
+    destruct H0. inversion H0.
+  * exfalso. pose (H (Bot)). assert (In (Bot) (Bot :: l)). apply in_eq. apply e in H0.
+    destruct H0. inversion H0.
+  * exfalso. pose (H (x1 --> x2)). assert (In (x1 --> x2) (x1 --> x2 :: l)). apply in_eq. apply e in H0.
+    destruct H0. inversion H0.
+  * assert (l = top_boxes le). apply IHX. intro. intros. apply H. apply in_cons. assumption.
+    rewrite H0. reflexivity.
+- simpl. destruct x.
+  * apply IHX.
+  * apply IHX.
+  * apply IHX.
+  * exfalso. apply p. exists x. reflexivity.
+Qed.
+ +
+Fixpoint flatten_list {A : Type} (l : list (list A)) : list A :=
+  match l with
+  | [ ] => [ ]
+  | h :: t => h ++ (flatten_list t)
+  end
+.
+ +
+Definition InT_flatten_list_InT_elem {A : Type} : forall (l : list (list A)) b,
+        InT b (flatten_list l) -> (existsT2 bs, (InT b bs) * (InT bs l)).
+Proof.
+induction l.
+- intros. simpl in X. inversion X.
+- intros. simpl in X. apply InT_app_or in X. destruct X.
+  * exists a. split ; [assumption | apply InT_eq].
+  * pose (IHl b). apply s in i. destruct i. destruct p. exists x. split ; [assumption | apply InT_cons ; assumption].
+Defined.
+ +
+Lemma redundant_flatten_list : forall ls (s : Seq), map (fun z : list MPropF * list MPropF => [z;s]) ls =
+flatten_list (map (fun y : list MPropF * list MPropF => [[y;s]]) ls).
+Proof.
+induction ls.
+- intros. simpl. reflexivity.
+- simpl. intros. rewrite IHls. reflexivity.
+Qed.
+ +
+Definition InT_trans_flatten_list {A : Type} : forall (l : list (list A)) bs b,
+        (InT b bs) -> (InT bs l) -> (InT b (flatten_list l)).
+Proof.
+induction l.
+- intros. inversion X0.
+- intros. inversion X0.
+  * subst. simpl. apply InT_or_app. auto.
+  * subst. simpl. apply InT_or_app. right. pose (IHl bs b X X1) ; assumption.
+Defined.
+ +
+(* The next lemma claims that for each sequent s there is a derivation of that sequent. *)
+ +
+Lemma der_s_inhabited : forall s, inhabited (KS_drv s).
+Proof.
+intros s.
+pose (@dpI Seq KS_rules (fun _ : Seq => True) s).
+assert (H: (fun _ : Seq => True) s). apply I. apply d in H. apply inhabits. assumption.
+Qed.
+ +
+(* The next definition deals with the property of being a derivation D0 of maximal height
+   for the sequent s. *)

+ +
+Definition is_mhd (s: Seq) (D0 : KS_drv s): Prop :=
+      forall (D1 : KS_drv s), derrec_height D1 <= derrec_height D0.
+ +
+(* The next lemma says that given a list and an element, there are only finitely many
+   ways to insert this element in a list. *)

+ +
+Definition list_of_splits : forall (l : list MPropF), existsT2 listSplits,
+                            forall l1 l2, ((l1 ++ l2 = l) <-> In (l1, l2) listSplits).
+Proof.
+induction l.
+- exists [([],[])]. intros. destruct l1. split ; intro. simpl in H. rewrite H. apply in_eq.
+  simpl in H. destruct H. inversion H. reflexivity. inversion H. split ; intro.
+  simpl in H. inversion H. simpl. inversion H. inversion H0. inversion H0.
+- destruct IHl. exists ([([], a :: l)] ++ (map (fun y => (a :: (fst y), snd y)) x)).
+  intros. split ; intro.
+  * apply in_or_app. destruct l1. simpl. left. left. simpl in H. rewrite H.
+    reflexivity. simpl in H. inversion H. subst. right. pose (i l1 l2). destruct i0.
+    assert (l1 ++ l2 = l1 ++ l2). reflexivity. apply H0 in H2.
+    pose (in_map (fun y : list MPropF * list MPropF => (a :: fst y, snd y)) x (l1, l2) H2).
+    simpl in i. assumption.
+  * simpl in H. destruct H. inversion H. simpl. reflexivity. rewrite in_map_iff in H.
+    destruct H. destruct H. inversion H. subst. simpl. pose (i (fst x0) (snd x0)).
+    destruct i0. assert ((fst x0, snd x0) = x0). destruct x0. simpl. reflexivity.
+    rewrite H3 in H2. apply H2 in H0. rewrite H0. reflexivity.
+Defined.
+ +
+Definition listInserts l (A : MPropF) := map (fun y => (fst y) ++ A :: (snd y)) (proj1_sigT2 (list_of_splits l)).
+ +
+(* The next two lemmas make sure that the definition listInserts indeed captures the intended
+   list. *)

+ +
+Lemma listInserts_In : forall l (A: MPropF) l1 l2, ((l1 ++ l2 = l) -> In (l1 ++ A :: l2) (listInserts l A)).
+Proof.
+intros. unfold listInserts. assert (In (l1, l2) (proj1_sigT2 (list_of_splits l))). destruct (list_of_splits l).
+simpl. pose (i l1 l2). apply i0. assumption.
+pose (in_map (fun y : list MPropF * list MPropF => fst y ++ A :: snd y) (proj1_sigT2 (list_of_splits l)) (l1, l2) H0).
+simpl in i. assumption.
+Qed.
+ +
+Lemma In_listInserts : forall l (A: MPropF) l0, In l0 (listInserts l A) ->
+                            (exists l1 l2, prod (l1 ++ l2 = l) (l1 ++ A :: l2 = l0)).
+Proof.
+intros. unfold listInserts in H. destruct (list_of_splits l). simpl in H. rewrite in_map_iff in H.
+destruct H. destruct H. subst. exists (fst x0). exists (snd x0). split. apply i.
+destruct x0. simpl. assumption. reflexivity.
+Qed.
+ +
+(* The definitions below allow you to create the list of all sequents given two lists and a
+   formula to insert in one of them. *)

+ +
+Definition listInsertsR_Seqs (Γ Δ : list MPropF) (A : MPropF) := map (fun y => (y, Δ)) (listInserts Γ A).
+ +
+Definition listInsertsL_Seqs (Γ Δ : list MPropF) (A : MPropF) := map (fun y => (Γ, y)) (listInserts Δ A).
+ +
+(* The next definition allows one to create all sequents *)
+ +
+Definition listInsertsRL_Seqs (Γ Δ : list MPropF) (A B : MPropF) :=
+                  flatten_list (map (fun z => (map (fun y => (z, y)) (listInserts Δ B))) (listInserts Γ A)).
+ +
+(* Some useful functions *)
+ +
+Fixpoint remove_nth (n: nat) (A : MPropF) l:=
+    match n with
+      | 0 => l
+      | 1 => match l with
+               | [] => []
+               | B::tl => if (eq_dec_form A B) then tl else B:: tl
+             end
+      | S m => match l with
+                 | [] => []
+                 | B::tl => B::(remove_nth m A tl)
+               end
+      end.
+ +
+Fixpoint nth_split (n : nat) (l : list MPropF) : (list MPropF * list MPropF) :=
+    match n with
+      | 0 => ([], l)
+      | 1 => match l with
+               | [] => ([], [])
+               | B::tl => ([B] , tl)
+             end
+      | S m => match l with
+                 | [] => ([], [])
+                 | B::tl => (B :: (fst (nth_split m tl)), snd (nth_split m tl))
+               end
+      end.
+ +
+Lemma nth_split_length : forall (l0 l1 : list MPropF), (nth_split (length l0) (l0 ++ l1)) = (l0, l1).
+Proof.
+induction l0.
+- intros. simpl. reflexivity.
+- intros. pose (IHl0 l1). simpl (length (a :: l0)). simpl ((a :: l0) ++ l1).
+  simpl. destruct l0.
+  * simpl. reflexivity.
+  * assert (match length (m :: l0) with
+| 0 => ([a], (m :: l0) ++ l1)
+| S _ =>
+    (a :: fst (nth_split (length (m :: l0)) ((m :: l0) ++ l1)),
+    snd (nth_split (length (m :: l0)) ((m :: l0) ++ l1)))
+end = (a :: fst (nth_split (length (m :: l0)) ((m :: l0) ++ l1)),
+    snd (nth_split (length (m :: l0)) ((m :: l0) ++ l1)))). reflexivity. rewrite H.
+clear H. rewrite e. simpl. reflexivity.
+Qed.
+ +
+Lemma nth_split_idL : forall (l0 l1 : list MPropF), l0 = fst (nth_split (length l0) (l0 ++ l1)).
+Proof.
+induction l0.
+- intros. simpl. reflexivity.
+- intros. simpl (length (a :: l0)). pose (IHl0 l1). assert (fst (nth_split (S (length l0)) ((a :: l0) ++ l1)) =
+  a :: fst (nth_split (length l0) (l0 ++ l1))). simpl. destruct l0. simpl. reflexivity.
+  simpl. reflexivity. rewrite H. rewrite <- e. reflexivity.
+Qed.
+ +
+Lemma nth_split_idR : forall (l0 l1 : list MPropF), l1 = snd (nth_split (length l0) (l0 ++ l1)).
+Proof.
+induction l0.
+- intros. simpl. reflexivity.
+- intros. simpl (length (a :: l0)). pose (IHl0 l1). rewrite e. destruct l0.
+  * simpl. reflexivity.
+  * simpl (length (m :: l0)). simpl (S (S (length l0))).
+    simpl (length (m :: l0)) in e. rewrite <- e.
+    assert ((S (S (length l0))) = (length (a :: m :: l0))). simpl. reflexivity.
+    rewrite H. rewrite nth_split_length. simpl. reflexivity.
+Qed.
+ +
+Lemma nth_split_length_id : forall (l0 l1 : list MPropF) n, (length l0 = n) ->
+                                (fst (nth_split n (l0 ++ l1)) = l0 /\
+                                snd (nth_split n (l0 ++ l1)) = l1).
+Proof.
+induction l0.
+- intros. simpl. split. simpl in H. subst. simpl. reflexivity. simpl in H. subst. simpl. reflexivity.
+- intros. simpl in H. subst. split.
+  * assert (J1:length l0 = length l0). reflexivity. pose (@IHl0 l1 (length l0) J1).
+    destruct a0. simpl. destruct l0. simpl. reflexivity. simpl. rewrite <- H.
+    simpl. reflexivity.
+  * assert (J1:length l0 = length l0). reflexivity. pose (@IHl0 l1 (length l0) J1).
+    destruct a0. rewrite <- H0. simpl ((a :: l0) ++ snd (nth_split (length l0) (l0 ++ l1))).
+    assert ((nth_split (S (length l0)) (a :: l0 ++ snd (nth_split (length l0) (l0 ++ l1))) =
+    (a :: l0 ,snd (nth_split (length l0) (l0 ++ l1))))).
+    pose (nth_split_length (a :: l0) (snd (nth_split (length l0) (l0 ++ l1)))). apply e.
+    rewrite H1. simpl. reflexivity.
+Qed.
+ +
+Lemma effective_remove_nth : forall A l0 l1, ((remove_nth (S (length l0)) A (l0 ++ A :: l1)) = l0 ++ l1).
+Proof.
+induction l0.
+- intros. simpl. destruct (eq_dec_form A A). reflexivity. exfalso. auto.
+- intros. simpl (S (length (a :: l0))). repeat rewrite <- app_assoc. simpl ((a :: l0) ++ A :: l1).
+  pose (IHl0 l1). simpl ((a :: l0) ++ l1). rewrite <- e. simpl. reflexivity.
+Qed.
+ +
+
+
+ +
+ + + diff --git a/K.KS.KS_wkn.html b/K.KS.KS_wkn.html new file mode 100644 index 0000000..c1187b0 --- /dev/null +++ b/K.KS.KS_wkn.html @@ -0,0 +1,518 @@ + + + + + + + + + + + + + +
+
+

K.KS.KS_wkn

+ +
+Require Import List.
+Export ListNotations.
+Require Import Lia.
+Require Import PeanoNat.
+Require Import Arith.
+ +
+Require Import KS_calc.
+Require Import KS_dec.
+ +
+(* We define the relations which take care of the notion of weakening. *)
+ +
+Inductive wkn_L (fml : MPropF) : relationT Seq :=
+  | wkn_LI Γ0 Γ1 Δ : wkn_L fml
+        (Γ0 ++ Γ1, Δ) (Γ0 ++ fml :: Γ1, Δ).
+ +
+Inductive wkn_R (fml : MPropF) : relationT Seq :=
+  | wkn_RI Γ Δ0 Δ1 : wkn_R fml
+        (Γ, Δ0 ++ Δ1) (Γ, Δ0 ++ fml :: Δ1).
+ +
+(* The following lemmas make sure that if a rule is applied on a sequent s with
+premises ps, then the same rule is applicable on a sequent sw which is a weakened
+version of s, with some premises psw that are such that they are either the same premises
+(in case the weakened formula is weakened in the rule) or weakened versions of ps. *)

+ +
+Lemma ImpR_app_wkn_L : forall s sw A ps,
+  (@wkn_L A s sw) ->
+  (ImpRRule [ps] s) ->
+  (existsT2 psw, (ImpRRule [psw] sw) * (@wkn_L A ps psw)).
+Proof.
+intros s sw A ps wkn RA. inversion RA. inversion wkn. subst.
+inversion H. subst. apply app2_find_hole in H1. destruct H1.
+repeat destruct s ; destruct p ; subst.
+- exists (Γ2 ++ A0 :: A :: Γ3, Δ0 ++ B :: Δ1). repeat split ; try assumption.
+  rewrite cons_single. rewrite cons_single with (v:=A0). rewrite app_assoc. rewrite app_assoc with (l:=Γ2).
+  apply wkn_LI.
+- exists ((Γ2 ++ A :: x) ++ A0 :: Γ1, Δ0 ++ B :: Δ1). split.
+  * assert (Γ2 ++ A :: x ++ Γ1 = (Γ2 ++ A :: x) ++ Γ1). rewrite <- app_assoc. reflexivity.
+    rewrite H0. apply ImpRRule_I ; assumption.
+  * repeat rewrite <- app_assoc. apply wkn_LI.
+- exists (Γ0 ++ A0 :: x ++ A :: Γ3, Δ0 ++ B :: Δ1). split.
+  * repeat rewrite <- app_assoc. apply ImpRRule_I ; assumption.
+  * rewrite cons_single. rewrite cons_single with (v:=A0). rewrite app_assoc. rewrite app_assoc with (l:=Γ0).
+    rewrite app_assoc. rewrite app_assoc with (l:=(Γ0 ++ [A0])). apply wkn_LI.
+Qed.
+ +
+Lemma ImpL_app_wkn_L : forall s sw A ps1 ps2,
+  (@wkn_L A s sw) ->
+  (ImpLRule [ps1;ps2] s) ->
+  (existsT2 psw1 psw2, (ImpLRule [psw1;psw2] sw) *
+                                                  (@wkn_L A ps1 psw1) *
+                                                  (@wkn_L A ps2 psw2)).
+Proof.
+intros s sw A ps1 ps2 wkn RA. inversion RA. inversion wkn. subst.
+inversion H. subst. apply app2_find_hole in H1. destruct H1. repeat destruct s ; destruct p ; subst.
+  - exists (Γ2 ++ A :: Γ1, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ A :: B :: Γ1, Δ0 ++ Δ1).
+    split. split. assert (E1: Γ2 ++ A :: Γ1 = (Γ2 ++ [A]) ++ Γ1). rewrite <- app_assoc.
+    simpl. auto. rewrite E1. assert (E2 : Γ2 ++ A :: B :: Γ1 = (Γ2 ++ [A]) ++ B :: Γ1).
+    rewrite <- app_assoc. simpl. auto. rewrite E2. assert (E3 : Γ2 ++ A :: A0 --> B :: Γ1 = (Γ2 ++ [A]) ++ A0 --> B :: Γ1).
+    rewrite <- app_assoc. simpl. auto. rewrite E3. apply ImpLRule_I.
+    apply wkn_LI. apply wkn_LI.
+  - exists (Γ2 ++ A :: x ++ Γ1, Δ0 ++ A0 :: Δ1). exists (Γ2 ++ A :: x ++ B :: Γ1, Δ0 ++ Δ1).
+    split. split. assert (E1: Γ2 ++ A :: x ++ Γ1 = (Γ2 ++ [A] ++ x) ++ Γ1). rewrite <- app_assoc.
+    simpl. auto. rewrite E1. assert (E2 : Γ2 ++ A :: x ++ B :: Γ1 = (Γ2 ++ [A] ++ x) ++ B :: Γ1).
+    rewrite <- app_assoc. simpl. auto. rewrite E2.
+    assert (E3 : Γ2 ++ A :: x ++ A0 --> B :: Γ1 = (Γ2 ++ [A] ++ x) ++ A0 --> B :: Γ1).
+    rewrite <- app_assoc. simpl. auto. rewrite E3. apply ImpLRule_I.
+    repeat rewrite <- app_assoc. apply wkn_LI. repeat rewrite <- app_assoc. apply wkn_LI.
+  - destruct x ; subst ; repeat rewrite app_nil_r.
+    + simpl in e0. subst. exists (Γ0 ++ A :: Γ1, Δ0 ++ A0 :: Δ1). exists (Γ0 ++ A :: B :: Γ1, Δ0 ++ Δ1) .
+      split. split. assert (E1: Γ0 ++ A :: Γ1 = (Γ0 ++ [A]) ++ Γ1). rewrite <- app_assoc.
+      simpl. auto. rewrite E1. assert (E2 : Γ0 ++ A :: B :: Γ1 = (Γ0 ++ [A]) ++ B :: Γ1).
+      rewrite <- app_assoc. simpl. auto. rewrite E2.
+      assert (E3 : Γ0 ++ A :: A0 --> B :: Γ1 = (Γ0 ++ [A]) ++ A0 --> B :: Γ1).
+      rewrite <- app_assoc. simpl. auto. rewrite E3. apply ImpLRule_I.
+      repeat rewrite <- app_assoc. apply wkn_LI. repeat rewrite <- app_assoc. apply wkn_LI.
+    + inversion e0. subst. exists (Γ0 ++ x ++ A :: Γ3, Δ0 ++ A0 :: Δ1).
+      exists (Γ0 ++ B :: x ++ A :: Γ3, Δ0 ++ Δ1). split. split.
+      repeat rewrite <- app_assoc. apply ImpLRule_I.
+      assert (Γ0 ++ x ++ Γ3 = (Γ0 ++ x) ++ Γ3). rewrite <- app_assoc. reflexivity.
+      rewrite H0. assert (Γ0 ++ x ++ A :: Γ3 = (Γ0 ++ x) ++ A :: Γ3). rewrite <- app_assoc. reflexivity.
+      rewrite H1. apply wkn_LI.
+      assert (Γ0 ++ B :: x ++ Γ3 = (Γ0 ++ B :: x) ++ Γ3). rewrite <- app_assoc. reflexivity.
+      rewrite H0. assert (Γ0 ++ B :: x ++ A :: Γ3 = (Γ0 ++ B :: x) ++ A :: Γ3). rewrite <- app_assoc. reflexivity.
+      rewrite H1. apply wkn_LI.
+Qed.
+ +
+Lemma KR_app_wkn_L : forall s sw A ps,
+  (@wkn_L A s sw) ->
+  (KRRule [ps] s) ->
+  ((KRRule [ps] sw) +
+   (existsT2 psw, (KRRule [psw] sw) * (@wkn_L (unBox_formula A) ps psw))).
+Proof.
+intros s sw A ps wkn RA. inversion RA. inversion wkn. rewrite <- H1 in H2.
+inversion H2. subst. destruct (dec_is_boxedT A).
+  * right. apply univ_gen_ext_splitR in X. destruct X. destruct s. repeat destruct p.
+    subst. exists (unboxed_list (x ++ A :: x0), [A0]). split.
+    + apply KRRule_I. intro. intros. apply in_app_or in H. destruct H. apply H0. apply in_or_app. auto.
+      inversion H. subst. assumption. apply H0. apply in_or_app. auto. apply univ_gen_ext_combine.
+      assumption. apply univ_gen_ext_cons. assumption.
+    + repeat rewrite unbox_app_distrib. simpl. apply wkn_LI.
+  * left. apply KRRule_I.
+    + assumption.
+    + apply univ_gen_ext_splitR in X. destruct X. destruct s. repeat destruct p.
+      subst. apply univ_gen_ext_combine. assumption. apply univ_gen_ext_extra. assumption.
+      assumption.
+Qed.
+ +
+Lemma ImpR_app_wkn_R : forall s sw A ps,
+  (@wkn_R A s sw) ->
+  (ImpRRule [ps] s) ->
+  ((existsT2 psw, (ImpRRule [psw] sw) * (@wkn_R A ps psw))).
+Proof.
+intros s sw A ps wkn RA. inversion RA. inversion wkn. subst. inversion H.
+subst. apply app2_find_hole in H2. destruct H2. repeat destruct s ; destruct p ; subst.
+  - exists (Γ0 ++ A0 :: Γ1, Δ2 ++ A :: B :: Δ1). split.
+    assert (E1: Δ2 ++ A :: B :: Δ1 = (Δ2 ++ [A]) ++ B :: Δ1). rewrite <- app_assoc.
+    simpl. auto. rewrite E1. assert (E3 : Δ2 ++ A :: A0 --> B :: Δ1 = (Δ2 ++ [A]) ++ A0 --> B :: Δ1).
+    rewrite <- app_assoc. simpl. auto. rewrite E3. apply ImpRRule_I.
+    apply wkn_RI.
+  - exists (Γ0 ++ A0 :: Γ1, Δ2 ++ A :: x ++ B :: Δ1).
+    split. assert (E1: Δ2 ++ A :: x ++ B :: Δ1 = (Δ2 ++ [A] ++ x) ++ B :: Δ1). rewrite <- app_assoc.
+    simpl. auto. rewrite E1. assert (E2 : Δ2 ++ A :: x ++ A0 --> B :: Δ1 = (Δ2 ++ [A] ++ x) ++ A0 --> B :: Δ1).
+    rewrite <- app_assoc. simpl. auto. rewrite E2. apply ImpRRule_I.
+    repeat rewrite <- app_assoc. apply wkn_RI.
+  - destruct x ; subst ; repeat rewrite app_nil_r.
+    + simpl in e0. subst. exists (Γ0 ++ A0 :: Γ1, Δ0 ++ A :: B :: Δ1).
+      split. assert (E1: Δ0 ++ A :: B :: Δ1 = (Δ0 ++ [A]) ++ B :: Δ1). rewrite <- app_assoc.
+      simpl. auto. rewrite E1.
+      assert (E3 : Δ0 ++ A :: A0 --> B :: Δ1 = (Δ0 ++ [A]) ++ A0 --> B :: Δ1).
+      rewrite <- app_assoc. simpl. auto. rewrite E3. apply ImpRRule_I.
+      repeat rewrite <- app_assoc. apply wkn_RI.
+    + inversion e0. subst. exists (Γ0 ++ A0 :: Γ1, Δ0 ++ B :: x ++ A :: Δ3).
+      split. repeat rewrite <- app_assoc. apply ImpRRule_I.
+      assert (Δ0 ++ B :: x ++ Δ3 = (Δ0 ++ B :: x) ++ Δ3). rewrite <- app_assoc. reflexivity.
+      rewrite H0. assert (Δ0 ++ B :: x ++ A :: Δ3 = (Δ0 ++ B :: x) ++ A :: Δ3). rewrite <- app_assoc. reflexivity.
+      rewrite H1. apply wkn_RI.
+Qed.
+ +
+Lemma ImpL_app_wkn_R : forall s sw A ps1 ps2,
+  (@wkn_R A s sw) ->
+  (ImpLRule [ps1;ps2] s) ->
+  (existsT2 psw1 psw2, (ImpLRule [psw1;psw2] sw) * (@wkn_R A ps1 psw1) *
+                                                   (@wkn_R A ps2 psw2)).
+Proof.
+intros s sw A ps1 ps2 wkn RA. inversion RA. inversion wkn. subst.
+inversion H. subst. apply app2_find_hole in H2. destruct H2. repeat destruct s.
+- destruct p. subst. exists (Γ0 ++ Γ1, Δ2 ++ A0 :: A :: Δ3).
+  exists (Γ0 ++ B :: Γ1, Δ2 ++ A :: Δ3). repeat split.
+  assert (E1: Δ2 ++ A0 :: A :: Δ3 = (Δ2 ++ [A0]) ++ A :: Δ3).
+  repeat rewrite <- app_assoc. simpl. reflexivity. rewrite E1.
+  assert (E2: Δ2 ++ A0 :: Δ3 = (Δ2 ++ [A0]) ++ Δ3).
+  repeat rewrite <- app_assoc. simpl. reflexivity. rewrite E2. apply wkn_RI.
+- destruct p. subst. exists (Γ0 ++ Γ1, (Δ2 ++ A :: x) ++ A0 :: Δ1). exists (Γ0 ++ B :: Γ1, (Δ2 ++ A :: x) ++ Δ1).
+  split. split.
+  * assert (E: Δ2 ++ A :: x ++ Δ1 = (Δ2 ++ A :: x) ++ Δ1). rewrite <- app_assoc. simpl. reflexivity.
+    rewrite E. apply ImpLRule_I ; assumption.
+  * repeat rewrite <- app_assoc. simpl. apply wkn_RI.
+  * repeat rewrite <- app_assoc. simpl. apply wkn_RI.
+- destruct p. subst. exists (Γ0 ++ Γ1, Δ0 ++ A0 :: x ++ A :: Δ3).
+  exists (Γ0 ++ B :: Γ1, Δ0 ++ x ++ A :: Δ3). repeat split.
+  * rewrite <- app_assoc. apply ImpLRule_I ; assumption.
+  * assert (E1: Δ0 ++ A0 :: x ++ Δ3 = (Δ0 ++ A0 :: x) ++ Δ3). rewrite <- app_assoc. simpl. reflexivity.
+    rewrite E1.
+    assert (E2: Δ0 ++ A0 :: x ++ A :: Δ3 = (Δ0 ++ A0 :: x) ++ A :: Δ3). rewrite <- app_assoc. simpl. reflexivity.
+    rewrite E2. apply wkn_RI.
+  * rewrite app_assoc with (l:=Δ0). apply wkn_RI.
+Qed.
+ +
+Lemma KR_app_wkn_R : forall s sw A ps,
+  (@wkn_R A s sw) ->
+  (KRRule [ps] s) ->
+  (KRRule [ps] sw).
+Proof.
+intros s sw A ps wkn RA. inversion RA. inversion wkn. rewrite <- H1 in H2.
+inversion H2. apply app2_find_hole in H6. destruct H6. repeat destruct s0.
+- destruct p. subst. assert (Δ2 ++ A :: Box A0 :: Δ1 = (Δ2 ++ [A]) ++ Box A0 :: Δ1).
+  rewrite <- app_assoc. simpl. reflexivity. rewrite H. apply KRRule_I ; assumption.
+- destruct p. subst. assert (E: Δ2 ++ A :: x ++ Box A0 :: Δ1 = (Δ2 ++ A :: x) ++ Box A0 :: Δ1).
+  repeat rewrite <- app_assoc. simpl. reflexivity. rewrite E.
+  apply KRRule_I ; assumption.
+- destruct p. subst. destruct x.
+  + rewrite app_nil_r. rewrite app_nil_l in e0. subst. assert (Δ0 ++ A :: Box A0 :: Δ1 = (Δ0 ++ [A]) ++ Box A0 :: Δ1).
+    rewrite <- app_assoc. reflexivity. rewrite H. apply KRRule_I ; assumption.
+  + inversion e0. subst. rewrite <- app_assoc. simpl. apply KRRule_I ; assumption.
+Qed.
+ +
+(* Now we can prove that weakening is height-preserving admissible. *)
+ +
+Theorem KS_wkn_L : forall (k : nat) s
+        (D0 : KS_prv s),
+        k = (derrec_height D0) ->
+          (forall sw A, ((@wkn_L A s sw) ->
+          existsT2 (D1 : KS_prv sw),
+          derrec_height D1 <= k)).
+Proof.
+induction k as [n IH] using (well_founded_induction_type lt_wf).
+intros s0 D0. remember D0 as D0'. destruct D0.
+(* D0 is a leaf *)
+- intros hei sw A wkn. inversion f.
+(* D0 ends with an application of rule *)
+- intros hei sw A wkn. inversion wkn. inversion k.
+  (* IdP *)
+  * inversion H1. rewrite <- H in H5. inversion H5. apply app2_find_hole in H7.
+    destruct H7. assert (DersNil: dersrec KS_rules (fun _ : Seq => False) []).
+    apply dersrec_nil.
+    destruct s.
+    + destruct s.
+      { destruct p. inversion e0. subst. pose (IdPRule_I P (Γ2 ++ [A]) Γ3 Δ0 Δ1). apply IdP in i. rewrite <- app_assoc in i.
+        simpl in i. pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ2 ++ A :: # P :: Γ3, Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+        left. reflexivity. reflexivity. }
+      { destruct p. destruct x.
+        - rewrite app_nil_l in e0. inversion e0. subst.
+          pose (IdPRule_I P ((Γ2 ++ []) ++ [A]) Γ3 Δ0 Δ1). apply IdP in i. rewrite <- app_assoc in i. simpl in i.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ2 ++ []) ++ A :: # P :: Γ3, Δ0 ++ # P :: Δ1) i DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+          left. reflexivity. reflexivity.
+        - inversion e0. subst.
+          pose (IdPRule_I P Γ2 (x ++ A :: Γ1) Δ0 Δ1). apply IdP in i.
+          assert (E0 : Γ2 ++ # P :: x ++ A :: Γ1 = (Γ2 ++ # P :: x) ++ A :: Γ1). rewrite <- app_assoc. reflexivity.
+          rewrite E0 in i.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ2 ++ # P :: x) ++ A :: Γ1, Δ0 ++ # P :: Δ1) i DersNil).
+          exists d0. simpl. repeat rewrite dersrec_height_nil.
+          left. reflexivity. reflexivity. }
+    + destruct p. subst. pose (IdPRule_I P (Γ0 ++ A :: x) Γ3 Δ0 Δ1). apply IdP in i. rewrite <- app_assoc in i. simpl in i.
+      pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[]) (Γ0 ++ A :: x ++ # P :: Γ3, Δ0 ++ # P :: Δ1) i DersNil).
+      exists d0. simpl. repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+  (* BotL *)
+  * inversion H1. rewrite <- H in H5. inversion H5.
+    assert (DersNil: dersrec KS_rules (fun _ : Seq => False) []).
+    apply dersrec_nil.
+    apply app2_find_hole in H7. destruct H7. destruct s.
+    + destruct s.
+      { destruct p. inversion e0. subst.
+        pose (BotLRule_I (Γ2 ++ [A]) Γ3 Δ). apply BotL in b. rewrite <- app_assoc in b. simpl in b.
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ2 ++ A :: Bot :: Γ3, Δ) b DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+        left. reflexivity. reflexivity. }
+      { destruct p. destruct x.
+        - rewrite app_nil_l in e0. inversion e0. subst.
+          pose (BotLRule_I ((Γ2 ++ []) ++ [A]) Γ3 Δ). apply BotL in b. rewrite <- app_assoc in b. simpl in b.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ2 ++ []) ++ A :: Bot :: Γ3, Δ) b DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+          left. reflexivity. reflexivity.
+        - inversion e0. subst.
+          pose (BotLRule_I Γ2 (x ++ A :: Γ1) Δ). apply BotL in b.
+          assert (E0: Γ2 ++ Bot :: x ++ A :: Γ1 = (Γ2 ++ Bot :: x) ++ A :: Γ1). rewrite <- app_assoc. reflexivity.
+          rewrite E0 in b.
+          pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+          (ps:=[]) ((Γ2 ++ Bot :: x) ++ A :: Γ1, Δ) b DersNil).
+          exists d0. simpl. repeat rewrite dersrec_height_nil.
+          left. reflexivity. reflexivity. }
+    + destruct p. subst. pose (BotLRule_I (Γ0 ++ A :: x) Γ3 Δ). apply BotL in b.
+      assert (E0 : (Γ0 ++ A :: x) ++ Bot :: Γ3 = Γ0 ++ A :: x ++ Bot :: Γ3).
+      rewrite <- app_assoc. reflexivity. rewrite E0 in b.
+      pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[]) (Γ0 ++ A :: x ++ Bot :: Γ3, Δ) b DersNil). exists d0. simpl.
+      repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+  (* ImpR *)
+  * assert (DersNil: dersrec KS_rules (fun _ : Seq => False) []).
+    apply dersrec_nil.
+    inversion H1. subst. inversion H5. subst. pose (ImpR_app_wkn_L _ _ _ _ wkn H1). destruct s.
+    repeat destruct p. remember [(Γ2 ++ A0 :: Γ3, Δ0 ++ B :: Δ1)] as ps'. destruct d.
+    inversion Heqps'. inversion Heqps'. subst.
+    assert (E: derrec_height d < S (derrec_height d)). auto.
+    assert (E1: derrec_height d = derrec_height d). auto. simpl in IH.
+    rewrite dersrec_height_nil in IH. 2: reflexivity. rewrite Nat.max_0_r in IH.
+    pose (IH (derrec_height d) E (Γ2 ++ A0 :: Γ3, Δ0 ++ B :: Δ1) d
+    E1 x A w).
+    destruct s. pose (dlCons x0 d0). apply ImpR in i.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x]) (Γ0 ++ A :: Γ1, Δ0 ++ A0 --> B :: Δ1) i).
+    pose (d2 d1). exists d3.
+    simpl. repeat rewrite dersrec_height_nil. repeat rewrite Nat.max_0_r.
+    rewrite <- Nat.succ_le_mono. assumption. reflexivity.
+  (* ImpL *)
+  * inversion H1. subst. inversion H5. subst. pose (ImpL_app_wkn_L _ _ _ _ _ wkn H1). repeat destruct s.
+    repeat destruct p. apply ImpL in i.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x;x0]) (Γ0 ++ A :: Γ1, Δ0 ++ Δ1) i). subst. simpl.
+    remember [(Γ2 ++ Γ3, Δ0 ++ A0 :: Δ1); (Γ2 ++ B :: Γ3, Δ0 ++ Δ1)] as ps'. destruct d.
+    inversion Heqps'. inversion Heqps'. subst.
+    remember [(Γ2 ++ B :: Γ3, Δ0 ++ Δ1)] as ps''. destruct d1. inversion Heqps''.
+    inversion Heqps''. simpl. subst. rewrite dersrec_height_nil. simpl in IH.
+    rewrite dersrec_height_nil in IH. rewrite Nat.max_0_r. rewrite Nat.max_0_r in IH.
+    assert (E1: derrec_height d < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+    apply Nat.lt_succ_r. apply Nat.le_max_l.
+    assert (E2: derrec_height d = derrec_height d). auto.
+    pose (IH (derrec_height d) E1 (Γ2 ++ Γ3, Δ0 ++ A0 :: Δ1) d E2 x A w0).
+    destruct s.
+    assert (E3: derrec_height d1 < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+    apply Nat.lt_succ_r. apply Nat.le_max_r.
+    assert (E4: derrec_height d1 = derrec_height d1). auto.
+    pose (IH (derrec_height d1) E3 (Γ2 ++ B :: Γ3, Δ0 ++ Δ1) d1 E4 x0 A w).
+    destruct s.
+    pose (dlCons x1 (dlCons x2 d2)). subst. pose (d0 d3). exists d4. simpl. rewrite dersrec_height_nil.
+    rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. apply Nat.max_le_compat.
+    assumption. assumption. reflexivity. reflexivity. reflexivity.
+  (* KR *)
+  * inversion X. rewrite <- H4 in X. subst. pose (KR_app_wkn_L _ _ _ _ wkn X). destruct s.
+    { apply KR in k0. subst. pose (derI (rules:=KS_rules)
+      (prems:=fun _ : Seq => False) (ps:=[(unboxed_list , [A0])])
+      (Γ0 ++ A :: Γ1, Δ) k0). subst. pose (d0 d). exists d1. simpl. reflexivity. }
+    { repeat destruct s. repeat destruct p. apply KR in k0.
+      remember [(unboxed_list , [A0])] as ps'. destruct d. inversion Heqps'. subst.
+      inversion Heqps'. subst. simpl. simpl in IH.
+      assert (E1: derrec_height d < S (Init.Nat.max (derrec_height d) (dersrec_height d0))).
+      rewrite dersrec_height_nil. rewrite Nat.max_0_r. apply Nat.lt_succ_r. left. reflexivity.
+      assert (E2: derrec_height d = derrec_height d). auto.
+      pose (IH (derrec_height d) E1 ((unboxed_list , [A0])) d E2 x (unBox_formula A) w).
+      destruct s. pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[x]) (Γ0 ++ A :: Γ1, Δ) k0). subst. simpl.
+      pose (dlCons x0 d0). pose (d1 d2). exists d3. simpl. rewrite dersrec_height_nil.
+      repeat rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. lia. auto. }
+Qed.
+ +
+Theorem KS_hpadm_wkn_L : forall s (D0 : KS_prv s),
+          (forall sw A, ((@wkn_L A s sw) ->
+          existsT2 (D1 : KS_prv sw),
+          derrec_height D1 <= derrec_height D0)).
+Proof.
+intros.
+assert (J0 : derrec_height D0 = derrec_height D0). auto.
+pose (KS_wkn_L _ _ D0 J0 _ _ H). auto.
+Qed.
+ +
+Theorem KS_wkn_R : forall (k : nat) s
+        (D0 : KS_prv s),
+        k = (derrec_height D0) ->
+          (forall sw A, ((@wkn_R A s sw) ->
+          existsT2 (D1 : KS_prv sw),
+          derrec_height D1 <= k)).
+Proof.
+induction k as [n IH] using (well_founded_induction_type lt_wf).
+intros s0 D0. remember D0 as D0'. destruct D0.
+(* D0 is a leaf *)
+- intros hei sw A wkn. inversion f.
+(* D0 ends with an application of rule *)
+- intros hei sw A wkn. inversion wkn. inversion k.
+  (* IdP *)
+  * inversion H1. rewrite <- H in H5. inversion H5. apply app2_find_hole in H8.
+    destruct H8. assert (DersNil: dersrec KS_rules (fun _ : Seq => False) []).
+    apply dersrec_nil.
+    repeat destruct s.
+    + destruct p. inversion e0. subst. pose (IdPRule_I P Γ0 Γ1 (Δ2 ++ [A]) Δ3). apply IdP in i. rewrite <- app_assoc in i. simpl in i.
+      pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[]) (Γ0 ++ # P :: Γ1, Δ2 ++ A :: # P :: Δ3) i DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+      left. reflexivity. reflexivity.
+    + destruct p. destruct x.
+      { rewrite app_nil_l in e0. inversion e0. subst.
+        pose (IdPRule_I P Γ0 Γ1 ((Δ2 ++ []) ++ [A]) Δ3). apply IdP in i. rewrite <- app_assoc in i. simpl in i.
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ0 ++ # P :: Γ1, (Δ2 ++ []) ++ A :: # P :: Δ3) i DersNil). exists d0. simpl. repeat rewrite dersrec_height_nil.
+        left. reflexivity. reflexivity. }
+      { inversion e0. subst.
+        pose (IdPRule_I P Γ0 Γ1 Δ2 (x ++ A :: Δ1)). apply IdP in i.
+        assert (E0: Δ2 ++ # P :: x ++ A :: Δ1 = (Δ2 ++ # P :: x) ++ A :: Δ1). rewrite <- app_assoc. reflexivity.
+        rewrite E0 in i.
+        pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+        (ps:=[]) (Γ0 ++ # P :: Γ1, (Δ2 ++ # P :: x) ++ A :: Δ1) i DersNil).
+        exists d0. simpl. repeat rewrite dersrec_height_nil.
+        left. reflexivity. reflexivity. }
+    + destruct p. subst. pose (IdPRule_I P Γ0 Γ1 (Δ0 ++ A :: x) Δ3). apply IdP in i. rewrite <- app_assoc in i. simpl in i.
+      pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+      (ps:=[]) (Γ0 ++ # P :: Γ1, Δ0 ++ A :: x ++ # P :: Δ3) i DersNil).
+      exists d0. simpl. repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+  (* BotL *)
+  * inversion H1. rewrite <- H in H5. inversion H5.
+    assert (DersNil: dersrec KS_rules (fun _ : Seq => False) []).
+    apply dersrec_nil.
+    pose (BotLRule_I Γ0 Γ1 (Δ0 ++ A :: Δ1)). apply BotL in b.
+    pose (derI (rules:=KS_rules)
+    (prems:=fun _ : Seq => False)
+    (ps:=[]) (Γ0 ++ Bot :: Γ1, Δ0 ++ A :: Δ1) b DersNil). subst. exists d0. simpl.
+    repeat rewrite dersrec_height_nil. left. reflexivity. reflexivity.
+  (* ImpR *)
+  * inversion H1. subst. inversion H5. subst. pose (ImpR_app_wkn_R _ _ _ _ wkn H1). destruct s.
+    destruct p. apply ImpR in i.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x]) (Γ0 ++ Γ1, Δ0 ++ A :: Δ1) i). subst. simpl.
+    remember [(Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3)] as ps'. destruct d. inversion Heqps'.
+    inversion Heqps'. subst. simpl. rewrite dersrec_height_nil. simpl in IH.
+    rewrite dersrec_height_nil in IH. rewrite Nat.max_0_r. rewrite Nat.max_0_r in IH.
+    assert (E: derrec_height d < S (derrec_height d)). auto.
+    assert (E1: derrec_height d = derrec_height d). auto.
+    pose (IH (derrec_height d) E (Γ0 ++ A0 :: Γ1, Δ2 ++ B :: Δ3) d E1 x A w).
+    destruct s.
+    pose (dlCons x0 d1). pose (d0 d2). exists d3. simpl. rewrite dersrec_height_nil.
+    rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. assumption. reflexivity. reflexivity. reflexivity.
+  (* ImpL *)
+  * inversion H1. subst. inversion H5. subst. pose (ImpL_app_wkn_R _ _ _ _ _ wkn H1). repeat destruct s.
+    repeat destruct p. apply ImpL in i.
+    pose (derI (rules:=KS_rules) (prems:=fun _ : Seq => False)
+    (ps:=[x;x0]) (Γ0 ++ A0 --> B :: Γ1, Δ0 ++ A :: Δ1) i). subst. simpl.
+    remember [(Γ0 ++ Γ1, Δ2 ++ A0 :: Δ3); (Γ0 ++ B :: Γ1, Δ2 ++ Δ3)] as ps'. destruct d.
+    inversion Heqps'. inversion Heqps'. subst.
+    remember [(Γ0 ++ B :: Γ1, Δ2 ++ Δ3)] as ps''. destruct d1. inversion Heqps''.
+    inversion Heqps''. simpl. subst. rewrite dersrec_height_nil. simpl in IH.
+    rewrite dersrec_height_nil in IH. rewrite Nat.max_0_r. rewrite Nat.max_0_r in IH.
+    assert (E1: derrec_height d < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+    apply Nat.lt_succ_r. apply Nat.le_max_l.
+    assert (E2: derrec_height d = derrec_height d). auto.
+    pose (IH (derrec_height d) E1 (Γ0 ++ Γ1, Δ2 ++ A0 :: Δ3) d E2 x A w0).
+    destruct s.
+    assert (E3: derrec_height d1 < S (Init.Nat.max (derrec_height d)(derrec_height d1))).
+    apply Nat.lt_succ_r. apply Nat.le_max_r.
+    assert (E4: derrec_height d1 = derrec_height d1). auto.
+    pose (IH (derrec_height d1) E3 (Γ0 ++ B :: Γ1, Δ2 ++ Δ3) d1 E4 x0 A w).
+    destruct s.
+    pose (dlCons x1 (dlCons x2 d2)). subst. pose (d0 d3). exists d4. simpl. rewrite dersrec_height_nil.
+    rewrite Nat.max_0_r. rewrite <- Nat.succ_le_mono. apply Nat.max_le_compat.
+    assumption. assumption. reflexivity. reflexivity. reflexivity.
+  (* KR *)
+  * inversion X. rewrite <- H4 in X. pose (KR_app_wkn_R _ _ _ _ wkn X).
+    apply KR in k0. pose (derI (rules:=KS_rules)
+    (prems:=fun _ : Seq => False) (ps:=[(unboxed_list , [A0])])
+    sw k0). subst. pose (d0 d). exists d1. simpl. reflexivity.
+Qed.
+ +
+Theorem KS_hpadm_wkn_R : forall s (D0 : KS_prv s),
+          (forall sw A, ((@wkn_R A s sw) ->
+          existsT2 (D1 : KS_prv sw),
+          derrec_height D1 <= derrec_height D0)).
+Proof.
+intros.
+assert (J0 : derrec_height D0 = derrec_height D0). auto.
+pose (KS_wkn_R _ _ D0 J0 _ _ H). auto.
+Qed.
+ +
+Theorem KS_list_wkn_R : forall (k : nat) Γ Δ0 Δ1
+        (D0 : KS_prv (Γ,Δ0 ++ Δ1)),
+        k = (derrec_height D0) ->
+          (forall l, existsT2 (D1 : KS_prv (Γ,Δ0 ++ l ++ Δ1)),
+           derrec_height D1 <= k).
+Proof.
+intros. induction l.
+- simpl. exists D0. lia.
+- simpl. destruct IHl.
+  assert (E: derrec_height x = derrec_height x). reflexivity.
+  assert (H0: wkn_R a (Γ, Δ0 ++ l ++ Δ1) (Γ, Δ0 ++ a :: l ++ Δ1)). apply wkn_RI.
+  pose (@KS_wkn_R (derrec_height x) (Γ, Δ0 ++ l ++ Δ1) x E (Γ, Δ0 ++ a :: l ++ Δ1) a H0).
+  destruct s. exists x0. lia.
+Qed.
+ +
+Theorem KS_list_wkn_L : forall (k : nat) Γ0 Γ1 Δ
+        (D0 : KS_prv (Γ0 ++ Γ1,Δ)),
+        k = (derrec_height D0) ->
+          (forall l, existsT2 (D1 : KS_prv (Γ0 ++ l ++ Γ1,Δ)),
+          derrec_height D1 <= k).
+Proof.
+intros. induction l.
+- simpl. exists D0. lia.
+- simpl. destruct IHl.
+  assert (E: derrec_height x = derrec_height x). reflexivity.
+  assert (H0: wkn_L a (Γ0 ++ l ++ Γ1, Δ) (Γ0 ++ a :: l ++ Γ1, Δ)). apply wkn_LI.
+  pose (@KS_wkn_L (derrec_height x) (Γ0 ++ l ++ Γ1, Δ) x E (Γ0 ++ a :: l ++ Γ1, Δ) a H0).
+  destruct s. exists x0. lia.
+Qed.
+
+
+ +
+ + + diff --git a/Syntax.CML_Syntax.html b/Syntax.CML_Syntax.html new file mode 100644 index 0000000..1beb6d2 --- /dev/null +++ b/Syntax.CML_Syntax.html @@ -0,0 +1,277 @@ + + + + + + + + + + + + + +
+
+

Syntax.CML_Syntax

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat String.
+ +
+Require Import general_export.
+ +
+Set Implicit Arguments.
+ +
+(* Definitions Language *)
+ +
+(* First, let us define the propositional formulas we use here. *)
+ +
+Inductive MPropF : Type :=
+ | Var : string -> MPropF
+ | Bot : MPropF
+ | Imp : MPropF -> MPropF -> MPropF
+ | Box : MPropF -> MPropF
+.
+ +
+Notation "# p" := (Var p) (at level 1).
+Notation "A --> B" := (Imp A B) (at level 16, right associativity).
+Notation "⊥" := Bot (at level 0).
+Notation "¬ A" := (A --> ) (at level 42).
+ +
+  Definition Top := (Bot --> Bot).
+  Definition Neg (A : MPropF) := A --> Bot.
+  Definition And (A B : MPropF) := Neg (A --> Neg B).
+  Definition Or (A B : MPropF) := (Neg A) --> B.
+  Definition Diam (A : MPropF) := Neg (Box (Neg A)).
+ +
+Fixpoint subformlist (φ : MPropF) : list MPropF :=match φ with
+| Var p => (Var p) :: nil | Bot => Bot :: nil
+| Imp ψ χ => (Imp ψ χ) ::
+(subformlist ψ) ++ (subformlist χ) | Box ψ => (Box ψ) :: (subformlist ψ)end.
+ +
+Lemma eq_dec_form : forall x y : MPropF, {x = y} + {x <> y}.
+Proof.
+repeat decide equality.
+Defined.
+ +
+Global Opaque eq_dec_form.
+ +
+Fixpoint size (φ : MPropF) : nat :=
+match φ with
+| Var p => 1| Bot => 1
+| Imp ψ χ => 1 + (size ψ) + (size χ) | Box ψ => 1 + (size ψ)
+end.
+ +
+Fixpoint size_LF (l : list MPropF) : nat :=
+match l with
+  | [] => 0
+  | h :: t => (size h) + (size_LF t)
+end.
+ +
+Fixpoint subst (σ : string -> MPropF) (φ : MPropF) : MPropF :=
+match φ with
+| Var p => (σ p)
+| Bot => Bot
+| Imp ψ χ => Imp (subst σ ψ) (subst σ χ)| Box ψ => Box (subst σ ψ)
+end.
+ +
+Definition is_atomicT A : Type :=
+                  (exists p, A = # p) + (A = Bot).
+ +
+(* Order all this *)
+ +
+Definition is_boxedT (A : MPropF) : Type :=
+                  exists (B : MPropF), A = Box B.
+ +
+Definition is_Boxed_list (Γ : list (MPropF)) : Prop :=
+    forall (A : MPropF), (In A Γ) -> (exists (B : MPropF), A = Box B).
+ +
+Definition is_Prime (Γ : list MPropF) : Prop :=
+    forall (A : MPropF), (In A Γ) ->
+    (exists (B : MPropF), A = Box B) \/ (exists P, A = # P) \/ (A = Bot).
+ +
+(* With these properties we can define restrictions of univ_gen_ext on
+   formulae. *)

+ +
+Definition nobox_gen_ext := univ_gen_ext (fun x => (is_boxedT x) -> False).
+ +
+(* A lemmas about nobox_gen_ext. *)
+ +
+Lemma nobox_gen_ext_injective : forall (l0 l1 l : list (MPropF)), (is_Boxed_list l0) -> (is_Boxed_list l1) ->
+                                (nobox_gen_ext l0 l) -> (nobox_gen_ext l1 l) -> l1 = l0.
+Proof.
+intros l0 l1 l Hl0 Hl1 gen. generalize dependent l1.
+induction gen.
+- intros. inversion X. reflexivity.
+- intros. inversion X.
+  * subst. assert (l0 = l). apply IHgen. intro. intros. apply Hl0. apply in_cons. assumption.
+    intro. intros. apply Hl1. apply in_cons. assumption. assumption. rewrite H. reflexivity.
+  * subst. exfalso. apply H1. apply Hl0. apply in_eq.
+- intros. apply IHgen. intro. intros. apply Hl0. assumption.
+  intro. intros. apply Hl1. assumption. inversion X.
+  subst. exfalso. apply p. apply Hl1. apply in_eq. subst. assumption.
+Qed.
+ +
+(* The next definitions help to define the combination of a list of boxed
+   formulae and the unboxing of all the formulae in that list. *)

+ +
+Definition unBox_formula (A : MPropF) : MPropF :=
+  match A with
+              | # P => # P
+              | Bot => Bot
+              | A --> B => A --> B
+              | Box A => A
+              end
+.
+ +
+Fixpoint unboxed_list (Γ : list (MPropF)) : list (MPropF):=
+  match Γ with
+  | [ ] => [ ]
+  | h :: t => (unBox_formula h :: unboxed_list t)
+  end
+.
+ +
+Fixpoint top_boxes (l : list (MPropF)) : list (MPropF) :=
+match l with
+  | nil => nil
+  | h :: t => match h with
+                | Box A => (Box A) :: top_boxes t
+                | _ => top_boxes t
+              end
+end.
+ +
+(* Now that we have defined these, we can prove some properties about them. *)
+ +
+Lemma unbox_app_distrib :
+  forall (l1 l2: list (MPropF)), unboxed_list (l1 ++ l2) = (unboxed_list l1) ++ (unboxed_list l2).
+Proof.
+induction l1.
+- intro l2. rewrite app_nil_l with (l:=l2). simpl. reflexivity.
+- intro l2. simpl. rewrite IHl1. reflexivity.
+Qed.
+ +
+Lemma subl_of_boxl_is_boxl {V : Set}:
+  forall (l1 l2: list (MPropF)), (incl l1 l2) -> (is_Boxed_list l2) -> (is_Boxed_list l1).
+Proof.
+intros. unfold is_Boxed_list. intros. apply H in H1. apply H0 in H1.
+destruct H1. exists x. assumption.
+Qed.
+ +
+Lemma tl_of_boxl_is_boxl {V : Set}:
+  forall (h : MPropF) (t l : list (MPropF)) (H: l = h :: t),
+         (is_Boxed_list l) -> (is_Boxed_list t).
+Proof.
+intros. unfold is_Boxed_list. intros. assert (Hyp: In A l).
+rewrite H. simpl. right. apply H1. apply H0 in Hyp. destruct Hyp.
+exists x. assumption.
+Qed.
+ +
+Lemma is_box_is_in_boxed_list : forall l (A : MPropF), In A l -> is_Boxed_list l -> (exists B, Box B = A).
+Proof.
+induction l.
+- intros. inversion H.
+- intros. inversion H.
+  + subst. unfold is_Boxed_list in H0. pose (H0 A).
+    apply e in H. destruct H. exists x. symmetry. assumption.
+  + apply IHl. assumption. unfold is_Boxed_list. intros. unfold is_Boxed_list in H0.
+    pose (H0 A0). apply e. apply in_cons. assumption.
+Qed.
+ +
+Lemma top_boxes_distr_app : forall (l1 l2 : list (MPropF)),
+      top_boxes (l1 ++ l2) = (top_boxes l1) ++ (top_boxes l2).
+Proof.
+induction l1.
+- intro l2. rewrite app_nil_l. simpl. reflexivity.
+- intro l2. simpl. destruct a ; try apply IHl1.
+  simpl. rewrite IHl1. reflexivity.
+Qed.
+ +
+Lemma box_in_top_boxes : forall l1 l2 A, existsT2 l3 l4, top_boxes (l1 ++ Box A :: l2) = l3 ++ Box A :: l4.
+Proof.
+intros. exists (top_boxes l1). exists (top_boxes l2). rewrite top_boxes_distr_app. auto.
+Qed.
+ +
+Lemma is_Boxed_list_top_boxes : forall l, is_Boxed_list (top_boxes l).
+Proof.
+intros. induction l.
+- simpl. intro. intros. inversion H.
+- intro. destruct a.
+  + simpl. intros. apply IHl in H. assumption.
+  + simpl. intros. apply IHl in H. assumption.
+  + simpl. intros. apply IHl in H. assumption.
+  + simpl. intros. destruct H.
+    * exists a. auto.
+    * apply IHl. assumption.
+Qed.
+ +
+Lemma nobox_gen_ext_top_boxes : forall l, nobox_gen_ext (top_boxes l) l.
+Proof.
+induction l.
+- simpl. apply univ_gen_ext_refl.
+- destruct a.
+  * simpl. apply univ_gen_ext_extra. intros. inversion X. inversion H. assumption.
+  * simpl. apply univ_gen_ext_extra. intros. inversion X. inversion H. assumption.
+  * simpl. apply univ_gen_ext_extra. intros. inversion X. inversion H. assumption.
+  * simpl. apply univ_gen_ext_cons. assumption.
+Qed.
+ +
+
+
+ +
+ + + diff --git a/Syntax.Syntax_export.html b/Syntax.Syntax_export.html new file mode 100644 index 0000000..5908bd1 --- /dev/null +++ b/Syntax.Syntax_export.html @@ -0,0 +1,43 @@ + + + + + + + + + + + + + +
+
+

Syntax.Syntax_export

+ +
+Require Export CML_Syntax.
+Require Export list_lems.
+Require Export remove_list_lems.
+
+
+ +
+ + + diff --git a/Syntax.list_lems.html b/Syntax.list_lems.html new file mode 100644 index 0000000..75e8d20 --- /dev/null +++ b/Syntax.list_lems.html @@ -0,0 +1,340 @@ + + + + + + + + + + + + + +
+
+

Syntax.list_lems

+ +
+Require Import List.
+Export ListNotations.
+ +
+Require Import genT.
+Require Import gen_tacs.
+Require Import List_lemmasT.
+Require Import existsT.
+ +
+Require Import CML_Syntax.
+ +
+(* Some useful lemmas about lists. *)
+ +
+Lemma in_exch_list : forall {A : Type} (l0 l1 l2 l3 l4 : list A) (a : A),
+  In a (l0 ++ l1 ++ l2 ++ l3 ++ l4) -> In a (l0 ++ l3 ++ l2 ++ l1 ++ l4).
+Proof.
+intros A l0 l1 l2 l3 l4 a H.
+apply in_app_or in H. destruct H. apply in_or_app. left. assumption.
+apply in_app_or in H. destruct H. apply in_or_app. right. apply in_or_app. right.
+apply in_or_app. right. apply in_or_app. left. assumption.
+apply in_app_or in H. destruct H. apply in_or_app. right. apply in_or_app. right.
+apply in_or_app. left. assumption.
+apply in_app_or in H. destruct H. apply in_or_app. right. apply in_or_app. left.
+assumption.
+apply in_or_app. right. apply in_or_app. right. apply in_or_app. right.
+apply in_or_app. right. assumption.
+Qed.
+ +
+Lemma InT_exch_list : forall {A : Type} (l0 l1 l2 l3 l4 : list A) (a : A),
+  InT a (l0 ++ l1 ++ l2 ++ l3 ++ l4) -> InT a (l0 ++ l3 ++ l2 ++ l1 ++ l4).
+Proof.
+intros A l0 l1 l2 l3 l4 a H.
+apply InT_app_or in H. destruct H. apply InT_or_app. left. assumption.
+apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app. right.
+apply InT_or_app. right. apply InT_or_app. left. assumption.
+apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app. right.
+apply InT_or_app. left. assumption.
+apply InT_app_or in i. destruct i. apply InT_or_app. right. apply InT_or_app. left.
+assumption.
+apply InT_or_app. right. apply InT_or_app. right. apply InT_or_app. right.
+apply InT_or_app. right. assumption.
+Qed.
+ +
+Lemma partition_1_element : forall {A : Type} (l1 l2 l3 l4 l5 l6 l7 : list A) a,
+l1 ++ l2 ++ l3 ++ l4 ++ l5 = l6 ++ a :: l7 ->
+  (existsT2 l8 l9, l1 = l8 ++ a :: l9) +
+  ((existsT2 l8 l9, l2 = l8 ++ a :: l9) +
+  ((existsT2 l8 l9, l3 = l8 ++ a :: l9) +
+  ((existsT2 l8 l9, l4 = l8 ++ a :: l9) +
+  ((existsT2 l8 l9, l5 = l8 ++ a :: l9))))).
+Proof.
+intros A l1. induction l1.
+- simpl. induction l2.
+  * simpl. induction l3.
+    + simpl. induction l4.
+      { simpl. intros. right. right. right. right. exists l6. exists l7.
+        assumption. }
+      { intros. destruct l6. simpl in H. right. right. right. left. exists []. simpl.
+        inversion H. exists l4. reflexivity.
+        inversion H. apply IHl4 in H2. destruct H2. destruct s. destruct s. exfalso.
+        apply app_cons_not_nil in e. assumption.
+        destruct s. destruct s. destruct s. exfalso.
+        apply app_cons_not_nil in e. assumption.
+        destruct s. destruct s. destruct s. exfalso.
+        apply app_cons_not_nil in e. assumption.
+        destruct s. destruct s. destruct s. right. right. right.
+        left. exists (a1 :: x). exists x0. simpl. rewrite e. reflexivity.
+        destruct s. destruct s. right. right. right. right. exists x. exists x0.
+        assumption. }
+    + intros l4 l5 l6 l7 a0 E. destruct l6.
+      { inversion E. right. right. left. exists []. exists l3. simpl. reflexivity. }
+      { inversion E. apply IHl3 in H1. destruct H1.
+        destruct s. destruct s. exfalso.
+        apply app_cons_not_nil in e. assumption.
+        destruct s. destruct s. destruct s. exfalso.
+        apply app_cons_not_nil in e. assumption.
+        destruct s. destruct s. destruct s. right. right. left. exists (a1 :: x).
+        exists x0. rewrite e. simpl. reflexivity.
+        right. right. right. assumption. }
+  * intros l3 l4 l5 l6 l7 a0 E. destruct l6. inversion E.
+    { inversion E. right. left. exists []. exists l2. simpl. reflexivity. }
+    { inversion E. apply IHl2 in H1. destruct H1.
+      destruct s. destruct s. exfalso.
+      apply app_cons_not_nil in e. assumption.
+      destruct s. destruct s. destruct s. right. left. exists (a1 :: x). exists x0.
+      rewrite e. simpl. reflexivity.
+      right. right. assumption. }
+- intros l2 l3 l4 l5 l6 l7 a0 E. destruct l6.
+  { inversion E. left. exists []. exists l1. auto. }
+  { inversion E. apply IHl1 in H1. destruct H1.
+    destruct s. destruct s. left. exists (a1 :: x). exists x0. rewrite e. auto.
+    right. assumption. }
+Qed.
+ +
+Lemma partition_1_element2 : forall {A : Type} (l1 l2 l3 l4 l5 l6 l7 : list A) a,
+l1 ++ l2 ++ l3 ++ l4 ++ l5 = l6 ++ a :: l7 ->
+  ((existsT2 l8 l9, (l1 = l8 ++ a :: l9) * (l9 ++ l2 ++ l3 ++ l4 ++ l5 = l7) * (l8 = l6)) +
+  ((existsT2 l8 l9, (l2 = l8 ++ a :: l9) * (l9 ++ l3 ++ l4 ++ l5 = l7) * (l1 ++ l8 = l6)) +
+  ((existsT2 l8 l9, (l3 = l8 ++ a :: l9) * (l9 ++ l4 ++ l5 = l7) * (l1 ++ l2 ++ l8 = l6)) +
+  ((existsT2 l8 l9, (l4 = l8 ++ a :: l9) * (l9 ++ l5 = l7) * (l1 ++ l2 ++ l3 ++ l8 = l6)) +
+  ((existsT2 l8 l9, (l5 = l8 ++ a :: l9) * (l9 = l7) * (l1 ++ l2 ++ l3 ++ l4 ++ l8 = l6))))))).
+Proof.
+intros A l1. induction l1.
+- simpl. induction l2.
+  * simpl. induction l3.
+    + simpl. induction l4.
+      { simpl. intros. right. right. right. right. exists l6. exists l7.
+        split. split. assumption. reflexivity. reflexivity. }
+      { intros. destruct l6. simpl in H. right. right. right. left. exists []. simpl.
+        inversion H. exists l4. split. split. reflexivity. reflexivity. reflexivity.
+        inversion H. apply IHl4 in H2. destruct H2. destruct s. destruct s. exfalso.
+        repeat destruct p. apply app_cons_not_nil in e0. assumption.
+        destruct s. destruct s. destruct s. exfalso.
+        repeat destruct p. apply app_cons_not_nil in e0. assumption.
+        destruct s. destruct s. destruct s. exfalso.
+        repeat destruct p. apply app_cons_not_nil in e0. assumption.
+        destruct s. destruct s. destruct s. right. right. right.
+        left. exists (a1 :: x). exists x0. simpl. repeat destruct p. rewrite e0.
+        split. split. reflexivity. assumption. subst. reflexivity.
+        destruct s. destruct s. right. right. right. right. exists x. exists x0.
+        split. split. repeat destruct p. assumption. repeat destruct p. subst. reflexivity.
+        repeat destruct p. subst. reflexivity. }
+    + intros l4 l5 l6 l7 a0 E. destruct l6.
+      { inversion E. right. right. left. exists []. exists l3. simpl. split. split. reflexivity. reflexivity. reflexivity. }
+      { inversion E. apply IHl3 in H1. destruct H1.
+        destruct s. destruct s. exfalso.
+        repeat destruct p. apply app_cons_not_nil in e0. assumption.
+        destruct s. destruct s. destruct s. exfalso.
+        repeat destruct p. apply app_cons_not_nil in e0. assumption.
+        destruct s. destruct s. destruct s. right. right. left. exists (a1 :: x).
+        exists x0. repeat destruct p. rewrite e0. simpl. split. split. reflexivity. assumption. subst. reflexivity.
+        right. right. right. destruct s. left. repeat destruct s. exists x. exists x0. repeat destruct p.
+        split. split. assumption. assumption. simpl. subst. reflexivity.
+        repeat destruct s. right. exists x. exists x0. repeat destruct p. split. split. assumption. assumption. subst. reflexivity. }
+  * intros l3 l4 l5 l6 l7 a0 E. destruct l6. inversion E.
+    { inversion E. right. left. exists []. exists l2. simpl. split. split. reflexivity. reflexivity. reflexivity. }
+    { inversion E. apply IHl2 in H1. destruct H1.
+      destruct s. destruct s. exfalso.
+      repeat destruct p. apply app_cons_not_nil in e0. assumption.
+      destruct s. destruct s. destruct s. right. left. exists (a1 :: x). exists x0.
+      repeat destruct p. rewrite e. simpl. subst. split. split. reflexivity. reflexivity. reflexivity.
+      right. right. destruct s. repeat destruct s. repeat destruct p. left. exists x. exists x0. subst. split. split. reflexivity.
+      reflexivity. reflexivity.
+      destruct s. repeat destruct s. repeat destruct p. subst. right. left. exists x. exists x0. subst. split. split. reflexivity.
+      reflexivity. reflexivity.
+      repeat destruct s. repeat destruct p. right. right. exists x. exists x0. subst. split. split. reflexivity.
+      reflexivity. reflexivity. }
+- intros l2 l3 l4 l5 l6 l7 a0 E. destruct l6.
+  { inversion E. left. exists []. exists l1. auto. }
+  { inversion E. apply IHl1 in H1. destruct H1.
+    destruct s. destruct s. left. exists (a1 :: x). exists x0. repeat destruct p. rewrite e0. split.
+    split. subst. reflexivity. subst. reflexivity. subst. reflexivity.
+    destruct s.
+    repeat destruct s. right. left. exists x. exists x0. repeat destruct p. subst. split. split. subst. reflexivity.
+    reflexivity. reflexivity.
+    destruct s.
+    repeat destruct s. right. right. left. exists x. exists x0. repeat destruct p. subst. split. split. subst. reflexivity.
+    reflexivity. reflexivity.
+    destruct s.
+    repeat destruct s. right. right. right. left. exists x. exists x0. repeat destruct p. subst. split. split. subst. reflexivity.
+    reflexivity. reflexivity.
+    destruct s.
+    repeat destruct s. right. right. right. right. exists x. exists x0. repeat destruct p. subst. split. split. subst. reflexivity.
+    reflexivity. reflexivity. }
+Qed.
+ +
+Lemma add_1_element_split_lists : forall {A : Type} (l1 l2 l3 l4 : list A) a,
+    l1 ++ l2 = l3 ++ l4 -> ((l1 = l3) * (l2 = l4)) +
+    (existsT2 l5 l6, ((l5 ++ a :: l6 ++ l2 = l3 ++ a :: l4) * (l5 ++ l6 = l1) * (l6 ++ l2 = l4) * (l5 = l3)) +
+                     ((l1 ++ l5 ++ a :: l6 = l3 ++ a :: l4) * (l5 ++ l6 = l2) * (l1 ++ l5 = l3) * (l6 = l4))).
+Proof.
+intros A l1. induction l1.
+- intros. rewrite app_nil_l in H. destruct l3.
+  + left. rewrite app_nil_l in H. split. reflexivity. assumption.
+  + right. exists (a0 :: l3). exists l4. right. split. split. split.
+    rewrite app_nil_l. reflexivity. symmetry. assumption. rewrite app_nil_l.
+    reflexivity. reflexivity.
+- destruct l3.
+  + intros. right. exists []. exists (a :: l1). left. split. split. split.
+    repeat rewrite app_nil_l. rewrite H. reflexivity. rewrite app_nil_l. reflexivity.
+    rewrite app_nil_l in H. assumption. reflexivity.
+  + intros. inversion H. apply IHl1 with (a:=a1) in H2. destruct H2.
+    * destruct p. subst. left. split. reflexivity. reflexivity.
+    * destruct s. destruct s. destruct s.
+      { repeat destruct p. subst. right. exists (a0 :: l3). exists x0.
+        left. split. split. split. reflexivity. reflexivity. reflexivity.
+        reflexivity. }
+      { repeat destruct p. subst. right. exists x. exists l4. right. split. split. split.
+        repeat rewrite app_assoc. reflexivity. reflexivity. reflexivity. reflexivity. }
+Qed.
+ +
+Lemma app2_find_hole {A : Type} : forall (l1 l2 l3 l4 : list A),
+              l1 ++ l2 = l3 ++ l4 ->
+              (existsT2 l5,
+                ((l3 = l1) * (l4 = l2)) +
+                ((l3 = l1 ++ l5) * (l2 = l5 ++ l4)) +
+                ((l1 = l3 ++ l5) * (l4 = l5 ++ l2))).
+Proof.
+induction l1.
+- intros. exists l3. left. right. split. reflexivity. assumption.
+- intros l2 l3 l4 E. destruct l3.
+  * rewrite app_nil_l in E. exists (a :: l1). right. split. reflexivity.
+    symmetry. assumption.
+  * inversion E. apply IHl1 in H1. destruct H1. destruct s.
+    + destruct s.
+      { destruct p. subst. exists []. left. left. auto. }
+      { destruct p. subst. exists x. left. right. auto. }
+    + destruct p. subst. exists x. right. auto.
+Qed.
+ +
+Theorem in_splitT : forall x (l:list MPropF), In x l -> existsT2 l1 l2, l = l1++x::l2.
+Proof.
+intros x l. induction l.
+- intro. inversion H.
+- intro. destruct (eq_dec_form x a).
+  * subst. exists nil. exists l. auto.
+  * assert (In x l). inversion H. subst. exfalso. apply n. reflexivity. assumption.
+    apply IHl in H0. destruct H0. destruct s. subst. exists ([a] ++ x0). exists x1.
+    auto.
+Defined.
+ +
+Lemma InT_dec : forall l (a : MPropF) , (InT a l) + ((InT a l) -> False).
+Proof.
+induction l.
+- intro. right. intro. inversion H.
+- intro a0. pose (IHl a0). destruct s.
+  * left. apply InT_cons. assumption.
+  * destruct (eq_dec_form a a0).
+    + subst. left. apply InT_eq.
+    + right. intro. inversion H.
+      { apply n. assumption. }
+      { apply f. assumption. }
+Qed.
+ +
+Definition eq_dec_listsF : forall (l0 l1 : list MPropF), {l0 = l1} + {l0 <> l1}.
+Proof.
+apply list_eq_dec. apply eq_dec_form.
+Defined.
+ +
+Definition eq_dec_seqs : forall (s0 s1 : rel (list MPropF)), {s0 = s1} + {s0 <> s1}.
+Proof.
+intros. destruct s0. destruct s1. destruct (eq_dec_listsF l l1) ; destruct (eq_dec_listsF l0 l2).
+- subst. left. reflexivity.
+- subst. right. intro. inversion H. auto.
+- subst. right. intro. inversion H. auto.
+- subst. right. intro. inversion H. auto.
+Defined.
+ +
+Definition seqs_in_splitT : forall (x : rel (list MPropF)) l,
+       In x l -> existsT2 l1 l2, l = l1 ++ x :: l2.
+Proof.
+intros x l. induction l.
+- intro. inversion H.
+- intro. destruct (eq_dec_seqs x a).
+  * subst. exists nil. exists l. auto.
+  * assert (In x l). inversion H. subst. exfalso. apply n. reflexivity. assumption.
+    apply IHl in H0. destruct H0. destruct s. subst. exists ([a] ++ x0). exists x1.
+    auto.
+Defined.
+ +
+Definition In_InT_seqs : forall (seq : rel (list MPropF)) seqs, In seq seqs -> InT seq seqs.
+Proof.
+intros seq seqs. induction seqs.
+- intro. inversion H.
+- intro. apply seqs_in_splitT in H. destruct H. destruct s. rewrite e. apply InT_or_app.
+  right. apply InT_eq.
+Defined.
+ +
+Lemma list_split_form : forall (A B : MPropF) l0 l1 l2 l3, (l0 ++ A :: l1 = l2 ++ B :: l3) ->
+                          ((A = B) * (l0 = l2) * (l1 = l3)) +
+                          (existsT2 l4 l5, (l0 = l4 ++ l5) * (l5 ++ A :: l1 = l3) * (l2 ++ [B] = l4)) +
+                          (existsT2 l4 l5, (l1 = l4 ++ l5) * (l0 ++ A :: l4 = l2) * (B :: l3 = l5)).
+Proof.
+intros A B l0. generalize dependent A. generalize dependent B. induction l0.
+- intros. simpl in H. destruct l2.
+  * simpl in H. left. left. inversion H. auto.
+  * simpl. inversion H. subst. right. exists l2. exists (B :: l3). auto.
+- simpl. simpl in IHl0. intros. destruct l2.
+  * left. right. simpl. exists [B]. exists l0. simpl. inversion H. subst. auto.
+  * inversion H. subst. pose (@IHl0 B A l1 l2 l3 H2). repeat destruct s.
+    + repeat destruct p. subst. left. left. auto.
+    + repeat destruct p. subst. left. right. exists ((m :: l2) ++ [B]). exists x0.
+      auto.
+    + repeat destruct p. subst. right. exists x. exists (B :: l3). auto.
+Qed.
+
+
+ +
+ + + diff --git a/Syntax.remove_list_lems.html b/Syntax.remove_list_lems.html new file mode 100644 index 0000000..eed635b --- /dev/null +++ b/Syntax.remove_list_lems.html @@ -0,0 +1,688 @@ + + + + + + + + + + + + + +
+
+

Syntax.remove_list_lems

+ +
+Require Import List.
+Export ListNotations.
+Require Import PeanoNat.
+Require Import Lia.
+ +
+Require Import existsT.
+ +
+Require Import CML_Syntax.
+ +
+Definition In_dec l (a : MPropF) := in_dec eq_dec_form a l.
+ +
+(* Let us prove some lemmas about remove. *)
+ +
+Lemma in_not_touched_remove : forall l1 (a0 a1 : MPropF),
+        In a0 l1 -> a0 <> a1 -> In a0 (remove eq_dec_form a1 l1).
+Proof.
+induction l1.
+- intros. inversion H.
+- intros. simpl. destruct (eq_dec_form a1 a).
+  * subst. apply IHl1. inversion H. exfalso. apply H0. auto. assumption. assumption.
+  * inversion H. subst. apply in_eq. apply in_cons. apply IHl1. assumption. assumption.
+Qed.
+ +
+Lemma remove_dist_app {A : Type} (eq_dec : forall x y : A, {x = y} + {x <> y}) :
+        forall (a : A) l1 l2, (@remove A eq_dec a (l1 ++ l2)) =
+                              (@remove A eq_dec a l1) ++ (@remove A eq_dec a l2).
+Proof.
+intros a l1. induction l1.
+- intro l2. rewrite app_nil_l. simpl. reflexivity.
+- intro l2. simpl. destruct (eq_dec a a0).
+  * apply IHl1.
+  * simpl. rewrite IHl1. reflexivity.
+Qed.
+ +
+Lemma remove_not_in_anymore : forall l (A : MPropF),
+          (In A (remove eq_dec_form A l)) -> False.
+Proof.
+induction l.
+- intros. simpl in H. inversion H.
+- intros. simpl in H. destruct (eq_dec_form A a). subst. apply IHl in H. assumption.
+  inversion H. apply n. symmetry. assumption. apply IHl in H0. assumption.
+Qed.
+ +
+Lemma in_remove_in_init : forall l A B,
+    In A (remove eq_dec_form B l) -> In A l.
+Proof.
+induction l.
+- intros. simpl. inversion H.
+- intros. destruct (eq_dec_form A a). subst. apply in_eq. apply in_cons.
+  pose (IHl A B). apply i. simpl in H. destruct (eq_dec_form B a).
+  * subst. assumption.
+  * inversion H. exfalso. apply n. symmetry. assumption. assumption.
+Qed.
+ +
+Lemma remove_preserv_NoDup : forall l (A : MPropF), NoDup l -> NoDup (remove eq_dec_form A l).
+Proof.
+induction l.
+- intros. simpl. apply NoDup_nil.
+- intros. simpl. destruct (eq_dec_form A a).
+  * subst. apply IHl. inversion H. assumption.
+  * apply NoDup_cons. intro. apply in_remove_in_init in H0. inversion H. apply H3. assumption.
+    apply IHl. inversion H. assumption.
+Qed.
+ +
+Lemma NoDup_destr_split : forall l1 l2 (A : MPropF), NoDup (l1 ++ A :: l2) -> NoDup (l1 ++ l2).
+Proof.
+induction l1.
+- intros. rewrite app_nil_l. rewrite app_nil_l in H. inversion H. assumption.
+- intros. simpl. apply NoDup_cons. intro. inversion H. subst. apply H3. apply in_app_or in H0.
+  destruct H0. apply in_or_app. left. assumption. apply in_or_app. right. apply in_cons.
+  assumption. simpl in H. inversion H. subst. apply IHl1 with (A:=A). assumption.
+Qed.
+ +
+Lemma remove_le_length : forall l (A : MPropF), length (remove eq_dec_form A l) <= length l.
+Proof.
+induction l.
+- intros. simpl. reflexivity.
+- intros. simpl. destruct (eq_dec_form A a).
+  * subst. apply le_S. apply IHl.
+  * simpl. apply le_n_S. apply IHl.
+Qed.
+ +
+Lemma remove_In_smaller_length : forall l (A : MPropF),
+                                 In A l -> length (remove eq_dec_form A l) < length l.
+Proof.
+induction l.
+- intros. inversion H.
+- intros. simpl. destruct (eq_dec_form A a).
+  * subst. unfold lt. apply le_n_S. apply remove_le_length.
+  * simpl. rewrite <- Nat.succ_lt_mono. apply IHl. inversion H. subst. exfalso. apply n. auto.
+    assumption.
+Qed.
+ +
+Lemma double_remove {A : Type} (eq_dec : forall x y : A, {x = y} + {x <> y}) :
+      forall a l, (@remove A eq_dec a (@remove A eq_dec a l)) = (@remove A eq_dec a l).
+Proof.
+intros a l. induction l.
+- simpl. reflexivity.
+- simpl. destruct (eq_dec a a0).
+  * subst. apply IHl.
+  * simpl. destruct (eq_dec a a0).
+    + exfalso. apply n. assumption.
+    + rewrite IHl. reflexivity.
+Qed.
+ +
+Lemma permut_remove {A : Type} (eq_dec : forall x y : A, {x = y} + {x <> y}) :
+      forall a0 a1 l, (@remove A eq_dec a0 (@remove A eq_dec a1 l)) =
+                      (@remove A eq_dec a1 (@remove A eq_dec a0 l)).
+Proof.
+intros a0 a1 l. induction l.
+- simpl. reflexivity.
+- simpl. destruct (eq_dec a1 a).
+  * subst. simpl. destruct (eq_dec a0 a).
+    + subst. reflexivity.
+    + simpl. destruct (eq_dec a a). apply IHl. exfalso. apply n0. reflexivity.
+  * simpl. destruct (eq_dec a0 a).
+    + subst. assumption.
+    + simpl. destruct (eq_dec a1 a). exfalso. apply n. assumption.
+      rewrite IHl. reflexivity.
+Qed.
+ +
+Lemma In_remove_diff : forall l (A B : MPropF), In A (remove eq_dec_form B l) -> A <> B.
+Proof.
+induction l ; intros.
+- intro. simpl in H. assumption.
+- simpl in H. destruct (eq_dec_form B a).
+  * subst. apply IHl. assumption.
+  * inversion H.
+    + subst. intro. apply n. symmetry. assumption.
+    + apply IHl. assumption.
+Qed.
+ +
+(* Now we define remove_list and prove some lemmas about it. *)
+ +
+Fixpoint remove_list (l1 l2: list (MPropF)) : list (MPropF) :=
+match l1 with
+  | [] => l2
+  | h1 :: t1 => remove eq_dec_form h1 (remove_list t1 l2)
+end.
+ +
+Lemma remove_list_of_nil : forall (l : list (MPropF)), remove_list l nil = nil.
+Proof.
+induction l.
+- simpl. reflexivity.
+- simpl. rewrite IHl. simpl. reflexivity.
+Qed.
+ +
+Lemma app_remove_list : forall (l1 l2 l3 : list (MPropF)),
+        remove_list (l1 ++ l2) l3 = remove_list l1 (remove_list l2 l3).
+Proof.
+induction l1.
+- simpl. firstorder.
+- induction l2.
+  * intro l3. rewrite app_nil_r. simpl. reflexivity.
+  * intro l3. simpl. pose (IHl1 (a0 :: l2) l3). simpl in e.
+    rewrite e. reflexivity.
+Qed.
+ +
+Lemma remove_list_preserv_NoDup : forall l1 l2, NoDup l2 -> NoDup (remove_list l1 l2).
+Proof.
+induction l1.
+- intros. simpl. assumption.
+- intros. simpl. apply IHl1 in H. apply remove_preserv_NoDup with (A:=a) in H.
+  assumption.
+Qed.
+ +
+Lemma remove_list_cont : forall l1 A, In A l1 -> (forall l2, In A (remove_list l1 l2) -> False).
+Proof.
+induction l1.
+- intros. inversion H.
+- intros. inversion H.
+  * subst. simpl in H0. apply remove_not_in_anymore in H0. assumption.
+  * simpl in H0. pose (IHl1 A H1 l2). apply f. apply in_remove_in_init with (B:= a). assumption.
+Qed.
+ +
+Lemma remove_list_dist_app : forall (l1 l2 l3 : list (MPropF)),
+        remove_list l1 (l2 ++ l3) = (remove_list l1 l2) ++ (remove_list l1 l3).
+Proof.
+induction l1.
+- intros. simpl. reflexivity.
+- simpl. intros. rewrite IHl1. simpl. rewrite remove_dist_app. reflexivity.
+Qed.
+ +
+Lemma permut_remove_remove_list : forall a (l1 l2 : list (MPropF)),
+      remove eq_dec_form a (remove_list l1 l2) =
+      remove_list l1 (remove eq_dec_form a l2).
+Proof.
+intros a l1. generalize dependent a. induction l1 ; simpl.
+- reflexivity.
+- intros. rewrite permut_remove. rewrite IHl1. reflexivity.
+Qed.
+ +
+Lemma swap_remove_list : forall (l1 l2 l3 : list (MPropF)),
+      remove_list (l1 ++ l2) l3 = remove_list (l2 ++ l1) l3.
+Proof.
+induction l1.
+- intros. rewrite app_nil_l. rewrite app_nil_r. reflexivity.
+- induction l2.
+  * rewrite app_nil_l. rewrite app_nil_r. reflexivity.
+  * intro l3. simpl. rewrite IHl1. simpl. rewrite permut_remove.
+    rewrite <- IHl2. simpl. rewrite IHl1. reflexivity.
+Qed.
+ +
+Lemma redund_remove_remove_list : forall a (l1 l2 : list (MPropF)),
+      remove eq_dec_form a (remove_list (remove eq_dec_form a l1) l2) =
+      remove eq_dec_form a (remove_list l1 l2).
+Proof.
+intro a. induction l1.
+- intro l2. simpl. reflexivity.
+- intro l2. simpl. destruct (eq_dec_form a a0).
+  * rewrite IHl1. subst. rewrite double_remove. reflexivity.
+  * simpl. rewrite permut_remove. rewrite IHl1. apply permut_remove.
+Qed.
+ +
+Lemma redund_remove : forall (l1 l2 l3 : list (MPropF)) a,
+      remove eq_dec_form a (remove_list l1 (remove_list (remove eq_dec_form a l2) l3)) =
+      remove eq_dec_form a (remove_list l1 (remove_list l2 l3)).
+Proof.
+intros. repeat rewrite <- app_remove_list. rewrite swap_remove_list.
+rewrite app_remove_list. rewrite redund_remove_remove_list. rewrite <- app_remove_list.
+rewrite swap_remove_list. reflexivity.
+Qed.
+ +
+Lemma redund_remove_list : forall (l1 l2 l3 : list (MPropF)),
+      remove_list l1 (remove_list (remove_list l1 l2) l3) = remove_list l1 (remove_list l2 l3).
+Proof.
+induction l1 ; intros ; simpl.
+- reflexivity.
+- rewrite redund_remove. rewrite IHl1. reflexivity.
+Qed.
+ +
+Lemma remove_list_in_single : forall l1 a, (In a l1) -> remove_list l1 [a] = nil.
+Proof.
+induction l1.
+- intros. inversion H.
+- intros. inversion H.
+  * subst. simpl. rewrite permut_remove_remove_list. simpl. destruct (eq_dec_form a0 a0).
+    apply remove_list_of_nil. exfalso. apply n. reflexivity.
+  * apply IHl1 in H0. simpl. rewrite H0. simpl. reflexivity.
+Qed.
+ +
+Lemma not_removed_remove_list : forall l2 l1 A, In A l2 -> (In A l1 -> False) -> In A (remove_list l1 l2).
+Proof.
+induction l2.
+- intros. inversion H.
+- induction l1.
+  * intros. simpl. assumption.
+  * intros. simpl. pose (in_not_touched_remove (remove_list l1 (a :: l2))). pose (i A).
+    pose (i0 a0). apply i1. apply IHl1. assumption. intro. apply H0. apply in_cons. assumption.
+    clear i1. clear i0. clear i. destruct (eq_dec_form A a0). intro. apply H0. subst. apply in_eq.
+    assumption.
+Qed.
+ +
+Lemma add_remove_list_preserve_NoDup : forall (l1 l2 : list (MPropF)),
+            NoDup l1 -> NoDup l2 -> NoDup (l1 ++ (remove_list l1 l2)).
+Proof.
+induction l1.
+- intros. rewrite app_nil_l. simpl. assumption.
+- intros. simpl. apply NoDup_cons.
+  * intro. apply in_app_or in H1. destruct H1. inversion H. apply H4. assumption.
+    apply remove_not_in_anymore in H1. assumption.
+  * rewrite permut_remove_remove_list. apply IHl1. inversion H. assumption.
+    apply remove_preserv_NoDup. assumption.
+Qed.
+ +
+Lemma remove_list_is_in : forall l1 l2 A, In A l1 -> In A (l2 ++ (remove_list l2 l1)).
+Proof.
+intros. pose (In_dec l2 A). destruct s.
+- apply in_or_app. left. assumption.
+- apply in_or_app. right. apply not_removed_remove_list ; assumption.
+Qed.
+ +
+Lemma In_remove_same : forall l1 l2 (A : MPropF), In A l1 ->
+                remove_list l1 (A :: l2) = remove_list l1 l2.
+Proof.
+induction l1.
+- intros. inversion H.
+- intros. inversion H.
+  * subst. simpl. rewrite permut_remove_remove_list. simpl. destruct (eq_dec_form A A).
+    rewrite permut_remove_remove_list. reflexivity. exfalso. apply n. reflexivity.
+  * simpl. pose (IHl1 l2 A H0). rewrite e. reflexivity.
+Qed.
+ +
+Lemma In_remove_length_same : forall l1 l2 (A : MPropF), In A l1 ->
+                length (remove_list l1 (A :: l2)) = length (remove_list l1 l2).
+Proof.
+intros. rewrite In_remove_same. reflexivity. assumption.
+Qed.
+ +
+Lemma length_le_remove_list : forall (l1 l2 : list (MPropF)), length (remove_list l1 l2) <= length l2.
+Proof.
+induction l1.
+- intros. auto.
+- intros. simpl. rewrite permut_remove_remove_list. pose (IHl1 (remove eq_dec_form a l2)).
+  apply Nat.le_trans with (m:=length (remove eq_dec_form a l2)). assumption.
+  apply remove_le_length.
+Qed.
+ +
+Lemma remove_list_singl_id_or_nil : forall l (A : MPropF), remove_list l [A] = nil \/ remove_list l [A] = [A].
+Proof.
+induction l.
+- intros. right. auto.
+- intros. pose (IHl A). destruct o. left. simpl. rewrite H. auto.
+  simpl. rewrite H. destruct (eq_dec_form A a).
+  * subst. left. simpl. destruct (eq_dec_form a a). reflexivity. exfalso. apply n.
+    reflexivity.
+  * right. simpl. destruct (eq_dec_form a A). exfalso. apply n. symmetry. assumption.
+    reflexivity.
+Qed.
+ +
+Lemma remove_list_non_empty_inter_smaller_length : forall l2 l1 (A : MPropF),
+                                 In A l1 -> In A l2 -> length (remove_list l1 l2) < length l2.
+Proof.
+induction l2.
+- intros. inversion H0.
+- intros. simpl. destruct (eq_dec_form A a).
+  * subst. rewrite In_remove_length_same. 2: assumption. unfold lt. apply le_n_S.
+    apply length_le_remove_list.
+  * inversion H0.
+    + exfalso. apply n. symmetry. assumption.
+    + assert (a :: l2 = [a] ++ l2). auto. rewrite H2. rewrite remove_list_dist_app.
+      rewrite app_length. pose (remove_list_singl_id_or_nil l1 a). destruct o.
+      rewrite H3. simpl. apply Nat.lt_lt_succ_r. apply IHl2 with (A:=A) ; assumption.
+      rewrite H3. simpl. rewrite <- Nat.succ_lt_mono. apply IHl2 with (A:=A) ; assumption.
+Qed.
+ +
+Lemma remove_list_delete_head : forall l1 l2 l3 A, remove_list (l1 ++ A :: l2) (A :: l3) = remove_list (l1 ++ A :: l2) l3.
+Proof.
+induction l1 ; intros ; simpl.
+- rewrite permut_remove_remove_list. simpl. destruct (eq_dec_form A A). symmetry. apply permut_remove_remove_list.
+  exfalso. apply n. reflexivity.
+- rewrite IHl1. reflexivity.
+Qed.
+ +
+Lemma remove_list_delete_head_In : forall l1 l2 A, In A l1 -> remove_list l1 (A :: l2) = remove_list l1 l2.
+Proof.
+intros. pose (In_split A l1 H). destruct e. destruct H0. subst. apply remove_list_delete_head.
+Qed.
+ +
+Lemma remove_list_in_nil : forall l1 l2 l3 A,
+        remove_list l1 (l2 ++ A :: l3) = nil ->
+        (existsT2 l4 l5, l1 = l4 ++ A :: l5).
+Proof.
+induction l1.
+- intros. simpl in H. destruct l2 ; inversion H.
+- induction l2.
+  * intros. simpl in H. rewrite permut_remove_remove_list in H. simpl in H. destruct (eq_dec_form a A).
+    + subst. exists []. exists l1. auto.
+    + pose (IHl1 [] (remove eq_dec_form a l3)). simpl in s. apply s in H. destruct H. destruct s0.
+      exists ([a] ++ x). exists x0. subst. auto.
+  * intros. simpl in H. rewrite permut_remove_remove_list in H. simpl in H. destruct (eq_dec_form a a0).
+    + subst. pose (IHl2 l3 A). apply s. rewrite <- permut_remove_remove_list in H. simpl. assumption.
+    + pose (IHl1 [] (remove eq_dec_form a (l2 ++ A :: l3)) a0). pose (s H). repeat destruct s0.
+      subst. apply IHl2 with (l3:= l3). simpl. rewrite permut_remove_remove_list.
+      rewrite remove_list_delete_head in H. assumption.
+Qed.
+ +
+Lemma remove_list_is_nil : forall l1 l2, (remove_list l1 l2 = nil <-> (forall A, (In A l2) -> (In A l1))).
+Proof.
+induction l1.
+- intro l2. split.
+  * intros. simpl in H. rewrite <- H. assumption.
+  * intros. simpl. destruct l2.
+    + reflexivity.
+    + exfalso. pose (H m). assert (In m (m :: l2)). apply in_eq. apply i in H0. inversion H0.
+- induction l2.
+  * split.
+    + intros. inversion H0.
+    + intros. apply remove_list_of_nil.
+  * split.
+    + intros. simpl in H. rewrite permut_remove_remove_list in H. simpl in H. destruct (eq_dec_form a a0).
+      subst. inversion H0. subst. apply in_eq. rewrite <- permut_remove_remove_list in H. simpl in IHl2.
+      rewrite IHl2 in H. apply H in H1. destruct H1. subst. apply in_eq. apply in_cons. assumption.
+      inversion H0. subst. apply in_cons. pose (remove_list_in_nil l1 [] (remove eq_dec_form a l2) A).
+      simpl in s. apply s in H. destruct H. destruct s0. subst. apply in_or_app. right. apply in_eq.
+      apply IHl2. 2: assumption. simpl. rewrite permut_remove_remove_list.
+      pose (app_eq_nil (remove_list l1 [a0]) (remove_list l1 (remove eq_dec_form a l2))). simpl in a1.
+      assert (H2: remove_list l1 [a0] ++ remove_list l1 (remove eq_dec_form a l2) = []).
+      rewrite <- remove_list_dist_app. simpl. assumption. apply a1 in H2. destruct H2. assumption.
+    + intros. simpl. rewrite permut_remove_remove_list. simpl. destruct (eq_dec_form a a0).
+      { subst. rewrite <- permut_remove_remove_list. simpl in IHl2. rewrite IHl2. intros.
+        pose (H A). apply i. apply in_cons. assumption. }
+      { assert (H1: (forall A : MPropF, In A l2 -> In A (a :: l1))). intros. apply H.
+        apply in_cons. assumption. apply IHl2 in H1.
+        assert (H2: a0 :: remove eq_dec_form a l2 = [a0] ++ remove eq_dec_form a l2). auto.
+        rewrite H2. rewrite remove_list_dist_app. clear H2. rewrite <- permut_remove_remove_list.
+        simpl in H1. rewrite H1. rewrite app_nil_r. apply remove_list_in_single. pose (H a0).
+        assert (H3: In a0 (a0 :: l2)). apply in_eq. apply i in H3. inversion H3. exfalso. apply n.
+        assumption. assumption. }
+Qed.
+ +
+Lemma remove_delete_origin : forall l1 l2 (A B : MPropF), (A <> B) ->
+            length (remove eq_dec_form A (l1 ++ B :: l2)) = S (length (remove eq_dec_form A (l1 ++ l2))).
+Proof.
+induction l1.
+- intros. repeat rewrite app_nil_l. simpl. destruct (eq_dec_form A B). exfalso. apply H. assumption.
+  simpl. reflexivity.
+- intros. simpl. destruct (eq_dec_form A a).
+  * apply IHl1. assumption.
+  * simpl. apply eq_S. apply IHl1. assumption.
+Qed.
+ +
+Lemma keep_list_delete_head_not_origin : forall l1 l2 l3 A, ((In A l1) -> False) ->
+                length (remove_list l1 (l2 ++ A :: l3)) = S (length (remove_list l1 (l2 ++ l3))).
+Proof.
+induction l1.
+- intros. simpl. rewrite app_length. simpl. rewrite app_length. auto.
+- intros. simpl. repeat rewrite remove_list_dist_app. assert (In A l1 -> False).
+  intro. apply H. apply in_cons. assumption. assert (A :: l3 = [A] ++ l3).
+  auto. rewrite H1. rewrite remove_list_dist_app. pose (remove_list_singl_id_or_nil l1 A).
+  destruct o. exfalso. rewrite remove_list_is_nil in H2. apply H0. apply H2.
+  apply in_eq. rewrite H2. apply remove_delete_origin. intro. apply H. subst. apply in_eq.
+Qed.
+ +
+Lemma keep_list_delete_head_not_In : forall l1 l2 A, ((In A l1) -> False) ->
+                length (remove_list l1 (A :: l2)) = S (length (remove_list l1 l2)).
+Proof.
+intros. pose (@keep_list_delete_head_not_origin l1 [] l2 A H). repeat rewrite app_nil_l in e.
+assumption.
+Qed.
+ +
+Lemma In_remove_In_list : forall (A B : MPropF) l, In A (remove eq_dec_form B l) -> In A l.
+Proof.
+induction l ; intros.
+- simpl in H. destruct H.
+- simpl in H. destruct (eq_dec_form B a).
+  * subst. apply in_cons. apply IHl. assumption.
+  * inversion H.
+    + subst. apply in_eq.
+    + apply in_cons. apply IHl. assumption.
+Qed.
+ +
+Lemma In_remove_list_In_list : forall (A : MPropF) l1 l2, In A (remove_list l1 l2) -> In A l2.
+Proof.
+intro A. induction l1 ; intros.
+- simpl in H. assumption.
+- simpl in H. apply In_remove_In_list in H. apply IHl1. assumption.
+Qed.
+ +
+Lemma In_remove_list_In_list_not_In_remove_list : forall (A : MPropF) l1 l2,
+            In A (remove_list l1 l2) -> (In A l2 /\ ((In A l1) -> False)).
+Proof.
+intro A. induction l1 ; intros.
+- simpl in H. split. assumption. intro. inversion H0.
+- simpl in H. split. apply In_remove_In_list in H. apply IHl1. assumption. intro.
+  inversion H0.
+  * subst. apply remove_not_in_anymore in H. assumption.
+  * apply In_remove_In_list in H. apply IHl1 in H. destruct H. apply H2. assumption.
+Qed.
+ +
+Lemma remove_list_incr_decr3 : forall (l3 l2 l1 : list (MPropF)),
+              (incl l1 l2) ->
+              length (remove_list l2 l3) <= length (remove_list l1 l3).
+Proof.
+induction l3 ; intros.
+- repeat rewrite remove_list_of_nil. auto.
+- destruct (In_dec l2 a).
+  + rewrite remove_list_delete_head_In. 2: assumption. destruct (In_dec l1 a).
+    * rewrite remove_list_delete_head_In. 2: assumption. apply IHl3 ; auto.
+    * rewrite keep_list_delete_head_not_In. 2: assumption. apply Nat.le_le_succ_r.
+      apply IHl3. assumption.
+  + repeat rewrite keep_list_delete_head_not_In. apply le_n_S. apply IHl3 ; auto.
+    intro. apply n. apply H. assumption. assumption.
+Qed.
+ +
+Lemma remove_list_incr_decr1 : forall (l3 l1 l2: list (MPropF)),
+              (exists A, In A l2 /\ In A l3 /\ (In A l1 -> False)) ->
+              (incl l1 l2) ->
+              length (remove_list l2 l3) < length (remove_list l1 l3).
+Proof.
+induction l3.
+- intros. destruct H. destruct H. destruct H1. exfalso. inversion H1.
+- intros. destruct H. destruct H. destruct H1. destruct (eq_dec_form a x).
+  * subst. rewrite remove_list_delete_head_In. 2: assumption.
+    rewrite keep_list_delete_head_not_In. 2: assumption. unfold lt.
+    apply le_n_S. apply remove_list_incr_decr3. assumption.
+  * inversion H1. exfalso. apply n ; assumption.
+    assert (H4: exists A : MPropF, In A l2 /\ In A l3 /\ (In A l1 -> False)).
+    exists x. auto. apply IHl3 in H4. 2 : assumption. unfold lt.
+    destruct (In_dec l2 a).
+    + rewrite remove_list_delete_head_In. 2: assumption. destruct (In_dec l1 a).
+      { rewrite remove_list_delete_head_In. 2: assumption. apply H4. }
+      { rewrite keep_list_delete_head_not_In. 2: assumption. apply le_n_S.
+        unfold lt in H4. apply Nat.lt_le_incl. assumption. }
+    + rewrite keep_list_delete_head_not_In. 2: assumption. rewrite keep_list_delete_head_not_In.
+      unfold lt in H4. apply le_n_S. assumption. intro. apply n0. apply H0. assumption.
+Qed.
+ +
+Lemma remove_list_incr_decr2 : forall (l4 l3 l1 : list (MPropF)),
+              (NoDup l4) ->
+              (NoDup l3) ->
+              (incl l4 l3) ->
+              length (remove_list l1 l4) <= length (remove_list l1 l3).
+Proof.
+induction l4.
+- intros. rewrite remove_list_of_nil. simpl. apply le_0_n.
+- intros. destruct (In_dec l1 a).
+  * rewrite remove_list_delete_head_In. 2: assumption. apply IHl4 ; try assumption.
+    inversion H. assumption. unfold incl. intros. apply H1. apply in_cons. assumption.
+  * rewrite keep_list_delete_head_not_In. 2: assumption. assert (H2: In a l3). apply H1.
+    apply in_eq. pose (in_split a l3 H2). repeat destruct e. destruct H3. rewrite H3.
+    rewrite keep_list_delete_head_not_origin. 2: assumption. apply le_n_S. apply IHl4.
+    inversion H. assumption. subst. apply NoDup_destr_split with (A:=a). assumption.
+    inversion H. unfold incl. intros. subst. assert (H9 : In a0 (a :: l4)). apply in_cons.
+    assumption. pose (H1 a0 H9). apply in_app_or in i. destruct i. apply in_or_app. left.
+    assumption. inversion H3. subst. exfalso. apply H6. assumption. apply in_or_app. right.
+    assumption.
+Qed.
+ +
+Lemma remove_list_incr_decr4 : forall (l4 l3 l1: list (MPropF)),
+              (NoDup l4) ->
+              (NoDup l3) ->
+              (incl l4 l3) ->
+              ((incl l3 l4) -> False) ->
+              (exists A, (In A l3) /\ ((In A l1) -> False) /\ ((In A l4) -> False)) ->
+              length (remove_list l1 l4) < length (remove_list l1 l3).
+Proof.
+induction l4.
+- intros. rewrite remove_list_of_nil. simpl. destruct H3. destruct H3. destruct H4. pose (In_split x l3 H3).
+  destruct e. destruct H6. subst. rewrite keep_list_delete_head_not_origin. 2: assumption.
+  apply Nat.lt_0_succ.
+- intros. destruct (In_dec l1 a).
+  * rewrite remove_list_delete_head_In. 2: assumption. apply IHl4 ; try assumption.
+    inversion H. assumption. unfold incl. intros. apply H1. apply in_cons. assumption.
+    intro. apply H2. unfold incl. intros. apply in_cons. apply H4. assumption. destruct H3.
+    destruct H3. destruct H4. exists x. repeat split ; try assumption. intro. apply H5.
+    apply in_cons. assumption.
+  * rewrite keep_list_delete_head_not_In. 2: assumption. assert (In a l3). apply H1.
+    apply in_eq. pose (In_split a l3 H4). destruct e. destruct H5. subst.
+    rewrite keep_list_delete_head_not_origin. 2 : assumption. rewrite <- Nat.succ_lt_mono.
+    apply IHl4. inversion H. assumption. apply NoDup_destr_split with (A:=a). assumption.
+    unfold incl. intros. pose (H1 a0). assert (In a0 (a :: l4)). apply in_cons. assumption.
+    apply i in H6. apply in_app_or in H6. destruct H6. apply in_or_app. left. assumption.
+    inversion H6. subst. inversion H. exfalso. apply H9. assumption. apply in_or_app. right.
+    assumption. intro. apply H2. unfold incl. intros. apply in_app_or in H6. destruct H6.
+    apply in_cons. apply H5. apply in_or_app. left. assumption. inversion H6. subst. apply in_eq.
+    apply in_cons. apply H5. apply in_or_app. right. assumption.
+    destruct H3. destruct H3. destruct H5. exists x1. repeat split ; try assumption.
+    apply in_app_or in H3. destruct H3. apply in_or_app. left. assumption. inversion H3.
+    subst. exfalso. apply H6. apply in_eq. apply in_or_app. right. assumption.
+    intro. apply H6. apply in_cons. assumption.
+Qed.
+ +
+Lemma remove_list_incr_decr : forall (l1 l2 l3 l4 : list (MPropF)),
+              (NoDup l4) ->
+              (NoDup l3) ->
+              (exists A, In A l2 /\ In A l3 /\ (In A l1 -> False)) ->
+              (incl l1 l2) ->
+              (incl l4 l3) ->
+              length (remove_list l2 l4) < length (remove_list l1 l3).
+Proof.
+intros. unfold lt.
+pose (remove_list_incr_decr2 _ _ l1 H H0 H3).
+repeat destruct H1. destruct H4. destruct (In_dec l4 x).
+- assert (H6: (exists A, In A l2 /\ In A l4 /\ (In A l1 -> False))).
+  exists x. repeat split ; assumption. pose (@remove_list_incr_decr1 l4 l1 l2 H6 H2).
+  unfold lt in l0. apply Nat.le_trans with (m:=length (remove_list l1 l4)) ; assumption.
+- assert ((incl l3 l4) -> False). intros. apply n. apply H6. assumption.
+  assert ((exists A, (In A l3) /\ ((In A l1) -> False) /\ ((In A l4) -> False))). exists x. auto.
+  pose (@remove_list_incr_decr3 l4 l2 l1 H2). pose (@remove_list_incr_decr4 l4 l3 l1 H H0 H3 H6 H7).
+  unfold lt in l5. apply le_n_S in l0.
+  apply Nat.le_trans with (m:=S (length (remove_list l1 l4))) ; assumption.
+Qed.
+ +
+Lemma In_remove_list_remove_redund : forall l1 l2 a, In a l1 ->
+                remove eq_dec_form a (remove_list l1 l2) = remove_list l1 l2.
+Proof.
+induction l1.
+- intros. inversion H.
+- intros. simpl. inversion H.
+  * subst. rewrite double_remove. reflexivity.
+  * pose (IHl1 l2 a0 H0). rewrite permut_remove. rewrite e. reflexivity.
+Qed.
+ +
+Lemma In_matters_remove_list : forall l1 l2, (incl l1 l2 /\ incl l2 l1) -> (forall l0,
+                                    remove_list l1 l0 = remove_list l2 l0).
+Proof.
+induction l1.
+- intros. destruct H. destruct l2. auto. unfold incl in H0. pose (H0 m). assert (In m (m :: l2)).
+  apply in_eq. apply i in H1. inversion H1.
+- intros. destruct H. simpl. pose (H a). assert (In a (a :: l1)). apply in_eq. apply i in H1.
+  apply in_split in H1. destruct H1. destruct H1. subst. destruct (In_dec l1 a).
+  * rewrite In_remove_list_remove_redund. 2: assumption. apply IHl1. split. intro. intro.
+    apply H. apply in_cons. assumption. intro. intro. apply H0 in H1. inversion H1. subst.
+    assumption. assumption.
+  * rewrite swap_remove_list. simpl. rewrite <- redund_remove_remove_list with (l1:=(x0 ++ x)).
+    pose (IHl1 (remove eq_dec_form a (x0 ++ x))). rewrite e.
+    auto. split. intro. intro. apply in_not_touched_remove. assert (In a0 (a :: l1)). apply in_cons.
+    assumption. apply H in H2. apply in_app_or in H2. destruct H2. apply in_or_app. right. assumption.
+    inversion H2. subst. exfalso. apply n. assumption. apply in_or_app. left. assumption.
+    intro. subst. apply n. assumption. intro. intro. pose (In_remove_diff (x0 ++ x) _ _ H1).
+    pose (In_remove_In_list a0 a (x0 ++ x) H1). assert (In a0 (x ++ a :: x0)). apply in_app_or in i0.
+    destruct i0. apply in_or_app. right. apply in_cons. assumption. apply in_or_app. left. assumption.
+    apply H0 in H2. inversion H2. exfalso. apply n0. symmetry. assumption. assumption.
+Qed.
+
+
+ +
+ + + diff --git a/UIML_extraction.UIML_extraction.html b/UIML_extraction.UIML_extraction.html new file mode 100644 index 0000000..59ef27f --- /dev/null +++ b/UIML_extraction.UIML_extraction.html @@ -0,0 +1,94 @@ + + + + + + + + + + + + + +
+
+

UIML_extraction.UIML_extraction

+ +
+Require Import GL.Interpolation.UIGL_braga.
+Require Import GLS_export.
+Require Import ExtrOcamlBasic ExtrOcamlString.
+ +
+Require Import K.Interpolation.UIK_braga.
+Require Import KS_export.
+Require Import ISL.PropQuantifiers ISL.DecisionProcedure.
+ +
+Require Import ISL.Simp.
+ +
+Fixpoint MPropF_of_form (f : Formulas.form) : MPropF :=
+match f with
+| Formulas.Var n => Var n
+| Formulas.Bot => Bot
+| Formulas.Implies f1 f2 => Imp (MPropF_of_form f1) (MPropF_of_form f2)
+| Formulas.And f1 f2 => Imp (Imp (MPropF_of_form f1) (Imp (MPropF_of_form f2) Bot)) Bot
+| Formulas.Or f1 f2 => Imp (Imp (MPropF_of_form f1) Bot) (MPropF_of_form f2)
+| Formulas.Box f => Box (MPropF_of_form f)
+end.
+ +
+Fixpoint form_of_MPropF (f : MPropF) : Formulas.form :=
+match f with
+| Var n => Formulas.Var n
+| Bot => Formulas.Bot
+| Imp f1 f2 => Formulas.Implies (form_of_MPropF f1) (form_of_MPropF f2)
+| Box f => Formulas.Box (form_of_MPropF f)
+end.
+ +
+Definition gl_UI p s := form_of_MPropF (proj1_sig (GL.Interpolation.UIGL_braga.GUI_tot p ([],[MPropF_of_form s]))).
+Definition k_UI p s := form_of_MPropF(proj1_sig (K.Interpolation.UIK_braga.GUI_tot p ([],[MPropF_of_form s]))).
+ +
+Definition isl_E v f := Ef v f.
+Definition isl_A v f := Af v f.
+ +
+Definition isl_simp f := simp f.
+ +
+Definition isl_simplified_E v f := E_simplified v f.
+Definition isl_simplified_A v f := A_simplified v f.
+ +
+Set Extraction Output Directory "extraction".
+ +
+Separate Extraction Provable_dec gl_UI k_UI isl_E isl_A isl_simplified_E isl_simplified_A Formulas.weight isl_simp.
+ +
+
+
+ +
+ + + diff --git a/config.js b/config.js new file mode 100644 index 0000000..72be613 --- /dev/null +++ b/config.js @@ -0,0 +1,72 @@ +var coqdocjs = coqdocjs || {}; + +coqdocjs.repl = { + "forall": "∀", + "exists": "∃", + "~": "¬", + "/\\": "∧", + "\\/": "∨", + "->": "→", + "<-": "←", + "<->": "↔", + "=>": "⇒", + "<>": "≠", + "<=": "≤", + ">=": "≥", + "el": "∈", + "nel": "∉", + "<<=": "⊆", + "|-": "⊢", + ">>": "»", + "<<": "⊆", + "++": "⧺", + "===": "≡", + "=/=": "≢", + "=~=": "≅", + "==>": "⟹", + "lhd": "⊲", + "rhd": "⊳", + "nat": "ℕ", + "alpha": "α", + "beta": "β", + "gamma": "γ", + "delta": "δ", + "epsilon": "ε", + "eta": "η", + "iota": "ι", + "kappa": "κ", + "lambda": "λ", + "mu": "μ", + "nu": "ν", + "omega": "ω", + "phi": "ϕ", + "pi": "π", + "psi": "ψ", + "rho": "ρ", + "sigma": "σ", + "tau": "τ", + "theta": "θ", + "xi": "ξ", + "zeta": "ζ", + "Delta": "Δ", + "Gamma": "Γ", + "Pi": "Π", + "Sigma": "Σ", + "Omega": "Ω", + "Xi": "Ξ" +}; + +coqdocjs.subscr = { + "0" : "₀", + "1" : "₁", + "2" : "₂", + "3" : "₃", + "4" : "₄", + "5" : "₅", + "6" : "₆", + "7" : "₇", + "8" : "₈", + "9" : "₉", +}; + +coqdocjs.replInText = ["==>","<=>", "=>", "->", "<-", ":="]; diff --git a/coqdoc.css b/coqdoc.css new file mode 100644 index 0000000..7753021 --- /dev/null +++ b/coqdoc.css @@ -0,0 +1,244 @@ +body { + font-family: Times New Roman, serif; + font-size: 1.5em; + color: #2D2D2D +} + +td { + padding: 0 10px; +} + +td.ms { + font-family: 'Courier New', monospace; +} + +a { + text-decoration: none; + border-radius: 3px; + padding-left: 3px; + padding-right: 3px; + margin-left: -3px; + margin-right: -3px; + color: inherit; + font-weight: bold; +} + +#main .code a, +#main .inlinecode a, +#toc a { + font-weight: inherit; +} + +a[href]:hover, +[clickable]:hover { + background-color: rgba(0, 0, 0, 0.1); + cursor: pointer; +} + +h, +h1, +h2, +h3, +h4, +h5 { + line-height: 1; + color: black; + text-rendering: optimizeLegibility; + font-weight: normal; + text-align: left; +} + +div+br { + display: none; +} + +div:empty { + display: none; +} + +#main h1 { + font-size: 2em; +} + +#main h2 { + font-size: 1.667rem; +} + +#main h3 { + font-size: 1.333em; +} + +#main h4, +#main h5, +#main h6 { + font-size: 1em; +} + +#toc h2 { + padding-bottom: 0; +} + +#main .doc { + margin: 0; + text-align: justify; +} + +.inlinecode, +.code, +#main pre { + font-family: monospace; +} + +.code>br:first-child { + display: none; +} + +.doc+.code { + margin-top: 0.5em; +} + +.block { + display: block; + margin-top: 5px; + margin-bottom: 5px; + padding: 10px; + text-align: center; +} + +.block img { + margin: 15px; +} + +table.infrule { + border: 0px; + margin-left: 50px; + margin-top: 10px; + margin-bottom: 10px; +} + +td.infrule { + font-family: "Droid Sans Mono", "DejaVu Sans Mono", monospace; + text-align: center; + padding: 0; + line-height: 1; +} + +tr.infrulemiddle hr { + margin: 1px 0 1px 0; +} + +.infrulenamecol { + color: rgb(60%, 60%, 60%); + padding-left: 1em; + padding-bottom: 0.1em +} + +.id[type="constructor"], +.id[type="projection"], +.id[type="method"], +.id[title="constructor"], +.id[title="projection"], +.id[title="method"] { + color: #A30E16; +} + +.id[type="var"], +.id[type="variable"], +.id[title="var"], +.id[title="variable"] { + color: inherit; +} + +.id[type="definition"], +.id[type="record"], +.id[type="class"], +.id[type="instance"], +.id[type="inductive"], +.id[type="library"], +.id[title="definition"], +.id[title="record"], +.id[title="class"], +.id[title="instance"], +.id[title="inductive"], +.id[title="library"] { + color: #A6650F; +} + +.id[type="lemma"], +.id[title="lemma"] { + color: #188B0C; +} + +.id[type="keyword"], +.id[type="notation"], +.id[type="abbreviation"], +.id[title="keyword"], +.id[title="notation"], +.id[title="abbreviation"] { + color: #2874AE; +} + +.comment { + color: #808080; +} + +/* TOC */ + +#toc h2 { + letter-spacing: 0; + font-size: 1.333em; +} + +/* Index */ + +#index { + margin: 0; + padding: 0; + width: 100%; +} + +#index #frontispiece { + margin: 1em auto; + padding: 1em; + width: 60%; +} + +.booktitle { + font-size: 140% +} + +.authors { + font-size: 90%; + line-height: 115%; +} + +.moreauthors { + font-size: 60% +} + +#index #entrance { + text-align: center; +} + +#index #entrance .spacer { + margin: 0 30px 0 30px; +} + +ul.doclist { + margin-top: 0em; + margin-bottom: 0em; +} + +#toc>* { + clear: both; +} + +#toc>a { + display: block; + float: left; + margin-top: 1em; +} + +#toc a h2 { + display: inline; +} diff --git a/coqdocjs.css b/coqdocjs.css new file mode 100644 index 0000000..d94bb58 --- /dev/null +++ b/coqdocjs.css @@ -0,0 +1,249 @@ +/* replace unicode */ + +.id[repl] .hidden { + font-size: 0; +} + +.id[repl]:before{ + content: attr(repl); +} + +/* folding proofs */ + +@keyframes show-proof { + 0% { + max-height: 1.2em; + opacity: 1; + } + 99% { + max-height: 1000em; + } + 100%{ + } +} + +@keyframes hide-proof { + from { + visibility: visible; + max-height: 10em; + opacity: 1; + } + to { + max-height: 1.2em; + } +} + +.proof { + cursor: pointer; +} +.proof * { + cursor: pointer; +} + +.proof { + overflow: hidden; + position: relative; + transition: opacity 1s; + display: inline-block; +} + +.proof[show="false"] { + max-height: 1.2em; + visibility: visible; + opacity: 0.3; +} + +.proof[show="false"][animate] { + animation-name: hide-proof; + animation-duration: 0.25s; +} + +.proof[show=true] { + animation-name: show-proof; + animation-duration: 10s; +} + +.proof[show="false"]:before { + position: absolute; + visibility: visible; + width: 100%; + height: 100%; + display: block; + opacity: 0; + content: "M"; +} +.proof[show="false"]:hover:before { + content: ""; +} + +.proof[show="false"] + br + br { + display: none; +} + +.proof[show="false"]:hover { + visibility: visible; + opacity: 0.5; +} + +#toggle-proofs[proof-status="no-proofs"] { + display: none; +} + +#toggle-proofs[proof-status="some-hidden"]:before { + content: "Show Proofs"; +} + +#toggle-proofs[proof-status="all-shown"]:before { + content: "Hide Proofs"; +} + + +/* page layout */ + +html, body { + height: 100%; + margin:0; + padding:0; +} + +@media only screen { /* no div with internal scrolling to allow printing of whole content */ + body { + display: flex; + flex-direction: column + } + + #content { + flex: 1; + overflow: auto; + display: flex; + flex-direction: column; + } +} + +#content:focus { + outline: none; /* prevent glow in OS X */ +} + +#main { + display: block; + padding: 16px; + padding-top: 1em; + padding-bottom: 2em; + margin-left: auto; + margin-right: auto; + max-width: 60em; + flex: 1 0 auto; +} + +.libtitle { + display: none; +} + +/* header */ +#header { + width:100%; + padding: 0; + margin: 0; + display: flex; + align-items: center; + background-color: rgb(21,57,105); + color: white; + font-weight: bold; + overflow: hidden; +} + + +.button { + cursor: pointer; +} + +#header * { + text-decoration: none; + vertical-align: middle; + margin-left: 15px; + margin-right: 15px; +} + +#header > .right, #header > .left { + display: flex; + flex: 1; + align-items: center; +} +#header > .left { + text-align: left; +} +#header > .right { + flex-direction: row-reverse; +} + +#header a, #header .button { + color: white; + box-sizing: border-box; +} + +#header a { + border-radius: 0; + padding: 0.2em; +} + +#header .button { + background-color: rgb(63, 103, 156); + border-radius: 1em; + padding-left: 0.5em; + padding-right: 0.5em; + margin: 0.2em; +} + +#header a:hover, #header .button:hover { + background-color: rgb(181, 213, 255); + color: black; +} + +#header h1 { padding: 0; + margin: 0;} + +/* footer */ +#footer { + text-align: center; + opacity: 0.5; + font-size: 75%; +} + +/* hyperlinks */ + +@keyframes highlight { + 50%{ + background-color: black; + } +} + +:target * { + animation-name: highlight; + animation-duration: 1s; +} + +a[name]:empty { + float: right; +} + +/* Proviola */ + +div.code { + width: auto; + float: none; +} + +div.goal { + position: fixed; + left: 75%; + width: 25%; + top: 3em; +} + +div.doc { + clear: both; +} + +span.command:hover { + background-color: inherit; +} diff --git a/coqdocjs.js b/coqdocjs.js new file mode 100644 index 0000000..10dc0bb --- /dev/null +++ b/coqdocjs.js @@ -0,0 +1,189 @@ +var coqdocjs = coqdocjs || {}; +(function(){ + +function replace(s){ + var m; + if (m = s.match(/^(.+)'/)) { + return replace(m[1])+"'"; + } else if (m = s.match(/^([A-Za-z]+)_?(\d+)$/)) { + return replace(m[1])+m[2].replace(/\d/g, function(d){ + if (coqdocjs.subscr.hasOwnProperty(d)) { + return coqdocjs.subscr[d]; + } else { + return d; + } + }); + } else if (coqdocjs.repl.hasOwnProperty(s)){ + return coqdocjs.repl[s] + } else { + return s; + } +} + +function toArray(nl){ + return Array.prototype.slice.call(nl); +} + +function replInTextNodes() { + coqdocjs.replInText.forEach(function(toReplace){ + toArray(document.getElementsByClassName("code")).concat(toArray(document.getElementsByClassName("inlinecode"))).forEach(function(elem){ + toArray(elem.childNodes).forEach(function(node){ + if (node.nodeType != Node.TEXT_NODE) return; + var fragments = node.textContent.split(toReplace); + node.textContent = fragments[fragments.length-1]; + for (var k = 0; k < fragments.length - 1; ++k) { + node.parentNode.insertBefore(document.createTextNode(fragments[k]),node); + var replacement = document.createElement("span"); + replacement.appendChild(document.createTextNode(toReplace)); + replacement.setAttribute("class", "id"); + replacement.setAttribute("type", "keyword"); + node.parentNode.insertBefore(replacement, node); + } + }); + }); + }); +} + +function replNodes() { + toArray(document.getElementsByClassName("id")).forEach(function(node){ + if (["var", "variable", "keyword", "notation", "definition", "inductive"].indexOf(node.getAttribute("type"))>=0){ + var text = node.textContent; + var replText = replace(text); + if(text != replText) { + node.setAttribute("repl", replText); + node.setAttribute("title", text); + var hidden = document.createElement("span"); + hidden.setAttribute("class", "hidden"); + while (node.firstChild) { + hidden.appendChild(node.firstChild); + } + node.appendChild(hidden); + } + } + }); +} + +function isVernacStart(l, t){ + t = t.trim(); + for(var s of l){ + if (t == s || t.startsWith(s+" ") || t.startsWith(s+".")){ + return true; + } + } + return false; +} + +function isProofStart(n){ + return isVernacStart(["Proof"], n.textContent) || + (isVernacStart(["Next"], n.textContent) && isVernacStart(["Obligation"], n.nextSibling.nextSibling.textContent)); +} + +function isProofEnd(s){ + return isVernacStart(["Qed", "Admitted", "Defined", "Abort"], s); +} + +function proofStatus(){ + var proofs = toArray(document.getElementsByClassName("proof")); + if(proofs.length) { + for(var proof of proofs) { + if (proof.getAttribute("show") === "false") { + return "some-hidden"; + } + } + return "all-shown"; + } + else { + return "no-proofs"; + } +} + +function updateView(){ + document.getElementById("toggle-proofs").setAttribute("proof-status", proofStatus()); +} + +function foldProofs() { + var hasCommands = true; + var nodes = document.getElementsByClassName("command"); + if(nodes.length == 0) { + hasCommands = false; + console.log("no command tags found") + nodes = document.getElementsByClassName("id"); + } + toArray(nodes).forEach(function(node){ + if(isProofStart(node)) { + var proof = document.createElement("span"); + proof.setAttribute("class", "proof"); + + node.parentNode.insertBefore(proof, node); + if(proof.previousSibling.nodeType === Node.TEXT_NODE) + proof.appendChild(proof.previousSibling); + while(node && !isProofEnd(node.textContent)) { + proof.appendChild(node); + node = proof.nextSibling; + } + if (proof.nextSibling) proof.appendChild(proof.nextSibling); // the Qed + if (!hasCommands && proof.nextSibling) proof.appendChild(proof.nextSibling); // the dot after the Qed + + proof.addEventListener("click", function(proof){return function(e){ + if (e.target.parentNode.tagName.toLowerCase() === "a") + return; + proof.setAttribute("show", proof.getAttribute("show") === "true" ? "false" : "true"); + proof.setAttribute("animate", ""); + updateView(); + };}(proof)); + proof.setAttribute("show", "false"); + } + }); +} + +function toggleProofs(){ + var someProofsHidden = proofStatus() === "some-hidden"; + toArray(document.getElementsByClassName("proof")).forEach(function(proof){ + proof.setAttribute("show", someProofsHidden); + proof.setAttribute("animate", ""); + }); + updateView(); +} + +function repairDom(){ + // pull whitespace out of command + toArray(document.getElementsByClassName("command")).forEach(function(node){ + while(node.firstChild && node.firstChild.textContent.trim() == ""){ + console.log("try move"); + node.parentNode.insertBefore(node.firstChild, node); + } + }); + toArray(document.getElementsByClassName("id")).forEach(function(node){ + node.setAttribute("type", node.getAttribute("title")); + }); + toArray(document.getElementsByClassName("idref")).forEach(function(ref){ + toArray(ref.childNodes).forEach(function(child){ + if (["var", "variable"].indexOf(child.getAttribute("type")) > -1) + ref.removeAttribute("href"); + }); + }); + +} + +function fixTitle(){ + var url = "/" + window.location.pathname; + var basename = url.substring(url.lastIndexOf('/')+1, url.lastIndexOf('.')); + if (basename === "toc") {document.title = "Table of Contents";} + else if (basename === "indexpage") {document.title = "Index";} + else {document.title = basename;} +} + +function postprocess(){ + repairDom(); + replInTextNodes() + replNodes(); + foldProofs(); + document.getElementById("toggle-proofs").addEventListener("click", toggleProofs); + updateView(); +} + +fixTitle(); +document.addEventListener('DOMContentLoaded', postprocess); + +coqdocjs.toggleProofs = toggleProofs; +})(); diff --git a/demo.html b/demo.html new file mode 100644 index 0000000..c94d08f --- /dev/null +++ b/demo.html @@ -0,0 +1,139 @@ + + + + + + + + + + Uniform interpolant calculator + + + + + +
+
+ +

Enter a formula below and choose a logic and interpolant to compute.

+ + + + +

+
Result:

+
+ + Usage instructions. + We support four logics: +
    +
  • intuitionistic logic (IL),
  • +
  • Gödel-Löb logic (GL),
  • +
  • basic modal logic (K), and +
  • intuitionistic Strong Löb logic (iSL).
  • +
+ You may use the following symbols: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
->implication
¬~negation
&conjunction (and)
|disjunction (or)
[]necessity (box)
<>possibility (diamond)
Tverum
F, #falsum
ppropositional variable to be quantified
q, r, … other propositional variables (in [a-z][a-z A-Z 0-9]*)
+

The quantifiers are always with respect to the variable p.

+

+ Disclaimer: + This page is only for the purpose of easy demonstration of the formally verified implementation in Coq (more information on this implementation can be found by clicking the links above). The + parsing library and the OCaml to JS compiler that were used + for building this page are not verified formally. + The functions have not yet been optimized; high run-time may occur even on small examples. +

+ + + +
+
+ + + diff --git a/index.html b/index.html new file mode 100644 index 0000000..3a32d47 --- /dev/null +++ b/index.html @@ -0,0 +1,10 @@ + + + + Index Page + + + + + + diff --git a/indexpage.html b/indexpage.html new file mode 100644 index 0000000..583179e --- /dev/null +++ b/indexpage.html @@ -0,0 +1,6674 @@ + + + + + + + + + + + + + +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Global IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(2915 entries)
Notation IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(42 entries)
Variable IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(114 entries)
Library IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(97 entries)
Lemma IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(1372 entries)
Constructor IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(190 entries)
Inductive IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(102 entries)
Section IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(66 entries)
Instance IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(25 entries)
Definition IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(907 entries)
+
+

Global Index

+

A

+A [definition, in ISL.PropQuantifiers]
+AccT [inductive, in General.genT]
+AccT_in_nextup_fc [lemma, in General.dd_fc]
+AccT_measure [definition, in General.gentree]
+AccT_measure' [lemma, in General.gentree]
+AccT_sind [definition, in General.genT]
+AccT_rec [definition, in General.genT]
+AccT_ind [definition, in General.genT]
+AccT_rect [definition, in General.genT]
+AccT_intro [constructor, in General.genT]
+Acc_invprem [lemma, in GL.Interpolation.UIGL_Canopy]
+Acc_less_imp [lemma, in GL.Interpolation.UIGL_Canopy]
+Acc_invprem [lemma, in K.Interpolation.UIK_Canopy]
+Acc_less_imp [lemma, in K.Interpolation.UIK_Canopy]
+additive_cut [lemma, in ISL.Cut]
+add_remove_list_preserve_NoDup [lemma, in Syntax.remove_list_lems]
+add_1_element_split_lists [lemma, in Syntax.list_lems]
+aderI [constructor, in General.ddT]
+aderrec [inductive, in General.ddT]
+aderrec_sind [definition, in General.ddT]
+aderrec_ind [definition, in General.ddT]
+adm [inductive, in General.ddT]
+admD [definition, in General.ddT]
+admDs [definition, in General.ddT]
+admI [constructor, in General.ddT]
+adm_single_trans [lemma, in General.ddT]
+adm_derrec_trans [lemma, in General.ddT]
+adm_adm [lemma, in General.ddT]
+adm_sind [definition, in General.ddT]
+adm_rec [definition, in General.ddT]
+adm_ind [definition, in General.ddT]
+adm_rect [definition, in General.ddT]
+adpI [constructor, in General.ddT]
+Af [definition, in ISL.PropQuantifiers]
+allPder [inductive, in General.dd_fc]
+allPderD [lemma, in General.dd_fc]
+allPderD_in [lemma, in General.dd_fc]
+allPder_dlConsD [lemma, in General.dd_fc]
+allPder_sind [definition, in General.dd_fc]
+allPder_rec [definition, in General.dd_fc]
+allPder_ind [definition, in General.dd_fc]
+allPder_rect [definition, in General.dd_fc]
+allPder_Cons [constructor, in General.dd_fc]
+allPder_Nil [constructor, in General.dd_fc]
+allP_all_in_d [lemma, in General.dd_fc]
+all_P_univ_gen_ext_nil [lemma, in General.univ_gen_ext]
+all_in_d_allP [lemma, in General.dd_fc]
+all_derl_dersl' [lemma, in General.ddT]
+all_derl_dersl [lemma, in General.ddT]
+all_dercl_derscl [lemma, in General.ddT]
+all_RHS_boxes_are_LHS_boxes_no_GLR [lemma, in GL.GLS.GLS_termination_measure]
+And [definition, in Syntax.CML_Syntax]
+And [constructor, in ISL.Formulas]
+AndL [constructor, in ISL.Sequents]
+AndL [lemma, in K.Interpolation.UIK_UI_prelims]
+AndL [lemma, in GL.Interpolation.UIGL_And_Or_rules]
+AndL_inv [lemma, in GL.Interpolation.UIGL_And_Or_rules]
+AndL_rev [lemma, in ISL.SequentProps]
+AndR [constructor, in ISL.Sequents]
+AndR [lemma, in K.Interpolation.UIK_UI_prelims]
+AndR [lemma, in GL.Interpolation.UIGL_And_Or_rules]
+AndR_inv [lemma, in GL.Interpolation.UIGL_And_Or_rules]
+AndR_rev [lemma, in ISL.SequentProps]
+and_assoc_ctx_R_R [lemma, in ISL.Simp]
+and_assoc_ctx_R_L [lemma, in ISL.Simp]
+and_assoc_ctx_L_R [lemma, in ISL.Simp]
+and_assoc_L [lemma, in ISL.Simp]
+and_assoc_R [lemma, in ISL.Simp]
+and_comm_ctx_L [lemma, in ISL.Simp]
+and_comm [lemma, in ISL.Simp]
+and_true [lemma, in General.gen]
+and_congruence [lemma, in ISL.Optimizations]
+anon [definition, in General.genT]
+anonD [lemma, in General.genT]
+anonI [lemma, in General.genT]
+anon_forall [lemma, in General.genT]
+anon_sigT [lemma, in General.genT]
+anon_iffT [lemma, in General.genT]
+anon_imp [lemma, in General.genT]
+anon_sum [lemma, in General.genT]
+anon_prod [lemma, in General.genT]
+anon_eq [lemma, in General.genT]
+apfst [definition, in General.gen_seq]
+appI [lemma, in General.gen_tacs]
+appl [lemma, in General.gen]
+applI [lemma, in General.gen_tacs]
+appl_cong [lemma, in General.gen_tacs]
+apprI [lemma, in General.gen_tacs]
+appr_cong [lemma, in General.gen_tacs]
+app_remove_list [lemma, in Syntax.remove_list_lems]
+app_split_at_sind [definition, in General.List_lemmasT]
+app_split_at_rec [definition, in General.List_lemmasT]
+app_split_at_ind [definition, in General.List_lemmasT]
+app_split_at_rect [definition, in General.List_lemmasT]
+app_split_at [inductive, in General.List_lemmasT]
+app_eq_appT2_single_tlR [lemma, in General.List_lemmasT]
+app_eq_appT2_single_tlL [lemma, in General.List_lemmasT]
+app_eq_appT2_single_hdR [lemma, in General.List_lemmasT]
+app_eq_appT2_single_hdL [lemma, in General.List_lemmasT]
+app_eq_appT2_nn [lemma, in General.List_lemmasT]
+app_tl_inversion [lemma, in General.List_lemmasT]
+app_hd_inversion [lemma, in General.List_lemmasT]
+app_singleton_tl_inversion [lemma, in General.List_lemmasT]
+app_singleton_inversion [lemma, in General.List_lemmasT]
+app_eq_unitT2 [lemma, in General.List_lemmasT]
+app_eq_consT [definition, in General.List_lemmasT]
+app_eq_appT2 [lemma, in General.List_lemmasT]
+app_eq_appT [lemma, in General.List_lemmasT]
+app_eq_app [lemma, in General.List_lemmasT]
+app_eq_nilT [lemma, in General.List_lemmasT]
+app_eq_consT2 [definition, in General.List_lemmasT]
+app_eq_cons [definition, in General.List_lemmasT]
+app_cons_single [lemma, in General.List_lemmasT]
+app_eq_unitT [lemma, in General.gen_tacs]
+app_assoc_cons [definition, in General.gen_tacs]
+app_eq_nil_iff [lemma, in General.gen_tacs]
+app2_find_hole [lemma, in Syntax.list_lems]
+apsnd [definition, in General.gen_seq]
+arg_cong_imp' [lemma, in General.gen]
+arg_cong_imp [lemma, in General.gen]
+arg_cong [lemma, in General.gen]
+arg1_cong_imp' [lemma, in General.gen]
+arg1_cong_imp [lemma, in General.gen]
+Arithmetic [section, in K.Interpolation.UIK_basics]
+asa_eq [lemma, in General.List_lemmasT]
+asa_appR [constructor, in General.List_lemmasT]
+asa_appL [constructor, in General.List_lemmasT]
+asa_single [constructor, in General.List_lemmasT]
+asmI [constructor, in General.ddT]
+asmsI [lemma, in General.ddT]
+Atom [constructor, in ISL.Sequents]
+A_simplified [definition, in ISL.Simp]
+A_right [lemma, in ISL.PropQuantifiers]
+a_rule_env_spec [lemma, in ISL.PropQuantifiers]
+a_rule_form_vars [lemma, in ISL.PropQuantifiers]
+a_rule_env_vars [lemma, in ISL.PropQuantifiers]
+A_eq [definition, in ISL.PropQuantifiers]
+a_rule_form_cong_strong [lemma, in ISL.PropQuantifiers]
+a_rule_form_cong [lemma, in ISL.PropQuantifiers]
+a_rule_env_cong_strong [lemma, in ISL.PropQuantifiers]
+a_rule_env_cong [lemma, in ISL.PropQuantifiers]
+a_rule_form [definition, in ISL.PropQuantifiers]
+a_rule_env [definition, in ISL.PropQuantifiers]
+

B

+Bot [constructor, in Syntax.CML_Syntax]
+Bot [constructor, in ISL.Formulas]
+BotL [constructor, in GL.GLS.GLS_calcs]
+BotL [constructor, in K.KS.KS_calc]
+BotLRule [inductive, in GL.GLS.GLS_calcs]
+BotLRule [inductive, in K.KS.KS_calc]
+BotLRule_sind [definition, in GL.GLS.GLS_calcs]
+BotLRule_rec [definition, in GL.GLS.GLS_calcs]
+BotLRule_ind [definition, in GL.GLS.GLS_calcs]
+BotLRule_rect [definition, in GL.GLS.GLS_calcs]
+BotLRule_I [constructor, in GL.GLS.GLS_calcs]
+BotLRule_sind [definition, in K.KS.KS_calc]
+BotLRule_rec [definition, in K.KS.KS_calc]
+BotLRule_ind [definition, in K.KS.KS_calc]
+BotLRule_rect [definition, in K.KS.KS_calc]
+BotLRule_I [constructor, in K.KS.KS_calc]
+botRule_fc_prems [lemma, in General.dd_fc]
+botRule_fc_ps [lemma, in General.dd_fc]
+botRule_fc_drs [lemma, in General.dd_fc]
+botRule_fc_rules [lemma, in General.dd_fc]
+botRule_fc_concl [lemma, in General.dd_fc]
+botRule_fc_sind [definition, in General.dd_fc]
+botRule_fc_rec [definition, in General.dd_fc]
+botRule_fc_ind [definition, in General.dd_fc]
+botRule_fc_rect [definition, in General.dd_fc]
+botRule_fcI [constructor, in General.dd_fc]
+botRule_fc [inductive, in General.dd_fc]
+BotR_remove [lemma, in GL.Interpolation.UIGL_And_Or_rules]
+botr_ps_der [lemma, in General.dd_fc]
+bot_is_rule [definition, in General.dd_fc]
+Box [constructor, in Syntax.CML_Syntax]
+Box [constructor, in ISL.Formulas]
+BoxR [constructor, in ISL.Sequents]
+box_congr [lemma, in ISL.Simp]
+box_in_top_boxes [lemma, in Syntax.CML_Syntax]
+box_preserv_top_boxes [lemma, in GL.GLS.GLS_termination_measure]
+

C

+Canopy [definition, in GL.Interpolation.UIGL_Canopy]
+Canopy [definition, in K.Interpolation.UIK_Canopy]
+Canopy_nodupseq_perm [lemma, in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+Canopy_nodupseq_perm_gen [lemma, in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+Canopy_measure [lemma, in K.Interpolation.UIK_UI_prelims]
+Canopy_lems [section, in K.Interpolation.UIK_UI_prelims]
+Canopy_LtSeq [lemma, in K.Interpolation.UIK_basics]
+Canopy_nil [lemma, in K.Interpolation.UIK_basics]
+Canopy_pos_var [lemma, in GL.Interpolation.UIGL_Canopy]
+Canopy_neg_var [lemma, in GL.Interpolation.UIGL_Canopy]
+Canopy_hp_inv_ctx [lemma, in GL.Interpolation.UIGL_Canopy]
+Canopy_equiprv_genR [lemma, in GL.Interpolation.UIGL_Canopy]
+Canopy_equiprv_genL [lemma, in GL.Interpolation.UIGL_Canopy]
+Canopy_equiprv [lemma, in GL.Interpolation.UIGL_Canopy]
+Canopy_critical [lemma, in GL.Interpolation.UIGL_Canopy]
+Canopy_nodupseq_equiprv_genL [lemma, in GL.Interpolation.UIGL_UI_prelims]
+Canopy_nodupseq_equiprv_genR [lemma, in GL.Interpolation.UIGL_UI_prelims]
+Canopy_LexSeq [lemma, in GL.Interpolation.UIGL_LexSeq]
+Canopy_nil [lemma, in GL.Interpolation.UIGL_LexSeq]
+Canopy_pos_var [lemma, in K.Interpolation.UIK_Canopy]
+Canopy_neg_var [lemma, in K.Interpolation.UIK_Canopy]
+Canopy_hp_inv_ctx [lemma, in K.Interpolation.UIK_Canopy]
+Canopy_equiprv_genR [lemma, in K.Interpolation.UIK_Canopy]
+Canopy_equiprv_genL [lemma, in K.Interpolation.UIK_Canopy]
+Canopy_equiprv [lemma, in K.Interpolation.UIK_Canopy]
+Canopy_critical [lemma, in K.Interpolation.UIK_Canopy]
+can_exchR [definition, in General.gen_seq]
+can_exchL [definition, in General.gen_seq]
+can_wkL_req [lemma, in General.gen_seq]
+can_wkL [definition, in General.gen_seq]
+can_rel [definition, in General.gstep]
+can_trf_rules_rtc_mono [definition, in General.gstep]
+can_trf_rules_rtc_mono' [lemma, in General.gstep]
+can_trf_rules_imp_rtc [lemma, in General.gstep]
+can_trf_rules_rtc [definition, in General.gstep]
+can_trf_derl [lemma, in General.gstep]
+can_trf_rules_req [lemma, in General.gstep]
+can_trf_rules_Un [lemma, in General.gstep]
+can_trf_rules_un [lemma, in General.gstep]
+can_trf_rules_rc_mono [definition, in General.gstep]
+can_trf_rules_mono [definition, in General.gstep]
+can_trf_rules_rc_mono' [lemma, in General.gstep]
+can_trf_rules_mono' [lemma, in General.gstep]
+can_trf_rules_imp_rc [lemma, in General.gstep]
+can_trf_rules_rc [definition, in General.gstep]
+can_trf_rules [definition, in General.gstep]
+casmI [constructor, in General.ddT]
+ccps [inductive, in General.ddT]
+ccpsD [lemma, in General.ddT]
+ccpsI [constructor, in General.ddT]
+ccps_sind [definition, in General.ddT]
+ccps_rec [definition, in General.ddT]
+ccps_ind [definition, in General.ddT]
+ccps_rect [definition, in General.ddT]
+choose_disj [definition, in ISL.Environments]
+choose_conj [definition, in ISL.Environments]
+choose_disj_equiv_R [lemma, in ISL.Optimizations]
+choose_disj_equiv_L [lemma, in ISL.Optimizations]
+choose_conj_equiv_R [lemma, in ISL.Optimizations]
+choose_conj_equiv_L [lemma, in ISL.Optimizations]
+Closure [inductive, in GL.GLS.GLS_exch]
+Closure [inductive, in K.KS.KS_exch]
+Closure_sind [definition, in GL.GLS.GLS_exch]
+Closure_rec [definition, in GL.GLS.GLS_exch]
+Closure_ind [definition, in GL.GLS.GLS_exch]
+Closure_rect [definition, in GL.GLS.GLS_exch]
+Closure_sind [definition, in K.KS.KS_exch]
+Closure_rec [definition, in K.KS.KS_exch]
+Closure_ind [definition, in K.KS.KS_exch]
+Closure_rect [definition, in K.KS.KS_exch]
+clos_rt_rtn1T [lemma, in General.rtcT]
+clos_rtn1_rtT [lemma, in General.rtcT]
+clos_rt_rt1nT [lemma, in General.rtcT]
+clos_rt1n_rtT [lemma, in General.rtcT]
+clos_refl_transT_n1_sind [definition, in General.rtcT]
+clos_refl_transT_n1_rec [definition, in General.rtcT]
+clos_refl_transT_n1_ind [definition, in General.rtcT]
+clos_refl_transT_n1_rect [definition, in General.rtcT]
+clos_refl_transT_n1 [inductive, in General.rtcT]
+clos_refl_transT_1n_sind [definition, in General.rtcT]
+clos_refl_transT_1n_rec [definition, in General.rtcT]
+clos_refl_transT_1n_ind [definition, in General.rtcT]
+clos_refl_transT_1n_rect [definition, in General.rtcT]
+clos_refl_transT_1n [inductive, in General.rtcT]
+clos_refl_transT_sind [definition, in General.rtcT]
+clos_refl_transT_rec [definition, in General.rtcT]
+clos_refl_transT_ind [definition, in General.rtcT]
+clos_refl_transT_rect [definition, in General.rtcT]
+clos_refl_transT [inductive, in General.rtcT]
+clos_reflT_sind [definition, in General.rtcT]
+clos_reflT_rec [definition, in General.rtcT]
+clos_reflT_ind [definition, in General.rtcT]
+clos_reflT_rect [definition, in General.rtcT]
+clos_reflT [inductive, in General.rtcT]
+CML_Syntax [library]
+conjunction [definition, in ISL.Environments]
+conjunction_L [lemma, in ISL.Optimizations]
+conjunction_R2 [lemma, in ISL.Optimizations]
+conjunction_R1 [lemma, in ISL.Optimizations]
+cons_singleton [lemma, in General.List_lemmasT]
+cons_eq_appT2 [lemma, in General.List_lemmasT]
+cons_eq_appT [lemma, in General.List_lemmasT]
+cons_eq_app [lemma, in General.List_lemmasT]
+cons_single [lemma, in General.List_lemmasT]
+cons_app_single [lemma, in General.swappedT]
+contraction [lemma, in ISL.SequentProps]
+contradic_subform_boxesF [lemma, in GL.GLS.GLS_termination_measure]
+CountablyManyFormulas [section, in ISL.Formulas]
+count_occ_n_imp_subformLF [lemma, in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+count_le_n_imp [lemma, in GL.Interpolation.UIGL_Canopy_ImpR]
+count_occ_n_imp_subformLF [lemma, in GL.Interpolation.UIGL_Canopy_ImpR]
+Craig_Interpolation [lemma, in K.Interpolation.K_Craig_Interp]
+crd_ra [lemma, in General.gstep]
+critical_empty_set [lemma, in K.Interpolation.UIK_basics]
+critical_nodupseq [lemma, in GL.Interpolation.UIGL_nodupseq]
+critical_Seq_InT_Canopy [lemma, in GL.Interpolation.UIGL_Canopy]
+critical_Seq_dec [definition, in GL.Interpolation.UIGL_Canopy]
+critical_Seq [definition, in GL.Interpolation.UIGL_Canopy]
+critical_empty_seq [lemma, in GL.Interpolation.UIGL_LexSeq]
+critical_Seq_InT_Canopy [lemma, in K.Interpolation.UIK_Canopy]
+critical_Seq_dec [definition, in K.Interpolation.UIK_Canopy]
+critical_Seq [definition, in K.Interpolation.UIK_Canopy]
+ctr_R_sind [definition, in K.KS.KS_ctr]
+ctr_R_rec [definition, in K.KS.KS_ctr]
+ctr_R_ind [definition, in K.KS.KS_ctr]
+ctr_R_rect [definition, in K.KS.KS_ctr]
+ctr_RI [constructor, in K.KS.KS_ctr]
+ctr_R [inductive, in K.KS.KS_ctr]
+ctr_L_sind [definition, in K.KS.KS_ctr]
+ctr_L_rec [definition, in K.KS.KS_ctr]
+ctr_L_ind [definition, in K.KS.KS_ctr]
+ctr_L_rect [definition, in K.KS.KS_ctr]
+ctr_LI [constructor, in K.KS.KS_ctr]
+ctr_L [inductive, in K.KS.KS_ctr]
+ctr_R_BotL_notapplic [lemma, in GL.GLS.GLS_ctr]
+ctr_R_IdB_notapplic [lemma, in GL.GLS.GLS_ctr]
+ctr_R_IdP_notapplic [lemma, in GL.GLS.GLS_ctr]
+ctr_L_BotL_notapplic [lemma, in GL.GLS.GLS_ctr]
+ctr_L_IdB_notapplic [lemma, in GL.GLS.GLS_ctr]
+ctr_L_IdP_notapplic [lemma, in GL.GLS.GLS_ctr]
+ctr_R_sind [definition, in GL.GLS.GLS_ctr]
+ctr_R_rec [definition, in GL.GLS.GLS_ctr]
+ctr_R_ind [definition, in GL.GLS.GLS_ctr]
+ctr_R_rect [definition, in GL.GLS.GLS_ctr]
+ctr_RI [constructor, in GL.GLS.GLS_ctr]
+ctr_R [inductive, in GL.GLS.GLS_ctr]
+ctr_L_sind [definition, in GL.GLS.GLS_ctr]
+ctr_L_rec [definition, in GL.GLS.GLS_ctr]
+ctr_L_ind [definition, in GL.GLS.GLS_ctr]
+ctr_L_rect [definition, in GL.GLS.GLS_ctr]
+ctr_LI [constructor, in GL.GLS.GLS_ctr]
+ctr_L [inductive, in GL.GLS.GLS_ctr]
+cut [lemma, in ISL.Cut]
+Cut [library]
+CutRule [inductive, in GL.GLS.GLS_cut_elim]
+CutRule [inductive, in K.KS.KS_cut_elim]
+CutRule_sind [definition, in GL.GLS.GLS_cut_elim]
+CutRule_rec [definition, in GL.GLS.GLS_cut_elim]
+CutRule_ind [definition, in GL.GLS.GLS_cut_elim]
+CutRule_rect [definition, in GL.GLS.GLS_cut_elim]
+CutRule_I [constructor, in GL.GLS.GLS_cut_elim]
+CutRule_sind [definition, in K.KS.KS_cut_elim]
+CutRule_rec [definition, in K.KS.KS_cut_elim]
+CutRule_ind [definition, in K.KS.KS_cut_elim]
+CutRule_rect [definition, in K.KS.KS_cut_elim]
+CutRule_I [constructor, in K.KS.KS_cut_elim]
+

D

+dcl_allT [definition, in General.ddT]
+dcsl_allT [definition, in General.ddT]
+ddT [library]
+dd_fc [library]
+decidable_is_negation [instance, in ISL.Environments]
+decidable_is_implication [instance, in ISL.Environments]
+decidable_is_double_negation [instance, in ISL.Environments]
+decide_in [lemma, in ISL.Environments]
+DecisionProcedure [library]
+decT_less_than_lt [lemma, in GL.GLS.GLS_termination_measure]
+decT_lex_lt [lemma, in GL.GLS.GLS_termination_measure]
+decT_lt [lemma, in GL.GLS.GLS_termination_measure]
+dec_non_nil_prems [lemma, in K.KS.KS_termination]
+dec_le [lemma, in K.KS.KS_termination_prelims]
+dec_GLS_rules [definition, in GL.GLS.GLS_dec]
+dec_GLR_rule [definition, in GL.GLS.GLS_dec]
+dec_box_in_list [definition, in GL.GLS.GLS_dec]
+dec_ImpL_rule [definition, in GL.GLS.GLS_dec]
+dec_ImpR_rule [definition, in GL.GLS.GLS_dec]
+dec_imp_in [definition, in GL.GLS.GLS_dec]
+dec_is_imp [definition, in GL.GLS.GLS_dec]
+dec_init_rules [definition, in GL.GLS.GLS_dec]
+dec_BotL_rule [definition, in GL.GLS.GLS_dec]
+dec_IdB_rule [definition, in GL.GLS.GLS_dec]
+dec_IdP_rule [definition, in GL.GLS.GLS_dec]
+dec_GLS_init_rules [definition, in GL.GLS.GLS_dec]
+dec_box_in [definition, in GL.GLS.GLS_dec]
+dec_is_box [definition, in GL.GLS.GLS_dec]
+dec_is_boxedT [definition, in GL.GLS.GLS_dec]
+dec_prop_var_in [definition, in GL.GLS.GLS_dec]
+dec_KS_rules [definition, in K.KS.KS_dec]
+dec_KR_rule [definition, in K.KS.KS_dec]
+dec_box_in_list [definition, in K.KS.KS_dec]
+dec_ImpL_rule [definition, in K.KS.KS_dec]
+dec_ImpR_rule [definition, in K.KS.KS_dec]
+dec_imp_in [definition, in K.KS.KS_dec]
+dec_is_imp [definition, in K.KS.KS_dec]
+dec_BotL_rule [definition, in K.KS.KS_dec]
+dec_IdP_rule [definition, in K.KS.KS_dec]
+dec_KS_init_rules [definition, in K.KS.KS_dec]
+dec_box_in [definition, in K.KS.KS_dec]
+dec_is_box [definition, in K.KS.KS_dec]
+dec_is_boxedT [definition, in K.KS.KS_dec]
+dec_prop_var_in [definition, in K.KS.KS_dec]
+dec_is_PropVar [definition, in K.KS.KS_dec]
+dercl [inductive, in General.ddT]
+dercl_soundness [lemma, in General.gstep]
+dercl_derl [definition, in General.ddT]
+dercl_derl' [lemma, in General.ddT]
+dercl_all_rect [lemma, in General.ddT]
+dercl_dercsl_rect_mut [definition, in General.ddT]
+dercl_rect_mut [definition, in General.ddT]
+dercl_rec_mut [definition, in General.ddT]
+dercl_ind_mut [definition, in General.ddT]
+dercl_sind [definition, in General.ddT]
+dercl_rec [definition, in General.ddT]
+dercl_ind [definition, in General.ddT]
+dercl_rect [definition, in General.ddT]
+dercsl [inductive, in General.ddT]
+dercsl_dersl [definition, in General.ddT]
+dercsl_rect_mut [definition, in General.ddT]
+dercsl_rec_mut [definition, in General.ddT]
+dercsl_ind_mut [definition, in General.ddT]
+dercsl_sind [definition, in General.ddT]
+dercsl_rec [definition, in General.ddT]
+dercsl_ind [definition, in General.ddT]
+dercsl_rect [definition, in General.ddT]
+derI [constructor, in General.ddT]
+derI_rules_mono [definition, in General.ddT]
+derl [inductive, in General.ddT]
+derl_fst_ext_rls [lemma, in General.gen_seq]
+derl_fst_ext_rls' [definition, in General.gen_seq]
+derl_fst_ext_rls'' [lemma, in General.gen_seq]
+derl_seqrule [lemma, in General.gen_seq]
+derl_seqrule' [definition, in General.gen_seq]
+derl_seqrule'' [lemma, in General.gen_seq]
+derl_height [definition, in General.dd_fc]
+derl_adm [definition, in General.ddT]
+derl_adm_s [lemma, in General.ddT]
+derl_sub_adm [lemma, in General.ddT]
+derl_mono [definition, in General.ddT]
+derl_mono' [definition, in General.ddT]
+derl_dersl_mono' [lemma, in General.ddT]
+derl_deriv [definition, in General.ddT]
+derl_deriv' [definition, in General.ddT]
+derl_dersl_deriv' [lemma, in General.ddT]
+derl_trans [definition, in General.ddT]
+derl_trans' [lemma, in General.ddT]
+derl_derrec_nil [definition, in General.ddT]
+derl_derrec [definition, in General.ddT]
+derl_derrec_trans [definition, in General.ddT]
+derl_derrec_trans' [lemma, in General.ddT]
+derl_all_rect [lemma, in General.ddT]
+derl_dercl [lemma, in General.ddT]
+derl_dersl_rect_mut [definition, in General.ddT]
+derl_dersl_single [lemma, in General.ddT]
+derl_rect_mut [definition, in General.ddT]
+derl_rec_mut [definition, in General.ddT]
+derl_ind_mut [definition, in General.ddT]
+derl_sind [definition, in General.ddT]
+derl_rec [definition, in General.ddT]
+derl_ind [definition, in General.ddT]
+derl_rect [definition, in General.ddT]
+derrec [inductive, in General.ddT]
+derrec_leaves_thms [lemma, in GL.GLS.GLS_der_dec]
+derrec_composition [lemma, in GL.GLS.GLS_der_dec]
+derrec_soundness [lemma, in General.gstep]
+derrec_dp_same2 [lemma, in General.dd_fc]
+derrec_dp_same [lemma, in General.dd_fc]
+derrec_fc_height [definition, in General.dd_fc]
+derrec_fc_size [definition, in General.dd_fc]
+derrec_fc_concl [definition, in General.dd_fc]
+derrec_fc_sind [definition, in General.dd_fc]
+derrec_fc_rec [definition, in General.dd_fc]
+derrec_fc_ind [definition, in General.dd_fc]
+derrec_fc_rect [definition, in General.dd_fc]
+derrec_fc [inductive, in General.dd_fc]
+derrec_concl [definition, in General.dd_fc]
+derrec_size [definition, in General.dd_fc]
+derrec_height [definition, in General.dd_fc]
+derrec_rect_mut_all [definition, in General.dd_fc]
+derrec_eq_swap [lemma, in General.ddT]
+derrec_adm [definition, in General.ddT]
+derrec_adm' [lemma, in General.ddT]
+derrec_all_rect2_nops [definition, in General.ddT]
+derrec_all_rect2 [lemma, in General.ddT]
+derrec_nil_derl [definition, in General.ddT]
+derrec_nil_derl_s [lemma, in General.ddT]
+derrec_derl_deriv [definition, in General.ddT]
+derrec_derl_deriv' [lemma, in General.ddT]
+derrec_rmono [definition, in General.ddT]
+derrec_rmono_s [lemma, in General.ddT]
+derrec_trans_imp [lemma, in General.ddT]
+derrec_same_nsR [lemma, in General.ddT]
+derrec_same_nsL [lemma, in General.ddT]
+derrec_same [lemma, in General.ddT]
+derrec_derrec [definition, in General.ddT]
+derrec_derrec' [lemma, in General.ddT]
+derrec_all_rect [lemma, in General.ddT]
+derrec_all_indT [lemma, in General.ddT]
+derrec_all_ind [lemma, in General.ddT]
+derrec_dersrec_rect_mut [definition, in General.ddT]
+derrec_ind_mut [definition, in General.ddT]
+derrec_rec_mut [definition, in General.ddT]
+derrec_rect_mut [definition, in General.ddT]
+derrec_sind [definition, in General.ddT]
+derrec_rec [definition, in General.ddT]
+derrec_ind [definition, in General.ddT]
+derrec_rect [definition, in General.ddT]
+derrec_height_False_ge_1 [lemma, in GL.GLS.GLS_inv_ImpR_ImpL]
+derrec_height_False_ge_1 [lemma, in K.KS.KS_inv_ImpR_ImpL]
+derscl_all_dercl [lemma, in General.ddT]
+dersl [inductive, in General.ddT]
+dersl_fst_ext_rls' [definition, in General.gen_seq]
+dersl_seqrule' [definition, in General.gen_seq]
+dersl_height [definition, in General.dd_fc]
+dersl_adm [definition, in General.ddT]
+dersl_mono [definition, in General.ddT]
+dersl_mono' [definition, in General.ddT]
+dersl_deriv [definition, in General.ddT]
+dersl_deriv' [definition, in General.ddT]
+dersl_trans_alt [lemma, in General.ddT]
+dersl_trans [definition, in General.ddT]
+dersl_app_eq [lemma, in General.ddT]
+dersl_cons [lemma, in General.ddT]
+dersl_dersrec_nil [lemma, in General.ddT]
+dersl_dersrec_trans [definition, in General.ddT]
+dersl_all_derl' [lemma, in General.ddT]
+dersl_all_derl [lemma, in General.ddT]
+dersl_rect_mut [definition, in General.ddT]
+dersl_rec_mut [definition, in General.ddT]
+dersl_ind_mut [definition, in General.ddT]
+dersl_sind [definition, in General.ddT]
+dersl_rec [definition, in General.ddT]
+dersl_ind [definition, in General.ddT]
+dersl_rect [definition, in General.ddT]
+dersrec [inductive, in General.ddT]
+dersrecD_forall_in_dersrec [lemma, in General.dd_fc]
+dersrecD_forall [definition, in General.ddT]
+dersrecD_all [definition, in General.ddT]
+dersrecI_forall [definition, in General.ddT]
+dersrecI_all [definition, in General.ddT]
+dersrec_derrec_height_le [lemma, in General.dd_fc]
+dersrec_derrec2_dp [lemma, in General.dd_fc]
+dersrec_derrec_dp [lemma, in General.dd_fc]
+dersrec_derrec2_height [lemma, in General.dd_fc]
+dersrec_derrec_height [lemma, in General.dd_fc]
+dersrec_double_verb [lemma, in General.dd_fc]
+dersrec_trees_concls_eq [lemma, in General.dd_fc]
+dersrec_fc_height [definition, in General.dd_fc]
+dersrec_fc_size [definition, in General.dd_fc]
+dersrec_fc_concls [definition, in General.dd_fc]
+dersrec_trees [definition, in General.dd_fc]
+dersrec_fcs_sind [definition, in General.dd_fc]
+dersrec_fcs_rec [definition, in General.dd_fc]
+dersrec_fcs_ind [definition, in General.dd_fc]
+dersrec_fcs_rect [definition, in General.dd_fc]
+dersrec_fcs [inductive, in General.dd_fc]
+dersrec_height_le [lemma, in General.dd_fc]
+dersrec_height_nil [lemma, in General.dd_fc]
+dersrec_tl_eq [lemma, in General.dd_fc]
+dersrec_hd_eq [lemma, in General.dd_fc]
+dersrec_single' [definition, in General.dd_fc]
+dersrec_singleI' [definition, in General.dd_fc]
+dersrec_singleD' [definition, in General.dd_fc]
+dersrec_tl [definition, in General.dd_fc]
+dersrec_hd [definition, in General.dd_fc]
+dersrec_concls [definition, in General.dd_fc]
+dersrec_size [definition, in General.dd_fc]
+dersrec_height [definition, in General.dd_fc]
+dersrec_doubleD [definition, in General.ddT]
+dersrec_double [lemma, in General.ddT]
+dersrec_adm [definition, in General.ddT]
+dersrec_nil_dersl [definition, in General.ddT]
+dersrec_derl_deriv [definition, in General.ddT]
+dersrec_rmono [definition, in General.ddT]
+dersrec_map_2 [lemma, in General.ddT]
+dersrec_map_single [lemma, in General.ddT]
+dersrec_singleI [definition, in General.ddT]
+dersrec_singleD [definition, in General.ddT]
+dersrec_single [lemma, in General.ddT]
+dersrec_appI [definition, in General.ddT]
+dersrec_appJ [definition, in General.ddT]
+dersrec_appR [definition, in General.ddT]
+dersrec_appL [definition, in General.ddT]
+dersrec_appD [definition, in General.ddT]
+dersrec_app [lemma, in General.ddT]
+dersrec_nil [lemma, in General.ddT]
+dersrec_forall [lemma, in General.ddT]
+dersrec_all [lemma, in General.ddT]
+dersrec_derrec [definition, in General.ddT]
+dersrec_ind_mut [definition, in General.ddT]
+dersrec_rec_mut [definition, in General.ddT]
+dersrec_rect_mut [definition, in General.ddT]
+dersrec_sind [definition, in General.ddT]
+dersrec_rec [definition, in General.ddT]
+dersrec_ind [definition, in General.ddT]
+dersrec_rect [definition, in General.ddT]
+ders_ders_fcs [lemma, in General.dd_fc]
+ders_concls_eq [lemma, in General.dd_fc]
+der_s_inhabited [lemma, in GL.GLS.GLS_der_dec]
+der_s_inhabited [lemma, in K.KS.KS_termination_prelims]
+der_trf_ht [lemma, in General.gstep]
+der_trf_rtc [lemma, in General.gstep]
+der_trf [lemma, in General.gstep]
+der_trf_derl' [definition, in General.gstep]
+der_trf_derl [lemma, in General.gstep]
+der_trf_rc [lemma, in General.gstep]
+der_trf_rc_derl [lemma, in General.gstep]
+der_trf_rc_adm [lemma, in General.gstep]
+der_botRule [lemma, in General.dd_fc]
+der_der_fc [lemma, in General.dd_fc]
+der_botr_ps_eq [lemma, in General.dd_fc]
+der_fc_concl_eq [lemma, in General.dd_fc]
+der_concl_eq [lemma, in General.dd_fc]
+der_botr_ps [definition, in General.dd_fc]
+Diam [definition, in Syntax.CML_Syntax]
+DiamL_lim [lemma, in K.Interpolation.UIK_UI_prelims]
+DiamL_lim [lemma, in GL.Interpolation.UIGL_UI_prelims]
+Diam_help [section, in K.Interpolation.UIK_UI_prelims]
+Diam_rec_UI_imp [lemma, in GL.Interpolation.UIGL_Diam_N_imp_UI]
+Diam_help [section, in GL.Interpolation.UIGL_UI_prelims]
+Diam_rec_UI [lemma, in GL.Interpolation.UIGL_UIDiam_N]
+difference_include [lemma, in ISL.Environments]
+difference_singleton [lemma, in ISL.Environments]
+diff_not_in [lemma, in ISL.Environments]
+diff_mult [lemma, in ISL.Environments]
+dim_all8 [definition, in General.ddT]
+dim_all4 [definition, in General.ddT]
+dim_all3 [definition, in General.ddT]
+dim_allT [definition, in General.ddT]
+dim_all [definition, in General.ddT]
+disjunction [definition, in ISL.Environments]
+disjunction_R [lemma, in ISL.Optimizations]
+disjunction_L [lemma, in ISL.Optimizations]
+dlCons [constructor, in General.ddT]
+dlCons_inj [lemma, in General.gstep]
+dlNil [constructor, in General.ddT]
+DLW_wf_lex [library]
+double_remove [lemma, in Syntax.remove_list_lems]
+double_negation_obviously_smaller [lemma, in ISL.Optimizations]
+dp [definition, in General.dd_fc]
+dpI [constructor, in General.ddT]
+dp_get_D [lemma, in General.dd_fc]
+dp_same_fun [lemma, in General.dd_fc]
+dp_same [lemma, in General.dd_fc]
+drl_allT' [definition, in General.ddT]
+drl_allT [definition, in General.ddT]
+drsl_allT' [definition, in General.ddT]
+drsl_allT [definition, in General.ddT]
+drs_trees_height [lemma, in General.dd_fc]
+dtcCons [constructor, in General.ddT]
+dtcderI [constructor, in General.ddT]
+dtcNil [constructor, in General.ddT]
+dtCons [constructor, in General.ddT]
+dtCons_eq [lemma, in General.ddT]
+dtderI [constructor, in General.ddT]
+dtNil [constructor, in General.ddT]
+dt2fun [definition, in General.gentree]
+

E

+E [definition, in ISL.PropQuantifiers]
+EA [definition, in ISL.PropQuantifiers]
+EA_vars [lemma, in ISL.PropQuantifiers]
+EA_eq [lemma, in ISL.PropQuantifiers]
+Ef [definition, in ISL.PropQuantifiers]
+effective_remove_nth [lemma, in GL.GLS.GLS_der_dec]
+effective_remove_nth [lemma, in K.KS.KS_termination_prelims]
+elements_elem_of [lemma, in ISL.Order]
+elements_open_boxes [lemma, in ISL.Environments]
+elements_env_add [lemma, in ISL.Environments]
+elem_of_list_In_1 [lemma, in ISL.Order]
+elem_of_open_boxes [lemma, in ISL.Environments]
+empty [inductive, in General.genT]
+empty [definition, in ISL.Environments]
+emptyT [inductive, in General.genT]
+emptyT_any [lemma, in General.genT]
+emptyT_any' [lemma, in General.genT]
+emptyT_sind [definition, in General.genT]
+emptyT_rec [definition, in General.genT]
+emptyT_ind [definition, in General.genT]
+emptyT_rect [definition, in General.genT]
+empty_seq_dec [definition, in K.Interpolation.UIK_basics]
+empty_seq [section, in K.Interpolation.UIK_basics]
+empty_seq_dec [definition, in GL.Interpolation.UIGL_LexSeq]
+empty_seq [section, in GL.Interpolation.UIGL_LexSeq]
+empty_False [lemma, in General.genT]
+empty_explosion [lemma, in General.genT]
+empty_sind [definition, in General.genT]
+empty_rec [definition, in General.genT]
+empty_ind [definition, in General.genT]
+empty_rect [definition, in General.genT]
+empty_relT_sind [definition, in General.genT]
+empty_relT_rec [definition, in General.genT]
+empty_relT_ind [definition, in General.genT]
+empty_relT_rect [definition, in General.genT]
+empty_relT [inductive, in General.genT]
+entail_correct [lemma, in ISL.PropQuantifiers]
+env [definition, in ISL.Environments]
+Environments [library]
+env_order_le_lt_trans [lemma, in ISL.Order]
+env_order_lt_le_trans [lemma, in ISL.Order]
+env_order_eq_add [lemma, in ISL.Order]
+env_order_cancel_right [lemma, in ISL.Order]
+env_order_4 [lemma, in ISL.Order]
+env_order_3 [lemma, in ISL.Order]
+env_order_2 [lemma, in ISL.Order]
+env_order_0 [lemma, in ISL.Order]
+env_order_disj_union_compat_strong_left [lemma, in ISL.Order]
+env_order_disj_union_compat_strong_right [lemma, in ISL.Order]
+env_order_refl_disj_union_compat [lemma, in ISL.Order]
+env_order_disj_union_compat [lemma, in ISL.Order]
+env_order_disj_union_compat_right [lemma, in ISL.Order]
+env_order_disj_union_compat_left [lemma, in ISL.Order]
+env_order_add_compat [lemma, in ISL.Order]
+env_order_compat' [lemma, in ISL.Order]
+env_order_compat [lemma, in ISL.Order]
+env_order_1 [lemma, in ISL.Order]
+env_order_equiv_left_compat [lemma, in ISL.Order]
+env_order_equiv_right_compat [lemma, in ISL.Order]
+env_order_trans [instance, in ISL.Order]
+env_order_refl [definition, in ISL.Order]
+env_order_singleton [lemma, in ISL.Order]
+env_weight_singleton [lemma, in ISL.Order]
+env_order [definition, in ISL.Order]
+env_weight_add [lemma, in ISL.Order]
+env_weight_disj_union [lemma, in ISL.Order]
+env_weight [definition, in ISL.Order]
+env_equiv_eq [lemma, in ISL.Environments]
+env_add_inv' [lemma, in ISL.Environments]
+env_add_inv [lemma, in ISL.Environments]
+env_add_comm [lemma, in ISL.Environments]
+env_in_add [lemma, in ISL.Environments]
+env_add_remove [lemma, in ISL.Environments]
+env_replace [lemma, in ISL.Environments]
+equiv_assoc [instance, in ISL.Environments]
+equiv_disj_union_compat_r [lemma, in ISL.Environments]
+eq_dec_form [lemma, in Syntax.CML_Syntax]
+eq_TrueI [lemma, in General.gen]
+eq_nnn_app [definition, in General.List_lemmasT]
+eq_app_canc2 [lemma, in General.List_lemmasT]
+eq_app_canc1 [lemma, in General.List_lemmasT]
+eq_dec_seqs [definition, in Syntax.list_lems]
+eq_dec_listsF [definition, in Syntax.list_lems]
+eq_S_F [lemma, in General.genT]
+ExcClosure [inductive, in GL.GLS.GLS_exch]
+ExcClosure [inductive, in K.KS.KS_exch]
+ExcClosure_sind [definition, in GL.GLS.GLS_exch]
+ExcClosure_rec [definition, in GL.GLS.GLS_exch]
+ExcClosure_ind [definition, in GL.GLS.GLS_exch]
+ExcClosure_rect [definition, in GL.GLS.GLS_exch]
+ExcClosure_sind [definition, in K.KS.KS_exch]
+ExcClosure_rec [definition, in K.KS.KS_exch]
+ExcClosure_ind [definition, in K.KS.KS_exch]
+ExcClosure_rect [definition, in K.KS.KS_exch]
+exchL_std_rule [lemma, in General.gen_seq]
+exchR_std_rule [lemma, in General.gen_seq]
+ExFalso [constructor, in ISL.Sequents]
+exfalso [lemma, in ISL.SequentProps]
+existsT [library]
+exists_prems_InT_list_of_premises [lemma, in K.KS.KS_termination]
+exists_prems_InT_list_of_premises [lemma, in GL.GLS.GLS_der_dec]
+exists_dec [definition, in ISL.DecisionProcedure]
+existT_inj' [lemma, in General.gstep]
+existT_inj [lemma, in General.gstep]
+ex1 [definition, in ISL.Simp]
+ex2 [definition, in ISL.Simp]
+ex3 [definition, in ISL.Simp]
+ex4 [definition, in ISL.Simp]
+ex5 [definition, in ISL.Simp]
+ex6 [definition, in ISL.Simp]
+E_simplified [definition, in ISL.Simp]
+E_of_empty [lemma, in ISL.PropQuantifiers]
+E_left [lemma, in ISL.PropQuantifiers]
+E_irr [lemma, in ISL.PropQuantifiers]
+e_rule_vars [lemma, in ISL.PropQuantifiers]
+E_eq [definition, in ISL.PropQuantifiers]
+e_rule_cong_strong [lemma, in ISL.PropQuantifiers]
+e_rule_cong [lemma, in ISL.PropQuantifiers]
+e_rule [definition, in ISL.PropQuantifiers]
+

F

+false_or [lemma, in General.gen]
+False_empty [lemma, in General.genT]
+fce3 [definition, in General.ddT]
+fcI [constructor, in General.dd_fc]
+fcI_inj [lemma, in General.dd_fc]
+fcsI [constructor, in General.dd_fc]
+fer_mono [lemma, in General.gen_seq]
+fextI [constructor, in General.gen_seq]
+fextI_eqc' [definition, in General.gen_seq]
+fextI_eq' [lemma, in General.gen_seq]
+fextI' [definition, in General.gen_seq]
+fext_e [lemma, in General.gen_seq]
+find_the_max_mhd [lemma, in K.KS.KS_termination]
+finite_premises_of_S [lemma, in K.KS.KS_termination]
+finite_premises_of_S [definition, in GL.GLS.GLS_der_dec]
+finite_BotL_premises_of_S [definition, in GL.GLS.GLS_der_dec]
+finite_IdB_premises_of_S [definition, in GL.GLS.GLS_der_dec]
+finite_IdP_premises_of_S [definition, in GL.GLS.GLS_der_dec]
+finite_GLR_premises_of_S [definition, in GL.GLS.GLS_der_dec]
+finite_ImpL_premises_of_S [definition, in GL.GLS.GLS_der_dec]
+finite_ImpR_premises_of_S [definition, in GL.GLS.GLS_der_dec]
+finite_KR_premises_of_S [definition, in K.KS.KS_termination_KR]
+finite_ImpL_premises_of_S [definition, in K.KS.KS_termination_ImpL]
+finite_ImpRules_premises_of_S [lemma, in GL.Interpolation.UIGL_Canopy]
+finite_ImpR_premises_of_S [definition, in K.KS.KS_termination_ImpR]
+finite_BotL_premises_of_S [lemma, in K.KS.KS_termination_init]
+finite_IdP_premises_of_S [lemma, in K.KS.KS_termination_init]
+finite_ImpRules_premises_of_S [lemma, in K.Interpolation.UIK_Canopy]
+fixpoint_nodup [lemma, in GL.Interpolation.UIGL_nodupseq]
+fixpoint_nodupseq [lemma, in GL.Interpolation.UIGL_nodupseq]
+flatmap [definition, in K.Interpolation.UIK_irred_short]
+flatmap [section, in K.Interpolation.UIK_irred_short]
+flatmap [definition, in GL.Interpolation.UIGL_irred_short]
+flatmap [section, in GL.Interpolation.UIGL_irred_short]
+flatmap.D [variable, in K.Interpolation.UIK_irred_short]
+flatmap.D [variable, in GL.Interpolation.UIGL_irred_short]
+flatmap.f [variable, in K.Interpolation.UIK_irred_short]
+flatmap.F [variable, in K.Interpolation.UIK_irred_short]
+flatmap.f [variable, in GL.Interpolation.UIGL_irred_short]
+flatmap.F [variable, in GL.Interpolation.UIGL_irred_short]
+flatmap.g [variable, in K.Interpolation.UIK_irred_short]
+flatmap.g [variable, in GL.Interpolation.UIGL_irred_short]
+flatmap.Hg [variable, in K.Interpolation.UIK_irred_short]
+flatmap.Hg [variable, in GL.Interpolation.UIGL_irred_short]
+flatmap.X [variable, in K.Interpolation.UIK_irred_short]
+flatmap.X [variable, in GL.Interpolation.UIGL_irred_short]
+flatten_list [definition, in GL.GLS.GLS_der_dec]
+flatten_list [definition, in K.KS.KS_termination_prelims]
+fmlsext [definition, in General.gen_seq]
+fmlsext_def [lemma, in General.gen_seq]
+fmlsext_fmlsext [lemma, in General.gen_seq]
+fold_Canopy [lemma, in GL.Interpolation.UIGL_Canopy]
+fold_Canopy [lemma, in K.Interpolation.UIK_Canopy]
+fomula_bottom [instance, in ISL.Formulas]
+ForallT [inductive, in General.genT]
+ForallTD_forall [definition, in General.genT]
+ForallTI_forall [definition, in General.genT]
+ForallT_Forall [lemma, in General.genT]
+ForallT_Forall' [lemma, in General.genT]
+ForallT_forall [lemma, in General.genT]
+ForallT_impl [lemma, in General.genT]
+ForallT_2I [definition, in General.genT]
+ForallT_2I' [definition, in General.genT]
+ForallT_D2 [definition, in General.genT]
+ForallT_D1 [definition, in General.genT]
+ForallT_2D [definition, in General.genT]
+ForallT_map_rev [lemma, in General.genT]
+ForallT_map [lemma, in General.genT]
+ForallT_map_2 [lemma, in General.genT]
+ForallT_2 [lemma, in General.genT]
+ForallT_appendI [definition, in General.genT]
+ForallT_appendI' [definition, in General.genT]
+ForallT_appendD2 [definition, in General.genT]
+ForallT_appendD1 [definition, in General.genT]
+ForallT_appendD [definition, in General.genT]
+ForallT_append [lemma, in General.genT]
+ForallT_cons_iff [lemma, in General.genT]
+ForallT_singleI [definition, in General.genT]
+ForallT_singleD [definition, in General.genT]
+ForallT_single [lemma, in General.genT]
+ForallT_cons_inv [lemma, in General.genT]
+ForallT_inv [lemma, in General.genT]
+ForallT_sind [definition, in General.genT]
+ForallT_rec [definition, in General.genT]
+ForallT_ind [definition, in General.genT]
+ForallT_rect [definition, in General.genT]
+ForallT_cons [constructor, in General.genT]
+ForallT_nil [constructor, in General.genT]
+forall_elem_list [lemma, in GL.GLS.GLS_der_dec]
+Forall_map_2 [lemma, in General.gen]
+Forall_map_single [lemma, in General.gen]
+Forall_single [lemma, in General.gen]
+Forall_append [lemma, in General.gen]
+Forall_cons_iff [lemma, in General.gen]
+Forall_cons_inv [lemma, in General.gen]
+Forall_ForallT' [lemma, in General.genT]
+Forall_ForallT [lemma, in General.genT]
+Forall2T [inductive, in General.genT]
+Forall2T_ex_r [lemma, in General.genT]
+Forall2T_ex_l [lemma, in General.genT]
+Forall2T_app [lemma, in General.genT]
+Forall2T_app_inv_r [lemma, in General.genT]
+Forall2T_app_inv_l [lemma, in General.genT]
+Forall2T_sind [definition, in General.genT]
+Forall2T_rec [definition, in General.genT]
+Forall2T_ind [definition, in General.genT]
+Forall2T_rect [definition, in General.genT]
+Forall2T_cons [constructor, in General.genT]
+Forall2T_nil [constructor, in General.genT]
+form [inductive, in ISL.Formulas]
+Formulas [library]
+form_of_MPropF [definition, in UIML_extraction.UIML_extraction]
+form_order [definition, in ISL.Formulas]
+form_count [instance, in ISL.Formulas]
+form_to_gen_tree [definition, in ISL.Formulas]
+form_eq_dec [instance, in ISL.Formulas]
+form_top [instance, in ISL.Formulas]
+form_sind [definition, in ISL.Formulas]
+form_rec [definition, in ISL.Formulas]
+form_ind [definition, in ISL.Formulas]
+form_rect [definition, in ISL.Formulas]
+fst_rel_sind [definition, in General.gen_seq]
+fst_rel_rec [definition, in General.gen_seq]
+fst_rel_ind [definition, in General.gen_seq]
+fst_rel_rect [definition, in General.gen_seq]
+fst_relI [constructor, in General.gen_seq]
+fst_rel [inductive, in General.gen_seq]
+fst_ext_rls_derl_fst_ext_rls' [definition, in General.gen_seq]
+fst_ext_rls_derl_fst_ext_rls [lemma, in General.gen_seq]
+fst_ext_rls_fst_ext_rls' [definition, in General.gen_seq]
+fst_ext_rls_fst_ext_rls [lemma, in General.gen_seq]
+fst_snd_ext [lemma, in General.gen_seq]
+fst_ext_rls_sind [definition, in General.gen_seq]
+fst_ext_rls_rec [definition, in General.gen_seq]
+fst_ext_rls_ind [definition, in General.gen_seq]
+fst_ext_rls_rect [definition, in General.gen_seq]
+fst_ext_rls [inductive, in General.gen_seq]
+fun_cong [lemma, in General.gen]
+

G

+gen [library]
+generalised_contraction [lemma, in ISL.SequentProps]
+generalised_axiom [lemma, in ISL.SequentProps]
+generalised_weakeningR [lemma, in ISL.SequentProps]
+generalised_weakeningL [lemma, in ISL.SequentProps]
+general_export [library]
+genT [library]
+gentree [library]
+gen_step_lem' [lemma, in General.gstep]
+gen_step2s_lem [definition, in General.gstep]
+gen_step2s_lem_ps [lemma, in General.gstep]
+gen_steps_lem [definition, in General.gstep]
+gen_steps_lem_ps [lemma, in General.gstep]
+gen_step2s [definition, in General.gstep]
+gen_steps [definition, in General.gstep]
+gen_step2_lemT [definition, in General.gstep]
+gen_step2_lem [definition, in General.gstep]
+gen_step2_lem_psT [lemma, in General.gstep]
+gen_step2_lem_ps [lemma, in General.gstep]
+gen_step_lemT [definition, in General.gstep]
+gen_step_lem [definition, in General.gstep]
+gen_step_lem_ps [lemma, in General.gstep]
+gen_step_lem_psT [lemma, in General.gstep]
+gen_step2_empty [definition, in General.gstep]
+gen_step2_sub_mono [lemma, in General.gstep]
+gen_step2 [definition, in General.gstep]
+gen_step'_sind [definition, in General.gstep]
+gen_step'_rec [definition, in General.gstep]
+gen_step'_ind [definition, in General.gstep]
+gen_step'_rect [definition, in General.gstep]
+gen_step' [inductive, in General.gstep]
+gen_step_def [lemma, in General.gstep]
+gen_step_sub_mono [lemma, in General.gstep]
+gen_step [definition, in General.gstep]
+gen_ext_add_elem_deep [lemma, in General.univ_gen_ext]
+gen_ext_elem_deep [lemma, in General.univ_gen_ext]
+gen_ext_delet_hd [lemma, in General.univ_gen_ext]
+gen_ext_diff [definition, in General.univ_gen_ext]
+gen_ext_diff' [lemma, in General.univ_gen_ext]
+gen_ext_InT [lemma, in General.univ_gen_ext]
+gen_ext_one [definition, in General.univ_gen_ext]
+gen_ext_one' [lemma, in General.univ_gen_ext]
+gen_ext_single [lemma, in General.univ_gen_ext]
+gen_ext_same_hd [lemma, in General.univ_gen_ext]
+gen_ext_combine [lemma, in General.univ_gen_ext]
+gen_ext_splitR [lemma, in General.univ_gen_ext]
+gen_ext_splitL [lemma, in General.univ_gen_ext]
+gen_ext_lem [lemma, in General.univ_gen_ext]
+gen_ext_sameR [definition, in General.univ_gen_ext]
+gen_ext_sameL [definition, in General.univ_gen_ext]
+gen_ext_app [lemma, in General.univ_gen_ext]
+gen_ext_trans [lemma, in General.univ_gen_ext]
+gen_ext_nil_any [lemma, in General.univ_gen_ext]
+gen_ext_appR [lemma, in General.univ_gen_ext]
+gen_ext_appL [lemma, in General.univ_gen_ext]
+gen_ext_refl [lemma, in General.univ_gen_ext]
+gen_ext [definition, in General.univ_gen_ext]
+gen_step2_tr_lem [lemma, in General.gentree]
+gen_step2_c_lem [lemma, in General.gentree]
+gen_step2_c [definition, in General.gentree]
+gen_step2_tr [definition, in General.gentree]
+gen_step_tr_lem [lemma, in General.gentree]
+gen_step_c_lem [lemma, in General.gentree]
+gen_step_c [definition, in General.gentree]
+gen_step_tr [definition, in General.gentree]
+gen_cong [lemma, in General.gen]
+gen_rec_UI_imp [lemma, in GL.Interpolation.UIGL_N_imp_UI]
+gen_tree_to_form [definition, in ISL.Formulas]
+gen_tacs [library]
+gen_seq [library]
+get_dpD [definition, in General.dd_fc]
+get_D [definition, in General.dd_fc]
+get_botrule [lemma, in General.dd_fc]
+Gflatmap [inductive, in K.Interpolation.UIK_irred_short]
+Gflatmap [inductive, in GL.Interpolation.UIGL_irred_short]
+Gflatmap_flat_map [lemma, in K.Interpolation.UIK_irred_short]
+Gflatmap_app_inv_left [lemma, in K.Interpolation.UIK_irred_short]
+Gflatmap_inv_sg_left [lemma, in K.Interpolation.UIK_irred_short]
+Gflatmap_inv_left [lemma, in K.Interpolation.UIK_irred_short]
+Gflatmap_sind [definition, in K.Interpolation.UIK_irred_short]
+Gflatmap_ind [definition, in K.Interpolation.UIK_irred_short]
+Gflatmap_flat_map [lemma, in GL.Interpolation.UIGL_irred_short]
+Gflatmap_app_inv_left [lemma, in GL.Interpolation.UIGL_irred_short]
+Gflatmap_inv_sg_left [lemma, in GL.Interpolation.UIGL_irred_short]
+Gflatmap_inv_left [lemma, in GL.Interpolation.UIGL_irred_short]
+Gflatmap_sind [definition, in GL.Interpolation.UIGL_irred_short]
+Gflatmap_ind [definition, in GL.Interpolation.UIGL_irred_short]
+Gfm_cons [constructor, in K.Interpolation.UIK_irred_short]
+Gfm_nil [constructor, in K.Interpolation.UIK_irred_short]
+Gfm_cons [constructor, in GL.Interpolation.UIGL_irred_short]
+Gfm_nil [constructor, in GL.Interpolation.UIGL_irred_short]
+gf_step2_tr_lem [lemma, in General.gentree]
+gf_step2_tr [definition, in General.gentree]
+gf2_sum [lemma, in General.gentree]
+gf2_step_tr_lem [lemma, in General.gentree]
+gf2_step_tr [definition, in General.gentree]
+Gimap [inductive, in K.Interpolation.UIK_braga]
+Gimap [inductive, in GL.Interpolation.UIGL_braga]
+Gimap_fun_rest [lemma, in K.Interpolation.UIK_braga]
+Gimap_cont.f [variable, in K.Interpolation.UIK_braga]
+Gimap_cont.D [variable, in K.Interpolation.UIK_braga]
+Gimap_cont.F [variable, in K.Interpolation.UIK_braga]
+Gimap_cont.Y [variable, in K.Interpolation.UIK_braga]
+Gimap_cont.X [variable, in K.Interpolation.UIK_braga]
+Gimap_cont [section, in K.Interpolation.UIK_braga]
+Gimap_fun [lemma, in K.Interpolation.UIK_braga]
+Gimap_map [lemma, in K.Interpolation.UIK_braga]
+Gimap_app_inv_left [lemma, in K.Interpolation.UIK_braga]
+Gimap_inv_sg_left [lemma, in K.Interpolation.UIK_braga]
+Gimap_inv_left [lemma, in K.Interpolation.UIK_braga]
+Gimap_sind [definition, in K.Interpolation.UIK_braga]
+Gimap_ind [definition, in K.Interpolation.UIK_braga]
+Gimap_fun_rest [lemma, in GL.Interpolation.UIGL_braga]
+Gimap_cont.f [variable, in GL.Interpolation.UIGL_braga]
+Gimap_cont.D [variable, in GL.Interpolation.UIGL_braga]
+Gimap_cont.F [variable, in GL.Interpolation.UIGL_braga]
+Gimap_cont.Y [variable, in GL.Interpolation.UIGL_braga]
+Gimap_cont.X [variable, in GL.Interpolation.UIGL_braga]
+Gimap_cont [section, in GL.Interpolation.UIGL_braga]
+Gimap_fun [lemma, in GL.Interpolation.UIGL_braga]
+Gimap_map [lemma, in GL.Interpolation.UIGL_braga]
+Gimap_app_inv_left [lemma, in GL.Interpolation.UIGL_braga]
+Gimap_inv_sg_left [lemma, in GL.Interpolation.UIGL_braga]
+Gimap_inv_left [lemma, in GL.Interpolation.UIGL_braga]
+Gimap_sind [definition, in GL.Interpolation.UIGL_braga]
+Gimap_ind [definition, in GL.Interpolation.UIGL_braga]
+Gim_cons [constructor, in K.Interpolation.UIK_braga]
+Gim_nil [constructor, in K.Interpolation.UIK_braga]
+Gim_cons [constructor, in GL.Interpolation.UIGL_braga]
+Gim_nil [constructor, in GL.Interpolation.UIGL_braga]
+Girred [inductive, in K.Interpolation.UIK_irred_short]
+Girred [inductive, in GL.Interpolation.UIGL_irred_short]
+Girred_fun [lemma, in K.Interpolation.UIK_irred_short]
+Girred_ind [definition, in K.Interpolation.UIK_irred_short]
+Girred_inv_not [lemma, in K.Interpolation.UIK_irred_short]
+Girred_inv_nil [lemma, in K.Interpolation.UIK_irred_short]
+Girred_not [constructor, in K.Interpolation.UIK_irred_short]
+Girred_nil [constructor, in K.Interpolation.UIK_irred_short]
+Girred_fun [lemma, in GL.Interpolation.UIGL_irred_short]
+Girred_ind [definition, in GL.Interpolation.UIGL_irred_short]
+Girred_inv_not [lemma, in GL.Interpolation.UIGL_irred_short]
+Girred_inv_nil [lemma, in GL.Interpolation.UIGL_irred_short]
+Girred_not [constructor, in GL.Interpolation.UIGL_irred_short]
+Girred_nil [constructor, in GL.Interpolation.UIGL_irred_short]
+GLR [constructor, in GL.GLS.GLS_calcs]
+GLRRule [inductive, in GL.GLS.GLS_calcs]
+GLRRule_sind [definition, in GL.GLS.GLS_calcs]
+GLRRule_rec [definition, in GL.GLS.GLS_calcs]
+GLRRule_ind [definition, in GL.GLS.GLS_calcs]
+GLRRule_rect [definition, in GL.GLS.GLS_calcs]
+GLRRule_I [constructor, in GL.GLS.GLS_calcs]
+GLR_help2 [definition, in GL.GLS.GLS_der_dec]
+GLR_help02 [definition, in GL.GLS.GLS_der_dec]
+GLR_help1 [definition, in GL.GLS.GLS_der_dec]
+GLR_help01 [definition, in GL.GLS.GLS_der_dec]
+GLR_app_wkn_R [lemma, in GL.GLS.GLS_wkn]
+GLR_app_wkn_L [lemma, in GL.GLS.GLS_wkn]
+GLR_applic_reduces_measure [lemma, in GL.GLS.GLS_termination_measure]
+GLR_applic_less_usable_boxes [lemma, in GL.GLS.GLS_termination_measure]
+GLR_applic_le_subform_boxes [lemma, in GL.GLS.GLS_termination_measure]
+GLR_applic_more_top_boxes [lemma, in GL.GLS.GLS_termination_measure]
+GLR_app_list_exchR [lemma, in GL.GLS.GLS_exch]
+GLR_app_list_exchL [lemma, in GL.GLS.GLS_exch]
+GLR_prems_less_ub [lemma, in GL.Interpolation.UIGL_LexSeq]
+GLR_prems_LexSeq [lemma, in GL.Interpolation.UIGL_LexSeq]
+GLR_prems [definition, in GL.Interpolation.UIGL_LexSeq]
+GLR_app_ctr_R [lemma, in GL.GLS.GLS_ctr]
+GLR_app_ctr_L [lemma, in GL.GLS.GLS_ctr]
+GLS_cut_adm [lemma, in GL.GLS.GLS_additive_cut]
+GLS_cut_adm_main [lemma, in GL.GLS.GLS_additive_cut]
+GLS_dec_der [lemma, in GL.GLS.GLS_der_dec]
+GLS_drv [definition, in GL.GLS.GLS_calcs]
+GLS_prv [definition, in GL.GLS.GLS_calcs]
+GLS_rules_sind [definition, in GL.GLS.GLS_calcs]
+GLS_rules_rec [definition, in GL.GLS.GLS_calcs]
+GLS_rules_ind [definition, in GL.GLS.GLS_calcs]
+GLS_rules_rect [definition, in GL.GLS.GLS_calcs]
+GLS_rules [inductive, in GL.GLS.GLS_calcs]
+GLS_XBoxed_list_wkn_L [lemma, in GL.GLS.GLS_wkn]
+GLS_prv_list_wkn_L [lemma, in GL.GLS.GLS_wkn]
+GLS_list_wkn_L [lemma, in GL.GLS.GLS_wkn]
+GLS_prv_list_wkn_R [lemma, in GL.GLS.GLS_wkn]
+GLS_list_wkn_R [lemma, in GL.GLS.GLS_wkn]
+GLS_prv_wkn_R [lemma, in GL.GLS.GLS_wkn]
+GLS_wkn_R [lemma, in GL.GLS.GLS_wkn]
+GLS_prv_wkn_L [lemma, in GL.GLS.GLS_wkn]
+GLS_wkn_L [lemma, in GL.GLS.GLS_wkn]
+GLS_cut_elimination [lemma, in GL.GLS.GLS_cut_elim]
+GLS_cut_drv [definition, in GL.GLS.GLS_cut_elim]
+GLS_cut_prv [definition, in GL.GLS.GLS_cut_elim]
+GLS_cut_rules_sind [definition, in GL.GLS.GLS_cut_elim]
+GLS_cut_rules_rec [definition, in GL.GLS.GLS_cut_elim]
+GLS_cut_rules_ind [definition, in GL.GLS.GLS_cut_elim]
+GLS_cut_rules_rect [definition, in GL.GLS.GLS_cut_elim]
+GLS_woc [constructor, in GL.GLS.GLS_cut_elim]
+GLS_cut_rules [inductive, in GL.GLS.GLS_cut_elim]
+GLS_adm_list_exch_LR [lemma, in GL.GLS.GLS_exch]
+GLS_hpadm_list_exch_L [lemma, in GL.GLS.GLS_exch]
+GLS_hpadm_list_exch_R [lemma, in GL.GLS.GLS_exch]
+GLS_der_list_exch_R [lemma, in GL.GLS.GLS_exch]
+GLS_der_list_exch_L [lemma, in GL.GLS.GLS_exch]
+GLS_adm_list_exch_R [lemma, in GL.GLS.GLS_exch]
+GLS_adm_list_exch_L [lemma, in GL.GLS.GLS_exch]
+GLS_hpadm_list_ctr_R [lemma, in GL.GLS.GLS_ctr]
+GLS_hpadm_list_ctr_L [lemma, in GL.GLS.GLS_ctr]
+GLS_hpadm_ctr_R [lemma, in GL.GLS.GLS_ctr]
+GLS_hpadm_ctr_L [lemma, in GL.GLS.GLS_ctr]
+GLS_hpadm_ctr_LR [lemma, in GL.GLS.GLS_ctr]
+GLS_wkn [library]
+GLS_dec [library]
+GLS_cut_elim [library]
+GLS_calcs [library]
+GLS_ctr [library]
+GLS_export [library]
+GLS_inv_ImpR_ImpL [library]
+GLS_exch [library]
+GLS_additive_cut [library]
+GLS_der_dec [library]
+GLS_termination_measure [library]
+gl_UI [definition, in UIML_extraction.UIML_extraction]
+gmultiset_elements_list_to_set_disj [lemma, in ISL.Environments]
+gmultiset_rec [lemma, in ISL.Environments]
+gmultiset_choose_or_empty [lemma, in ISL.Environments]
+GN [inductive, in GL.Interpolation.UIGL_braga]
+GN [section, in GL.Interpolation.UIGL_braga]
+GN_inv_noinit_nolessub [lemma, in GL.Interpolation.UIGL_braga]
+GN_inv_noinit_lessub [lemma, in GL.Interpolation.UIGL_braga]
+GN_inv_init [lemma, in GL.Interpolation.UIGL_braga]
+GN_fun0 [lemma, in GL.Interpolation.UIGL_braga]
+GN_fun [lemma, in GL.Interpolation.UIGL_braga]
+GN_inv_noinit_nolessub0 [lemma, in GL.Interpolation.UIGL_braga]
+GN_inv_noinit_lessub0 [lemma, in GL.Interpolation.UIGL_braga]
+GN_inv_init0 [lemma, in GL.Interpolation.UIGL_braga]
+GN_less [constructor, in GL.Interpolation.UIGL_braga]
+GN_less_ub [constructor, in GL.Interpolation.UIGL_braga]
+GN_init_seq [constructor, in GL.Interpolation.UIGL_braga]
+GN.F [variable, in GL.Interpolation.UIGL_braga]
+GN.Ffun [variable, in GL.Interpolation.UIGL_braga]
+GN.p [variable, in GL.Interpolation.UIGL_braga]
+Good_pos_in_pos_top_imps [lemma, in GL.GLS.GLS_der_dec]
+Good_pos_in_pos_top_imps [lemma, in K.KS.KS_termination_ImpR]
+gsc_gstr [lemma, in General.gentree]
+gsI [constructor, in General.gstep]
+gstep [library]
+gstr_gf2 [lemma, in General.gentree]
+gs_gs' [lemma, in General.gstep]
+gs_gsc [lemma, in General.gentree]
+gs2c_gs2tr [lemma, in General.gentree]
+gs2tr_gf2 [lemma, in General.gentree]
+gs2_hs2 [lemma, in General.gentree]
+gs2_tr_height [lemma, in General.gentree]
+gs2_tr_size [lemma, in General.gentree]
+gs2_gs2c [lemma, in General.gentree]
+GUI [inductive, in K.Interpolation.UIK_braga]
+GUI [inductive, in GL.Interpolation.UIGL_braga]
+GUI_inv_critic_not_init [lemma, in K.Interpolation.UIK_braga]
+GUI_inv_not_critic [lemma, in K.Interpolation.UIK_braga]
+GUI_inv_critic_init [lemma, in K.Interpolation.UIK_braga]
+GUI_inv_empty_seq [lemma, in K.Interpolation.UIK_braga]
+GUI_tot [definition, in K.Interpolation.UIK_braga]
+GUI_fun [lemma, in K.Interpolation.UIK_braga]
+GUI_critic_not_init [constructor, in K.Interpolation.UIK_braga]
+GUI_not_critic [constructor, in K.Interpolation.UIK_braga]
+GUI_critic_init [constructor, in K.Interpolation.UIK_braga]
+GUI_empty_seq [constructor, in K.Interpolation.UIK_braga]
+GUI_inv_critic_not_init [lemma, in GL.Interpolation.UIGL_braga]
+GUI_inv_not_critic [lemma, in GL.Interpolation.UIGL_braga]
+GUI_inv_critic_init [lemma, in GL.Interpolation.UIGL_braga]
+GUI_inv_empty_seq [lemma, in GL.Interpolation.UIGL_braga]
+GUI_tot [definition, in GL.Interpolation.UIGL_braga]
+GUI_fun [lemma, in GL.Interpolation.UIGL_braga]
+GUI_critic_not_init [constructor, in GL.Interpolation.UIGL_braga]
+GUI_not_critic [constructor, in GL.Interpolation.UIGL_braga]
+GUI_critic_init [constructor, in GL.Interpolation.UIGL_braga]
+GUI_empty_seq [constructor, in GL.Interpolation.UIGL_braga]
+

H

+height [definition, in ISL.SequentProps]
+height_0 [lemma, in ISL.SequentProps]
+height_step2_tr_lem [lemma, in General.gentree]
+height_step2_tr [definition, in General.gentree]
+hs2_sumh [lemma, in General.gentree]
+

I

+IdBRule [inductive, in GL.GLS.GLS_calcs]
+IdBRule_sind [definition, in GL.GLS.GLS_calcs]
+IdBRule_rec [definition, in GL.GLS.GLS_calcs]
+IdBRule_ind [definition, in GL.GLS.GLS_calcs]
+IdBRule_rect [definition, in GL.GLS.GLS_calcs]
+IdBRule_I [constructor, in GL.GLS.GLS_calcs]
+IdP [constructor, in GL.GLS.GLS_calcs]
+IdP [constructor, in K.KS.KS_calc]
+IdPRule [inductive, in GL.GLS.GLS_calcs]
+IdPRule [inductive, in K.KS.KS_calc]
+IdPRule_sind [definition, in GL.GLS.GLS_calcs]
+IdPRule_rec [definition, in GL.GLS.GLS_calcs]
+IdPRule_ind [definition, in GL.GLS.GLS_calcs]
+IdPRule_rect [definition, in GL.GLS.GLS_calcs]
+IdPRule_I [constructor, in GL.GLS.GLS_calcs]
+IdPRule_sind [definition, in K.KS.KS_calc]
+IdPRule_rec [definition, in K.KS.KS_calc]
+IdPRule_ind [definition, in K.KS.KS_calc]
+IdPRule_rect [definition, in K.KS.KS_calc]
+IdPRule_I [constructor, in K.KS.KS_calc]
+Idrule [inductive, in General.gen_seq]
+Idrule_sind [definition, in General.gen_seq]
+Idrule_rec [definition, in General.gen_seq]
+Idrule_ind [definition, in General.gen_seq]
+Idrule_rect [definition, in General.gen_seq]
+Idrule_I [constructor, in General.gen_seq]
+Id_all_form [lemma, in GL.GLS.GLS_calcs]
+Id_InT_Canopy [definition, in GL.Interpolation.UIGL_Canopy]
+Id_all_form [lemma, in K.KS.KS_calc]
+Id_InT_Canopy [lemma, in K.Interpolation.UIK_Canopy]
+iffD1 [lemma, in General.gen]
+iffD2 [lemma, in General.gen]
+iffT_prod [lemma, in General.genT]
+iffT_D2 [definition, in General.genT]
+iffT_D1 [definition, in General.genT]
+iffT_sym [definition, in General.genT]
+iffT_D2' [lemma, in General.genT]
+iffT_D1' [lemma, in General.genT]
+iffT_refl [lemma, in General.genT]
+iffT_sym' [lemma, in General.genT]
+iffT_trans [lemma, in General.genT]
+if_rev_eq [lemma, in General.List_lemmasT]
+if_eq_rev_eq [lemma, in General.List_lemmasT]
+iGLS_cut [constructor, in GL.GLS.GLS_cut_elim]
+imap [definition, in K.Interpolation.UIK_braga]
+imap [section, in K.Interpolation.UIK_braga]
+imap [definition, in GL.Interpolation.UIGL_braga]
+imap [section, in GL.Interpolation.UIGL_braga]
+imap.D [variable, in K.Interpolation.UIK_braga]
+imap.D [variable, in GL.Interpolation.UIGL_braga]
+imap.f [variable, in K.Interpolation.UIK_braga]
+imap.F [variable, in K.Interpolation.UIK_braga]
+imap.f [variable, in GL.Interpolation.UIGL_braga]
+imap.F [variable, in GL.Interpolation.UIGL_braga]
+imap.Ffun [variable, in K.Interpolation.UIK_braga]
+imap.Ffun [variable, in GL.Interpolation.UIGL_braga]
+imap.g [variable, in K.Interpolation.UIK_braga]
+imap.g [variable, in GL.Interpolation.UIGL_braga]
+imap.Hg [variable, in K.Interpolation.UIK_braga]
+imap.Hg [variable, in GL.Interpolation.UIGL_braga]
+imap.X [variable, in K.Interpolation.UIK_braga]
+imap.X [variable, in GL.Interpolation.UIGL_braga]
+imap.Y [variable, in K.Interpolation.UIK_braga]
+imap.Y [variable, in GL.Interpolation.UIGL_braga]
+Imp [constructor, in Syntax.CML_Syntax]
+ImpBox [constructor, in ISL.Sequents]
+ImpBox_dup [lemma, in ISL.SequentProps]
+ImpL [constructor, in GL.GLS.GLS_calcs]
+ImpL [lemma, in ISL.SequentProps]
+ImpL [constructor, in K.KS.KS_calc]
+ImpLAnd [constructor, in ISL.Sequents]
+ImpLAnd_rev [lemma, in ISL.SequentProps]
+ImpLBox_prev [lemma, in ISL.SequentProps]
+Implies [constructor, in ISL.Formulas]
+ImpLImp [constructor, in ISL.Sequents]
+ImpLImp_dup [lemma, in ISL.SequentProps]
+ImpLImp_prev [lemma, in ISL.SequentProps]
+ImpLOr [constructor, in ISL.Sequents]
+ImpLOr_rev [lemma, in ISL.SequentProps]
+ImpLRule [inductive, in GL.GLS.GLS_calcs]
+ImpLRule [inductive, in K.KS.KS_calc]
+ImpLRule_sind [definition, in GL.GLS.GLS_calcs]
+ImpLRule_rec [definition, in GL.GLS.GLS_calcs]
+ImpLRule_ind [definition, in GL.GLS.GLS_calcs]
+ImpLRule_rect [definition, in GL.GLS.GLS_calcs]
+ImpLRule_I [constructor, in GL.GLS.GLS_calcs]
+ImpLRule_sind [definition, in K.KS.KS_calc]
+ImpLRule_rec [definition, in K.KS.KS_calc]
+ImpLRule_ind [definition, in K.KS.KS_calc]
+ImpLRule_rect [definition, in K.KS.KS_calc]
+ImpLRule_I [constructor, in K.KS.KS_calc]
+ImpLVar [constructor, in ISL.Sequents]
+ImpLVar_rev [lemma, in ISL.SequentProps]
+ImpL_app_ctr_R [lemma, in K.KS.KS_ctr]
+ImpL_app_ctr_L [lemma, in K.KS.KS_ctr]
+ImpL_app_wkn_R [lemma, in K.KS.KS_wkn]
+ImpL_app_wkn_L [lemma, in K.KS.KS_wkn]
+ImpL_help1 [definition, in GL.GLS.GLS_der_dec]
+ImpL_help01 [definition, in GL.GLS.GLS_der_dec]
+ImpL_help2 [definition, in GL.GLS.GLS_der_dec]
+ImpL_help02 [definition, in GL.GLS.GLS_der_dec]
+ImpL_help002 [definition, in GL.GLS.GLS_der_dec]
+ImpL_app_wkn_R [lemma, in GL.GLS.GLS_wkn]
+ImpL_app_wkn_L [lemma, in GL.GLS.GLS_wkn]
+ImpL_help1 [definition, in K.KS.KS_termination_ImpL]
+ImpL_help01 [definition, in K.KS.KS_termination_ImpL]
+ImpL_help2 [definition, in K.KS.KS_termination_ImpL]
+ImpL_help02 [definition, in K.KS.KS_termination_ImpL]
+ImpL_help002 [definition, in K.KS.KS_termination_ImpL]
+ImpL_app_list_exchR [lemma, in K.KS.KS_exch_ImpL]
+ImpL_app_list_exchL [lemma, in K.KS.KS_exch_ImpL]
+ImpL_applic_reduces_measure [lemma, in GL.GLS.GLS_termination_measure]
+ImpL_applic_reduces_ub_or_imp [lemma, in GL.GLS.GLS_termination_measure]
+ImpL_applic_less_Imp_same_usable_boxes [lemma, in GL.GLS.GLS_termination_measure]
+ImpL_inv [lemma, in GL.GLS.GLS_inv_ImpR_ImpL]
+ImpL_app_list_exchR [lemma, in GL.GLS.GLS_exch]
+ImpL_app_list_exchL [lemma, in GL.GLS.GLS_exch]
+ImpL_app_ctr_R [lemma, in GL.GLS.GLS_ctr]
+ImpL_app_ctr_L [lemma, in GL.GLS.GLS_ctr]
+ImpL_inv [lemma, in K.KS.KS_inv_ImpR_ImpL]
+ImpR [constructor, in ISL.Sequents]
+ImpR [constructor, in GL.GLS.GLS_calcs]
+ImpR [constructor, in K.KS.KS_calc]
+ImpRRule [inductive, in GL.GLS.GLS_calcs]
+ImpRRule [inductive, in K.KS.KS_calc]
+ImpRRule_sind [definition, in GL.GLS.GLS_calcs]
+ImpRRule_rec [definition, in GL.GLS.GLS_calcs]
+ImpRRule_ind [definition, in GL.GLS.GLS_calcs]
+ImpRRule_rect [definition, in GL.GLS.GLS_calcs]
+ImpRRule_I [constructor, in GL.GLS.GLS_calcs]
+ImpRRule_sind [definition, in K.KS.KS_calc]
+ImpRRule_rec [definition, in K.KS.KS_calc]
+ImpRRule_ind [definition, in K.KS.KS_calc]
+ImpRRule_rect [definition, in K.KS.KS_calc]
+ImpRRule_I [constructor, in K.KS.KS_calc]
+ImpRule_Canopy [lemma, in GL.Interpolation.UIGL_Canopy]
+ImpRule_Canopy [lemma, in K.Interpolation.UIK_Canopy]
+ImpR_app_ctr_R [lemma, in K.KS.KS_ctr]
+ImpR_app_ctr_L [lemma, in K.KS.KS_ctr]
+ImpR_app_wkn_R [lemma, in K.KS.KS_wkn]
+ImpR_app_wkn_L [lemma, in K.KS.KS_wkn]
+ImpR_help2 [definition, in GL.GLS.GLS_der_dec]
+ImpR_help02 [definition, in GL.GLS.GLS_der_dec]
+ImpR_help002 [definition, in GL.GLS.GLS_der_dec]
+ImpR_help1 [definition, in GL.GLS.GLS_der_dec]
+ImpR_help01 [definition, in GL.GLS.GLS_der_dec]
+ImpR_rev [lemma, in ISL.SequentProps]
+ImpR_app_wkn_R [lemma, in GL.GLS.GLS_wkn]
+ImpR_app_wkn_L [lemma, in GL.GLS.GLS_wkn]
+ImpR_applic_reduces_measure [lemma, in GL.GLS.GLS_termination_measure]
+ImpR_applic_reduces_ub_or_imp [lemma, in GL.GLS.GLS_termination_measure]
+ImpR_applic_less_Imp_same_usable_boxes [lemma, in GL.GLS.GLS_termination_measure]
+ImpR_inv [lemma, in GL.GLS.GLS_inv_ImpR_ImpL]
+ImpR_ImpL_hpinv [lemma, in GL.GLS.GLS_inv_ImpR_ImpL]
+ImpR_app_list_exchR [lemma, in GL.GLS.GLS_exch]
+ImpR_app_list_exchL [lemma, in GL.GLS.GLS_exch]
+ImpR_app_ctr_R [lemma, in GL.GLS.GLS_ctr]
+ImpR_app_ctr_L [lemma, in GL.GLS.GLS_ctr]
+ImpR_help2 [definition, in K.KS.KS_termination_ImpR]
+ImpR_help02 [definition, in K.KS.KS_termination_ImpR]
+ImpR_help002 [definition, in K.KS.KS_termination_ImpR]
+ImpR_help1 [definition, in K.KS.KS_termination_ImpR]
+ImpR_help01 [definition, in K.KS.KS_termination_ImpR]
+ImpR_inv [lemma, in K.KS.KS_inv_ImpR_ImpL]
+ImpR_ImpL_hpinv [lemma, in K.KS.KS_inv_ImpR_ImpL]
+ImpR_app_list_exchR [lemma, in K.KS.KS_exch_ImpR]
+ImpR_app_list_exchL [lemma, in K.KS.KS_exch_ImpR]
+imp_cut [lemma, in ISL.SequentProps]
+incl_idS [lemma, in GL.Interpolation.UIGL_nodupseq]
+incl_id [lemma, in GL.Interpolation.UIGL_nodupseq]
+incl_ctr_R [lemma, in GL.Interpolation.UIGL_nodupseq]
+incl_ctr_R_hpadm [lemma, in GL.Interpolation.UIGL_nodupseq]
+incl_ctr_L [lemma, in GL.Interpolation.UIGL_nodupseq]
+incl_ctr_L_hpadm [lemma, in GL.Interpolation.UIGL_nodupseq]
+incl_nodup_top_boxes [lemma, in GL.Interpolation.UIGL_nodupseq]
+incl_nodupseq_subform_boxesS [lemma, in GL.Interpolation.UIGL_nodupseq]
+incl_nodup_subform_boxesLF [lemma, in GL.Interpolation.UIGL_nodupseq]
+incl_prv [lemma, in GL.Interpolation.UIGL_UI_prelims]
+incl_hpadm_prv [lemma, in GL.Interpolation.UIGL_UI_prelims]
+IndClo [constructor, in GL.GLS.GLS_exch]
+IndClo [constructor, in K.KS.KS_exch]
+IndLExch [constructor, in GL.GLS.GLS_exch]
+IndLExch [constructor, in K.KS.KS_exch]
+IndRExch [constructor, in GL.GLS.GLS_exch]
+IndRExch [constructor, in K.KS.KS_exch]
+inhabited_anon [lemma, in General.genT]
+InitClo [constructor, in GL.GLS.GLS_exch]
+InitClo [constructor, in K.KS.KS_exch]
+InitLExch [constructor, in GL.GLS.GLS_exch]
+InitLExch [constructor, in K.KS.KS_exch]
+InitRExch [constructor, in GL.GLS.GLS_exch]
+InitRExch [constructor, in K.KS.KS_exch]
+InT [inductive, in General.genT]
+InT_seqext [lemma, in General.gen_seq]
+InT_seqextR [lemma, in General.gen_seq]
+InT_seqextL [lemma, in General.gen_seq]
+InT_list_of_premises_exists_prems [lemma, in K.KS.KS_termination]
+InT_In_Seq [lemma, in K.Interpolation.UIK_basics]
+InT_list_of_premises_exists_prems [lemma, in GL.GLS.GLS_der_dec]
+InT_trans_flatten_list [definition, in GL.GLS.GLS_der_dec]
+InT_flatten_list_InT_elem [definition, in GL.GLS.GLS_der_dec]
+InT_map_iff [definition, in GL.GLS.GLS_der_dec]
+InT_trans_flatten_list [definition, in K.KS.KS_termination_prelims]
+InT_flatten_list_InT_elem [definition, in K.KS.KS_termination_prelims]
+InT_map_iff [definition, in K.KS.KS_termination_prelims]
+InT_univ_gen_mod [lemma, in General.univ_gen_mod]
+InT_In_Seq [lemma, in GL.Interpolation.UIGL_basics]
+InT_gen_ext [lemma, in General.univ_gen_ext]
+InT_univ_gen_ext [lemma, in General.univ_gen_ext]
+InT_var_provar [lemma, in K.Interpolation.K_Craig_Interp]
+InT_list_exch_L [lemma, in K.KS.KS_exch_prelims]
+InT_list_exch_R [lemma, in K.KS.KS_exch_prelims]
+InT_flat_map [lemma, in GL.Interpolation.UIGL_Canopy]
+InT_In_inv_prems [lemma, in GL.Interpolation.UIGL_Canopy]
+InT_list_exch_L [lemma, in GL.GLS.GLS_exch]
+InT_list_exch_R [lemma, in GL.GLS.GLS_exch]
+InT_or_app [definition, in General.List_lemmasT]
+InT_app_or [definition, in General.List_lemmasT]
+InT_singleton_mid [lemma, in General.List_lemmasT]
+InT_mid [lemma, in General.List_lemmasT]
+InT_pt_I [lemma, in General.List_lemmasT]
+InT_pair_triple_sind [definition, in General.List_lemmasT]
+InT_pair_triple_rec [definition, in General.List_lemmasT]
+InT_pair_triple_ind [definition, in General.List_lemmasT]
+InT_pair_triple_rect [definition, in General.List_lemmasT]
+InT_pt_tl [constructor, in General.List_lemmasT]
+InT_pt_hd [constructor, in General.List_lemmasT]
+InT_pair_triple [inductive, in General.List_lemmasT]
+InT_dec [lemma, in Syntax.list_lems]
+InT_exch_list [lemma, in Syntax.list_lems]
+InT_In_eq' [lemma, in General.genT]
+InT_In_eq [lemma, in General.genT]
+InT_In' [lemma, in General.genT]
+InT_In [lemma, in General.genT]
+InT_concat [lemma, in General.genT]
+InT_mapI [definition, in General.genT]
+InT_map_iffT [definition, in General.genT]
+InT_mapE [lemma, in General.genT]
+InT_map [lemma, in General.genT]
+InT_inv [lemma, in General.genT]
+InT_split [lemma, in General.genT]
+InT_nilE [lemma, in General.genT]
+InT_nilE' [lemma, in General.genT]
+InT_appE [lemma, in General.genT]
+InT_appE' [lemma, in General.genT]
+InT_appR [lemma, in General.genT]
+InT_appL [lemma, in General.genT]
+InT_2nd [definition, in General.genT]
+InT_eq [definition, in General.genT]
+InT_sind [definition, in General.genT]
+InT_rec [definition, in General.genT]
+InT_ind [definition, in General.genT]
+InT_rect [definition, in General.genT]
+InT_cons [constructor, in General.genT]
+InT_eq' [constructor, in General.genT]
+InT_flat_map [lemma, in K.Interpolation.UIK_Canopy]
+InT_In_inv_prems [lemma, in K.Interpolation.UIK_Canopy]
+invprem [definition, in GL.Interpolation.UIGL_Canopy]
+invprem [definition, in K.Interpolation.UIK_Canopy]
+inv_prems_measure [lemma, in K.Interpolation.UIK_UI_prelims]
+inv_prems_LtSeq [lemma, in K.Interpolation.UIK_basics]
+inv_prems_id_critical [lemma, in GL.Interpolation.UIGL_Canopy]
+inv_prems [definition, in GL.Interpolation.UIGL_Canopy]
+inv_prems_LexSeq [lemma, in GL.Interpolation.UIGL_LexSeq]
+inv_prems_id_critical [lemma, in K.Interpolation.UIK_Canopy]
+inv_prems [definition, in K.Interpolation.UIK_Canopy]
+in_drs_concl_in_allT [lemma, in K.KS.KS_termination]
+In_unboxed_list [lemma, in K.Interpolation.UIK_UI_prelims]
+In_list_In_propvar_subform_list [lemma, in K.Interpolation.UIK_UI_prelims]
+In_list_In_list_prop_LF [lemma, in K.Interpolation.UIK_UI_prelims]
+In_list_prop_LF [lemma, in K.Interpolation.UIK_UI_prelims]
+In_list_prop_LF_bis [lemma, in K.Interpolation.UIK_basics]
+In_list_prop_LF [lemma, in K.Interpolation.UIK_basics]
+In_l_imp_In_pos_top_imps [lemma, in GL.GLS.GLS_der_dec]
+In_pos_top_imps_split_l [definition, in GL.GLS.GLS_der_dec]
+In_pos_top_imps_In_l [lemma, in GL.GLS.GLS_der_dec]
+In_pos_top_imps_imp [lemma, in GL.GLS.GLS_der_dec]
+In_pos_top_imps_0_False [lemma, in GL.GLS.GLS_der_dec]
+In_listInserts [lemma, in GL.GLS.GLS_der_dec]
+In_InT_pair [definition, in GL.GLS.GLS_der_dec]
+In_InT [lemma, in GL.GLS.GLS_der_dec]
+in_replace [lemma, in GL.Interpolation.UIGL_Canopy_ImpR]
+in_not_touched_replace [lemma, in GL.Interpolation.UIGL_Canopy_ImpR]
+In_listInserts [lemma, in K.KS.KS_termination_prelims]
+In_InT_pair [definition, in K.KS.KS_termination_prelims]
+In_InT [lemma, in K.KS.KS_termination_prelims]
+In_list_prop_LF_bis [lemma, in GL.Interpolation.UIGL_basics]
+In_list_prop_LF [lemma, in GL.Interpolation.UIGL_basics]
+in_nextup_fc_nu [definition, in General.dd_fc]
+in_nextup_fc_eqv [lemma, in General.dd_fc]
+in_nextup_nu [definition, in General.dd_fc]
+in_nextup_eqv [lemma, in General.dd_fc]
+in_trees_drs [lemma, in General.dd_fc]
+in_drs_trees [lemma, in General.dd_fc]
+in_nextup_fc_sind [definition, in General.dd_fc]
+in_nextup_fc_rec [definition, in General.dd_fc]
+in_nextup_fc_ind [definition, in General.dd_fc]
+in_nextup_fc_rect [definition, in General.dd_fc]
+in_nextup_fcI [constructor, in General.dd_fc]
+in_nextup_fc [inductive, in General.dd_fc]
+in_drs_drs_hd [lemma, in General.dd_fc]
+in_dersrec_single' [lemma, in General.dd_fc]
+in_nextup_concl_in [lemma, in General.dd_fc]
+in_drs_concl_in [lemma, in General.dd_fc]
+in_nextup_sind [definition, in General.dd_fc]
+in_nextup_rec [definition, in General.dd_fc]
+in_nextup_ind [definition, in General.dd_fc]
+in_nextup_rect [definition, in General.dd_fc]
+in_nextupI [constructor, in General.dd_fc]
+in_nextup [inductive, in General.dd_fc]
+in_dersrec_sind [definition, in General.dd_fc]
+in_dersrec_rec [definition, in General.dd_fc]
+in_dersrec_ind [definition, in General.dd_fc]
+in_dersrec_rect [definition, in General.dd_fc]
+in_dersrec_tl [constructor, in General.dd_fc]
+in_dersrec_hd [constructor, in General.dd_fc]
+in_dersrec [inductive, in General.dd_fc]
+in_nextup_height [definition, in General.gentree]
+in_nextup_size [definition, in General.gentree]
+In_XBoxed_list_gen [lemma, in GL.Interpolation.UIGL_nodupseq]
+In_XBoxed_list [lemma, in GL.Interpolation.UIGL_nodupseq]
+in_adm [definition, in General.ddT]
+in_derl [lemma, in General.ddT]
+in_single [lemma, in General.gen]
+In_matters_remove_list [lemma, in Syntax.remove_list_lems]
+In_remove_list_remove_redund [lemma, in Syntax.remove_list_lems]
+In_remove_list_In_list_not_In_remove_list [lemma, in Syntax.remove_list_lems]
+In_remove_list_In_list [lemma, in Syntax.remove_list_lems]
+In_remove_In_list [lemma, in Syntax.remove_list_lems]
+In_remove_length_same [lemma, in Syntax.remove_list_lems]
+In_remove_same [lemma, in Syntax.remove_list_lems]
+In_remove_diff [lemma, in Syntax.remove_list_lems]
+in_remove_in_init [lemma, in Syntax.remove_list_lems]
+in_not_touched_remove [lemma, in Syntax.remove_list_lems]
+In_dec [definition, in Syntax.remove_list_lems]
+in_top_boxes [lemma, in GL.GLS.GLS_termination_measure]
+In_incl_subform_boxes [lemma, in GL.GLS.GLS_termination_measure]
+in_subform_boxesF_smaller_length_form [lemma, in GL.GLS.GLS_termination_measure]
+In_subform_boxesLF_box [lemma, in GL.GLS.GLS_termination_measure]
+In_subform_boxesF_box [lemma, in GL.GLS.GLS_termination_measure]
+In_n_imp_subformLF_is_non_0 [lemma, in GL.GLS.GLS_termination_measure]
+In_propvar_subform [lemma, in GL.Interpolation.UIGL_UI_prelims]
+In_subform_boxes [lemma, in GL.Interpolation.UIGL_UI_prelims]
+In_list_In_propvar_subform_list [lemma, in GL.Interpolation.UIGL_UI_prelims]
+In_list_In_list_prop_LF [lemma, in GL.Interpolation.UIGL_UI_prelims]
+In_list_prop_LF [lemma, in GL.Interpolation.UIGL_UI_prelims]
+In_l_imp_In_pos_top_imps [lemma, in K.KS.KS_termination_ImpR]
+In_pos_top_imps_split_l [definition, in K.KS.KS_termination_ImpR]
+In_pos_top_imps_In_l [lemma, in K.KS.KS_termination_ImpR]
+In_pos_top_imps_imp [lemma, in K.KS.KS_termination_ImpR]
+In_pos_top_imps_0_False [lemma, in K.KS.KS_termination_ImpR]
+in_top_boxes [definition, in GL.GLS.GLS_dec]
+In_InT_seqs [definition, in Syntax.list_lems]
+in_splitT [lemma, in Syntax.list_lems]
+in_exch_list [lemma, in Syntax.list_lems]
+In_InT [lemma, in General.genT]
+in_top_boxes [definition, in K.KS.KS_dec]
+In_open_boxes [lemma, in ISL.Environments]
+in_rm [lemma, in ISL.Environments]
+in_difference [lemma, in ISL.Environments]
+in_map_ext [lemma, in ISL.Environments]
+in_map_empty [lemma, in ISL.Environments]
+in_map_in [lemma, in ISL.Environments]
+in_subset [definition, in ISL.Environments]
+in_in_map [lemma, in ISL.Environments]
+in_map [definition, in ISL.Environments]
+in_map_aux [definition, in ISL.Environments]
+In_n_imp_subformLF_is_non_0 [lemma, in K.Interpolation.UIK_Canopy]
+In_Box_size_LF_is_non_0 [lemma, in K.KS.KS_termination_measure]
+In_Imp_size_LF_is_non_0 [lemma, in K.KS.KS_termination_measure]
+irred [definition, in K.Interpolation.UIK_irred_short]
+irred [section, in K.Interpolation.UIK_irred_short]
+irred [definition, in GL.Interpolation.UIGL_irred_short]
+irred [section, in GL.Interpolation.UIGL_irred_short]
+irreducible [definition, in ISL.Environments]
+irred_provability [lemma, in K.Interpolation.UIK_irred_high_level]
+irred_high_level.provability.HP [variable, in K.Interpolation.UIK_irred_high_level]
+irred_high_level.provability.P [variable, in K.Interpolation.UIK_irred_high_level]
+irred_high_level.provability [section, in K.Interpolation.UIK_irred_high_level]
+irred_high_level_spec [lemma, in K.Interpolation.UIK_irred_high_level]
+irred_reach [lemma, in K.Interpolation.UIK_irred_high_level]
+irred_max [lemma, in K.Interpolation.UIK_irred_high_level]
+irred_high_level.irred_not [variable, in K.Interpolation.UIK_irred_high_level]
+irred_high_level.irred_nil [variable, in K.Interpolation.UIK_irred_high_level]
+irred_high_level.irred [variable, in K.Interpolation.UIK_irred_high_level]
+irred_high_level.f_wf [variable, in K.Interpolation.UIK_irred_high_level]
+irred_high_level.f [variable, in K.Interpolation.UIK_irred_high_level]
+irred_high_level.X [variable, in K.Interpolation.UIK_irred_high_level]
+irred_high_level [section, in K.Interpolation.UIK_irred_high_level]
+irred_not [lemma, in K.Interpolation.UIK_irred_short]
+irred_nil [lemma, in K.Interpolation.UIK_irred_short]
+irred_spec [lemma, in K.Interpolation.UIK_irred_short]
+irred_provability [lemma, in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.provability.HP [variable, in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.provability.P [variable, in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.provability [section, in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level_spec [lemma, in GL.Interpolation.UIGL_irred_high_level]
+irred_reach [lemma, in GL.Interpolation.UIGL_irred_high_level]
+irred_max [lemma, in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.irred_not [variable, in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.irred_nil [variable, in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.irred [variable, in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.f_wf [variable, in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.f [variable, in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.X [variable, in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level [section, in GL.Interpolation.UIGL_irred_high_level]
+irred_not [lemma, in GL.Interpolation.UIGL_irred_short]
+irred_nil [lemma, in GL.Interpolation.UIGL_irred_short]
+irred_spec [lemma, in GL.Interpolation.UIGL_irred_short]
+irred.f [variable, in K.Interpolation.UIK_irred_short]
+irred.f [variable, in GL.Interpolation.UIGL_irred_short]
+irred.Girred_ind.HQ1 [variable, in K.Interpolation.UIK_irred_short]
+irred.Girred_ind.HQ0 [variable, in K.Interpolation.UIK_irred_short]
+irred.Girred_ind.HP1 [variable, in K.Interpolation.UIK_irred_short]
+irred.Girred_ind.HP0 [variable, in K.Interpolation.UIK_irred_short]
+irred.Girred_ind.Q [variable, in K.Interpolation.UIK_irred_short]
+irred.Girred_ind.P [variable, in K.Interpolation.UIK_irred_short]
+irred.Girred_ind [section, in K.Interpolation.UIK_irred_short]
+irred.Girred_ind.HQ1 [variable, in GL.Interpolation.UIGL_irred_short]
+irred.Girred_ind.HQ0 [variable, in GL.Interpolation.UIGL_irred_short]
+irred.Girred_ind.HP1 [variable, in GL.Interpolation.UIGL_irred_short]
+irred.Girred_ind.HP0 [variable, in GL.Interpolation.UIGL_irred_short]
+irred.Girred_ind.Q [variable, in GL.Interpolation.UIGL_irred_short]
+irred.Girred_ind.P [variable, in GL.Interpolation.UIGL_irred_short]
+irred.Girred_ind [section, in GL.Interpolation.UIGL_irred_short]
+irred.hf [variable, in K.Interpolation.UIK_irred_short]
+irred.hf [variable, in GL.Interpolation.UIGL_irred_short]
+irred.irred_pwc [variable, in K.Interpolation.UIK_irred_short]
+irred.irred_pwc [variable, in GL.Interpolation.UIGL_irred_short]
+irred.X [variable, in K.Interpolation.UIK_irred_short]
+irred.X [variable, in GL.Interpolation.UIGL_irred_short]
+irreflexive_form_order [instance, in ISL.Formulas]
+isl_simplified_A [definition, in UIML_extraction.UIML_extraction]
+isl_simplified_E [definition, in UIML_extraction.UIML_extraction]
+isl_simp [definition, in UIML_extraction.UIML_extraction]
+isl_A [definition, in UIML_extraction.UIML_extraction]
+isl_E [definition, in UIML_extraction.UIML_extraction]
+iSL_uniform_interpolation [lemma, in ISL.PropQuantifiers]
+is_init_UI [lemma, in K.Interpolation.UIK_UI_prelims]
+is_init_UI_equiv_Top [lemma, in K.Interpolation.UIK_UI_prelims]
+is_init_Canopy [lemma, in K.Interpolation.UIK_UI_prelims]
+is_init [definition, in K.Interpolation.UIK_basics]
+is_mhd [definition, in GL.GLS.GLS_der_dec]
+is_mhd [definition, in K.KS.KS_termination_prelims]
+is_box_weight_open_box [lemma, in ISL.SequentProps]
+is_Boxed_list_top_boxes [lemma, in Syntax.CML_Syntax]
+is_box_is_in_boxed_list [lemma, in Syntax.CML_Syntax]
+is_Prime [definition, in Syntax.CML_Syntax]
+is_Boxed_list [definition, in Syntax.CML_Syntax]
+is_boxedT [definition, in Syntax.CML_Syntax]
+is_atomicT [definition, in Syntax.CML_Syntax]
+is_nextup_ndt [lemma, in General.dd_fc]
+is_nextup_sind [definition, in General.dd_fc]
+is_nextup_rec [definition, in General.dd_fc]
+is_nextup_ind [definition, in General.dd_fc]
+is_nextup_rect [definition, in General.dd_fc]
+is_nextupI [constructor, in General.dd_fc]
+is_nextup [inductive, in General.dd_fc]
+is_init_nodupseq [lemma, in GL.Interpolation.UIGL_nodupseq]
+is_Prime_dec [definition, in GL.Interpolation.UIGL_Canopy]
+is_box_in_top_boxes [lemma, in GL.GLS.GLS_termination_measure]
+is_init_UI [lemma, in GL.Interpolation.UIGL_UI_prelims]
+is_init_UI_equiv_Top [lemma, in GL.Interpolation.UIGL_UI_prelims]
+is_init_Canopy [lemma, in GL.Interpolation.UIGL_UI_prelims]
+is_init [definition, in GL.Interpolation.UIGL_LexSeq]
+is_not_box_open_box [lemma, in ISL.Environments]
+is_box [definition, in ISL.Environments]
+is_negation [definition, in ISL.Environments]
+is_implication [definition, in ISL.Environments]
+is_double_negation [definition, in ISL.Environments]
+is_implication_obviously_smaller [lemma, in ISL.Optimizations]
+is_Prime_dec [definition, in K.Interpolation.UIK_Canopy]
+

K

+keep_list_delete_head_not_In [lemma, in Syntax.remove_list_lems]
+keep_list_delete_head_not_origin [lemma, in Syntax.remove_list_lems]
+KR [constructor, in K.KS.KS_calc]
+KRRule [inductive, in K.KS.KS_calc]
+KRRule_sind [definition, in K.KS.KS_calc]
+KRRule_rec [definition, in K.KS.KS_calc]
+KRRule_ind [definition, in K.KS.KS_calc]
+KRRule_rect [definition, in K.KS.KS_calc]
+KRRule_I [constructor, in K.KS.KS_calc]
+KR_app_ctr_R [lemma, in K.KS.KS_ctr]
+KR_app_ctr_L [lemma, in K.KS.KS_ctr]
+KR_app_wkn_R [lemma, in K.KS.KS_wkn]
+KR_app_wkn_L [lemma, in K.KS.KS_wkn]
+KR_prems_LtSeq [lemma, in K.Interpolation.UIK_basics]
+KR_prems [definition, in K.Interpolation.UIK_basics]
+KR_help2 [definition, in K.KS.KS_termination_KR]
+KR_help02 [definition, in K.KS.KS_termination_KR]
+KR_help1 [definition, in K.KS.KS_termination_KR]
+KR_help01 [definition, in K.KS.KS_termination_KR]
+KR_app_list_exchR [lemma, in K.KS.KS_exch_KR]
+KR_app_list_exchL [lemma, in K.KS.KS_exch_KR]
+KS_hpadm_list_ctr_R [lemma, in K.KS.KS_ctr]
+KS_hpadm_list_ctr_L [lemma, in K.KS.KS_ctr]
+KS_hpadm_ctr_R [lemma, in K.KS.KS_ctr]
+KS_hpadm_ctr_L [lemma, in K.KS.KS_ctr]
+KS_hpadm_ctr_LR [lemma, in K.KS.KS_ctr]
+KS_hpadm_ctr_LR0 [lemma, in K.KS.KS_ctr]
+KS_list_wkn_L [lemma, in K.KS.KS_wkn]
+KS_list_wkn_R [lemma, in K.KS.KS_wkn]
+KS_hpadm_wkn_R [lemma, in K.KS.KS_wkn]
+KS_wkn_R [lemma, in K.KS.KS_wkn]
+KS_hpadm_wkn_L [lemma, in K.KS.KS_wkn]
+KS_wkn_L [lemma, in K.KS.KS_wkn]
+KS_termin_der_is_mhd [lemma, in K.KS.KS_termination]
+KS_termin3 [lemma, in K.KS.KS_termination]
+KS_termin2 [lemma, in K.KS.KS_termination]
+KS_termin1 [lemma, in K.KS.KS_termination]
+KS_termin [lemma, in K.KS.KS_termination]
+KS_termin_base [lemma, in K.KS.KS_termination]
+KS_cut_elimination [lemma, in K.KS.KS_cut_elim]
+KS_cut_drv [definition, in K.KS.KS_cut_elim]
+KS_cut_prv [definition, in K.KS.KS_cut_elim]
+KS_cut_rules_sind [definition, in K.KS.KS_cut_elim]
+KS_cut_rules_rec [definition, in K.KS.KS_cut_elim]
+KS_cut_rules_ind [definition, in K.KS.KS_cut_elim]
+KS_cut_rules_rect [definition, in K.KS.KS_cut_elim]
+KS_cut [constructor, in K.KS.KS_cut_elim]
+KS_woc [constructor, in K.KS.KS_cut_elim]
+KS_cut_rules [inductive, in K.KS.KS_cut_elim]
+KS_cut_adm [lemma, in K.KS.KS_additive_cut]
+KS_cut_adm_main [lemma, in K.KS.KS_additive_cut]
+KS_drv [definition, in K.KS.KS_calc]
+KS_prv [definition, in K.KS.KS_calc]
+KS_rules_sind [definition, in K.KS.KS_calc]
+KS_rules_rec [definition, in K.KS.KS_calc]
+KS_rules_ind [definition, in K.KS.KS_calc]
+KS_rules_rect [definition, in K.KS.KS_calc]
+KS_rules [inductive, in K.KS.KS_calc]
+KS_adm_list_exch_LR [lemma, in K.KS.KS_exch]
+KS_hpadm_list_exch_R [lemma, in K.KS.KS_exch]
+KS_hpadm_list_exch_L [lemma, in K.KS.KS_exch]
+KS_hpadm_list_exch_L0 [lemma, in K.KS.KS_exch]
+KS_hpadm_list_exch_R0 [lemma, in K.KS.KS_exch]
+KS_der_list_exch_R [lemma, in K.KS.KS_exch]
+KS_der_list_exch_L [lemma, in K.KS.KS_exch]
+KS_adm_list_exch_R [lemma, in K.KS.KS_exch]
+KS_adm_list_exch_L [lemma, in K.KS.KS_exch]
+KS_exch_KR [library]
+KS_inv_ImpR_ImpL [library]
+KS_termination_measure [library]
+KS_dec [library]
+KS_termination_ImpR [library]
+KS_exch_ImpR [library]
+KS_ctr [library]
+KS_termination_init [library]
+KS_exch [library]
+KS_calc [library]
+KS_export [library]
+KS_termination [library]
+KS_additive_cut [library]
+KS_exch_ImpL [library]
+KS_cut_elim [library]
+KS_exch_prelims [library]
+KS_termination_ImpL [library]
+KS_wkn [library]
+KS_termination_KR [library]
+KS_termination_prelims [library]
+k_UI [definition, in UIML_extraction.UIML_extraction]
+K_Craig_Interp [library]
+

L

+length_le_remove_list [lemma, in Syntax.remove_list_lems]
+length_usable_boxes_is_0 [lemma, in GL.GLS.GLS_termination_measure]
+length_form [definition, in GL.GLS.GLS_termination_measure]
+leq_ub_Canopy [lemma, in GL.Interpolation.UIGL_LexSeq]
+leq_ub_unif [lemma, in GL.Interpolation.UIGL_LexSeq]
+less_imp [definition, in GL.Interpolation.UIGL_Canopy]
+less_thanS_strong_inductionT [lemma, in GL.GLS.GLS_termination_measure]
+less_thanS_trans [lemma, in GL.GLS.GLS_termination_measure]
+less_thanS_wf [lemma, in GL.GLS.GLS_termination_measure]
+less_thanS_inv [lemma, in GL.GLS.GLS_termination_measure]
+less_thanS [definition, in GL.GLS.GLS_termination_measure]
+less_ub_witness [lemma, in GL.Interpolation.UIGL_UI_prelims]
+less_imp [definition, in K.Interpolation.UIK_Canopy]
+leT [inductive, in General.genT]
+leT_ex_plus [lemma, in General.genT]
+leT_or_gt [lemma, in General.genT]
+leT_S_or_eq [lemma, in General.genT]
+leT_S_F [lemma, in General.genT]
+leT_plus_l [lemma, in General.genT]
+leT_plus_r [lemma, in General.genT]
+leT_0_n [lemma, in General.genT]
+leT_trans [definition, in General.genT]
+leT_trans' [lemma, in General.genT]
+leT_S_n [definition, in General.genT]
+leT_S_n' [lemma, in General.genT]
+leT_n_S [lemma, in General.genT]
+leT_sind [definition, in General.genT]
+leT_rec [definition, in General.genT]
+leT_ind [definition, in General.genT]
+leT_rect [definition, in General.genT]
+leT_S [constructor, in General.genT]
+leT_n [constructor, in General.genT]
+lex [inductive, in K.Interpolation.UIK_Def_measure]
+lex [inductive, in GL.GLS.DLW_wf_lex]
+lex [inductive, in GL.Interpolation.UIGL_Def_measure]
+LexSeq [definition, in GL.Interpolation.UIGL_LexSeq]
+LexSeq_nodupseq_case [lemma, in GL.Interpolation.UIGL_nodupseq]
+LexSeq_nodupseq [lemma, in GL.Interpolation.UIGL_nodupseq]
+LexSeq_trans [lemma, in GL.Interpolation.UIGL_LexSeq]
+LexSeq_properties [section, in GL.Interpolation.UIGL_LexSeq]
+LexSeq_ind [definition, in GL.Interpolation.UIGL_LexSeq]
+LexSeq_ind.P [variable, in GL.Interpolation.UIGL_LexSeq]
+LexSeq_ind [section, in GL.Interpolation.UIGL_LexSeq]
+lex_rect [lemma, in K.Interpolation.UIK_Def_measure]
+lex_wf.lex_rect.HP [variable, in K.Interpolation.UIK_Def_measure]
+lex_wf.lex_rect.P [variable, in K.Interpolation.UIK_Def_measure]
+lex_wf.lex_rect [section, in K.Interpolation.UIK_Def_measure]
+lex_wf [lemma, in K.Interpolation.UIK_Def_measure]
+lex_cons_inv [lemma, in K.Interpolation.UIK_Def_measure]
+lex_length [lemma, in K.Interpolation.UIK_Def_measure]
+_ <lex _ [notation, in K.Interpolation.UIK_Def_measure]
+lex_sind [definition, in K.Interpolation.UIK_Def_measure]
+lex_ind [definition, in K.Interpolation.UIK_Def_measure]
+lex_cons [constructor, in K.Interpolation.UIK_Def_measure]
+lex_skip [constructor, in K.Interpolation.UIK_Def_measure]
+lex_wf.Rwf [variable, in K.Interpolation.UIK_Def_measure]
+lex_wf.R [variable, in K.Interpolation.UIK_Def_measure]
+lex_wf.X [variable, in K.Interpolation.UIK_Def_measure]
+lex_wf [section, in K.Interpolation.UIK_Def_measure]
+lex_trans [lemma, in GL.GLS.GLS_termination_measure]
+lex_wf [lemma, in GL.GLS.DLW_wf_lex]
+lex_cons_inv [lemma, in GL.GLS.DLW_wf_lex]
+lex_length [lemma, in GL.GLS.DLW_wf_lex]
+_ <lex _ [notation, in GL.GLS.DLW_wf_lex]
+lex_sind [definition, in GL.GLS.DLW_wf_lex]
+lex_ind [definition, in GL.GLS.DLW_wf_lex]
+lex_cons [constructor, in GL.GLS.DLW_wf_lex]
+lex_skip [constructor, in GL.GLS.DLW_wf_lex]
+lex_wf.Rwf [variable, in GL.GLS.DLW_wf_lex]
+lex_wf.R [variable, in GL.GLS.DLW_wf_lex]
+lex_wf.X [variable, in GL.GLS.DLW_wf_lex]
+lex_wf [section, in GL.GLS.DLW_wf_lex]
+lex_rect [lemma, in GL.Interpolation.UIGL_Def_measure]
+lex_wf.lex_rect.HP [variable, in GL.Interpolation.UIGL_Def_measure]
+lex_wf.lex_rect.P [variable, in GL.Interpolation.UIGL_Def_measure]
+lex_wf.lex_rect [section, in GL.Interpolation.UIGL_Def_measure]
+lex_wf [lemma, in GL.Interpolation.UIGL_Def_measure]
+lex_cons_inv [lemma, in GL.Interpolation.UIGL_Def_measure]
+lex_length [lemma, in GL.Interpolation.UIGL_Def_measure]
+_ <lex _ [notation, in GL.Interpolation.UIGL_Def_measure]
+lex_sind [definition, in GL.Interpolation.UIGL_Def_measure]
+lex_ind [definition, in GL.Interpolation.UIGL_Def_measure]
+lex_cons [constructor, in GL.Interpolation.UIGL_Def_measure]
+lex_skip [constructor, in GL.Interpolation.UIGL_Def_measure]
+lex_wf.Rwf [variable, in GL.Interpolation.UIGL_Def_measure]
+lex_wf.R [variable, in GL.Interpolation.UIGL_Def_measure]
+lex_wf.X [variable, in GL.Interpolation.UIGL_Def_measure]
+lex_wf [section, in GL.Interpolation.UIGL_Def_measure]
+le_False_lt [lemma, in GL.GLS.GLS_der_dec]
+le_False_lt [lemma, in K.KS.KS_termination_prelims]
+le_dersrec_height [lemma, in General.dd_fc]
+Lindenbaum_Tarski_preorder_Bot [lemma, in ISL.Optimizations]
+Lindenbaum_Tarski_preorder [definition, in ISL.Optimizations]
+listInserts [definition, in GL.GLS.GLS_der_dec]
+listInserts [definition, in K.KS.KS_termination_prelims]
+listInsertsL_Seqs [definition, in GL.GLS.GLS_der_dec]
+listInsertsL_Seqs [definition, in K.KS.KS_termination_prelims]
+listInsertsRL_Seqs [definition, in GL.GLS.GLS_der_dec]
+listInsertsRL_Seqs [definition, in K.KS.KS_termination_prelims]
+listInsertsR_Seqs [definition, in GL.GLS.GLS_der_dec]
+listInsertsR_Seqs [definition, in K.KS.KS_termination_prelims]
+listInserts_In [lemma, in GL.GLS.GLS_der_dec]
+listInserts_In [lemma, in K.KS.KS_termination_prelims]
+list_is_nil [definition, in K.Interpolation.UIK_irred_high_level]
+list_of_premises [definition, in K.KS.KS_termination]
+list_disj_wkn_R [lemma, in K.Interpolation.UIK_UI_prelims]
+list_disj_L [lemma, in K.Interpolation.UIK_UI_prelims]
+list_conj_R [lemma, in K.Interpolation.UIK_UI_prelims]
+list_conj_wkn_L [lemma, in K.Interpolation.UIK_UI_prelims]
+list_conj_disj_properties [section, in K.Interpolation.UIK_UI_prelims]
+list_prop_LF_propvar_subform_list [lemma, in K.Interpolation.UIK_UI_prelims]
+list_prop_LF_In [lemma, in K.Interpolation.UIK_basics]
+list_prop_LF [definition, in K.Interpolation.UIK_basics]
+list_prop_F [definition, in K.Interpolation.UIK_basics]
+list_disj [definition, in K.Interpolation.UIK_basics]
+list_conj [definition, in K.Interpolation.UIK_basics]
+list_of_premises [definition, in GL.GLS.GLS_der_dec]
+list_of_splits [definition, in GL.GLS.GLS_der_dec]
+list_of_splits [definition, in K.KS.KS_termination_prelims]
+list_prop_LF_In [lemma, in GL.Interpolation.UIGL_basics]
+list_prop_LF [definition, in GL.Interpolation.UIGL_basics]
+list_prop_F [definition, in GL.Interpolation.UIGL_basics]
+list_disj [definition, in GL.Interpolation.UIGL_basics]
+list_conj [definition, in GL.Interpolation.UIGL_basics]
+list_disj_wkn_R [lemma, in GL.Interpolation.UIGL_And_Or_rules]
+list_disj_L [lemma, in GL.Interpolation.UIGL_And_Or_rules]
+list_conj_R [lemma, in GL.Interpolation.UIGL_And_Or_rules]
+list_conj_wkn_L [lemma, in GL.Interpolation.UIGL_And_Or_rules]
+list_conj_disj_properties [section, in GL.Interpolation.UIGL_And_Or_rules]
+list_preserv_XBoxed_list [lemma, in GL.GLS.GLS_calcs]
+list_exch_L_permLR [lemma, in K.KS.KS_exch_prelims]
+list_exch_L_permR [lemma, in K.KS.KS_exch_prelims]
+list_exch_L_permL [lemma, in K.KS.KS_exch_prelims]
+list_exch_R_permLR [lemma, in K.KS.KS_exch_prelims]
+list_exch_R_permR [lemma, in K.KS.KS_exch_prelims]
+list_exch_R_permL [lemma, in K.KS.KS_exch_prelims]
+list_exch_L_same_R [lemma, in K.KS.KS_exch_prelims]
+list_exch_R_same_L [lemma, in K.KS.KS_exch_prelims]
+list_exch_L_id [lemma, in K.KS.KS_exch_prelims]
+list_exch_R_id [lemma, in K.KS.KS_exch_prelims]
+list_exch_R_sind [definition, in K.KS.KS_exch_prelims]
+list_exch_R_rec [definition, in K.KS.KS_exch_prelims]
+list_exch_R_ind [definition, in K.KS.KS_exch_prelims]
+list_exch_R_rect [definition, in K.KS.KS_exch_prelims]
+list_exch_RI [constructor, in K.KS.KS_exch_prelims]
+list_exch_R [inductive, in K.KS.KS_exch_prelims]
+list_exch_L_sind [definition, in K.KS.KS_exch_prelims]
+list_exch_L_rec [definition, in K.KS.KS_exch_prelims]
+list_exch_L_ind [definition, in K.KS.KS_exch_prelims]
+list_exch_L_rect [definition, in K.KS.KS_exch_prelims]
+list_exch_LI [constructor, in K.KS.KS_exch_prelims]
+list_exch_L [inductive, in K.KS.KS_exch_prelims]
+list_prop_LF_In [lemma, in GL.Interpolation.UIGL_UI_prelims]
+list_prop_LF_propvar_subform_list [lemma, in GL.Interpolation.UIGL_UI_prelims]
+list_exch_R_BotL_notapplic [lemma, in GL.GLS.GLS_exch]
+list_exch_R_IdB_notapplic [lemma, in GL.GLS.GLS_exch]
+list_exch_R_IdP_notapplic [lemma, in GL.GLS.GLS_exch]
+list_exch_L_BotL_notapplic [lemma, in GL.GLS.GLS_exch]
+list_exch_L_IdB_notapplic [lemma, in GL.GLS.GLS_exch]
+list_exch_L_IdP_notapplic [lemma, in GL.GLS.GLS_exch]
+list_exch_L_permLR [lemma, in GL.GLS.GLS_exch]
+list_exch_L_permR [lemma, in GL.GLS.GLS_exch]
+list_exch_L_permL [lemma, in GL.GLS.GLS_exch]
+list_exch_R_permLR [lemma, in GL.GLS.GLS_exch]
+list_exch_R_permR [lemma, in GL.GLS.GLS_exch]
+list_exch_R_permL [lemma, in GL.GLS.GLS_exch]
+list_exch_L_same_R [lemma, in GL.GLS.GLS_exch]
+list_exch_R_same_L [lemma, in GL.GLS.GLS_exch]
+list_exch_L_id [lemma, in GL.GLS.GLS_exch]
+list_exch_R_id [lemma, in GL.GLS.GLS_exch]
+list_exch_R_sind [definition, in GL.GLS.GLS_exch]
+list_exch_R_rec [definition, in GL.GLS.GLS_exch]
+list_exch_R_ind [definition, in GL.GLS.GLS_exch]
+list_exch_R_rect [definition, in GL.GLS.GLS_exch]
+list_exch_RI [constructor, in GL.GLS.GLS_exch]
+list_exch_R [inductive, in GL.GLS.GLS_exch]
+list_exch_L_sind [definition, in GL.GLS.GLS_exch]
+list_exch_L_rec [definition, in GL.GLS.GLS_exch]
+list_exch_L_ind [definition, in GL.GLS.GLS_exch]
+list_exch_L_rect [definition, in GL.GLS.GLS_exch]
+list_exch_LI [constructor, in GL.GLS.GLS_exch]
+list_exch_L [inductive, in GL.GLS.GLS_exch]
+list_is_nil [definition, in K.Interpolation.UIK_irred_short]
+list_nil_or_tail_singleton [lemma, in General.List_lemmasT]
+list_insert1 [lemma, in General.List_lemmasT]
+list_eq_singleT_nobrac [lemma, in General.List_lemmasT]
+list_eq_singleT [lemma, in General.List_lemmasT]
+list_eq_single [lemma, in General.List_lemmasT]
+list_eq_nil [lemma, in General.List_lemmasT]
+list_rearr23 [lemma, in General.List_lemmasT]
+list_rearr22 [lemma, in General.List_lemmasT]
+list_rearr21 [lemma, in General.List_lemmasT]
+list_rearr20 [lemma, in General.List_lemmasT]
+list_rearr19 [lemma, in General.List_lemmasT]
+list_rearr18 [lemma, in General.List_lemmasT]
+list_rearr17_R [lemma, in General.List_lemmasT]
+list_rearr16_R [lemma, in General.List_lemmasT]
+list_rearr16 [lemma, in General.List_lemmasT]
+list_rearr16' [lemma, in General.List_lemmasT]
+list_rearr15_R [lemma, in General.List_lemmasT]
+list_rearr15 [lemma, in General.List_lemmasT]
+list_rearr14 [lemma, in General.List_lemmasT]
+list_rearr13 [lemma, in General.List_lemmasT]
+list_rearr11 [lemma, in General.List_lemmasT]
+list_rearr10 [lemma, in General.List_lemmasT]
+list_rearr9 [lemma, in General.List_lemmasT]
+list_rearr8 [lemma, in General.List_lemmasT]
+list_rearr7 [lemma, in General.List_lemmasT]
+list_rearr6 [lemma, in General.List_lemmasT]
+list_rearr5 [lemma, in General.List_lemmasT]
+list_rearr4 [lemma, in General.List_lemmasT]
+list_rearr2 [lemma, in General.List_lemmasT]
+list_rearr1 [lemma, in General.List_lemmasT]
+list_is_nil [definition, in GL.Interpolation.UIGL_irred_high_level]
+list_split_form [lemma, in Syntax.list_lems]
+list_to_set_disj_open_boxes [lemma, in ISL.Environments]
+list_to_set_disj_rm [lemma, in ISL.Environments]
+list_to_set_disj_env_add [lemma, in ISL.Environments]
+list_is_nil [definition, in GL.Interpolation.UIGL_irred_short]
+List_lemmasT [library]
+list_lems [library]
+LogDefinition [section, in GL.Interpolation.UIGL_LexSeq]
+logic [section, in GL.Interpolation.UIGL_UI_prelims]
+Logic_Abrv [section, in K.Interpolation.UIK_basics]
+Logic_Abrv [section, in GL.Interpolation.UIGL_basics]
+LtSeq [definition, in K.Interpolation.UIK_basics]
+LtSeq_trans [lemma, in K.Interpolation.UIK_basics]
+LtSeq_properties [section, in K.Interpolation.UIK_basics]
+LtSeq_ind [definition, in K.Interpolation.UIK_basics]
+LtSeq_ind.P [variable, in K.Interpolation.UIK_basics]
+LtSeq_ind [section, in K.Interpolation.UIK_basics]
+lt_decT [lemma, in K.Interpolation.UIK_basics]
+

M

+make_conj_comm_ctx_L [lemma, in ISL.Simp]
+make_conj_comm_ctx_R [lemma, in ISL.Simp]
+make_conj_comm [lemma, in ISL.Simp]
+make_disj_comm_ctx_L [lemma, in ISL.Simp]
+make_disj_comm_ctx_R [lemma, in ISL.Simp]
+make_disj_comm [lemma, in ISL.Simp]
+make_impl [definition, in ISL.Environments]
+make_disj [definition, in ISL.Environments]
+make_conj [definition, in ISL.Environments]
+make_impl_complete_R [lemma, in ISL.Optimizations]
+make_impl_complete_L2 [lemma, in ISL.Optimizations]
+make_impl_complete_L [lemma, in ISL.Optimizations]
+make_impl_sound_L2' [lemma, in ISL.Optimizations]
+make_impl_sound_L2 [lemma, in ISL.Optimizations]
+make_impl_sound_R [lemma, in ISL.Optimizations]
+make_impl_sound_L [lemma, in ISL.Optimizations]
+make_disj_complete_R [lemma, in ISL.Optimizations]
+make_disj_sound_R [lemma, in ISL.Optimizations]
+make_disj_complete_L [lemma, in ISL.Optimizations]
+make_disj_sound_L [lemma, in ISL.Optimizations]
+make_disj_equiv_R [lemma, in ISL.Optimizations]
+make_disj_equiv_L [lemma, in ISL.Optimizations]
+make_conj_complete_R [lemma, in ISL.Optimizations]
+make_conj_sound_R [lemma, in ISL.Optimizations]
+make_conj_complete_L [lemma, in ISL.Optimizations]
+make_conj_sound_L [lemma, in ISL.Optimizations]
+make_conj_equiv_R [lemma, in ISL.Optimizations]
+make_conj_equiv_L [lemma, in ISL.Optimizations]
+map_fmlsext_fmlsext [lemma, in General.gen_seq]
+map_seqext_seqext [lemma, in General.gen_seq]
+map_eq_nil [lemma, in General.gen]
+map_app_ex [lemma, in General.gen]
+map_cons_ex' [lemma, in General.gen]
+map_cons_ex [lemma, in General.gen]
+measure [definition, in General.gentree]
+measure [definition, in GL.GLS.GLS_termination_measure]
+measure [definition, in GL.Interpolation.UIGL_LexSeq]
+measure [definition, in K.KS.KS_termination_measure]
+measure_rect [definition, in K.Interpolation.UIK_Def_measure]
+measure_rect.F [variable, in K.Interpolation.UIK_Def_measure]
+measure_rect.P [variable, in K.Interpolation.UIK_Def_measure]
+measure_rect.m [variable, in K.Interpolation.UIK_Def_measure]
+measure_rect.X [variable, in K.Interpolation.UIK_Def_measure]
+measure_rect [section, in K.Interpolation.UIK_Def_measure]
+measure_rect [definition, in GL.GLS.DLW_wf_lex]
+measure_rect.F [variable, in GL.GLS.DLW_wf_lex]
+measure_rect.P [variable, in GL.GLS.DLW_wf_lex]
+measure_rect.m [variable, in GL.GLS.DLW_wf_lex]
+measure_rect.X [variable, in GL.GLS.DLW_wf_lex]
+measure_rect [section, in GL.GLS.DLW_wf_lex]
+measure_rect [definition, in GL.Interpolation.UIGL_Def_measure]
+measure_rect.F [variable, in GL.Interpolation.UIGL_Def_measure]
+measure_rect.P [variable, in GL.Interpolation.UIGL_Def_measure]
+measure_rect.m [variable, in GL.Interpolation.UIGL_Def_measure]
+measure_rect.X [variable, in GL.Interpolation.UIGL_Def_measure]
+measure_rect [section, in GL.Interpolation.UIGL_Def_measure]
+measure_is_0 [lemma, in K.KS.KS_termination_measure]
+mhd [definition, in K.KS.KS_termination]
+midI [lemma, in General.gen_tacs]
+MPropF [inductive, in Syntax.CML_Syntax]
+MPropF_sind [definition, in Syntax.CML_Syntax]
+MPropF_rec [definition, in Syntax.CML_Syntax]
+MPropF_ind [definition, in Syntax.CML_Syntax]
+MPropF_rect [definition, in Syntax.CML_Syntax]
+MPropF_of_form [definition, in UIML_extraction.UIML_extraction]
+multeq_meq [lemma, in ISL.Environments]
+mult_ImpR [lemma, in GL.Interpolation.UIGL_Canopy_ImpR]
+mult_ImpL_L [lemma, in GL.Interpolation.UIGL_Canopy_ImpL]
+mult_ImpL_R [lemma, in GL.Interpolation.UIGL_Canopy_ImpL]
+

N

+N [definition, in GL.Interpolation.UIGL_braga]
+N [section, in GL.Interpolation.UIGL_braga]
+Neg [definition, in Syntax.CML_Syntax]
+nextup [definition, in General.dd_fc]
+nextup_height [lemma, in General.dd_fc]
+nextup_in_nu_fc [definition, in General.dd_fc]
+nextup_in_nu [definition, in General.dd_fc]
+nextup_height [lemma, in General.gentree]
+nextup_size [lemma, in General.gentree]
+nil_eq_appT [definition, in General.List_lemmasT]
+nil_eq_app [definition, in General.List_lemmasT]
+nil_eq_list [definition, in General.List_lemmasT]
+nnn_app_eq [lemma, in General.List_lemmasT]
+nobox_top_boxes [lemma, in K.Interpolation.UIK_UI_prelims]
+nobox_gen_ext_top_boxes_identity [lemma, in GL.GLS.GLS_der_dec]
+nobox_gen_ext_top_boxes_identity [lemma, in K.KS.KS_termination_prelims]
+nobox_gen_ext_top_boxes [lemma, in Syntax.CML_Syntax]
+nobox_gen_ext_injective [lemma, in Syntax.CML_Syntax]
+nobox_gen_ext [definition, in Syntax.CML_Syntax]
+nobox_gen_ext_exch_L [lemma, in K.KS.KS_exch_prelims]
+nobox_gen_ext_exch_R [lemma, in K.KS.KS_exch_prelims]
+nobox_top_boxes [lemma, in GL.Interpolation.UIGL_UI_prelims]
+nobox_gen_ext_exch_L [lemma, in GL.GLS.GLS_exch]
+nobox_gen_ext_exch_R [lemma, in GL.GLS.GLS_exch]
+nodupseq [definition, in GL.Interpolation.UIGL_nodupseq]
+nodupseq [section, in GL.Interpolation.UIGL_nodupseq]
+nodupseq_prv_hpadm_RL [lemma, in GL.Interpolation.UIGL_nodupseq]
+nodupseq_prv_hpadm_LR [lemma, in GL.Interpolation.UIGL_nodupseq]
+nodupseq_prv [lemma, in GL.Interpolation.UIGL_nodupseq]
+nodupseq_hpadm_prv_RL [lemma, in GL.Interpolation.UIGL_nodupseq]
+nodupseq_hpadm_prv_LR [lemma, in GL.Interpolation.UIGL_nodupseq]
+nodupseq_id [lemma, in GL.Interpolation.UIGL_nodupseq]
+nodupseq_GLR_prems [lemma, in GL.Interpolation.UIGL_nodupseq]
+nodup_length [lemma, in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+nodup_id [lemma, in GL.Interpolation.UIGL_nodupseq]
+nodup_XBoxed_list [lemma, in GL.Interpolation.UIGL_nodupseq]
+nodup_top_boxes [lemma, in GL.Interpolation.UIGL_nodupseq]
+nodup_nil [lemma, in GL.Interpolation.UIGL_nodupseq]
+nodup_app [lemma, in GL.Interpolation.UIGL_nodupseq]
+NoDup_destr_split [lemma, in Syntax.remove_list_lems]
+NoDup_usable_boxes [lemma, in GL.GLS.GLS_termination_measure]
+NoDup_subform_boxesS [lemma, in GL.GLS.GLS_termination_measure]
+NoDup_subform_boxesLF [lemma, in GL.GLS.GLS_termination_measure]
+NoDup_subform_boxesF [lemma, in GL.GLS.GLS_termination_measure]
+NoDup_incl_lengthT [lemma, in GL.GLS.GLS_termination_measure]
+nodup_facts [section, in GL.Interpolation.UIGL_UI_prelims]
+NoDup_incl_lengthT [lemma, in K.KS.KS_termination_measure]
+nolessub_In [lemma, in GL.Interpolation.UIGL_UI_prelims]
+noless_ub_incl_subform_boxesS [lemma, in GL.Interpolation.UIGL_Diam_UI_imp_N_prelim]
+non_empty [definition, in General.List_lemmasT]
+notin_replace [lemma, in GL.Interpolation.UIGL_Canopy_ImpR]
+not_init_empty_set [lemma, in K.Interpolation.UIK_basics]
+not_removed_remove_list [lemma, in Syntax.remove_list_lems]
+not_init_empty_seq [lemma, in GL.Interpolation.UIGL_LexSeq]
+no_usable_boxes_all_RHS_are_LHS [lemma, in GL.GLS.GLS_termination_measure]
+no_RHS_box_no_GLR [lemma, in GL.GLS.GLS_termination_measure]
+no_KS_rule_applic [lemma, in K.KS.KS_termination_measure]
+nth_split_length_id [lemma, in GL.GLS.GLS_der_dec]
+nth_split_idR [lemma, in GL.GLS.GLS_der_dec]
+nth_split_idL [lemma, in GL.GLS.GLS_der_dec]
+nth_split_length [lemma, in GL.GLS.GLS_der_dec]
+nth_split [definition, in GL.GLS.GLS_der_dec]
+nth_split_length_id [lemma, in K.KS.KS_termination_prelims]
+nth_split_idR [lemma, in K.KS.KS_termination_prelims]
+nth_split_idL [lemma, in K.KS.KS_termination_prelims]
+nth_split_length [lemma, in K.KS.KS_termination_prelims]
+nth_split [definition, in K.KS.KS_termination_prelims]
+N_spec [lemma, in GL.Interpolation.UIGL_braga]
+N_pwc [definition, in GL.Interpolation.UIGL_braga]
+n_imp_subformS_ImpR_mult [lemma, in GL.Interpolation.UIGL_Canopy_ImpR]
+n_imp_subformLF_replace [lemma, in GL.Interpolation.UIGL_Canopy_ImpR]
+n_imp_subformS_nodupseq [lemma, in GL.Interpolation.UIGL_nodupseq]
+n_imp_subformLF_nodup [lemma, in GL.Interpolation.UIGL_nodupseq]
+n_imp_subformLF_dist_app [lemma, in GL.GLS.GLS_termination_measure]
+n_imp_subformS_is_0 [lemma, in GL.GLS.GLS_termination_measure]
+n_imp_subformS [definition, in GL.GLS.GLS_termination_measure]
+n_imp_subformLF [definition, in GL.GLS.GLS_termination_measure]
+n_imp_subformF [definition, in GL.GLS.GLS_termination_measure]
+N_nodupseq [lemma, in GL.Interpolation.UIGL_UI_inter]
+n_imp_unboxed [lemma, in K.Interpolation.UIK_Canopy]
+n_imp_nobox_gen_ext [lemma, in K.Interpolation.UIK_Canopy]
+n_imp_subformLF_dist_app [lemma, in K.Interpolation.UIK_Canopy]
+n_imp_subformS_is_0 [lemma, in K.Interpolation.UIK_Canopy]
+n_imp_subformS [definition, in K.Interpolation.UIK_Canopy]
+n_imp_subformLF [definition, in K.Interpolation.UIK_Canopy]
+n_imp_subformF [definition, in K.Interpolation.UIK_Canopy]
+N.p [variable, in GL.Interpolation.UIGL_braga]
+

O

+obviously_smaller [definition, in ISL.Environments]
+obviously_smaller_compatible_GT [lemma, in ISL.Optimizations]
+obviously_smaller_compatible_LT [lemma, in ISL.Optimizations]
+occurs_in_map_open_box [lemma, in ISL.Environments]
+occurs_in_open_boxes [lemma, in ISL.Environments]
+occurs_in_make_impl2 [lemma, in ISL.Environments]
+occurs_in_make_impl [lemma, in ISL.Environments]
+occurs_in_make_disj [lemma, in ISL.Environments]
+occurs_in_make_conj [lemma, in ISL.Environments]
+occurs_in [definition, in ISL.Formulas]
+openboxes_env_order [lemma, in ISL.Order]
+open_boxes_case [lemma, in ISL.SequentProps]
+open_boxes_R [lemma, in ISL.SequentProps]
+open_box_L [lemma, in ISL.SequentProps]
+open_boxes_env_order [lemma, in ISL.Order]
+open_boxes_spec' [lemma, in ISL.Environments]
+open_boxes_spec [lemma, in ISL.Environments]
+open_boxes_remove [lemma, in ISL.Environments]
+open_boxes_add [lemma, in ISL.Environments]
+open_boxes_singleton [lemma, in ISL.Environments]
+open_boxes_disj_union [lemma, in ISL.Environments]
+open_boxes_empty [lemma, in ISL.Environments]
+open_boxes [definition, in ISL.Environments]
+open_box [definition, in ISL.Environments]
+Optimizations [library]
+Or [definition, in Syntax.CML_Syntax]
+Or [constructor, in ISL.Formulas]
+Order [library]
+OrL [constructor, in ISL.Sequents]
+OrL [lemma, in K.Interpolation.UIK_UI_prelims]
+OrL [lemma, in GL.Interpolation.UIGL_And_Or_rules]
+OrL_inv [lemma, in GL.Interpolation.UIGL_And_Or_rules]
+OrL_rev [lemma, in ISL.SequentProps]
+OrR [lemma, in K.Interpolation.UIK_UI_prelims]
+OrR [lemma, in GL.Interpolation.UIGL_And_Or_rules]
+OrR_inv [lemma, in GL.Interpolation.UIGL_And_Or_rules]
+OrR_idemp [lemma, in ISL.Optimizations]
+OrR1 [constructor, in ISL.Sequents]
+OrR1Bot_rev [lemma, in ISL.SequentProps]
+OrR2 [constructor, in ISL.Sequents]
+OrR2Bot_rev [lemma, in ISL.SequentProps]
+or_assoc_ctx_R_R [lemma, in ISL.Simp]
+or_assoc_ctx_R_L [lemma, in ISL.Simp]
+or_assoc_ctx_L_R [lemma, in ISL.Simp]
+or_assoc_L [lemma, in ISL.Simp]
+or_assoc_R [lemma, in ISL.Simp]
+or_comm_ctx_R [lemma, in ISL.Simp]
+or_comm_ctx_L [lemma, in ISL.Simp]
+or_comm [lemma, in ISL.Simp]
+or_false [lemma, in General.gen]
+or_congruence [lemma, in ISL.Optimizations]
+

P

+pair_eqI [lemma, in General.gen]
+partition_singleton_app [lemma, in General.List_lemmasT]
+partition_2_3 [lemma, in General.List_lemmasT]
+partition_3_2 [lemma, in General.List_lemmasT]
+partition_2_2T [lemma, in General.List_lemmasT]
+partition_2_2 [lemma, in General.List_lemmasT]
+partition_1_element2 [lemma, in Syntax.list_lems]
+partition_1_element [lemma, in Syntax.list_lems]
+permT_trans [constructor, in GL.Interpolation.UIGL_PermutationT]
+permT_swap [constructor, in GL.Interpolation.UIGL_PermutationT]
+permT_skip [constructor, in GL.Interpolation.UIGL_PermutationT]
+permT_nil [constructor, in GL.Interpolation.UIGL_PermutationT]
+PermutationT [inductive, in GL.Interpolation.UIGL_PermutationT]
+PermutationT [section, in GL.Interpolation.UIGL_PermutationT]
+PermutationTS [definition, in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_nodupseq [lemma, in GL.Interpolation.UIGL_nodupseq]
+PermutationTS_Canopy [lemma, in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_usable_boxes [lemma, in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_critic [lemma, in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_is_init [lemma, in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_GLR_prems [lemma, in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_restr_list_prop_fst [lemma, in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_restr_list_prop_snd [lemma, in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_prv [lemma, in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_prv_hpadm [lemma, in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_sym [lemma, in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_UI [lemma, in GL.Interpolation.UIGL_UI_inter]
+PermutationT_ind_T [lemma, in GL.Interpolation.UIGL_PermutationT]
+PermutationT_cons_app [lemma, in GL.Interpolation.UIGL_PermutationT]
+PermutationT_app_comm [lemma, in GL.Interpolation.UIGL_PermutationT]
+PermutationT_cons_append [lemma, in GL.Interpolation.UIGL_PermutationT]
+PermutationT_app [lemma, in GL.Interpolation.UIGL_PermutationT]
+PermutationT_app_head [lemma, in GL.Interpolation.UIGL_PermutationT]
+PermutationT_app_tail [lemma, in GL.Interpolation.UIGL_PermutationT]
+PermutationT_sym [lemma, in GL.Interpolation.UIGL_PermutationT]
+PermutationT_refl [lemma, in GL.Interpolation.UIGL_PermutationT]
+PermutationT_sind [definition, in GL.Interpolation.UIGL_PermutationT]
+PermutationT_rec [definition, in GL.Interpolation.UIGL_PermutationT]
+PermutationT_ind [definition, in GL.Interpolation.UIGL_PermutationT]
+PermutationT_rect [definition, in GL.Interpolation.UIGL_PermutationT]
+PermutationT_nodupseq [lemma, in GL.Interpolation.UIGL_PermutationTS]
+PermutationT_top_boxes [lemma, in GL.Interpolation.UIGL_PermutationTS]
+PermutationT_XBoxed_list [lemma, in GL.Interpolation.UIGL_PermutationTS]
+Permutation_replace [lemma, in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+Permutation_remove [lemma, in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+Permutation_repeat_extract [lemma, in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+Permutation_replace_repeat [lemma, in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+Permutation_PermutationT [lemma, in GL.Interpolation.UIGL_PermutationT]
+Permutation_vs_cons_invT [lemma, in GL.Interpolation.UIGL_PermutationT]
+Permutation_vs_elt_invT [lemma, in GL.Interpolation.UIGL_PermutationT]
+Permutation_subform_boxesLF [lemma, in GL.Interpolation.UIGL_PermutationTS]
+permut_remove_remove_list [lemma, in Syntax.remove_list_lems]
+permut_remove [lemma, in Syntax.remove_list_lems]
+PiffD1 [lemma, in General.gen]
+PiffD2 [lemma, in General.gen]
+pointed_env_ms_order [definition, in ISL.Order]
+pointed_env_order [definition, in ISL.Order]
+pointed_env [definition, in ISL.Order]
+pos_top_imps [definition, in GL.GLS.GLS_der_dec]
+pos_top_imps [definition, in K.KS.KS_termination_prelims]
+pow5_gt_0 [lemma, in ISL.Order]
+pq_correct [lemma, in ISL.PropQuantifiers]
+prems_Box_R [definition, in GL.GLS.GLS_der_dec]
+prems_Imp_L [definition, in GL.GLS.GLS_der_dec]
+prems_Imp_R [definition, in GL.GLS.GLS_der_dec]
+prems_Box_R [definition, in K.KS.KS_termination_KR]
+prems_dersrec [lemma, in General.ddT]
+prems_Imp_L [definition, in K.KS.KS_termination_ImpL]
+prems_Imp_R [definition, in K.KS.KS_termination_ImpR]
+prod_nat_split [lemma, in General.genT]
+prod_mono [lemma, in General.genT]
+proj1_sigT2 [definition, in GL.GLS.GLS_der_dec]
+proj1_sigT2 [definition, in K.KS.KS_termination_prelims]
+proj2_sigT2 [definition, in GL.GLS.GLS_der_dec]
+proj2_sigT2 [definition, in K.KS.KS_termination_prelims]
+Proof_tree_dec [lemma, in ISL.DecisionProcedure]
+proper_Provable [instance, in ISL.Sequents]
+Proper_env_order_refl [instance, in ISL.Order]
+Proper_env_order [instance, in ISL.Order]
+Proper_env_order_refl_env_weight [instance, in ISL.Order]
+Proper_env_weight [instance, in ISL.Order]
+Proper_elements [instance, in ISL.Environments]
+proper_open_boxes [instance, in ISL.Environments]
+proper_difference [instance, in ISL.Environments]
+proper_disj_union [instance, in ISL.Environments]
+proper_elem_of [instance, in ISL.Environments]
+proper_rm [instance, in ISL.DecisionProcedure]
+PropQuantifiers [library]
+propvar_subform_list_restr_list_prop [lemma, in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_Canopy [lemma, in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_witnessT [lemma, in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_witness [lemma, in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_disj [lemma, in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_conj [lemma, in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_top_boxes [lemma, in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_nobox_gen_ext [lemma, in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_unboxed_list [lemma, in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_app [lemma, in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list [definition, in K.Interpolation.UIK_UI_prelims]
+propvar_subform [definition, in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_nobox_gen_ext [lemma, in K.Interpolation.K_Craig_Interp]
+propvar_subform_list_unboxed_list [lemma, in K.Interpolation.K_Craig_Interp]
+propvar_subform_list_app [lemma, in K.Interpolation.K_Craig_Interp]
+propvar_subform_list [definition, in K.Interpolation.K_Craig_Interp]
+propvar_subform [definition, in K.Interpolation.K_Craig_Interp]
+propvar_subform_list_nodup [lemma, in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_restr_list_prop [lemma, in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_Canopy [lemma, in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_witnessT [lemma, in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_witness [lemma, in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_disj [lemma, in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_conj [lemma, in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_top_boxes [lemma, in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_nobox_gen_ext [lemma, in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_XBoxed_list [lemma, in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_app [lemma, in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list [definition, in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform [definition, in GL.Interpolation.UIGL_UI_prelims]
+Prop_Subform [section, in K.Interpolation.UIK_UI_prelims]
+Prop_Subform [section, in GL.Interpolation.UIGL_UI_prelims]
+Provable [inductive, in ISL.Sequents]
+Provable_sind [definition, in ISL.Sequents]
+Provable_rec [definition, in ISL.Sequents]
+Provable_ind [definition, in ISL.Sequents]
+Provable_rect [definition, in ISL.Sequents]
+Provable_dec [lemma, in ISL.DecisionProcedure]
+p_contr [lemma, in ISL.SequentProps]
+

R

+radm [inductive, in General.gstep]
+radmD [definition, in General.gstep]
+radmI [constructor, in General.gstep]
+radm_sind [definition, in General.gstep]
+radm_rec [definition, in General.gstep]
+radm_ind [definition, in General.gstep]
+radm_rect [definition, in General.gstep]
+Random [section, in K.Interpolation.UIK_basics]
+Random [section, in GL.Interpolation.UIGL_basics]
+rappl [lemma, in General.gen]
+RA_mhd_decreases [lemma, in K.KS.KS_termination]
+rec_UI_imp [lemma, in GL.Interpolation.UIGL_N_imp_UI]
+redundant_flatten_list [lemma, in GL.GLS.GLS_der_dec]
+redundant_flatten_list [lemma, in K.KS.KS_termination_prelims]
+redund_remove_list [lemma, in Syntax.remove_list_lems]
+redund_remove [lemma, in Syntax.remove_list_lems]
+redund_remove_remove_list [lemma, in Syntax.remove_list_lems]
+Reflexive_Transitive_ClosureT.R [variable, in General.rtcT]
+Reflexive_Transitive_ClosureT.A [variable, in General.rtcT]
+Reflexive_Transitive_ClosureT [section, in General.rtcT]
+Reflexive_ClosureT.R [variable, in General.rtcT]
+Reflexive_ClosureT.A [variable, in General.rtcT]
+Reflexive_ClosureT [section, in General.rtcT]
+rel [definition, in General.gen_tacs]
+relationT [definition, in General.genT]
+relmap [inductive, in General.gen_seq]
+relmap_sind [definition, in General.gen_seq]
+relmap_rec [definition, in General.gen_seq]
+relmap_ind [definition, in General.gen_seq]
+relmap_rect [definition, in General.gen_seq]
+rel_adm_rtc [lemma, in General.gstep]
+rel_admD [definition, in General.gstep]
+rel_adm_sind [definition, in General.gstep]
+rel_adm_rec [definition, in General.gstep]
+rel_adm_ind [definition, in General.gstep]
+rel_adm_rect [definition, in General.gstep]
+rel_admI [constructor, in General.gstep]
+rel_adm [inductive, in General.gstep]
+removed_box_exists [lemma, in GL.GLS.GLS_termination_measure]
+remove_n_imp_subformLF_decomp [lemma, in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+remove_n_imp_subformLF [lemma, in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+remove_list_decr_in [lemma, in K.Interpolation.UIK_UI_prelims]
+remove_nth [definition, in GL.GLS.GLS_der_dec]
+remove_nth [definition, in K.KS.KS_termination_prelims]
+remove_Permutation [lemma, in GL.Interpolation.UIGL_nodupseq]
+remove_list_incr_decr [lemma, in Syntax.remove_list_lems]
+remove_list_incr_decr4 [lemma, in Syntax.remove_list_lems]
+remove_list_incr_decr2 [lemma, in Syntax.remove_list_lems]
+remove_list_incr_decr1 [lemma, in Syntax.remove_list_lems]
+remove_list_incr_decr3 [lemma, in Syntax.remove_list_lems]
+remove_delete_origin [lemma, in Syntax.remove_list_lems]
+remove_list_is_nil [lemma, in Syntax.remove_list_lems]
+remove_list_in_nil [lemma, in Syntax.remove_list_lems]
+remove_list_delete_head_In [lemma, in Syntax.remove_list_lems]
+remove_list_delete_head [lemma, in Syntax.remove_list_lems]
+remove_list_non_empty_inter_smaller_length [lemma, in Syntax.remove_list_lems]
+remove_list_singl_id_or_nil [lemma, in Syntax.remove_list_lems]
+remove_list_is_in [lemma, in Syntax.remove_list_lems]
+remove_list_in_single [lemma, in Syntax.remove_list_lems]
+remove_list_dist_app [lemma, in Syntax.remove_list_lems]
+remove_list_cont [lemma, in Syntax.remove_list_lems]
+remove_list_preserv_NoDup [lemma, in Syntax.remove_list_lems]
+remove_list_of_nil [lemma, in Syntax.remove_list_lems]
+remove_list [definition, in Syntax.remove_list_lems]
+remove_In_smaller_length [lemma, in Syntax.remove_list_lems]
+remove_le_length [lemma, in Syntax.remove_list_lems]
+remove_preserv_NoDup [lemma, in Syntax.remove_list_lems]
+remove_not_in_anymore [lemma, in Syntax.remove_list_lems]
+remove_dist_app [lemma, in Syntax.remove_list_lems]
+remove_rest_gen_ext [lemma, in GL.GLS.GLS_inv_ImpR_ImpL]
+remove_list_decr_in [lemma, in GL.Interpolation.UIGL_UI_prelims]
+remove_In_env_order [lemma, in ISL.Order]
+remove_In_env_order_refl [lemma, in ISL.Order]
+remove_env_order [lemma, in ISL.Order]
+remove_add_rest_gen_ext [lemma, in GL.GLS.GLS_dec]
+remove_include [lemma, in ISL.Environments]
+remove_rest_gen_ext [lemma, in K.KS.KS_inv_ImpR_ImpL]
+remove_list_lems [library]
+repeat_S [lemma, in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+repeat_n_imp_subformLF [lemma, in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+repeat_more_than_one [lemma, in GL.Interpolation.UIGL_Canopy_ImpL]
+replace [definition, in GL.Interpolation.UIGL_Canopy_ImpR]
+replace_n_imp_subformLF [lemma, in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+replace_app [lemma, in GL.Interpolation.UIGL_Canopy_ImpR]
+req [definition, in General.gen]
+req_trans [lemma, in General.gen]
+req_sym [lemma, in General.gen]
+req_refl [lemma, in General.gen]
+restr_list_prop [definition, in K.Interpolation.UIK_basics]
+restr_list_prop [definition, in GL.Interpolation.UIGL_basics]
+restr_list_prop_nodup [lemma, in GL.Interpolation.UIGL_UI_prelims]
+rest_gen_ext [definition, in General.univ_gen_ext]
+rest_nobox_gen_ext_trans [lemma, in GL.GLS.GLS_inv_ImpR_ImpL]
+rest_nobox_gen_ext_trans [lemma, in K.KS.KS_inv_ImpR_ImpL]
+rev_pair [definition, in General.gen_seq]
+RHS_top_box_is_subform [lemma, in GL.GLS.GLS_termination_measure]
+RHS_top_box_is_subformLF [lemma, in GL.GLS.GLS_termination_measure]
+rlI [constructor, in General.gen_seq]
+rlI_eq [lemma, in General.gen_seq]
+rls [definition, in General.gen]
+rlsmap [inductive, in General.gen_seq]
+rlsmap_sind [definition, in General.gen_seq]
+rlsmap_rec [definition, in General.gen_seq]
+rlsmap_ind [definition, in General.gen_seq]
+rlsmap_rect [definition, in General.gen_seq]
+rlsT [definition, in General.genT]
+rm [definition, in ISL.Environments]
+rmI [constructor, in General.gen_seq]
+rmI_eq [lemma, in General.gen_seq]
+rm_mono [lemma, in General.gen_seq]
+rsub [definition, in General.gen]
+rsubD [definition, in General.gen]
+rsubI [definition, in General.gen]
+rsub_adm [definition, in General.ddT]
+rsub_derl_adm [definition, in General.ddT]
+rsub_derl [definition, in General.ddT]
+rsub_imp [definition, in General.gen]
+rsub_id [lemma, in General.gen]
+rsub_trans [lemma, in General.gen]
+rsub_def [lemma, in General.gen]
+rsub_emptyT [lemma, in General.genT]
+rtcT [library]
+rtn1T_trans [constructor, in General.rtcT]
+rtn1T_refl [constructor, in General.rtcT]
+rtT_trans [constructor, in General.rtcT]
+rtT_refl [constructor, in General.rtcT]
+rtT_step [constructor, in General.rtcT]
+rT_refl [constructor, in General.rtcT]
+rT_step [constructor, in General.rtcT]
+rt1nT_trans [constructor, in General.rtcT]
+rt1nT_refl [constructor, in General.rtcT]
+rUnI [constructor, in General.gstep]
+rUnion [inductive, in General.gstep]
+runion [inductive, in General.gstep]
+rUnion_sind [definition, in General.gstep]
+rUnion_rec [definition, in General.gstep]
+rUnion_ind [definition, in General.gstep]
+rUnion_rect [definition, in General.gstep]
+runion_sind [definition, in General.gstep]
+runion_rec [definition, in General.gstep]
+runion_ind [definition, in General.gstep]
+runion_rect [definition, in General.gstep]
+run_r [constructor, in General.gstep]
+run_l [constructor, in General.gstep]
+

S

+Sctxt [constructor, in General.gen_seq]
+Sctxt_nil [lemma, in General.gen_seq]
+Sctxt_e' [lemma, in General.gen_seq]
+Sctxt_alt [lemma, in General.gen_seq]
+Sctxt_s [constructor, in General.gen_seq]
+Sctxt_eq [lemma, in General.gen_seq]
+Sctxt_e [lemma, in General.gen_seq]
+Sctxt' [constructor, in General.gen_seq]
+Seq [definition, in GL.GLS.GLS_calcs]
+Seq [definition, in K.KS.KS_calc]
+seqext [definition, in General.gen_seq]
+seqext_defp [lemma, in General.gen_seq]
+seqext_def [lemma, in General.gen_seq]
+seqext_seqext [lemma, in General.gen_seq]
+seqrule [inductive, in General.gen_seq]
+seqrule_mono' [definition, in General.gen_seq]
+seqrule_mono [lemma, in General.gen_seq]
+seqrule_same [lemma, in General.gen_seq]
+seqrule_s_sind [definition, in General.gen_seq]
+seqrule_s_rec [definition, in General.gen_seq]
+seqrule_s_ind [definition, in General.gen_seq]
+seqrule_s_rect [definition, in General.gen_seq]
+seqrule_s [inductive, in General.gen_seq]
+seqrule_derl_seqrule' [definition, in General.gen_seq]
+seqrule_derl_seqrule [lemma, in General.gen_seq]
+seqrule_seqrule' [definition, in General.gen_seq]
+seqrule_seqrule [lemma, in General.gen_seq]
+seqrule_id [lemma, in General.gen_seq]
+seqrule_sind [definition, in General.gen_seq]
+seqrule_rec [definition, in General.gen_seq]
+seqrule_ind [definition, in General.gen_seq]
+seqrule_rect [definition, in General.gen_seq]
+seqrule' [inductive, in General.gen_seq]
+seqrule'_sind [definition, in General.gen_seq]
+seqrule'_rec [definition, in General.gen_seq]
+seqrule'_ind [definition, in General.gen_seq]
+seqrule'_rect [definition, in General.gen_seq]
+seqs_in_splitT [definition, in Syntax.list_lems]
+SequentProps [library]
+Sequents [library]
+ser_mono [lemma, in General.gen_seq]
+set_leq_ub_unif [lemma, in GL.Interpolation.UIGL_UI_prelims]
+sextI [constructor, in General.gen_seq]
+sext_rev_fext [lemma, in General.gen_seq]
+sext_e [lemma, in General.gen_seq]
+se_single [constructor, in General.gen_seq]
+se_empty [constructor, in General.gen_seq]
+simp [definition, in ISL.Simp]
+Simp [library]
+simp_equiv [lemma, in ISL.Simp]
+simp_equiv_box [lemma, in ISL.Simp]
+simp_equiv_imp [lemma, in ISL.Simp]
+simp_equiv_imp_R [lemma, in ISL.Simp]
+simp_equiv_imp_L [lemma, in ISL.Simp]
+simp_imps_self_equiv_R [lemma, in ISL.Simp]
+simp_imps_self_equiv_L [lemma, in ISL.Simp]
+simp_imp_self_equiv_R [lemma, in ISL.Simp]
+simp_imp_self_equiv_L [lemma, in ISL.Simp]
+simp_equiv_and [lemma, in ISL.Simp]
+simp_equiv_and_R [lemma, in ISL.Simp]
+simp_equiv_and_L [lemma, in ISL.Simp]
+simp_ands_self_equiv_R [lemma, in ISL.Simp]
+simp_ands_self_equiv_L [lemma, in ISL.Simp]
+simp_equiv_or [lemma, in ISL.Simp]
+simp_equiv_or_R [lemma, in ISL.Simp]
+simp_ors_self_equiv_R [lemma, in ISL.Simp]
+simp_equiv_or_L [lemma, in ISL.Simp]
+simp_ors_self_equiv_L [lemma, in ISL.Simp]
+simp_imps [definition, in ISL.Simp]
+simp_imp [definition, in ISL.Simp]
+simp_ands [definition, in ISL.Simp]
+simp_ors [definition, in ISL.Simp]
+single [definition, in General.swappedT]
+singleton [instance, in ISL.Environments]
+singletonMS [instance, in ISL.Environments]
+singleton_mult_notin [lemma, in ISL.Environments]
+singleton_mult_in [lemma, in ISL.Environments]
+single_eq_listT_nobrac [definition, in General.List_lemmasT]
+single_eq_listT [definition, in General.List_lemmasT]
+single_eq_list [definition, in General.List_lemmasT]
+single_eq [lemma, in General.swappedT]
+sing_empty_app_cons [lemma, in General.gen_seq]
+sing_empty_app [lemma, in General.gen_seq]
+sing_empty_sind [definition, in General.gen_seq]
+sing_empty_rec [definition, in General.gen_seq]
+sing_empty_ind [definition, in General.gen_seq]
+sing_empty_rect [definition, in General.gen_seq]
+sing_empty [inductive, in General.gen_seq]
+size [definition, in Syntax.CML_Syntax]
+size_LF_nil_unbox_top_box [lemma, in K.Interpolation.UIK_basics]
+size_LF [definition, in Syntax.CML_Syntax]
+size_step2_tr_lem [lemma, in General.gentree]
+size_step2_tr [definition, in General.gentree]
+size_top_boxes [lemma, in K.KS.KS_termination_measure]
+size_unboxed [lemma, in K.KS.KS_termination_measure]
+size_nobox_gen_ext [lemma, in K.KS.KS_termination_measure]
+size_LF_dist_app [lemma, in K.KS.KS_termination_measure]
+snd_rel_sind [definition, in General.gen_seq]
+snd_rel_rec [definition, in General.gen_seq]
+snd_rel_ind [definition, in General.gen_seq]
+snd_rel_rect [definition, in General.gen_seq]
+snd_relI [constructor, in General.gen_seq]
+snd_rel [inductive, in General.gen_seq]
+snd_fst_ext [lemma, in General.gen_seq]
+snd_ext_rls_sind [definition, in General.gen_seq]
+snd_ext_rls_rec [definition, in General.gen_seq]
+snd_ext_rls_ind [definition, in General.gen_seq]
+snd_ext_rls_rect [definition, in General.gen_seq]
+snd_ext_rls [inductive, in General.gen_seq]
+specialised_weakening [lemma, in ISL.Optimizations]
+sr_Id_alt [lemma, in General.gen_seq]
+string_dec [instance, in ISL.Formulas]
+strongness [lemma, in ISL.Optimizations]
+SubAnd [constructor, in ISL.Formulas]
+SubBox [constructor, in ISL.Formulas]
+SubEq [constructor, in ISL.Formulas]
+subform [inductive, in ISL.Formulas]
+subformlist [definition, in Syntax.CML_Syntax]
+subform_boxesLF_dist_app [lemma, in GL.GLS.GLS_termination_measure]
+subform_boxesS [definition, in GL.GLS.GLS_termination_measure]
+subform_boxesLF [definition, in GL.GLS.GLS_termination_measure]
+subform_boxesF [definition, in GL.GLS.GLS_termination_measure]
+subform_boxesLF_nodup [lemma, in GL.Interpolation.UIGL_UI_prelims]
+subform_boxesLF_top_boxes [lemma, in GL.Interpolation.UIGL_LexSeq]
+subform_sind [definition, in ISL.Formulas]
+subform_ind [definition, in ISL.Formulas]
+SubImpl [constructor, in ISL.Formulas]
+subl_of_boxl_is_boxl [lemma, in Syntax.CML_Syntax]
+SubOr [constructor, in ISL.Formulas]
+subst [definition, in Syntax.CML_Syntax]
+subst_dep [lemma, in General.List_lemmasT]
+sumh_step2_tr_lem [lemma, in General.gentree]
+sumh_step2_tr [definition, in General.gentree]
+sum_step2_tr_lem [lemma, in General.gentree]
+sum_step2_tr_D_gf2 [definition, in General.gentree]
+sum_step2_tr_gf2 [lemma, in General.gentree]
+sum_step2_tr [definition, in General.gentree]
+swapped [inductive, in General.swappedT]
+swappedT [library]
+swapped_gen_refl [lemma, in General.swappedT]
+swapped_gen_app_L [lemma, in General.swappedT]
+swapped__gen [lemma, in General.swappedT]
+swapped_spec_opp [lemma, in General.swappedT]
+swapped_gen_front_mid [lemma, in General.swappedT]
+swapped_gen_sind [definition, in General.swappedT]
+swapped_gen_rec [definition, in General.swappedT]
+swapped_gen_ind [definition, in General.swappedT]
+swapped_gen_rect [definition, in General.swappedT]
+swapped_gen_I [constructor, in General.swappedT]
+swapped_gen [inductive, in General.swappedT]
+swapped__n_mid [lemma, in General.swappedT]
+swapped_spec_front_mid [lemma, in General.swappedT]
+swapped_app_mid_R [lemma, in General.swappedT]
+swapped_app_mid_L [lemma, in General.swappedT]
+swapped_spec_conv [lemma, in General.swappedT]
+swapped_spec_comm [lemma, in General.swappedT]
+swapped_spec_trans_exact [lemma, in General.swappedT]
+swapped_spec_trans [lemma, in General.swappedT]
+swapped_app_L [lemma, in General.swappedT]
+swapped_spec_refl [lemma, in General.swappedT]
+swapped_spec_sind [definition, in General.swappedT]
+swapped_spec_rec [definition, in General.swappedT]
+swapped_spec_ind [definition, in General.swappedT]
+swapped_spec_rect [definition, in General.swappedT]
+swapped_spec_step [constructor, in General.swappedT]
+swapped_spec_I [constructor, in General.swappedT]
+swapped_spec [inductive, in General.swappedT]
+swapped_map [lemma, in General.swappedT]
+swapped_map_ex [lemma, in General.swappedT]
+swapped_ca2 [lemma, in General.swappedT]
+swapped_ca1 [lemma, in General.swappedT]
+swapped_Rc1 [lemma, in General.swappedT]
+swapped_Rc2 [lemma, in General.swappedT]
+swapped_comm [lemma, in General.swappedT]
+swapped_simpleR [lemma, in General.swappedT]
+swapped_simpleL [lemma, in General.swappedT]
+swapped_simple' [lemma, in General.swappedT]
+swapped_simple [lemma, in General.swappedT]
+swapped_singleRE [lemma, in General.swappedT]
+swapped_singleLE [lemma, in General.swappedT]
+swapped_nilRE [lemma, in General.swappedT]
+swapped_nilLE [lemma, in General.swappedT]
+swapped_single [definition, in General.swappedT]
+swapped_cons [lemma, in General.swappedT]
+swapped_R [lemma, in General.swappedT]
+swapped_L [lemma, in General.swappedT]
+swapped_same [lemma, in General.swappedT]
+swapped_I' [lemma, in General.swappedT]
+swapped_sind [definition, in General.swappedT]
+swapped_rec [definition, in General.swappedT]
+swapped_ind [definition, in General.swappedT]
+swapped_rect [definition, in General.swappedT]
+swapped_I [constructor, in General.swappedT]
+swap_remove_list [lemma, in Syntax.remove_list_lems]
+Syntax_export [library]
+S_le_False [lemma, in GL.GLS.GLS_termination_measure]
+

T

+tail_inv_singleton2 [lemma, in General.List_lemmasT]
+tail_inv_singleton [lemma, in General.List_lemmasT]
+tautology_cut [lemma, in ISL.Optimizations]
+term_IH_help [lemma, in K.KS.KS_termination]
+term_meas_is_0 [lemma, in K.KS.KS_termination_measure]
+tl_of_boxl_is_boxl [lemma, in Syntax.CML_Syntax]
+Top [definition, in Syntax.CML_Syntax]
+TopL_remove [lemma, in K.Interpolation.UIK_UI_prelims]
+TopL_remove [lemma, in GL.Interpolation.UIGL_And_Or_rules]
+TopL_rev [lemma, in ISL.SequentProps]
+TopR [lemma, in K.Interpolation.UIK_UI_prelims]
+TopR [lemma, in GL.Interpolation.UIGL_And_Or_rules]
+top_boxes_Canopy_noless_ub [lemma, in GL.Interpolation.UIGL_Diam_UI_imp_N_prelim]
+top_boxes_nobox_gen_ext [definition, in GL.GLS.GLS_der_dec]
+top_imps [definition, in GL.GLS.GLS_der_dec]
+top_boxes_nobox_gen_ext [definition, in K.KS.KS_termination_prelims]
+top_imps [definition, in K.KS.KS_termination_prelims]
+top_boxes_distr_app [lemma, in Syntax.CML_Syntax]
+top_boxes [definition, in Syntax.CML_Syntax]
+top_boxes_incl_list [lemma, in GL.GLS.GLS_termination_measure]
+top_boxes_diam_jump [lemma, in GL.Interpolation.UIGL_UI_prelims]
+top_boxes_facts [section, in GL.Interpolation.UIGL_UI_prelims]
+top_boxes_nodup [lemma, in GL.Interpolation.UIGL_UI_prelims]
+top_boxes_XBoxed_list [lemma, in GL.Interpolation.UIGL_LexSeq]
+top_boxes_incl_list [lemma, in K.KS.KS_dec]
+top_provable [lemma, in ISL.Optimizations]
+transitiveT [definition, in General.rtcT]
+transitiveT [definition, in General.genT]
+transitive_form_order [instance, in ISL.Formulas]
+trf [definition, in General.gen_tacs]
+trf_rules_derl [lemma, in General.gstep]
+trf_rules_rtc [lemma, in General.gstep]
+true_and [lemma, in General.gen]
+

U

+ub_nodupseq [lemma, in GL.Interpolation.UIGL_nodupseq]
+ub_stable [lemma, in GL.Interpolation.UIGL_UI_prelims]
+UI [definition, in K.Interpolation.UIK_braga]
+UI [section, in K.Interpolation.UIK_braga]
+UI [definition, in GL.Interpolation.UIGL_braga]
+UI [section, in GL.Interpolation.UIGL_braga]
+UIGL_And_Or_rules [library]
+UIGL_Diam_UI_imp_N_prelim [library]
+UIGL_irred_short [library]
+UIGL_Canopy_nodupseq_perm [library]
+UIGL_Canopy_ImpL [library]
+UIGL_irred_high_level [library]
+UIGL_UIDiam_N [library]
+UIGL_Diam_N_imp_UI [library]
+UIGL_UIOne [library]
+UIGL_braga [library]
+UIGL_Diam_UI_imp_N [library]
+UIGL_Canopy [library]
+UIGL_Canopy_ImpR [library]
+UIGL_UIThree [library]
+UIGL_nodupseq [library]
+UIGL_basics [library]
+UIGL_UITwo [library]
+UIGL_PermutationT [library]
+UIGL_UI_inter [library]
+UIGL_PermutationTS [library]
+UIGL_UI_prelims [library]
+UIGL_Def_measure [library]
+UIGL_LexSeq [library]
+UIGL_N_imp_UI [library]
+UIK_irred_high_level [library]
+UIK_irred_short [library]
+UIK_UIOne [library]
+UIK_UI_prelims [library]
+UIK_Canopy [library]
+UIK_UITwo [library]
+UIK_basics [library]
+UIK_UIThree [library]
+UIK_braga [library]
+UIK_Def_measure [library]
+UIML_extraction [library]
+UIPDiam [section, in GL.Interpolation.UIGL_UIDiam_N]
+UIPOne [section, in K.Interpolation.UIK_UIOne]
+UIPOne [section, in GL.Interpolation.UIGL_UIOne]
+UIPThree [section, in K.Interpolation.UIK_UIThree]
+UIPThree [section, in GL.Interpolation.UIGL_UIThree]
+UIPTwo [section, in K.Interpolation.UIK_UITwo]
+UIPTwo [section, in GL.Interpolation.UIGL_UITwo]
+UI_One [lemma, in K.Interpolation.UIK_UIOne]
+UI_GUI [lemma, in K.Interpolation.UIK_braga]
+UI_spec [lemma, in K.Interpolation.UIK_braga]
+UI_GUI [lemma, in GL.Interpolation.UIGL_braga]
+UI_spec [lemma, in GL.Interpolation.UIGL_braga]
+UI_Diam_rec_imp [lemma, in GL.Interpolation.UIGL_Diam_UI_imp_N]
+UI_Two [lemma, in K.Interpolation.UIK_UITwo]
+UI_Three [lemma, in K.Interpolation.UIK_UIThree]
+UI_Two [lemma, in GL.Interpolation.UIGL_UITwo]
+UI_nodupseq_gen [lemma, in GL.Interpolation.UIGL_UI_inter]
+UI_nodupseq_converse [lemma, in GL.Interpolation.UIGL_UI_inter]
+UI_nodupseq [lemma, in GL.Interpolation.UIGL_UI_inter]
+UI_Three [lemma, in GL.Interpolation.UIGL_UIThree]
+UI_One [lemma, in GL.Interpolation.UIGL_UIOne]
+UI.p [variable, in K.Interpolation.UIK_braga]
+UI.p [variable, in GL.Interpolation.UIGL_braga]
+UI.UI_pwc [variable, in K.Interpolation.UIK_braga]
+UI.UI_pwc [variable, in GL.Interpolation.UIGL_braga]
+unboxed_list_In_unfold [lemma, in K.Interpolation.UIK_UI_prelims]
+unboxed_list_In [lemma, in K.Interpolation.UIK_UI_prelims]
+unboxed_list [definition, in Syntax.CML_Syntax]
+unbox_app_distrib [lemma, in Syntax.CML_Syntax]
+unBox_formula [definition, in Syntax.CML_Syntax]
+UniformInterpolation [section, in ISL.PropQuantifiers]
+UniformInterpolation.Correctness [section, in ISL.PropQuantifiers]
+UniformInterpolation.Correctness.EntailmentCorrect [section, in ISL.PropQuantifiers]
+UniformInterpolation.Correctness.PropQuantCorrect [section, in ISL.PropQuantifiers]
+UniformInterpolation.Correctness.VariablesCorrect [section, in ISL.PropQuantifiers]
+UniformInterpolation.p [variable, in ISL.PropQuantifiers]
+UniformInterpolation.PropQuantDefinition [section, in ISL.PropQuantifiers]
+_ • _ [notation, in ISL.PropQuantifiers]
+□⁻¹ _ [notation, in ISL.PropQuantifiers]
+union_difference_R [lemma, in ISL.Environments]
+union_difference_L [lemma, in ISL.Environments]
+union_mult [lemma, in ISL.Environments]
+unit_eq_appT2 [definition, in General.List_lemmasT]
+unit_eq_app [definition, in General.List_lemmasT]
+unit_eq_appT [lemma, in General.gen_tacs]
+univ_gen_ext_n_imp_subform [lemma, in GL.Interpolation.UIGL_Canopy_ImpR]
+univ_gen_ext_more_occ [lemma, in GL.Interpolation.UIGL_Canopy_ImpR]
+univ_gen_ext_S_count_occ [lemma, in GL.Interpolation.UIGL_Canopy_ImpR]
+univ_gen_ext_count_occ [lemma, in GL.Interpolation.UIGL_Canopy_ImpR]
+univ_gen_mod_smaller_length [lemma, in General.univ_gen_mod]
+univ_gen_mod_In [lemma, in General.univ_gen_mod]
+univ_gen_mod_elem_deep [lemma, in General.univ_gen_mod]
+univ_gen_mod_same_hd [lemma, in General.univ_gen_mod]
+univ_gen_mod_combine [lemma, in General.univ_gen_mod]
+univ_gen_mod_splitR [lemma, in General.univ_gen_mod]
+univ_gen_mod_splitL [lemma, in General.univ_gen_mod]
+univ_gen_mod_lem [lemma, in General.univ_gen_mod]
+univ_gen_mod_refl [lemma, in General.univ_gen_mod]
+univ_gen_mod_sind [definition, in General.univ_gen_mod]
+univ_gen_mod_rec [definition, in General.univ_gen_mod]
+univ_gen_mod_ind [definition, in General.univ_gen_mod]
+univ_gen_mod_rect [definition, in General.univ_gen_mod]
+univ_gen_mod_modif [constructor, in General.univ_gen_mod]
+univ_gen_mod_cons [constructor, in General.univ_gen_mod]
+univ_gen_mod_nil [constructor, in General.univ_gen_mod]
+univ_gen_mod [inductive, in General.univ_gen_mod]
+univ_gen_ext_not_In_delete [lemma, in General.univ_gen_ext]
+univ_gen_ext_same_length_id [lemma, in General.univ_gen_ext]
+univ_gen_ext_smaller_length [lemma, in General.univ_gen_ext]
+univ_gen_ext_In [lemma, in General.univ_gen_ext]
+univ_gen_ext_Q_weaker_than_P [lemma, in General.univ_gen_ext]
+univ_gen_ext_add_elem_deep [lemma, in General.univ_gen_ext]
+univ_gen_ext_elem_deep [lemma, in General.univ_gen_ext]
+univ_gen_ext_same_hd [lemma, in General.univ_gen_ext]
+univ_gen_ext_combine [lemma, in General.univ_gen_ext]
+univ_gen_ext_splitR [lemma, in General.univ_gen_ext]
+univ_gen_ext_splitL [lemma, in General.univ_gen_ext]
+univ_gen_ext_lem [lemma, in General.univ_gen_ext]
+univ_gen_ext_appR [lemma, in General.univ_gen_ext]
+univ_gen_ext_appL [lemma, in General.univ_gen_ext]
+univ_gen_ext_nil_all_P [lemma, in General.univ_gen_ext]
+univ_gen_ext_trans [lemma, in General.univ_gen_ext]
+univ_gen_ext_refl [lemma, in General.univ_gen_ext]
+univ_gen_ext_sind [definition, in General.univ_gen_ext]
+univ_gen_ext_rec [definition, in General.univ_gen_ext]
+univ_gen_ext_ind [definition, in General.univ_gen_ext]
+univ_gen_ext_rect [definition, in General.univ_gen_ext]
+univ_gen_ext_extra [constructor, in General.univ_gen_ext]
+univ_gen_ext_cons [constructor, in General.univ_gen_ext]
+univ_gen_ext_nil [constructor, in General.univ_gen_ext]
+univ_gen_ext [inductive, in General.univ_gen_ext]
+univ_gen_ext_incl_subform_boxes [lemma, in GL.GLS.GLS_termination_measure]
+univ_gen_ext [library]
+univ_gen_mod [library]
+Unnamed_thm0 [definition, in General.swappedT]
+Unnamed_thm [definition, in General.swappedT]
+usable_boxes [definition, in GL.GLS.GLS_termination_measure]
+

V

+Var [constructor, in Syntax.CML_Syntax]
+Var [constructor, in ISL.Formulas]
+variable [definition, in ISL.Formulas]
+variables_disjunction [lemma, in ISL.Environments]
+variables_conjunction [lemma, in ISL.Environments]
+vars_incl [definition, in ISL.PropQuantifiers]
+var_not_in_env [definition, in ISL.Environments]
+

W

+want_prod_under_universal4 [lemma, in General.genT]
+want_right_prod_under_universal' [lemma, in General.genT]
+want_right_prod_under_universal [lemma, in General.genT]
+want_left_prod_under_universal [lemma, in General.genT]
+weakening [lemma, in ISL.SequentProps]
+weakeningL [lemma, in General.gen_seq]
+weak_ImpL [lemma, in ISL.SequentProps]
+weak_cut [lemma, in ISL.Optimizations]
+weight [definition, in ISL.Formulas]
+weight_open_box [lemma, in ISL.SequentProps]
+weight_open_box [lemma, in ISL.Order]
+weight_ind [definition, in ISL.Formulas]
+weight_pos [lemma, in ISL.Formulas]
+well_foundedT [definition, in General.genT]
+wf_LtSeq [lemma, in K.Interpolation.UIK_basics]
+wf_pointed_env_ms_order [lemma, in ISL.Order]
+wf_pointed_order [lemma, in ISL.Order]
+wf_env_order [definition, in ISL.Order]
+wf_LexSeq [lemma, in GL.Interpolation.UIGL_LexSeq]
+wkL_valid' [definition, in General.gen_seq]
+wkL_valid [definition, in General.gen_seq]
+wkn_R_sind [definition, in K.KS.KS_wkn]
+wkn_R_rec [definition, in K.KS.KS_wkn]
+wkn_R_ind [definition, in K.KS.KS_wkn]
+wkn_R_rect [definition, in K.KS.KS_wkn]
+wkn_RI [constructor, in K.KS.KS_wkn]
+wkn_R [inductive, in K.KS.KS_wkn]
+wkn_L_sind [definition, in K.KS.KS_wkn]
+wkn_L_rec [definition, in K.KS.KS_wkn]
+wkn_L_ind [definition, in K.KS.KS_wkn]
+wkn_L_rect [definition, in K.KS.KS_wkn]
+wkn_LI [constructor, in K.KS.KS_wkn]
+wkn_L [inductive, in K.KS.KS_wkn]
+wkn_R_BotL_notapplic [lemma, in GL.GLS.GLS_wkn]
+wkn_R_sind [definition, in GL.GLS.GLS_wkn]
+wkn_R_rec [definition, in GL.GLS.GLS_wkn]
+wkn_R_ind [definition, in GL.GLS.GLS_wkn]
+wkn_R_rect [definition, in GL.GLS.GLS_wkn]
+wkn_RI [constructor, in GL.GLS.GLS_wkn]
+wkn_R [inductive, in GL.GLS.GLS_wkn]
+wkn_L_sind [definition, in GL.GLS.GLS_wkn]
+wkn_L_rec [definition, in GL.GLS.GLS_wkn]
+wkn_L_ind [definition, in GL.GLS.GLS_wkn]
+wkn_L_rect [definition, in GL.GLS.GLS_wkn]
+wkn_LI [constructor, in GL.GLS.GLS_wkn]
+wkn_L [inductive, in GL.GLS.GLS_wkn]
+

X

+XBoxed_list [definition, in GL.GLS.GLS_calcs]
+XBoxed_list_In_unfold [lemma, in GL.Interpolation.UIGL_nodupseq]
+XBoxed_list_In_gen [lemma, in GL.Interpolation.UIGL_nodupseq]
+XBoxed_list_In [lemma, in GL.Interpolation.UIGL_nodupseq]
+XBoxed_list_same_subform_boxes [lemma, in GL.GLS.GLS_termination_measure]
+XBox_app_distrib [lemma, in GL.GLS.GLS_calcs]
+

other

+existsT2 _ .. _ , _ (type_scope) [notation, in General.existsT]
+existsT _ .. _ , _ (type_scope) [notation, in General.existsT]
+_ ∈ _ [notation, in K.Interpolation.UIK_irred_high_level]
+_ ∈ _ [notation, in K.Interpolation.UIK_braga]
+_ ⊢ _ [notation, in ISL.Sequents]
+_ ∈ _ [notation, in GL.Interpolation.UIGL_braga]
+_ --> _ [notation, in Syntax.CML_Syntax]
+_ << _ [notation, in GL.GLS.GLS_termination_measure]
+_ ≺· _ [notation, in ISL.Order]
+_ ≼ _ [notation, in ISL.Order]
+_ ≺ _ [notation, in ISL.Order]
+_ • _ [notation, in ISL.Order]
+_ ∈ _ [notation, in K.Interpolation.UIK_irred_short]
+_ ∈ _ [notation, in GL.Interpolation.UIGL_irred_high_level]
+_ ⇢ _ [notation, in ISL.Environments]
+_ ⊻ _ [notation, in ISL.Environments]
+_ ⊼ _ [notation, in ISL.Environments]
+_ • _ [notation, in ISL.Environments]
+_ ≼ _ [notation, in ISL.Optimizations]
+_ ∈ _ [notation, in GL.Interpolation.UIGL_irred_short]
+_ ≺f _ [notation, in ISL.Formulas]
+_ _ ⇔ _ _ [notation, in ISL.Formulas]
+_ → _ [notation, in ISL.Formulas]
+_ ∨ _ [notation, in ISL.Formulas]
+_ ∧ _ [notation, in ISL.Formulas]
+T~ _ [notation, in General.genT]
+# _ [notation, in Syntax.CML_Syntax]
+¬ _ [notation, in Syntax.CML_Syntax]
+¬ _ [notation, in ISL.Formulas]
+⊗ _ [notation, in ISL.Environments]
+⊙ _ [notation, in ISL.Environments]
+ [notation, in ISL.Formulas]
+ [notation, in Syntax.CML_Syntax]
+ [notation, in ISL.Formulas]
+ [notation, in ISL.Environments]
+ [notation, in ISL.Environments]
+□ _ [notation, in ISL.Formulas]
+


+

Notation Index

+

L

+_ <lex _ [in K.Interpolation.UIK_Def_measure]
+_ <lex _ [in GL.GLS.DLW_wf_lex]
+_ <lex _ [in GL.Interpolation.UIGL_Def_measure]
+

U

+_ • _ [in ISL.PropQuantifiers]
+□⁻¹ _ [in ISL.PropQuantifiers]
+

other

+existsT2 _ .. _ , _ (type_scope) [in General.existsT]
+existsT _ .. _ , _ (type_scope) [in General.existsT]
+_ ∈ _ [in K.Interpolation.UIK_irred_high_level]
+_ ∈ _ [in K.Interpolation.UIK_braga]
+_ ⊢ _ [in ISL.Sequents]
+_ ∈ _ [in GL.Interpolation.UIGL_braga]
+_ --> _ [in Syntax.CML_Syntax]
+_ << _ [in GL.GLS.GLS_termination_measure]
+_ ≺· _ [in ISL.Order]
+_ ≼ _ [in ISL.Order]
+_ ≺ _ [in ISL.Order]
+_ • _ [in ISL.Order]
+_ ∈ _ [in K.Interpolation.UIK_irred_short]
+_ ∈ _ [in GL.Interpolation.UIGL_irred_high_level]
+_ ⇢ _ [in ISL.Environments]
+_ ⊻ _ [in ISL.Environments]
+_ ⊼ _ [in ISL.Environments]
+_ • _ [in ISL.Environments]
+_ ≼ _ [in ISL.Optimizations]
+_ ∈ _ [in GL.Interpolation.UIGL_irred_short]
+_ ≺f _ [in ISL.Formulas]
+_ _ ⇔ _ _ [in ISL.Formulas]
+_ → _ [in ISL.Formulas]
+_ ∨ _ [in ISL.Formulas]
+_ ∧ _ [in ISL.Formulas]
+T~ _ [in General.genT]
+# _ [in Syntax.CML_Syntax]
+¬ _ [in Syntax.CML_Syntax]
+¬ _ [in ISL.Formulas]
+⊗ _ [in ISL.Environments]
+⊙ _ [in ISL.Environments]
+ [in ISL.Formulas]
+ [in Syntax.CML_Syntax]
+ [in ISL.Formulas]
+ [in ISL.Environments]
+ [in ISL.Environments]
+□ _ [in ISL.Formulas]
+


+

Variable Index

+

F

+flatmap.D [in K.Interpolation.UIK_irred_short]
+flatmap.D [in GL.Interpolation.UIGL_irred_short]
+flatmap.f [in K.Interpolation.UIK_irred_short]
+flatmap.F [in K.Interpolation.UIK_irred_short]
+flatmap.f [in GL.Interpolation.UIGL_irred_short]
+flatmap.F [in GL.Interpolation.UIGL_irred_short]
+flatmap.g [in K.Interpolation.UIK_irred_short]
+flatmap.g [in GL.Interpolation.UIGL_irred_short]
+flatmap.Hg [in K.Interpolation.UIK_irred_short]
+flatmap.Hg [in GL.Interpolation.UIGL_irred_short]
+flatmap.X [in K.Interpolation.UIK_irred_short]
+flatmap.X [in GL.Interpolation.UIGL_irred_short]
+

G

+Gimap_cont.f [in K.Interpolation.UIK_braga]
+Gimap_cont.D [in K.Interpolation.UIK_braga]
+Gimap_cont.F [in K.Interpolation.UIK_braga]
+Gimap_cont.Y [in K.Interpolation.UIK_braga]
+Gimap_cont.X [in K.Interpolation.UIK_braga]
+Gimap_cont.f [in GL.Interpolation.UIGL_braga]
+Gimap_cont.D [in GL.Interpolation.UIGL_braga]
+Gimap_cont.F [in GL.Interpolation.UIGL_braga]
+Gimap_cont.Y [in GL.Interpolation.UIGL_braga]
+Gimap_cont.X [in GL.Interpolation.UIGL_braga]
+GN.F [in GL.Interpolation.UIGL_braga]
+GN.Ffun [in GL.Interpolation.UIGL_braga]
+GN.p [in GL.Interpolation.UIGL_braga]
+

I

+imap.D [in K.Interpolation.UIK_braga]
+imap.D [in GL.Interpolation.UIGL_braga]
+imap.f [in K.Interpolation.UIK_braga]
+imap.F [in K.Interpolation.UIK_braga]
+imap.f [in GL.Interpolation.UIGL_braga]
+imap.F [in GL.Interpolation.UIGL_braga]
+imap.Ffun [in K.Interpolation.UIK_braga]
+imap.Ffun [in GL.Interpolation.UIGL_braga]
+imap.g [in K.Interpolation.UIK_braga]
+imap.g [in GL.Interpolation.UIGL_braga]
+imap.Hg [in K.Interpolation.UIK_braga]
+imap.Hg [in GL.Interpolation.UIGL_braga]
+imap.X [in K.Interpolation.UIK_braga]
+imap.X [in GL.Interpolation.UIGL_braga]
+imap.Y [in K.Interpolation.UIK_braga]
+imap.Y [in GL.Interpolation.UIGL_braga]
+irred_high_level.provability.HP [in K.Interpolation.UIK_irred_high_level]
+irred_high_level.provability.P [in K.Interpolation.UIK_irred_high_level]
+irred_high_level.irred_not [in K.Interpolation.UIK_irred_high_level]
+irred_high_level.irred_nil [in K.Interpolation.UIK_irred_high_level]
+irred_high_level.irred [in K.Interpolation.UIK_irred_high_level]
+irred_high_level.f_wf [in K.Interpolation.UIK_irred_high_level]
+irred_high_level.f [in K.Interpolation.UIK_irred_high_level]
+irred_high_level.X [in K.Interpolation.UIK_irred_high_level]
+irred_high_level.provability.HP [in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.provability.P [in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.irred_not [in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.irred_nil [in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.irred [in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.f_wf [in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.f [in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level.X [in GL.Interpolation.UIGL_irred_high_level]
+irred.f [in K.Interpolation.UIK_irred_short]
+irred.f [in GL.Interpolation.UIGL_irred_short]
+irred.Girred_ind.HQ1 [in K.Interpolation.UIK_irred_short]
+irred.Girred_ind.HQ0 [in K.Interpolation.UIK_irred_short]
+irred.Girred_ind.HP1 [in K.Interpolation.UIK_irred_short]
+irred.Girred_ind.HP0 [in K.Interpolation.UIK_irred_short]
+irred.Girred_ind.Q [in K.Interpolation.UIK_irred_short]
+irred.Girred_ind.P [in K.Interpolation.UIK_irred_short]
+irred.Girred_ind.HQ1 [in GL.Interpolation.UIGL_irred_short]
+irred.Girred_ind.HQ0 [in GL.Interpolation.UIGL_irred_short]
+irred.Girred_ind.HP1 [in GL.Interpolation.UIGL_irred_short]
+irred.Girred_ind.HP0 [in GL.Interpolation.UIGL_irred_short]
+irred.Girred_ind.Q [in GL.Interpolation.UIGL_irred_short]
+irred.Girred_ind.P [in GL.Interpolation.UIGL_irred_short]
+irred.hf [in K.Interpolation.UIK_irred_short]
+irred.hf [in GL.Interpolation.UIGL_irred_short]
+irred.irred_pwc [in K.Interpolation.UIK_irred_short]
+irred.irred_pwc [in GL.Interpolation.UIGL_irred_short]
+irred.X [in K.Interpolation.UIK_irred_short]
+irred.X [in GL.Interpolation.UIGL_irred_short]
+

L

+LexSeq_ind.P [in GL.Interpolation.UIGL_LexSeq]
+lex_wf.lex_rect.HP [in K.Interpolation.UIK_Def_measure]
+lex_wf.lex_rect.P [in K.Interpolation.UIK_Def_measure]
+lex_wf.Rwf [in K.Interpolation.UIK_Def_measure]
+lex_wf.R [in K.Interpolation.UIK_Def_measure]
+lex_wf.X [in K.Interpolation.UIK_Def_measure]
+lex_wf.Rwf [in GL.GLS.DLW_wf_lex]
+lex_wf.R [in GL.GLS.DLW_wf_lex]
+lex_wf.X [in GL.GLS.DLW_wf_lex]
+lex_wf.lex_rect.HP [in GL.Interpolation.UIGL_Def_measure]
+lex_wf.lex_rect.P [in GL.Interpolation.UIGL_Def_measure]
+lex_wf.Rwf [in GL.Interpolation.UIGL_Def_measure]
+lex_wf.R [in GL.Interpolation.UIGL_Def_measure]
+lex_wf.X [in GL.Interpolation.UIGL_Def_measure]
+LtSeq_ind.P [in K.Interpolation.UIK_basics]
+

M

+measure_rect.F [in K.Interpolation.UIK_Def_measure]
+measure_rect.P [in K.Interpolation.UIK_Def_measure]
+measure_rect.m [in K.Interpolation.UIK_Def_measure]
+measure_rect.X [in K.Interpolation.UIK_Def_measure]
+measure_rect.F [in GL.GLS.DLW_wf_lex]
+measure_rect.P [in GL.GLS.DLW_wf_lex]
+measure_rect.m [in GL.GLS.DLW_wf_lex]
+measure_rect.X [in GL.GLS.DLW_wf_lex]
+measure_rect.F [in GL.Interpolation.UIGL_Def_measure]
+measure_rect.P [in GL.Interpolation.UIGL_Def_measure]
+measure_rect.m [in GL.Interpolation.UIGL_Def_measure]
+measure_rect.X [in GL.Interpolation.UIGL_Def_measure]
+

N

+N.p [in GL.Interpolation.UIGL_braga]
+

R

+Reflexive_Transitive_ClosureT.R [in General.rtcT]
+Reflexive_Transitive_ClosureT.A [in General.rtcT]
+Reflexive_ClosureT.R [in General.rtcT]
+Reflexive_ClosureT.A [in General.rtcT]
+

U

+UI.p [in K.Interpolation.UIK_braga]
+UI.p [in GL.Interpolation.UIGL_braga]
+UI.UI_pwc [in K.Interpolation.UIK_braga]
+UI.UI_pwc [in GL.Interpolation.UIGL_braga]
+UniformInterpolation.p [in ISL.PropQuantifiers]
+


+

Library Index

+

C

+CML_Syntax
+Cut
+

D

+ddT
+dd_fc
+DecisionProcedure
+DLW_wf_lex
+

E

+Environments
+existsT
+

F

+Formulas
+

G

+gen
+general_export
+genT
+gentree
+gen_tacs
+gen_seq
+GLS_wkn
+GLS_dec
+GLS_cut_elim
+GLS_calcs
+GLS_ctr
+GLS_export
+GLS_inv_ImpR_ImpL
+GLS_exch
+GLS_additive_cut
+GLS_der_dec
+GLS_termination_measure
+gstep
+

K

+KS_exch_KR
+KS_inv_ImpR_ImpL
+KS_termination_measure
+KS_dec
+KS_termination_ImpR
+KS_exch_ImpR
+KS_ctr
+KS_termination_init
+KS_exch
+KS_calc
+KS_export
+KS_termination
+KS_additive_cut
+KS_exch_ImpL
+KS_cut_elim
+KS_exch_prelims
+KS_termination_ImpL
+KS_wkn
+KS_termination_KR
+KS_termination_prelims
+K_Craig_Interp
+

L

+List_lemmasT
+list_lems
+

O

+Optimizations
+Order
+

P

+PropQuantifiers
+

R

+remove_list_lems
+rtcT
+

S

+SequentProps
+Sequents
+Simp
+swappedT
+Syntax_export
+

U

+UIGL_And_Or_rules
+UIGL_Diam_UI_imp_N_prelim
+UIGL_irred_short
+UIGL_Canopy_nodupseq_perm
+UIGL_Canopy_ImpL
+UIGL_irred_high_level
+UIGL_UIDiam_N
+UIGL_Diam_N_imp_UI
+UIGL_UIOne
+UIGL_braga
+UIGL_Diam_UI_imp_N
+UIGL_Canopy
+UIGL_Canopy_ImpR
+UIGL_UIThree
+UIGL_nodupseq
+UIGL_basics
+UIGL_UITwo
+UIGL_PermutationT
+UIGL_UI_inter
+UIGL_PermutationTS
+UIGL_UI_prelims
+UIGL_Def_measure
+UIGL_LexSeq
+UIGL_N_imp_UI
+UIK_irred_high_level
+UIK_irred_short
+UIK_UIOne
+UIK_UI_prelims
+UIK_Canopy
+UIK_UITwo
+UIK_basics
+UIK_UIThree
+UIK_braga
+UIK_Def_measure
+UIML_extraction
+univ_gen_ext
+univ_gen_mod
+


+

Lemma Index

+

A

+AccT_in_nextup_fc [in General.dd_fc]
+AccT_measure' [in General.gentree]
+Acc_invprem [in GL.Interpolation.UIGL_Canopy]
+Acc_less_imp [in GL.Interpolation.UIGL_Canopy]
+Acc_invprem [in K.Interpolation.UIK_Canopy]
+Acc_less_imp [in K.Interpolation.UIK_Canopy]
+additive_cut [in ISL.Cut]
+add_remove_list_preserve_NoDup [in Syntax.remove_list_lems]
+add_1_element_split_lists [in Syntax.list_lems]
+adm_single_trans [in General.ddT]
+adm_derrec_trans [in General.ddT]
+adm_adm [in General.ddT]
+allPderD [in General.dd_fc]
+allPderD_in [in General.dd_fc]
+allPder_dlConsD [in General.dd_fc]
+allP_all_in_d [in General.dd_fc]
+all_P_univ_gen_ext_nil [in General.univ_gen_ext]
+all_in_d_allP [in General.dd_fc]
+all_derl_dersl' [in General.ddT]
+all_derl_dersl [in General.ddT]
+all_dercl_derscl [in General.ddT]
+all_RHS_boxes_are_LHS_boxes_no_GLR [in GL.GLS.GLS_termination_measure]
+AndL [in K.Interpolation.UIK_UI_prelims]
+AndL [in GL.Interpolation.UIGL_And_Or_rules]
+AndL_inv [in GL.Interpolation.UIGL_And_Or_rules]
+AndL_rev [in ISL.SequentProps]
+AndR [in K.Interpolation.UIK_UI_prelims]
+AndR [in GL.Interpolation.UIGL_And_Or_rules]
+AndR_inv [in GL.Interpolation.UIGL_And_Or_rules]
+AndR_rev [in ISL.SequentProps]
+and_assoc_ctx_R_R [in ISL.Simp]
+and_assoc_ctx_R_L [in ISL.Simp]
+and_assoc_ctx_L_R [in ISL.Simp]
+and_assoc_L [in ISL.Simp]
+and_assoc_R [in ISL.Simp]
+and_comm_ctx_L [in ISL.Simp]
+and_comm [in ISL.Simp]
+and_true [in General.gen]
+and_congruence [in ISL.Optimizations]
+anonD [in General.genT]
+anonI [in General.genT]
+anon_forall [in General.genT]
+anon_sigT [in General.genT]
+anon_iffT [in General.genT]
+anon_imp [in General.genT]
+anon_sum [in General.genT]
+anon_prod [in General.genT]
+anon_eq [in General.genT]
+appI [in General.gen_tacs]
+appl [in General.gen]
+applI [in General.gen_tacs]
+appl_cong [in General.gen_tacs]
+apprI [in General.gen_tacs]
+appr_cong [in General.gen_tacs]
+app_remove_list [in Syntax.remove_list_lems]
+app_eq_appT2_single_tlR [in General.List_lemmasT]
+app_eq_appT2_single_tlL [in General.List_lemmasT]
+app_eq_appT2_single_hdR [in General.List_lemmasT]
+app_eq_appT2_single_hdL [in General.List_lemmasT]
+app_eq_appT2_nn [in General.List_lemmasT]
+app_tl_inversion [in General.List_lemmasT]
+app_hd_inversion [in General.List_lemmasT]
+app_singleton_tl_inversion [in General.List_lemmasT]
+app_singleton_inversion [in General.List_lemmasT]
+app_eq_unitT2 [in General.List_lemmasT]
+app_eq_appT2 [in General.List_lemmasT]
+app_eq_appT [in General.List_lemmasT]
+app_eq_app [in General.List_lemmasT]
+app_eq_nilT [in General.List_lemmasT]
+app_cons_single [in General.List_lemmasT]
+app_eq_unitT [in General.gen_tacs]
+app_eq_nil_iff [in General.gen_tacs]
+app2_find_hole [in Syntax.list_lems]
+arg_cong_imp' [in General.gen]
+arg_cong_imp [in General.gen]
+arg_cong [in General.gen]
+arg1_cong_imp' [in General.gen]
+arg1_cong_imp [in General.gen]
+asa_eq [in General.List_lemmasT]
+asmsI [in General.ddT]
+A_right [in ISL.PropQuantifiers]
+a_rule_env_spec [in ISL.PropQuantifiers]
+a_rule_form_vars [in ISL.PropQuantifiers]
+a_rule_env_vars [in ISL.PropQuantifiers]
+a_rule_form_cong_strong [in ISL.PropQuantifiers]
+a_rule_form_cong [in ISL.PropQuantifiers]
+a_rule_env_cong_strong [in ISL.PropQuantifiers]
+a_rule_env_cong [in ISL.PropQuantifiers]
+

B

+botRule_fc_prems [in General.dd_fc]
+botRule_fc_ps [in General.dd_fc]
+botRule_fc_drs [in General.dd_fc]
+botRule_fc_rules [in General.dd_fc]
+botRule_fc_concl [in General.dd_fc]
+BotR_remove [in GL.Interpolation.UIGL_And_Or_rules]
+botr_ps_der [in General.dd_fc]
+box_congr [in ISL.Simp]
+box_in_top_boxes [in Syntax.CML_Syntax]
+box_preserv_top_boxes [in GL.GLS.GLS_termination_measure]
+

C

+Canopy_nodupseq_perm [in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+Canopy_nodupseq_perm_gen [in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+Canopy_measure [in K.Interpolation.UIK_UI_prelims]
+Canopy_LtSeq [in K.Interpolation.UIK_basics]
+Canopy_nil [in K.Interpolation.UIK_basics]
+Canopy_pos_var [in GL.Interpolation.UIGL_Canopy]
+Canopy_neg_var [in GL.Interpolation.UIGL_Canopy]
+Canopy_hp_inv_ctx [in GL.Interpolation.UIGL_Canopy]
+Canopy_equiprv_genR [in GL.Interpolation.UIGL_Canopy]
+Canopy_equiprv_genL [in GL.Interpolation.UIGL_Canopy]
+Canopy_equiprv [in GL.Interpolation.UIGL_Canopy]
+Canopy_critical [in GL.Interpolation.UIGL_Canopy]
+Canopy_nodupseq_equiprv_genL [in GL.Interpolation.UIGL_UI_prelims]
+Canopy_nodupseq_equiprv_genR [in GL.Interpolation.UIGL_UI_prelims]
+Canopy_LexSeq [in GL.Interpolation.UIGL_LexSeq]
+Canopy_nil [in GL.Interpolation.UIGL_LexSeq]
+Canopy_pos_var [in K.Interpolation.UIK_Canopy]
+Canopy_neg_var [in K.Interpolation.UIK_Canopy]
+Canopy_hp_inv_ctx [in K.Interpolation.UIK_Canopy]
+Canopy_equiprv_genR [in K.Interpolation.UIK_Canopy]
+Canopy_equiprv_genL [in K.Interpolation.UIK_Canopy]
+Canopy_equiprv [in K.Interpolation.UIK_Canopy]
+Canopy_critical [in K.Interpolation.UIK_Canopy]
+can_wkL_req [in General.gen_seq]
+can_trf_rules_rtc_mono' [in General.gstep]
+can_trf_rules_imp_rtc [in General.gstep]
+can_trf_derl [in General.gstep]
+can_trf_rules_req [in General.gstep]
+can_trf_rules_Un [in General.gstep]
+can_trf_rules_un [in General.gstep]
+can_trf_rules_rc_mono' [in General.gstep]
+can_trf_rules_mono' [in General.gstep]
+can_trf_rules_imp_rc [in General.gstep]
+ccpsD [in General.ddT]
+choose_disj_equiv_R [in ISL.Optimizations]
+choose_disj_equiv_L [in ISL.Optimizations]
+choose_conj_equiv_R [in ISL.Optimizations]
+choose_conj_equiv_L [in ISL.Optimizations]
+clos_rt_rtn1T [in General.rtcT]
+clos_rtn1_rtT [in General.rtcT]
+clos_rt_rt1nT [in General.rtcT]
+clos_rt1n_rtT [in General.rtcT]
+conjunction_L [in ISL.Optimizations]
+conjunction_R2 [in ISL.Optimizations]
+conjunction_R1 [in ISL.Optimizations]
+cons_singleton [in General.List_lemmasT]
+cons_eq_appT2 [in General.List_lemmasT]
+cons_eq_appT [in General.List_lemmasT]
+cons_eq_app [in General.List_lemmasT]
+cons_single [in General.List_lemmasT]
+cons_app_single [in General.swappedT]
+contraction [in ISL.SequentProps]
+contradic_subform_boxesF [in GL.GLS.GLS_termination_measure]
+count_occ_n_imp_subformLF [in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+count_le_n_imp [in GL.Interpolation.UIGL_Canopy_ImpR]
+count_occ_n_imp_subformLF [in GL.Interpolation.UIGL_Canopy_ImpR]
+Craig_Interpolation [in K.Interpolation.K_Craig_Interp]
+crd_ra [in General.gstep]
+critical_empty_set [in K.Interpolation.UIK_basics]
+critical_nodupseq [in GL.Interpolation.UIGL_nodupseq]
+critical_Seq_InT_Canopy [in GL.Interpolation.UIGL_Canopy]
+critical_empty_seq [in GL.Interpolation.UIGL_LexSeq]
+critical_Seq_InT_Canopy [in K.Interpolation.UIK_Canopy]
+ctr_R_BotL_notapplic [in GL.GLS.GLS_ctr]
+ctr_R_IdB_notapplic [in GL.GLS.GLS_ctr]
+ctr_R_IdP_notapplic [in GL.GLS.GLS_ctr]
+ctr_L_BotL_notapplic [in GL.GLS.GLS_ctr]
+ctr_L_IdB_notapplic [in GL.GLS.GLS_ctr]
+ctr_L_IdP_notapplic [in GL.GLS.GLS_ctr]
+cut [in ISL.Cut]
+

D

+decide_in [in ISL.Environments]
+decT_less_than_lt [in GL.GLS.GLS_termination_measure]
+decT_lex_lt [in GL.GLS.GLS_termination_measure]
+decT_lt [in GL.GLS.GLS_termination_measure]
+dec_non_nil_prems [in K.KS.KS_termination]
+dec_le [in K.KS.KS_termination_prelims]
+dercl_soundness [in General.gstep]
+dercl_derl' [in General.ddT]
+dercl_all_rect [in General.ddT]
+derl_fst_ext_rls [in General.gen_seq]
+derl_fst_ext_rls'' [in General.gen_seq]
+derl_seqrule [in General.gen_seq]
+derl_seqrule'' [in General.gen_seq]
+derl_adm_s [in General.ddT]
+derl_sub_adm [in General.ddT]
+derl_dersl_mono' [in General.ddT]
+derl_dersl_deriv' [in General.ddT]
+derl_trans' [in General.ddT]
+derl_derrec_trans' [in General.ddT]
+derl_all_rect [in General.ddT]
+derl_dercl [in General.ddT]
+derl_dersl_single [in General.ddT]
+derrec_leaves_thms [in GL.GLS.GLS_der_dec]
+derrec_composition [in GL.GLS.GLS_der_dec]
+derrec_soundness [in General.gstep]
+derrec_dp_same2 [in General.dd_fc]
+derrec_dp_same [in General.dd_fc]
+derrec_eq_swap [in General.ddT]
+derrec_adm' [in General.ddT]
+derrec_all_rect2 [in General.ddT]
+derrec_nil_derl_s [in General.ddT]
+derrec_derl_deriv' [in General.ddT]
+derrec_rmono_s [in General.ddT]
+derrec_trans_imp [in General.ddT]
+derrec_same_nsR [in General.ddT]
+derrec_same_nsL [in General.ddT]
+derrec_same [in General.ddT]
+derrec_derrec' [in General.ddT]
+derrec_all_rect [in General.ddT]
+derrec_all_indT [in General.ddT]
+derrec_all_ind [in General.ddT]
+derrec_height_False_ge_1 [in GL.GLS.GLS_inv_ImpR_ImpL]
+derrec_height_False_ge_1 [in K.KS.KS_inv_ImpR_ImpL]
+derscl_all_dercl [in General.ddT]
+dersl_trans_alt [in General.ddT]
+dersl_app_eq [in General.ddT]
+dersl_cons [in General.ddT]
+dersl_dersrec_nil [in General.ddT]
+dersl_all_derl' [in General.ddT]
+dersl_all_derl [in General.ddT]
+dersrecD_forall_in_dersrec [in General.dd_fc]
+dersrec_derrec_height_le [in General.dd_fc]
+dersrec_derrec2_dp [in General.dd_fc]
+dersrec_derrec_dp [in General.dd_fc]
+dersrec_derrec2_height [in General.dd_fc]
+dersrec_derrec_height [in General.dd_fc]
+dersrec_double_verb [in General.dd_fc]
+dersrec_trees_concls_eq [in General.dd_fc]
+dersrec_height_le [in General.dd_fc]
+dersrec_height_nil [in General.dd_fc]
+dersrec_tl_eq [in General.dd_fc]
+dersrec_hd_eq [in General.dd_fc]
+dersrec_double [in General.ddT]
+dersrec_map_2 [in General.ddT]
+dersrec_map_single [in General.ddT]
+dersrec_single [in General.ddT]
+dersrec_app [in General.ddT]
+dersrec_nil [in General.ddT]
+dersrec_forall [in General.ddT]
+dersrec_all [in General.ddT]
+ders_ders_fcs [in General.dd_fc]
+ders_concls_eq [in General.dd_fc]
+der_s_inhabited [in GL.GLS.GLS_der_dec]
+der_s_inhabited [in K.KS.KS_termination_prelims]
+der_trf_ht [in General.gstep]
+der_trf_rtc [in General.gstep]
+der_trf [in General.gstep]
+der_trf_derl [in General.gstep]
+der_trf_rc [in General.gstep]
+der_trf_rc_derl [in General.gstep]
+der_trf_rc_adm [in General.gstep]
+der_botRule [in General.dd_fc]
+der_der_fc [in General.dd_fc]
+der_botr_ps_eq [in General.dd_fc]
+der_fc_concl_eq [in General.dd_fc]
+der_concl_eq [in General.dd_fc]
+DiamL_lim [in K.Interpolation.UIK_UI_prelims]
+DiamL_lim [in GL.Interpolation.UIGL_UI_prelims]
+Diam_rec_UI_imp [in GL.Interpolation.UIGL_Diam_N_imp_UI]
+Diam_rec_UI [in GL.Interpolation.UIGL_UIDiam_N]
+difference_include [in ISL.Environments]
+difference_singleton [in ISL.Environments]
+diff_not_in [in ISL.Environments]
+diff_mult [in ISL.Environments]
+disjunction_R [in ISL.Optimizations]
+disjunction_L [in ISL.Optimizations]
+dlCons_inj [in General.gstep]
+double_remove [in Syntax.remove_list_lems]
+double_negation_obviously_smaller [in ISL.Optimizations]
+dp_get_D [in General.dd_fc]
+dp_same_fun [in General.dd_fc]
+dp_same [in General.dd_fc]
+drs_trees_height [in General.dd_fc]
+dtCons_eq [in General.ddT]
+

E

+EA_vars [in ISL.PropQuantifiers]
+EA_eq [in ISL.PropQuantifiers]
+effective_remove_nth [in GL.GLS.GLS_der_dec]
+effective_remove_nth [in K.KS.KS_termination_prelims]
+elements_elem_of [in ISL.Order]
+elements_open_boxes [in ISL.Environments]
+elements_env_add [in ISL.Environments]
+elem_of_list_In_1 [in ISL.Order]
+elem_of_open_boxes [in ISL.Environments]
+emptyT_any [in General.genT]
+emptyT_any' [in General.genT]
+empty_False [in General.genT]
+empty_explosion [in General.genT]
+entail_correct [in ISL.PropQuantifiers]
+env_order_le_lt_trans [in ISL.Order]
+env_order_lt_le_trans [in ISL.Order]
+env_order_eq_add [in ISL.Order]
+env_order_cancel_right [in ISL.Order]
+env_order_4 [in ISL.Order]
+env_order_3 [in ISL.Order]
+env_order_2 [in ISL.Order]
+env_order_0 [in ISL.Order]
+env_order_disj_union_compat_strong_left [in ISL.Order]
+env_order_disj_union_compat_strong_right [in ISL.Order]
+env_order_refl_disj_union_compat [in ISL.Order]
+env_order_disj_union_compat [in ISL.Order]
+env_order_disj_union_compat_right [in ISL.Order]
+env_order_disj_union_compat_left [in ISL.Order]
+env_order_add_compat [in ISL.Order]
+env_order_compat' [in ISL.Order]
+env_order_compat [in ISL.Order]
+env_order_1 [in ISL.Order]
+env_order_equiv_left_compat [in ISL.Order]
+env_order_equiv_right_compat [in ISL.Order]
+env_order_singleton [in ISL.Order]
+env_weight_singleton [in ISL.Order]
+env_weight_add [in ISL.Order]
+env_weight_disj_union [in ISL.Order]
+env_equiv_eq [in ISL.Environments]
+env_add_inv' [in ISL.Environments]
+env_add_inv [in ISL.Environments]
+env_add_comm [in ISL.Environments]
+env_in_add [in ISL.Environments]
+env_add_remove [in ISL.Environments]
+env_replace [in ISL.Environments]
+equiv_disj_union_compat_r [in ISL.Environments]
+eq_dec_form [in Syntax.CML_Syntax]
+eq_TrueI [in General.gen]
+eq_app_canc2 [in General.List_lemmasT]
+eq_app_canc1 [in General.List_lemmasT]
+eq_S_F [in General.genT]
+exchL_std_rule [in General.gen_seq]
+exchR_std_rule [in General.gen_seq]
+exfalso [in ISL.SequentProps]
+exists_prems_InT_list_of_premises [in K.KS.KS_termination]
+exists_prems_InT_list_of_premises [in GL.GLS.GLS_der_dec]
+existT_inj' [in General.gstep]
+existT_inj [in General.gstep]
+E_of_empty [in ISL.PropQuantifiers]
+E_left [in ISL.PropQuantifiers]
+E_irr [in ISL.PropQuantifiers]
+e_rule_vars [in ISL.PropQuantifiers]
+e_rule_cong_strong [in ISL.PropQuantifiers]
+e_rule_cong [in ISL.PropQuantifiers]
+

F

+false_or [in General.gen]
+False_empty [in General.genT]
+fcI_inj [in General.dd_fc]
+fer_mono [in General.gen_seq]
+fextI_eq' [in General.gen_seq]
+fext_e [in General.gen_seq]
+find_the_max_mhd [in K.KS.KS_termination]
+finite_premises_of_S [in K.KS.KS_termination]
+finite_ImpRules_premises_of_S [in GL.Interpolation.UIGL_Canopy]
+finite_BotL_premises_of_S [in K.KS.KS_termination_init]
+finite_IdP_premises_of_S [in K.KS.KS_termination_init]
+finite_ImpRules_premises_of_S [in K.Interpolation.UIK_Canopy]
+fixpoint_nodup [in GL.Interpolation.UIGL_nodupseq]
+fixpoint_nodupseq [in GL.Interpolation.UIGL_nodupseq]
+fmlsext_def [in General.gen_seq]
+fmlsext_fmlsext [in General.gen_seq]
+fold_Canopy [in GL.Interpolation.UIGL_Canopy]
+fold_Canopy [in K.Interpolation.UIK_Canopy]
+ForallT_Forall [in General.genT]
+ForallT_Forall' [in General.genT]
+ForallT_forall [in General.genT]
+ForallT_impl [in General.genT]
+ForallT_map_rev [in General.genT]
+ForallT_map [in General.genT]
+ForallT_map_2 [in General.genT]
+ForallT_2 [in General.genT]
+ForallT_append [in General.genT]
+ForallT_cons_iff [in General.genT]
+ForallT_single [in General.genT]
+ForallT_cons_inv [in General.genT]
+ForallT_inv [in General.genT]
+forall_elem_list [in GL.GLS.GLS_der_dec]
+Forall_map_2 [in General.gen]
+Forall_map_single [in General.gen]
+Forall_single [in General.gen]
+Forall_append [in General.gen]
+Forall_cons_iff [in General.gen]
+Forall_cons_inv [in General.gen]
+Forall_ForallT' [in General.genT]
+Forall_ForallT [in General.genT]
+Forall2T_ex_r [in General.genT]
+Forall2T_ex_l [in General.genT]
+Forall2T_app [in General.genT]
+Forall2T_app_inv_r [in General.genT]
+Forall2T_app_inv_l [in General.genT]
+fst_ext_rls_derl_fst_ext_rls [in General.gen_seq]
+fst_ext_rls_fst_ext_rls [in General.gen_seq]
+fst_snd_ext [in General.gen_seq]
+fun_cong [in General.gen]
+

G

+generalised_contraction [in ISL.SequentProps]
+generalised_axiom [in ISL.SequentProps]
+generalised_weakeningR [in ISL.SequentProps]
+generalised_weakeningL [in ISL.SequentProps]
+gen_step_lem' [in General.gstep]
+gen_step2s_lem_ps [in General.gstep]
+gen_steps_lem_ps [in General.gstep]
+gen_step2_lem_psT [in General.gstep]
+gen_step2_lem_ps [in General.gstep]
+gen_step_lem_ps [in General.gstep]
+gen_step_lem_psT [in General.gstep]
+gen_step2_sub_mono [in General.gstep]
+gen_step_def [in General.gstep]
+gen_step_sub_mono [in General.gstep]
+gen_ext_add_elem_deep [in General.univ_gen_ext]
+gen_ext_elem_deep [in General.univ_gen_ext]
+gen_ext_delet_hd [in General.univ_gen_ext]
+gen_ext_diff' [in General.univ_gen_ext]
+gen_ext_InT [in General.univ_gen_ext]
+gen_ext_one' [in General.univ_gen_ext]
+gen_ext_single [in General.univ_gen_ext]
+gen_ext_same_hd [in General.univ_gen_ext]
+gen_ext_combine [in General.univ_gen_ext]
+gen_ext_splitR [in General.univ_gen_ext]
+gen_ext_splitL [in General.univ_gen_ext]
+gen_ext_lem [in General.univ_gen_ext]
+gen_ext_app [in General.univ_gen_ext]
+gen_ext_trans [in General.univ_gen_ext]
+gen_ext_nil_any [in General.univ_gen_ext]
+gen_ext_appR [in General.univ_gen_ext]
+gen_ext_appL [in General.univ_gen_ext]
+gen_ext_refl [in General.univ_gen_ext]
+gen_step2_tr_lem [in General.gentree]
+gen_step2_c_lem [in General.gentree]
+gen_step_tr_lem [in General.gentree]
+gen_step_c_lem [in General.gentree]
+gen_cong [in General.gen]
+gen_rec_UI_imp [in GL.Interpolation.UIGL_N_imp_UI]
+get_botrule [in General.dd_fc]
+Gflatmap_flat_map [in K.Interpolation.UIK_irred_short]
+Gflatmap_app_inv_left [in K.Interpolation.UIK_irred_short]
+Gflatmap_inv_sg_left [in K.Interpolation.UIK_irred_short]
+Gflatmap_inv_left [in K.Interpolation.UIK_irred_short]
+Gflatmap_flat_map [in GL.Interpolation.UIGL_irred_short]
+Gflatmap_app_inv_left [in GL.Interpolation.UIGL_irred_short]
+Gflatmap_inv_sg_left [in GL.Interpolation.UIGL_irred_short]
+Gflatmap_inv_left [in GL.Interpolation.UIGL_irred_short]
+gf_step2_tr_lem [in General.gentree]
+gf2_sum [in General.gentree]
+gf2_step_tr_lem [in General.gentree]
+Gimap_fun_rest [in K.Interpolation.UIK_braga]
+Gimap_fun [in K.Interpolation.UIK_braga]
+Gimap_map [in K.Interpolation.UIK_braga]
+Gimap_app_inv_left [in K.Interpolation.UIK_braga]
+Gimap_inv_sg_left [in K.Interpolation.UIK_braga]
+Gimap_inv_left [in K.Interpolation.UIK_braga]
+Gimap_fun_rest [in GL.Interpolation.UIGL_braga]
+Gimap_fun [in GL.Interpolation.UIGL_braga]
+Gimap_map [in GL.Interpolation.UIGL_braga]
+Gimap_app_inv_left [in GL.Interpolation.UIGL_braga]
+Gimap_inv_sg_left [in GL.Interpolation.UIGL_braga]
+Gimap_inv_left [in GL.Interpolation.UIGL_braga]
+Girred_fun [in K.Interpolation.UIK_irred_short]
+Girred_inv_not [in K.Interpolation.UIK_irred_short]
+Girred_inv_nil [in K.Interpolation.UIK_irred_short]
+Girred_fun [in GL.Interpolation.UIGL_irred_short]
+Girred_inv_not [in GL.Interpolation.UIGL_irred_short]
+Girred_inv_nil [in GL.Interpolation.UIGL_irred_short]
+GLR_app_wkn_R [in GL.GLS.GLS_wkn]
+GLR_app_wkn_L [in GL.GLS.GLS_wkn]
+GLR_applic_reduces_measure [in GL.GLS.GLS_termination_measure]
+GLR_applic_less_usable_boxes [in GL.GLS.GLS_termination_measure]
+GLR_applic_le_subform_boxes [in GL.GLS.GLS_termination_measure]
+GLR_applic_more_top_boxes [in GL.GLS.GLS_termination_measure]
+GLR_app_list_exchR [in GL.GLS.GLS_exch]
+GLR_app_list_exchL [in GL.GLS.GLS_exch]
+GLR_prems_less_ub [in GL.Interpolation.UIGL_LexSeq]
+GLR_prems_LexSeq [in GL.Interpolation.UIGL_LexSeq]
+GLR_app_ctr_R [in GL.GLS.GLS_ctr]
+GLR_app_ctr_L [in GL.GLS.GLS_ctr]
+GLS_cut_adm [in GL.GLS.GLS_additive_cut]
+GLS_cut_adm_main [in GL.GLS.GLS_additive_cut]
+GLS_dec_der [in GL.GLS.GLS_der_dec]
+GLS_XBoxed_list_wkn_L [in GL.GLS.GLS_wkn]
+GLS_prv_list_wkn_L [in GL.GLS.GLS_wkn]
+GLS_list_wkn_L [in GL.GLS.GLS_wkn]
+GLS_prv_list_wkn_R [in GL.GLS.GLS_wkn]
+GLS_list_wkn_R [in GL.GLS.GLS_wkn]
+GLS_prv_wkn_R [in GL.GLS.GLS_wkn]
+GLS_wkn_R [in GL.GLS.GLS_wkn]
+GLS_prv_wkn_L [in GL.GLS.GLS_wkn]
+GLS_wkn_L [in GL.GLS.GLS_wkn]
+GLS_cut_elimination [in GL.GLS.GLS_cut_elim]
+GLS_adm_list_exch_LR [in GL.GLS.GLS_exch]
+GLS_hpadm_list_exch_L [in GL.GLS.GLS_exch]
+GLS_hpadm_list_exch_R [in GL.GLS.GLS_exch]
+GLS_der_list_exch_R [in GL.GLS.GLS_exch]
+GLS_der_list_exch_L [in GL.GLS.GLS_exch]
+GLS_adm_list_exch_R [in GL.GLS.GLS_exch]
+GLS_adm_list_exch_L [in GL.GLS.GLS_exch]
+GLS_hpadm_list_ctr_R [in GL.GLS.GLS_ctr]
+GLS_hpadm_list_ctr_L [in GL.GLS.GLS_ctr]
+GLS_hpadm_ctr_R [in GL.GLS.GLS_ctr]
+GLS_hpadm_ctr_L [in GL.GLS.GLS_ctr]
+GLS_hpadm_ctr_LR [in GL.GLS.GLS_ctr]
+gmultiset_elements_list_to_set_disj [in ISL.Environments]
+gmultiset_rec [in ISL.Environments]
+gmultiset_choose_or_empty [in ISL.Environments]
+GN_inv_noinit_nolessub [in GL.Interpolation.UIGL_braga]
+GN_inv_noinit_lessub [in GL.Interpolation.UIGL_braga]
+GN_inv_init [in GL.Interpolation.UIGL_braga]
+GN_fun0 [in GL.Interpolation.UIGL_braga]
+GN_fun [in GL.Interpolation.UIGL_braga]
+GN_inv_noinit_nolessub0 [in GL.Interpolation.UIGL_braga]
+GN_inv_noinit_lessub0 [in GL.Interpolation.UIGL_braga]
+GN_inv_init0 [in GL.Interpolation.UIGL_braga]
+Good_pos_in_pos_top_imps [in GL.GLS.GLS_der_dec]
+Good_pos_in_pos_top_imps [in K.KS.KS_termination_ImpR]
+gsc_gstr [in General.gentree]
+gstr_gf2 [in General.gentree]
+gs_gs' [in General.gstep]
+gs_gsc [in General.gentree]
+gs2c_gs2tr [in General.gentree]
+gs2tr_gf2 [in General.gentree]
+gs2_hs2 [in General.gentree]
+gs2_tr_height [in General.gentree]
+gs2_tr_size [in General.gentree]
+gs2_gs2c [in General.gentree]
+GUI_inv_critic_not_init [in K.Interpolation.UIK_braga]
+GUI_inv_not_critic [in K.Interpolation.UIK_braga]
+GUI_inv_critic_init [in K.Interpolation.UIK_braga]
+GUI_inv_empty_seq [in K.Interpolation.UIK_braga]
+GUI_fun [in K.Interpolation.UIK_braga]
+GUI_inv_critic_not_init [in GL.Interpolation.UIGL_braga]
+GUI_inv_not_critic [in GL.Interpolation.UIGL_braga]
+GUI_inv_critic_init [in GL.Interpolation.UIGL_braga]
+GUI_inv_empty_seq [in GL.Interpolation.UIGL_braga]
+GUI_fun [in GL.Interpolation.UIGL_braga]
+

H

+height_0 [in ISL.SequentProps]
+height_step2_tr_lem [in General.gentree]
+hs2_sumh [in General.gentree]
+

I

+Id_all_form [in GL.GLS.GLS_calcs]
+Id_all_form [in K.KS.KS_calc]
+Id_InT_Canopy [in K.Interpolation.UIK_Canopy]
+iffD1 [in General.gen]
+iffD2 [in General.gen]
+iffT_prod [in General.genT]
+iffT_D2' [in General.genT]
+iffT_D1' [in General.genT]
+iffT_refl [in General.genT]
+iffT_sym' [in General.genT]
+iffT_trans [in General.genT]
+if_rev_eq [in General.List_lemmasT]
+if_eq_rev_eq [in General.List_lemmasT]
+ImpBox_dup [in ISL.SequentProps]
+ImpL [in ISL.SequentProps]
+ImpLAnd_rev [in ISL.SequentProps]
+ImpLBox_prev [in ISL.SequentProps]
+ImpLImp_dup [in ISL.SequentProps]
+ImpLImp_prev [in ISL.SequentProps]
+ImpLOr_rev [in ISL.SequentProps]
+ImpLVar_rev [in ISL.SequentProps]
+ImpL_app_ctr_R [in K.KS.KS_ctr]
+ImpL_app_ctr_L [in K.KS.KS_ctr]
+ImpL_app_wkn_R [in K.KS.KS_wkn]
+ImpL_app_wkn_L [in K.KS.KS_wkn]
+ImpL_app_wkn_R [in GL.GLS.GLS_wkn]
+ImpL_app_wkn_L [in GL.GLS.GLS_wkn]
+ImpL_app_list_exchR [in K.KS.KS_exch_ImpL]
+ImpL_app_list_exchL [in K.KS.KS_exch_ImpL]
+ImpL_applic_reduces_measure [in GL.GLS.GLS_termination_measure]
+ImpL_applic_reduces_ub_or_imp [in GL.GLS.GLS_termination_measure]
+ImpL_applic_less_Imp_same_usable_boxes [in GL.GLS.GLS_termination_measure]
+ImpL_inv [in GL.GLS.GLS_inv_ImpR_ImpL]
+ImpL_app_list_exchR [in GL.GLS.GLS_exch]
+ImpL_app_list_exchL [in GL.GLS.GLS_exch]
+ImpL_app_ctr_R [in GL.GLS.GLS_ctr]
+ImpL_app_ctr_L [in GL.GLS.GLS_ctr]
+ImpL_inv [in K.KS.KS_inv_ImpR_ImpL]
+ImpRule_Canopy [in GL.Interpolation.UIGL_Canopy]
+ImpRule_Canopy [in K.Interpolation.UIK_Canopy]
+ImpR_app_ctr_R [in K.KS.KS_ctr]
+ImpR_app_ctr_L [in K.KS.KS_ctr]
+ImpR_app_wkn_R [in K.KS.KS_wkn]
+ImpR_app_wkn_L [in K.KS.KS_wkn]
+ImpR_rev [in ISL.SequentProps]
+ImpR_app_wkn_R [in GL.GLS.GLS_wkn]
+ImpR_app_wkn_L [in GL.GLS.GLS_wkn]
+ImpR_applic_reduces_measure [in GL.GLS.GLS_termination_measure]
+ImpR_applic_reduces_ub_or_imp [in GL.GLS.GLS_termination_measure]
+ImpR_applic_less_Imp_same_usable_boxes [in GL.GLS.GLS_termination_measure]
+ImpR_inv [in GL.GLS.GLS_inv_ImpR_ImpL]
+ImpR_ImpL_hpinv [in GL.GLS.GLS_inv_ImpR_ImpL]
+ImpR_app_list_exchR [in GL.GLS.GLS_exch]
+ImpR_app_list_exchL [in GL.GLS.GLS_exch]
+ImpR_app_ctr_R [in GL.GLS.GLS_ctr]
+ImpR_app_ctr_L [in GL.GLS.GLS_ctr]
+ImpR_inv [in K.KS.KS_inv_ImpR_ImpL]
+ImpR_ImpL_hpinv [in K.KS.KS_inv_ImpR_ImpL]
+ImpR_app_list_exchR [in K.KS.KS_exch_ImpR]
+ImpR_app_list_exchL [in K.KS.KS_exch_ImpR]
+imp_cut [in ISL.SequentProps]
+incl_idS [in GL.Interpolation.UIGL_nodupseq]
+incl_id [in GL.Interpolation.UIGL_nodupseq]
+incl_ctr_R [in GL.Interpolation.UIGL_nodupseq]
+incl_ctr_R_hpadm [in GL.Interpolation.UIGL_nodupseq]
+incl_ctr_L [in GL.Interpolation.UIGL_nodupseq]
+incl_ctr_L_hpadm [in GL.Interpolation.UIGL_nodupseq]
+incl_nodup_top_boxes [in GL.Interpolation.UIGL_nodupseq]
+incl_nodupseq_subform_boxesS [in GL.Interpolation.UIGL_nodupseq]
+incl_nodup_subform_boxesLF [in GL.Interpolation.UIGL_nodupseq]
+incl_prv [in GL.Interpolation.UIGL_UI_prelims]
+incl_hpadm_prv [in GL.Interpolation.UIGL_UI_prelims]
+inhabited_anon [in General.genT]
+InT_seqext [in General.gen_seq]
+InT_seqextR [in General.gen_seq]
+InT_seqextL [in General.gen_seq]
+InT_list_of_premises_exists_prems [in K.KS.KS_termination]
+InT_In_Seq [in K.Interpolation.UIK_basics]
+InT_list_of_premises_exists_prems [in GL.GLS.GLS_der_dec]
+InT_univ_gen_mod [in General.univ_gen_mod]
+InT_In_Seq [in GL.Interpolation.UIGL_basics]
+InT_gen_ext [in General.univ_gen_ext]
+InT_univ_gen_ext [in General.univ_gen_ext]
+InT_var_provar [in K.Interpolation.K_Craig_Interp]
+InT_list_exch_L [in K.KS.KS_exch_prelims]
+InT_list_exch_R [in K.KS.KS_exch_prelims]
+InT_flat_map [in GL.Interpolation.UIGL_Canopy]
+InT_In_inv_prems [in GL.Interpolation.UIGL_Canopy]
+InT_list_exch_L [in GL.GLS.GLS_exch]
+InT_list_exch_R [in GL.GLS.GLS_exch]
+InT_singleton_mid [in General.List_lemmasT]
+InT_mid [in General.List_lemmasT]
+InT_pt_I [in General.List_lemmasT]
+InT_dec [in Syntax.list_lems]
+InT_exch_list [in Syntax.list_lems]
+InT_In_eq' [in General.genT]
+InT_In_eq [in General.genT]
+InT_In' [in General.genT]
+InT_In [in General.genT]
+InT_concat [in General.genT]
+InT_mapE [in General.genT]
+InT_map [in General.genT]
+InT_inv [in General.genT]
+InT_split [in General.genT]
+InT_nilE [in General.genT]
+InT_nilE' [in General.genT]
+InT_appE [in General.genT]
+InT_appE' [in General.genT]
+InT_appR [in General.genT]
+InT_appL [in General.genT]
+InT_flat_map [in K.Interpolation.UIK_Canopy]
+InT_In_inv_prems [in K.Interpolation.UIK_Canopy]
+inv_prems_measure [in K.Interpolation.UIK_UI_prelims]
+inv_prems_LtSeq [in K.Interpolation.UIK_basics]
+inv_prems_id_critical [in GL.Interpolation.UIGL_Canopy]
+inv_prems_LexSeq [in GL.Interpolation.UIGL_LexSeq]
+inv_prems_id_critical [in K.Interpolation.UIK_Canopy]
+in_drs_concl_in_allT [in K.KS.KS_termination]
+In_unboxed_list [in K.Interpolation.UIK_UI_prelims]
+In_list_In_propvar_subform_list [in K.Interpolation.UIK_UI_prelims]
+In_list_In_list_prop_LF [in K.Interpolation.UIK_UI_prelims]
+In_list_prop_LF [in K.Interpolation.UIK_UI_prelims]
+In_list_prop_LF_bis [in K.Interpolation.UIK_basics]
+In_list_prop_LF [in K.Interpolation.UIK_basics]
+In_l_imp_In_pos_top_imps [in GL.GLS.GLS_der_dec]
+In_pos_top_imps_In_l [in GL.GLS.GLS_der_dec]
+In_pos_top_imps_imp [in GL.GLS.GLS_der_dec]
+In_pos_top_imps_0_False [in GL.GLS.GLS_der_dec]
+In_listInserts [in GL.GLS.GLS_der_dec]
+In_InT [in GL.GLS.GLS_der_dec]
+in_replace [in GL.Interpolation.UIGL_Canopy_ImpR]
+in_not_touched_replace [in GL.Interpolation.UIGL_Canopy_ImpR]
+In_listInserts [in K.KS.KS_termination_prelims]
+In_InT [in K.KS.KS_termination_prelims]
+In_list_prop_LF_bis [in GL.Interpolation.UIGL_basics]
+In_list_prop_LF [in GL.Interpolation.UIGL_basics]
+in_nextup_fc_eqv [in General.dd_fc]
+in_nextup_eqv [in General.dd_fc]
+in_trees_drs [in General.dd_fc]
+in_drs_trees [in General.dd_fc]
+in_drs_drs_hd [in General.dd_fc]
+in_dersrec_single' [in General.dd_fc]
+in_nextup_concl_in [in General.dd_fc]
+in_drs_concl_in [in General.dd_fc]
+In_XBoxed_list_gen [in GL.Interpolation.UIGL_nodupseq]
+In_XBoxed_list [in GL.Interpolation.UIGL_nodupseq]
+in_derl [in General.ddT]
+in_single [in General.gen]
+In_matters_remove_list [in Syntax.remove_list_lems]
+In_remove_list_remove_redund [in Syntax.remove_list_lems]
+In_remove_list_In_list_not_In_remove_list [in Syntax.remove_list_lems]
+In_remove_list_In_list [in Syntax.remove_list_lems]
+In_remove_In_list [in Syntax.remove_list_lems]
+In_remove_length_same [in Syntax.remove_list_lems]
+In_remove_same [in Syntax.remove_list_lems]
+In_remove_diff [in Syntax.remove_list_lems]
+in_remove_in_init [in Syntax.remove_list_lems]
+in_not_touched_remove [in Syntax.remove_list_lems]
+in_top_boxes [in GL.GLS.GLS_termination_measure]
+In_incl_subform_boxes [in GL.GLS.GLS_termination_measure]
+in_subform_boxesF_smaller_length_form [in GL.GLS.GLS_termination_measure]
+In_subform_boxesLF_box [in GL.GLS.GLS_termination_measure]
+In_subform_boxesF_box [in GL.GLS.GLS_termination_measure]
+In_n_imp_subformLF_is_non_0 [in GL.GLS.GLS_termination_measure]
+In_propvar_subform [in GL.Interpolation.UIGL_UI_prelims]
+In_subform_boxes [in GL.Interpolation.UIGL_UI_prelims]
+In_list_In_propvar_subform_list [in GL.Interpolation.UIGL_UI_prelims]
+In_list_In_list_prop_LF [in GL.Interpolation.UIGL_UI_prelims]
+In_list_prop_LF [in GL.Interpolation.UIGL_UI_prelims]
+In_l_imp_In_pos_top_imps [in K.KS.KS_termination_ImpR]
+In_pos_top_imps_In_l [in K.KS.KS_termination_ImpR]
+In_pos_top_imps_imp [in K.KS.KS_termination_ImpR]
+In_pos_top_imps_0_False [in K.KS.KS_termination_ImpR]
+in_splitT [in Syntax.list_lems]
+in_exch_list [in Syntax.list_lems]
+In_InT [in General.genT]
+In_open_boxes [in ISL.Environments]
+in_rm [in ISL.Environments]
+in_difference [in ISL.Environments]
+in_map_ext [in ISL.Environments]
+in_map_empty [in ISL.Environments]
+in_map_in [in ISL.Environments]
+in_in_map [in ISL.Environments]
+In_n_imp_subformLF_is_non_0 [in K.Interpolation.UIK_Canopy]
+In_Box_size_LF_is_non_0 [in K.KS.KS_termination_measure]
+In_Imp_size_LF_is_non_0 [in K.KS.KS_termination_measure]
+irred_provability [in K.Interpolation.UIK_irred_high_level]
+irred_high_level_spec [in K.Interpolation.UIK_irred_high_level]
+irred_reach [in K.Interpolation.UIK_irred_high_level]
+irred_max [in K.Interpolation.UIK_irred_high_level]
+irred_not [in K.Interpolation.UIK_irred_short]
+irred_nil [in K.Interpolation.UIK_irred_short]
+irred_spec [in K.Interpolation.UIK_irred_short]
+irred_provability [in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level_spec [in GL.Interpolation.UIGL_irred_high_level]
+irred_reach [in GL.Interpolation.UIGL_irred_high_level]
+irred_max [in GL.Interpolation.UIGL_irred_high_level]
+irred_not [in GL.Interpolation.UIGL_irred_short]
+irred_nil [in GL.Interpolation.UIGL_irred_short]
+irred_spec [in GL.Interpolation.UIGL_irred_short]
+iSL_uniform_interpolation [in ISL.PropQuantifiers]
+is_init_UI [in K.Interpolation.UIK_UI_prelims]
+is_init_UI_equiv_Top [in K.Interpolation.UIK_UI_prelims]
+is_init_Canopy [in K.Interpolation.UIK_UI_prelims]
+is_box_weight_open_box [in ISL.SequentProps]
+is_Boxed_list_top_boxes [in Syntax.CML_Syntax]
+is_box_is_in_boxed_list [in Syntax.CML_Syntax]
+is_nextup_ndt [in General.dd_fc]
+is_init_nodupseq [in GL.Interpolation.UIGL_nodupseq]
+is_box_in_top_boxes [in GL.GLS.GLS_termination_measure]
+is_init_UI [in GL.Interpolation.UIGL_UI_prelims]
+is_init_UI_equiv_Top [in GL.Interpolation.UIGL_UI_prelims]
+is_init_Canopy [in GL.Interpolation.UIGL_UI_prelims]
+is_not_box_open_box [in ISL.Environments]
+is_implication_obviously_smaller [in ISL.Optimizations]
+

K

+keep_list_delete_head_not_In [in Syntax.remove_list_lems]
+keep_list_delete_head_not_origin [in Syntax.remove_list_lems]
+KR_app_ctr_R [in K.KS.KS_ctr]
+KR_app_ctr_L [in K.KS.KS_ctr]
+KR_app_wkn_R [in K.KS.KS_wkn]
+KR_app_wkn_L [in K.KS.KS_wkn]
+KR_prems_LtSeq [in K.Interpolation.UIK_basics]
+KR_app_list_exchR [in K.KS.KS_exch_KR]
+KR_app_list_exchL [in K.KS.KS_exch_KR]
+KS_hpadm_list_ctr_R [in K.KS.KS_ctr]
+KS_hpadm_list_ctr_L [in K.KS.KS_ctr]
+KS_hpadm_ctr_R [in K.KS.KS_ctr]
+KS_hpadm_ctr_L [in K.KS.KS_ctr]
+KS_hpadm_ctr_LR [in K.KS.KS_ctr]
+KS_hpadm_ctr_LR0 [in K.KS.KS_ctr]
+KS_list_wkn_L [in K.KS.KS_wkn]
+KS_list_wkn_R [in K.KS.KS_wkn]
+KS_hpadm_wkn_R [in K.KS.KS_wkn]
+KS_wkn_R [in K.KS.KS_wkn]
+KS_hpadm_wkn_L [in K.KS.KS_wkn]
+KS_wkn_L [in K.KS.KS_wkn]
+KS_termin_der_is_mhd [in K.KS.KS_termination]
+KS_termin3 [in K.KS.KS_termination]
+KS_termin2 [in K.KS.KS_termination]
+KS_termin1 [in K.KS.KS_termination]
+KS_termin [in K.KS.KS_termination]
+KS_termin_base [in K.KS.KS_termination]
+KS_cut_elimination [in K.KS.KS_cut_elim]
+KS_cut_adm [in K.KS.KS_additive_cut]
+KS_cut_adm_main [in K.KS.KS_additive_cut]
+KS_adm_list_exch_LR [in K.KS.KS_exch]
+KS_hpadm_list_exch_R [in K.KS.KS_exch]
+KS_hpadm_list_exch_L [in K.KS.KS_exch]
+KS_hpadm_list_exch_L0 [in K.KS.KS_exch]
+KS_hpadm_list_exch_R0 [in K.KS.KS_exch]
+KS_der_list_exch_R [in K.KS.KS_exch]
+KS_der_list_exch_L [in K.KS.KS_exch]
+KS_adm_list_exch_R [in K.KS.KS_exch]
+KS_adm_list_exch_L [in K.KS.KS_exch]
+

L

+length_le_remove_list [in Syntax.remove_list_lems]
+length_usable_boxes_is_0 [in GL.GLS.GLS_termination_measure]
+leq_ub_Canopy [in GL.Interpolation.UIGL_LexSeq]
+leq_ub_unif [in GL.Interpolation.UIGL_LexSeq]
+less_thanS_strong_inductionT [in GL.GLS.GLS_termination_measure]
+less_thanS_trans [in GL.GLS.GLS_termination_measure]
+less_thanS_wf [in GL.GLS.GLS_termination_measure]
+less_thanS_inv [in GL.GLS.GLS_termination_measure]
+less_ub_witness [in GL.Interpolation.UIGL_UI_prelims]
+leT_ex_plus [in General.genT]
+leT_or_gt [in General.genT]
+leT_S_or_eq [in General.genT]
+leT_S_F [in General.genT]
+leT_plus_l [in General.genT]
+leT_plus_r [in General.genT]
+leT_0_n [in General.genT]
+leT_trans' [in General.genT]
+leT_S_n' [in General.genT]
+leT_n_S [in General.genT]
+LexSeq_nodupseq_case [in GL.Interpolation.UIGL_nodupseq]
+LexSeq_nodupseq [in GL.Interpolation.UIGL_nodupseq]
+LexSeq_trans [in GL.Interpolation.UIGL_LexSeq]
+lex_rect [in K.Interpolation.UIK_Def_measure]
+lex_wf [in K.Interpolation.UIK_Def_measure]
+lex_cons_inv [in K.Interpolation.UIK_Def_measure]
+lex_length [in K.Interpolation.UIK_Def_measure]
+lex_trans [in GL.GLS.GLS_termination_measure]
+lex_wf [in GL.GLS.DLW_wf_lex]
+lex_cons_inv [in GL.GLS.DLW_wf_lex]
+lex_length [in GL.GLS.DLW_wf_lex]
+lex_rect [in GL.Interpolation.UIGL_Def_measure]
+lex_wf [in GL.Interpolation.UIGL_Def_measure]
+lex_cons_inv [in GL.Interpolation.UIGL_Def_measure]
+lex_length [in GL.Interpolation.UIGL_Def_measure]
+le_False_lt [in GL.GLS.GLS_der_dec]
+le_False_lt [in K.KS.KS_termination_prelims]
+le_dersrec_height [in General.dd_fc]
+Lindenbaum_Tarski_preorder_Bot [in ISL.Optimizations]
+listInserts_In [in GL.GLS.GLS_der_dec]
+listInserts_In [in K.KS.KS_termination_prelims]
+list_disj_wkn_R [in K.Interpolation.UIK_UI_prelims]
+list_disj_L [in K.Interpolation.UIK_UI_prelims]
+list_conj_R [in K.Interpolation.UIK_UI_prelims]
+list_conj_wkn_L [in K.Interpolation.UIK_UI_prelims]
+list_prop_LF_propvar_subform_list [in K.Interpolation.UIK_UI_prelims]
+list_prop_LF_In [in K.Interpolation.UIK_basics]
+list_prop_LF_In [in GL.Interpolation.UIGL_basics]
+list_disj_wkn_R [in GL.Interpolation.UIGL_And_Or_rules]
+list_disj_L [in GL.Interpolation.UIGL_And_Or_rules]
+list_conj_R [in GL.Interpolation.UIGL_And_Or_rules]
+list_conj_wkn_L [in GL.Interpolation.UIGL_And_Or_rules]
+list_preserv_XBoxed_list [in GL.GLS.GLS_calcs]
+list_exch_L_permLR [in K.KS.KS_exch_prelims]
+list_exch_L_permR [in K.KS.KS_exch_prelims]
+list_exch_L_permL [in K.KS.KS_exch_prelims]
+list_exch_R_permLR [in K.KS.KS_exch_prelims]
+list_exch_R_permR [in K.KS.KS_exch_prelims]
+list_exch_R_permL [in K.KS.KS_exch_prelims]
+list_exch_L_same_R [in K.KS.KS_exch_prelims]
+list_exch_R_same_L [in K.KS.KS_exch_prelims]
+list_exch_L_id [in K.KS.KS_exch_prelims]
+list_exch_R_id [in K.KS.KS_exch_prelims]
+list_prop_LF_In [in GL.Interpolation.UIGL_UI_prelims]
+list_prop_LF_propvar_subform_list [in GL.Interpolation.UIGL_UI_prelims]
+list_exch_R_BotL_notapplic [in GL.GLS.GLS_exch]
+list_exch_R_IdB_notapplic [in GL.GLS.GLS_exch]
+list_exch_R_IdP_notapplic [in GL.GLS.GLS_exch]
+list_exch_L_BotL_notapplic [in GL.GLS.GLS_exch]
+list_exch_L_IdB_notapplic [in GL.GLS.GLS_exch]
+list_exch_L_IdP_notapplic [in GL.GLS.GLS_exch]
+list_exch_L_permLR [in GL.GLS.GLS_exch]
+list_exch_L_permR [in GL.GLS.GLS_exch]
+list_exch_L_permL [in GL.GLS.GLS_exch]
+list_exch_R_permLR [in GL.GLS.GLS_exch]
+list_exch_R_permR [in GL.GLS.GLS_exch]
+list_exch_R_permL [in GL.GLS.GLS_exch]
+list_exch_L_same_R [in GL.GLS.GLS_exch]
+list_exch_R_same_L [in GL.GLS.GLS_exch]
+list_exch_L_id [in GL.GLS.GLS_exch]
+list_exch_R_id [in GL.GLS.GLS_exch]
+list_nil_or_tail_singleton [in General.List_lemmasT]
+list_insert1 [in General.List_lemmasT]
+list_eq_singleT_nobrac [in General.List_lemmasT]
+list_eq_singleT [in General.List_lemmasT]
+list_eq_single [in General.List_lemmasT]
+list_eq_nil [in General.List_lemmasT]
+list_rearr23 [in General.List_lemmasT]
+list_rearr22 [in General.List_lemmasT]
+list_rearr21 [in General.List_lemmasT]
+list_rearr20 [in General.List_lemmasT]
+list_rearr19 [in General.List_lemmasT]
+list_rearr18 [in General.List_lemmasT]
+list_rearr17_R [in General.List_lemmasT]
+list_rearr16_R [in General.List_lemmasT]
+list_rearr16 [in General.List_lemmasT]
+list_rearr16' [in General.List_lemmasT]
+list_rearr15_R [in General.List_lemmasT]
+list_rearr15 [in General.List_lemmasT]
+list_rearr14 [in General.List_lemmasT]
+list_rearr13 [in General.List_lemmasT]
+list_rearr11 [in General.List_lemmasT]
+list_rearr10 [in General.List_lemmasT]
+list_rearr9 [in General.List_lemmasT]
+list_rearr8 [in General.List_lemmasT]
+list_rearr7 [in General.List_lemmasT]
+list_rearr6 [in General.List_lemmasT]
+list_rearr5 [in General.List_lemmasT]
+list_rearr4 [in General.List_lemmasT]
+list_rearr2 [in General.List_lemmasT]
+list_rearr1 [in General.List_lemmasT]
+list_split_form [in Syntax.list_lems]
+list_to_set_disj_open_boxes [in ISL.Environments]
+list_to_set_disj_rm [in ISL.Environments]
+list_to_set_disj_env_add [in ISL.Environments]
+LtSeq_trans [in K.Interpolation.UIK_basics]
+lt_decT [in K.Interpolation.UIK_basics]
+

M

+make_conj_comm_ctx_L [in ISL.Simp]
+make_conj_comm_ctx_R [in ISL.Simp]
+make_conj_comm [in ISL.Simp]
+make_disj_comm_ctx_L [in ISL.Simp]
+make_disj_comm_ctx_R [in ISL.Simp]
+make_disj_comm [in ISL.Simp]
+make_impl_complete_R [in ISL.Optimizations]
+make_impl_complete_L2 [in ISL.Optimizations]
+make_impl_complete_L [in ISL.Optimizations]
+make_impl_sound_L2' [in ISL.Optimizations]
+make_impl_sound_L2 [in ISL.Optimizations]
+make_impl_sound_R [in ISL.Optimizations]
+make_impl_sound_L [in ISL.Optimizations]
+make_disj_complete_R [in ISL.Optimizations]
+make_disj_sound_R [in ISL.Optimizations]
+make_disj_complete_L [in ISL.Optimizations]
+make_disj_sound_L [in ISL.Optimizations]
+make_disj_equiv_R [in ISL.Optimizations]
+make_disj_equiv_L [in ISL.Optimizations]
+make_conj_complete_R [in ISL.Optimizations]
+make_conj_sound_R [in ISL.Optimizations]
+make_conj_complete_L [in ISL.Optimizations]
+make_conj_sound_L [in ISL.Optimizations]
+make_conj_equiv_R [in ISL.Optimizations]
+make_conj_equiv_L [in ISL.Optimizations]
+map_fmlsext_fmlsext [in General.gen_seq]
+map_seqext_seqext [in General.gen_seq]
+map_eq_nil [in General.gen]
+map_app_ex [in General.gen]
+map_cons_ex' [in General.gen]
+map_cons_ex [in General.gen]
+measure_is_0 [in K.KS.KS_termination_measure]
+midI [in General.gen_tacs]
+multeq_meq [in ISL.Environments]
+mult_ImpR [in GL.Interpolation.UIGL_Canopy_ImpR]
+mult_ImpL_L [in GL.Interpolation.UIGL_Canopy_ImpL]
+mult_ImpL_R [in GL.Interpolation.UIGL_Canopy_ImpL]
+

N

+nextup_height [in General.dd_fc]
+nextup_height [in General.gentree]
+nextup_size [in General.gentree]
+nnn_app_eq [in General.List_lemmasT]
+nobox_top_boxes [in K.Interpolation.UIK_UI_prelims]
+nobox_gen_ext_top_boxes_identity [in GL.GLS.GLS_der_dec]
+nobox_gen_ext_top_boxes_identity [in K.KS.KS_termination_prelims]
+nobox_gen_ext_top_boxes [in Syntax.CML_Syntax]
+nobox_gen_ext_injective [in Syntax.CML_Syntax]
+nobox_gen_ext_exch_L [in K.KS.KS_exch_prelims]
+nobox_gen_ext_exch_R [in K.KS.KS_exch_prelims]
+nobox_top_boxes [in GL.Interpolation.UIGL_UI_prelims]
+nobox_gen_ext_exch_L [in GL.GLS.GLS_exch]
+nobox_gen_ext_exch_R [in GL.GLS.GLS_exch]
+nodupseq_prv_hpadm_RL [in GL.Interpolation.UIGL_nodupseq]
+nodupseq_prv_hpadm_LR [in GL.Interpolation.UIGL_nodupseq]
+nodupseq_prv [in GL.Interpolation.UIGL_nodupseq]
+nodupseq_hpadm_prv_RL [in GL.Interpolation.UIGL_nodupseq]
+nodupseq_hpadm_prv_LR [in GL.Interpolation.UIGL_nodupseq]
+nodupseq_id [in GL.Interpolation.UIGL_nodupseq]
+nodupseq_GLR_prems [in GL.Interpolation.UIGL_nodupseq]
+nodup_length [in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+nodup_id [in GL.Interpolation.UIGL_nodupseq]
+nodup_XBoxed_list [in GL.Interpolation.UIGL_nodupseq]
+nodup_top_boxes [in GL.Interpolation.UIGL_nodupseq]
+nodup_nil [in GL.Interpolation.UIGL_nodupseq]
+nodup_app [in GL.Interpolation.UIGL_nodupseq]
+NoDup_destr_split [in Syntax.remove_list_lems]
+NoDup_usable_boxes [in GL.GLS.GLS_termination_measure]
+NoDup_subform_boxesS [in GL.GLS.GLS_termination_measure]
+NoDup_subform_boxesLF [in GL.GLS.GLS_termination_measure]
+NoDup_subform_boxesF [in GL.GLS.GLS_termination_measure]
+NoDup_incl_lengthT [in GL.GLS.GLS_termination_measure]
+NoDup_incl_lengthT [in K.KS.KS_termination_measure]
+nolessub_In [in GL.Interpolation.UIGL_UI_prelims]
+noless_ub_incl_subform_boxesS [in GL.Interpolation.UIGL_Diam_UI_imp_N_prelim]
+notin_replace [in GL.Interpolation.UIGL_Canopy_ImpR]
+not_init_empty_set [in K.Interpolation.UIK_basics]
+not_removed_remove_list [in Syntax.remove_list_lems]
+not_init_empty_seq [in GL.Interpolation.UIGL_LexSeq]
+no_usable_boxes_all_RHS_are_LHS [in GL.GLS.GLS_termination_measure]
+no_RHS_box_no_GLR [in GL.GLS.GLS_termination_measure]
+no_KS_rule_applic [in K.KS.KS_termination_measure]
+nth_split_length_id [in GL.GLS.GLS_der_dec]
+nth_split_idR [in GL.GLS.GLS_der_dec]
+nth_split_idL [in GL.GLS.GLS_der_dec]
+nth_split_length [in GL.GLS.GLS_der_dec]
+nth_split_length_id [in K.KS.KS_termination_prelims]
+nth_split_idR [in K.KS.KS_termination_prelims]
+nth_split_idL [in K.KS.KS_termination_prelims]
+nth_split_length [in K.KS.KS_termination_prelims]
+N_spec [in GL.Interpolation.UIGL_braga]
+n_imp_subformS_ImpR_mult [in GL.Interpolation.UIGL_Canopy_ImpR]
+n_imp_subformLF_replace [in GL.Interpolation.UIGL_Canopy_ImpR]
+n_imp_subformS_nodupseq [in GL.Interpolation.UIGL_nodupseq]
+n_imp_subformLF_nodup [in GL.Interpolation.UIGL_nodupseq]
+n_imp_subformLF_dist_app [in GL.GLS.GLS_termination_measure]
+n_imp_subformS_is_0 [in GL.GLS.GLS_termination_measure]
+N_nodupseq [in GL.Interpolation.UIGL_UI_inter]
+n_imp_unboxed [in K.Interpolation.UIK_Canopy]
+n_imp_nobox_gen_ext [in K.Interpolation.UIK_Canopy]
+n_imp_subformLF_dist_app [in K.Interpolation.UIK_Canopy]
+n_imp_subformS_is_0 [in K.Interpolation.UIK_Canopy]
+

O

+obviously_smaller_compatible_GT [in ISL.Optimizations]
+obviously_smaller_compatible_LT [in ISL.Optimizations]
+occurs_in_map_open_box [in ISL.Environments]
+occurs_in_open_boxes [in ISL.Environments]
+occurs_in_make_impl2 [in ISL.Environments]
+occurs_in_make_impl [in ISL.Environments]
+occurs_in_make_disj [in ISL.Environments]
+occurs_in_make_conj [in ISL.Environments]
+openboxes_env_order [in ISL.Order]
+open_boxes_case [in ISL.SequentProps]
+open_boxes_R [in ISL.SequentProps]
+open_box_L [in ISL.SequentProps]
+open_boxes_env_order [in ISL.Order]
+open_boxes_spec' [in ISL.Environments]
+open_boxes_spec [in ISL.Environments]
+open_boxes_remove [in ISL.Environments]
+open_boxes_add [in ISL.Environments]
+open_boxes_singleton [in ISL.Environments]
+open_boxes_disj_union [in ISL.Environments]
+open_boxes_empty [in ISL.Environments]
+OrL [in K.Interpolation.UIK_UI_prelims]
+OrL [in GL.Interpolation.UIGL_And_Or_rules]
+OrL_inv [in GL.Interpolation.UIGL_And_Or_rules]
+OrL_rev [in ISL.SequentProps]
+OrR [in K.Interpolation.UIK_UI_prelims]
+OrR [in GL.Interpolation.UIGL_And_Or_rules]
+OrR_inv [in GL.Interpolation.UIGL_And_Or_rules]
+OrR_idemp [in ISL.Optimizations]
+OrR1Bot_rev [in ISL.SequentProps]
+OrR2Bot_rev [in ISL.SequentProps]
+or_assoc_ctx_R_R [in ISL.Simp]
+or_assoc_ctx_R_L [in ISL.Simp]
+or_assoc_ctx_L_R [in ISL.Simp]
+or_assoc_L [in ISL.Simp]
+or_assoc_R [in ISL.Simp]
+or_comm_ctx_R [in ISL.Simp]
+or_comm_ctx_L [in ISL.Simp]
+or_comm [in ISL.Simp]
+or_false [in General.gen]
+or_congruence [in ISL.Optimizations]
+

P

+pair_eqI [in General.gen]
+partition_singleton_app [in General.List_lemmasT]
+partition_2_3 [in General.List_lemmasT]
+partition_3_2 [in General.List_lemmasT]
+partition_2_2T [in General.List_lemmasT]
+partition_2_2 [in General.List_lemmasT]
+partition_1_element2 [in Syntax.list_lems]
+partition_1_element [in Syntax.list_lems]
+PermutationTS_nodupseq [in GL.Interpolation.UIGL_nodupseq]
+PermutationTS_Canopy [in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_usable_boxes [in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_critic [in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_is_init [in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_GLR_prems [in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_restr_list_prop_fst [in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_restr_list_prop_snd [in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_prv [in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_prv_hpadm [in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_sym [in GL.Interpolation.UIGL_PermutationTS]
+PermutationTS_UI [in GL.Interpolation.UIGL_UI_inter]
+PermutationT_ind_T [in GL.Interpolation.UIGL_PermutationT]
+PermutationT_cons_app [in GL.Interpolation.UIGL_PermutationT]
+PermutationT_app_comm [in GL.Interpolation.UIGL_PermutationT]
+PermutationT_cons_append [in GL.Interpolation.UIGL_PermutationT]
+PermutationT_app [in GL.Interpolation.UIGL_PermutationT]
+PermutationT_app_head [in GL.Interpolation.UIGL_PermutationT]
+PermutationT_app_tail [in GL.Interpolation.UIGL_PermutationT]
+PermutationT_sym [in GL.Interpolation.UIGL_PermutationT]
+PermutationT_refl [in GL.Interpolation.UIGL_PermutationT]
+PermutationT_nodupseq [in GL.Interpolation.UIGL_PermutationTS]
+PermutationT_top_boxes [in GL.Interpolation.UIGL_PermutationTS]
+PermutationT_XBoxed_list [in GL.Interpolation.UIGL_PermutationTS]
+Permutation_replace [in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+Permutation_remove [in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+Permutation_repeat_extract [in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+Permutation_replace_repeat [in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+Permutation_PermutationT [in GL.Interpolation.UIGL_PermutationT]
+Permutation_vs_cons_invT [in GL.Interpolation.UIGL_PermutationT]
+Permutation_vs_elt_invT [in GL.Interpolation.UIGL_PermutationT]
+Permutation_subform_boxesLF [in GL.Interpolation.UIGL_PermutationTS]
+permut_remove_remove_list [in Syntax.remove_list_lems]
+permut_remove [in Syntax.remove_list_lems]
+PiffD1 [in General.gen]
+PiffD2 [in General.gen]
+pow5_gt_0 [in ISL.Order]
+pq_correct [in ISL.PropQuantifiers]
+prems_dersrec [in General.ddT]
+prod_nat_split [in General.genT]
+prod_mono [in General.genT]
+Proof_tree_dec [in ISL.DecisionProcedure]
+propvar_subform_list_restr_list_prop [in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_Canopy [in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_witnessT [in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_witness [in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_disj [in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_conj [in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_top_boxes [in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_nobox_gen_ext [in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_unboxed_list [in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_app [in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list_nobox_gen_ext [in K.Interpolation.K_Craig_Interp]
+propvar_subform_list_unboxed_list [in K.Interpolation.K_Craig_Interp]
+propvar_subform_list_app [in K.Interpolation.K_Craig_Interp]
+propvar_subform_list_nodup [in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_restr_list_prop [in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_Canopy [in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_witnessT [in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_witness [in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_disj [in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_conj [in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_top_boxes [in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_nobox_gen_ext [in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_XBoxed_list [in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform_list_app [in GL.Interpolation.UIGL_UI_prelims]
+Provable_dec [in ISL.DecisionProcedure]
+p_contr [in ISL.SequentProps]
+

R

+rappl [in General.gen]
+RA_mhd_decreases [in K.KS.KS_termination]
+rec_UI_imp [in GL.Interpolation.UIGL_N_imp_UI]
+redundant_flatten_list [in GL.GLS.GLS_der_dec]
+redundant_flatten_list [in K.KS.KS_termination_prelims]
+redund_remove_list [in Syntax.remove_list_lems]
+redund_remove [in Syntax.remove_list_lems]
+redund_remove_remove_list [in Syntax.remove_list_lems]
+rel_adm_rtc [in General.gstep]
+removed_box_exists [in GL.GLS.GLS_termination_measure]
+remove_n_imp_subformLF_decomp [in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+remove_n_imp_subformLF [in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+remove_list_decr_in [in K.Interpolation.UIK_UI_prelims]
+remove_Permutation [in GL.Interpolation.UIGL_nodupseq]
+remove_list_incr_decr [in Syntax.remove_list_lems]
+remove_list_incr_decr4 [in Syntax.remove_list_lems]
+remove_list_incr_decr2 [in Syntax.remove_list_lems]
+remove_list_incr_decr1 [in Syntax.remove_list_lems]
+remove_list_incr_decr3 [in Syntax.remove_list_lems]
+remove_delete_origin [in Syntax.remove_list_lems]
+remove_list_is_nil [in Syntax.remove_list_lems]
+remove_list_in_nil [in Syntax.remove_list_lems]
+remove_list_delete_head_In [in Syntax.remove_list_lems]
+remove_list_delete_head [in Syntax.remove_list_lems]
+remove_list_non_empty_inter_smaller_length [in Syntax.remove_list_lems]
+remove_list_singl_id_or_nil [in Syntax.remove_list_lems]
+remove_list_is_in [in Syntax.remove_list_lems]
+remove_list_in_single [in Syntax.remove_list_lems]
+remove_list_dist_app [in Syntax.remove_list_lems]
+remove_list_cont [in Syntax.remove_list_lems]
+remove_list_preserv_NoDup [in Syntax.remove_list_lems]
+remove_list_of_nil [in Syntax.remove_list_lems]
+remove_In_smaller_length [in Syntax.remove_list_lems]
+remove_le_length [in Syntax.remove_list_lems]
+remove_preserv_NoDup [in Syntax.remove_list_lems]
+remove_not_in_anymore [in Syntax.remove_list_lems]
+remove_dist_app [in Syntax.remove_list_lems]
+remove_rest_gen_ext [in GL.GLS.GLS_inv_ImpR_ImpL]
+remove_list_decr_in [in GL.Interpolation.UIGL_UI_prelims]
+remove_In_env_order [in ISL.Order]
+remove_In_env_order_refl [in ISL.Order]
+remove_env_order [in ISL.Order]
+remove_add_rest_gen_ext [in GL.GLS.GLS_dec]
+remove_include [in ISL.Environments]
+remove_rest_gen_ext [in K.KS.KS_inv_ImpR_ImpL]
+repeat_S [in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+repeat_n_imp_subformLF [in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+repeat_more_than_one [in GL.Interpolation.UIGL_Canopy_ImpL]
+replace_n_imp_subformLF [in GL.Interpolation.UIGL_Canopy_nodupseq_perm]
+replace_app [in GL.Interpolation.UIGL_Canopy_ImpR]
+req_trans [in General.gen]
+req_sym [in General.gen]
+req_refl [in General.gen]
+restr_list_prop_nodup [in GL.Interpolation.UIGL_UI_prelims]
+rest_nobox_gen_ext_trans [in GL.GLS.GLS_inv_ImpR_ImpL]
+rest_nobox_gen_ext_trans [in K.KS.KS_inv_ImpR_ImpL]
+RHS_top_box_is_subform [in GL.GLS.GLS_termination_measure]
+RHS_top_box_is_subformLF [in GL.GLS.GLS_termination_measure]
+rlI_eq [in General.gen_seq]
+rmI_eq [in General.gen_seq]
+rm_mono [in General.gen_seq]
+rsub_id [in General.gen]
+rsub_trans [in General.gen]
+rsub_def [in General.gen]
+rsub_emptyT [in General.genT]
+

S

+Sctxt_nil [in General.gen_seq]
+Sctxt_e' [in General.gen_seq]
+Sctxt_alt [in General.gen_seq]
+Sctxt_eq [in General.gen_seq]
+Sctxt_e [in General.gen_seq]
+seqext_defp [in General.gen_seq]
+seqext_def [in General.gen_seq]
+seqext_seqext [in General.gen_seq]
+seqrule_mono [in General.gen_seq]
+seqrule_same [in General.gen_seq]
+seqrule_derl_seqrule [in General.gen_seq]
+seqrule_seqrule [in General.gen_seq]
+seqrule_id [in General.gen_seq]
+ser_mono [in General.gen_seq]
+set_leq_ub_unif [in GL.Interpolation.UIGL_UI_prelims]
+sext_rev_fext [in General.gen_seq]
+sext_e [in General.gen_seq]
+simp_equiv [in ISL.Simp]
+simp_equiv_box [in ISL.Simp]
+simp_equiv_imp [in ISL.Simp]
+simp_equiv_imp_R [in ISL.Simp]
+simp_equiv_imp_L [in ISL.Simp]
+simp_imps_self_equiv_R [in ISL.Simp]
+simp_imps_self_equiv_L [in ISL.Simp]
+simp_imp_self_equiv_R [in ISL.Simp]
+simp_imp_self_equiv_L [in ISL.Simp]
+simp_equiv_and [in ISL.Simp]
+simp_equiv_and_R [in ISL.Simp]
+simp_equiv_and_L [in ISL.Simp]
+simp_ands_self_equiv_R [in ISL.Simp]
+simp_ands_self_equiv_L [in ISL.Simp]
+simp_equiv_or [in ISL.Simp]
+simp_equiv_or_R [in ISL.Simp]
+simp_ors_self_equiv_R [in ISL.Simp]
+simp_equiv_or_L [in ISL.Simp]
+simp_ors_self_equiv_L [in ISL.Simp]
+singleton_mult_notin [in ISL.Environments]
+singleton_mult_in [in ISL.Environments]
+single_eq [in General.swappedT]
+sing_empty_app_cons [in General.gen_seq]
+sing_empty_app [in General.gen_seq]
+size_LF_nil_unbox_top_box [in K.Interpolation.UIK_basics]
+size_step2_tr_lem [in General.gentree]
+size_top_boxes [in K.KS.KS_termination_measure]
+size_unboxed [in K.KS.KS_termination_measure]
+size_nobox_gen_ext [in K.KS.KS_termination_measure]
+size_LF_dist_app [in K.KS.KS_termination_measure]
+snd_fst_ext [in General.gen_seq]
+specialised_weakening [in ISL.Optimizations]
+sr_Id_alt [in General.gen_seq]
+strongness [in ISL.Optimizations]
+subform_boxesLF_dist_app [in GL.GLS.GLS_termination_measure]
+subform_boxesLF_nodup [in GL.Interpolation.UIGL_UI_prelims]
+subform_boxesLF_top_boxes [in GL.Interpolation.UIGL_LexSeq]
+subl_of_boxl_is_boxl [in Syntax.CML_Syntax]
+subst_dep [in General.List_lemmasT]
+sumh_step2_tr_lem [in General.gentree]
+sum_step2_tr_lem [in General.gentree]
+sum_step2_tr_gf2 [in General.gentree]
+swapped_gen_refl [in General.swappedT]
+swapped_gen_app_L [in General.swappedT]
+swapped__gen [in General.swappedT]
+swapped_spec_opp [in General.swappedT]
+swapped_gen_front_mid [in General.swappedT]
+swapped__n_mid [in General.swappedT]
+swapped_spec_front_mid [in General.swappedT]
+swapped_app_mid_R [in General.swappedT]
+swapped_app_mid_L [in General.swappedT]
+swapped_spec_conv [in General.swappedT]
+swapped_spec_comm [in General.swappedT]
+swapped_spec_trans_exact [in General.swappedT]
+swapped_spec_trans [in General.swappedT]
+swapped_app_L [in General.swappedT]
+swapped_spec_refl [in General.swappedT]
+swapped_map [in General.swappedT]
+swapped_map_ex [in General.swappedT]
+swapped_ca2 [in General.swappedT]
+swapped_ca1 [in General.swappedT]
+swapped_Rc1 [in General.swappedT]
+swapped_Rc2 [in General.swappedT]
+swapped_comm [in General.swappedT]
+swapped_simpleR [in General.swappedT]
+swapped_simpleL [in General.swappedT]
+swapped_simple' [in General.swappedT]
+swapped_simple [in General.swappedT]
+swapped_singleRE [in General.swappedT]
+swapped_singleLE [in General.swappedT]
+swapped_nilRE [in General.swappedT]
+swapped_nilLE [in General.swappedT]
+swapped_cons [in General.swappedT]
+swapped_R [in General.swappedT]
+swapped_L [in General.swappedT]
+swapped_same [in General.swappedT]
+swapped_I' [in General.swappedT]
+swap_remove_list [in Syntax.remove_list_lems]
+S_le_False [in GL.GLS.GLS_termination_measure]
+

T

+tail_inv_singleton2 [in General.List_lemmasT]
+tail_inv_singleton [in General.List_lemmasT]
+tautology_cut [in ISL.Optimizations]
+term_IH_help [in K.KS.KS_termination]
+term_meas_is_0 [in K.KS.KS_termination_measure]
+tl_of_boxl_is_boxl [in Syntax.CML_Syntax]
+TopL_remove [in K.Interpolation.UIK_UI_prelims]
+TopL_remove [in GL.Interpolation.UIGL_And_Or_rules]
+TopL_rev [in ISL.SequentProps]
+TopR [in K.Interpolation.UIK_UI_prelims]
+TopR [in GL.Interpolation.UIGL_And_Or_rules]
+top_boxes_Canopy_noless_ub [in GL.Interpolation.UIGL_Diam_UI_imp_N_prelim]
+top_boxes_distr_app [in Syntax.CML_Syntax]
+top_boxes_incl_list [in GL.GLS.GLS_termination_measure]
+top_boxes_diam_jump [in GL.Interpolation.UIGL_UI_prelims]
+top_boxes_nodup [in GL.Interpolation.UIGL_UI_prelims]
+top_boxes_XBoxed_list [in GL.Interpolation.UIGL_LexSeq]
+top_boxes_incl_list [in K.KS.KS_dec]
+top_provable [in ISL.Optimizations]
+trf_rules_derl [in General.gstep]
+trf_rules_rtc [in General.gstep]
+true_and [in General.gen]
+

U

+ub_nodupseq [in GL.Interpolation.UIGL_nodupseq]
+ub_stable [in GL.Interpolation.UIGL_UI_prelims]
+UI_One [in K.Interpolation.UIK_UIOne]
+UI_GUI [in K.Interpolation.UIK_braga]
+UI_spec [in K.Interpolation.UIK_braga]
+UI_GUI [in GL.Interpolation.UIGL_braga]
+UI_spec [in GL.Interpolation.UIGL_braga]
+UI_Diam_rec_imp [in GL.Interpolation.UIGL_Diam_UI_imp_N]
+UI_Two [in K.Interpolation.UIK_UITwo]
+UI_Three [in K.Interpolation.UIK_UIThree]
+UI_Two [in GL.Interpolation.UIGL_UITwo]
+UI_nodupseq_gen [in GL.Interpolation.UIGL_UI_inter]
+UI_nodupseq_converse [in GL.Interpolation.UIGL_UI_inter]
+UI_nodupseq [in GL.Interpolation.UIGL_UI_inter]
+UI_Three [in GL.Interpolation.UIGL_UIThree]
+UI_One [in GL.Interpolation.UIGL_UIOne]
+unboxed_list_In_unfold [in K.Interpolation.UIK_UI_prelims]
+unboxed_list_In [in K.Interpolation.UIK_UI_prelims]
+unbox_app_distrib [in Syntax.CML_Syntax]
+union_difference_R [in ISL.Environments]
+union_difference_L [in ISL.Environments]
+union_mult [in ISL.Environments]
+unit_eq_appT [in General.gen_tacs]
+univ_gen_ext_n_imp_subform [in GL.Interpolation.UIGL_Canopy_ImpR]
+univ_gen_ext_more_occ [in GL.Interpolation.UIGL_Canopy_ImpR]
+univ_gen_ext_S_count_occ [in GL.Interpolation.UIGL_Canopy_ImpR]
+univ_gen_ext_count_occ [in GL.Interpolation.UIGL_Canopy_ImpR]
+univ_gen_mod_smaller_length [in General.univ_gen_mod]
+univ_gen_mod_In [in General.univ_gen_mod]
+univ_gen_mod_elem_deep [in General.univ_gen_mod]
+univ_gen_mod_same_hd [in General.univ_gen_mod]
+univ_gen_mod_combine [in General.univ_gen_mod]
+univ_gen_mod_splitR [in General.univ_gen_mod]
+univ_gen_mod_splitL [in General.univ_gen_mod]
+univ_gen_mod_lem [in General.univ_gen_mod]
+univ_gen_mod_refl [in General.univ_gen_mod]
+univ_gen_ext_not_In_delete [in General.univ_gen_ext]
+univ_gen_ext_same_length_id [in General.univ_gen_ext]
+univ_gen_ext_smaller_length [in General.univ_gen_ext]
+univ_gen_ext_In [in General.univ_gen_ext]
+univ_gen_ext_Q_weaker_than_P [in General.univ_gen_ext]
+univ_gen_ext_add_elem_deep [in General.univ_gen_ext]
+univ_gen_ext_elem_deep [in General.univ_gen_ext]
+univ_gen_ext_same_hd [in General.univ_gen_ext]
+univ_gen_ext_combine [in General.univ_gen_ext]
+univ_gen_ext_splitR [in General.univ_gen_ext]
+univ_gen_ext_splitL [in General.univ_gen_ext]
+univ_gen_ext_lem [in General.univ_gen_ext]
+univ_gen_ext_appR [in General.univ_gen_ext]
+univ_gen_ext_appL [in General.univ_gen_ext]
+univ_gen_ext_nil_all_P [in General.univ_gen_ext]
+univ_gen_ext_trans [in General.univ_gen_ext]
+univ_gen_ext_refl [in General.univ_gen_ext]
+univ_gen_ext_incl_subform_boxes [in GL.GLS.GLS_termination_measure]
+

V

+variables_disjunction [in ISL.Environments]
+variables_conjunction [in ISL.Environments]
+

W

+want_prod_under_universal4 [in General.genT]
+want_right_prod_under_universal' [in General.genT]
+want_right_prod_under_universal [in General.genT]
+want_left_prod_under_universal [in General.genT]
+weakening [in ISL.SequentProps]
+weakeningL [in General.gen_seq]
+weak_ImpL [in ISL.SequentProps]
+weak_cut [in ISL.Optimizations]
+weight_open_box [in ISL.SequentProps]
+weight_open_box [in ISL.Order]
+weight_pos [in ISL.Formulas]
+wf_LtSeq [in K.Interpolation.UIK_basics]
+wf_pointed_env_ms_order [in ISL.Order]
+wf_pointed_order [in ISL.Order]
+wf_LexSeq [in GL.Interpolation.UIGL_LexSeq]
+wkn_R_BotL_notapplic [in GL.GLS.GLS_wkn]
+

X

+XBoxed_list_In_unfold [in GL.Interpolation.UIGL_nodupseq]
+XBoxed_list_In_gen [in GL.Interpolation.UIGL_nodupseq]
+XBoxed_list_In [in GL.Interpolation.UIGL_nodupseq]
+XBoxed_list_same_subform_boxes [in GL.GLS.GLS_termination_measure]
+XBox_app_distrib [in GL.GLS.GLS_calcs]
+


+

Constructor Index

+

A

+AccT_intro [in General.genT]
+aderI [in General.ddT]
+admI [in General.ddT]
+adpI [in General.ddT]
+allPder_Cons [in General.dd_fc]
+allPder_Nil [in General.dd_fc]
+And [in ISL.Formulas]
+AndL [in ISL.Sequents]
+AndR [in ISL.Sequents]
+asa_appR [in General.List_lemmasT]
+asa_appL [in General.List_lemmasT]
+asa_single [in General.List_lemmasT]
+asmI [in General.ddT]
+Atom [in ISL.Sequents]
+

B

+Bot [in Syntax.CML_Syntax]
+Bot [in ISL.Formulas]
+BotL [in GL.GLS.GLS_calcs]
+BotL [in K.KS.KS_calc]
+BotLRule_I [in GL.GLS.GLS_calcs]
+BotLRule_I [in K.KS.KS_calc]
+botRule_fcI [in General.dd_fc]
+Box [in Syntax.CML_Syntax]
+Box [in ISL.Formulas]
+BoxR [in ISL.Sequents]
+

C

+casmI [in General.ddT]
+ccpsI [in General.ddT]
+ctr_RI [in K.KS.KS_ctr]
+ctr_LI [in K.KS.KS_ctr]
+ctr_RI [in GL.GLS.GLS_ctr]
+ctr_LI [in GL.GLS.GLS_ctr]
+CutRule_I [in GL.GLS.GLS_cut_elim]
+CutRule_I [in K.KS.KS_cut_elim]
+

D

+derI [in General.ddT]
+dlCons [in General.ddT]
+dlNil [in General.ddT]
+dpI [in General.ddT]
+dtcCons [in General.ddT]
+dtcderI [in General.ddT]
+dtcNil [in General.ddT]
+dtCons [in General.ddT]
+dtderI [in General.ddT]
+dtNil [in General.ddT]
+

E

+ExFalso [in ISL.Sequents]
+

F

+fcI [in General.dd_fc]
+fcsI [in General.dd_fc]
+fextI [in General.gen_seq]
+ForallT_cons [in General.genT]
+ForallT_nil [in General.genT]
+Forall2T_cons [in General.genT]
+Forall2T_nil [in General.genT]
+fst_relI [in General.gen_seq]
+

G

+Gfm_cons [in K.Interpolation.UIK_irred_short]
+Gfm_nil [in K.Interpolation.UIK_irred_short]
+Gfm_cons [in GL.Interpolation.UIGL_irred_short]
+Gfm_nil [in GL.Interpolation.UIGL_irred_short]
+Gim_cons [in K.Interpolation.UIK_braga]
+Gim_nil [in K.Interpolation.UIK_braga]
+Gim_cons [in GL.Interpolation.UIGL_braga]
+Gim_nil [in GL.Interpolation.UIGL_braga]
+Girred_not [in K.Interpolation.UIK_irred_short]
+Girred_nil [in K.Interpolation.UIK_irred_short]
+Girred_not [in GL.Interpolation.UIGL_irred_short]
+Girred_nil [in GL.Interpolation.UIGL_irred_short]
+GLR [in GL.GLS.GLS_calcs]
+GLRRule_I [in GL.GLS.GLS_calcs]
+GLS_woc [in GL.GLS.GLS_cut_elim]
+GN_less [in GL.Interpolation.UIGL_braga]
+GN_less_ub [in GL.Interpolation.UIGL_braga]
+GN_init_seq [in GL.Interpolation.UIGL_braga]
+gsI [in General.gstep]
+GUI_critic_not_init [in K.Interpolation.UIK_braga]
+GUI_not_critic [in K.Interpolation.UIK_braga]
+GUI_critic_init [in K.Interpolation.UIK_braga]
+GUI_empty_seq [in K.Interpolation.UIK_braga]
+GUI_critic_not_init [in GL.Interpolation.UIGL_braga]
+GUI_not_critic [in GL.Interpolation.UIGL_braga]
+GUI_critic_init [in GL.Interpolation.UIGL_braga]
+GUI_empty_seq [in GL.Interpolation.UIGL_braga]
+

I

+IdBRule_I [in GL.GLS.GLS_calcs]
+IdP [in GL.GLS.GLS_calcs]
+IdP [in K.KS.KS_calc]
+IdPRule_I [in GL.GLS.GLS_calcs]
+IdPRule_I [in K.KS.KS_calc]
+Idrule_I [in General.gen_seq]
+iGLS_cut [in GL.GLS.GLS_cut_elim]
+Imp [in Syntax.CML_Syntax]
+ImpBox [in ISL.Sequents]
+ImpL [in GL.GLS.GLS_calcs]
+ImpL [in K.KS.KS_calc]
+ImpLAnd [in ISL.Sequents]
+Implies [in ISL.Formulas]
+ImpLImp [in ISL.Sequents]
+ImpLOr [in ISL.Sequents]
+ImpLRule_I [in GL.GLS.GLS_calcs]
+ImpLRule_I [in K.KS.KS_calc]
+ImpLVar [in ISL.Sequents]
+ImpR [in ISL.Sequents]
+ImpR [in GL.GLS.GLS_calcs]
+ImpR [in K.KS.KS_calc]
+ImpRRule_I [in GL.GLS.GLS_calcs]
+ImpRRule_I [in K.KS.KS_calc]
+IndClo [in GL.GLS.GLS_exch]
+IndClo [in K.KS.KS_exch]
+IndLExch [in GL.GLS.GLS_exch]
+IndLExch [in K.KS.KS_exch]
+IndRExch [in GL.GLS.GLS_exch]
+IndRExch [in K.KS.KS_exch]
+InitClo [in GL.GLS.GLS_exch]
+InitClo [in K.KS.KS_exch]
+InitLExch [in GL.GLS.GLS_exch]
+InitLExch [in K.KS.KS_exch]
+InitRExch [in GL.GLS.GLS_exch]
+InitRExch [in K.KS.KS_exch]
+InT_pt_tl [in General.List_lemmasT]
+InT_pt_hd [in General.List_lemmasT]
+InT_cons [in General.genT]
+InT_eq' [in General.genT]
+in_nextup_fcI [in General.dd_fc]
+in_nextupI [in General.dd_fc]
+in_dersrec_tl [in General.dd_fc]
+in_dersrec_hd [in General.dd_fc]
+is_nextupI [in General.dd_fc]
+

K

+KR [in K.KS.KS_calc]
+KRRule_I [in K.KS.KS_calc]
+KS_cut [in K.KS.KS_cut_elim]
+KS_woc [in K.KS.KS_cut_elim]
+

L

+leT_S [in General.genT]
+leT_n [in General.genT]
+lex_cons [in K.Interpolation.UIK_Def_measure]
+lex_skip [in K.Interpolation.UIK_Def_measure]
+lex_cons [in GL.GLS.DLW_wf_lex]
+lex_skip [in GL.GLS.DLW_wf_lex]
+lex_cons [in GL.Interpolation.UIGL_Def_measure]
+lex_skip [in GL.Interpolation.UIGL_Def_measure]
+list_exch_RI [in K.KS.KS_exch_prelims]
+list_exch_LI [in K.KS.KS_exch_prelims]
+list_exch_RI [in GL.GLS.GLS_exch]
+list_exch_LI [in GL.GLS.GLS_exch]
+

O

+Or [in ISL.Formulas]
+OrL [in ISL.Sequents]
+OrR1 [in ISL.Sequents]
+OrR2 [in ISL.Sequents]
+

P

+permT_trans [in GL.Interpolation.UIGL_PermutationT]
+permT_swap [in GL.Interpolation.UIGL_PermutationT]
+permT_skip [in GL.Interpolation.UIGL_PermutationT]
+permT_nil [in GL.Interpolation.UIGL_PermutationT]
+

R

+radmI [in General.gstep]
+rel_admI [in General.gstep]
+rlI [in General.gen_seq]
+rmI [in General.gen_seq]
+rtn1T_trans [in General.rtcT]
+rtn1T_refl [in General.rtcT]
+rtT_trans [in General.rtcT]
+rtT_refl [in General.rtcT]
+rtT_step [in General.rtcT]
+rT_refl [in General.rtcT]
+rT_step [in General.rtcT]
+rt1nT_trans [in General.rtcT]
+rt1nT_refl [in General.rtcT]
+rUnI [in General.gstep]
+run_r [in General.gstep]
+run_l [in General.gstep]
+

S

+Sctxt [in General.gen_seq]
+Sctxt_s [in General.gen_seq]
+Sctxt' [in General.gen_seq]
+sextI [in General.gen_seq]
+se_single [in General.gen_seq]
+se_empty [in General.gen_seq]
+snd_relI [in General.gen_seq]
+SubAnd [in ISL.Formulas]
+SubBox [in ISL.Formulas]
+SubEq [in ISL.Formulas]
+SubImpl [in ISL.Formulas]
+SubOr [in ISL.Formulas]
+swapped_gen_I [in General.swappedT]
+swapped_spec_step [in General.swappedT]
+swapped_spec_I [in General.swappedT]
+swapped_I [in General.swappedT]
+

U

+univ_gen_mod_modif [in General.univ_gen_mod]
+univ_gen_mod_cons [in General.univ_gen_mod]
+univ_gen_mod_nil [in General.univ_gen_mod]
+univ_gen_ext_extra [in General.univ_gen_ext]
+univ_gen_ext_cons [in General.univ_gen_ext]
+univ_gen_ext_nil [in General.univ_gen_ext]
+

V

+Var [in Syntax.CML_Syntax]
+Var [in ISL.Formulas]
+

W

+wkn_RI [in K.KS.KS_wkn]
+wkn_LI [in K.KS.KS_wkn]
+wkn_RI [in GL.GLS.GLS_wkn]
+wkn_LI [in GL.GLS.GLS_wkn]
+


+

Inductive Index

+

A

+AccT [in General.genT]
+aderrec [in General.ddT]
+adm [in General.ddT]
+allPder [in General.dd_fc]
+app_split_at [in General.List_lemmasT]
+

B

+BotLRule [in GL.GLS.GLS_calcs]
+BotLRule [in K.KS.KS_calc]
+botRule_fc [in General.dd_fc]
+

C

+ccps [in General.ddT]
+Closure [in GL.GLS.GLS_exch]
+Closure [in K.KS.KS_exch]
+clos_refl_transT_n1 [in General.rtcT]
+clos_refl_transT_1n [in General.rtcT]
+clos_refl_transT [in General.rtcT]
+clos_reflT [in General.rtcT]
+ctr_R [in K.KS.KS_ctr]
+ctr_L [in K.KS.KS_ctr]
+ctr_R [in GL.GLS.GLS_ctr]
+ctr_L [in GL.GLS.GLS_ctr]
+CutRule [in GL.GLS.GLS_cut_elim]
+CutRule [in K.KS.KS_cut_elim]
+

D

+dercl [in General.ddT]
+dercsl [in General.ddT]
+derl [in General.ddT]
+derrec [in General.ddT]
+derrec_fc [in General.dd_fc]
+dersl [in General.ddT]
+dersrec [in General.ddT]
+dersrec_fcs [in General.dd_fc]
+

E

+empty [in General.genT]
+emptyT [in General.genT]
+empty_relT [in General.genT]
+ExcClosure [in GL.GLS.GLS_exch]
+ExcClosure [in K.KS.KS_exch]
+

F

+ForallT [in General.genT]
+Forall2T [in General.genT]
+form [in ISL.Formulas]
+fst_rel [in General.gen_seq]
+fst_ext_rls [in General.gen_seq]
+

G

+gen_step' [in General.gstep]
+Gflatmap [in K.Interpolation.UIK_irred_short]
+Gflatmap [in GL.Interpolation.UIGL_irred_short]
+Gimap [in K.Interpolation.UIK_braga]
+Gimap [in GL.Interpolation.UIGL_braga]
+Girred [in K.Interpolation.UIK_irred_short]
+Girred [in GL.Interpolation.UIGL_irred_short]
+GLRRule [in GL.GLS.GLS_calcs]
+GLS_rules [in GL.GLS.GLS_calcs]
+GLS_cut_rules [in GL.GLS.GLS_cut_elim]
+GN [in GL.Interpolation.UIGL_braga]
+GUI [in K.Interpolation.UIK_braga]
+GUI [in GL.Interpolation.UIGL_braga]
+

I

+IdBRule [in GL.GLS.GLS_calcs]
+IdPRule [in GL.GLS.GLS_calcs]
+IdPRule [in K.KS.KS_calc]
+Idrule [in General.gen_seq]
+ImpLRule [in GL.GLS.GLS_calcs]
+ImpLRule [in K.KS.KS_calc]
+ImpRRule [in GL.GLS.GLS_calcs]
+ImpRRule [in K.KS.KS_calc]
+InT [in General.genT]
+InT_pair_triple [in General.List_lemmasT]
+in_nextup_fc [in General.dd_fc]
+in_nextup [in General.dd_fc]
+in_dersrec [in General.dd_fc]
+is_nextup [in General.dd_fc]
+

K

+KRRule [in K.KS.KS_calc]
+KS_cut_rules [in K.KS.KS_cut_elim]
+KS_rules [in K.KS.KS_calc]
+

L

+leT [in General.genT]
+lex [in K.Interpolation.UIK_Def_measure]
+lex [in GL.GLS.DLW_wf_lex]
+lex [in GL.Interpolation.UIGL_Def_measure]
+list_exch_R [in K.KS.KS_exch_prelims]
+list_exch_L [in K.KS.KS_exch_prelims]
+list_exch_R [in GL.GLS.GLS_exch]
+list_exch_L [in GL.GLS.GLS_exch]
+

M

+MPropF [in Syntax.CML_Syntax]
+

P

+PermutationT [in GL.Interpolation.UIGL_PermutationT]
+Provable [in ISL.Sequents]
+

R

+radm [in General.gstep]
+relmap [in General.gen_seq]
+rel_adm [in General.gstep]
+rlsmap [in General.gen_seq]
+rUnion [in General.gstep]
+runion [in General.gstep]
+

S

+seqrule [in General.gen_seq]
+seqrule_s [in General.gen_seq]
+seqrule' [in General.gen_seq]
+sing_empty [in General.gen_seq]
+snd_rel [in General.gen_seq]
+snd_ext_rls [in General.gen_seq]
+subform [in ISL.Formulas]
+swapped [in General.swappedT]
+swapped_gen [in General.swappedT]
+swapped_spec [in General.swappedT]
+

U

+univ_gen_mod [in General.univ_gen_mod]
+univ_gen_ext [in General.univ_gen_ext]
+

W

+wkn_R [in K.KS.KS_wkn]
+wkn_L [in K.KS.KS_wkn]
+wkn_R [in GL.GLS.GLS_wkn]
+wkn_L [in GL.GLS.GLS_wkn]
+


+

Section Index

+

A

+Arithmetic [in K.Interpolation.UIK_basics]
+

C

+Canopy_lems [in K.Interpolation.UIK_UI_prelims]
+CountablyManyFormulas [in ISL.Formulas]
+

D

+Diam_help [in K.Interpolation.UIK_UI_prelims]
+Diam_help [in GL.Interpolation.UIGL_UI_prelims]
+

E

+empty_seq [in K.Interpolation.UIK_basics]
+empty_seq [in GL.Interpolation.UIGL_LexSeq]
+

F

+flatmap [in K.Interpolation.UIK_irred_short]
+flatmap [in GL.Interpolation.UIGL_irred_short]
+

G

+Gimap_cont [in K.Interpolation.UIK_braga]
+Gimap_cont [in GL.Interpolation.UIGL_braga]
+GN [in GL.Interpolation.UIGL_braga]
+

I

+imap [in K.Interpolation.UIK_braga]
+imap [in GL.Interpolation.UIGL_braga]
+irred [in K.Interpolation.UIK_irred_short]
+irred [in GL.Interpolation.UIGL_irred_short]
+irred_high_level.provability [in K.Interpolation.UIK_irred_high_level]
+irred_high_level [in K.Interpolation.UIK_irred_high_level]
+irred_high_level.provability [in GL.Interpolation.UIGL_irred_high_level]
+irred_high_level [in GL.Interpolation.UIGL_irred_high_level]
+irred.Girred_ind [in K.Interpolation.UIK_irred_short]
+irred.Girred_ind [in GL.Interpolation.UIGL_irred_short]
+

L

+LexSeq_properties [in GL.Interpolation.UIGL_LexSeq]
+LexSeq_ind [in GL.Interpolation.UIGL_LexSeq]
+lex_wf.lex_rect [in K.Interpolation.UIK_Def_measure]
+lex_wf [in K.Interpolation.UIK_Def_measure]
+lex_wf [in GL.GLS.DLW_wf_lex]
+lex_wf.lex_rect [in GL.Interpolation.UIGL_Def_measure]
+lex_wf [in GL.Interpolation.UIGL_Def_measure]
+list_conj_disj_properties [in K.Interpolation.UIK_UI_prelims]
+list_conj_disj_properties [in GL.Interpolation.UIGL_And_Or_rules]
+LogDefinition [in GL.Interpolation.UIGL_LexSeq]
+logic [in GL.Interpolation.UIGL_UI_prelims]
+Logic_Abrv [in K.Interpolation.UIK_basics]
+Logic_Abrv [in GL.Interpolation.UIGL_basics]
+LtSeq_properties [in K.Interpolation.UIK_basics]
+LtSeq_ind [in K.Interpolation.UIK_basics]
+

M

+measure_rect [in K.Interpolation.UIK_Def_measure]
+measure_rect [in GL.GLS.DLW_wf_lex]
+measure_rect [in GL.Interpolation.UIGL_Def_measure]
+

N

+N [in GL.Interpolation.UIGL_braga]
+nodupseq [in GL.Interpolation.UIGL_nodupseq]
+nodup_facts [in GL.Interpolation.UIGL_UI_prelims]
+

P

+PermutationT [in GL.Interpolation.UIGL_PermutationT]
+Prop_Subform [in K.Interpolation.UIK_UI_prelims]
+Prop_Subform [in GL.Interpolation.UIGL_UI_prelims]
+

R

+Random [in K.Interpolation.UIK_basics]
+Random [in GL.Interpolation.UIGL_basics]
+Reflexive_Transitive_ClosureT [in General.rtcT]
+Reflexive_ClosureT [in General.rtcT]
+

T

+top_boxes_facts [in GL.Interpolation.UIGL_UI_prelims]
+

U

+UI [in K.Interpolation.UIK_braga]
+UI [in GL.Interpolation.UIGL_braga]
+UIPDiam [in GL.Interpolation.UIGL_UIDiam_N]
+UIPOne [in K.Interpolation.UIK_UIOne]
+UIPOne [in GL.Interpolation.UIGL_UIOne]
+UIPThree [in K.Interpolation.UIK_UIThree]
+UIPThree [in GL.Interpolation.UIGL_UIThree]
+UIPTwo [in K.Interpolation.UIK_UITwo]
+UIPTwo [in GL.Interpolation.UIGL_UITwo]
+UniformInterpolation [in ISL.PropQuantifiers]
+UniformInterpolation.Correctness [in ISL.PropQuantifiers]
+UniformInterpolation.Correctness.EntailmentCorrect [in ISL.PropQuantifiers]
+UniformInterpolation.Correctness.PropQuantCorrect [in ISL.PropQuantifiers]
+UniformInterpolation.Correctness.VariablesCorrect [in ISL.PropQuantifiers]
+UniformInterpolation.PropQuantDefinition [in ISL.PropQuantifiers]
+


+

Instance Index

+

D

+decidable_is_negation [in ISL.Environments]
+decidable_is_implication [in ISL.Environments]
+decidable_is_double_negation [in ISL.Environments]
+

E

+env_order_trans [in ISL.Order]
+equiv_assoc [in ISL.Environments]
+

F

+fomula_bottom [in ISL.Formulas]
+form_count [in ISL.Formulas]
+form_eq_dec [in ISL.Formulas]
+form_top [in ISL.Formulas]
+

I

+irreflexive_form_order [in ISL.Formulas]
+

P

+proper_Provable [in ISL.Sequents]
+Proper_env_order_refl [in ISL.Order]
+Proper_env_order [in ISL.Order]
+Proper_env_order_refl_env_weight [in ISL.Order]
+Proper_env_weight [in ISL.Order]
+Proper_elements [in ISL.Environments]
+proper_open_boxes [in ISL.Environments]
+proper_difference [in ISL.Environments]
+proper_disj_union [in ISL.Environments]
+proper_elem_of [in ISL.Environments]
+proper_rm [in ISL.DecisionProcedure]
+

S

+singleton [in ISL.Environments]
+singletonMS [in ISL.Environments]
+string_dec [in ISL.Formulas]
+

T

+transitive_form_order [in ISL.Formulas]
+


+

Definition Index

+

A

+A [in ISL.PropQuantifiers]
+AccT_measure [in General.gentree]
+AccT_sind [in General.genT]
+AccT_rec [in General.genT]
+AccT_ind [in General.genT]
+AccT_rect [in General.genT]
+aderrec_sind [in General.ddT]
+aderrec_ind [in General.ddT]
+admD [in General.ddT]
+admDs [in General.ddT]
+adm_sind [in General.ddT]
+adm_rec [in General.ddT]
+adm_ind [in General.ddT]
+adm_rect [in General.ddT]
+Af [in ISL.PropQuantifiers]
+allPder_sind [in General.dd_fc]
+allPder_rec [in General.dd_fc]
+allPder_ind [in General.dd_fc]
+allPder_rect [in General.dd_fc]
+And [in Syntax.CML_Syntax]
+anon [in General.genT]
+apfst [in General.gen_seq]
+app_split_at_sind [in General.List_lemmasT]
+app_split_at_rec [in General.List_lemmasT]
+app_split_at_ind [in General.List_lemmasT]
+app_split_at_rect [in General.List_lemmasT]
+app_eq_consT [in General.List_lemmasT]
+app_eq_consT2 [in General.List_lemmasT]
+app_eq_cons [in General.List_lemmasT]
+app_assoc_cons [in General.gen_tacs]
+apsnd [in General.gen_seq]
+A_simplified [in ISL.Simp]
+A_eq [in ISL.PropQuantifiers]
+a_rule_form [in ISL.PropQuantifiers]
+a_rule_env [in ISL.PropQuantifiers]
+

B

+BotLRule_sind [in GL.GLS.GLS_calcs]
+BotLRule_rec [in GL.GLS.GLS_calcs]
+BotLRule_ind [in GL.GLS.GLS_calcs]
+BotLRule_rect [in GL.GLS.GLS_calcs]
+BotLRule_sind [in K.KS.KS_calc]
+BotLRule_rec [in K.KS.KS_calc]
+BotLRule_ind [in K.KS.KS_calc]
+BotLRule_rect [in K.KS.KS_calc]
+botRule_fc_sind [in General.dd_fc]
+botRule_fc_rec [in General.dd_fc]
+botRule_fc_ind [in General.dd_fc]
+botRule_fc_rect [in General.dd_fc]
+bot_is_rule [in General.dd_fc]
+

C

+Canopy [in GL.Interpolation.UIGL_Canopy]
+Canopy [in K.Interpolation.UIK_Canopy]
+can_exchR [in General.gen_seq]
+can_exchL [in General.gen_seq]
+can_wkL [in General.gen_seq]
+can_rel [in General.gstep]
+can_trf_rules_rtc_mono [in General.gstep]
+can_trf_rules_rtc [in General.gstep]
+can_trf_rules_rc_mono [in General.gstep]
+can_trf_rules_mono [in General.gstep]
+can_trf_rules_rc [in General.gstep]
+can_trf_rules [in General.gstep]
+ccps_sind [in General.ddT]
+ccps_rec [in General.ddT]
+ccps_ind [in General.ddT]
+ccps_rect [in General.ddT]
+choose_disj [in ISL.Environments]
+choose_conj [in ISL.Environments]
+Closure_sind [in GL.GLS.GLS_exch]
+Closure_rec [in GL.GLS.GLS_exch]
+Closure_ind [in GL.GLS.GLS_exch]
+Closure_rect [in GL.GLS.GLS_exch]
+Closure_sind [in K.KS.KS_exch]
+Closure_rec [in K.KS.KS_exch]
+Closure_ind [in K.KS.KS_exch]
+Closure_rect [in K.KS.KS_exch]
+clos_refl_transT_n1_sind [in General.rtcT]
+clos_refl_transT_n1_rec [in General.rtcT]
+clos_refl_transT_n1_ind [in General.rtcT]
+clos_refl_transT_n1_rect [in General.rtcT]
+clos_refl_transT_1n_sind [in General.rtcT]
+clos_refl_transT_1n_rec [in General.rtcT]
+clos_refl_transT_1n_ind [in General.rtcT]
+clos_refl_transT_1n_rect [in General.rtcT]
+clos_refl_transT_sind [in General.rtcT]
+clos_refl_transT_rec [in General.rtcT]
+clos_refl_transT_ind [in General.rtcT]
+clos_refl_transT_rect [in General.rtcT]
+clos_reflT_sind [in General.rtcT]
+clos_reflT_rec [in General.rtcT]
+clos_reflT_ind [in General.rtcT]
+clos_reflT_rect [in General.rtcT]
+conjunction [in ISL.Environments]
+critical_Seq_dec [in GL.Interpolation.UIGL_Canopy]
+critical_Seq [in GL.Interpolation.UIGL_Canopy]
+critical_Seq_dec [in K.Interpolation.UIK_Canopy]
+critical_Seq [in K.Interpolation.UIK_Canopy]
+ctr_R_sind [in K.KS.KS_ctr]
+ctr_R_rec [in K.KS.KS_ctr]
+ctr_R_ind [in K.KS.KS_ctr]
+ctr_R_rect [in K.KS.KS_ctr]
+ctr_L_sind [in K.KS.KS_ctr]
+ctr_L_rec [in K.KS.KS_ctr]
+ctr_L_ind [in K.KS.KS_ctr]
+ctr_L_rect [in K.KS.KS_ctr]
+ctr_R_sind [in GL.GLS.GLS_ctr]
+ctr_R_rec [in GL.GLS.GLS_ctr]
+ctr_R_ind [in GL.GLS.GLS_ctr]
+ctr_R_rect [in GL.GLS.GLS_ctr]
+ctr_L_sind [in GL.GLS.GLS_ctr]
+ctr_L_rec [in GL.GLS.GLS_ctr]
+ctr_L_ind [in GL.GLS.GLS_ctr]
+ctr_L_rect [in GL.GLS.GLS_ctr]
+CutRule_sind [in GL.GLS.GLS_cut_elim]
+CutRule_rec [in GL.GLS.GLS_cut_elim]
+CutRule_ind [in GL.GLS.GLS_cut_elim]
+CutRule_rect [in GL.GLS.GLS_cut_elim]
+CutRule_sind [in K.KS.KS_cut_elim]
+CutRule_rec [in K.KS.KS_cut_elim]
+CutRule_ind [in K.KS.KS_cut_elim]
+CutRule_rect [in K.KS.KS_cut_elim]
+

D

+dcl_allT [in General.ddT]
+dcsl_allT [in General.ddT]
+dec_GLS_rules [in GL.GLS.GLS_dec]
+dec_GLR_rule [in GL.GLS.GLS_dec]
+dec_box_in_list [in GL.GLS.GLS_dec]
+dec_ImpL_rule [in GL.GLS.GLS_dec]
+dec_ImpR_rule [in GL.GLS.GLS_dec]
+dec_imp_in [in GL.GLS.GLS_dec]
+dec_is_imp [in GL.GLS.GLS_dec]
+dec_init_rules [in GL.GLS.GLS_dec]
+dec_BotL_rule [in GL.GLS.GLS_dec]
+dec_IdB_rule [in GL.GLS.GLS_dec]
+dec_IdP_rule [in GL.GLS.GLS_dec]
+dec_GLS_init_rules [in GL.GLS.GLS_dec]
+dec_box_in [in GL.GLS.GLS_dec]
+dec_is_box [in GL.GLS.GLS_dec]
+dec_is_boxedT [in GL.GLS.GLS_dec]
+dec_prop_var_in [in GL.GLS.GLS_dec]
+dec_KS_rules [in K.KS.KS_dec]
+dec_KR_rule [in K.KS.KS_dec]
+dec_box_in_list [in K.KS.KS_dec]
+dec_ImpL_rule [in K.KS.KS_dec]
+dec_ImpR_rule [in K.KS.KS_dec]
+dec_imp_in [in K.KS.KS_dec]
+dec_is_imp [in K.KS.KS_dec]
+dec_BotL_rule [in K.KS.KS_dec]
+dec_IdP_rule [in K.KS.KS_dec]
+dec_KS_init_rules [in K.KS.KS_dec]
+dec_box_in [in K.KS.KS_dec]
+dec_is_box [in K.KS.KS_dec]
+dec_is_boxedT [in K.KS.KS_dec]
+dec_prop_var_in [in K.KS.KS_dec]
+dec_is_PropVar [in K.KS.KS_dec]
+dercl_derl [in General.ddT]
+dercl_dercsl_rect_mut [in General.ddT]
+dercl_rect_mut [in General.ddT]
+dercl_rec_mut [in General.ddT]
+dercl_ind_mut [in General.ddT]
+dercl_sind [in General.ddT]
+dercl_rec [in General.ddT]
+dercl_ind [in General.ddT]
+dercl_rect [in General.ddT]
+dercsl_dersl [in General.ddT]
+dercsl_rect_mut [in General.ddT]
+dercsl_rec_mut [in General.ddT]
+dercsl_ind_mut [in General.ddT]
+dercsl_sind [in General.ddT]
+dercsl_rec [in General.ddT]
+dercsl_ind [in General.ddT]
+dercsl_rect [in General.ddT]
+derI_rules_mono [in General.ddT]
+derl_fst_ext_rls' [in General.gen_seq]
+derl_seqrule' [in General.gen_seq]
+derl_height [in General.dd_fc]
+derl_adm [in General.ddT]
+derl_mono [in General.ddT]
+derl_mono' [in General.ddT]
+derl_deriv [in General.ddT]
+derl_deriv' [in General.ddT]
+derl_trans [in General.ddT]
+derl_derrec_nil [in General.ddT]
+derl_derrec [in General.ddT]
+derl_derrec_trans [in General.ddT]
+derl_dersl_rect_mut [in General.ddT]
+derl_rect_mut [in General.ddT]
+derl_rec_mut [in General.ddT]
+derl_ind_mut [in General.ddT]
+derl_sind [in General.ddT]
+derl_rec [in General.ddT]
+derl_ind [in General.ddT]
+derl_rect [in General.ddT]
+derrec_fc_height [in General.dd_fc]
+derrec_fc_size [in General.dd_fc]
+derrec_fc_concl [in General.dd_fc]
+derrec_fc_sind [in General.dd_fc]
+derrec_fc_rec [in General.dd_fc]
+derrec_fc_ind [in General.dd_fc]
+derrec_fc_rect [in General.dd_fc]
+derrec_concl [in General.dd_fc]
+derrec_size [in General.dd_fc]
+derrec_height [in General.dd_fc]
+derrec_rect_mut_all [in General.dd_fc]
+derrec_adm [in General.ddT]
+derrec_all_rect2_nops [in General.ddT]
+derrec_nil_derl [in General.ddT]
+derrec_derl_deriv [in General.ddT]
+derrec_rmono [in General.ddT]
+derrec_derrec [in General.ddT]
+derrec_dersrec_rect_mut [in General.ddT]
+derrec_ind_mut [in General.ddT]
+derrec_rec_mut [in General.ddT]
+derrec_rect_mut [in General.ddT]
+derrec_sind [in General.ddT]
+derrec_rec [in General.ddT]
+derrec_ind [in General.ddT]
+derrec_rect [in General.ddT]
+dersl_fst_ext_rls' [in General.gen_seq]
+dersl_seqrule' [in General.gen_seq]
+dersl_height [in General.dd_fc]
+dersl_adm [in General.ddT]
+dersl_mono [in General.ddT]
+dersl_mono' [in General.ddT]
+dersl_deriv [in General.ddT]
+dersl_deriv' [in General.ddT]
+dersl_trans [in General.ddT]
+dersl_dersrec_trans [in General.ddT]
+dersl_rect_mut [in General.ddT]
+dersl_rec_mut [in General.ddT]
+dersl_ind_mut [in General.ddT]
+dersl_sind [in General.ddT]
+dersl_rec [in General.ddT]
+dersl_ind [in General.ddT]
+dersl_rect [in General.ddT]
+dersrecD_forall [in General.ddT]
+dersrecD_all [in General.ddT]
+dersrecI_forall [in General.ddT]
+dersrecI_all [in General.ddT]
+dersrec_fc_height [in General.dd_fc]
+dersrec_fc_size [in General.dd_fc]
+dersrec_fc_concls [in General.dd_fc]
+dersrec_trees [in General.dd_fc]
+dersrec_fcs_sind [in General.dd_fc]
+dersrec_fcs_rec [in General.dd_fc]
+dersrec_fcs_ind [in General.dd_fc]
+dersrec_fcs_rect [in General.dd_fc]
+dersrec_single' [in General.dd_fc]
+dersrec_singleI' [in General.dd_fc]
+dersrec_singleD' [in General.dd_fc]
+dersrec_tl [in General.dd_fc]
+dersrec_hd [in General.dd_fc]
+dersrec_concls [in General.dd_fc]
+dersrec_size [in General.dd_fc]
+dersrec_height [in General.dd_fc]
+dersrec_doubleD [in General.ddT]
+dersrec_adm [in General.ddT]
+dersrec_nil_dersl [in General.ddT]
+dersrec_derl_deriv [in General.ddT]
+dersrec_rmono [in General.ddT]
+dersrec_singleI [in General.ddT]
+dersrec_singleD [in General.ddT]
+dersrec_appI [in General.ddT]
+dersrec_appJ [in General.ddT]
+dersrec_appR [in General.ddT]
+dersrec_appL [in General.ddT]
+dersrec_appD [in General.ddT]
+dersrec_derrec [in General.ddT]
+dersrec_ind_mut [in General.ddT]
+dersrec_rec_mut [in General.ddT]
+dersrec_rect_mut [in General.ddT]
+dersrec_sind [in General.ddT]
+dersrec_rec [in General.ddT]
+dersrec_ind [in General.ddT]
+dersrec_rect [in General.ddT]
+der_trf_derl' [in General.gstep]
+der_botr_ps [in General.dd_fc]
+Diam [in Syntax.CML_Syntax]
+dim_all8 [in General.ddT]
+dim_all4 [in General.ddT]
+dim_all3 [in General.ddT]
+dim_allT [in General.ddT]
+dim_all [in General.ddT]
+disjunction [in ISL.Environments]
+dp [in General.dd_fc]
+drl_allT' [in General.ddT]
+drl_allT [in General.ddT]
+drsl_allT' [in General.ddT]
+drsl_allT [in General.ddT]
+dt2fun [in General.gentree]
+

E

+E [in ISL.PropQuantifiers]
+EA [in ISL.PropQuantifiers]
+Ef [in ISL.PropQuantifiers]
+empty [in ISL.Environments]
+emptyT_sind [in General.genT]
+emptyT_rec [in General.genT]
+emptyT_ind [in General.genT]
+emptyT_rect [in General.genT]
+empty_seq_dec [in K.Interpolation.UIK_basics]
+empty_seq_dec [in GL.Interpolation.UIGL_LexSeq]
+empty_sind [in General.genT]
+empty_rec [in General.genT]
+empty_ind [in General.genT]
+empty_rect [in General.genT]
+empty_relT_sind [in General.genT]
+empty_relT_rec [in General.genT]
+empty_relT_ind [in General.genT]
+empty_relT_rect [in General.genT]
+env [in ISL.Environments]
+env_order_refl [in ISL.Order]
+env_order [in ISL.Order]
+env_weight [in ISL.Order]
+eq_nnn_app [in General.List_lemmasT]
+eq_dec_seqs [in Syntax.list_lems]
+eq_dec_listsF [in Syntax.list_lems]
+ExcClosure_sind [in GL.GLS.GLS_exch]
+ExcClosure_rec [in GL.GLS.GLS_exch]
+ExcClosure_ind [in GL.GLS.GLS_exch]
+ExcClosure_rect [in GL.GLS.GLS_exch]
+ExcClosure_sind [in K.KS.KS_exch]
+ExcClosure_rec [in K.KS.KS_exch]
+ExcClosure_ind [in K.KS.KS_exch]
+ExcClosure_rect [in K.KS.KS_exch]
+exists_dec [in ISL.DecisionProcedure]
+ex1 [in ISL.Simp]
+ex2 [in ISL.Simp]
+ex3 [in ISL.Simp]
+ex4 [in ISL.Simp]
+ex5 [in ISL.Simp]
+ex6 [in ISL.Simp]
+E_simplified [in ISL.Simp]
+E_eq [in ISL.PropQuantifiers]
+e_rule [in ISL.PropQuantifiers]
+

F

+fce3 [in General.ddT]
+fextI_eqc' [in General.gen_seq]
+fextI' [in General.gen_seq]
+finite_premises_of_S [in GL.GLS.GLS_der_dec]
+finite_BotL_premises_of_S [in GL.GLS.GLS_der_dec]
+finite_IdB_premises_of_S [in GL.GLS.GLS_der_dec]
+finite_IdP_premises_of_S [in GL.GLS.GLS_der_dec]
+finite_GLR_premises_of_S [in GL.GLS.GLS_der_dec]
+finite_ImpL_premises_of_S [in GL.GLS.GLS_der_dec]
+finite_ImpR_premises_of_S [in GL.GLS.GLS_der_dec]
+finite_KR_premises_of_S [in K.KS.KS_termination_KR]
+finite_ImpL_premises_of_S [in K.KS.KS_termination_ImpL]
+finite_ImpR_premises_of_S [in K.KS.KS_termination_ImpR]
+flatmap [in K.Interpolation.UIK_irred_short]
+flatmap [in GL.Interpolation.UIGL_irred_short]
+flatten_list [in GL.GLS.GLS_der_dec]
+flatten_list [in K.KS.KS_termination_prelims]
+fmlsext [in General.gen_seq]
+ForallTD_forall [in General.genT]
+ForallTI_forall [in General.genT]
+ForallT_2I [in General.genT]
+ForallT_2I' [in General.genT]
+ForallT_D2 [in General.genT]
+ForallT_D1 [in General.genT]
+ForallT_2D [in General.genT]
+ForallT_appendI [in General.genT]
+ForallT_appendI' [in General.genT]
+ForallT_appendD2 [in General.genT]
+ForallT_appendD1 [in General.genT]
+ForallT_appendD [in General.genT]
+ForallT_singleI [in General.genT]
+ForallT_singleD [in General.genT]
+ForallT_sind [in General.genT]
+ForallT_rec [in General.genT]
+ForallT_ind [in General.genT]
+ForallT_rect [in General.genT]
+Forall2T_sind [in General.genT]
+Forall2T_rec [in General.genT]
+Forall2T_ind [in General.genT]
+Forall2T_rect [in General.genT]
+form_of_MPropF [in UIML_extraction.UIML_extraction]
+form_order [in ISL.Formulas]
+form_to_gen_tree [in ISL.Formulas]
+form_sind [in ISL.Formulas]
+form_rec [in ISL.Formulas]
+form_ind [in ISL.Formulas]
+form_rect [in ISL.Formulas]
+fst_rel_sind [in General.gen_seq]
+fst_rel_rec [in General.gen_seq]
+fst_rel_ind [in General.gen_seq]
+fst_rel_rect [in General.gen_seq]
+fst_ext_rls_derl_fst_ext_rls' [in General.gen_seq]
+fst_ext_rls_fst_ext_rls' [in General.gen_seq]
+fst_ext_rls_sind [in General.gen_seq]
+fst_ext_rls_rec [in General.gen_seq]
+fst_ext_rls_ind [in General.gen_seq]
+fst_ext_rls_rect [in General.gen_seq]
+

G

+gen_step2s_lem [in General.gstep]
+gen_steps_lem [in General.gstep]
+gen_step2s [in General.gstep]
+gen_steps [in General.gstep]
+gen_step2_lemT [in General.gstep]
+gen_step2_lem [in General.gstep]
+gen_step_lemT [in General.gstep]
+gen_step_lem [in General.gstep]
+gen_step2_empty [in General.gstep]
+gen_step2 [in General.gstep]
+gen_step'_sind [in General.gstep]
+gen_step'_rec [in General.gstep]
+gen_step'_ind [in General.gstep]
+gen_step'_rect [in General.gstep]
+gen_step [in General.gstep]
+gen_ext_diff [in General.univ_gen_ext]
+gen_ext_one [in General.univ_gen_ext]
+gen_ext_sameR [in General.univ_gen_ext]
+gen_ext_sameL [in General.univ_gen_ext]
+gen_ext [in General.univ_gen_ext]
+gen_step2_c [in General.gentree]
+gen_step2_tr [in General.gentree]
+gen_step_c [in General.gentree]
+gen_step_tr [in General.gentree]
+gen_tree_to_form [in ISL.Formulas]
+get_dpD [in General.dd_fc]
+get_D [in General.dd_fc]
+Gflatmap_sind [in K.Interpolation.UIK_irred_short]
+Gflatmap_ind [in K.Interpolation.UIK_irred_short]
+Gflatmap_sind [in GL.Interpolation.UIGL_irred_short]
+Gflatmap_ind [in GL.Interpolation.UIGL_irred_short]
+gf_step2_tr [in General.gentree]
+gf2_step_tr [in General.gentree]
+Gimap_sind [in K.Interpolation.UIK_braga]
+Gimap_ind [in K.Interpolation.UIK_braga]
+Gimap_sind [in GL.Interpolation.UIGL_braga]
+Gimap_ind [in GL.Interpolation.UIGL_braga]
+Girred_ind [in K.Interpolation.UIK_irred_short]
+Girred_ind [in GL.Interpolation.UIGL_irred_short]
+GLRRule_sind [in GL.GLS.GLS_calcs]
+GLRRule_rec [in GL.GLS.GLS_calcs]
+GLRRule_ind [in GL.GLS.GLS_calcs]
+GLRRule_rect [in GL.GLS.GLS_calcs]
+GLR_help2 [in GL.GLS.GLS_der_dec]
+GLR_help02 [in GL.GLS.GLS_der_dec]
+GLR_help1 [in GL.GLS.GLS_der_dec]
+GLR_help01 [in GL.GLS.GLS_der_dec]
+GLR_prems [in GL.Interpolation.UIGL_LexSeq]
+GLS_drv [in GL.GLS.GLS_calcs]
+GLS_prv [in GL.GLS.GLS_calcs]
+GLS_rules_sind [in GL.GLS.GLS_calcs]
+GLS_rules_rec [in GL.GLS.GLS_calcs]
+GLS_rules_ind [in GL.GLS.GLS_calcs]
+GLS_rules_rect [in GL.GLS.GLS_calcs]
+GLS_cut_drv [in GL.GLS.GLS_cut_elim]
+GLS_cut_prv [in GL.GLS.GLS_cut_elim]
+GLS_cut_rules_sind [in GL.GLS.GLS_cut_elim]
+GLS_cut_rules_rec [in GL.GLS.GLS_cut_elim]
+GLS_cut_rules_ind [in GL.GLS.GLS_cut_elim]
+GLS_cut_rules_rect [in GL.GLS.GLS_cut_elim]
+gl_UI [in UIML_extraction.UIML_extraction]
+GUI_tot [in K.Interpolation.UIK_braga]
+GUI_tot [in GL.Interpolation.UIGL_braga]
+

H

+height [in ISL.SequentProps]
+height_step2_tr [in General.gentree]
+

I

+IdBRule_sind [in GL.GLS.GLS_calcs]
+IdBRule_rec [in GL.GLS.GLS_calcs]
+IdBRule_ind [in GL.GLS.GLS_calcs]
+IdBRule_rect [in GL.GLS.GLS_calcs]
+IdPRule_sind [in GL.GLS.GLS_calcs]
+IdPRule_rec [in GL.GLS.GLS_calcs]
+IdPRule_ind [in GL.GLS.GLS_calcs]
+IdPRule_rect [in GL.GLS.GLS_calcs]
+IdPRule_sind [in K.KS.KS_calc]
+IdPRule_rec [in K.KS.KS_calc]
+IdPRule_ind [in K.KS.KS_calc]
+IdPRule_rect [in K.KS.KS_calc]
+Idrule_sind [in General.gen_seq]
+Idrule_rec [in General.gen_seq]
+Idrule_ind [in General.gen_seq]
+Idrule_rect [in General.gen_seq]
+Id_InT_Canopy [in GL.Interpolation.UIGL_Canopy]
+iffT_D2 [in General.genT]
+iffT_D1 [in General.genT]
+iffT_sym [in General.genT]
+imap [in K.Interpolation.UIK_braga]
+imap [in GL.Interpolation.UIGL_braga]
+ImpLRule_sind [in GL.GLS.GLS_calcs]
+ImpLRule_rec [in GL.GLS.GLS_calcs]
+ImpLRule_ind [in GL.GLS.GLS_calcs]
+ImpLRule_rect [in GL.GLS.GLS_calcs]
+ImpLRule_sind [in K.KS.KS_calc]
+ImpLRule_rec [in K.KS.KS_calc]
+ImpLRule_ind [in K.KS.KS_calc]
+ImpLRule_rect [in K.KS.KS_calc]
+ImpL_help1 [in GL.GLS.GLS_der_dec]
+ImpL_help01 [in GL.GLS.GLS_der_dec]
+ImpL_help2 [in GL.GLS.GLS_der_dec]
+ImpL_help02 [in GL.GLS.GLS_der_dec]
+ImpL_help002 [in GL.GLS.GLS_der_dec]
+ImpL_help1 [in K.KS.KS_termination_ImpL]
+ImpL_help01 [in K.KS.KS_termination_ImpL]
+ImpL_help2 [in K.KS.KS_termination_ImpL]
+ImpL_help02 [in K.KS.KS_termination_ImpL]
+ImpL_help002 [in K.KS.KS_termination_ImpL]
+ImpRRule_sind [in GL.GLS.GLS_calcs]
+ImpRRule_rec [in GL.GLS.GLS_calcs]
+ImpRRule_ind [in GL.GLS.GLS_calcs]
+ImpRRule_rect [in GL.GLS.GLS_calcs]
+ImpRRule_sind [in K.KS.KS_calc]
+ImpRRule_rec [in K.KS.KS_calc]
+ImpRRule_ind [in K.KS.KS_calc]
+ImpRRule_rect [in K.KS.KS_calc]
+ImpR_help2 [in GL.GLS.GLS_der_dec]
+ImpR_help02 [in GL.GLS.GLS_der_dec]
+ImpR_help002 [in GL.GLS.GLS_der_dec]
+ImpR_help1 [in GL.GLS.GLS_der_dec]
+ImpR_help01 [in GL.GLS.GLS_der_dec]
+ImpR_help2 [in K.KS.KS_termination_ImpR]
+ImpR_help02 [in K.KS.KS_termination_ImpR]
+ImpR_help002 [in K.KS.KS_termination_ImpR]
+ImpR_help1 [in K.KS.KS_termination_ImpR]
+ImpR_help01 [in K.KS.KS_termination_ImpR]
+InT_trans_flatten_list [in GL.GLS.GLS_der_dec]
+InT_flatten_list_InT_elem [in GL.GLS.GLS_der_dec]
+InT_map_iff [in GL.GLS.GLS_der_dec]
+InT_trans_flatten_list [in K.KS.KS_termination_prelims]
+InT_flatten_list_InT_elem [in K.KS.KS_termination_prelims]
+InT_map_iff [in K.KS.KS_termination_prelims]
+InT_or_app [in General.List_lemmasT]
+InT_app_or [in General.List_lemmasT]
+InT_pair_triple_sind [in General.List_lemmasT]
+InT_pair_triple_rec [in General.List_lemmasT]
+InT_pair_triple_ind [in General.List_lemmasT]
+InT_pair_triple_rect [in General.List_lemmasT]
+InT_mapI [in General.genT]
+InT_map_iffT [in General.genT]
+InT_2nd [in General.genT]
+InT_eq [in General.genT]
+InT_sind [in General.genT]
+InT_rec [in General.genT]
+InT_ind [in General.genT]
+InT_rect [in General.genT]
+invprem [in GL.Interpolation.UIGL_Canopy]
+invprem [in K.Interpolation.UIK_Canopy]
+inv_prems [in GL.Interpolation.UIGL_Canopy]
+inv_prems [in K.Interpolation.UIK_Canopy]
+In_pos_top_imps_split_l [in GL.GLS.GLS_der_dec]
+In_InT_pair [in GL.GLS.GLS_der_dec]
+In_InT_pair [in K.KS.KS_termination_prelims]
+in_nextup_fc_nu [in General.dd_fc]
+in_nextup_nu [in General.dd_fc]
+in_nextup_fc_sind [in General.dd_fc]
+in_nextup_fc_rec [in General.dd_fc]
+in_nextup_fc_ind [in General.dd_fc]
+in_nextup_fc_rect [in General.dd_fc]
+in_nextup_sind [in General.dd_fc]
+in_nextup_rec [in General.dd_fc]
+in_nextup_ind [in General.dd_fc]
+in_nextup_rect [in General.dd_fc]
+in_dersrec_sind [in General.dd_fc]
+in_dersrec_rec [in General.dd_fc]
+in_dersrec_ind [in General.dd_fc]
+in_dersrec_rect [in General.dd_fc]
+in_nextup_height [in General.gentree]
+in_nextup_size [in General.gentree]
+in_adm [in General.ddT]
+In_dec [in Syntax.remove_list_lems]
+In_pos_top_imps_split_l [in K.KS.KS_termination_ImpR]
+in_top_boxes [in GL.GLS.GLS_dec]
+In_InT_seqs [in Syntax.list_lems]
+in_top_boxes [in K.KS.KS_dec]
+in_subset [in ISL.Environments]
+in_map [in ISL.Environments]
+in_map_aux [in ISL.Environments]
+irred [in K.Interpolation.UIK_irred_short]
+irred [in GL.Interpolation.UIGL_irred_short]
+irreducible [in ISL.Environments]
+isl_simplified_A [in UIML_extraction.UIML_extraction]
+isl_simplified_E [in UIML_extraction.UIML_extraction]
+isl_simp [in UIML_extraction.UIML_extraction]
+isl_A [in UIML_extraction.UIML_extraction]
+isl_E [in UIML_extraction.UIML_extraction]
+is_init [in K.Interpolation.UIK_basics]
+is_mhd [in GL.GLS.GLS_der_dec]
+is_mhd [in K.KS.KS_termination_prelims]
+is_Prime [in Syntax.CML_Syntax]
+is_Boxed_list [in Syntax.CML_Syntax]
+is_boxedT [in Syntax.CML_Syntax]
+is_atomicT [in Syntax.CML_Syntax]
+is_nextup_sind [in General.dd_fc]
+is_nextup_rec [in General.dd_fc]
+is_nextup_ind [in General.dd_fc]
+is_nextup_rect [in General.dd_fc]
+is_Prime_dec [in GL.Interpolation.UIGL_Canopy]
+is_init [in GL.Interpolation.UIGL_LexSeq]
+is_box [in ISL.Environments]
+is_negation [in ISL.Environments]
+is_implication [in ISL.Environments]
+is_double_negation [in ISL.Environments]
+is_Prime_dec [in K.Interpolation.UIK_Canopy]
+

K

+KRRule_sind [in K.KS.KS_calc]
+KRRule_rec [in K.KS.KS_calc]
+KRRule_ind [in K.KS.KS_calc]
+KRRule_rect [in K.KS.KS_calc]
+KR_prems [in K.Interpolation.UIK_basics]
+KR_help2 [in K.KS.KS_termination_KR]
+KR_help02 [in K.KS.KS_termination_KR]
+KR_help1 [in K.KS.KS_termination_KR]
+KR_help01 [in K.KS.KS_termination_KR]
+KS_cut_drv [in K.KS.KS_cut_elim]
+KS_cut_prv [in K.KS.KS_cut_elim]
+KS_cut_rules_sind [in K.KS.KS_cut_elim]
+KS_cut_rules_rec [in K.KS.KS_cut_elim]
+KS_cut_rules_ind [in K.KS.KS_cut_elim]
+KS_cut_rules_rect [in K.KS.KS_cut_elim]
+KS_drv [in K.KS.KS_calc]
+KS_prv [in K.KS.KS_calc]
+KS_rules_sind [in K.KS.KS_calc]
+KS_rules_rec [in K.KS.KS_calc]
+KS_rules_ind [in K.KS.KS_calc]
+KS_rules_rect [in K.KS.KS_calc]
+k_UI [in UIML_extraction.UIML_extraction]
+

L

+length_form [in GL.GLS.GLS_termination_measure]
+less_imp [in GL.Interpolation.UIGL_Canopy]
+less_thanS [in GL.GLS.GLS_termination_measure]
+less_imp [in K.Interpolation.UIK_Canopy]
+leT_trans [in General.genT]
+leT_S_n [in General.genT]
+leT_sind [in General.genT]
+leT_rec [in General.genT]
+leT_ind [in General.genT]
+leT_rect [in General.genT]
+LexSeq [in GL.Interpolation.UIGL_LexSeq]
+LexSeq_ind [in GL.Interpolation.UIGL_LexSeq]
+lex_sind [in K.Interpolation.UIK_Def_measure]
+lex_ind [in K.Interpolation.UIK_Def_measure]
+lex_sind [in GL.GLS.DLW_wf_lex]
+lex_ind [in GL.GLS.DLW_wf_lex]
+lex_sind [in GL.Interpolation.UIGL_Def_measure]
+lex_ind [in GL.Interpolation.UIGL_Def_measure]
+Lindenbaum_Tarski_preorder [in ISL.Optimizations]
+listInserts [in GL.GLS.GLS_der_dec]
+listInserts [in K.KS.KS_termination_prelims]
+listInsertsL_Seqs [in GL.GLS.GLS_der_dec]
+listInsertsL_Seqs [in K.KS.KS_termination_prelims]
+listInsertsRL_Seqs [in GL.GLS.GLS_der_dec]
+listInsertsRL_Seqs [in K.KS.KS_termination_prelims]
+listInsertsR_Seqs [in GL.GLS.GLS_der_dec]
+listInsertsR_Seqs [in K.KS.KS_termination_prelims]
+list_is_nil [in K.Interpolation.UIK_irred_high_level]
+list_of_premises [in K.KS.KS_termination]
+list_prop_LF [in K.Interpolation.UIK_basics]
+list_prop_F [in K.Interpolation.UIK_basics]
+list_disj [in K.Interpolation.UIK_basics]
+list_conj [in K.Interpolation.UIK_basics]
+list_of_premises [in GL.GLS.GLS_der_dec]
+list_of_splits [in GL.GLS.GLS_der_dec]
+list_of_splits [in K.KS.KS_termination_prelims]
+list_prop_LF [in GL.Interpolation.UIGL_basics]
+list_prop_F [in GL.Interpolation.UIGL_basics]
+list_disj [in GL.Interpolation.UIGL_basics]
+list_conj [in GL.Interpolation.UIGL_basics]
+list_exch_R_sind [in K.KS.KS_exch_prelims]
+list_exch_R_rec [in K.KS.KS_exch_prelims]
+list_exch_R_ind [in K.KS.KS_exch_prelims]
+list_exch_R_rect [in K.KS.KS_exch_prelims]
+list_exch_L_sind [in K.KS.KS_exch_prelims]
+list_exch_L_rec [in K.KS.KS_exch_prelims]
+list_exch_L_ind [in K.KS.KS_exch_prelims]
+list_exch_L_rect [in K.KS.KS_exch_prelims]
+list_exch_R_sind [in GL.GLS.GLS_exch]
+list_exch_R_rec [in GL.GLS.GLS_exch]
+list_exch_R_ind [in GL.GLS.GLS_exch]
+list_exch_R_rect [in GL.GLS.GLS_exch]
+list_exch_L_sind [in GL.GLS.GLS_exch]
+list_exch_L_rec [in GL.GLS.GLS_exch]
+list_exch_L_ind [in GL.GLS.GLS_exch]
+list_exch_L_rect [in GL.GLS.GLS_exch]
+list_is_nil [in K.Interpolation.UIK_irred_short]
+list_is_nil [in GL.Interpolation.UIGL_irred_high_level]
+list_is_nil [in GL.Interpolation.UIGL_irred_short]
+LtSeq [in K.Interpolation.UIK_basics]
+LtSeq_ind [in K.Interpolation.UIK_basics]
+

M

+make_impl [in ISL.Environments]
+make_disj [in ISL.Environments]
+make_conj [in ISL.Environments]
+measure [in General.gentree]
+measure [in GL.GLS.GLS_termination_measure]
+measure [in GL.Interpolation.UIGL_LexSeq]
+measure [in K.KS.KS_termination_measure]
+measure_rect [in K.Interpolation.UIK_Def_measure]
+measure_rect [in GL.GLS.DLW_wf_lex]
+measure_rect [in GL.Interpolation.UIGL_Def_measure]
+mhd [in K.KS.KS_termination]
+MPropF_sind [in Syntax.CML_Syntax]
+MPropF_rec [in Syntax.CML_Syntax]
+MPropF_ind [in Syntax.CML_Syntax]
+MPropF_rect [in Syntax.CML_Syntax]
+MPropF_of_form [in UIML_extraction.UIML_extraction]
+

N

+N [in GL.Interpolation.UIGL_braga]
+Neg [in Syntax.CML_Syntax]
+nextup [in General.dd_fc]
+nextup_in_nu_fc [in General.dd_fc]
+nextup_in_nu [in General.dd_fc]
+nil_eq_appT [in General.List_lemmasT]
+nil_eq_app [in General.List_lemmasT]
+nil_eq_list [in General.List_lemmasT]
+nobox_gen_ext [in Syntax.CML_Syntax]
+nodupseq [in GL.Interpolation.UIGL_nodupseq]
+non_empty [in General.List_lemmasT]
+nth_split [in GL.GLS.GLS_der_dec]
+nth_split [in K.KS.KS_termination_prelims]
+N_pwc [in GL.Interpolation.UIGL_braga]
+n_imp_subformS [in GL.GLS.GLS_termination_measure]
+n_imp_subformLF [in GL.GLS.GLS_termination_measure]
+n_imp_subformF [in GL.GLS.GLS_termination_measure]
+n_imp_subformS [in K.Interpolation.UIK_Canopy]
+n_imp_subformLF [in K.Interpolation.UIK_Canopy]
+n_imp_subformF [in K.Interpolation.UIK_Canopy]
+

O

+obviously_smaller [in ISL.Environments]
+occurs_in [in ISL.Formulas]
+open_boxes [in ISL.Environments]
+open_box [in ISL.Environments]
+Or [in Syntax.CML_Syntax]
+

P

+PermutationTS [in GL.Interpolation.UIGL_PermutationTS]
+PermutationT_sind [in GL.Interpolation.UIGL_PermutationT]
+PermutationT_rec [in GL.Interpolation.UIGL_PermutationT]
+PermutationT_ind [in GL.Interpolation.UIGL_PermutationT]
+PermutationT_rect [in GL.Interpolation.UIGL_PermutationT]
+pointed_env_ms_order [in ISL.Order]
+pointed_env_order [in ISL.Order]
+pointed_env [in ISL.Order]
+pos_top_imps [in GL.GLS.GLS_der_dec]
+pos_top_imps [in K.KS.KS_termination_prelims]
+prems_Box_R [in GL.GLS.GLS_der_dec]
+prems_Imp_L [in GL.GLS.GLS_der_dec]
+prems_Imp_R [in GL.GLS.GLS_der_dec]
+prems_Box_R [in K.KS.KS_termination_KR]
+prems_Imp_L [in K.KS.KS_termination_ImpL]
+prems_Imp_R [in K.KS.KS_termination_ImpR]
+proj1_sigT2 [in GL.GLS.GLS_der_dec]
+proj1_sigT2 [in K.KS.KS_termination_prelims]
+proj2_sigT2 [in GL.GLS.GLS_der_dec]
+proj2_sigT2 [in K.KS.KS_termination_prelims]
+propvar_subform_list [in K.Interpolation.UIK_UI_prelims]
+propvar_subform [in K.Interpolation.UIK_UI_prelims]
+propvar_subform_list [in K.Interpolation.K_Craig_Interp]
+propvar_subform [in K.Interpolation.K_Craig_Interp]
+propvar_subform_list [in GL.Interpolation.UIGL_UI_prelims]
+propvar_subform [in GL.Interpolation.UIGL_UI_prelims]
+Provable_sind [in ISL.Sequents]
+Provable_rec [in ISL.Sequents]
+Provable_ind [in ISL.Sequents]
+Provable_rect [in ISL.Sequents]
+

R

+radmD [in General.gstep]
+radm_sind [in General.gstep]
+radm_rec [in General.gstep]
+radm_ind [in General.gstep]
+radm_rect [in General.gstep]
+rel [in General.gen_tacs]
+relationT [in General.genT]
+relmap_sind [in General.gen_seq]
+relmap_rec [in General.gen_seq]
+relmap_ind [in General.gen_seq]
+relmap_rect [in General.gen_seq]
+rel_admD [in General.gstep]
+rel_adm_sind [in General.gstep]
+rel_adm_rec [in General.gstep]
+rel_adm_ind [in General.gstep]
+rel_adm_rect [in General.gstep]
+remove_nth [in GL.GLS.GLS_der_dec]
+remove_nth [in K.KS.KS_termination_prelims]
+remove_list [in Syntax.remove_list_lems]
+replace [in GL.Interpolation.UIGL_Canopy_ImpR]
+req [in General.gen]
+restr_list_prop [in K.Interpolation.UIK_basics]
+restr_list_prop [in GL.Interpolation.UIGL_basics]
+rest_gen_ext [in General.univ_gen_ext]
+rev_pair [in General.gen_seq]
+rls [in General.gen]
+rlsmap_sind [in General.gen_seq]
+rlsmap_rec [in General.gen_seq]
+rlsmap_ind [in General.gen_seq]
+rlsmap_rect [in General.gen_seq]
+rlsT [in General.genT]
+rm [in ISL.Environments]
+rsub [in General.gen]
+rsubD [in General.gen]
+rsubI [in General.gen]
+rsub_adm [in General.ddT]
+rsub_derl_adm [in General.ddT]
+rsub_derl [in General.ddT]
+rsub_imp [in General.gen]
+rUnion_sind [in General.gstep]
+rUnion_rec [in General.gstep]
+rUnion_ind [in General.gstep]
+rUnion_rect [in General.gstep]
+runion_sind [in General.gstep]
+runion_rec [in General.gstep]
+runion_ind [in General.gstep]
+runion_rect [in General.gstep]
+

S

+Seq [in GL.GLS.GLS_calcs]
+Seq [in K.KS.KS_calc]
+seqext [in General.gen_seq]
+seqrule_mono' [in General.gen_seq]
+seqrule_s_sind [in General.gen_seq]
+seqrule_s_rec [in General.gen_seq]
+seqrule_s_ind [in General.gen_seq]
+seqrule_s_rect [in General.gen_seq]
+seqrule_derl_seqrule' [in General.gen_seq]
+seqrule_seqrule' [in General.gen_seq]
+seqrule_sind [in General.gen_seq]
+seqrule_rec [in General.gen_seq]
+seqrule_ind [in General.gen_seq]
+seqrule_rect [in General.gen_seq]
+seqrule'_sind [in General.gen_seq]
+seqrule'_rec [in General.gen_seq]
+seqrule'_ind [in General.gen_seq]
+seqrule'_rect [in General.gen_seq]
+seqs_in_splitT [in Syntax.list_lems]
+simp [in ISL.Simp]
+simp_imps [in ISL.Simp]
+simp_imp [in ISL.Simp]
+simp_ands [in ISL.Simp]
+simp_ors [in ISL.Simp]
+single [in General.swappedT]
+single_eq_listT_nobrac [in General.List_lemmasT]
+single_eq_listT [in General.List_lemmasT]
+single_eq_list [in General.List_lemmasT]
+sing_empty_sind [in General.gen_seq]
+sing_empty_rec [in General.gen_seq]
+sing_empty_ind [in General.gen_seq]
+sing_empty_rect [in General.gen_seq]
+size [in Syntax.CML_Syntax]
+size_LF [in Syntax.CML_Syntax]
+size_step2_tr [in General.gentree]
+snd_rel_sind [in General.gen_seq]
+snd_rel_rec [in General.gen_seq]
+snd_rel_ind [in General.gen_seq]
+snd_rel_rect [in General.gen_seq]
+snd_ext_rls_sind [in General.gen_seq]
+snd_ext_rls_rec [in General.gen_seq]
+snd_ext_rls_ind [in General.gen_seq]
+snd_ext_rls_rect [in General.gen_seq]
+subformlist [in Syntax.CML_Syntax]
+subform_boxesS [in GL.GLS.GLS_termination_measure]
+subform_boxesLF [in GL.GLS.GLS_termination_measure]
+subform_boxesF [in GL.GLS.GLS_termination_measure]
+subform_sind [in ISL.Formulas]
+subform_ind [in ISL.Formulas]
+subst [in Syntax.CML_Syntax]
+sumh_step2_tr [in General.gentree]
+sum_step2_tr_D_gf2 [in General.gentree]
+sum_step2_tr [in General.gentree]
+swapped_gen_sind [in General.swappedT]
+swapped_gen_rec [in General.swappedT]
+swapped_gen_ind [in General.swappedT]
+swapped_gen_rect [in General.swappedT]
+swapped_spec_sind [in General.swappedT]
+swapped_spec_rec [in General.swappedT]
+swapped_spec_ind [in General.swappedT]
+swapped_spec_rect [in General.swappedT]
+swapped_single [in General.swappedT]
+swapped_sind [in General.swappedT]
+swapped_rec [in General.swappedT]
+swapped_ind [in General.swappedT]
+swapped_rect [in General.swappedT]
+

T

+Top [in Syntax.CML_Syntax]
+top_boxes_nobox_gen_ext [in GL.GLS.GLS_der_dec]
+top_imps [in GL.GLS.GLS_der_dec]
+top_boxes_nobox_gen_ext [in K.KS.KS_termination_prelims]
+top_imps [in K.KS.KS_termination_prelims]
+top_boxes [in Syntax.CML_Syntax]
+transitiveT [in General.rtcT]
+transitiveT [in General.genT]
+trf [in General.gen_tacs]
+

U

+UI [in K.Interpolation.UIK_braga]
+UI [in GL.Interpolation.UIGL_braga]
+unboxed_list [in Syntax.CML_Syntax]
+unBox_formula [in Syntax.CML_Syntax]
+unit_eq_appT2 [in General.List_lemmasT]
+unit_eq_app [in General.List_lemmasT]
+univ_gen_mod_sind [in General.univ_gen_mod]
+univ_gen_mod_rec [in General.univ_gen_mod]
+univ_gen_mod_ind [in General.univ_gen_mod]
+univ_gen_mod_rect [in General.univ_gen_mod]
+univ_gen_ext_sind [in General.univ_gen_ext]
+univ_gen_ext_rec [in General.univ_gen_ext]
+univ_gen_ext_ind [in General.univ_gen_ext]
+univ_gen_ext_rect [in General.univ_gen_ext]
+Unnamed_thm0 [in General.swappedT]
+Unnamed_thm [in General.swappedT]
+usable_boxes [in GL.GLS.GLS_termination_measure]
+

V

+variable [in ISL.Formulas]
+vars_incl [in ISL.PropQuantifiers]
+var_not_in_env [in ISL.Environments]
+

W

+weight [in ISL.Formulas]
+weight_ind [in ISL.Formulas]
+well_foundedT [in General.genT]
+wf_env_order [in ISL.Order]
+wkL_valid' [in General.gen_seq]
+wkL_valid [in General.gen_seq]
+wkn_R_sind [in K.KS.KS_wkn]
+wkn_R_rec [in K.KS.KS_wkn]
+wkn_R_ind [in K.KS.KS_wkn]
+wkn_R_rect [in K.KS.KS_wkn]
+wkn_L_sind [in K.KS.KS_wkn]
+wkn_L_rec [in K.KS.KS_wkn]
+wkn_L_ind [in K.KS.KS_wkn]
+wkn_L_rect [in K.KS.KS_wkn]
+wkn_R_sind [in GL.GLS.GLS_wkn]
+wkn_R_rec [in GL.GLS.GLS_wkn]
+wkn_R_ind [in GL.GLS.GLS_wkn]
+wkn_R_rect [in GL.GLS.GLS_wkn]
+wkn_L_sind [in GL.GLS.GLS_wkn]
+wkn_L_rec [in GL.GLS.GLS_wkn]
+wkn_L_ind [in GL.GLS.GLS_wkn]
+wkn_L_rect [in GL.GLS.GLS_wkn]
+

X

+XBoxed_list [in GL.GLS.GLS_calcs]
+


+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Global IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(2915 entries)
Notation IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(42 entries)
Variable IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(114 entries)
Library IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(97 entries)
Lemma IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(1372 entries)
Constructor IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(190 entries)
Inductive IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(102 entries)
Section IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(66 entries)
Instance IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(25 entries)
Definition IndexABCDEFGHIJKLMNOPQRSTUVWXYZ_other(907 entries)
+
+ +
+ + + diff --git a/toc.html b/toc.html new file mode 100644 index 0000000..711fbea --- /dev/null +++ b/toc.html @@ -0,0 +1,500 @@ + + + + + + + + + + + + + +
+
+
+ +

General

+ + +

Syntax for K and GL

+ + +

The calculus KS and its properties

+ + + +

Uniform interpolation for K

+ + + +

The calculus GLS and its properties

+ + +

Uniform interpolation for GL

+ + +

ISL.Environments

+ +

ISL.Formulas

+ +

ISL.Order

+

ISL.PropQuantifiers

+ +

ISL.SequentProps

+ +

ISL.Sequents

+ + +

Extraction file

+
+
+ +
+ + + diff --git a/uiml_demo.bc.js b/uiml_demo.bc.js new file mode 100644 index 0000000..f68397e --- /dev/null +++ b/uiml_demo.bc.js @@ -0,0 +1,33245 @@ +//# 1 ".uiml_demo.eobjs/jsoo/uiml_demo.bc.runtime.js" +// Generated by js_of_ocaml +//# buildInfo:effects=false, kind=unknown, use-js-string=true, version=5.8.2 +//# 3 ".uiml_demo.eobjs/jsoo/uiml_demo.bc.runtime.js" + +//# 7 ".uiml_demo.eobjs/jsoo/uiml_demo.bc.runtime.js" +(function + (Object){ + typeof globalThis !== "object" + && + (this + ? get() + : (Object.defineProperty + (Object.prototype, "_T_", {configurable: true, get: get}), + _T_)); + function get(){ + var global = this || self; + global.globalThis = global; + delete Object.prototype._T_; + } + } + (Object)); +(function(globalThis){ + "use strict"; + function caml_subarray_to_jsbytes(a, i, len){ + var f = String.fromCharCode; + if(i == 0 && len <= 4096 && len == a.length) return f.apply(null, a); + var s = ""; + for(; 0 < len; i += 1024, len -= 1024) + s += f.apply(null, a.slice(i, i + Math.min(len, 1024))); + return s; + } + function caml_string_of_jsbytes(x){return x;} + function caml_string_of_array(a){ + return caml_string_of_jsbytes(caml_subarray_to_jsbytes(a, 0, a.length)); + } + function caml_ba_get_1(ba, i0){return ba.get(ba.offset(i0));} + function BigStringReader(bs, i){this.s = bs; this.i = i;} + BigStringReader.prototype = + {read8u: function(){return caml_ba_get_1(this.s, this.i++);}, + read8s: function(){return caml_ba_get_1(this.s, this.i++) << 24 >> 24;}, + read16u: + function(){ + var s = this.s, i = this.i; + this.i = i + 2; + return caml_ba_get_1(s, i) << 8 | caml_ba_get_1(s, i + 1); + }, + read16s: + function(){ + var s = this.s, i = this.i; + this.i = i + 2; + return caml_ba_get_1(s, i) << 24 >> 16 | caml_ba_get_1(s, i + 1); + }, + read32u: + function(){ + var s = this.s, i = this.i; + this.i = i + 4; + return (caml_ba_get_1(s, i) << 24 | caml_ba_get_1(s, i + 1) << 16 + | caml_ba_get_1(s, i + 2) << 8 + | caml_ba_get_1(s, i + 3)) + >>> 0; + }, + read32s: + function(){ + var s = this.s, i = this.i; + this.i = i + 4; + return caml_ba_get_1(s, i) << 24 | caml_ba_get_1(s, i + 1) << 16 + | caml_ba_get_1(s, i + 2) << 8 + | caml_ba_get_1(s, i + 3); + }, + readstr: + function(len){ + var i = this.i, arr = new Array(len); + for(var j = 0; j < len; j++) arr[j] = caml_ba_get_1(this.s, i + j); + this.i = i + len; + return caml_string_of_array(arr); + }, + readuint8array: + function(len){ + var i = this.i, offset = this.offset(i); + this.i = i + len; + return this.s.data.subarray(offset, offset + len); + }}; + function caml_str_repeat(n, s){ + if(n == 0) return ""; + if(s.repeat) return s.repeat(n); + var r = "", l = 0; + for(;;){ + if(n & 1) r += s; + n >>= 1; + if(n == 0) return r; + s += s; + l++; + if(l == 9) s.slice(0, 1); + } + } + function caml_convert_string_to_bytes(s){ + if(s.t == 2) + s.c += caml_str_repeat(s.l - s.c.length, "\0"); + else + s.c = caml_subarray_to_jsbytes(s.c, 0, s.c.length); + s.t = 0; + } + function jsoo_is_ascii(s){ + if(s.length < 24){ + for(var i = 0; i < s.length; i++) if(s.charCodeAt(i) > 127) return false; + return true; + } + else + return ! /[^\x00-\x7f]/.test(s); + } + function caml_utf16_of_utf8(s){ + for(var b = "", t = "", c, c1, c2, v, i = 0, l = s.length; i < l; i++){ + c1 = s.charCodeAt(i); + if(c1 < 0x80){ + for(var j = i + 1; j < l && (c1 = s.charCodeAt(j)) < 0x80; j++) ; + if(j - i > 512){ + t.substr(0, 1); + b += t; + t = ""; + b += s.slice(i, j); + } + else + t += s.slice(i, j); + if(j == l) break; + i = j; + } + v = 1; + if(++i < l && ((c2 = s.charCodeAt(i)) & - 64) == 128){ + c = c2 + (c1 << 6); + if(c1 < 0xe0){ + v = c - 0x3080; + if(v < 0x80) v = 1; + } + else{ + v = 2; + if(++i < l && ((c2 = s.charCodeAt(i)) & - 64) == 128){ + c = c2 + (c << 6); + if(c1 < 0xf0){ + v = c - 0xe2080; + if(v < 0x800 || v >= 0xd7ff && v < 0xe000) v = 2; + } + else{ + v = 3; + if(++i < l && ((c2 = s.charCodeAt(i)) & - 64) == 128 && c1 < 0xf5){ + v = c2 - 0x3c82080 + (c << 6); + if(v < 0x10000 || v > 0x10ffff) v = 3; + } + } + } + } + } + if(v < 4){ + i -= v; + t += "\ufffd"; + } + else if(v > 0xffff) + t += String.fromCharCode(0xd7c0 + (v >> 10), 0xdc00 + (v & 0x3FF)); + else + t += String.fromCharCode(v); + if(t.length > 1024){t.substr(0, 1); b += t; t = "";} + } + return b + t; + } + function MlBytes(tag, contents, length){ + this.t = tag; + this.c = contents; + this.l = length; + } + MlBytes.prototype.toString = + function(){ + switch(this.t){ + case 9: + return this.c; + default: caml_convert_string_to_bytes(this); + case 0: + if(jsoo_is_ascii(this.c)){this.t = 9; return this.c;} this.t = 8; + case 8: + return this.c; + } + }; + MlBytes.prototype.toUtf16 = + function(){ + var r = this.toString(); + if(this.t == 9) return r; + return caml_utf16_of_utf8(r); + }; + MlBytes.prototype.slice = + function(){ + var content = this.t == 4 ? this.c.slice() : this.c; + return new MlBytes(this.t, content, this.l); + }; + function caml_utf8_of_utf16(s){ + for(var b = "", t = b, c, d, i = 0, l = s.length; i < l; i++){ + c = s.charCodeAt(i); + if(c < 0x80){ + for(var j = i + 1; j < l && (c = s.charCodeAt(j)) < 0x80; j++) ; + if(j - i > 512){ + t.substr(0, 1); + b += t; + t = ""; + b += s.slice(i, j); + } + else + t += s.slice(i, j); + if(j == l) break; + i = j; + } + if(c < 0x800){ + t += String.fromCharCode(0xc0 | c >> 6); + t += String.fromCharCode(0x80 | c & 0x3f); + } + else if(c < 0xd800 || c >= 0xdfff) + t += + String.fromCharCode + (0xe0 | c >> 12, 0x80 | c >> 6 & 0x3f, 0x80 | c & 0x3f); + else if + (c >= 0xdbff || i + 1 == l || (d = s.charCodeAt(i + 1)) < 0xdc00 + || d > 0xdfff) + t += "\xef\xbf\xbd"; + else{ + i++; + c = (c << 10) + d - 0x35fdc00; + t += + String.fromCharCode + (0xf0 | c >> 18, + 0x80 | c >> 12 & 0x3f, + 0x80 | c >> 6 & 0x3f, + 0x80 | c & 0x3f); + } + if(t.length > 1024){t.substr(0, 1); b += t; t = "";} + } + return b + t; + } + function caml_string_of_jsstring(s){ + return jsoo_is_ascii(s) + ? caml_string_of_jsbytes(s) + : caml_string_of_jsbytes(caml_utf8_of_utf16(s)); + } + var + unix_error = + ["E2BIG", + "EACCES", + "EAGAIN", + "EBADF", + "EBUSY", + "ECHILD", + "EDEADLK", + "EDOM", + "EEXIST", + "EFAULT", + "EFBIG", + "EINTR", + "EINVAL", + "EIO", + "EISDIR", + "EMFILE", + "EMLINK", + "ENAMETOOLONG", + "ENFILE", + "ENODEV", + "ENOENT", + "ENOEXEC", + "ENOLCK", + "ENOMEM", + "ENOSPC", + "ENOSYS", + "ENOTDIR", + "ENOTEMPTY", + "ENOTTY", + "ENXIO", + "EPERM", + "EPIPE", + "ERANGE", + "EROFS", + "ESPIPE", + "ESRCH", + "EXDEV", + "EWOULDBLOCK", + "EINPROGRESS", + "EALREADY", + "ENOTSOCK", + "EDESTADDRREQ", + "EMSGSIZE", + "EPROTOTYPE", + "ENOPROTOOPT", + "EPROTONOSUPPORT", + "ESOCKTNOSUPPORT", + "EOPNOTSUPP", + "EPFNOSUPPORT", + "EAFNOSUPPORT", + "EADDRINUSE", + "EADDRNOTAVAIL", + "ENETDOWN", + "ENETUNREACH", + "ENETRESET", + "ECONNABORTED", + "ECONNRESET", + "ENOBUFS", + "EISCONN", + "ENOTCONN", + "ESHUTDOWN", + "ETOOMANYREFS", + "ETIMEDOUT", + "ECONNREFUSED", + "EHOSTDOWN", + "EHOSTUNREACH", + "ELOOP", + "EOVERFLOW"]; + function make_unix_err_args(code, syscall, path, errno){ + var variant = unix_error.indexOf(code); + if(variant < 0){if(errno == null) errno = - 9999; variant = [0, errno];} + var + args = + [variant, + caml_string_of_jsstring(syscall || ""), + caml_string_of_jsstring(path || "")]; + return args; + } + var caml_named_values = {}; + function caml_named_value(nm){return caml_named_values[nm];} + function jsoo_sys_getenv(n){ + var process = globalThis.process; + if(process && process.env && process.env[n] != undefined) + return process.env[n]; + if(globalThis.jsoo_static_env && globalThis.jsoo_static_env[n]) + return globalThis.jsoo_static_env[n]; + } + var caml_record_backtrace_flag = 0; + (function(){ + var r = jsoo_sys_getenv("OCAMLRUNPARAM"); + if(r !== undefined){ + var l = r.split(","); + for(var i = 0; i < l.length; i++) + if(l[i] == "b"){ + caml_record_backtrace_flag = 1; + break; + } + else if(l[i].startsWith("b=")) + caml_record_backtrace_flag = + l[i].slice(2); + else + continue; + } + } + ()); + var caml_global_data = [0]; + function caml_exn_with_js_backtrace(exn, force){ + if(! exn.js_error || force || exn[0] == 248) + exn.js_error = new globalThis.Error("Js exception containing backtrace"); + return exn; + } + function caml_maybe_attach_backtrace(exn, force){ + return caml_record_backtrace_flag + ? caml_exn_with_js_backtrace(exn, force) + : exn; + } + function caml_raise_with_args(tag, args){ + throw caml_maybe_attach_backtrace([0, tag].concat(args)); + } + function caml_is_ml_bytes(s){return s instanceof MlBytes;} + function caml_is_ml_string(s){ + return typeof s === "string" && ! /[^\x00-\xff]/.test(s); + } + function caml_bytes_of_array(a){ + if(! (a instanceof Uint8Array)) a = new Uint8Array(a); + return new MlBytes(4, a, a.length); + } + function caml_bytes_of_jsbytes(s){return new MlBytes(0, s, s.length);} + function caml_jsbytes_of_string(x){return x;} + function caml_bytes_of_string(s){ + return caml_bytes_of_jsbytes(caml_jsbytes_of_string(s)); + } + function caml_raise_with_arg(tag, arg){ + throw caml_maybe_attach_backtrace([0, tag, arg]); + } + function caml_raise_with_string(tag, msg){ + caml_raise_with_arg(tag, caml_string_of_jsbytes(msg)); + } + function caml_raise_sys_error(msg){ + caml_raise_with_string(caml_global_data.Sys_error, msg); + } + function caml_raise_no_such_file(name){ + caml_raise_sys_error(name + ": No such file or directory"); + } + function caml_convert_bytes_to_array(s){ + var a = new Uint8Array(s.l), b = s.c, l = b.length, i = 0; + for(; i < l; i++) a[i] = b.charCodeAt(i); + for(l = s.l; i < l; i++) a[i] = 0; + s.c = a; + s.t = 4; + return a; + } + function caml_uint8_array_of_bytes(s){ + if(s.t != 4) caml_convert_bytes_to_array(s); + return s.c; + } + function caml_invalid_argument(msg){ + caml_raise_with_string(caml_global_data.Invalid_argument, msg); + } + function caml_create_bytes(len){ + if(len < 0) caml_invalid_argument("Bytes.create"); + return new MlBytes(len ? 2 : 9, "", len); + } + function caml_ml_bytes_length(s){return s.l;} + function caml_blit_bytes(s1, i1, s2, i2, len){ + if(len == 0) return 0; + if(i2 == 0 && (len >= s2.l || s2.t == 2 && len >= s2.c.length)){ + s2.c = + s1.t == 4 + ? caml_subarray_to_jsbytes(s1.c, i1, len) + : i1 == 0 && s1.c.length == len ? s1.c : s1.c.substr(i1, len); + s2.t = s2.c.length == s2.l ? 0 : 2; + } + else if(s2.t == 2 && i2 == s2.c.length){ + s2.c += + s1.t == 4 + ? caml_subarray_to_jsbytes(s1.c, i1, len) + : i1 == 0 && s1.c.length == len ? s1.c : s1.c.substr(i1, len); + s2.t = s2.c.length == s2.l ? 0 : 2; + } + else{ + if(s2.t != 4) caml_convert_bytes_to_array(s2); + var c1 = s1.c, c2 = s2.c; + if(s1.t == 4) + if(i2 <= i1) + for(var i = 0; i < len; i++) c2[i2 + i] = c1[i1 + i]; + else + for(var i = len - 1; i >= 0; i--) c2[i2 + i] = c1[i1 + i]; + else{ + var l = Math.min(len, c1.length - i1); + for(var i = 0; i < l; i++) c2[i2 + i] = c1.charCodeAt(i1 + i); + for(; i < len; i++) c2[i2 + i] = 0; + } + } + return 0; + } + function MlFile(){} + function MlFakeFile(content){this.data = content;} + MlFakeFile.prototype = new MlFile(); + MlFakeFile.prototype.constructor = MlFakeFile; + MlFakeFile.prototype.truncate = + function(len){ + var old = this.data; + this.data = caml_create_bytes(len | 0); + caml_blit_bytes(old, 0, this.data, 0, len); + }; + MlFakeFile.prototype.length = + function(){return caml_ml_bytes_length(this.data);}; + MlFakeFile.prototype.write = + function(offset, buf, pos, len){ + var clen = this.length(); + if(offset + len >= clen){ + var new_str = caml_create_bytes(offset + len), old_data = this.data; + this.data = new_str; + caml_blit_bytes(old_data, 0, this.data, 0, clen); + } + caml_blit_bytes(caml_bytes_of_array(buf), pos, this.data, offset, len); + return 0; + }; + MlFakeFile.prototype.read = + function(offset, buf, pos, len){ + var clen = this.length(); + if(offset + len >= clen) len = clen - offset; + if(len){ + var data = caml_create_bytes(len | 0); + caml_blit_bytes(this.data, offset, data, 0, len); + buf.set(caml_uint8_array_of_bytes(data), pos); + } + return len; + }; + function MlFakeFd(name, file, flags){ + this.file = file; + this.name = name; + this.flags = flags; + } + MlFakeFd.prototype.err_closed = + function(){ + caml_raise_sys_error(this.name + ": file descriptor already closed"); + }; + MlFakeFd.prototype.length = + function(){if(this.file) return this.file.length(); this.err_closed();}; + MlFakeFd.prototype.write = + function(offset, buf, pos, len){ + if(this.file) return this.file.write(offset, buf, pos, len); + this.err_closed(); + }; + MlFakeFd.prototype.read = + function(offset, buf, pos, len){ + if(this.file) return this.file.read(offset, buf, pos, len); + this.err_closed(); + }; + MlFakeFd.prototype.close = function(){this.file = undefined;}; + function MlFakeDevice(root, f){ + this.content = {}; + this.root = root; + this.lookupFun = f; + } + MlFakeDevice.prototype.nm = function(name){return this.root + name;}; + MlFakeDevice.prototype.create_dir_if_needed = + function(name){ + var comp = name.split("/"), res = ""; + for(var i = 0; i < comp.length - 1; i++){ + res += comp[i] + "/"; + if(this.content[res]) continue; + this.content[res] = Symbol("directory"); + } + }; + MlFakeDevice.prototype.slash = + function(name){return /\/$/.test(name) ? name : name + "/";}; + MlFakeDevice.prototype.lookup = + function(name){ + if(! this.content[name] && this.lookupFun){ + var + res = + this.lookupFun + (caml_string_of_jsbytes(this.root), caml_string_of_jsbytes(name)); + if(res !== 0){ + this.create_dir_if_needed(name); + this.content[name] = new MlFakeFile(caml_bytes_of_string(res[1])); + } + } + }; + MlFakeDevice.prototype.exists = + function(name){ + if(name == "") return 1; + var name_slash = this.slash(name); + if(this.content[name_slash]) return 1; + this.lookup(name); + return this.content[name] ? 1 : 0; + }; + MlFakeDevice.prototype.isFile = + function(name){return this.exists(name) && ! this.is_dir(name) ? 1 : 0;}; + MlFakeDevice.prototype.mkdir = + function(name, mode, raise_unix){ + var unix_error = raise_unix && caml_named_value("Unix.Unix_error"); + if(this.exists(name)) + if(unix_error) + caml_raise_with_args + (unix_error, make_unix_err_args("EEXIST", "mkdir", this.nm(name))); + else + caml_raise_sys_error(name + ": File exists"); + var parent = /^(.*)\/[^/]+/.exec(name); + parent = parent && parent[1] || ""; + if(! this.exists(parent)) + if(unix_error) + caml_raise_with_args + (unix_error, make_unix_err_args("ENOENT", "mkdir", this.nm(parent))); + else + caml_raise_sys_error(parent + ": No such file or directory"); + if(! this.is_dir(parent)) + if(unix_error) + caml_raise_with_args + (unix_error, make_unix_err_args("ENOTDIR", "mkdir", this.nm(parent))); + else + caml_raise_sys_error(parent + ": Not a directory"); + this.create_dir_if_needed(this.slash(name)); + }; + MlFakeDevice.prototype.rmdir = + function(name, raise_unix){ + var + unix_error = raise_unix && caml_named_value("Unix.Unix_error"), + name_slash = name == "" ? "" : this.slash(name), + r = new RegExp("^" + name_slash + "([^/]+)"); + if(! this.exists(name)) + if(unix_error) + caml_raise_with_args + (unix_error, make_unix_err_args("ENOENT", "rmdir", this.nm(name))); + else + caml_raise_sys_error(name + ": No such file or directory"); + if(! this.is_dir(name)) + if(unix_error) + caml_raise_with_args + (unix_error, make_unix_err_args("ENOTDIR", "rmdir", this.nm(name))); + else + caml_raise_sys_error(name + ": Not a directory"); + for(var n in this.content) + if(n.match(r)) + if(unix_error) + caml_raise_with_args + (unix_error, make_unix_err_args("ENOTEMPTY", "rmdir", this.nm(name))); + else + caml_raise_sys_error(this.nm(name) + ": Directory not empty"); + delete this.content[name_slash]; + }; + MlFakeDevice.prototype.readdir = + function(name){ + var name_slash = name == "" ? "" : this.slash(name); + if(! this.exists(name)) + caml_raise_sys_error(name + ": No such file or directory"); + if(! this.is_dir(name)) caml_raise_sys_error(name + ": Not a directory"); + var r = new RegExp("^" + name_slash + "([^/]+)"), seen = {}, a = []; + for(var n in this.content){ + var m = n.match(r); + if(m && ! seen[m[1]]){seen[m[1]] = true; a.push(m[1]);} + } + return a; + }; + MlFakeDevice.prototype.opendir = + function(name, raise_unix){ + var + unix_error = raise_unix && caml_named_value("Unix.Unix_error"), + a = this.readdir(name), + c = false, + i = 0; + return {readSync: + function(){ + if(c) + if(unix_error) + caml_raise_with_args + (unix_error, + make_unix_err_args("EBADF", "closedir", this.nm(name))); + else + caml_raise_sys_error(name + ": closedir failed"); + if(i == a.length) return null; + var entry = a[i]; + i++; + return {name: entry}; + }, + closeSync: + function(){ + if(c) + if(unix_error) + caml_raise_with_args + (unix_error, + make_unix_err_args("EBADF", "closedir", this.nm(name))); + else + caml_raise_sys_error(name + ": closedir failed"); + c = true; + a = []; + }}; + }; + MlFakeDevice.prototype.is_dir = + function(name){ + if(name == "") return true; + var name_slash = this.slash(name); + return this.content[name_slash] ? 1 : 0; + }; + MlFakeDevice.prototype.unlink = + function(name){ + var ok = this.content[name] ? true : false; + delete this.content[name]; + return ok; + }; + MlFakeDevice.prototype.open = + function(name, f){ + var file; + if(f.rdonly && f.wronly) + caml_raise_sys_error + (this.nm(name) + + " : flags Open_rdonly and Open_wronly are not compatible"); + if(f.text && f.binary) + caml_raise_sys_error + (this.nm(name) + + " : flags Open_text and Open_binary are not compatible"); + this.lookup(name); + if(this.content[name]){ + if(this.is_dir(name)) + caml_raise_sys_error(this.nm(name) + " : is a directory"); + if(f.create && f.excl) + caml_raise_sys_error(this.nm(name) + " : file already exists"); + file = this.content[name]; + if(f.truncate) file.truncate(); + } + else if(f.create){ + this.create_dir_if_needed(name); + this.content[name] = new MlFakeFile(caml_create_bytes(0)); + file = this.content[name]; + } + else + caml_raise_no_such_file(this.nm(name)); + return new MlFakeFd(this.nm(name), file, f); + }; + MlFakeDevice.prototype.open = + function(name, f){ + var file; + if(f.rdonly && f.wronly) + caml_raise_sys_error + (this.nm(name) + + " : flags Open_rdonly and Open_wronly are not compatible"); + if(f.text && f.binary) + caml_raise_sys_error + (this.nm(name) + + " : flags Open_text and Open_binary are not compatible"); + this.lookup(name); + if(this.content[name]){ + if(this.is_dir(name)) + caml_raise_sys_error(this.nm(name) + " : is a directory"); + if(f.create && f.excl) + caml_raise_sys_error(this.nm(name) + " : file already exists"); + file = this.content[name]; + if(f.truncate) file.truncate(); + } + else if(f.create){ + this.create_dir_if_needed(name); + this.content[name] = new MlFakeFile(caml_create_bytes(0)); + file = this.content[name]; + } + else + caml_raise_no_such_file(this.nm(name)); + return new MlFakeFd(this.nm(name), file, f); + }; + MlFakeDevice.prototype.register = + function(name, content){ + var file; + if(this.content[name]) + caml_raise_sys_error(this.nm(name) + " : file already exists"); + if(caml_is_ml_bytes(content)) file = new MlFakeFile(content); + if(caml_is_ml_string(content)) + file = new MlFakeFile(caml_bytes_of_string(content)); + else if(content instanceof Array) + file = new MlFakeFile(caml_bytes_of_array(content)); + else if(typeof content === "string") + file = new MlFakeFile(caml_bytes_of_jsbytes(content)); + else if(content.toString){ + var + bytes = + caml_bytes_of_string(caml_string_of_jsstring(content.toString())); + file = new MlFakeFile(bytes); + } + if(file){ + this.create_dir_if_needed(name); + this.content[name] = file; + } + else + caml_raise_sys_error + (this.nm(name) + " : registering file with invalid content type"); + }; + MlFakeDevice.prototype.constructor = MlFakeDevice; + function MlFakeFd_out(fd, flags){ + MlFakeFile.call(this, caml_create_bytes(0)); + this.log = function(s){return 0;}; + if(fd == 1 && typeof console.log == "function") + this.log = console.log; + else if(fd == 2 && typeof console.error == "function") + this.log = console.error; + else if(typeof console.log == "function") this.log = console.log; + this.flags = flags; + } + MlFakeFd_out.prototype.length = function(){return 0;}; + MlFakeFd_out.prototype.write = + function(offset, buf, pos, len){ + if(this.log){ + if + (len > 0 && pos >= 0 && pos + len <= buf.length + && buf[pos + len - 1] == 10) + len--; + var src = caml_create_bytes(len); + caml_blit_bytes(caml_bytes_of_array(buf), pos, src, 0, len); + this.log(src.toUtf16()); + return 0; + } + caml_raise_sys_error(this.fd + ": file descriptor already closed"); + }; + MlFakeFd_out.prototype.read = + function(offset, buf, pos, len){ + caml_raise_sys_error(this.fd + ": file descriptor is write only"); + }; + MlFakeFd_out.prototype.close = function(){this.log = undefined;}; + var caml_int64_offset = Math.pow(2, - 24); + function caml_raise_constant(tag){throw tag;} + function caml_raise_zero_divide(){ + caml_raise_constant(caml_global_data.Division_by_zero); + } + function MlInt64(lo, mi, hi){ + this.lo = lo & 0xffffff; + this.mi = mi & 0xffffff; + this.hi = hi & 0xffff; + } + MlInt64.prototype.caml_custom = "_j"; + MlInt64.prototype.copy = + function(){return new MlInt64(this.lo, this.mi, this.hi);}; + MlInt64.prototype.ucompare = + function(x){ + if(this.hi > x.hi) return 1; + if(this.hi < x.hi) return - 1; + if(this.mi > x.mi) return 1; + if(this.mi < x.mi) return - 1; + if(this.lo > x.lo) return 1; + if(this.lo < x.lo) return - 1; + return 0; + }; + MlInt64.prototype.compare = + function(x){ + var hi = this.hi << 16, xhi = x.hi << 16; + if(hi > xhi) return 1; + if(hi < xhi) return - 1; + if(this.mi > x.mi) return 1; + if(this.mi < x.mi) return - 1; + if(this.lo > x.lo) return 1; + if(this.lo < x.lo) return - 1; + return 0; + }; + MlInt64.prototype.neg = + function(){ + var + lo = - this.lo, + mi = - this.mi + (lo >> 24), + hi = - this.hi + (mi >> 24); + return new MlInt64(lo, mi, hi); + }; + MlInt64.prototype.add = + function(x){ + var + lo = this.lo + x.lo, + mi = this.mi + x.mi + (lo >> 24), + hi = this.hi + x.hi + (mi >> 24); + return new MlInt64(lo, mi, hi); + }; + MlInt64.prototype.sub = + function(x){ + var + lo = this.lo - x.lo, + mi = this.mi - x.mi + (lo >> 24), + hi = this.hi - x.hi + (mi >> 24); + return new MlInt64(lo, mi, hi); + }; + MlInt64.prototype.mul = + function(x){ + var + lo = this.lo * x.lo, + mi = (lo * caml_int64_offset | 0) + this.mi * x.lo + this.lo * x.mi, + hi = + (mi * caml_int64_offset | 0) + this.hi * x.lo + this.mi * x.mi + + this.lo * x.hi; + return new MlInt64(lo, mi, hi); + }; + MlInt64.prototype.isZero = + function(){return (this.lo | this.mi | this.hi) == 0;}; + MlInt64.prototype.isNeg = function(){return this.hi << 16 < 0;}; + MlInt64.prototype.and = + function(x){ + return new MlInt64(this.lo & x.lo, this.mi & x.mi, this.hi & x.hi); + }; + MlInt64.prototype.or = + function(x){ + return new MlInt64(this.lo | x.lo, this.mi | x.mi, this.hi | x.hi); + }; + MlInt64.prototype.xor = + function(x){ + return new MlInt64(this.lo ^ x.lo, this.mi ^ x.mi, this.hi ^ x.hi); + }; + MlInt64.prototype.shift_left = + function(s){ + s = s & 63; + if(s == 0) return this; + if(s < 24) + return new + MlInt64 + (this.lo << s, + this.mi << s | this.lo >> 24 - s, + this.hi << s | this.mi >> 24 - s); + if(s < 48) + return new + MlInt64 + (0, this.lo << s - 24, this.mi << s - 24 | this.lo >> 48 - s); + return new MlInt64(0, 0, this.lo << s - 48); + }; + MlInt64.prototype.shift_right_unsigned = + function(s){ + s = s & 63; + if(s == 0) return this; + if(s < 24) + return new + MlInt64 + (this.lo >> s | this.mi << 24 - s, + this.mi >> s | this.hi << 24 - s, + this.hi >> s); + if(s < 48) + return new + MlInt64 + (this.mi >> s - 24 | this.hi << 48 - s, this.hi >> s - 24, 0); + return new MlInt64(this.hi >> s - 48, 0, 0); + }; + MlInt64.prototype.shift_right = + function(s){ + s = s & 63; + if(s == 0) return this; + var h = this.hi << 16 >> 16; + if(s < 24) + return new + MlInt64 + (this.lo >> s | this.mi << 24 - s, + this.mi >> s | h << 24 - s, + this.hi << 16 >> s >>> 16); + var sign = this.hi << 16 >> 31; + if(s < 48) + return new + MlInt64 + (this.mi >> s - 24 | this.hi << 48 - s, + this.hi << 16 >> s - 24 >> 16, + sign & 0xffff); + return new MlInt64(this.hi << 16 >> s - 32, sign, sign); + }; + MlInt64.prototype.lsl1 = + function(){ + this.hi = this.hi << 1 | this.mi >> 23; + this.mi = (this.mi << 1 | this.lo >> 23) & 0xffffff; + this.lo = this.lo << 1 & 0xffffff; + }; + MlInt64.prototype.lsr1 = + function(){ + this.lo = (this.lo >>> 1 | this.mi << 23) & 0xffffff; + this.mi = (this.mi >>> 1 | this.hi << 23) & 0xffffff; + this.hi = this.hi >>> 1; + }; + MlInt64.prototype.udivmod = + function(x){ + var + offset = 0, + modulus = this.copy(), + divisor = x.copy(), + quotient = new MlInt64(0, 0, 0); + while(modulus.ucompare(divisor) > 0){offset++; divisor.lsl1();} + while(offset >= 0){ + offset--; + quotient.lsl1(); + if(modulus.ucompare(divisor) >= 0){ + quotient.lo++; + modulus = modulus.sub(divisor); + } + divisor.lsr1(); + } + return {quotient: quotient, modulus: modulus}; + }; + MlInt64.prototype.div = + function(y){ + var x = this; + if(y.isZero()) caml_raise_zero_divide(); + var sign = x.hi ^ y.hi; + if(x.hi & 0x8000) x = x.neg(); + if(y.hi & 0x8000) y = y.neg(); + var q = x.udivmod(y).quotient; + if(sign & 0x8000) q = q.neg(); + return q; + }; + MlInt64.prototype.mod = + function(y){ + var x = this; + if(y.isZero()) caml_raise_zero_divide(); + var sign = x.hi; + if(x.hi & 0x8000) x = x.neg(); + if(y.hi & 0x8000) y = y.neg(); + var r = x.udivmod(y).modulus; + if(sign & 0x8000) r = r.neg(); + return r; + }; + MlInt64.prototype.toInt = function(){return this.lo | this.mi << 24;}; + MlInt64.prototype.toFloat = + function(){ + return (this.hi << 16) * Math.pow(2, 32) + this.mi * Math.pow(2, 24) + + this.lo; + }; + MlInt64.prototype.toArray = + function(){ + return [this.hi >> 8, + this.hi & 0xff, + this.mi >> 16, + this.mi >> 8 & 0xff, + this.mi & 0xff, + this.lo >> 16, + this.lo >> 8 & 0xff, + this.lo & 0xff]; + }; + MlInt64.prototype.lo32 = + function(){return this.lo | (this.mi & 0xff) << 24;}; + MlInt64.prototype.hi32 = + function(){return this.mi >>> 8 & 0xffff | this.hi << 16;}; + function MlMutex(){this.locked = false;} + function MlNat(x){ + this.data = new Int32Array(x); + this.length = this.data.length + 2; + } + MlNat.prototype.caml_custom = "_nat"; + function caml_ml_string_length(s){return s.length;} + function caml_string_unsafe_get(s, i){return s.charCodeAt(i);} + function caml_uint8_array_of_string(s){ + var l = caml_ml_string_length(s), a = new Uint8Array(l), i = 0; + for(; i < l; i++) a[i] = caml_string_unsafe_get(s, i); + return a; + } + function caml_bytes_bound_error(){ + caml_invalid_argument("index out of bounds"); + } + function caml_bytes_unsafe_set(s, i, c){ + c &= 0xff; + if(s.t != 4){ + if(i == s.c.length){ + s.c += String.fromCharCode(c); + if(i + 1 == s.l) s.t = 0; + return 0; + } + caml_convert_bytes_to_array(s); + } + s.c[i] = c; + return 0; + } + function caml_bytes_set(s, i, c){ + if(i >>> 0 >= s.l) caml_bytes_bound_error(); + return caml_bytes_unsafe_set(s, i, c); + } + function MlNodeFd(fd, flags){ + this.fs = require("fs"); + this.fd = fd; + this.flags = flags; + } + MlNodeFd.prototype = new MlFile(); + MlNodeFd.prototype.constructor = MlNodeFd; + MlNodeFd.prototype.truncate = + function(len){ + try{this.fs.ftruncateSync(this.fd, len | 0);} + catch(err){caml_raise_sys_error(err.toString());} + }; + MlNodeFd.prototype.length = + function(){ + try{return this.fs.fstatSync(this.fd).size;} + catch(err){caml_raise_sys_error(err.toString());} + }; + MlNodeFd.prototype.write = + function(offset, buf, buf_offset, len){ + try{ + if(this.flags.isCharacterDevice) + this.fs.writeSync(this.fd, buf, buf_offset, len); + else + this.fs.writeSync(this.fd, buf, buf_offset, len, offset); + } + catch(err){caml_raise_sys_error(err.toString());} + return 0; + }; + MlNodeFd.prototype.read = + function(offset, a, buf_offset, len){ + try{ + if(this.flags.isCharacterDevice) + var read = this.fs.readSync(this.fd, a, buf_offset, len); + else + var read = this.fs.readSync(this.fd, a, buf_offset, len, offset); + return read; + } + catch(err){caml_raise_sys_error(err.toString());} + }; + MlNodeFd.prototype.close = + function(){ + try{this.fs.closeSync(this.fd); return 0;} + catch(err){caml_raise_sys_error(err.toString());} + }; + function MlNodeDevice(root){this.fs = require("fs"); this.root = root;} + MlNodeDevice.prototype.nm = function(name){return this.root + name;}; + MlNodeDevice.prototype.exists = + function(name){ + try{return this.fs.existsSync(this.nm(name)) ? 1 : 0;} + catch(err){return 0;} + }; + MlNodeDevice.prototype.isFile = + function(name){ + try{return this.fs.statSync(this.nm(name)).isFile() ? 1 : 0;} + catch(err){caml_raise_sys_error(err.toString());} + }; + MlNodeDevice.prototype.mkdir = + function(name, mode, raise_unix){ + try{this.fs.mkdirSync(this.nm(name), {mode: mode}); return 0;} + catch(err){this.raise_nodejs_error(err, raise_unix);} + }; + MlNodeDevice.prototype.rmdir = + function(name, raise_unix){ + try{this.fs.rmdirSync(this.nm(name)); return 0;} + catch(err){this.raise_nodejs_error(err, raise_unix);} + }; + MlNodeDevice.prototype.readdir = + function(name, raise_unix){ + try{return this.fs.readdirSync(this.nm(name));} + catch(err){this.raise_nodejs_error(err, raise_unix);} + }; + MlNodeDevice.prototype.is_dir = + function(name){ + try{return this.fs.statSync(this.nm(name)).isDirectory() ? 1 : 0;} + catch(err){caml_raise_sys_error(err.toString());} + }; + MlNodeDevice.prototype.unlink = + function(name, raise_unix){ + try{ + var b = this.fs.existsSync(this.nm(name)) ? 1 : 0; + this.fs.unlinkSync(this.nm(name)); + return b; + } + catch(err){this.raise_nodejs_error(err, raise_unix);} + }; + MlNodeDevice.prototype.open = + function(name, f, raise_unix){ + var consts = require("constants"), res = 0; + for(var key in f) + switch(key){ + case "rdonly": + res |= consts.O_RDONLY; break; + case "wronly": + res |= consts.O_WRONLY; break; + case "append": + res |= consts.O_WRONLY | consts.O_APPEND; break; + case "create": + res |= consts.O_CREAT; break; + case "truncate": + res |= consts.O_TRUNC; break; + case "excl": + res |= consts.O_EXCL; break; + case "binary": + res |= consts.O_BINARY; break; + case "text": + res |= consts.O_TEXT; break; + case "nonblock": + res |= consts.O_NONBLOCK; break; + } + try{ + var + fd = this.fs.openSync(this.nm(name), res), + isCharacterDevice = + this.fs.lstatSync(this.nm(name)).isCharacterDevice(); + f.isCharacterDevice = isCharacterDevice; + return new MlNodeFd(fd, f); + } + catch(err){this.raise_nodejs_error(err, raise_unix);} + }; + MlNodeDevice.prototype.rename = + function(o, n, raise_unix){ + try{this.fs.renameSync(this.nm(o), this.nm(n));} + catch(err){this.raise_nodejs_error(err, raise_unix);} + }; + MlNodeDevice.prototype.stat = + function(name, raise_unix){ + try{ + var js_stats = this.fs.statSync(this.nm(name)); + return this.stats_from_js(js_stats); + } + catch(err){this.raise_nodejs_error(err, raise_unix);} + }; + MlNodeDevice.prototype.lstat = + function(name, raise_unix){ + try{ + var js_stats = this.fs.lstatSync(this.nm(name)); + return this.stats_from_js(js_stats); + } + catch(err){this.raise_nodejs_error(err, raise_unix);} + }; + MlNodeDevice.prototype.symlink = + function(to_dir, target, path, raise_unix){ + try{ + this.fs.symlinkSync + (this.nm(target), this.nm(path), to_dir ? "dir" : "file"); + return 0; + } + catch(err){this.raise_nodejs_error(err, raise_unix);} + }; + MlNodeDevice.prototype.readlink = + function(name, raise_unix){ + try{ + var link = this.fs.readlinkSync(this.nm(name), "utf8"); + return caml_string_of_jsstring(link); + } + catch(err){this.raise_nodejs_error(err, raise_unix);} + }; + MlNodeDevice.prototype.opendir = + function(name, raise_unix){ + try{return this.fs.opendirSync(this.nm(name));} + catch(err){this.raise_nodejs_error(err, raise_unix);} + }; + MlNodeDevice.prototype.raise_nodejs_error = + function(err, raise_unix){ + var unix_error = caml_named_value("Unix.Unix_error"); + if(raise_unix && unix_error){ + var + args = make_unix_err_args(err.code, err.syscall, err.path, err.errno); + caml_raise_with_args(unix_error, args); + } + else + caml_raise_sys_error(err.toString()); + }; + MlNodeDevice.prototype.stats_from_js = + function(js_stats){ + var file_kind; + if(js_stats.isFile()) + file_kind = 0; + else if(js_stats.isDirectory()) + file_kind = 1; + else if(js_stats.isCharacterDevice()) + file_kind = 2; + else if(js_stats.isBlockDevice()) + file_kind = 3; + else if(js_stats.isSymbolicLink()) + file_kind = 4; + else if(js_stats.isFIFO()) + file_kind = 5; + else if(js_stats.isSocket()) file_kind = 6; + return [0, + js_stats.dev, + js_stats.ino, + file_kind, + js_stats.mode, + js_stats.nlink, + js_stats.uid, + js_stats.gid, + js_stats.rdev, + js_stats.size, + js_stats.atimeMs, + js_stats.mtimeMs, + js_stats.ctimeMs]; + }; + MlNodeDevice.prototype.constructor = MlNodeDevice; + var MlObjectTable; + if(typeof globalThis.Map === "undefined") + MlObjectTable = + function(){ + function NaiveLookup(objs){this.objs = objs;} + NaiveLookup.prototype.get = + function(v){ + for(var i = 0; i < this.objs.length; i++) + if(this.objs[i] === v) return i; + }; + NaiveLookup.prototype.set = function(){}; + return function(){ + this.objs = []; + this.lookup = new NaiveLookup(this.objs);}; + } + (); + else + MlObjectTable = + function(){this.objs = []; this.lookup = new globalThis.Map();}; + MlObjectTable.prototype.store = + function(v){this.lookup.set(v, this.objs.length); this.objs.push(v);}; + MlObjectTable.prototype.recall = + function(v){ + var i = this.lookup.get(v); + return i === undefined ? undefined : this.objs.length - i; + }; + function MlStringReader(s, i){ + this.s = caml_jsbytes_of_string(s); + this.i = i; + } + MlStringReader.prototype = + {read8u: function(){return this.s.charCodeAt(this.i++);}, + read8s: function(){return this.s.charCodeAt(this.i++) << 24 >> 24;}, + read16u: + function(){ + var s = this.s, i = this.i; + this.i = i + 2; + return s.charCodeAt(i) << 8 | s.charCodeAt(i + 1); + }, + read16s: + function(){ + var s = this.s, i = this.i; + this.i = i + 2; + return s.charCodeAt(i) << 24 >> 16 | s.charCodeAt(i + 1); + }, + read32u: + function(){ + var s = this.s, i = this.i; + this.i = i + 4; + return (s.charCodeAt(i) << 24 | s.charCodeAt(i + 1) << 16 + | s.charCodeAt(i + 2) << 8 + | s.charCodeAt(i + 3)) + >>> 0; + }, + read32s: + function(){ + var s = this.s, i = this.i; + this.i = i + 4; + return s.charCodeAt(i) << 24 | s.charCodeAt(i + 1) << 16 + | s.charCodeAt(i + 2) << 8 + | s.charCodeAt(i + 3); + }, + readstr: + function(len){ + var i = this.i; + this.i = i + len; + return caml_string_of_jsbytes(this.s.substring(i, i + len)); + }, + readuint8array: + function(len){ + var b = new Uint8Array(len), s = this.s, i = this.i; + for(var j = 0; j < len; j++) b[j] = s.charCodeAt(i + j); + this.i = i + len; + return b; + }}; + function caml_int64_create_lo_hi(lo, hi){ + return new + MlInt64 + (lo & 0xffffff, + lo >>> 24 & 0xff | (hi & 0xffff) << 8, + hi >>> 16 & 0xffff); + } + function caml_int64_hi32(v){return v.hi32();} + function caml_int64_lo32(v){return v.lo32();} + function caml_array_bound_error(){ + caml_invalid_argument("index out of bounds"); + } + var caml_ba_custom_name = "_bigarr02"; + function Ml_Bigarray(kind, layout, dims, buffer){ + this.kind = kind; + this.layout = layout; + this.dims = dims; + this.data = buffer; + } + Ml_Bigarray.prototype.caml_custom = caml_ba_custom_name; + Ml_Bigarray.prototype.offset = + function(arg){ + var ofs = 0; + if(typeof arg === "number") arg = [arg]; + if(! (arg instanceof Array)) + caml_invalid_argument("bigarray.js: invalid offset"); + if(this.dims.length != arg.length) + caml_invalid_argument("Bigarray.get/set: bad number of dimensions"); + if(this.layout == 0) + for(var i = 0; i < this.dims.length; i++){ + if(arg[i] < 0 || arg[i] >= this.dims[i]) caml_array_bound_error(); + ofs = ofs * this.dims[i] + arg[i]; + } + else + for(var i = this.dims.length - 1; i >= 0; i--){ + if(arg[i] < 1 || arg[i] > this.dims[i]) caml_array_bound_error(); + ofs = ofs * this.dims[i] + (arg[i] - 1); + } + return ofs; + }; + Ml_Bigarray.prototype.get = + function(ofs){ + switch(this.kind){ + case 7: + var l = this.data[ofs * 2 + 0], h = this.data[ofs * 2 + 1]; + return caml_int64_create_lo_hi(l, h); + case 10: + case 11: + var r = this.data[ofs * 2 + 0], i = this.data[ofs * 2 + 1]; + return [254, r, i]; + default: return this.data[ofs]; + } + }; + Ml_Bigarray.prototype.set = + function(ofs, v){ + switch(this.kind){ + case 7: + this.data[ofs * 2 + 0] = caml_int64_lo32(v); + this.data[ofs * 2 + 1] = caml_int64_hi32(v); + break; + case 10: + case 11: + this.data[ofs * 2 + 0] = v[1]; this.data[ofs * 2 + 1] = v[2]; break; + default: this.data[ofs] = v; break; + } + return 0; + }; + Ml_Bigarray.prototype.fill = + function(v){ + switch(this.kind){ + case 7: + var a = caml_int64_lo32(v), b = caml_int64_hi32(v); + if(a == b) + this.data.fill(a); + else + for(var i = 0; i < this.data.length; i++) + this.data[i] = i % 2 == 0 ? a : b; + break; + case 10: + case 11: + var im = v[1], re = v[2]; + if(im == re) + this.data.fill(im); + else + for(var i = 0; i < this.data.length; i++) + this.data[i] = i % 2 == 0 ? im : re; + break; + default: this.data.fill(v); break; + } + }; + Ml_Bigarray.prototype.compare = + function(b, total){ + if(this.layout != b.layout || this.kind != b.kind){ + var k1 = this.kind | this.layout << 8, k2 = b.kind | b.layout << 8; + return k2 - k1; + } + if(this.dims.length != b.dims.length) + return b.dims.length - this.dims.length; + for(var i = 0; i < this.dims.length; i++) + if(this.dims[i] != b.dims[i]) return this.dims[i] < b.dims[i] ? - 1 : 1; + switch(this.kind){ + case 0: + case 1: + case 10: + case 11: + var x, y; + for(var i = 0; i < this.data.length; i++){ + x = this.data[i]; + y = b.data[i]; + if(x < y) return - 1; + if(x > y) return 1; + if(x != y){ + if(! total) return NaN; + if(x == x) return 1; + if(y == y) return - 1; + } + } + break; + case 7: + for(var i = 0; i < this.data.length; i += 2){ + if(this.data[i + 1] < b.data[i + 1]) return - 1; + if(this.data[i + 1] > b.data[i + 1]) return 1; + if(this.data[i] >>> 0 < b.data[i] >>> 0) return - 1; + if(this.data[i] >>> 0 > b.data[i] >>> 0) return 1; + } + break; + case 2: + case 3: + case 4: + case 5: + case 6: + case 8: + case 9: + case 12: + for(var i = 0; i < this.data.length; i++){ + if(this.data[i] < b.data[i]) return - 1; + if(this.data[i] > b.data[i]) return 1; + } + break; + } + return 0; + }; + function Ml_Bigarray_c_1_1(kind, layout, dims, buffer){ + this.kind = kind; + this.layout = layout; + this.dims = dims; + this.data = buffer; + } + Ml_Bigarray_c_1_1.prototype = new Ml_Bigarray(); + Ml_Bigarray_c_1_1.prototype.offset = + function(arg){ + if(typeof arg !== "number") + if(arg instanceof Array && arg.length == 1) + arg = arg[0]; + else + caml_invalid_argument("Ml_Bigarray_c_1_1.offset"); + if(arg < 0 || arg >= this.dims[0]) caml_array_bound_error(); + return arg; + }; + Ml_Bigarray_c_1_1.prototype.get = function(ofs){return this.data[ofs];}; + Ml_Bigarray_c_1_1.prototype.set = + function(ofs, v){this.data[ofs] = v; return 0;}; + Ml_Bigarray_c_1_1.prototype.fill = + function(v){this.data.fill(v); return 0;}; + function UInt8ArrayReader(s, i){this.s = s; this.i = i;} + UInt8ArrayReader.prototype = + {read8u: function(){return this.s[this.i++];}, + read8s: function(){return this.s[this.i++] << 24 >> 24;}, + read16u: + function(){ + var s = this.s, i = this.i; + this.i = i + 2; + return s[i] << 8 | s[i + 1]; + }, + read16s: + function(){ + var s = this.s, i = this.i; + this.i = i + 2; + return s[i] << 24 >> 16 | s[i + 1]; + }, + read32u: + function(){ + var s = this.s, i = this.i; + this.i = i + 4; + return (s[i] << 24 | s[i + 1] << 16 | s[i + 2] << 8 | s[i + 3]) >>> 0; + }, + read32s: + function(){ + var s = this.s, i = this.i; + this.i = i + 4; + return s[i] << 24 | s[i + 1] << 16 | s[i + 2] << 8 | s[i + 3]; + }, + readstr: + function(len){ + var i = this.i; + this.i = i + len; + return caml_string_of_array(this.s.subarray(i, i + len)); + }, + readuint8array: + function(len){ + var i = this.i; + this.i = i + len; + return this.s.subarray(i, i + len); + }}; + function incr_nat(nat, ofs, len, carry_in){ + var carry = carry_in; + for(var i = 0; i < len; i++){ + var x = (nat.data[ofs + i] >>> 0) + carry; + nat.data[ofs + i] = x | 0; + if(x == x >>> 0){carry = 0; break;} else carry = 1; + } + return carry; + } + function add_nat(nat1, ofs1, len1, nat2, ofs2, len2, carry_in){ + var carry = carry_in; + for(var i = 0; i < len2; i++){ + var + x = (nat1.data[ofs1 + i] >>> 0) + (nat2.data[ofs2 + i] >>> 0) + carry; + nat1.data[ofs1 + i] = x; + if(x == x >>> 0) carry = 0; else carry = 1; + } + return incr_nat(nat1, ofs1 + len2, len1 - len2, carry); + } + function caml_ba_get_size(dims){ + var n_dims = dims.length, size = 1; + for(var i = 0; i < n_dims; i++){ + if(dims[i] < 0) + caml_invalid_argument("Bigarray.create: negative dimension"); + size = size * dims[i]; + } + return size; + } + function caml_ba_get_size_per_element(kind){ + switch(kind){case 7:case 10:case 11: return 2;default: return 1; + } + } + function caml_ba_create_unsafe(kind, layout, dims, data){ + var size_per_element = caml_ba_get_size_per_element(kind); + if(caml_ba_get_size(dims) * size_per_element != data.length) + caml_invalid_argument("length doesn't match dims"); + if(layout == 0 && dims.length == 1 && size_per_element == 1) + return new Ml_Bigarray_c_1_1(kind, layout, dims, data); + return new Ml_Bigarray(kind, layout, dims, data); + } + function bigstring_of_array_buffer(ab){ + var ta = new Uint8Array(ab); + return caml_ba_create_unsafe(12, 0, [ta.length], ta); + } + function bigstring_of_typed_array(ba){ + var + ta = + new + Uint8Array + (ba.buffer, ba.byteOffset, ba.length * ba.BYTES_PER_ELEMENT); + return caml_ba_create_unsafe(12, 0, [ta.length], ta); + } + function bigstring_to_array_buffer(bs){return bs.data.buffer;} + function bigstring_to_typed_array(bs){return bs.data;} + function caml_bigstring_blit_string_to_ba(str1, pos1, ba2, pos2, len){ + if(12 != ba2.kind) + caml_invalid_argument("caml_bigstring_blit_string_to_ba: kind mismatch"); + if(len == 0) return 0; + var ofs2 = ba2.offset(pos2); + if(pos1 + len > caml_ml_string_length(str1)) caml_array_bound_error(); + if(ofs2 + len > ba2.data.length) caml_array_bound_error(); + var slice = caml_uint8_array_of_string(str1).slice(pos1, pos1 + len); + ba2.data.set(slice, ofs2); + return 0; + } + function bigstringaf_blit_from_bytes(src, src_off, dst, dst_off, len){ + return caml_bigstring_blit_string_to_ba(src, src_off, dst, dst_off, len); + } + function caml_bigstring_blit_ba_to_ba(ba1, pos1, ba2, pos2, len){ + if(12 != ba1.kind) + caml_invalid_argument("caml_bigstring_blit_ba_to_ba: kind mismatch"); + if(12 != ba2.kind) + caml_invalid_argument("caml_bigstring_blit_ba_to_ba: kind mismatch"); + if(len == 0) return 0; + var ofs1 = ba1.offset(pos1), ofs2 = ba2.offset(pos2); + if(ofs1 + len > ba1.data.length) caml_array_bound_error(); + if(ofs2 + len > ba2.data.length) caml_array_bound_error(); + var slice = ba1.data.subarray(ofs1, ofs1 + len); + ba2.data.set(slice, pos2); + return 0; + } + function bigstringaf_blit_to_bigstring(src, src_off, dst, dst_off, len){return caml_bigstring_blit_ba_to_ba(src, src_off, dst, dst_off, len); + } + function caml_bigstring_blit_ba_to_bytes(ba1, pos1, bytes2, pos2, len){ + if(12 != ba1.kind) + caml_invalid_argument("caml_bigstring_blit_string_to_ba: kind mismatch"); + if(len == 0) return 0; + var ofs1 = ba1.offset(pos1); + if(ofs1 + len > ba1.data.length) caml_array_bound_error(); + if(pos2 + len > caml_ml_bytes_length(bytes2)) caml_array_bound_error(); + var slice = ba1.data.slice(ofs1, ofs1 + len); + caml_blit_bytes(caml_bytes_of_array(slice), 0, bytes2, pos2, len); + return 0; + } + function bigstringaf_blit_to_bytes(src, src_off, dst, dst_off, len){ + return caml_bigstring_blit_ba_to_bytes(src, src_off, dst, dst_off, len); + } + function bigstringaf_memchr(ba, ba_off, chr, len){ + for(var i = 0; i < len; i++) + if(caml_ba_get_1(ba, ba_off + i) == chr) return ba_off + i; + return - 1; + } + function caml_int_compare(a, b){ + if(a < b) return - 1; + if(a == b) return 0; + return 1; + } + function bigstringaf_memcmp_bigstring(ba1, ba1_off, ba2, ba2_off, len){ + for(var i = 0; i < len; i++){ + var + c = + caml_int_compare + (caml_ba_get_1(ba1, ba1_off + i), caml_ba_get_1(ba2, ba2_off + i)); + if(c != 0) return c; + } + return 0; + } + function bigstringaf_memcmp_string(ba, ba_off, str, str_off, len){ + for(var i = 0; i < len; i++){ + var + c = + caml_int_compare + (caml_ba_get_1(ba, ba_off + i), + caml_string_unsafe_get(str, str_off + i)); + if(c != 0) return c; + } + return 0; + } + function blit_nat(nat1, ofs1, nat2, ofs2, len){ + for(var i = 0; i < len; i++) nat1.data[ofs1 + i] = nat2.data[ofs2 + i]; + return 0; + } + var + caml_MD5Transform = + function(){ + function add(x, y){return x + y | 0;} + function xx(q, a, b, x, s, t){ + a = add(add(a, q), add(x, t)); + return add(a << s | a >>> 32 - s, b); + } + function ff(a, b, c, d, x, s, t){ + return xx(b & c | ~ b & d, a, b, x, s, t); + } + function gg(a, b, c, d, x, s, t){ + return xx(b & d | c & ~ d, a, b, x, s, t); + } + function hh(a, b, c, d, x, s, t){return xx(b ^ c ^ d, a, b, x, s, t);} + function ii(a, b, c, d, x, s, t){ + return xx(c ^ (b | ~ d), a, b, x, s, t); + } + return function(w, buffer){ + var a = w[0], b = w[1], c = w[2], d = w[3]; + a = ff(a, b, c, d, buffer[0], 7, 0xD76AA478); + d = ff(d, a, b, c, buffer[1], 12, 0xE8C7B756); + c = ff(c, d, a, b, buffer[2], 17, 0x242070DB); + b = ff(b, c, d, a, buffer[3], 22, 0xC1BDCEEE); + a = ff(a, b, c, d, buffer[4], 7, 0xF57C0FAF); + d = ff(d, a, b, c, buffer[5], 12, 0x4787C62A); + c = ff(c, d, a, b, buffer[6], 17, 0xA8304613); + b = ff(b, c, d, a, buffer[7], 22, 0xFD469501); + a = ff(a, b, c, d, buffer[8], 7, 0x698098D8); + d = ff(d, a, b, c, buffer[9], 12, 0x8B44F7AF); + c = ff(c, d, a, b, buffer[10], 17, 0xFFFF5BB1); + b = ff(b, c, d, a, buffer[11], 22, 0x895CD7BE); + a = ff(a, b, c, d, buffer[12], 7, 0x6B901122); + d = ff(d, a, b, c, buffer[13], 12, 0xFD987193); + c = ff(c, d, a, b, buffer[14], 17, 0xA679438E); + b = ff(b, c, d, a, buffer[15], 22, 0x49B40821); + a = gg(a, b, c, d, buffer[1], 5, 0xF61E2562); + d = gg(d, a, b, c, buffer[6], 9, 0xC040B340); + c = gg(c, d, a, b, buffer[11], 14, 0x265E5A51); + b = gg(b, c, d, a, buffer[0], 20, 0xE9B6C7AA); + a = gg(a, b, c, d, buffer[5], 5, 0xD62F105D); + d = gg(d, a, b, c, buffer[10], 9, 0x02441453); + c = gg(c, d, a, b, buffer[15], 14, 0xD8A1E681); + b = gg(b, c, d, a, buffer[4], 20, 0xE7D3FBC8); + a = gg(a, b, c, d, buffer[9], 5, 0x21E1CDE6); + d = gg(d, a, b, c, buffer[14], 9, 0xC33707D6); + c = gg(c, d, a, b, buffer[3], 14, 0xF4D50D87); + b = gg(b, c, d, a, buffer[8], 20, 0x455A14ED); + a = gg(a, b, c, d, buffer[13], 5, 0xA9E3E905); + d = gg(d, a, b, c, buffer[2], 9, 0xFCEFA3F8); + c = gg(c, d, a, b, buffer[7], 14, 0x676F02D9); + b = gg(b, c, d, a, buffer[12], 20, 0x8D2A4C8A); + a = hh(a, b, c, d, buffer[5], 4, 0xFFFA3942); + d = hh(d, a, b, c, buffer[8], 11, 0x8771F681); + c = hh(c, d, a, b, buffer[11], 16, 0x6D9D6122); + b = hh(b, c, d, a, buffer[14], 23, 0xFDE5380C); + a = hh(a, b, c, d, buffer[1], 4, 0xA4BEEA44); + d = hh(d, a, b, c, buffer[4], 11, 0x4BDECFA9); + c = hh(c, d, a, b, buffer[7], 16, 0xF6BB4B60); + b = hh(b, c, d, a, buffer[10], 23, 0xBEBFBC70); + a = hh(a, b, c, d, buffer[13], 4, 0x289B7EC6); + d = hh(d, a, b, c, buffer[0], 11, 0xEAA127FA); + c = hh(c, d, a, b, buffer[3], 16, 0xD4EF3085); + b = hh(b, c, d, a, buffer[6], 23, 0x04881D05); + a = hh(a, b, c, d, buffer[9], 4, 0xD9D4D039); + d = hh(d, a, b, c, buffer[12], 11, 0xE6DB99E5); + c = hh(c, d, a, b, buffer[15], 16, 0x1FA27CF8); + b = hh(b, c, d, a, buffer[2], 23, 0xC4AC5665); + a = ii(a, b, c, d, buffer[0], 6, 0xF4292244); + d = ii(d, a, b, c, buffer[7], 10, 0x432AFF97); + c = ii(c, d, a, b, buffer[14], 15, 0xAB9423A7); + b = ii(b, c, d, a, buffer[5], 21, 0xFC93A039); + a = ii(a, b, c, d, buffer[12], 6, 0x655B59C3); + d = ii(d, a, b, c, buffer[3], 10, 0x8F0CCC92); + c = ii(c, d, a, b, buffer[10], 15, 0xFFEFF47D); + b = ii(b, c, d, a, buffer[1], 21, 0x85845DD1); + a = ii(a, b, c, d, buffer[8], 6, 0x6FA87E4F); + d = ii(d, a, b, c, buffer[15], 10, 0xFE2CE6E0); + c = ii(c, d, a, b, buffer[6], 15, 0xA3014314); + b = ii(b, c, d, a, buffer[13], 21, 0x4E0811A1); + a = ii(a, b, c, d, buffer[4], 6, 0xF7537E82); + d = ii(d, a, b, c, buffer[11], 10, 0xBD3AF235); + c = ii(c, d, a, b, buffer[2], 15, 0x2AD7D2BB); + b = ii(b, c, d, a, buffer[9], 21, 0xEB86D391); + w[0] = add(a, w[0]); + w[1] = add(b, w[1]); + w[2] = add(c, w[2]); + w[3] = add(d, w[3]);}; + } + (); + function caml_MD5Final(ctx){ + var in_buf = ctx.len & 0x3f; + ctx.b8[in_buf] = 0x80; + in_buf++; + if(in_buf > 56){ + for(var j = in_buf; j < 64; j++) ctx.b8[j] = 0; + caml_MD5Transform(ctx.w, ctx.b32); + for(var j = 0; j < 56; j++) ctx.b8[j] = 0; + } + else + for(var j = in_buf; j < 56; j++) ctx.b8[j] = 0; + ctx.b32[14] = ctx.len << 3; + ctx.b32[15] = ctx.len >> 29 & 0x1FFFFFFF; + caml_MD5Transform(ctx.w, ctx.b32); + var t = new Uint8Array(16); + for(var i = 0; i < 4; i++) + for(var j = 0; j < 4; j++) t[i * 4 + j] = ctx.w[i] >> 8 * j & 0xFF; + return t; + } + function caml_MD5Init(){ + var + buffer = new ArrayBuffer(64), + b32 = new Uint32Array(buffer), + b8 = new Uint8Array(buffer); + return {len: 0, + w: + new Uint32Array([0x67452301, 0xEFCDAB89, 0x98BADCFE, 0x10325476]), + b32: b32, + b8: b8}; + } + function caml_MD5Update(ctx, input, input_len){ + var in_buf = ctx.len & 0x3f, input_pos = 0; + ctx.len += input_len; + if(in_buf){ + var missing = 64 - in_buf; + if(input_len < missing){ + ctx.b8.set(input.subarray(0, input_len), in_buf); + return; + } + ctx.b8.set(input.subarray(0, missing), in_buf); + caml_MD5Transform(ctx.w, ctx.b32); + input_len -= missing; + input_pos += missing; + } + while(input_len >= 64){ + ctx.b8.set(input.subarray(input_pos, input_pos + 64), 0); + caml_MD5Transform(ctx.w, ctx.b32); + input_len -= 64; + input_pos += 64; + } + if(input_len) + ctx.b8.set(input.subarray(input_pos, input_pos + input_len), 0); + } + function caml_acosh_float(x){return Math.acosh(x);} + function caml_call_gen(f, args){ + var + n = f.l >= 0 ? f.l : f.l = f.length, + argsLen = args.length, + d = n - argsLen; + if(d == 0) + return f.apply(null, args); + else if(d < 0){ + var g = f.apply(null, args.slice(0, n)); + if(typeof g !== "function") return g; + return caml_call_gen(g, args.slice(n)); + } + else{ + switch(d){ + case 1: + { + var + g = + function(x){ + var nargs = new Array(argsLen + 1); + for(var i = 0; i < argsLen; i++) nargs[i] = args[i]; + nargs[argsLen] = x; + return f.apply(null, nargs); + }; + break; + } + case 2: + { + var + g = + function(x, y){ + var nargs = new Array(argsLen + 2); + for(var i = 0; i < argsLen; i++) nargs[i] = args[i]; + nargs[argsLen] = x; + nargs[argsLen + 1] = y; + return f.apply(null, nargs); + }; + break; + } + default: + var + g = + function(){ + var + extra_args = arguments.length == 0 ? 1 : arguments.length, + nargs = new Array(args.length + extra_args); + for(var i = 0; i < args.length; i++) nargs[i] = args[i]; + for(var i = 0; i < arguments.length; i++) + nargs[args.length + i] = arguments[i]; + return caml_call_gen(f, nargs); + }; + } + g.l = d; + return g; + } + } + function caml_alloc_dummy_infix(){ + return function f(x){return caml_call_gen(f.fun, [x]);}; + } + function caml_alloc_stack(hv, hx, hf){return 0;} + var + caml_argv = + function(){ + var process = globalThis.process, main = "a.out", args = []; + if(process && process.argv && process.argv.length > 1){ + var argv = process.argv; + main = argv[1]; + args = argv.slice(2); + } + var p = caml_string_of_jsstring(main), args2 = [0, p]; + for(var i = 0; i < args.length; i++) + args2.push(caml_string_of_jsstring(args[i])); + return args2; + } + (); + function caml_array_append(a1, a2){ + var l1 = a1.length, l2 = a2.length, l = l1 + l2 - 1, a = new Array(l); + a[0] = 0; + var i = 1, j = 1; + for(; i < l1; i++) a[i] = a1[i]; + for(; i < l; i++, j++) a[i] = a2[j]; + return a; + } + function caml_array_blit(a1, i1, a2, i2, len){ + if(i2 <= i1) + for(var j = 1; j <= len; j++) a2[i2 + j] = a1[i1 + j]; + else + for(var j = len; j >= 1; j--) a2[i2 + j] = a1[i1 + j]; + return 0; + } + function caml_array_concat(l){ + var a = [0]; + while(l !== 0){ + var b = l[1]; + for(var i = 1; i < b.length; i++) a.push(b[i]); + l = l[2]; + } + return a; + } + function caml_array_fill(array, ofs, len, v){ + for(var i = 0; i < len; i++) array[ofs + i + 1] = v; + return 0; + } + function caml_array_get(array, index){ + if(index < 0 || index >= array.length - 1) caml_array_bound_error(); + return array[index + 1]; + } + function caml_array_of_bytes(x){return caml_uint8_array_of_bytes(x);} + function caml_array_of_string(x){return caml_uint8_array_of_string(x);} + function caml_array_set(array, index, newval){ + if(index < 0 || index >= array.length - 1) caml_array_bound_error(); + array[index + 1] = newval; + return 0; + } + function caml_array_sub(a, i, len){ + var a2 = new Array(len + 1); + a2[0] = 0; + for(var i2 = 1, i1 = i + 1; i2 <= len; i2++, i1++) a2[i2] = a[i1]; + return a2; + } + function caml_asinh_float(x){return Math.asinh(x);} + function caml_atanh_float(x){return Math.atanh(x);} + function caml_atomic_cas(ref, o, n){ + if(ref[1] === o){ref[1] = n; return 1;} + return 0; + } + function caml_atomic_exchange(ref, v){ + var r = ref[1]; + ref[1] = v; + return r; + } + function caml_atomic_fetch_add(ref, i){ + var old = ref[1]; + ref[1] += i; + return old; + } + function caml_atomic_load(ref){return ref[1];} + function caml_atomic_make_contended(a){return [0, a];} + function caml_ba_blit(src, dst){ + if(dst.dims.length != src.dims.length) + caml_invalid_argument("Bigarray.blit: dimension mismatch"); + for(var i = 0; i < dst.dims.length; i++) + if(dst.dims[i] != src.dims[i]) + caml_invalid_argument("Bigarray.blit: dimension mismatch"); + dst.data.set(src.data); + return 0; + } + function caml_ba_change_layout(ba, layout){ + if(ba.layout == layout) return ba; + var new_dims = []; + for(var i = 0; i < ba.dims.length; i++) + new_dims[i] = ba.dims[ba.dims.length - i - 1]; + return caml_ba_create_unsafe(ba.kind, layout, new_dims, ba.data); + } + function caml_ba_compare(a, b, total){return a.compare(b, total);} + function caml_ba_create_buffer(kind, size){ + var view; + switch(kind){ + case 0: + view = Float32Array; break; + case 1: + view = Float64Array; break; + case 2: + view = Int8Array; break; + case 3: + view = Uint8Array; break; + case 4: + view = Int16Array; break; + case 5: + view = Uint16Array; break; + case 6: + view = Int32Array; break; + case 7: + view = Int32Array; break; + case 8: + view = Int32Array; break; + case 9: + view = Int32Array; break; + case 10: + view = Float32Array; break; + case 11: + view = Float64Array; break; + case 12: + view = Uint8Array; break; + } + if(! view) caml_invalid_argument("Bigarray.create: unsupported kind"); + var data = new view(size * caml_ba_get_size_per_element(kind)); + return data; + } + function caml_js_from_array(a){return a.slice(1);} + function caml_ba_create(kind, layout, dims_ml){ + var + dims = caml_js_from_array(dims_ml), + data = caml_ba_create_buffer(kind, caml_ba_get_size(dims)); + return caml_ba_create_unsafe(kind, layout, dims, data); + } + function caml_ba_create_from(data1, data2, jstyp, kind, layout, dims){ + if(data2 || caml_ba_get_size_per_element(kind) == 2) + caml_invalid_argument + ("caml_ba_create_from: use return caml_ba_create_unsafe"); + return caml_ba_create_unsafe(kind, layout, dims, data1); + } + function caml_int32_float_of_bits(x){ + var int32a = new Int32Array(1); + int32a[0] = x; + var float32a = new Float32Array(int32a.buffer); + return float32a[0]; + } + function caml_int64_of_bytes(a){ + return new + MlInt64 + (a[7] << 0 | a[6] << 8 | a[5] << 16, + a[4] << 0 | a[3] << 8 | a[2] << 16, + a[1] << 0 | a[0] << 8); + } + function caml_int64_float_of_bits(x){ + var lo = x.lo, mi = x.mi, hi = x.hi, exp = (hi & 0x7fff) >> 4; + if(exp == 2047) + return (lo | mi | hi & 0xf) == 0 + ? hi & 0x8000 ? - Infinity : Infinity + : NaN; + var k = Math.pow(2, - 24), res = (lo * k + mi) * k + (hi & 0xf); + if(exp > 0){ + res += 16; + res *= Math.pow(2, exp - 1027); + } + else + res *= Math.pow(2, - 1026); + if(hi & 0x8000) res = - res; + return res; + } + function caml_failwith(msg){ + if(! caml_global_data.Failure) + caml_global_data.Failure = [248, caml_string_of_jsbytes("Failure"), - 3]; + caml_raise_with_string(caml_global_data.Failure, msg); + } + function caml_ba_deserialize(reader, sz, name){ + var num_dims = reader.read32s(); + if(num_dims < 0 || num_dims > 16) + caml_failwith("input_value: wrong number of bigarray dimensions"); + var + tag = reader.read32s(), + kind = tag & 0xff, + layout = tag >> 8 & 1, + dims = []; + if(name == "_bigarr02") + for(var i = 0; i < num_dims; i++){ + var size_dim = reader.read16u(); + if(size_dim == 0xffff){ + var size_dim_hi = reader.read32u(), size_dim_lo = reader.read32u(); + if(size_dim_hi != 0) + caml_failwith("input_value: bigarray dimension overflow in 32bit"); + size_dim = size_dim_lo; + } + dims.push(size_dim); + } + else + for(var i = 0; i < num_dims; i++) dims.push(reader.read32u()); + var + size = caml_ba_get_size(dims), + data = caml_ba_create_buffer(kind, size), + ba = caml_ba_create_unsafe(kind, layout, dims, data); + switch(kind){ + case 2: + for(var i = 0; i < size; i++) data[i] = reader.read8s(); break; + case 3: + case 12: + for(var i = 0; i < size; i++) data[i] = reader.read8u(); break; + case 4: + for(var i = 0; i < size; i++) data[i] = reader.read16s(); break; + case 5: + for(var i = 0; i < size; i++) data[i] = reader.read16u(); break; + case 6: + for(var i = 0; i < size; i++) data[i] = reader.read32s(); break; + case 8: + case 9: + var sixty = reader.read8u(); + if(sixty) + caml_failwith + ("input_value: cannot read bigarray with 64-bit OCaml ints"); + for(var i = 0; i < size; i++) data[i] = reader.read32s(); + break; + case 7: + var t = new Array(8); + for(var i = 0; i < size; i++){ + for(var j = 0; j < 8; j++) t[j] = reader.read8u(); + var int64 = caml_int64_of_bytes(t); + ba.set(i, int64); + } + break; + case 1: + var t = new Array(8); + for(var i = 0; i < size; i++){ + for(var j = 0; j < 8; j++) t[j] = reader.read8u(); + var f = caml_int64_float_of_bits(caml_int64_of_bytes(t)); + ba.set(i, f); + } + break; + case 0: + for(var i = 0; i < size; i++){ + var f = caml_int32_float_of_bits(reader.read32s()); + ba.set(i, f); + } + break; + case 10: + for(var i = 0; i < size; i++){ + var + re = caml_int32_float_of_bits(reader.read32s()), + im = caml_int32_float_of_bits(reader.read32s()); + ba.set(i, [254, re, im]); + } + break; + case 11: + var t = new Array(8); + for(var i = 0; i < size; i++){ + for(var j = 0; j < 8; j++) t[j] = reader.read8u(); + var re = caml_int64_float_of_bits(caml_int64_of_bytes(t)); + for(var j = 0; j < 8; j++) t[j] = reader.read8u(); + var im = caml_int64_float_of_bits(caml_int64_of_bytes(t)); + ba.set(i, [254, re, im]); + } + break; + } + sz[0] = (4 + num_dims) * 4; + return caml_ba_create_unsafe(kind, layout, dims, data); + } + function caml_ba_dim(ba, i){ + if(i < 0 || i >= ba.dims.length) caml_invalid_argument("Bigarray.dim"); + return ba.dims[i]; + } + function caml_ba_dim_1(ba){return caml_ba_dim(ba, 0);} + function caml_ba_dim_2(ba){return caml_ba_dim(ba, 1);} + function caml_ba_dim_3(ba){return caml_ba_dim(ba, 2);} + function caml_ba_fill(ba, v){ba.fill(v); return 0;} + function caml_ba_kind_of_typed_array(ta){ + var kind; + if(ta instanceof Float32Array) + kind = 0; + else if(ta instanceof Float64Array) + kind = 1; + else if(ta instanceof Int8Array) + kind = 2; + else if(ta instanceof Uint8Array) + kind = 3; + else if(ta instanceof Uint8ClampedArray) + kind = 3; + else if(ta instanceof Int16Array) + kind = 4; + else if(ta instanceof Uint16Array) + kind = 5; + else if(ta instanceof Int32Array) + kind = 6; + else if(ta instanceof Uint32Array) + kind = 6; + else + caml_invalid_argument("caml_ba_kind_of_typed_array: unsupported kind"); + return kind; + } + function caml_ba_from_typed_array(ta){ + var + kind = caml_ba_kind_of_typed_array(ta), + ta = + ta instanceof Uint32Array + ? new Int32Array(ta.buffer, ta.byteOffset, ta.length) + : ta; + return caml_ba_create_unsafe(kind, 0, [ta.length], ta); + } + function caml_ba_get_2(ba, i0, i1){return ba.get(ba.offset([i0, i1]));} + function caml_ba_get_3(ba, i0, i1, i2){ + return ba.get(ba.offset([i0, i1, i2])); + } + function caml_ba_get_generic(ba, i){ + var ofs = ba.offset(caml_js_from_array(i)); + return ba.get(ofs); + } + function caml_mul(a, b){return Math.imul(a, b);} + function caml_hash_mix_int(h, d){ + d = caml_mul(d, 0xcc9e2d51 | 0); + d = d << 15 | d >>> 32 - 15; + d = caml_mul(d, 0x1b873593); + h ^= d; + h = h << 13 | h >>> 32 - 13; + return (h + (h << 2) | 0) + (0xe6546b64 | 0) | 0; + } + var log2_ok = Math.log2 && Math.log2(1.1235582092889474E+307) == 1020; + function jsoo_floor_log2(x){ + if(log2_ok) return Math.floor(Math.log2(x)); + var i = 0; + if(x == 0) return - Infinity; + if(x >= 1) while(x >= 2){x /= 2; i++;} else while(x < 1){x *= 2; i--;} + return i; + } + function caml_int64_create_lo_mi_hi(lo, mi, hi){return new MlInt64(lo, mi, hi); + } + function caml_int64_bits_of_float(x){ + if(! isFinite(x)){ + if(isNaN(x)) return caml_int64_create_lo_mi_hi(1, 0, 0x7ff0); + return x > 0 + ? caml_int64_create_lo_mi_hi(0, 0, 0x7ff0) + : caml_int64_create_lo_mi_hi(0, 0, 0xfff0); + } + var sign = x == 0 && 1 / x == - Infinity ? 0x8000 : x >= 0 ? 0 : 0x8000; + if(sign) x = - x; + var exp = jsoo_floor_log2(x) + 1023; + if(exp <= 0){ + exp = 0; + x /= Math.pow(2, - 1026); + } + else{ + x /= Math.pow(2, exp - 1027); + if(x < 16){x *= 2; exp -= 1;} + if(exp == 0) x /= 2; + } + var k = Math.pow(2, 24), r3 = x | 0; + x = (x - r3) * k; + var r2 = x | 0; + x = (x - r2) * k; + var r1 = x | 0; + r3 = r3 & 0xf | sign | exp << 4; + return caml_int64_create_lo_mi_hi(r1, r2, r3); + } + function caml_hash_mix_int64(h, v){ + h = caml_hash_mix_int(h, caml_int64_lo32(v)); + h = caml_hash_mix_int(h, caml_int64_hi32(v)); + return h; + } + function caml_hash_mix_float(h, v0){ + return caml_hash_mix_int64(h, caml_int64_bits_of_float(v0)); + } + function caml_ba_hash(ba){ + var num_elts = caml_ba_get_size(ba.dims), h = 0; + switch(ba.kind){ + case 2: + case 3: + case 12: + if(num_elts > 256) num_elts = 256; + var w = 0, i = 0; + for(i = 0; i + 4 <= ba.data.length; i += 4){ + w = + ba.data[i + 0] | ba.data[i + 1] << 8 | ba.data[i + 2] << 16 + | ba.data[i + 3] << 24; + h = caml_hash_mix_int(h, w); + } + w = 0; + switch(num_elts & 3){ + case 3: + w = ba.data[i + 2] << 16; + case 2: + w |= ba.data[i + 1] << 8; + case 1: + w |= ba.data[i + 0]; h = caml_hash_mix_int(h, w); + } + break; + case 4: + case 5: + if(num_elts > 128) num_elts = 128; + var w = 0, i = 0; + for(i = 0; i + 2 <= ba.data.length; i += 2){ + w = ba.data[i + 0] | ba.data[i + 1] << 16; + h = caml_hash_mix_int(h, w); + } + if((num_elts & 1) != 0) h = caml_hash_mix_int(h, ba.data[i]); + break; + case 6: + if(num_elts > 64) num_elts = 64; + for(var i = 0; i < num_elts; i++) h = caml_hash_mix_int(h, ba.data[i]); + break; + case 8: + case 9: + if(num_elts > 64) num_elts = 64; + for(var i = 0; i < num_elts; i++) h = caml_hash_mix_int(h, ba.data[i]); + break; + case 7: + if(num_elts > 32) num_elts = 32; + num_elts *= 2; + for(var i = 0; i < num_elts; i++) h = caml_hash_mix_int(h, ba.data[i]); + break; + case 10: + num_elts *= 2; + case 0: + if(num_elts > 64) num_elts = 64; + for(var i = 0; i < num_elts; i++) + h = caml_hash_mix_float(h, ba.data[i]); + break; + case 11: + num_elts *= 2; + case 1: + if(num_elts > 32) num_elts = 32; + for(var i = 0; i < num_elts; i++) + h = caml_hash_mix_float(h, ba.data[i]); + break; + } + return h; + } + function caml_ba_init(){return 0;} + function caml_ba_kind(ba){return ba.kind;} + function caml_ba_layout(ba){return ba.layout;} + function caml_ba_map_file(vfd, kind, layout, shared, dims, pos){caml_failwith("caml_ba_map_file not implemented"); + } + function caml_ba_map_file_bytecode(argv, argn){ + return caml_ba_map_file + (argv[0], argv[1], argv[2], argv[3], argv[4], argv[5]); + } + function caml_ba_num_dims(ba){return ba.dims.length;} + function caml_ba_reshape(ba, vind){ + vind = caml_js_from_array(vind); + var new_dim = [], num_dims = vind.length; + if(num_dims < 0 || num_dims > 16) + caml_invalid_argument("Bigarray.reshape: bad number of dimensions"); + var num_elts = 1; + for(var i = 0; i < num_dims; i++){ + new_dim[i] = vind[i]; + if(new_dim[i] < 0) + caml_invalid_argument("Bigarray.reshape: negative dimension"); + num_elts = num_elts * new_dim[i]; + } + var size = caml_ba_get_size(ba.dims); + if(num_elts != size) + caml_invalid_argument("Bigarray.reshape: size mismatch"); + return caml_ba_create_unsafe(ba.kind, ba.layout, new_dim, ba.data); + } + function caml_int32_bits_of_float(x){ + var float32a = new Float32Array(1); + float32a[0] = x; + var int32a = new Int32Array(float32a.buffer); + return int32a[0] | 0; + } + function caml_int64_to_bytes(x){return x.toArray();} + function caml_ba_serialize(writer, ba, sz){ + writer.write(32, ba.dims.length); + writer.write(32, ba.kind | ba.layout << 8); + if(ba.caml_custom == "_bigarr02") + for(var i = 0; i < ba.dims.length; i++) + if(ba.dims[i] < 0xffff) + writer.write(16, ba.dims[i]); + else{ + writer.write(16, 0xffff); + writer.write(32, 0); + writer.write(32, ba.dims[i]); + } + else + for(var i = 0; i < ba.dims.length; i++) writer.write(32, ba.dims[i]); + switch(ba.kind){ + case 2: + case 3: + case 12: + for(var i = 0; i < ba.data.length; i++) writer.write(8, ba.data[i]); + break; + case 4: + case 5: + for(var i = 0; i < ba.data.length; i++) writer.write(16, ba.data[i]); + break; + case 6: + for(var i = 0; i < ba.data.length; i++) writer.write(32, ba.data[i]); + break; + case 8: + case 9: + writer.write(8, 0); + for(var i = 0; i < ba.data.length; i++) writer.write(32, ba.data[i]); + break; + case 7: + for(var i = 0; i < ba.data.length / 2; i++){ + var b = caml_int64_to_bytes(ba.get(i)); + for(var j = 0; j < 8; j++) writer.write(8, b[j]); + } + break; + case 1: + for(var i = 0; i < ba.data.length; i++){ + var b = caml_int64_to_bytes(caml_int64_bits_of_float(ba.get(i))); + for(var j = 0; j < 8; j++) writer.write(8, b[j]); + } + break; + case 0: + for(var i = 0; i < ba.data.length; i++){ + var b = caml_int32_bits_of_float(ba.get(i)); + writer.write(32, b); + } + break; + case 10: + for(var i = 0; i < ba.data.length / 2; i++){ + var j = ba.get(i); + writer.write(32, caml_int32_bits_of_float(j[1])); + writer.write(32, caml_int32_bits_of_float(j[2])); + } + break; + case 11: + for(var i = 0; i < ba.data.length / 2; i++){ + var + complex = ba.get(i), + b = caml_int64_to_bytes(caml_int64_bits_of_float(complex[1])); + for(var j = 0; j < 8; j++) writer.write(8, b[j]); + var b = caml_int64_to_bytes(caml_int64_bits_of_float(complex[2])); + for(var j = 0; j < 8; j++) writer.write(8, b[j]); + } + break; + } + sz[0] = (4 + ba.dims.length) * 4; + sz[1] = (4 + ba.dims.length) * 8; + } + function caml_ba_set_1(ba, i0, v){ba.set(ba.offset(i0), v); return 0;} + function caml_ba_set_2(ba, i0, i1, v){ + ba.set(ba.offset([i0, i1]), v); + return 0; + } + function caml_ba_set_3(ba, i0, i1, i2, v){ + ba.set(ba.offset([i0, i1, i2]), v); + return 0; + } + function caml_ba_set_generic(ba, i, v){ + ba.set(ba.offset(caml_js_from_array(i)), v); + return 0; + } + function caml_ba_slice(ba, vind){ + vind = caml_js_from_array(vind); + var num_inds = vind.length, index = [], sub_dims = [], ofs; + if(num_inds > ba.dims.length) + caml_invalid_argument("Bigarray.slice: too many indices"); + if(ba.layout == 0){ + for(var i = 0; i < num_inds; i++) index[i] = vind[i]; + for(; i < ba.dims.length; i++) index[i] = 0; + sub_dims = ba.dims.slice(num_inds); + } + else{ + for(var i = 0; i < num_inds; i++) + index[ba.dims.length - num_inds + i] = vind[i]; + for(var i = 0; i < ba.dims.length - num_inds; i++) index[i] = 1; + sub_dims = ba.dims.slice(0, ba.dims.length - num_inds); + } + ofs = ba.offset(index); + var + size = caml_ba_get_size(sub_dims), + size_per_element = caml_ba_get_size_per_element(ba.kind), + new_data = + ba.data.subarray + (ofs * size_per_element, (ofs + size) * size_per_element); + return caml_ba_create_unsafe(ba.kind, ba.layout, sub_dims, new_data); + } + function caml_ba_sub(ba, ofs, len){ + var changed_dim, mul = 1; + if(ba.layout == 0){ + for(var i = 1; i < ba.dims.length; i++) mul = mul * ba.dims[i]; + changed_dim = 0; + } + else{ + for(var i = 0; i < ba.dims.length - 1; i++) mul = mul * ba.dims[i]; + changed_dim = ba.dims.length - 1; + ofs = ofs - 1; + } + if(ofs < 0 || len < 0 || ofs + len > ba.dims[changed_dim]) + caml_invalid_argument("Bigarray.sub: bad sub-array"); + var new_dims = []; + for(var i = 0; i < ba.dims.length; i++) new_dims[i] = ba.dims[i]; + new_dims[changed_dim] = len; + mul *= caml_ba_get_size_per_element(ba.kind); + var new_data = ba.data.subarray(ofs * mul, (ofs + len) * mul); + return caml_ba_create_unsafe(ba.kind, ba.layout, new_dims, new_data); + } + function caml_ba_to_typed_array(ba){return ba.data;} + function caml_ba_uint8_get16(ba, i0){ + var ofs = ba.offset(i0); + if(ofs + 1 >= ba.data.length) caml_array_bound_error(); + var b1 = ba.get(ofs), b2 = ba.get(ofs + 1); + return b1 | b2 << 8; + } + function caml_ba_uint8_get32(ba, i0){ + var ofs = ba.offset(i0); + if(ofs + 3 >= ba.data.length) caml_array_bound_error(); + var + b1 = ba.get(ofs + 0), + b2 = ba.get(ofs + 1), + b3 = ba.get(ofs + 2), + b4 = ba.get(ofs + 3); + return b1 << 0 | b2 << 8 | b3 << 16 | b4 << 24; + } + function caml_ba_uint8_get64(ba, i0){ + var ofs = ba.offset(i0); + if(ofs + 7 >= ba.data.length) caml_array_bound_error(); + var + b1 = ba.get(ofs + 0), + b2 = ba.get(ofs + 1), + b3 = ba.get(ofs + 2), + b4 = ba.get(ofs + 3), + b5 = ba.get(ofs + 4), + b6 = ba.get(ofs + 5), + b7 = ba.get(ofs + 6), + b8 = ba.get(ofs + 7); + return caml_int64_of_bytes([b8, b7, b6, b5, b4, b3, b2, b1]); + } + function caml_ba_uint8_set16(ba, i0, v){ + var ofs = ba.offset(i0); + if(ofs + 1 >= ba.data.length) caml_array_bound_error(); + ba.set(ofs + 0, v & 0xff); + ba.set(ofs + 1, v >>> 8 & 0xff); + return 0; + } + function caml_ba_uint8_set32(ba, i0, v){ + var ofs = ba.offset(i0); + if(ofs + 3 >= ba.data.length) caml_array_bound_error(); + ba.set(ofs + 0, v & 0xff); + ba.set(ofs + 1, v >>> 8 & 0xff); + ba.set(ofs + 2, v >>> 16 & 0xff); + ba.set(ofs + 3, v >>> 24 & 0xff); + return 0; + } + function caml_ba_uint8_set64(ba, i0, v){ + var ofs = ba.offset(i0); + if(ofs + 7 >= ba.data.length) caml_array_bound_error(); + var v = caml_int64_to_bytes(v); + for(var i = 0; i < 8; i++) ba.set(ofs + i, v[7 - i]); + return 0; + } + function caml_backtrace_status(_unit){ + return caml_record_backtrace_flag ? 1 : 0; + } + function caml_bigstring_blit_bytes_to_ba(str1, pos1, ba2, pos2, len){ + if(12 != ba2.kind) + caml_invalid_argument("caml_bigstring_blit_string_to_ba: kind mismatch"); + if(len == 0) return 0; + var ofs2 = ba2.offset(pos2); + if(pos1 + len > caml_ml_bytes_length(str1)) caml_array_bound_error(); + if(ofs2 + len > ba2.data.length) caml_array_bound_error(); + var slice = caml_uint8_array_of_bytes(str1).slice(pos1, pos1 + len); + ba2.data.set(slice, ofs2); + return 0; + } + function caml_bigstring_memcmp(s1, pos1, s2, pos2, len){ + for(var i = 0; i < len; i++){ + var a = caml_ba_get_1(s1, pos1 + i), b = caml_ba_get_1(s2, pos2 + i); + if(a < b) return - 1; + if(a > b) return 1; + } + return 0; + } + function caml_blit_string(a, b, c, d, e){ + caml_blit_bytes(caml_bytes_of_string(a), b, c, d, e); + return 0; + } + function caml_bswap16(x){return (x & 0x00FF) << 8 | (x & 0xFF00) >> 8;} + function caml_jsstring_of_string(s){ + if(jsoo_is_ascii(s)) return s; + return caml_utf16_of_utf8(s); + } + function caml_build_symbols(symb){ + var r = {}; + if(symb) + for(var i = 1; i < symb.length; i++) + r[caml_jsstring_of_string(symb[i][1])] = symb[i][2]; + return r; + } + function caml_bytes_compare(s1, s2){ + s1.t & 6 && caml_convert_string_to_bytes(s1); + s2.t & 6 && caml_convert_string_to_bytes(s2); + return s1.c < s2.c ? - 1 : s1.c > s2.c ? 1 : 0; + } + function caml_bytes_equal(s1, s2){ + if(s1 === s2) return 1; + s1.t & 6 && caml_convert_string_to_bytes(s1); + s2.t & 6 && caml_convert_string_to_bytes(s2); + return s1.c == s2.c ? 1 : 0; + } + function caml_bytes_unsafe_get(s, i){ + switch(s.t & 6){ + default: if(i >= s.c.length) return 0; + case 0: + return s.c.charCodeAt(i); + case 4: + return s.c[i]; + } + } + function caml_bytes_get(s, i){ + if(i >>> 0 >= s.l) caml_bytes_bound_error(); + return caml_bytes_unsafe_get(s, i); + } + function caml_bytes_get16(s, i){ + if(i >>> 0 >= s.l - 1) caml_bytes_bound_error(); + var + b1 = caml_bytes_unsafe_get(s, i), + b2 = caml_bytes_unsafe_get(s, i + 1); + return b2 << 8 | b1; + } + function caml_bytes_get32(s, i){ + if(i >>> 0 >= s.l - 3) caml_bytes_bound_error(); + var + b1 = caml_bytes_unsafe_get(s, i), + b2 = caml_bytes_unsafe_get(s, i + 1), + b3 = caml_bytes_unsafe_get(s, i + 2), + b4 = caml_bytes_unsafe_get(s, i + 3); + return b4 << 24 | b3 << 16 | b2 << 8 | b1; + } + function caml_bytes_get64(s, i){ + if(i >>> 0 >= s.l - 7) caml_bytes_bound_error(); + var a = new Array(8); + for(var j = 0; j < 8; j++) a[7 - j] = caml_bytes_unsafe_get(s, i + j); + return caml_int64_of_bytes(a); + } + function caml_bytes_lessequal(s1, s2){ + s1.t & 6 && caml_convert_string_to_bytes(s1); + s2.t & 6 && caml_convert_string_to_bytes(s2); + return s1.c <= s2.c ? 1 : 0; + } + function caml_bytes_greaterequal(s1, s2){return caml_bytes_lessequal(s2, s1); + } + function caml_bytes_lessthan(s1, s2){ + s1.t & 6 && caml_convert_string_to_bytes(s1); + s2.t & 6 && caml_convert_string_to_bytes(s2); + return s1.c < s2.c ? 1 : 0; + } + function caml_bytes_greaterthan(s1, s2){return caml_bytes_lessthan(s2, s1); + } + function caml_bytes_notequal(s1, s2){return 1 - caml_bytes_equal(s1, s2);} + function caml_bytes_of_utf16_jsstring(s){ + var tag = 9; + if(! jsoo_is_ascii(s)) tag = 8, s = caml_utf8_of_utf16(s); + return new MlBytes(tag, s, s.length); + } + function caml_bytes_set16(s, i, i16){ + if(i >>> 0 >= s.l - 1) caml_bytes_bound_error(); + var b2 = 0xFF & i16 >> 8, b1 = 0xFF & i16; + caml_bytes_unsafe_set(s, i + 0, b1); + caml_bytes_unsafe_set(s, i + 1, b2); + return 0; + } + function caml_bytes_set32(s, i, i32){ + if(i >>> 0 >= s.l - 3) caml_bytes_bound_error(); + var + b4 = 0xFF & i32 >> 24, + b3 = 0xFF & i32 >> 16, + b2 = 0xFF & i32 >> 8, + b1 = 0xFF & i32; + caml_bytes_unsafe_set(s, i + 0, b1); + caml_bytes_unsafe_set(s, i + 1, b2); + caml_bytes_unsafe_set(s, i + 2, b3); + caml_bytes_unsafe_set(s, i + 3, b4); + return 0; + } + function caml_bytes_set64(s, i, i64){ + if(i >>> 0 >= s.l - 7) caml_bytes_bound_error(); + var a = caml_int64_to_bytes(i64); + for(var j = 0; j < 8; j++) caml_bytes_unsafe_set(s, i + 7 - j, a[j]); + return 0; + } + var caml_callback = caml_call_gen; + function caml_cbrt_float(x){return Math.cbrt(x);} + var caml_ml_channels = new Array(); + function caml_ml_channel_get(id){return caml_ml_channels[id];} + function caml_channel_descriptor(chanid){ + var chan = caml_ml_channel_get(chanid); + return chan.fd; + } + function caml_check_bound(array, index){ + if(index >>> 0 >= array.length - 1) caml_array_bound_error(); + return array; + } + function caml_classify_float(x){ + if(isFinite(x)){ + if(Math.abs(x) >= 2.2250738585072014e-308) return 0; + if(x != 0) return 1; + return 2; + } + return isNaN(x) ? 4 : 3; + } + function caml_is_continuation_tag(t){return 0;} + function caml_int32_unmarshal(reader, size){size[0] = 4; return reader.read32s(); + } + function caml_nativeint_unmarshal(reader, size){ + switch(reader.read8u()){ + case 1: + size[0] = 4; return reader.read32s(); + case 2: + caml_failwith("input_value: native integer value too large"); + default: caml_failwith("input_value: ill-formed native integer"); + } + } + function caml_int64_unmarshal(reader, size){ + var t = new Array(8); + for(var j = 0; j < 8; j++) t[j] = reader.read8u(); + size[0] = 8; + return caml_int64_of_bytes(t); + } + function caml_int64_marshal(writer, v, sizes){ + var b = caml_int64_to_bytes(v); + for(var i = 0; i < 8; i++) writer.write(8, b[i]); + sizes[0] = 8; + sizes[1] = 8; + } + function caml_int64_compare(x, y, total){return x.compare(y);} + function caml_int64_hash(v){return v.lo32() ^ v.hi32();} + var + caml_custom_ops = + {"_j": + {deserialize: caml_int64_unmarshal, + serialize: caml_int64_marshal, + fixed_length: 8, + compare: caml_int64_compare, + hash: caml_int64_hash}, + "_i": {deserialize: caml_int32_unmarshal, fixed_length: 4}, + "_n": {deserialize: caml_nativeint_unmarshal, fixed_length: 4}, + "_bigarray": + {deserialize: + function(reader, sz){ + return caml_ba_deserialize(reader, sz, "_bigarray"); + }, + serialize: caml_ba_serialize, + compare: caml_ba_compare, + hash: caml_ba_hash}, + "_bigarr02": + {deserialize: + function(reader, sz){ + return caml_ba_deserialize(reader, sz, "_bigarr02"); + }, + serialize: caml_ba_serialize, + compare: caml_ba_compare, + hash: caml_ba_hash}}; + function caml_compare_val_get_custom(a){ + return caml_custom_ops[a.caml_custom] + && caml_custom_ops[a.caml_custom].compare; + } + function caml_compare_val_number_custom(num, custom, swap, total){ + var comp = caml_compare_val_get_custom(custom); + if(comp){ + var x = swap > 0 ? comp(custom, num, total) : comp(num, custom, total); + if(total && x != x) return swap; + if(+ x != + x) return + x; + if((x | 0) != 0) return x | 0; + } + return swap; + } + function caml_compare_val_tag(a){ + if(typeof a === "number") + return 1000; + else if(caml_is_ml_bytes(a)) + return 252; + else if(caml_is_ml_string(a)) + return 1252; + else if(a instanceof Array && a[0] === a[0] >>> 0 && a[0] <= 255){var tag = a[0] | 0; return tag == 254 ? 0 : tag;} + else if(a instanceof String) + return 12520; + else if(typeof a == "string") + return 12520; + else if(a instanceof Number) + return 1000; + else if(a && a.caml_custom) + return 1255; + else if(a && a.compare) + return 1256; + else if(typeof a == "function") + return 1247; + else if(typeof a == "symbol") return 1251; + return 1001; + } + function caml_string_compare(s1, s2){ + return s1 < s2 ? - 1 : s1 > s2 ? 1 : 0; + } + function caml_compare_val(a, b, total){ + var stack = []; + for(;;){ + if(! (total && a === b)){ + var tag_a = caml_compare_val_tag(a); + if(tag_a == 250){a = a[1]; continue;} + var tag_b = caml_compare_val_tag(b); + if(tag_b == 250){b = b[1]; continue;} + if(tag_a !== tag_b){ + if(tag_a == 1000){ + if(tag_b == 1255) + return caml_compare_val_number_custom(a, b, - 1, total); + return - 1; + } + if(tag_b == 1000){ + if(tag_a == 1255) + return caml_compare_val_number_custom(b, a, 1, total); + return 1; + } + return tag_a < tag_b ? - 1 : 1; + } + switch(tag_a){ + case 247: + caml_invalid_argument("compare: functional value"); break; + case 248: + var x = caml_int_compare(a[2], b[2]); if(x != 0) return x | 0; break; + case 249: + caml_invalid_argument("compare: functional value"); break; + case 250: + caml_invalid_argument("equal: got Forward_tag, should not happen"); + break; + case 251: + caml_invalid_argument("equal: abstract value"); break; + case 252: + if(a !== b){ + var x = caml_bytes_compare(a, b); + if(x != 0) return x | 0; + } + break; + case 253: + caml_invalid_argument("equal: got Double_tag, should not happen"); + break; + case 254: + caml_invalid_argument + ("equal: got Double_array_tag, should not happen"); + break; + case 255: + caml_invalid_argument("equal: got Custom_tag, should not happen"); + break; + case 1247: + caml_invalid_argument("compare: functional value"); break; + case 1255: + var comp = caml_compare_val_get_custom(a); + if(comp != caml_compare_val_get_custom(b)) + return a.caml_custom < b.caml_custom ? - 1 : 1; + if(! comp) caml_invalid_argument("compare: abstract value"); + var x = comp(a, b, total); + if(x != x) return total ? - 1 : x; + if(x !== (x | 0)) return - 1; + if(x != 0) return x | 0; + break; + case 1256: + var x = a.compare(b, total); + if(x != x) return total ? - 1 : x; + if(x !== (x | 0)) return - 1; + if(x != 0) return x | 0; + break; + case 1000: + a = + a; + b = + b; + if(a < b) return - 1; + if(a > b) return 1; + if(a != b){ + if(! total) return NaN; + if(a == a) return 1; + if(b == b) return - 1; + } + break; + case 1001: + if(a < b) return - 1; + if(a > b) return 1; + if(a != b){ + if(! total) return NaN; + if(a == a) return 1; + if(b == b) return - 1; + } + break; + case 1251: + if(a !== b){if(! total) return NaN; return 1;} break; + case 1252: + var a = caml_jsbytes_of_string(a), b = caml_jsbytes_of_string(b); + if(a !== b){if(a < b) return - 1; if(a > b) return 1;} + break; + case 12520: + var a = a.toString(), b = b.toString(); + if(a !== b){if(a < b) return - 1; if(a > b) return 1;} + break; + case 246: + case 254: + default: + if(caml_is_continuation_tag(tag_a)){ + caml_invalid_argument("compare: continuation value"); + break; + } + if(a.length != b.length) return a.length < b.length ? - 1 : 1; + if(a.length > 1) stack.push(a, b, 1); + break; + } + } + if(stack.length == 0) return 0; + var i = stack.pop(); + b = stack.pop(); + a = stack.pop(); + if(i + 1 < a.length) stack.push(a, b, i + 1); + a = a[i]; + b = b[i]; + } + } + function caml_compare(a, b){return caml_compare_val(a, b, true);} + function caml_continuation_use_noexc(cont){ + var stack = cont[1]; + cont[1] = 0; + return stack; + } + function caml_continuation_use_and_update_handler_noexc + (cont, hval, hexn, heff){ + var stack = caml_continuation_use_noexc(cont); + stack[3] = [0, hval, hexn, heff]; + return stack; + } + function caml_convert_raw_backtrace(){return [0];} + function caml_convert_raw_backtrace_slot(){ + caml_failwith("caml_convert_raw_backtrace_slot"); + } + function caml_copysign_float(x, y){ + if(y == 0) y = 1 / y; + x = Math.abs(x); + return y < 0 ? - x : x; + } + function caml_cosh_float(x){return Math.cosh(x);} + function fs_node_supported(){ + return typeof globalThis.process !== "undefined" + && typeof globalThis.process.versions !== "undefined" + && typeof globalThis.process.versions.node !== "undefined"; + } + function make_path_is_absolute(){ + function posix(path){ + if(path.charAt(0) === "/") return ["", path.substring(1)]; + return; + } + function win32(path){ + var + splitDeviceRe = + /^([a-zA-Z]:|[\\/]{2}[^\\/]+[\\/]+[^\\/]+)?([\\/])?([\s\S]*?)$/, + result = splitDeviceRe.exec(path), + device = result[1] || "", + isUnc = Boolean(device && device.charAt(1) !== ":"); + if(Boolean(result[2] || isUnc)){ + var root = result[1] || "", sep = result[2] || ""; + return [root, path.substring(root.length + sep.length)]; + } + return; + } + return fs_node_supported() && globalThis.process + && globalThis.process.platform + ? globalThis.process.platform === "win32" ? win32 : posix + : posix; + } + var path_is_absolute = make_path_is_absolute(); + function caml_trailing_slash(name){ + return name.slice(- 1) !== "/" ? name + "/" : name; + } + if(fs_node_supported() && globalThis.process && globalThis.process.cwd) + var caml_current_dir = globalThis.process.cwd().replace(/\\/g, "/"); + else + var caml_current_dir = "/static"; + caml_current_dir = caml_trailing_slash(caml_current_dir); + function caml_make_path(name){ + name = caml_jsstring_of_string(name); + if(! path_is_absolute(name)) name = caml_current_dir + name; + var + comp0 = path_is_absolute(name), + comp = comp0[1].split("/"), + ncomp = []; + for(var i = 0; i < comp.length; i++) + switch(comp[i]){ + case "..": + if(ncomp.length > 1) ncomp.pop(); break; + case ".": break; + case "": break; + default: ncomp.push(comp[i]); break; + } + ncomp.unshift(comp0[0]); + ncomp.orig = name; + return ncomp; + } + function caml_get_root(path){ + var x = path_is_absolute(path); + if(! x) return; + return x[0] + "/"; + } + var + caml_root = + caml_get_root(caml_current_dir) + || caml_failwith("unable to compute caml_root"), + jsoo_mount_point = []; + if(fs_node_supported()) + jsoo_mount_point.push + ({path: caml_root, device: new MlNodeDevice(caml_root)}); + else + jsoo_mount_point.push + ({path: caml_root, device: new MlFakeDevice(caml_root)}); + jsoo_mount_point.push + ({path: "/static/", device: new MlFakeDevice("/static/")}); + function resolve_fs_device(name){ + var + path = caml_make_path(name), + name = path.join("/"), + name_slash = caml_trailing_slash(name), + res; + for(var i = 0; i < jsoo_mount_point.length; i++){ + var m = jsoo_mount_point[i]; + if + (name_slash.search(m.path) == 0 + && (! res || res.path.length < m.path.length)) + res = + {path: m.path, + device: m.device, + rest: name.substring(m.path.length, name.length)}; + } + if(! res && fs_node_supported()){ + var root = caml_get_root(name); + if(root && root.match(/^[a-zA-Z]:\/$/)){ + var m = {path: root, device: new MlNodeDevice(root)}; + jsoo_mount_point.push(m); + res = + {path: m.path, + device: m.device, + rest: name.substring(m.path.length, name.length)}; + } + } + if(res) return res; + caml_raise_sys_error("no device found for " + name_slash); + } + function caml_create_file(name, content){ + var root = resolve_fs_device(name); + if(! root.device.register) caml_failwith("cannot register file"); + root.device.register(root.rest, content); + return 0; + } + function caml_create_string(len){caml_invalid_argument("String.create");} + var caml_custom_event_index = 0, caml_decompress_input = null; + function caml_div(x, y){ + if(y == 0) caml_raise_zero_divide(); + return x / y | 0; + } + var caml_domain_dls = [0]; + function caml_domain_dls_get(unit){return caml_domain_dls;} + function caml_domain_dls_set(a){caml_domain_dls = a;} + var caml_domain_id = 0; + function caml_ml_mutex_unlock(t){t.locked = false; return 0;} + var caml_domain_latest_idx = 1; + function caml_domain_spawn(f, mutex){ + var id = caml_domain_latest_idx++, old = caml_domain_id; + caml_domain_id = id; + var res = caml_callback(f, [0]); + caml_domain_id = old; + caml_ml_mutex_unlock(mutex); + return id; + } + var caml_ephe_data_offset = 2, caml_ephe_key_offset = 3; + function caml_ephe_unset_data(x){ + if(globalThis.FinalizationRegistry && globalThis.WeakRef) + if(x[1] instanceof globalThis.FinalizationRegistry) + for(var j = caml_ephe_key_offset; j < x.length; j++){ + var key = x[j]; + if(key instanceof globalThis.WeakRef){ + key = key.deref(); + if(key) x[1].unregister(key); + } + } + x[caml_ephe_data_offset] = undefined; + return 0; + } + function caml_ephe_set_data(x, data){ + if(globalThis.FinalizationRegistry && globalThis.WeakRef) + if(! (x[1] instanceof globalThis.FinalizationRegistry)){ + x[1] = + new + globalThis.FinalizationRegistry + (function(){caml_ephe_unset_data(x);}); + for(var j = caml_ephe_key_offset; j < x.length; j++){ + var key = x[j]; + if(key instanceof globalThis.WeakRef){ + key = key.deref(); + if(key) x[1].register(key, undefined, key); + } + } + } + x[caml_ephe_data_offset] = data; + return 0; + } + function caml_ephe_blit_data(src, dst){ + var n = src[caml_ephe_data_offset]; + if(n === undefined) + caml_ephe_unset_data(dst); + else + caml_ephe_set_data(dst, n); + return 0; + } + function caml_ephe_blit_key(a1, i1, a2, i2, len){ + caml_array_blit + (a1, + caml_ephe_key_offset + i1 - 1, + a2, + caml_ephe_key_offset + i2 - 1, + len); + return 0; + } + function caml_ephe_check_data(x){ + return x[caml_ephe_data_offset] === undefined ? 0 : 1; + } + function caml_ephe_check_key(x, i){ + var weak = x[caml_ephe_key_offset + i]; + if(globalThis.WeakRef && weak instanceof globalThis.WeakRef) + weak = weak.deref(); + return weak === undefined ? 0 : 1; + } + function caml_weak_create(n){ + if(n < 0) caml_invalid_argument("Weak.create"); + var x = [251, "caml_ephe_list_head"]; + x.length = caml_ephe_key_offset + n; + return x; + } + function caml_ephe_create(n){var x = caml_weak_create(n); return x;} + function caml_ephe_get_data(x){ + return x[caml_ephe_data_offset] === undefined + ? 0 + : [0, x[caml_ephe_data_offset]]; + } + function caml_obj_dup(x){ + var l = x.length, a = new Array(l); + for(var i = 0; i < l; i++) a[i] = x[i]; + return a; + } + function caml_ephe_get_data_copy(x){ + return x[caml_ephe_data_offset] === undefined + ? 0 + : [0, caml_obj_dup(x[caml_ephe_data_offset])]; + } + function caml_ephe_get_key(x, i){ + if(i < 0 || caml_ephe_key_offset + i >= x.length) + caml_invalid_argument("Weak.get_key"); + var weak = x[caml_ephe_key_offset + i]; + if(globalThis.WeakRef && weak instanceof globalThis.WeakRef) + weak = weak.deref(); + return weak === undefined ? 0 : [0, weak]; + } + function caml_ephe_get_key_copy(x, i){ + if(i < 0 || caml_ephe_key_offset + i >= x.length) + caml_invalid_argument("Weak.get_copy"); + var y = caml_ephe_get_key(x, i); + if(y === 0) return y; + var z = y[1]; + if(z instanceof Array) return [0, caml_obj_dup(z)]; + return y; + } + function caml_ephe_set_key(x, i, v){ + if(i < 0 || caml_ephe_key_offset + i >= x.length) + caml_invalid_argument("Weak.set"); + if(v instanceof Object && globalThis.WeakRef){ + if(x[1].register) x[1].register(v, undefined, v); + x[caml_ephe_key_offset + i] = new globalThis.WeakRef(v); + } + else + x[caml_ephe_key_offset + i] = v; + return 0; + } + function caml_ephe_unset_key(x, i){ + if(i < 0 || caml_ephe_key_offset + i >= x.length) + caml_invalid_argument("Weak.set"); + if + (globalThis.WeakRef + && x[caml_ephe_key_offset + i] instanceof globalThis.WeakRef + && x[1].unregister){ + var old = x[caml_ephe_key_offset + i].deref(); + if(old !== undefined){ + var count = 0; + for(var j = caml_ephe_key_offset; j < x.length; j++){ + var key = x[j]; + if(key instanceof globalThis.WeakRef){ + key = key.deref(); + if(key === old) count++; + } + } + if(count == 1) x[1].unregister(old); + } + } + x[caml_ephe_key_offset + i] = undefined; + return 0; + } + function caml_equal(x, y){return + (caml_compare_val(x, y, false) == 0);} + function caml_erf_float(x){ + var + a1 = 0.254829592, + a2 = - 0.284496736, + a3 = 1.421413741, + a4 = - 1.453152027, + a5 = 1.061405429, + p = 0.3275911, + sign = 1; + if(x < 0) sign = - 1; + x = Math.abs(x); + var + t = 1.0 / (1.0 + p * x), + y = + 1.0 + - + ((((a5 * t + a4) * t + a3) * t + a2) * t + a1) * t + * Math.exp(- (x * x)); + return sign * y; + } + function caml_erfc_float(x){return 1 - caml_erf_float(x);} + function caml_eventlog_pause(unit){return 0;} + function caml_eventlog_resume(unit){return 0;} + var caml_executable_name = caml_argv[1]; + function caml_exp2_float(x){return Math.pow(2, x);} + function caml_expm1_float(x){return Math.expm1(x);} + function caml_is_special_exception(exn){ + switch(exn[2]){case - 8:case - 11:case - 12: return 1;default: return 0; + } + } + function caml_format_exception(exn){ + var r = ""; + if(exn[0] == 0){ + r += exn[1][1]; + if + (exn.length == 3 && exn[2][0] == 0 && caml_is_special_exception(exn[1])) + var bucket = exn[2], start = 1; + else + var start = 2, bucket = exn; + r += "("; + for(var i = start; i < bucket.length; i++){ + if(i > start) r += ", "; + var v = bucket[i]; + if(typeof v == "number") + r += v.toString(); + else if(v instanceof MlBytes) + r += '"' + v.toString() + '"'; + else if(typeof v == "string") + r += '"' + v.toString() + '"'; + else + r += "_"; + } + r += ")"; + } + else if(exn[0] == 248) r += exn[1]; + return r; + } + function caml_fatal_uncaught_exception(err){ + if(err instanceof Array && (err[0] == 0 || err[0] == 248)){ + var handler = caml_named_value("Printexc.handle_uncaught_exception"); + if(handler) + caml_callback(handler, [err, false]); + else{ + var + msg = caml_format_exception(err), + at_exit = caml_named_value("Pervasives.do_at_exit"); + if(at_exit) caml_callback(at_exit, [0]); + console.error("Fatal error: exception " + msg); + if(err.js_error) throw err.js_error; + } + } + else + throw err; + } + function caml_fill_bytes(s, i, l, c){ + if(l > 0) + if(i == 0 && (l >= s.l || s.t == 2 && l >= s.c.length)) + if(c == 0){ + s.c = ""; + s.t = 2; + } + else{ + s.c = caml_str_repeat(l, String.fromCharCode(c)); + s.t = l == s.l ? 0 : 2; + } + else{ + if(s.t != 4) caml_convert_bytes_to_array(s); + for(l += i; i < l; i++) s.c[i] = c; + } + return 0; + } + function caml_final_register(){return 0;} + var all_finalizers = new globalThis.Set(); + function caml_final_register_called_without_value(cb, a){ + if(globalThis.FinalizationRegistry && a instanceof Object){ + var + x = + new + globalThis.FinalizationRegistry + (function(x){all_finalizers.delete(x); cb(0); return;}); + x.register(a, x); + all_finalizers.add(x); + } + return 0; + } + function caml_final_release(){return 0;} + function caml_finish_formatting(f, rawbuffer){ + if(f.uppercase) rawbuffer = rawbuffer.toUpperCase(); + var len = rawbuffer.length; + if(f.signedconv && (f.sign < 0 || f.signstyle != "-")) len++; + if(f.alternate){if(f.base == 8) len += 1; if(f.base == 16) len += 2;} + var buffer = ""; + if(f.justify == "+" && f.filler == " ") + for(var i = len; i < f.width; i++) buffer += " "; + if(f.signedconv) + if(f.sign < 0) + buffer += "-"; + else if(f.signstyle != "-") buffer += f.signstyle; + if(f.alternate && f.base == 8) buffer += "0"; + if(f.alternate && f.base == 16) buffer += f.uppercase ? "0X" : "0x"; + if(f.justify == "+" && f.filler == "0") + for(var i = len; i < f.width; i++) buffer += "0"; + buffer += rawbuffer; + if(f.justify == "-") for(var i = len; i < f.width; i++) buffer += " "; + return caml_string_of_jsbytes(buffer); + } + function caml_float_compare(x, y){ + if(x === y) return 0; + if(x < y) return - 1; + if(x > y) return 1; + if(x === x) return 1; + if(y === y) return - 1; + return 0; + } + function caml_float_of_bytes(a){ + return caml_int64_float_of_bits(caml_int64_of_bytes(a)); + } + function caml_float_of_string(s){ + var res; + s = caml_jsbytes_of_string(s); + res = + s; + if(s.length > 0 && res === res) return res; + s = s.replace(/_/g, ""); + res = + s; + if(s.length > 0 && res === res || /^[+-]?nan$/i.test(s)) return res; + var m = /^ *([+-]?)0x([0-9a-f]+)\.?([0-9a-f]*)(p([+-]?[0-9]+))?/i.exec(s); + if(m){ + var + m3 = m[3].replace(/0+$/, ""), + mantissa = parseInt(m[1] + m[2] + m3, 16), + exponent = (m[5] | 0) - 4 * m3.length; + res = mantissa * Math.pow(2, exponent); + return res; + } + if(/^\+?inf(inity)?$/i.test(s)) return Infinity; + if(/^-inf(inity)?$/i.test(s)) return - Infinity; + caml_failwith("float_of_string"); + } + function caml_floatarray_blit(a1, i1, a2, i2, len){ + if(i2 <= i1) + for(var j = 1; j <= len; j++) a2[i2 + j] = a1[i1 + j]; + else + for(var j = len; j >= 1; j--) a2[i2 + j] = a1[i1 + j]; + return 0; + } + function caml_floatarray_create(len){ + if(len < 0) caml_array_bound_error(); + var len = len + 1 | 0, b = new Array(len); + b[0] = 254; + for(var i = 1; i < len; i++) b[i] = 0; + return b; + } + function caml_fma_float(x, y, z){ + var + SPLIT = Math.pow(2, 27) + 1, + MIN_VALUE = Math.pow(2, - 1022), + EPSILON = Math.pow(2, - 52), + C = 416, + A = Math.pow(2, + C), + B = Math.pow(2, - C); + function multiply(a, b){ + var + at = SPLIT * a, + ahi = at - (at - a), + alo = a - ahi, + bt = SPLIT * b, + bhi = bt - (bt - b), + blo = b - bhi, + p = a * b, + e = ahi * bhi - p + ahi * blo + alo * bhi + alo * blo; + return {p: p, e: e}; + } + function add(a, b){ + var s = a + b, v = s - a, e = a - (s - v) + (b - v); + return {s: s, e: e}; + } + function adjust(x, y){ + return x !== 0 && y !== 0 && SPLIT * x - (SPLIT * x - x) === x + ? x * (1 + (x < 0 ? - 1 : + 1) * (y < 0 ? - 1 : + 1) * EPSILON) + : x; + } + if + (x === 0 || x !== x || x === + (1 / 0) || x === - (1 / 0) || y === 0 + || y !== y + || y === + (1 / 0) + || y === - (1 / 0)) + return x * y + z; + if(z === 0) return x * y; + if(z !== z || z === + (1 / 0) || z === - (1 / 0)) return z; + var scale = 1; + while(Math.abs(x) > A){scale *= A; x *= B;} + while(Math.abs(y) > A){scale *= A; y *= B;} + if(scale === 1 / 0) return x * y * scale; + while(Math.abs(x) < B){scale *= B; x *= A;} + while(Math.abs(y) < B){scale *= B; y *= A;} + if(scale === 0) return z; + var xs = x, ys = y, zs = z / scale; + if(Math.abs(zs) > Math.abs(xs * ys) * 4 / EPSILON) return z; + if(Math.abs(zs) < Math.abs(xs * ys) * EPSILON / 4 * EPSILON / 4) + zs = (z < 0 ? - 1 : + 1) * MIN_VALUE; + var + xy = multiply(xs, ys), + s = add(xy.p, zs), + u = add(xy.e, s.e), + i = add(s.s, u.s), + f = i.s + adjust(i.e, u.e); + if(f === 0) return f; + var fs = f * scale; + if(Math.abs(fs) > MIN_VALUE) return fs; + return fs + adjust(f - fs / scale, i.e) * scale; + } + function caml_parse_format(fmt){ + fmt = caml_jsbytes_of_string(fmt); + var len = fmt.length; + if(len > 31) caml_invalid_argument("format_int: format too long"); + var + f = + {justify: "+", + signstyle: "-", + filler: " ", + alternate: false, + base: 0, + signedconv: false, + width: 0, + uppercase: false, + sign: 1, + prec: - 1, + conv: "f"}; + for(var i = 0; i < len; i++){ + var c = fmt.charAt(i); + switch(c){ + case "-": + f.justify = "-"; break; + case "+": + case " ": + f.signstyle = c; break; + case "0": + f.filler = "0"; break; + case "#": + f.alternate = true; break; + case "1": + case "2": + case "3": + case "4": + case "5": + case "6": + case "7": + case "8": + case "9": + f.width = 0; + while(c = fmt.charCodeAt(i) - 48, c >= 0 && c <= 9){f.width = f.width * 10 + c; i++;} + i--; + break; + case ".": + f.prec = 0; + i++; + while(c = fmt.charCodeAt(i) - 48, c >= 0 && c <= 9){f.prec = f.prec * 10 + c; i++;} + i--; + case "d": + case "i": + f.signedconv = true; + case "u": + f.base = 10; break; + case "x": + f.base = 16; break; + case "X": + f.base = 16; f.uppercase = true; break; + case "o": + f.base = 8; break; + case "e": + case "f": + case "g": + f.signedconv = true; f.conv = c; break; + case "E": + case "F": + case "G": + f.signedconv = true; + f.uppercase = true; + f.conv = c.toLowerCase(); + break; + } + } + return f; + } + function caml_format_float(fmt, x){ + function toFixed(x, dp){ + if(Math.abs(x) < 1.0) + return x.toFixed(dp); + else{ + var e = parseInt(x.toString().split("+")[1]); + if(e > 20){ + e -= 20; + x /= Math.pow(10, e); + x += new Array(e + 1).join("0"); + if(dp > 0) x = x + "." + new Array(dp + 1).join("0"); + return x; + } + else + return x.toFixed(dp); + } + } + var s, f = caml_parse_format(fmt), prec = f.prec < 0 ? 6 : f.prec; + if(x < 0 || x == 0 && 1 / x == - Infinity){f.sign = - 1; x = - x;} + if(isNaN(x)){ + s = "nan"; + f.filler = " "; + } + else if(! isFinite(x)){ + s = "inf"; + f.filler = " "; + } + else + switch(f.conv){ + case "e": + var s = x.toExponential(prec), i = s.length; + if(s.charAt(i - 3) == "e") + s = s.slice(0, i - 1) + "0" + s.slice(i - 1); + break; + case "f": + s = toFixed(x, prec); break; + case "g": + prec = prec ? prec : 1; + s = x.toExponential(prec - 1); + var j = s.indexOf("e"), exp = + s.slice(j + 1); + if(exp < - 4 || x >= 1e21 || x.toFixed(0).length > prec){ + var i = j - 1; + while(s.charAt(i) == "0") i--; + if(s.charAt(i) == ".") i--; + s = s.slice(0, i + 1) + s.slice(j); + i = s.length; + if(s.charAt(i - 3) == "e") + s = s.slice(0, i - 1) + "0" + s.slice(i - 1); + break; + } + else{ + var p = prec; + if(exp < 0){ + p -= exp + 1; + s = x.toFixed(p); + } + else + while(s = x.toFixed(p), s.length > prec + 1) p--; + if(p){ + var i = s.length - 1; + while(s.charAt(i) == "0") i--; + if(s.charAt(i) == ".") i--; + s = s.slice(0, i + 1); + } + } + break; + } + return caml_finish_formatting(f, s); + } + function caml_format_int(fmt, i){ + if(caml_jsbytes_of_string(fmt) == "%d") + return caml_string_of_jsbytes("" + i); + var f = caml_parse_format(fmt); + if(i < 0) if(f.signedconv){f.sign = - 1; i = - i;} else i >>>= 0; + var s = i.toString(f.base); + if(f.prec >= 0){ + f.filler = " "; + var n = f.prec - s.length; + if(n > 0) s = caml_str_repeat(n, "0") + s; + } + return caml_finish_formatting(f, s); + } + var caml_oo_last_id = 0; + function caml_fresh_oo_id(){return caml_oo_last_id++;} + function caml_frexp_float(x){ + if(x == 0 || ! isFinite(x)) return [0, x, 0]; + var neg = x < 0; + if(neg) x = - x; + var exp = Math.max(- 1023, jsoo_floor_log2(x) + 1); + x *= Math.pow(2, - exp); + while(x < 0.5){x *= 2; exp--;} + while(x >= 1){x *= 0.5; exp++;} + if(neg) x = - x; + return [0, x, exp]; + } + function jsoo_create_file(name, content){ + var + name = caml_string_of_jsbytes(name), + content = caml_string_of_jsbytes(content); + return caml_create_file(name, content); + } + function caml_fs_init(){ + var tmp = globalThis.caml_fs_tmp; + if(tmp) + for(var i = 0; i < tmp.length; i++) + jsoo_create_file(tmp[i].name, tmp[i].content); + globalThis.jsoo_create_file = jsoo_create_file; + globalThis.caml_fs_tmp = []; + return 0; + } + function caml_gc_compaction(){return 0;} + function caml_gc_counters(){return [254, 0, 0, 0];} + function caml_gc_full_major(unit){ + if(typeof globalThis.gc == "function") globalThis.gc(); + return 0; + } + function caml_gc_get(){return [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0];} + function caml_gc_huge_fallback_count(unit){return 0;} + function caml_gc_major(unit){ + if(typeof globalThis.gc == "function") globalThis.gc(); + return 0; + } + function caml_gc_major_slice(work){return 0;} + function caml_gc_minor(unit){ + if(typeof globalThis.gc == "function") globalThis.gc(true); + return 0; + } + function caml_gc_minor_words(unit){return 0;} + function caml_gc_quick_stat(){ + return [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]; + } + function caml_gc_set(_control){return 0;} + function caml_gc_stat(){return caml_gc_quick_stat();} + function caml_get_continuation_callstack(){return [0];} + function caml_get_current_callstack(){return [0];} + function caml_get_exception_backtrace(){return 0;} + function caml_get_exception_raw_backtrace(){return [0];} + function caml_get_global_data(){return caml_global_data;} + function caml_get_major_bucket(n){return 0;} + function caml_get_major_credit(n){return 0;} + function caml_get_minor_free(unit){return 0;} + var caml_method_cache = []; + function caml_get_public_method(obj, tag, cacheid){ + var meths = obj[1], ofs = caml_method_cache[cacheid]; + if(ofs === undefined) + for(var i = caml_method_cache.length; i < cacheid; i++) + caml_method_cache[i] = 0; + else if(meths[ofs] === tag) return meths[ofs - 1]; + var li = 3, hi = meths[1] * 2 + 1, mi; + while(li < hi){ + mi = li + hi >> 1 | 1; + if(tag < meths[mi + 1]) hi = mi - 2; else li = mi; + } + caml_method_cache[cacheid] = li + 1; + return tag == meths[li + 1] ? meths[li] : 0; + } + function caml_gr_arc_aux(ctx, cx, cy, ry, rx, a1, a2){ + while(a1 > a2) a2 += 360; + a1 /= 180; + a2 /= 180; + var + rot = 0, + xPos, + yPos, + xPos_prev, + yPos_prev, + space = 2, + num = (a2 - a1) * Math.PI * ((rx + ry) / 2) / space | 0, + delta = (a2 - a1) * Math.PI / num, + i = a1 * Math.PI; + for(var j = 0; j <= num; j++){ + xPos = + cx - rx * Math.sin(i) * Math.sin(rot * Math.PI) + + ry * Math.cos(i) * Math.cos(rot * Math.PI); + xPos = xPos.toFixed(2); + yPos = + cy + ry * Math.cos(i) * Math.sin(rot * Math.PI) + + rx * Math.sin(i) * Math.cos(rot * Math.PI); + yPos = yPos.toFixed(2); + if(j == 0) + ctx.moveTo(xPos, yPos); + else if(xPos_prev != xPos || yPos_prev != yPos) ctx.lineTo(xPos, yPos); + xPos_prev = xPos; + yPos_prev = yPos; + i -= delta; + } + return 0; + } + var caml_gr_state; + function caml_gr_state_get(){ + if(caml_gr_state) return caml_gr_state; + throw caml_maybe_attach_backtrace + ([0, + caml_named_value("Graphics.Graphic_failure"), + caml_string_of_jsbytes("Not initialized")]); + } + function caml_gr_blit_image(im, x, y){ + var + s = caml_gr_state_get(), + im2 = + s.context.getImageData + (x, s.height - im.height - y, im.width, im.height); + for(var i = 0; i < im2.data.length; i += 4){ + im.data[i] = im2.data[i]; + im.data[i + 1] = im2.data[i + 1]; + im.data[i + 2] = im2.data[i + 2]; + im.data[i + 3] = im2.data[i + 3]; + } + return 0; + } + function caml_gr_clear_graph(){ + var s = caml_gr_state_get(); + s.canvas.width = s.width; + s.canvas.height = s.height; + return 0; + } + function caml_gr_close_graph(){ + var s = caml_gr_state_get(); + s.canvas.width = 0; + s.canvas.height = 0; + return 0; + } + function caml_gr_close_subwindow(a){ + caml_failwith("caml_gr_close_subwindow not Implemented"); + } + function caml_gr_create_image(x, y){ + var s = caml_gr_state_get(); + return s.context.createImageData(x, y); + } + function caml_gr_current_x(){var s = caml_gr_state_get(); return s.x;} + function caml_gr_current_y(){var s = caml_gr_state_get(); return s.y;} + function caml_gr_display_mode(){ + caml_failwith("caml_gr_display_mode not Implemented"); + } + function caml_gr_doc_of_state(state){ + if(state.canvas.ownerDocument) return state.canvas.ownerDocument; + } + function caml_gr_draw_arc(x, y, rx, ry, a1, a2){ + var s = caml_gr_state_get(); + s.context.beginPath(); + caml_gr_arc_aux(s.context, x, s.height - y, rx, ry, a1, a2); + s.context.stroke(); + return 0; + } + function caml_gr_draw_str(str){ + var s = caml_gr_state_get(), m = s.context.measureText(str), dx = m.width; + s.context.fillText(str, s.x, s.height - s.y); + s.x += dx | 0; + return 0; + } + function caml_gr_draw_char(c){ + caml_gr_draw_str(String.fromCharCode(c)); + return 0; + } + function caml_gr_draw_image(im, x, y){ + var s = caml_gr_state_get(); + if(! im.image){ + var canvas = document.createElement("canvas"); + canvas.width = s.width; + canvas.height = s.height; + canvas.getContext("2d").putImageData(im, 0, 0); + var image = new globalThis.Image(); + image.onload = + function(){ + s.context.drawImage(image, x, s.height - im.height - y); + im.image = image; + }; + image.src = canvas.toDataURL("image/png"); + } + else + s.context.drawImage(im.image, x, s.height - im.height - y); + return 0; + } + function caml_gr_draw_rect(x, y, w, h){ + var s = caml_gr_state_get(); + s.context.strokeRect(x, s.height - y, w, - h); + return 0; + } + function caml_gr_draw_string(str){ + caml_gr_draw_str(caml_jsstring_of_string(str)); + return 0; + } + function caml_gr_dump_image(im){ + var data = [0]; + for(var i = 0; i < im.height; i++){ + data[i + 1] = [0]; + for(var j = 0; j < im.width; j++){ + var + o = i * (im.width * 4) + j * 4, + r = im.data[o + 0], + g = im.data[o + 1], + b = im.data[o + 2]; + data[i + 1][j + 1] = (r << 16) + (g << 8) + b; + } + } + return data; + } + function caml_gr_fill_arc(x, y, rx, ry, a1, a2){ + var s = caml_gr_state_get(); + s.context.beginPath(); + caml_gr_arc_aux(s.context, x, s.height - y, rx, ry, a1, a2); + s.context.fill(); + return 0; + } + function caml_gr_fill_poly(ar){ + var s = caml_gr_state_get(); + s.context.beginPath(); + s.context.moveTo(ar[1][1], s.height - ar[1][2]); + for(var i = 2; i < ar.length; i++) + s.context.lineTo(ar[i][1], s.height - ar[i][2]); + s.context.lineTo(ar[1][1], s.height - ar[1][2]); + s.context.fill(); + return 0; + } + function caml_gr_fill_rect(x, y, w, h){ + var s = caml_gr_state_get(); + s.context.fillRect(x, s.height - y, w, - h); + return 0; + } + function caml_gr_lineto(x, y){ + var s = caml_gr_state_get(); + s.context.beginPath(); + s.context.moveTo(s.x, s.height - s.y); + s.context.lineTo(x, s.height - y); + s.context.stroke(); + s.x = x; + s.y = y; + return 0; + } + function caml_gr_make_image(arr){ + var + s = caml_gr_state_get(), + h = arr.length - 1, + w = arr[1].length - 1, + im = s.context.createImageData(w, h); + for(var i = 0; i < h; i++) + for(var j = 0; j < w; j++){ + var c = arr[i + 1][j + 1], o = i * (w * 4) + j * 4; + if(c == - 1){ + im.data[o + 0] = 0; + im.data[o + 1] = 0; + im.data[o + 2] = 0; + im.data[o + 3] = 0; + } + else{ + im.data[o + 0] = c >> 16 & 0xff; + im.data[o + 1] = c >> 8 & 0xff; + im.data[o + 2] = c >> 0 & 0Xff; + im.data[o + 3] = 0xff; + } + } + return im; + } + function caml_gr_moveto(x, y){ + var s = caml_gr_state_get(); + s.x = x; + s.y = y; + return 0; + } + function caml_gr_set_window_title(name){ + var s = caml_gr_state_get(); + s.title = name; + var jsname = caml_jsstring_of_string(name); + if(s.set_title) s.set_title(jsname); + return 0; + } + function caml_gr_set_line_width(w){ + var s = caml_gr_state_get(); + s.line_width = w; + s.context.lineWidth = w; + return 0; + } + function caml_gr_set_text_size(size){ + var s = caml_gr_state_get(); + s.text_size = size; + s.context.font = s.text_size + "px " + caml_jsstring_of_string(s.font); + return 0; + } + function caml_gr_set_font(f){ + var s = caml_gr_state_get(); + s.font = f; + s.context.font = s.text_size + "px " + caml_jsstring_of_string(s.font); + return 0; + } + function caml_gr_set_color(color){ + var s = caml_gr_state_get(); + function convert(number){ + var str = "" + number.toString(16); + while(str.length < 2) str = "0" + str; + return str; + } + var r = color >> 16 & 0xff, g = color >> 8 & 0xff, b = color >> 0 & 0xff; + s.color = color; + var c_str = "#" + convert(r) + convert(g) + convert(b); + s.context.fillStyle = c_str; + s.context.strokeStyle = c_str; + return 0; + } + function caml_gr_resize_window(w, h){ + var s = caml_gr_state_get(); + s.width = w; + s.height = h; + s.canvas.width = w; + s.canvas.height = h; + return 0; + } + function caml_gr_state_init(){ + caml_gr_moveto(caml_gr_state.x, caml_gr_state.y); + caml_gr_resize_window(caml_gr_state.width, caml_gr_state.height); + caml_gr_set_line_width(caml_gr_state.line_width); + caml_gr_set_text_size(caml_gr_state.text_size); + caml_gr_set_font(caml_gr_state.font); + caml_gr_set_color(caml_gr_state.color); + caml_gr_set_window_title(caml_gr_state.title); + caml_gr_state.context.textBaseline = "bottom"; + } + function caml_gr_state_set(ctx){ + caml_gr_state = ctx; + caml_gr_state_init(); + return 0; + } + function caml_gr_state_create(canvas, w, h){ + var context = canvas.getContext("2d"); + return {context: context, + canvas: canvas, + x: 0, + y: 0, + width: w, + height: h, + line_width: 1, + font: caml_string_of_jsbytes("fixed"), + text_size: 26, + color: 0x000000, + title: caml_string_of_jsbytes("")}; + } + function caml_gr_open_graph(info){ + var info = caml_jsstring_of_string(info); + function get(name){ + var res = info.match("(^|,) *" + name + " *= *([a-zA-Z0-9_]+) *(,|$)"); + if(res) return res[2]; + } + var specs = []; + if(! (info == "")) specs.push(info); + var target = get("target"); + if(! target) target = ""; + var status = get("status"); + if(! status) specs.push("status=1"); + var w = get("width"); + w = w ? parseInt(w) : 200; + specs.push("width=" + w); + var h = get("height"); + h = h ? parseInt(h) : 200; + specs.push("height=" + h); + var win = globalThis.open("about:blank", target, specs.join(",")); + if(! win) caml_failwith("Graphics.open_graph: cannot open the window"); + var doc = win.document, canvas = doc.createElement("canvas"); + canvas.width = w; + canvas.height = h; + var ctx = caml_gr_state_create(canvas, w, h); + ctx.set_title = function(title){doc.title = title;}; + caml_gr_state_set(ctx); + var body = doc.body; + body.style.margin = "0px"; + body.appendChild(canvas); + return 0; + } + function caml_gr_open_subwindow(a, b, c, d){ + caml_failwith("caml_gr_open_subwindow not Implemented"); + } + function caml_gr_plot(x, y){ + var + s = caml_gr_state_get(), + im = s.context.createImageData(1, 1), + d = im.data, + color = s.color; + d[0] = color >> 16 & 0xff; + d[1] = color >> 8 & 0xff, d[2] = color >> 0 & 0xff; + d[3] = 0xFF; + s.x = x; + s.y = y; + s.context.putImageData(im, x, s.height - y); + return 0; + } + function caml_gr_point_color(x, y){ + var + s = caml_gr_state_get(), + im = s.context.getImageData(x, s.height - y, 1, 1), + d = im.data; + return (d[0] << 16) + (d[1] << 8) + d[2]; + } + function caml_gr_remember_mode(){ + caml_failwith("caml_gr_remember_mode not Implemented"); + } + function caml_gr_sigio_handler(){return 0;} + function caml_gr_sigio_signal(){return 0;} + function caml_gr_size_x(){var s = caml_gr_state_get(); return s.width;} + function caml_gr_size_y(){var s = caml_gr_state_get(); return s.height;} + function caml_gr_synchronize(){ + caml_failwith("caml_gr_synchronize not Implemented"); + } + function caml_gr_text_size(txt){ + var + s = caml_gr_state_get(), + w = s.context.measureText(caml_jsstring_of_string(txt)).width; + return [0, w, s.text_size]; + } + function caml_gr_wait_event(_evl){ + caml_failwith + ("caml_gr_wait_event not Implemented: use Graphics_js instead"); + } + function caml_gr_window_id(a){ + caml_failwith("caml_gr_window_id not Implemented"); + } + function caml_greaterequal(x, y){ + return + (caml_compare_val(x, y, false) >= 0); + } + function caml_greaterthan(x, y){ + return + (caml_compare_val(x, y, false) > 0); + } + function caml_hash_mix_jsbytes(h, s){ + var len = s.length, i, w; + for(i = 0; i + 4 <= len; i += 4){ + w = + s.charCodeAt(i) | s.charCodeAt(i + 1) << 8 | s.charCodeAt(i + 2) << 16 + | s.charCodeAt(i + 3) << 24; + h = caml_hash_mix_int(h, w); + } + w = 0; + switch(len & 3){ + case 3: + w = s.charCodeAt(i + 2) << 16; + case 2: + w |= s.charCodeAt(i + 1) << 8; + case 1: + w |= s.charCodeAt(i); h = caml_hash_mix_int(h, w); + } + h ^= len; + return h; + } + function caml_hash_mix_string(h, v){ + return caml_hash_mix_jsbytes(h, caml_jsbytes_of_string(v)); + } + function caml_hash_mix_bytes_arr(h, s){ + var len = s.length, i, w; + for(i = 0; i + 4 <= len; i += 4){ + w = s[i] | s[i + 1] << 8 | s[i + 2] << 16 | s[i + 3] << 24; + h = caml_hash_mix_int(h, w); + } + w = 0; + switch(len & 3){ + case 3: + w = s[i + 2] << 16; + case 2: + w |= s[i + 1] << 8; + case 1: + w |= s[i]; h = caml_hash_mix_int(h, w); + } + h ^= len; + return h; + } + function caml_ml_bytes_content(s){ + switch(s.t & 6){ + default: caml_convert_string_to_bytes(s); + case 0: + return s.c; + case 4: + return s.c; + } + } + function caml_hash_mix_bytes(h, v){ + var content = caml_ml_bytes_content(v); + return typeof content === "string" + ? caml_hash_mix_jsbytes(h, content) + : caml_hash_mix_bytes_arr(h, content); + } + function caml_hash_mix_final(h){ + h ^= h >>> 16; + h = caml_mul(h, 0x85ebca6b | 0); + h ^= h >>> 13; + h = caml_mul(h, 0xc2b2ae35 | 0); + h ^= h >>> 16; + return h; + } + function caml_hash(count, limit, seed, obj){ + var queue, rd, wr, sz, num, h, v, i, len; + sz = limit; + if(sz < 0 || sz > 256) sz = 256; + num = count; + h = seed; + queue = [obj]; + rd = 0; + wr = 1; + while(rd < wr && num > 0){ + v = queue[rd++]; + if(v && v.caml_custom){ + if + (caml_custom_ops[v.caml_custom] && caml_custom_ops[v.caml_custom].hash){ + var hh = caml_custom_ops[v.caml_custom].hash(v); + h = caml_hash_mix_int(h, hh); + num--; + } + } + else if(v instanceof Array && v[0] === (v[0] | 0)) + switch(v[0]){ + case 248: + h = caml_hash_mix_int(h, v[2]); num--; break; + case 250: + queue[--rd] = v[1]; break; + default: + if(caml_is_continuation_tag(v[0])) break; + var tag = v.length - 1 << 10 | v[0]; + h = caml_hash_mix_int(h, tag); + for(i = 1, len = v.length; i < len; i++){if(wr >= sz) break; queue[wr++] = v[i]; + } + break; + } + else if(caml_is_ml_bytes(v)){ + h = caml_hash_mix_bytes(h, v); + num--; + } + else if(caml_is_ml_string(v)){ + h = caml_hash_mix_string(h, v); + num--; + } + else if(typeof v === "string"){ + h = caml_hash_mix_jsbytes(h, v); + num--; + } + else if(v === (v | 0)){ + h = caml_hash_mix_int(h, v + v + 1); + num--; + } + else if(typeof v === "number"){h = caml_hash_mix_float(h, v); num--;} + } + h = caml_hash_mix_final(h); + return h & 0x3FFFFFFF; + } + function caml_hash_mix_bigstring(h, bs){ + return caml_hash_mix_bytes_arr(h, bs.data); + } + function num_digits_nat(nat, ofs, len){ + for(var i = len - 1; i >= 0; i--) if(nat.data[ofs + i] != 0) return i + 1; + return 1; + } + function caml_hash_nat(x){ + var len = num_digits_nat(x, 0, x.data.length), h = 0; + for(var i = 0; i < len; i++) h = caml_hash_mix_int(h, x.data[i]); + return h; + } + function caml_hexstring_of_float(x, prec, style){ + if(! isFinite(x)){ + if(isNaN(x)) return caml_string_of_jsstring("nan"); + return caml_string_of_jsstring(x > 0 ? "infinity" : "-infinity"); + } + var sign = x == 0 && 1 / x == - Infinity ? 1 : x >= 0 ? 0 : 1; + if(sign) x = - x; + var exp = 0; + if(x == 0) + ; + else if(x < 1) + while(x < 1 && exp > - 1022){x *= 2; exp--;} + else + while(x >= 2){x /= 2; exp++;} + var exp_sign = exp < 0 ? "" : "+", sign_str = ""; + if(sign) + sign_str = "-"; + else + switch(style){ + case 43: + sign_str = "+"; break; + case 32: + sign_str = " "; break; + default: break; + } + if(prec >= 0 && prec < 13){ + var cst = Math.pow(2, prec * 4); + x = Math.round(x * cst) / cst; + } + var x_str = x.toString(16); + if(prec >= 0){ + var idx = x_str.indexOf("."); + if(idx < 0) + x_str += "." + caml_str_repeat(prec, "0"); + else{ + var size = idx + 1 + prec; + if(x_str.length < size) + x_str += caml_str_repeat(size - x_str.length, "0"); + else + x_str = x_str.substr(0, size); + } + } + return caml_string_of_jsstring + (sign_str + "0x" + x_str + "p" + exp_sign + exp.toString(10)); + } + function caml_hypot_float(x, y){return Math.hypot(x, y);} + var caml_marshal_header_size = 20; + function caml_refill(chan){ + if(chan.refill != null){ + var str = chan.refill(), str_a = caml_uint8_array_of_string(str); + if(str_a.length == 0) + chan.refill = null; + else{ + if(chan.buffer.length < chan.buffer_max + str_a.length){ + var b = new Uint8Array(chan.buffer_max + str_a.length); + b.set(chan.buffer); + chan.buffer = b; + } + chan.buffer.set(str_a, chan.buffer_max); + chan.offset += str_a.length; + chan.buffer_max += str_a.length; + } + } + else{ + var + nread = + chan.file.read + (chan.offset, + chan.buffer, + chan.buffer_max, + chan.buffer.length - chan.buffer_max); + chan.offset += nread; + chan.buffer_max += nread; + } + } + function caml_raise_end_of_file(){ + caml_raise_constant(caml_global_data.End_of_file); + } + function caml_marshal_data_size(s, ofs){ + var r = new UInt8ArrayReader(caml_uint8_array_of_bytes(s), ofs); + function readvlq(overflow){ + var c = r.read8u(), n = c & 0x7F; + while((c & 0x80) != 0){ + c = r.read8u(); + var n7 = n << 7; + if(n != n7 >> 7) overflow[0] = true; + n = n7 | c & 0x7F; + } + return n; + } + switch(r.read32u()){ + case 0x8495A6BE: + var header_len = 20, data_len = r.read32u(); break; + case 0x8495A6BD: + var + header_len = r.read8u() & 0x3F, + overflow = [false], + data_len = readvlq(overflow); + if(overflow[0]) + caml_failwith + ("Marshal.data_size: object too large to be read back on this platform"); + break; + case 0x8495A6BF: + default: caml_failwith("Marshal.data_size: bad object"); break; + } + return header_len - caml_marshal_header_size + data_len; + } + function caml_input_value_from_reader(reader, ofs){ + function readvlq(overflow){ + var c = reader.read8u(), n = c & 0x7F; + while((c & 0x80) != 0){ + c = reader.read8u(); + var n7 = n << 7; + if(n != n7 >> 7) overflow[0] = true; + n = n7 | c & 0x7F; + } + return n; + } + var magic = reader.read32u(); + switch(magic){ + case 0x8495A6BE: + var + header_len = 20, + compressed = 0, + data_len = reader.read32u(), + uncompressed_data_len = data_len, + num_objects = reader.read32u(), + _size_32 = reader.read32u(), + _size_64 = reader.read32u(); + break; + case 0x8495A6BD: + var + header_len = reader.read8u() & 0x3F, + compressed = 1, + overflow = [false], + data_len = readvlq(overflow), + uncompressed_data_len = readvlq(overflow), + num_objects = readvlq(overflow), + _size_32 = readvlq(overflow), + _size_64 = readvlq(overflow); + if(overflow[0]) + caml_failwith + ("caml_input_value_from_reader: object too large to be read back on this platform"); + break; + case 0x8495A6BF: + caml_failwith + ("caml_input_value_from_reader: object too large to be read back on a 32-bit platform"); + break; + default: + caml_failwith("caml_input_value_from_reader: bad object"); break; + } + var + stack = [], + intern_obj_table = num_objects > 0 ? [] : null, + obj_counter = 0; + function intern_rec(reader){ + var code = reader.read8u(); + if(code >= 0x40) + if(code >= 0x80){ + var tag = code & 0xF, size = code >> 4 & 0x7, v = [tag]; + if(size == 0) return v; + if(intern_obj_table) intern_obj_table[obj_counter++] = v; + stack.push(v, size); + return v; + } + else + return code & 0x3F; + else if(code >= 0x20){ + var len = code & 0x1F, v = reader.readstr(len); + if(intern_obj_table) intern_obj_table[obj_counter++] = v; + return v; + } + else + switch(code){ + case 0x00: + return reader.read8s(); + case 0x01: + return reader.read16s(); + case 0x02: + return reader.read32s(); + case 0x03: + caml_failwith("input_value: integer too large"); break; + case 0x04: + var offset = reader.read8u(); + if(compressed == 0) offset = obj_counter - offset; + return intern_obj_table[offset]; + case 0x05: + var offset = reader.read16u(); + if(compressed == 0) offset = obj_counter - offset; + return intern_obj_table[offset]; + case 0x06: + var offset = reader.read32u(); + if(compressed == 0) offset = obj_counter - offset; + return intern_obj_table[offset]; + case 0x08: + var + header = reader.read32u(), + tag = header & 0xFF, + size = header >> 10, + v = [tag]; + if(size == 0) return v; + if(intern_obj_table) intern_obj_table[obj_counter++] = v; + stack.push(v, size); + return v; + case 0x13: + caml_failwith("input_value: data block too large"); break; + case 0x09: + var len = reader.read8u(), v = reader.readstr(len); + if(intern_obj_table) intern_obj_table[obj_counter++] = v; + return v; + case 0x0A: + var len = reader.read32u(), v = reader.readstr(len); + if(intern_obj_table) intern_obj_table[obj_counter++] = v; + return v; + case 0x0C: + var t = new Array(8); + for(var i = 0; i < 8; i++) t[7 - i] = reader.read8u(); + var v = caml_float_of_bytes(t); + if(intern_obj_table) intern_obj_table[obj_counter++] = v; + return v; + case 0x0B: + var t = new Array(8); + for(var i = 0; i < 8; i++) t[i] = reader.read8u(); + var v = caml_float_of_bytes(t); + if(intern_obj_table) intern_obj_table[obj_counter++] = v; + return v; + case 0x0E: + var len = reader.read8u(), v = new Array(len + 1); + v[0] = 254; + var t = new Array(8); + if(intern_obj_table) intern_obj_table[obj_counter++] = v; + for(var i = 1; i <= len; i++){ + for(var j = 0; j < 8; j++) t[7 - j] = reader.read8u(); + v[i] = caml_float_of_bytes(t); + } + return v; + case 0x0D: + var len = reader.read8u(), v = new Array(len + 1); + v[0] = 254; + var t = new Array(8); + if(intern_obj_table) intern_obj_table[obj_counter++] = v; + for(var i = 1; i <= len; i++){ + for(var j = 0; j < 8; j++) t[j] = reader.read8u(); + v[i] = caml_float_of_bytes(t); + } + return v; + case 0x07: + var len = reader.read32u(), v = new Array(len + 1); + v[0] = 254; + if(intern_obj_table) intern_obj_table[obj_counter++] = v; + var t = new Array(8); + for(var i = 1; i <= len; i++){ + for(var j = 0; j < 8; j++) t[7 - j] = reader.read8u(); + v[i] = caml_float_of_bytes(t); + } + return v; + case 0x0F: + var len = reader.read32u(), v = new Array(len + 1); + v[0] = 254; + var t = new Array(8); + for(var i = 1; i <= len; i++){ + for(var j = 0; j < 8; j++) t[j] = reader.read8u(); + v[i] = caml_float_of_bytes(t); + } + return v; + case 0x10: + case 0x11: + caml_failwith("input_value: code pointer"); break; + case 0x12: + case 0x18: + case 0x19: + var c, s = ""; + while((c = reader.read8u()) != 0) s += String.fromCharCode(c); + var ops = caml_custom_ops[s], expected_size; + if(! ops) + caml_failwith("input_value: unknown custom block identifier"); + switch(code){ + case 0x12: break; + case 0x19: + if(! ops.fixed_length) + caml_failwith("input_value: expected a fixed-size custom block"); + expected_size = ops.fixed_length; + break; + case 0x18: + expected_size = reader.read32u(); + reader.read32s(); + reader.read32s(); + break; + } + var + old_pos = reader.i, + size = [0], + v = ops.deserialize(reader, size); + if(expected_size != undefined) + if(expected_size != size[0]) + caml_failwith + ("input_value: incorrect length of serialized custom block"); + if(intern_obj_table) intern_obj_table[obj_counter++] = v; + return v; + default: caml_failwith("input_value: ill-formed message"); + } + } + if(compressed) + if(caml_decompress_input) + var + data = reader.readuint8array(data_len), + res = new Uint8Array(uncompressed_data_len), + res = caml_decompress_input(data, res), + reader = new UInt8ArrayReader(res, 0); + else + caml_failwith("input_value: compressed object, cannot decompress"); + var res = intern_rec(reader); + while(stack.length > 0){ + var size = stack.pop(), v = stack.pop(), d = v.length; + if(d < size) stack.push(v, size); + v[d] = intern_rec(reader); + } + if(typeof ofs != "number") ofs[0] = reader.i; + return res; + } + function caml_string_of_bytes(s){ + s.t & 6 && caml_convert_string_to_bytes(s); + return caml_string_of_jsbytes(s.c); + } + function caml_input_value_from_bytes(s, ofs){ + var + reader = + new + MlStringReader + (caml_string_of_bytes(s), typeof ofs == "number" ? ofs : ofs[0]); + return caml_input_value_from_reader(reader, ofs); + } + function caml_input_value(chanid){ + var + chan = caml_ml_channel_get(chanid), + header = new Uint8Array(caml_marshal_header_size); + function block(buffer, offset, n){ + var r = 0; + while(r < n){ + if(chan.buffer_curr >= chan.buffer_max){ + chan.buffer_curr = 0; + chan.buffer_max = 0; + caml_refill(chan); + } + if(chan.buffer_curr >= chan.buffer_max) break; + buffer[offset + r] = chan.buffer[chan.buffer_curr]; + chan.buffer_curr++; + r++; + } + return r; + } + var r = block(header, 0, caml_marshal_header_size); + if(r == 0) + caml_raise_end_of_file(); + else if(r < caml_marshal_header_size) + caml_failwith("input_value: truncated object"); + var + len = caml_marshal_data_size(caml_bytes_of_array(header), 0), + buf = new Uint8Array(len + caml_marshal_header_size); + buf.set(header, 0); + var r = block(buf, caml_marshal_header_size, len); + if(r < len) + caml_failwith("input_value: truncated object " + r + " " + len); + var + offset = [0], + res = caml_input_value_from_bytes(caml_bytes_of_array(buf), offset); + chan.offset = chan.offset + offset[0]; + return res; + } + function caml_input_value_from_string(s, ofs){ + var reader = new MlStringReader(s, typeof ofs == "number" ? ofs : ofs[0]); + return caml_input_value_from_reader(reader, ofs); + } + function caml_input_value_to_outside_heap(c){return caml_input_value(c);} + function caml_install_signal_handler(){return 0;} + function caml_int32_bswap(x){ + return (x & 0x000000FF) << 24 | (x & 0x0000FF00) << 8 + | (x & 0x00FF0000) >>> 8 + | (x & 0xFF000000) >>> 24; + } + function caml_int64_add(x, y){return x.add(y);} + function caml_int64_and(x, y){return x.and(y);} + function caml_int64_bswap(x){ + var y = caml_int64_to_bytes(x); + return caml_int64_of_bytes + ([y[7], y[6], y[5], y[4], y[3], y[2], y[1], y[0]]); + } + function caml_int64_div(x, y){return x.div(y);} + function caml_int64_is_zero(x){return + x.isZero();} + function caml_int64_of_int32(x){ + return new MlInt64(x & 0xffffff, x >> 24 & 0xffffff, x >> 31 & 0xffff); + } + function caml_int64_to_int32(x){return x.toInt();} + function caml_int64_is_negative(x){return + x.isNeg();} + function caml_int64_neg(x){return x.neg();} + function caml_int64_format(fmt, x){ + var f = caml_parse_format(fmt); + if(f.signedconv && caml_int64_is_negative(x)){f.sign = - 1; x = caml_int64_neg(x);} + var + buffer = "", + wbase = caml_int64_of_int32(f.base), + cvtbl = "0123456789abcdef"; + do{ + var p = x.udivmod(wbase); + x = p.quotient; + buffer = cvtbl.charAt(caml_int64_to_int32(p.modulus)) + buffer; + } + while + (! caml_int64_is_zero(x)); + if(f.prec >= 0){ + f.filler = " "; + var n = f.prec - buffer.length; + if(n > 0) buffer = caml_str_repeat(n, "0") + buffer; + } + return caml_finish_formatting(f, buffer); + } + function caml_int64_mod(x, y){return x.mod(y);} + function caml_int64_mul(x, y){return x.mul(y);} + function caml_int64_of_float(x){ + if(x < 0) x = Math.ceil(x); + return new + MlInt64 + (x & 0xffffff, + Math.floor(x * caml_int64_offset) & 0xffffff, + Math.floor(x * caml_int64_offset * caml_int64_offset) & 0xffff); + } + function caml_int64_ult(x, y){return x.ucompare(y) < 0;} + function caml_parse_sign_and_base(s){ + var i = 0, len = caml_ml_string_length(s), base = 10, sign = 1; + if(len > 0) + switch(caml_string_unsafe_get(s, i)){ + case 45: + i++; sign = - 1; break; + case 43: + i++; sign = 1; break; + } + if(i + 1 < len && caml_string_unsafe_get(s, i) == 48) + switch(caml_string_unsafe_get(s, i + 1)){ + case 120: + case 88: + base = 16; i += 2; break; + case 111: + case 79: + base = 8; i += 2; break; + case 98: + case 66: + base = 2; i += 2; break; + case 117: + case 85: + i += 2; break; + } + return [i, sign, base]; + } + function caml_parse_digit(c){ + if(c >= 48 && c <= 57) return c - 48; + if(c >= 65 && c <= 90) return c - 55; + if(c >= 97 && c <= 122) return c - 87; + return - 1; + } + function caml_int64_of_string(s){ + var + r = caml_parse_sign_and_base(s), + i = r[0], + sign = r[1], + base = r[2], + base64 = caml_int64_of_int32(base), + threshold = + new MlInt64(0xffffff, 0xfffffff, 0xffff).udivmod(base64).quotient, + c = caml_string_unsafe_get(s, i), + d = caml_parse_digit(c); + if(d < 0 || d >= base) caml_failwith("int_of_string"); + var res = caml_int64_of_int32(d); + for(;;){ + i++; + c = caml_string_unsafe_get(s, i); + if(c == 95) continue; + d = caml_parse_digit(c); + if(d < 0 || d >= base) break; + if(caml_int64_ult(threshold, res)) caml_failwith("int_of_string"); + d = caml_int64_of_int32(d); + res = caml_int64_add(caml_int64_mul(base64, res), d); + if(caml_int64_ult(res, d)) caml_failwith("int_of_string"); + } + if(i != caml_ml_string_length(s)) caml_failwith("int_of_string"); + if(base == 10 && caml_int64_ult(new MlInt64(0, 0, 0x8000), res)) + caml_failwith("int_of_string"); + if(sign < 0) res = caml_int64_neg(res); + return res; + } + function caml_int64_or(x, y){return x.or(y);} + function caml_int64_shift_left(x, s){return x.shift_left(s);} + function caml_int64_shift_right(x, s){return x.shift_right(s);} + function caml_int64_shift_right_unsigned(x, s){return x.shift_right_unsigned(s); + } + function caml_int64_sub(x, y){return x.sub(y);} + function caml_int64_to_float(x){return x.toFloat();} + function caml_int64_xor(x, y){return x.xor(y);} + function caml_int_of_string(s){ + var + r = caml_parse_sign_and_base(s), + i = r[0], + sign = r[1], + base = r[2], + len = caml_ml_string_length(s), + threshold = - 1 >>> 0, + c = i < len ? caml_string_unsafe_get(s, i) : 0, + d = caml_parse_digit(c); + if(d < 0 || d >= base) caml_failwith("int_of_string"); + var res = d; + for(i++; i < len; i++){ + c = caml_string_unsafe_get(s, i); + if(c == 95) continue; + d = caml_parse_digit(c); + if(d < 0 || d >= base) break; + res = base * res + d; + if(res > threshold) caml_failwith("int_of_string"); + } + if(i != len) caml_failwith("int_of_string"); + res = sign * res; + if(base == 10 && (res | 0) != res) caml_failwith("int_of_string"); + return res | 0; + } + function caml_is_js(){return 1;} + function caml_is_printable(c){return + (c > 31 && c < 127);} + function caml_js_call(f, o, args){ + return f.apply(o, caml_js_from_array(args)); + } + function caml_js_delete(o, f){delete o[f]; return 0;} + function caml_js_equals(x, y){return + (x == y);} + function caml_js_error_of_exception(exn){ + if(exn.js_error) return exn.js_error; + return null; + } + function caml_js_error_option_of_exception(exn){ + if(exn.js_error) return [0, exn.js_error]; + return 0; + } + function caml_js_eval_string(s){return eval(caml_jsstring_of_string(s));} + function caml_js_expr(s){ + console.error("caml_js_expr: fallback to runtime evaluation\n"); + return eval(caml_jsstring_of_string(s)); + } + function caml_js_from_bool(x){return ! ! x;} + function caml_js_from_float(x){return x;} + function caml_js_from_string(s){return caml_jsstring_of_string(s);} + function caml_js_fun_call(f, a){ + switch(a.length){ + case 1: + return f(); + case 2: + return f(a[1]); + case 3: + return f(a[1], a[2]); + case 4: + return f(a[1], a[2], a[3]); + case 5: + return f(a[1], a[2], a[3], a[4]); + case 6: + return f(a[1], a[2], a[3], a[4], a[5]); + case 7: + return f(a[1], a[2], a[3], a[4], a[5], a[6]); + case 8: + return f(a[1], a[2], a[3], a[4], a[5], a[6], a[7]); + } + return f.apply(null, caml_js_from_array(a)); + } + function caml_js_function_arity(f){return f.l >= 0 ? f.l : f.l = f.length;} + function caml_js_get(o, f){return o[f];} + function caml_js_get_console(){ + var + c = console, + m = + ["log", + "debug", + "info", + "warn", + "error", + "assert", + "dir", + "dirxml", + "trace", + "group", + "groupCollapsed", + "groupEnd", + "time", + "timeEnd"]; + function f(){} + for(var i = 0; i < m.length; i++) if(! c[m[i]]) c[m[i]] = f; + return c; + } + function caml_js_html_entities(s){ + var entity = /^&#?[0-9a-zA-Z]+;$/; + if(s.match(entity)){ + var str, temp = document.createElement("p"); + temp.innerHTML = s; + str = temp.textContent || temp.innerText; + temp = null; + return str; + } + else + caml_failwith("Invalid entity " + s); + } + var caml_js_regexps = {amp: /&/g, lt: / 0){ + var args = new Array(len); + for(var i = 0; i < len; i++) args[i] = arguments[i]; + } + else + args = [undefined]; + var res = caml_callback(f, args); + return res instanceof Function ? caml_js_wrap_callback(res) : res;}; + } + function caml_js_wrap_callback_arguments(f){ + return function(){ + var len = arguments.length, args = new Array(len); + for(var i = 0; i < len; i++) args[i] = arguments[i]; + return caml_callback(f, [args]);}; + } + function caml_js_wrap_callback_strict(arity, f){ + return function(){ + var + n = arguments.length, + args = new Array(arity), + len = Math.min(arguments.length, arity); + for(var i = 0; i < len; i++) args[i] = arguments[i]; + return caml_callback(f, args);}; + } + function caml_js_wrap_callback_unsafe(f){ + return function(){ + var len = caml_js_function_arity(f), args = new Array(len); + for(var i = 0; i < len; i++) args[i] = arguments[i]; + return caml_callback(f, args);}; + } + function caml_js_wrap_meth_callback(f){ + return function(){ + var len = arguments.length, args = new Array(len + 1); + args[0] = this; + for(var i = 0; i < len; i++) args[i + 1] = arguments[i]; + var res = caml_callback(f, args); + return res instanceof Function ? caml_js_wrap_callback(res) : res;}; + } + function caml_js_wrap_meth_callback_arguments(f){ + return function(){ + var len = arguments.length, args = new Array(len); + for(var i = 0; i < len; i++) args[i] = arguments[i]; + return caml_callback(f, [this, args]);}; + } + function caml_js_wrap_meth_callback_strict(arity, f){ + return function(){ + var args = new Array(arity + 1), len = Math.min(arguments.length, arity); + args[0] = this; + for(var i = 0; i < len; i++) args[i + 1] = arguments[i]; + return caml_callback(f, args);}; + } + function caml_js_wrap_meth_callback_unsafe(f){ + return function(){ + var len = caml_js_function_arity(f) - 1, args = new Array(len + 1); + args[0] = this; + for(var i = 0; i < len; i++) args[i + 1] = arguments[i]; + return caml_callback(f, args);}; + } + function caml_jsoo_flags_effects(unit){return 0;} + function caml_jsoo_flags_use_js_string(unit){return 1;} + function caml_lazy_make_forward(v){return [250, v];} + function caml_obj_tag(x){ + if(x instanceof Array && x[0] == x[0] >>> 0) + return x[0]; + else if(caml_is_ml_bytes(x)) + return 252; + else if(caml_is_ml_string(x)) + return 252; + else if(x instanceof Function || typeof x == "function") + return 247; + else if(x && x.caml_custom) return 255; else return 1000; + } + function caml_lazy_read_result(o){ + return caml_obj_tag(o) == 250 ? o[1] : o; + } + function caml_obj_update_tag(b, o, n){ + if(b[0] == o){b[0] = n; return 1;} + return 0; + } + function caml_lazy_reset_to_lazy(o){ + caml_obj_update_tag(o, 244, 246); + return 0; + } + function caml_lazy_update_to_forcing(o){ + return o instanceof Array && o[0] == o[0] >>> 0 + && caml_obj_update_tag(o, 246, 244) + ? 0 + : 1; + } + function caml_lazy_update_to_forward(o){ + caml_obj_update_tag(o, 244, 250); + return 0; + } + function caml_ldexp_float(x, exp){ + exp |= 0; + if(exp > 1023){ + exp -= 1023; + x *= Math.pow(2, 1023); + if(exp > 1023){exp -= 1023; x *= Math.pow(2, 1023);} + } + if(exp < - 1023){exp += 1023; x *= Math.pow(2, - 1023);} + x *= Math.pow(2, exp); + return x; + } + function caml_lessequal(x, y){ + return + (caml_compare_val(x, y, false) <= 0); + } + function caml_lessthan(x, y){return + (caml_compare_val(x, y, false) < 0);} + function caml_lex_array(s){ + s = caml_jsbytes_of_string(s); + var l = s.length / 2, a = new Array(l); + for(var i = 0; i < l; i++) + a[i] = (s.charCodeAt(2 * i) | s.charCodeAt(2 * i + 1) << 8) << 16 >> 16; + return a; + } + function caml_lex_engine(tbl, start_state, lexbuf){ + var + lex_buffer = 2, + lex_buffer_len = 3, + lex_start_pos = 5, + lex_curr_pos = 6, + lex_last_pos = 7, + lex_last_action = 8, + lex_eof_reached = 9, + lex_base = 1, + lex_backtrk = 2, + lex_default = 3, + lex_trans = 4, + lex_check = 5; + if(! tbl.lex_default){ + tbl.lex_base = caml_lex_array(tbl[lex_base]); + tbl.lex_backtrk = caml_lex_array(tbl[lex_backtrk]); + tbl.lex_check = caml_lex_array(tbl[lex_check]); + tbl.lex_trans = caml_lex_array(tbl[lex_trans]); + tbl.lex_default = caml_lex_array(tbl[lex_default]); + } + var + c, + state = start_state, + buffer = caml_uint8_array_of_bytes(lexbuf[lex_buffer]); + if(state >= 0){ + lexbuf[lex_last_pos] = lexbuf[lex_start_pos] = lexbuf[lex_curr_pos]; + lexbuf[lex_last_action] = - 1; + } + else + state = - state - 1; + for(;;){ + var base = tbl.lex_base[state]; + if(base < 0) return - base - 1; + var backtrk = tbl.lex_backtrk[state]; + if(backtrk >= 0){ + lexbuf[lex_last_pos] = lexbuf[lex_curr_pos]; + lexbuf[lex_last_action] = backtrk; + } + if(lexbuf[lex_curr_pos] >= lexbuf[lex_buffer_len]) + if(lexbuf[lex_eof_reached] == 0) return - state - 1; else c = 256; + else{c = buffer[lexbuf[lex_curr_pos]]; lexbuf[lex_curr_pos]++;} + if(tbl.lex_check[base + c] == state) + state = tbl.lex_trans[base + c]; + else + state = tbl.lex_default[state]; + if(state < 0){ + lexbuf[lex_curr_pos] = lexbuf[lex_last_pos]; + if(lexbuf[lex_last_action] == - 1) + caml_failwith("lexing: empty token"); + else + return lexbuf[lex_last_action]; + } + else if(c == 256) lexbuf[lex_eof_reached] = 0; + } + } + function caml_list_mount_point(){ + var prev = 0; + for(var i = 0; i < jsoo_mount_point.length; i++){ + var old = prev; + prev = [0, caml_string_of_jsbytes(jsoo_mount_point[i].path), old]; + } + return prev; + } + function caml_list_of_js_array(a){ + var l = 0; + for(var i = a.length - 1; i >= 0; i--){var e = a[i]; l = [0, e, l];} + return l; + } + function caml_list_to_js_array(l){ + var a = []; + for(; l !== 0; l = l[2]) a.push(l[1]); + return a; + } + function caml_log10_float(x){return Math.log10(x);} + function caml_log1p_float(x){return Math.log1p(x);} + function caml_log2_float(x){return Math.log2(x);} + function caml_new_string(s){return caml_string_of_jsbytes(s);} + function caml_lxm_next(v){ + function shift_l(x, k){return caml_int64_shift_left(x, k);} + function shift_r(x, k){return caml_int64_shift_right_unsigned(x, k);} + function or(a, b){return caml_int64_or(a, b);} + function xor(a, b){return caml_int64_xor(a, b);} + function add(a, b){return caml_int64_add(a, b);} + function mul(a, b){return caml_int64_mul(a, b);} + function rotl(x, k){return or(shift_l(x, k), shift_r(x, 64 - k));} + function get(a, i){return caml_ba_get_1(a, i);} + function set(a, i, x){return caml_ba_set_1(a, i, x);} + var + M = caml_int64_of_string(caml_new_string("0xd1342543de82ef95")), + daba = caml_int64_of_string(caml_new_string("0xdaba0b6eb09322e3")), + z, + q0, + q1, + st = v, + a = get(st, 0), + s = get(st, 1), + x0 = get(st, 2), + x1 = get(st, 3); + z = add(s, x0); + z = mul(xor(z, shift_r(z, 32)), daba); + z = mul(xor(z, shift_r(z, 32)), daba); + z = xor(z, shift_r(z, 32)); + set(st, 1, add(mul(s, M), a)); + var q0 = x0, q1 = x1; + q1 = xor(q1, q0); + q0 = rotl(q0, 24); + q0 = xor(xor(q0, q1), shift_l(q1, 16)); + q1 = rotl(q1, 37); + set(st, 2, q0); + set(st, 3, q1); + return z; + } + function caml_make_float_vect(len){ + if(len < 0) caml_array_bound_error(); + var len = len + 1 | 0, b = new Array(len); + b[0] = 254; + for(var i = 1; i < len; i++) b[i] = 0; + return b; + } + function caml_make_vect(len, init){ + if(len < 0) caml_array_bound_error(); + var len = len + 1 | 0, b = new Array(len); + b[0] = 0; + for(var i = 1; i < len; i++) b[i] = init; + return b; + } + var + caml_marshal_constants = + {PREFIX_SMALL_BLOCK: 0x80, + PREFIX_SMALL_INT: 0x40, + PREFIX_SMALL_STRING: 0x20, + CODE_INT8: 0x00, + CODE_INT16: 0x01, + CODE_INT32: 0x02, + CODE_INT64: 0x03, + CODE_SHARED8: 0x04, + CODE_SHARED16: 0x05, + CODE_SHARED32: 0x06, + CODE_BLOCK32: 0x08, + CODE_BLOCK64: 0x13, + CODE_STRING8: 0x09, + CODE_STRING32: 0x0A, + CODE_DOUBLE_BIG: 0x0B, + CODE_DOUBLE_LITTLE: 0x0C, + CODE_DOUBLE_ARRAY8_BIG: 0x0D, + CODE_DOUBLE_ARRAY8_LITTLE: 0x0E, + CODE_DOUBLE_ARRAY32_BIG: 0x0F, + CODE_DOUBLE_ARRAY32_LITTLE: 0x07, + CODE_CODEPOINTER: 0x10, + CODE_INFIXPOINTER: 0x11, + CODE_CUSTOM: 0x12, + CODE_CUSTOM_LEN: 0x18, + CODE_CUSTOM_FIXED: 0x19}; + function caml_maybe_print_stats(unit){return 0;} + function caml_md5_bytes(s, ofs, len){ + var ctx = caml_MD5Init(), a = caml_uint8_array_of_bytes(s); + caml_MD5Update(ctx, a.subarray(ofs, ofs + len), len); + return caml_string_of_array(caml_MD5Final(ctx)); + } + function caml_ml_input_block(chanid, ba, i, l){ + var + chan = caml_ml_channel_get(chanid), + n = l, + avail = chan.buffer_max - chan.buffer_curr; + if(l <= avail){ + ba.set(chan.buffer.subarray(chan.buffer_curr, chan.buffer_curr + l), i); + chan.buffer_curr += l; + } + else if(avail > 0){ + ba.set + (chan.buffer.subarray(chan.buffer_curr, chan.buffer_curr + avail), i); + chan.buffer_curr += avail; + n = avail; + } + else{ + chan.buffer_curr = 0; + chan.buffer_max = 0; + caml_refill(chan); + var avail = chan.buffer_max - chan.buffer_curr; + if(n > avail) n = avail; + ba.set(chan.buffer.subarray(chan.buffer_curr, chan.buffer_curr + n), i); + chan.buffer_curr += n; + } + return n | 0; + } + function caml_md5_chan(chanid, toread){ + var ctx = caml_MD5Init(), buffer = new Uint8Array(4096); + if(toread < 0) + while(true){ + var read = caml_ml_input_block(chanid, buffer, 0, buffer.length); + if(read == 0) break; + caml_MD5Update(ctx, buffer.subarray(0, read), read); + } + else + while(toread > 0){ + var + read = + caml_ml_input_block + (chanid, buffer, 0, toread > buffer.length ? buffer.length : toread); + if(read == 0) caml_raise_end_of_file(); + caml_MD5Update(ctx, buffer.subarray(0, read), read); + toread -= read; + } + return caml_string_of_array(caml_MD5Final(ctx)); + } + function caml_md5_string(s, ofs, len){ + return caml_md5_bytes(caml_bytes_of_string(s), ofs, len); + } + function caml_memprof_discard(t){return 0;} + function caml_memprof_set(_control){return 0;} + function caml_memprof_start(rate, stack_size, tracker){return 0;} + function caml_memprof_stop(unit){return 0;} + function caml_ml_channel_redirect(captured, into){ + var + to_restore = caml_ml_channel_get(captured), + new_ = caml_ml_channel_get(into); + caml_ml_channels[captured] = new_; + return to_restore; + } + function caml_ml_channel_restore(captured, to_restore){caml_ml_channels[captured] = to_restore; return 0; + } + function caml_ml_channel_size(chanid){ + var chan = caml_ml_channel_get(chanid); + return chan.file.length(); + } + function caml_ml_channel_size_64(chanid){ + var chan = caml_ml_channel_get(chanid); + return caml_int64_of_float(chan.file.length()); + } + var caml_sys_fds = new Array(3); + function caml_sys_close(fd){ + var file = caml_sys_fds[fd]; + if(file) file.close(); + delete caml_sys_fds[fd]; + return 0; + } + function caml_ml_flush(chanid){ + var chan = caml_ml_channel_get(chanid); + if(! chan.opened) caml_raise_sys_error("Cannot flush a closed channel"); + if(! chan.buffer || chan.buffer_curr == 0) return 0; + if(chan.output) + chan.output(caml_subarray_to_jsbytes(chan.buffer, 0, chan.buffer_curr)); + else + chan.file.write(chan.offset, chan.buffer, 0, chan.buffer_curr); + chan.offset += chan.buffer_curr; + chan.buffer_curr = 0; + return 0; + } + function caml_ml_close_channel(chanid){ + var chan = caml_ml_channel_get(chanid); + if(chan.opened){ + chan.opened = false; + caml_sys_close(chan.fd); + chan.fd = - 1; + chan.buffer = new Uint8Array(0); + chan.buffer_curr = 0; + chan.buffer_max = 0; + } + return 0; + } + function caml_ml_condition_broadcast(t){return 0;} + function caml_ml_condition_new(unit){return {condition: 1};} + function caml_ml_condition_signal(t){return 0;} + function caml_ml_condition_wait(t, mutext){return 0;} + function caml_ml_debug_info_status(){return 0;} + function caml_ml_domain_cpu_relax(unit){return 0;} + function caml_ml_domain_id(unit){return caml_domain_id;} + function caml_ml_domain_set_name(_name){return 0;} + var caml_ml_domain_unique_token_ = [0]; + function caml_ml_domain_unique_token(unit){return caml_ml_domain_unique_token_; + } + var caml_runtime_warnings = 0; + function caml_ml_enable_runtime_warnings(bool){caml_runtime_warnings = bool; return 0; + } + function caml_ml_input(chanid, b, i, l){ + var ba = caml_uint8_array_of_bytes(b); + return caml_ml_input_block(chanid, ba, i, l); + } + function caml_ml_input_bigarray(chanid, b, i, l){ + var ba = caml_ba_to_typed_array(b); + return caml_ml_input_block(chanid, ba, i, l); + } + function caml_ml_input_char(chanid){ + var chan = caml_ml_channel_get(chanid); + if(chan.buffer_curr >= chan.buffer_max){ + chan.buffer_curr = 0; + chan.buffer_max = 0; + caml_refill(chan); + } + if(chan.buffer_curr >= chan.buffer_max) caml_raise_end_of_file(); + var res = chan.buffer[chan.buffer_curr]; + chan.buffer_curr++; + return res; + } + function caml_ml_input_int(chanid){ + var chan = caml_ml_channel_get(chanid), res = 0; + for(var i = 0; i < 4; i++) + res = (res << 8) + caml_ml_input_char(chanid) | 0; + return res | 0; + } + function caml_ml_input_scan_line(chanid){ + var chan = caml_ml_channel_get(chanid), p = chan.buffer_curr; + do + if(p >= chan.buffer_max){ + if(chan.buffer_curr > 0){ + chan.buffer.set(chan.buffer.subarray(chan.buffer_curr), 0); + p -= chan.buffer_curr; + chan.buffer_max -= chan.buffer_curr; + chan.buffer_curr = 0; + } + if(chan.buffer_max >= chan.buffer.length) return - chan.buffer_max | 0; + var prev_max = chan.buffer_max; + caml_refill(chan); + if(prev_max == chan.buffer_max) return - chan.buffer_max | 0; + } + while + (chan.buffer[p++] != 10); + return p - chan.buffer_curr | 0; + } + function caml_ml_is_buffered(chanid){ + return caml_ml_channel_get(chanid).buffered ? 1 : 0; + } + function caml_ml_mutex_lock(t){ + if(t.locked) + caml_failwith("Mutex.lock: mutex already locked. Cannot wait."); + else + t.locked = true; + return 0; + } + function caml_ml_mutex_new(unit){return new MlMutex();} + function caml_ml_mutex_try_lock(t){ + if(! t.locked){t.locked = true; return 1;} + return 0; + } + function caml_sys_open_for_node(fd, flags){ + if(flags.name) + try{ + var fs = require("fs"), fd2 = fs.openSync(flags.name, "rs"); + return new MlNodeFd(fd2, flags); + } + catch(e){} + return new MlNodeFd(fd, flags); + } + function caml_sys_open_internal(file, idx){ + if(idx == undefined) idx = caml_sys_fds.length; + caml_sys_fds[idx] = file; + return idx | 0; + } + function caml_sys_open(name, flags, _perms){ + var f = {}; + while(flags){ + switch(flags[1]){ + case 0: + f.rdonly = 1; break; + case 1: + f.wronly = 1; break; + case 2: + f.append = 1; break; + case 3: + f.create = 1; break; + case 4: + f.truncate = 1; break; + case 5: + f.excl = 1; break; + case 6: + f.binary = 1; break; + case 7: + f.text = 1; break; + case 8: + f.nonblock = 1; break; + } + flags = flags[2]; + } + if(f.rdonly && f.wronly) + caml_raise_sys_error + (caml_jsbytes_of_string(name) + + " : flags Open_rdonly and Open_wronly are not compatible"); + if(f.text && f.binary) + caml_raise_sys_error + (caml_jsbytes_of_string(name) + + " : flags Open_text and Open_binary are not compatible"); + var root = resolve_fs_device(name), file = root.device.open(root.rest, f); + return caml_sys_open_internal(file, undefined); + } + (function(){ + function file(fd, flags){ + return fs_node_supported() + ? caml_sys_open_for_node(fd, flags) + : new MlFakeFd_out(fd, flags); + } + caml_sys_open_internal + (file(0, {rdonly: 1, altname: "/dev/stdin", isCharacterDevice: true}), + 0); + caml_sys_open_internal + (file(1, {buffered: 2, wronly: 1, isCharacterDevice: true}), 1); + caml_sys_open_internal + (file(2, {buffered: 2, wronly: 1, isCharacterDevice: true}), 2); + } + ()); + function caml_ml_open_descriptor_in(fd){ + var file = caml_sys_fds[fd]; + if(file.flags.wronly) caml_raise_sys_error("fd " + fd + " is writeonly"); + var + refill = null, + channel = + {file: file, + offset: file.flags.append ? file.length() : 0, + fd: fd, + opened: true, + out: false, + buffer_curr: 0, + buffer_max: 0, + buffer: new Uint8Array(65536), + refill: refill}; + caml_ml_channels[channel.fd] = channel; + return channel.fd; + } + function caml_ml_open_descriptor_out(fd){ + var file = caml_sys_fds[fd]; + if(file.flags.rdonly) caml_raise_sys_error("fd " + fd + " is readonly"); + var + buffered = file.flags.buffered !== undefined ? file.flags.buffered : 1, + channel = + {file: file, + offset: file.flags.append ? file.length() : 0, + fd: fd, + opened: true, + out: true, + buffer_curr: 0, + buffer: new Uint8Array(65536), + buffered: buffered}; + caml_ml_channels[channel.fd] = channel; + return channel.fd; + } + function caml_ml_out_channels_list(){ + var l = 0; + for(var c = 0; c < caml_ml_channels.length; c++) + if + (caml_ml_channels[c] && caml_ml_channels[c].opened + && caml_ml_channels[c].out) + l = [0, caml_ml_channels[c].fd, l]; + return l; + } + function caml_ml_output_ta(chanid, buffer, offset, len){ + var chan = caml_ml_channel_get(chanid); + if(! chan.opened) + caml_raise_sys_error("Cannot output to a closed channel"); + buffer = buffer.subarray(offset, offset + len); + if(chan.buffer_curr + buffer.length > chan.buffer.length){ + var b = new Uint8Array(chan.buffer_curr + buffer.length); + b.set(chan.buffer); + chan.buffer = b; + } + switch(chan.buffered){ + case 0: + chan.buffer.set(buffer, chan.buffer_curr); + chan.buffer_curr += buffer.length; + caml_ml_flush(chanid); + break; + case 1: + chan.buffer.set(buffer, chan.buffer_curr); + chan.buffer_curr += buffer.length; + if(chan.buffer_curr >= chan.buffer.length) caml_ml_flush(chanid); + break; + case 2: + var id = buffer.lastIndexOf(10); + if(id < 0){ + chan.buffer.set(buffer, chan.buffer_curr); + chan.buffer_curr += buffer.length; + if(chan.buffer_curr >= chan.buffer.length) caml_ml_flush(chanid); + } + else{ + chan.buffer.set(buffer.subarray(0, id + 1), chan.buffer_curr); + chan.buffer_curr += id + 1; + caml_ml_flush(chanid); + chan.buffer.set(buffer.subarray(id + 1), chan.buffer_curr); + chan.buffer_curr += buffer.length - id - 1; + } + break; + } + return 0; + } + function caml_ml_output_bytes(chanid, buffer, offset, len){ + var buffer = caml_uint8_array_of_bytes(buffer); + return caml_ml_output_ta(chanid, buffer, offset, len); + } + function caml_ml_output(chanid, buffer, offset, len){ + return caml_ml_output_bytes + (chanid, caml_bytes_of_string(buffer), offset, len); + } + function caml_ml_output_bigarray(chanid, buffer, offset, len){ + var buffer = caml_ba_to_typed_array(buffer); + return caml_ml_output_ta(chanid, buffer, offset, len); + } + function caml_ml_output_char(chanid, c){ + var s = caml_string_of_jsbytes(String.fromCharCode(c)); + caml_ml_output(chanid, s, 0, 1); + return 0; + } + function caml_ml_output_int(chanid, i){ + var + arr = [i >> 24 & 0xFF, i >> 16 & 0xFF, i >> 8 & 0xFF, i & 0xFF], + s = caml_string_of_array(arr); + caml_ml_output(chanid, s, 0, 4); + return 0; + } + function caml_pos_in(chanid){ + var chan = caml_ml_channel_get(chanid); + return chan.offset - (chan.buffer_max - chan.buffer_curr) | 0; + } + function caml_ml_pos_in(chanid){return caml_pos_in(chanid);} + function caml_ml_pos_in_64(chanid){ + return caml_int64_of_float(caml_pos_in(chanid)); + } + function caml_pos_out(chanid){ + var chan = caml_ml_channel_get(chanid); + return chan.offset + chan.buffer_curr; + } + function caml_ml_pos_out(chanid){return caml_pos_out(chanid);} + function caml_ml_pos_out_64(chanid){ + return caml_int64_of_float(caml_pos_out(chanid)); + } + function caml_ml_runtime_events_pause(){return 0;} + function caml_ml_runtime_events_resume(){return 0;} + function caml_ml_runtime_events_start(){return 0;} + function caml_ml_runtime_warnings_enabled(_unit){return caml_runtime_warnings; + } + function caml_seek_in(chanid, pos){ + var chan = caml_ml_channel_get(chanid); + if(chan.refill != null) caml_raise_sys_error("Illegal seek"); + if + (pos >= chan.offset - chan.buffer_max && pos <= chan.offset + && chan.file.flags.binary) + chan.buffer_curr = chan.buffer_max - (chan.offset - pos); + else{chan.offset = pos; chan.buffer_curr = 0; chan.buffer_max = 0;} + return 0; + } + function caml_ml_seek_in(chanid, pos){return caml_seek_in(chanid, pos);} + function caml_ml_seek_in_64(chanid, pos){ + var pos = caml_int64_to_float(pos); + return caml_seek_in(chanid, pos); + } + function caml_seek_out(chanid, pos){ + caml_ml_flush(chanid); + var chan = caml_ml_channel_get(chanid); + chan.offset = pos; + return 0; + } + function caml_ml_seek_out(chanid, pos){return caml_seek_out(chanid, pos);} + function caml_ml_seek_out_64(chanid, pos){ + var pos = caml_int64_to_float(pos); + return caml_seek_out(chanid, pos); + } + function caml_ml_set_binary_mode(chanid, mode){ + var chan = caml_ml_channel_get(chanid); + chan.file.flags.text = ! mode; + chan.file.flags.binary = mode; + return 0; + } + function caml_ml_set_buffered(chanid, v){ + caml_ml_channel_get(chanid).buffered = v; + if(! v) caml_ml_flush(chanid); + return 0; + } + function caml_ml_set_channel_name(chanid, name){ + var chan = caml_ml_channel_get(chanid); + chan.name = name; + return 0; + } + function caml_ml_set_channel_output(chanid, f){ + var chan = caml_ml_channel_get(chanid); + chan.output = function(s){f(s);}; + return 0; + } + function caml_ml_set_channel_refill(chanid, f){ + caml_ml_channel_get(chanid).refill = f; + return 0; + } + function caml_mod(x, y){if(y == 0) caml_raise_zero_divide(); return x % y;} + function caml_modf_float(x){ + if(isFinite(x)){ + var neg = 1 / x < 0; + x = Math.abs(x); + var i = Math.floor(x), f = x - i; + if(neg){i = - i; f = - f;} + return [0, f, i]; + } + if(isNaN(x)) return [0, NaN, NaN]; + return [0, 1 / x, x]; + } + function caml_mount_autoload(name, f){ + var + path = caml_make_path(name), + name = caml_trailing_slash(path.join("/")); + jsoo_mount_point.push({path: name, device: new MlFakeDevice(name, f)}); + return 0; + } + function caml_lex_run_mem(s, i, mem, curr_pos){ + for(;;){ + var dst = s.charCodeAt(i); + i++; + if(dst == 0xff) return; + var src = s.charCodeAt(i); + i++; + if(src == 0xff) + mem[dst + 1] = curr_pos; + else + mem[dst + 1] = mem[src + 1]; + } + } + function caml_lex_run_tag(s, i, mem){ + for(;;){ + var dst = s.charCodeAt(i); + i++; + if(dst == 0xff) return; + var src = s.charCodeAt(i); + i++; + if(src == 0xff) mem[dst + 1] = - 1; else mem[dst + 1] = mem[src + 1]; + } + } + function caml_new_lex_engine(tbl, start_state, lexbuf){ + var + lex_buffer = 2, + lex_buffer_len = 3, + lex_start_pos = 5, + lex_curr_pos = 6, + lex_last_pos = 7, + lex_last_action = 8, + lex_eof_reached = 9, + lex_mem = 10, + lex_base = 1, + lex_backtrk = 2, + lex_default = 3, + lex_trans = 4, + lex_check = 5, + lex_base_code = 6, + lex_backtrk_code = 7, + lex_default_code = 8, + lex_trans_code = 9, + lex_check_code = 10, + lex_code = 11; + if(! tbl.lex_default){ + tbl.lex_base = caml_lex_array(tbl[lex_base]); + tbl.lex_backtrk = caml_lex_array(tbl[lex_backtrk]); + tbl.lex_check = caml_lex_array(tbl[lex_check]); + tbl.lex_trans = caml_lex_array(tbl[lex_trans]); + tbl.lex_default = caml_lex_array(tbl[lex_default]); + } + if(! tbl.lex_default_code){ + tbl.lex_base_code = caml_lex_array(tbl[lex_base_code]); + tbl.lex_backtrk_code = caml_lex_array(tbl[lex_backtrk_code]); + tbl.lex_check_code = caml_lex_array(tbl[lex_check_code]); + tbl.lex_trans_code = caml_lex_array(tbl[lex_trans_code]); + tbl.lex_default_code = caml_lex_array(tbl[lex_default_code]); + } + if(tbl.lex_code == null) + tbl.lex_code = caml_jsbytes_of_string(tbl[lex_code]); + var + c, + state = start_state, + buffer = caml_uint8_array_of_bytes(lexbuf[lex_buffer]); + if(state >= 0){ + lexbuf[lex_last_pos] = lexbuf[lex_start_pos] = lexbuf[lex_curr_pos]; + lexbuf[lex_last_action] = - 1; + } + else + state = - state - 1; + for(;;){ + var base = tbl.lex_base[state]; + if(base < 0){ + var pc_off = tbl.lex_base_code[state]; + caml_lex_run_tag(tbl.lex_code, pc_off, lexbuf[lex_mem]); + return - base - 1; + } + var backtrk = tbl.lex_backtrk[state]; + if(backtrk >= 0){ + var pc_off = tbl.lex_backtrk_code[state]; + caml_lex_run_tag(tbl.lex_code, pc_off, lexbuf[lex_mem]); + lexbuf[lex_last_pos] = lexbuf[lex_curr_pos]; + lexbuf[lex_last_action] = backtrk; + } + if(lexbuf[lex_curr_pos] >= lexbuf[lex_buffer_len]) + if(lexbuf[lex_eof_reached] == 0) return - state - 1; else c = 256; + else{c = buffer[lexbuf[lex_curr_pos]]; lexbuf[lex_curr_pos]++;} + var pstate = state; + if(tbl.lex_check[base + c] == state) + state = tbl.lex_trans[base + c]; + else + state = tbl.lex_default[state]; + if(state < 0){ + lexbuf[lex_curr_pos] = lexbuf[lex_last_pos]; + if(lexbuf[lex_last_action] == - 1) + caml_failwith("lexing: empty token"); + else + return lexbuf[lex_last_action]; + } + else{ + var base_code = tbl.lex_base_code[pstate], pc_off; + if(tbl.lex_check_code[base_code + c] == pstate) + pc_off = tbl.lex_trans_code[base_code + c]; + else + pc_off = tbl.lex_default_code[pstate]; + if(pc_off > 0) + caml_lex_run_mem + (tbl.lex_code, pc_off, lexbuf[lex_mem], lexbuf[lex_curr_pos]); + if(c == 256) lexbuf[lex_eof_reached] = 0; + } + } + } + function caml_nextafter_float(x, y){ + if(isNaN(x) || isNaN(y)) return NaN; + if(x == y) return y; + if(x == 0) return y < 0 ? - Math.pow(2, - 1074) : Math.pow(2, - 1074); + var bits = caml_int64_bits_of_float(x), one = caml_int64_of_int32(1); + if(x < y == x > 0) + bits = caml_int64_add(bits, one); + else + bits = caml_int64_sub(bits, one); + return caml_int64_float_of_bits(bits); + } + function caml_notequal(x, y){ + return + (caml_compare_val(x, y, false) != 0); + } + function caml_obj_add_offset(v, offset){ + caml_failwith("Obj.add_offset is not supported"); + } + function caml_obj_block(tag, size){ + var o = new Array(size + 1); + o[0] = tag; + for(var i = 1; i <= size; i++) o[i] = 0; + return o; + } + function caml_obj_compare_and_swap(x, i, old, n){ + if(x[i + 1] == old){x[i + 1] = n; return 1;} + return 0; + } + function caml_obj_is_block(x){return + (x instanceof Array);} + function caml_obj_is_shared(x){return 1;} + function caml_obj_make_forward(b, v){b[0] = 250; b[1] = v; return 0;} + function caml_obj_raw_field(o, i){return o[i + 1];} + function caml_obj_reachable_words(o){return 0;} + function caml_obj_set_raw_field(o, i, v){return o[i + 1] = v;} + function caml_obj_set_tag(x, tag){x[0] = tag; return 0;} + function caml_obj_truncate(x, s){ + if(s <= 0 || s + 1 > x.length) caml_invalid_argument("Obj.truncate"); + if(x.length != s + 1) x.length = s + 1; + return 0; + } + function caml_obj_with_tag(tag, x){ + var l = x.length, a = new Array(l); + a[0] = tag; + for(var i = 1; i < l; i++) a[i] = x[i]; + return a; + } + function caml_ojs_new_arr(c, a){ + switch(a.length){ + case 0: + return new c; + case 1: + return new c(a[0]); + case 2: + return new c(a[0], a[1]); + case 3: + return new c(a[0], a[1], a[2]); + case 4: + return new c(a[0], a[1], a[2], a[3]); + case 5: + return new c(a[0], a[1], a[2], a[3], a[4]); + case 6: + return new c(a[0], a[1], a[2], a[3], a[4], a[5]); + case 7: + return new c(a[0], a[1], a[2], a[3], a[4], a[5], a[6]); + } + function F(){return c.apply(this, a);} + F.prototype = c.prototype; + return new F; + } + var + caml_output_val = + function(){ + function Writer(){this.chunk = [];} + Writer.prototype = + {chunk_idx: 20, + block_len: 0, + obj_counter: 0, + size_32: 0, + size_64: 0, + write: + function(size, value){ + for(var i = size - 8; i >= 0; i -= 8) + this.chunk[this.chunk_idx++] = value >> i & 0xFF; + }, + write_at: + function(pos, size, value){ + var pos = pos; + for(var i = size - 8; i >= 0; i -= 8) + this.chunk[pos++] = value >> i & 0xFF; + }, + write_code: + function(size, code, value){ + this.chunk[this.chunk_idx++] = code; + for(var i = size - 8; i >= 0; i -= 8) + this.chunk[this.chunk_idx++] = value >> i & 0xFF; + }, + write_shared: + function(offset){ + if(offset < 1 << 8) + this.write_code(8, 0x04, offset); + else if(offset < 1 << 16) + this.write_code(16, 0x05, offset); + else + this.write_code(32, 0x06, offset); + }, + pos: function(){return this.chunk_idx;}, + finalize: + function(){ + this.block_len = this.chunk_idx - 20; + this.chunk_idx = 0; + this.write(32, 0x8495A6BE); + this.write(32, this.block_len); + this.write(32, this.obj_counter); + this.write(32, this.size_32); + this.write(32, this.size_64); + return this.chunk; + }}; + return function(v, flags){ + flags = caml_list_to_js_array(flags); + var + no_sharing = flags.indexOf(0) !== - 1, + closures = flags.indexOf(1) !== - 1; + if(closures) + console.warn + ("in caml_output_val: flag Marshal.Closures is not supported."); + var + writer = new Writer(), + stack = [], + intern_obj_table = no_sharing ? null : new MlObjectTable(); + function memo(v){ + if(no_sharing) return false; + var existing_offset = intern_obj_table.recall(v); + if(existing_offset){ + writer.write_shared(existing_offset); + return true; + } + else{intern_obj_table.store(v); return false;} + } + function extern_rec(v){ + if(v.caml_custom){ + if(memo(v)) return; + var + name = v.caml_custom, + ops = caml_custom_ops[name], + sz_32_64 = [0, 0]; + if(! ops.serialize) + caml_invalid_argument("output_value: abstract value (Custom)"); + if(ops.fixed_length == undefined){ + writer.write(8, 0x18); + for(var i = 0; i < name.length; i++) + writer.write(8, name.charCodeAt(i)); + writer.write(8, 0); + var header_pos = writer.pos(); + for(var i = 0; i < 12; i++) writer.write(8, 0); + ops.serialize(writer, v, sz_32_64); + writer.write_at(header_pos, 32, sz_32_64[0]); + writer.write_at(header_pos + 4, 32, 0); + writer.write_at(header_pos + 8, 32, sz_32_64[1]); + } + else{ + writer.write(8, 0x19); + for(var i = 0; i < name.length; i++) + writer.write(8, name.charCodeAt(i)); + writer.write(8, 0); + var old_pos = writer.pos(); + ops.serialize(writer, v, sz_32_64); + if(ops.fixed_length != writer.pos() - old_pos) + caml_failwith + ("output_value: incorrect fixed sizes specified by " + name); + } + writer.size_32 += 2 + (sz_32_64[0] + 3 >> 2); + writer.size_64 += 2 + (sz_32_64[1] + 7 >> 3); + } + else if(v instanceof Array && v[0] === (v[0] | 0)){ + if(v[0] == 251) + caml_failwith("output_value: abstract value (Abstract)"); + if(caml_is_continuation_tag(v[0])) + caml_invalid_argument("output_value: continuation value"); + if(v.length > 1 && memo(v)) return; + if(v[0] < 16 && v.length - 1 < 8) + writer.write(8, 0x80 + v[0] + (v.length - 1 << 4)); + else + writer.write_code(32, 0x08, v.length - 1 << 10 | v[0]); + writer.size_32 += v.length; + writer.size_64 += v.length; + if(v.length > 1) stack.push(v, 1); + } + else if(caml_is_ml_bytes(v)){ + if(! caml_is_ml_bytes(caml_string_of_jsbytes(""))) + caml_failwith + ("output_value: [Bytes.t] cannot safely be marshaled with [--enable use-js-string]"); + if(memo(v)) return; + var len = caml_ml_bytes_length(v); + if(len < 0x20) + writer.write(8, 0x20 + len); + else if(len < 0x100) + writer.write_code(8, 0x09, len); + else + writer.write_code(32, 0x0A, len); + for(var i = 0; i < len; i++) + writer.write(8, caml_bytes_unsafe_get(v, i)); + writer.size_32 += 1 + ((len + 4) / 4 | 0); + writer.size_64 += 1 + ((len + 8) / 8 | 0); + } + else if(caml_is_ml_string(v)){ + if(memo(v)) return; + var len = caml_ml_string_length(v); + if(len < 0x20) + writer.write(8, 0x20 + len); + else if(len < 0x100) + writer.write_code(8, 0x09, len); + else + writer.write_code(32, 0x0A, len); + for(var i = 0; i < len; i++) + writer.write(8, caml_string_unsafe_get(v, i)); + writer.size_32 += 1 + ((len + 4) / 4 | 0); + writer.size_64 += 1 + ((len + 8) / 8 | 0); + } + else if(v != (v | 0)){ + var type_of_v = typeof v; + if(type_of_v != "number") + caml_failwith("output_value: abstract value (" + type_of_v + ")"); + if(memo(v)) return; + var t = caml_int64_to_bytes(caml_int64_bits_of_float(v)); + writer.write(8, 0x0C); + for(var i = 0; i < 8; i++) writer.write(8, t[7 - i]); + writer.size_32 += 3; + writer.size_64 += 2; + } + else if(v >= 0 && v < 0x40) + writer.write(8, 0X40 + v); + else if(v >= - (1 << 7) && v < 1 << 7) + writer.write_code(8, 0x00, v); + else if(v >= - (1 << 15) && v < 1 << 15) + writer.write_code(16, 0x01, v); + else + writer.write_code(32, 0x02, v); + } + extern_rec(v); + while(stack.length > 0){ + var i = stack.pop(), v = stack.pop(); + if(i + 1 < v.length) stack.push(v, i + 1); + extern_rec(v[i]); + } + if(intern_obj_table) + writer.obj_counter = intern_obj_table.objs.length; + writer.finalize(); + return writer.chunk;}; + } + (); + function caml_output_value_to_string(v, flags){ + return caml_string_of_array(caml_output_val(v, flags)); + } + function caml_output_value(chanid, v, flags){ + var s = caml_output_value_to_string(v, flags); + caml_ml_output(chanid, s, 0, caml_ml_string_length(s)); + return 0; + } + function caml_output_value_to_buffer(s, ofs, len, v, flags){ + var t = caml_output_val(v, flags); + if(t.length > len) caml_failwith("Marshal.to_buffer: buffer overflow"); + caml_blit_bytes(t, 0, s, ofs, t.length); + return 0; + } + function caml_output_value_to_bytes(v, flags){ + return caml_bytes_of_array(caml_output_val(v, flags)); + } + var caml_parser_trace = 0; + function caml_parse_engine(tables, env, cmd, arg){ + var + ERRCODE = 256, + loop = 6, + testshift = 7, + shift = 8, + shift_recover = 9, + reduce = 10, + READ_TOKEN = 0, + RAISE_PARSE_ERROR = 1, + GROW_STACKS_1 = 2, + GROW_STACKS_2 = 3, + COMPUTE_SEMANTIC_ACTION = 4, + CALL_ERROR_FUNCTION = 5, + env_s_stack = 1, + env_v_stack = 2, + env_symb_start_stack = 3, + env_symb_end_stack = 4, + env_stacksize = 5, + env_stackbase = 6, + env_curr_char = 7, + env_lval = 8, + env_symb_start = 9, + env_symb_end = 10, + env_asp = 11, + env_rule_len = 12, + env_rule_number = 13, + env_sp = 14, + env_state = 15, + env_errflag = 16, + tbl_transl_const = 2, + tbl_transl_block = 3, + tbl_lhs = 4, + tbl_len = 5, + tbl_defred = 6, + tbl_dgoto = 7, + tbl_sindex = 8, + tbl_rindex = 9, + tbl_gindex = 10, + tbl_tablesize = 11, + tbl_table = 12, + tbl_check = 13, + tbl_names_const = 15, + tbl_names_block = 16; + function log(x){ + var s = caml_string_of_jsbytes(x + "\n"); + caml_ml_output(2, s, 0, caml_ml_string_length(s)); + } + function token_name(names, number){ + var str = caml_jsstring_of_string(names); + if(str[0] == "\x00") return ""; + return str.split("\x00")[number]; + } + function print_token(state, tok){ + var token, kind; + if(tok instanceof Array){ + token = token_name(tables[tbl_names_block], tok[0]); + if(typeof tok[1] == "number") + kind = "" + tok[1]; + else if(typeof tok[1] == "string") + kind = tok[1]; + else if(tok[1] instanceof MlBytes) + kind = caml_jsbytes_of_string(tok[1]); + else + kind = "_"; + log("State " + state + ": read token " + token + "(" + kind + ")"); + } + else{ + token = token_name(tables[tbl_names_const], tok); + log("State " + state + ": read token " + token); + } + } + if(! tables.dgoto){ + tables.defred = caml_lex_array(tables[tbl_defred]); + tables.sindex = caml_lex_array(tables[tbl_sindex]); + tables.check = caml_lex_array(tables[tbl_check]); + tables.rindex = caml_lex_array(tables[tbl_rindex]); + tables.table = caml_lex_array(tables[tbl_table]); + tables.len = caml_lex_array(tables[tbl_len]); + tables.lhs = caml_lex_array(tables[tbl_lhs]); + tables.gindex = caml_lex_array(tables[tbl_gindex]); + tables.dgoto = caml_lex_array(tables[tbl_dgoto]); + } + var + res = 0, + n, + n1, + n2, + state1, + sp = env[env_sp], + state = env[env_state], + errflag = env[env_errflag]; + exit: + for(;;) + next: + switch(cmd){ + case 0: + state = 0; errflag = 0; + case 6: + n = tables.defred[state]; + if(n != 0){cmd = reduce; break;} + if(env[env_curr_char] >= 0){cmd = testshift; break;} + res = READ_TOKEN; + break exit; + case 1: + if(arg instanceof Array){ + env[env_curr_char] = tables[tbl_transl_block][arg[0] + 1]; + env[env_lval] = arg[1]; + } + else{ + env[env_curr_char] = tables[tbl_transl_const][arg + 1]; + env[env_lval] = 0; + } + if(caml_parser_trace) print_token(state, arg); + case 7: + n1 = tables.sindex[state]; + n2 = n1 + env[env_curr_char]; + if + (n1 != 0 && n2 >= 0 && n2 <= tables[tbl_tablesize] + && tables.check[n2] == env[env_curr_char]){cmd = shift; break;} + n1 = tables.rindex[state]; + n2 = n1 + env[env_curr_char]; + if + (n1 != 0 && n2 >= 0 && n2 <= tables[tbl_tablesize] + && tables.check[n2] == env[env_curr_char]){ + n = tables.table[n2]; + cmd = reduce; + break; + } + if(errflag <= 0){res = CALL_ERROR_FUNCTION; break exit;} + case 5: + if(errflag < 3){ + errflag = 3; + for(;;){ + state1 = env[env_s_stack][sp + 1]; + n1 = tables.sindex[state1]; + n2 = n1 + ERRCODE; + if + (n1 != 0 && n2 >= 0 && n2 <= tables[tbl_tablesize] + && tables.check[n2] == ERRCODE){ + if(caml_parser_trace) log("Recovering in state " + state1); + cmd = shift_recover; + break next; + } + else{ + if(caml_parser_trace) log("Discarding state " + state1); + if(sp <= env[env_stackbase]){ + if(caml_parser_trace) log("No more states to discard"); + return RAISE_PARSE_ERROR; + } + sp--; + } + } + } + else{ + if(env[env_curr_char] == 0) return RAISE_PARSE_ERROR; + if(caml_parser_trace) log("Discarding last token read"); + env[env_curr_char] = - 1; + cmd = loop; + break; + } + case 8: + env[env_curr_char] = - 1; if(errflag > 0) errflag--; + case 9: + if(caml_parser_trace) + log("State " + state + ": shift to state " + tables.table[n2]); + state = tables.table[n2]; + sp++; + if(sp >= env[env_stacksize]){res = GROW_STACKS_1; break exit;} + case 2: + env[env_s_stack][sp + 1] = state; + env[env_v_stack][sp + 1] = env[env_lval]; + env[env_symb_start_stack][sp + 1] = env[env_symb_start]; + env[env_symb_end_stack][sp + 1] = env[env_symb_end]; + cmd = loop; + break; + case 10: + if(caml_parser_trace) log("State " + state + ": reduce by rule " + n); + var m = tables.len[n]; + env[env_asp] = sp; + env[env_rule_number] = n; + env[env_rule_len] = m; + sp = sp - m + 1; + m = tables.lhs[n]; + state1 = env[env_s_stack][sp]; + n1 = tables.gindex[m]; + n2 = n1 + state1; + if + (n1 != 0 && n2 >= 0 && n2 <= tables[tbl_tablesize] + && tables.check[n2] == state1) + state = tables.table[n2]; + else + state = tables.dgoto[m]; + if(sp >= env[env_stacksize]){res = GROW_STACKS_2; break exit;} + case 3: + res = COMPUTE_SEMANTIC_ACTION; break exit; + case 4: + env[env_s_stack][sp + 1] = state; + env[env_v_stack][sp + 1] = arg; + var asp = env[env_asp]; + env[env_symb_end_stack][sp + 1] = env[env_symb_end_stack][asp + 1]; + if(sp > asp) + env[env_symb_start_stack][sp + 1] = env[env_symb_end_stack][asp + 1]; + cmd = loop; + break; + default: return RAISE_PARSE_ERROR; + } + env[env_sp] = sp; + env[env_state] = state; + env[env_errflag] = errflag; + return res; + } + function caml_pure_js_expr(s){ + console.error("caml_pure_js_expr: fallback to runtime evaluation\n"); + return eval(caml_jsstring_of_string(s)); + } + function caml_raise_not_a_dir(name){ + caml_raise_sys_error(name + ": Not a directory"); + } + function caml_raise_not_found(){ + caml_raise_constant(caml_global_data.Not_found); + } + function caml_raw_backtrace_length(){return 0;} + function caml_raw_backtrace_next_slot(){return 0;} + function caml_raw_backtrace_slot(){ + caml_invalid_argument + ("Printexc.get_raw_backtrace_slot: index out of bounds"); + } + function caml_read_file_content(name){ + var + name = typeof name == "string" ? caml_string_of_jsbytes(name) : name, + root = resolve_fs_device(name); + if(root.device.exists(root.rest)){ + var + file = root.device.open(root.rest, {rdonly: 1}), + len = file.length(), + buf = new Uint8Array(len); + file.read(0, buf, 0, len); + return caml_string_of_array(buf); + } + caml_raise_no_such_file(caml_jsbytes_of_string(name)); + } + function caml_recommended_domain_count(unit){return 1;} + function caml_record_backtrace(b){ + caml_record_backtrace_flag = b; + return 0; + } + function caml_register_channel_for_spacetime(_channel){return 0;} + function caml_register_global(n, v, name_opt){ + if(name_opt){ + var name = name_opt; + if(globalThis.toplevelReloc) + n = caml_callback(globalThis.toplevelReloc, [name]); + else if(caml_global_data.symbols){ + if(! caml_global_data.symidx) + caml_global_data.symidx = caml_build_symbols(caml_global_data.symbols); + var nid = caml_global_data.symidx[name]; + if(nid >= 0) + n = nid; + else + caml_failwith("caml_register_global: cannot locate " + name); + } + } + caml_global_data[n + 1] = v; + if(name_opt) caml_global_data[name_opt] = v; + } + function caml_register_named_value(nm, v){ + caml_named_values[caml_jsbytes_of_string(nm)] = v; + return 0; + } + function caml_restore_raw_backtrace(exn, bt){return 0;} + function caml_round_float(x){ + if(x >= 0){ + var y = Math.floor(x); + return x - y >= 0.5 ? y + 1 : y; + } + else{var y = Math.ceil(x); return y - x >= 0.5 ? y - 1 : y;} + } + function caml_runtime_events_create_cursor(target){return {};} + function caml_runtime_events_free_cursor(cursor){return 0;} + function caml_runtime_events_read_poll(cursor, callbacks, num){return 0;} + function caml_runtime_events_user_register + (event_name, event_tag, event_type){ + caml_custom_event_index += 1; + return [0, caml_custom_event_index, event_name, event_type, event_tag]; + } + function caml_runtime_events_user_resolve(){return 0;} + function caml_runtime_events_user_write(event, event_content){return 0;} + function caml_runtime_parameters(_unit){return caml_string_of_jsbytes("");} + function caml_runtime_variant(_unit){return caml_string_of_jsbytes("");} + function caml_set_oo_id(b){b[2] = caml_oo_last_id++; return b;} + function caml_set_parser_trace(bool){ + var oldflag = caml_parser_trace; + caml_parser_trace = bool; + return oldflag; + } + function caml_set_static_env(k, v){ + if(! globalThis.jsoo_static_env) globalThis.jsoo_static_env = {}; + globalThis.jsoo_static_env[k] = v; + return 0; + } + function caml_signbit_float(x){if(x == 0) x = 1 / x; return x < 0 ? 1 : 0;} + function caml_sinh_float(x){return Math.sinh(x);} + function caml_spacetime_enabled(_unit){return 0;} + function caml_spacetime_only_works_for_native_code(){ + caml_failwith("Spacetime profiling only works for native code"); + } + function caml_str_initialize(unit){return 0;} + function caml_string_bound_error(){ + caml_invalid_argument("index out of bounds"); + } + function caml_string_concat(a, b){return a + b;} + function caml_string_equal(s1, s2){if(s1 === s2) return 1; return 0;} + function caml_string_get(s, i){ + if(i >>> 0 >= caml_ml_string_length(s)) caml_string_bound_error(); + return caml_string_unsafe_get(s, i); + } + function caml_string_get16(s, i){ + if(i >>> 0 >= caml_ml_string_length(s) - 1) caml_string_bound_error(); + var + b1 = caml_string_unsafe_get(s, i), + b2 = caml_string_unsafe_get(s, i + 1); + return b2 << 8 | b1; + } + function caml_string_get32(s, i){ + if(i >>> 0 >= caml_ml_string_length(s) - 3) caml_string_bound_error(); + var + b1 = caml_string_unsafe_get(s, i), + b2 = caml_string_unsafe_get(s, i + 1), + b3 = caml_string_unsafe_get(s, i + 2), + b4 = caml_string_unsafe_get(s, i + 3); + return b4 << 24 | b3 << 16 | b2 << 8 | b1; + } + function caml_string_get64(s, i){ + if(i >>> 0 >= caml_ml_string_length(s) - 7) caml_string_bound_error(); + var a = new Array(8); + for(var j = 0; j < 8; j++) a[7 - j] = caml_string_unsafe_get(s, i + j); + return caml_int64_of_bytes(a); + } + function caml_string_lessequal(s1, s2){return s1 <= s2 ? 1 : 0;} + function caml_string_greaterequal(s1, s2){return caml_string_lessequal(s2, s1); + } + function caml_string_lessthan(s1, s2){return s1 < s2 ? 1 : 0;} + function caml_string_greaterthan(s1, s2){return caml_string_lessthan(s2, s1); + } + function caml_string_hash(h, v){ + var h = caml_hash_mix_string(h, v), h = caml_hash_mix_final(h); + return h & 0x3FFFFFFF; + } + function caml_string_notequal(s1, s2){ + return 1 - caml_string_equal(s1, s2); + } + function caml_string_set(s, i, c){caml_failwith("caml_string_set");} + function caml_string_set16(s, i, i16){caml_failwith("caml_string_set16");} + function caml_string_set32(s, i, i32){caml_failwith("caml_string_set32");} + function caml_string_set64(s, i, i64){caml_failwith("caml_string_set64");} + function caml_string_unsafe_set(s, i, c){ + caml_failwith("caml_string_unsafe_set"); + } + function caml_sys_argv(a){return caml_argv;} + function caml_sys_chdir(dir){ + var root = resolve_fs_device(dir); + if(root.device.exists(root.rest)){ + if(root.rest) + caml_current_dir = caml_trailing_slash(root.path + root.rest); + else + caml_current_dir = root.path; + return 0; + } + else + caml_raise_no_such_file(caml_jsbytes_of_string(dir)); + } + function caml_sys_const_backend_type(){ + return [0, caml_string_of_jsbytes("js_of_ocaml")]; + } + function caml_sys_const_big_endian(){return 0;} + function caml_sys_const_int_size(){return 32;} + function caml_sys_const_max_wosize(){return 0x7FFFFFFF / 4 | 0;} + function caml_sys_const_naked_pointers_checked(_unit){return 0;} + var + os_type = + globalThis.process && globalThis.process.platform + && globalThis.process.platform == "win32" + ? "Cygwin" + : "Unix"; + function caml_sys_const_ostype_cygwin(){return os_type == "Cygwin" ? 1 : 0; + } + function caml_sys_const_ostype_unix(){return os_type == "Unix" ? 1 : 0;} + function caml_sys_const_ostype_win32(){return os_type == "Win32" ? 1 : 0;} + function caml_sys_const_word_size(){return 32;} + function caml_sys_executable_name(a){return caml_executable_name;} + function caml_sys_exit(code){ + if(globalThis.quit) globalThis.quit(code); + if(globalThis.process && globalThis.process.exit) + globalThis.process.exit(code); + caml_invalid_argument("Function 'exit' not implemented"); + } + function caml_sys_file_exists(name){ + var root = resolve_fs_device(name); + return root.device.exists(root.rest); + } + function caml_sys_get_argv(a){return [0, caml_argv[1], caml_argv];} + function caml_sys_get_config(){ + return [0, caml_string_of_jsbytes(os_type), 32, 0]; + } + function caml_sys_getcwd(){ + return caml_string_of_jsbytes(caml_current_dir); + } + function caml_sys_getenv(name){ + var r = jsoo_sys_getenv(caml_jsstring_of_string(name)); + if(r === undefined) caml_raise_not_found(); + return caml_string_of_jsstring(r); + } + function caml_sys_is_directory(name){ + var root = resolve_fs_device(name), a = root.device.is_dir(root.rest); + return a ? 1 : 0; + } + function caml_sys_is_regular_file(name){ + var root = resolve_fs_device(name); + return root.device.isFile(root.rest); + } + function caml_sys_isatty(_chan){return 0;} + function caml_sys_mkdir(name, perm){ + var root = resolve_fs_device(name); + root.device.mkdir(root.rest, perm); + return 0; + } + function caml_sys_modify_argv(arg){caml_argv = arg; return 0;} + function caml_sys_random_seed(){ + if(globalThis.crypto) + if(globalThis.crypto.getRandomValues){ + var a = globalThis.crypto.getRandomValues(new Int32Array(4)); + return [0, a[0], a[1], a[2], a[3]]; + } + else if(globalThis.crypto.randomBytes){ + var a = new Int32Array(globalThis.crypto.randomBytes(16).buffer); + return [0, a[0], a[1], a[2], a[3]]; + } + var now = new Date().getTime(), x = now ^ 0xffffffff * Math.random(); + return [0, x]; + } + function caml_sys_read_directory(name){ + var + root = resolve_fs_device(name), + a = root.device.readdir(root.rest), + l = new Array(a.length + 1); + l[0] = 0; + for(var i = 0; i < a.length; i++) l[i + 1] = caml_string_of_jsbytes(a[i]); + return l; + } + function caml_sys_remove(name){ + var root = resolve_fs_device(name), ok = root.device.unlink(root.rest); + if(ok == 0) caml_raise_no_such_file(caml_jsbytes_of_string(name)); + return 0; + } + function caml_sys_rename(o, n){ + var o_root = resolve_fs_device(o), n_root = resolve_fs_device(n); + if(o_root.device != n_root.device) + caml_failwith("caml_sys_rename: cannot move file between two filesystem"); + if(! o_root.device.rename) + caml_failwith("caml_sys_rename: no implemented"); + o_root.device.rename(o_root.rest, n_root.rest); + } + function caml_sys_rmdir(name){ + var root = resolve_fs_device(name); + root.device.rmdir(root.rest); + return 0; + } + function caml_sys_system_command(cmd){ + var cmd = caml_jsstring_of_string(cmd); + if(typeof require != "undefined"){ + var child_process = require("child_process"); + if(child_process && child_process.execSync) + try{child_process.execSync(cmd, {stdio: "inherit"}); return 0;} + catch(e){return 1;} + } + else + return 127; + } + var caml_initial_time = new Date().getTime() * 0.001; + function caml_sys_time(){ + var now = new Date().getTime(); + return now * 0.001 - caml_initial_time; + } + function caml_sys_time_include_children(b){return caml_sys_time();} + function caml_sys_unsafe_getenv(name){return caml_sys_getenv(name);} + function caml_tanh_float(x){return Math.tanh(x);} + function caml_to_js_string(s){return caml_jsstring_of_string(s);} + function caml_trampoline(res){ + var c = 1; + while(res && res.joo_tramp){ + res = res.joo_tramp.apply(null, res.joo_args); + c++; + } + return res; + } + function caml_trampoline_return(f, args){return {joo_tramp: f, joo_args: args}; + } + function caml_trunc_float(x){return Math.trunc(x);} + function caml_unix_cleanup(){} + function caml_unix_closedir(dir_handle){ + try{dir_handle.pointer.closeSync();} + catch(e){ + var unix_error = caml_named_value("Unix.Unix_error"); + caml_raise_with_args + (unix_error, make_unix_err_args("EBADF", "closedir", dir_handle.path)); + } + } + function caml_unix_filedescr_of_fd(x){return x;} + function caml_unix_findclose(dir_handle){return caml_unix_closedir(dir_handle); + } + function caml_unix_opendir(path){ + var root = resolve_fs_device(path); + if(! root.device.opendir) + caml_failwith("caml_unix_opendir: not implemented"); + var dir_handle = root.device.opendir(root.rest, true); + return {pointer: dir_handle, path: path}; + } + function caml_unix_readdir(dir_handle){ + var entry; + try{entry = dir_handle.pointer.readSync();} + catch(e){ + var unix_error = caml_named_value("Unix.Unix_error"); + caml_raise_with_args + (unix_error, make_unix_err_args("EBADF", "readdir", dir_handle.path)); + } + if(entry === null) + caml_raise_end_of_file(); + else + return caml_string_of_jsstring(entry.name); + } + function caml_unix_findfirst(path){ + var path_js = caml_jsstring_of_string(path); + path_js = path_js.replace(/(^|[\\\/])\*\.\*$/, ""); + path = caml_string_of_jsstring(path_js); + var + dir_handle = caml_unix_opendir(path), + first_entry = caml_unix_readdir(dir_handle); + return [0, first_entry, dir_handle]; + } + function caml_unix_findnext(dir_handle){return caml_unix_readdir(dir_handle); + } + function caml_unix_getpwuid(unit){caml_raise_not_found();} + function caml_unix_gettimeofday(){return new Date().getTime() / 1000;} + function caml_unix_getuid(unit){ + if(globalThis.process && globalThis.process.getuid) + return globalThis.process.getuid(); + caml_raise_not_found(); + } + function caml_unix_gmtime(t){ + var + d = new Date(t * 1000), + d_num = d.getTime(), + januaryfirst = new Date(Date.UTC(d.getUTCFullYear(), 0, 1)).getTime(), + doy = Math.floor((d_num - januaryfirst) / 86400000); + return [0, + d.getUTCSeconds(), + d.getUTCMinutes(), + d.getUTCHours(), + d.getUTCDate(), + d.getUTCMonth(), + d.getUTCFullYear() - 1900, + d.getUTCDay(), + doy, + false | 0]; + } + function caml_unix_has_symlink(unit){return fs_node_supported() ? 1 : 0;} + function caml_unix_inet_addr_of_string(){return 0;} + function caml_unix_isatty(fileDescriptor){ + if(fs_node_supported()){ + var tty = require("tty"); + return tty.isatty(fileDescriptor) ? 1 : 0; + } + else + return 0; + } + function caml_unix_localtime(t){ + var + d = new Date(t * 1000), + d_num = d.getTime(), + januaryfirst = new Date(d.getFullYear(), 0, 1).getTime(), + doy = Math.floor((d_num - januaryfirst) / 86400000), + jan = new Date(d.getFullYear(), 0, 1), + jul = new Date(d.getFullYear(), 6, 1), + stdTimezoneOffset = + Math.max(jan.getTimezoneOffset(), jul.getTimezoneOffset()); + return [0, + d.getSeconds(), + d.getMinutes(), + d.getHours(), + d.getDate(), + d.getMonth(), + d.getFullYear() - 1900, + d.getDay(), + doy, + d.getTimezoneOffset() < stdTimezoneOffset | 0]; + } + function caml_unix_lstat(name){ + var root = resolve_fs_device(name); + if(! root.device.lstat) caml_failwith("caml_unix_lstat: not implemented"); + return root.device.lstat(root.rest, true); + } + function caml_unix_lstat_64(name){ + var r = caml_unix_lstat(name); + r[9] = caml_int64_of_int32(r[9]); + return r; + } + function caml_unix_mkdir(name, perm){ + var root = resolve_fs_device(name); + if(! root.device.mkdir) caml_failwith("caml_unix_mkdir: not implemented"); + return root.device.mkdir(root.rest, perm, true); + } + function caml_unix_mktime(tm){ + var + d = new Date(tm[6] + 1900, tm[5], tm[4], tm[3], tm[2], tm[1]).getTime(), + t = Math.floor(d / 1000), + tm2 = caml_unix_localtime(t); + return [0, t, tm2]; + } + function caml_unix_readlink(name){ + var root = resolve_fs_device(name); + if(! root.device.readlink) + caml_failwith("caml_unix_readlink: not implemented"); + return root.device.readlink(root.rest, true); + } + function caml_unix_rewinddir(dir_handle){ + caml_unix_closedir(dir_handle); + var new_dir_handle = caml_unix_opendir(dir_handle.path); + dir_handle.pointer = new_dir_handle.pointer; + return 0; + } + function caml_unix_rmdir(name){ + var root = resolve_fs_device(name); + if(! root.device.rmdir) caml_failwith("caml_unix_rmdir: not implemented"); + return root.device.rmdir(root.rest, true); + } + function caml_unix_startup(){} + function caml_unix_stat(name){ + var root = resolve_fs_device(name); + if(! root.device.stat) caml_failwith("caml_unix_stat: not implemented"); + return root.device.stat(root.rest, true); + } + function caml_unix_stat_64(name){ + var r = caml_unix_stat(name); + r[9] = caml_int64_of_int32(r[9]); + return r; + } + function caml_unix_symlink(to_dir, src, dst){ + var src_root = resolve_fs_device(src), dst_root = resolve_fs_device(dst); + if(src_root.device != dst_root.device) + caml_failwith + ("caml_unix_symlink: cannot symlink between two filesystems"); + if(! src_root.device.symlink) + caml_failwith("caml_unix_symlink: not implemented"); + return src_root.device.symlink(to_dir, src_root.rest, dst_root.rest, true); + } + function caml_unix_time(){return Math.floor(caml_unix_gettimeofday());} + function caml_unix_unlink(name){ + var root = resolve_fs_device(name); + if(! root.device.unlink) + caml_failwith("caml_unix_unlink: not implemented"); + return root.device.unlink(root.rest, true); + } + function caml_unmount(name){ + var + path = caml_make_path(name), + name = caml_trailing_slash(path.join("/")), + idx = - 1; + for(var i = 0; i < jsoo_mount_point.length; i++) + if(jsoo_mount_point[i].path == name) idx = i; + if(idx > - 1) jsoo_mount_point.splice(idx, 1); + return 0; + } + function caml_update_dummy(x, y){ + if(y.fun){x.fun = y.fun; return 0;} + if(typeof y === "function"){x.fun = y; return 0;} + var i = y.length; + while(i--) x[i] = y[i]; + return 0; + } + function caml_weak_set(x, i, v){ + if(v == 0) caml_ephe_unset_key(x, i); else caml_ephe_set_key(x, i, v[1]); + return 0; + } + function caml_wrap_exception(e){ + { + if(e instanceof Array) return e; + var exn; + if + (globalThis.RangeError && e instanceof globalThis.RangeError + && e.message + && e.message.match(/maximum call stack/i)) + exn = caml_global_data.Stack_overflow; + else if + (globalThis.InternalError && e instanceof globalThis.InternalError + && e.message + && e.message.match(/too much recursion/i)) + exn = caml_global_data.Stack_overflow; + else if(e instanceof globalThis.Error && caml_named_value("jsError")) + exn = [0, caml_named_value("jsError"), e]; + else + exn = [0, caml_global_data.Failure, caml_string_of_jsstring(String(e))]; + if(e instanceof globalThis.Error) exn.js_error = e; + return exn; + } + } + function caml_xmlhttprequest_create(unit){ + if(typeof globalThis.XMLHttpRequest !== "undefined") + try{return new globalThis.XMLHttpRequest;}catch(e){} + if(typeof globalThis.activeXObject !== "undefined"){ + try{return new globalThis.activeXObject("Msxml2.XMLHTTP");}catch(e){} + try{return new globalThis.activeXObject("Msxml3.XMLHTTP");}catch(e){} + try{return new globalThis.activeXObject("Microsoft.XMLHTTP");}catch(e){} + } + caml_failwith("Cannot create a XMLHttpRequest"); + } + function compare_digits_nat(nat1, ofs1, nat2, ofs2){ + if(nat1.data[ofs1] > nat2.data[ofs2]) return 1; + if(nat1.data[ofs1] < nat2.data[ofs2]) return - 1; + return 0; + } + function compare_nat(nat1, ofs1, len1, nat2, ofs2, len2){ + var + a = num_digits_nat(nat1, ofs1, len1), + b = num_digits_nat(nat2, ofs2, len2); + if(a > b) return 1; + if(a < b) return - 1; + for(var i = len1 - 1; i >= 0; i--){ + if(nat1.data[ofs1 + i] >>> 0 > nat2.data[ofs2 + i] >>> 0) return 1; + if(nat1.data[ofs1 + i] >>> 0 < nat2.data[ofs2 + i] >>> 0) return - 1; + } + return 0; + } + function compare_nat_real(nat1, nat2){ + return compare_nat(nat1, 0, nat1.data.length, nat2, 0, nat2.data.length); + } + function complement_nat(nat, ofs, len){ + for(var i = 0; i < len; i++) + nat.data[ofs + i] = (- 1 >>> 0) - (nat.data[ofs + i] >>> 0); + } + function create_nat(size){ + var arr = new MlNat(size); + for(var i = 0; i < size; i++) arr.data[i] = - 1; + return arr; + } + function decr_nat(nat, ofs, len, carry_in){ + var borrow = carry_in == 1 ? 0 : 1; + for(var i = 0; i < len; i++){ + var x = (nat.data[ofs + i] >>> 0) - borrow; + nat.data[ofs + i] = x; + if(x >= 0){borrow = 0; break;} else borrow = 1; + } + return borrow == 1 ? 0 : 1; + } + function deserialize_nat(reader, sz){ + var len = reader.read32s(), nat = new MlNat(len); + for(var i = 0; i < len; i++) nat.data[i] = reader.read32s(); + sz[0] = len * 4; + return nat; + } + function div_helper(a, b, c){ + var + x = a * 65536 + (b >>> 16), + y = Math.floor(x / c) * 65536, + z = x % c * 65536, + w = z + (b & 0x0000FFFF); + return [y + Math.floor(w / c), w % c]; + } + function div_digit_nat(natq, ofsq, natr, ofsr, nat1, ofs1, len, nat2, ofs2){ + var rem = nat1.data[ofs1 + len - 1] >>> 0; + for(var i = len - 2; i >= 0; i--){ + var + x = div_helper(rem, nat1.data[ofs1 + i] >>> 0, nat2.data[ofs2] >>> 0); + natq.data[ofsq + i] = x[0]; + rem = x[1]; + } + natr.data[ofsr] = rem; + return 0; + } + function num_leading_zero_bits_in_digit(nat, ofs){ + var a = nat.data[ofs], b = 0; + if(a & 0xFFFF0000){b += 16; a >>>= 16;} + if(a & 0xFF00){b += 8; a >>>= 8;} + if(a & 0xF0){b += 4; a >>>= 4;} + if(a & 12){b += 2; a >>>= 2;} + if(a & 2){b += 1; a >>>= 1;} + if(a & 1) b += 1; + return 32 - b; + } + function shift_left_nat(nat1, ofs1, len1, nat2, ofs2, nbits){ + if(nbits == 0){nat2.data[ofs2] = 0; return 0;} + var wrap = 0; + for(var i = 0; i < len1; i++){ + var a = nat1.data[ofs1 + i] >>> 0; + nat1.data[ofs1 + i] = a << nbits | wrap; + wrap = a >>> 32 - nbits; + } + nat2.data[ofs2] = wrap; + return 0; + } + function shift_right_nat(nat1, ofs1, len1, nat2, ofs2, nbits){ + if(nbits == 0){nat2.data[ofs2] = 0; return 0;} + var wrap = 0; + for(var i = len1 - 1; i >= 0; i--){ + var a = nat1.data[ofs1 + i] >>> 0; + nat1.data[ofs1 + i] = a >>> nbits | wrap; + wrap = a << 32 - nbits; + } + nat2.data[ofs2] = wrap; + return 0; + } + function set_to_zero_nat(nat, ofs, len){ + for(var i = 0; i < len; i++) nat.data[ofs + i] = 0; + return 0; + } + function nat_of_array(l){return new MlNat(l);} + function mult_digit_nat(nat1, ofs1, len1, nat2, ofs2, len2, nat3, ofs3){ + var carry = 0, a = nat3.data[ofs3] >>> 0; + for(var i = 0; i < len2; i++){ + var + x1 = + (nat1.data[ofs1 + i] >>> 0) + + (nat2.data[ofs2 + i] >>> 0) * (a & 0x0000FFFF) + + carry, + x2 = (nat2.data[ofs2 + i] >>> 0) * (a >>> 16); + carry = Math.floor(x2 / 65536); + var x3 = x1 + x2 % 65536 * 65536; + nat1.data[ofs1 + i] = x3; + carry += Math.floor(x3 / 4294967296); + } + return len2 < len1 && carry + ? add_nat + (nat1, ofs1 + len2, len1 - len2, nat_of_array([carry]), 0, 1, 0) + : carry; + } + function sub_nat(nat1, ofs1, len1, nat2, ofs2, len2, carry_in){ + var borrow = carry_in == 1 ? 0 : 1; + for(var i = 0; i < len2; i++){ + var + x = (nat1.data[ofs1 + i] >>> 0) - (nat2.data[ofs2 + i] >>> 0) - borrow; + nat1.data[ofs1 + i] = x; + if(x >= 0) borrow = 0; else borrow = 1; + } + return decr_nat(nat1, ofs1 + len2, len1 - len2, borrow == 1 ? 0 : 1); + } + function div_nat(nat1, ofs1, len1, nat2, ofs2, len2){ + if(len2 == 1){ + div_digit_nat(nat1, ofs1 + 1, nat1, ofs1, nat1, ofs1, len1, nat2, ofs2); + return 0; + } + var s = num_leading_zero_bits_in_digit(nat2, ofs2 + len2 - 1); + shift_left_nat(nat2, ofs2, len2, nat_of_array([0]), 0, s); + shift_left_nat(nat1, ofs1, len1, nat_of_array([0]), 0, s); + var d = (nat2.data[ofs2 + len2 - 1] >>> 0) + 1, a = create_nat(len2 + 1); + for(var i = len1 - 1; i >= len2; i--){ + var + quo = + d == 4294967296 + ? nat1.data[ofs1 + i] >>> 0 + : div_helper + (nat1.data[ofs1 + i] >>> 0, nat1.data[ofs1 + i - 1] >>> 0, d) + [0]; + set_to_zero_nat(a, 0, len2 + 1); + mult_digit_nat(a, 0, len2 + 1, nat2, ofs2, len2, nat_of_array([quo]), 0); + sub_nat(nat1, ofs1 + i - len2, len2 + 1, a, 0, len2 + 1, 1); + while + (nat1.data[ofs1 + i] != 0 + || compare_nat(nat1, ofs1 + i - len2, len2, nat2, ofs2, len2) >= 0){ + quo = quo + 1; + sub_nat(nat1, ofs1 + i - len2, len2 + 1, nat2, ofs2, len2, 1); + } + nat1.data[ofs1 + i] = quo; + } + shift_right_nat(nat1, ofs1, len2, nat_of_array([0]), 0, s); + shift_right_nat(nat2, ofs2, len2, nat_of_array([0]), 0, s); + return 0; + } + function serialize_nat(writer, nat, sz){ + var len = nat.data.length; + writer.write(32, len); + for(var i = 0; i < len; i++) writer.write(32, nat.data[i]); + sz[0] = len * 4; + sz[1] = len * 8; + } + function initialize_nat(){ + caml_custom_ops["_nat"] = + {deserialize: deserialize_nat, + serialize: serialize_nat, + hash: caml_hash_nat}; + } + function is_digit_int(nat, ofs){if(nat.data[ofs] >= 0) return 1; return 0;} + function is_digit_odd(nat, ofs){if(nat.data[ofs] & 1) return 1; return 0;} + function is_digit_zero(nat, ofs){ + if(nat.data[ofs] == 0) return 1; + return 0; + } + function jsoo_create_file_extern(name, content){ + if(globalThis.jsoo_create_file) + globalThis.jsoo_create_file(name, content); + else{ + if(! globalThis.caml_fs_tmp) globalThis.caml_fs_tmp = []; + globalThis.caml_fs_tmp.push({name: name, content: content}); + } + return 0; + } + function jsoo_effect_not_supported(){ + caml_failwith("Effect handlers are not supported"); + } + function land_digit_nat(nat1, ofs1, nat2, ofs2){nat1.data[ofs1] &= nat2.data[ofs2]; return 0; + } + function length_nat(x){return x.data.length;} + function lor_digit_nat(nat1, ofs1, nat2, ofs2){nat1.data[ofs1] |= nat2.data[ofs2]; return 0; + } + function lxor_digit_nat(nat1, ofs1, nat2, ofs2){nat1.data[ofs1] ^= nat2.data[ofs2]; return 0; + } + function mult_nat(nat1, ofs1, len1, nat2, ofs2, len2, nat3, ofs3, len3){ + var carry = 0; + for(var i = 0; i < len3; i++) + carry += + mult_digit_nat + (nat1, ofs1 + i, len1 - i, nat2, ofs2, len2, nat3, ofs3 + i); + return carry; + } + function nth_digit_nat(nat, ofs){return nat.data[ofs];} + function nth_digit_nat_native(nat, ofs){return nat.data[ofs];} + var + re_match = + function(){ + var + re_word_letters = + [0x00, + 0x00, + 0x00, + 0x00, + 0x00, + 0x00, + 0xFF, + 0x03, + 0xFE, + 0xFF, + 0xFF, + 0x87, + 0xFE, + 0xFF, + 0xFF, + 0x07, + 0x00, + 0x00, + 0x00, + 0x00, + 0x00, + 0x00, + 0x00, + 0x00, + 0xFF, + 0xFF, + 0x7F, + 0xFF, + 0xFF, + 0xFF, + 0x7F, + 0xFF], + opcodes = + {CHAR: 0, + CHARNORM: 1, + STRING: 2, + STRINGNORM: 3, + CHARCLASS: 4, + BOL: 5, + EOL: 6, + WORDBOUNDARY: 7, + BEGGROUP: 8, + ENDGROUP: 9, + REFGROUP: 10, + ACCEPT: 11, + SIMPLEOPT: 12, + SIMPLESTAR: 13, + SIMPLEPLUS: 14, + GOTO: 15, + PUSHBACK: 16, + SETMARK: 17, + CHECKPROGRESS: 18}; + function is_word_letter(c){ + return re_word_letters[c >> 3] >> (c & 7) & 1; + } + function in_bitset(s, i){ + return caml_string_get(s, i >> 3) >> (i & 7) & 1; + } + function re_match_impl(re, s, pos, partial){ + var + prog = caml_js_from_array(re[1]), + cpool = caml_js_from_array(re[2]), + normtable = caml_jsbytes_of_string(re[3]), + numgroups = re[4] | 0, + numregisters = re[5] | 0, + startchars = re[6] | 0, + s = caml_uint8_array_of_string(s), + pc = 0, + quit = false, + stack = [], + groups = new Array(numgroups), + re_register = new Array(numregisters); + for(var i = 0; i < groups.length; i++) + groups[i] = {start: - 1, end: - 1}; + groups[0].start = pos; + function backtrack(){ + while(stack.length){ + var item = stack.pop(); + if(item.undo) + item.undo.obj[item.undo.prop] = item.undo.value; + else if(item.pos){pc = item.pos.pc; pos = item.pos.txt; return;} + } + quit = true; + } + function push(item){stack.push(item);} + function accept(){ + groups[0].end = pos; + var result = new Array(1 + groups.length * 2); + result[0] = 0; + for(var i = 0; i < groups.length; i++){ + var g = groups[i]; + if(g.start < 0 || g.end < 0) g.start = g.end = - 1; + result[2 * i + 1] = g.start; + result[2 * i + 1 + 1] = g.end; + } + return result; + } + function prefix_match(){ + if(partial) return accept(); else backtrack(); + } + while(! quit){ + var + op = prog[pc] & 0xff, + sarg = prog[pc] >> 8, + uarg = sarg & 0xff, + c = s[pos], + group; + pc++; + switch(op){ + case opcodes.CHAR: + if(pos === s.length){prefix_match(); break;} + if(c === uarg) pos++; else backtrack(); + break; + case opcodes.CHARNORM: + if(pos === s.length){prefix_match(); break;} + if(normtable.charCodeAt(c) === uarg) pos++; else backtrack(); + break; + case opcodes.STRING: + for + (var arg = caml_jsbytes_of_string(cpool[uarg]), i = 0; + i < arg.length; + i++){ + if(pos === s.length){prefix_match(); break;} + if(c === arg.charCodeAt(i)) + c = s[++pos]; + else{backtrack(); break;} + } + break; + case opcodes.STRINGNORM: + for + (var arg = caml_jsbytes_of_string(cpool[uarg]), i = 0; + i < arg.length; + i++){ + if(pos === s.length){prefix_match(); break;} + if(normtable.charCodeAt(c) === arg.charCodeAt(i)) + c = s[++pos]; + else{backtrack(); break;} + } + break; + case opcodes.CHARCLASS: + if(pos === s.length){prefix_match(); break;} + if(in_bitset(cpool[uarg], c)) pos++; else backtrack(); + break; + case opcodes.BOL: + if(pos > 0 && s[pos - 1] != 10) backtrack(); break; + case opcodes.EOL: + if(pos < s.length && s[pos] != 10) backtrack(); break; + case opcodes.WORDBOUNDARY: + if(pos == 0){ + if(pos === s.length){prefix_match(); break;} + if(is_word_letter(s[0])) break; + backtrack(); + } + else if(pos === s.length){ + if(is_word_letter(s[pos - 1])) break; + backtrack(); + } + else{ + if(is_word_letter(s[pos - 1]) != is_word_letter(s[pos])) break; + backtrack(); + } + break; + case opcodes.BEGGROUP: + group = groups[uarg]; + push({undo: {obj: group, prop: "start", value: group.start}}); + group.start = pos; + break; + case opcodes.ENDGROUP: + group = groups[uarg]; + push({undo: {obj: group, prop: "end", value: group.end}}); + group.end = pos; + break; + case opcodes.REFGROUP: + group = groups[uarg]; + if(group.start < 0 || group.end < 0){backtrack(); break;} + for(var i = group.start; i < group.end; i++){ + if(pos === s.length){prefix_match(); break;} + if(s[i] != s[pos]){backtrack(); break;} + pos++; + } + break; + case opcodes.SIMPLEOPT: + if(in_bitset(cpool[uarg], c)) pos++; break; + case opcodes.SIMPLESTAR: + while(in_bitset(cpool[uarg], c)) c = s[++pos]; break; + case opcodes.SIMPLEPLUS: + if(pos === s.length){prefix_match(); break;} + if(in_bitset(cpool[uarg], c)) + do c = s[++pos];while(in_bitset(cpool[uarg], c)); + else + backtrack(); + break; + case opcodes.ACCEPT: return accept(); + case opcodes.GOTO: + pc = pc + sarg; break; + case opcodes.PUSHBACK: + push({pos: {pc: pc + sarg, txt: pos}}); break; + case opcodes.SETMARK: + push + ({undo: {obj: re_register, prop: uarg, value: re_register[uarg]}}); + re_register[uarg] = pos; + break; + case opcodes.CHECKPROGRESS: + if(re_register[uarg] === pos) backtrack(); break; + default: throw new Error("Invalid bytecode"); + } + } + return 0; + } + return re_match_impl; + } + (); + function re_partial_match(re, s, pos){ + if(pos < 0 || pos > caml_ml_string_length(s)) + caml_invalid_argument("Str.partial_match"); + var res = re_match(re, s, pos, 1); + return res ? res : [0]; + } + function re_replacement_text(repl, groups, orig){ + var + repl = caml_jsbytes_of_string(repl), + len = repl.length, + orig = caml_jsbytes_of_string(orig), + res = "", + n = 0, + cur, + start, + end, + c; + while(n < len){ + cur = repl.charAt(n++); + if(cur != "\\") + res += cur; + else{ + if(n == len) caml_failwith("Str.replace: illegal backslash sequence"); + cur = repl.charAt(n++); + switch(cur){ + case "\\": + res += cur; break; + case "0": + case "1": + case "2": + case "3": + case "4": + case "5": + case "6": + case "7": + case "8": + case "9": + c = + cur; + if(c * 2 >= groups.length - 1) + caml_failwith("Str.replace: reference to unmatched group"); + start = caml_array_get(groups, c * 2); + end = caml_array_get(groups, c * 2 + 1); + if(start == - 1) + caml_failwith("Str.replace: reference to unmatched group"); + res += orig.slice(start, end); + break; + default: res += "\\" + cur; + } + } + } + return caml_string_of_jsbytes(res); + } + function re_search_backward(re, s, pos){ + if(pos < 0 || pos > caml_ml_string_length(s)) + caml_invalid_argument("Str.search_backward"); + while(pos >= 0){ + var res = re_match(re, s, pos, 0); + if(res) return res; + pos--; + } + return [0]; + } + function re_search_forward(re, s, pos){ + if(pos < 0 || pos > caml_ml_string_length(s)) + caml_invalid_argument("Str.search_forward"); + while(pos <= caml_ml_string_length(s)){ + var res = re_match(re, s, pos, 0); + if(res) return res; + pos++; + } + return [0]; + } + function re_string_match(re, s, pos){ + if(pos < 0 || pos > caml_ml_string_length(s)) + caml_invalid_argument("Str.string_match"); + var res = re_match(re, s, pos, 0); + return res ? res : [0]; + } + function set_digit_nat(nat, ofs, digit){nat.data[ofs] = digit; return 0;} + function set_digit_nat_native(nat, ofs, digit){nat.data[ofs] = digit; return 0; + } + function square_nat(nat1, ofs1, len1, nat2, ofs2, len2){ + var carry = 0; + carry += add_nat(nat1, ofs1, len1, nat1, ofs1, len1, 0); + carry += mult_nat(nat1, ofs1, len1, nat2, ofs2, len2, nat2, ofs2, len2); + return carry; + } + function caml_setup_uncaught_exception_handler(){ + var process = globalThis.process; + if(process && process.on) + process.on + ("uncaughtException", + function(err, origin){ + caml_fatal_uncaught_exception(err); + process.exit(2); + }); + else if(globalThis.addEventListener) + globalThis.addEventListener + ("error", + function(event){ + if(event.error) caml_fatal_uncaught_exception(event.error); + }); + } + caml_setup_uncaught_exception_handler(); + globalThis.jsoo_runtime = + {bigstringaf_memchr: bigstringaf_memchr, + bigstringaf_memcmp_string: bigstringaf_memcmp_string, + bigstringaf_memcmp_bigstring: bigstringaf_memcmp_bigstring, + bigstringaf_blit_from_bytes: bigstringaf_blit_from_bytes, + bigstringaf_blit_to_bigstring: bigstringaf_blit_to_bigstring, + bigstringaf_blit_to_bytes: bigstringaf_blit_to_bytes, + caml_runtime_events_read_poll: caml_runtime_events_read_poll, + caml_runtime_events_free_cursor: caml_runtime_events_free_cursor, + caml_runtime_events_create_cursor: caml_runtime_events_create_cursor, + caml_ml_runtime_events_resume: caml_ml_runtime_events_resume, + caml_ml_runtime_events_pause: caml_ml_runtime_events_pause, + caml_ml_runtime_events_start: caml_ml_runtime_events_start, + caml_runtime_events_user_resolve: caml_runtime_events_user_resolve, + caml_runtime_events_user_write: caml_runtime_events_user_write, + caml_runtime_events_user_register: caml_runtime_events_user_register, + caml_custom_event_index: caml_custom_event_index, + caml_decompress_input: caml_decompress_input, + jsoo_effect_not_supported: jsoo_effect_not_supported, + caml_ml_condition_signal: caml_ml_condition_signal, + caml_ml_condition_broadcast: caml_ml_condition_broadcast, + caml_ml_condition_wait: caml_ml_condition_wait, + caml_ml_condition_new: caml_ml_condition_new, + caml_get_continuation_callstack: caml_get_continuation_callstack, + caml_continuation_use_and_update_handler_noexc: + caml_continuation_use_and_update_handler_noexc, + caml_continuation_use_noexc: caml_continuation_use_noexc, + caml_alloc_stack: caml_alloc_stack, + caml_ml_mutex_unlock: caml_ml_mutex_unlock, + caml_ml_mutex_try_lock: caml_ml_mutex_try_lock, + caml_ml_mutex_lock: caml_ml_mutex_lock, + caml_ml_mutex_new: caml_ml_mutex_new, + MlMutex: MlMutex, + caml_lxm_next: caml_lxm_next, + caml_ml_domain_cpu_relax: caml_ml_domain_cpu_relax, + caml_ml_domain_id: caml_ml_domain_id, + caml_domain_spawn: caml_domain_spawn, + caml_domain_id: caml_domain_id, + caml_recommended_domain_count: caml_recommended_domain_count, + caml_ml_domain_set_name: caml_ml_domain_set_name, + caml_ml_domain_unique_token: caml_ml_domain_unique_token, + caml_atomic_make_contended: caml_atomic_make_contended, + caml_atomic_exchange: caml_atomic_exchange, + caml_atomic_fetch_add: caml_atomic_fetch_add, + caml_atomic_cas: caml_atomic_cas, + caml_atomic_load: caml_atomic_load, + caml_domain_dls_get: caml_domain_dls_get, + caml_domain_dls_set: caml_domain_dls_set, + caml_domain_dls: caml_domain_dls, + caml_ephe_check_data: caml_ephe_check_data, + caml_ephe_unset_data: caml_ephe_unset_data, + caml_ephe_set_data: caml_ephe_set_data, + caml_ephe_get_data_copy: caml_ephe_get_data_copy, + caml_ephe_get_data: caml_ephe_get_data, + caml_ephe_blit_data: caml_ephe_blit_data, + caml_ephe_blit_key: caml_ephe_blit_key, + caml_ephe_check_key: caml_ephe_check_key, + caml_ephe_get_key_copy: caml_ephe_get_key_copy, + caml_ephe_get_key: caml_ephe_get_key, + caml_weak_set: caml_weak_set, + caml_weak_create: caml_weak_create, + caml_ephe_create: caml_ephe_create, + caml_ephe_unset_key: caml_ephe_unset_key, + caml_ephe_set_key: caml_ephe_set_key, + caml_ephe_data_offset: caml_ephe_data_offset, + caml_ephe_key_offset: caml_ephe_key_offset, + caml_unix_inet_addr_of_string: caml_unix_inet_addr_of_string, + caml_unix_findclose: caml_unix_findclose, + caml_unix_findnext: caml_unix_findnext, + caml_unix_findfirst: caml_unix_findfirst, + caml_unix_rewinddir: caml_unix_rewinddir, + caml_unix_closedir: caml_unix_closedir, + caml_unix_readdir: caml_unix_readdir, + caml_unix_opendir: caml_unix_opendir, + caml_unix_has_symlink: caml_unix_has_symlink, + caml_unix_getpwuid: caml_unix_getpwuid, + caml_unix_getuid: caml_unix_getuid, + caml_unix_unlink: caml_unix_unlink, + caml_unix_readlink: caml_unix_readlink, + caml_unix_symlink: caml_unix_symlink, + caml_unix_rmdir: caml_unix_rmdir, + caml_unix_mkdir: caml_unix_mkdir, + caml_unix_lstat_64: caml_unix_lstat_64, + caml_unix_lstat: caml_unix_lstat, + caml_unix_stat_64: caml_unix_stat_64, + caml_unix_stat: caml_unix_stat, + make_unix_err_args: make_unix_err_args, + caml_unix_isatty: caml_unix_isatty, + caml_unix_filedescr_of_fd: caml_unix_filedescr_of_fd, + caml_unix_cleanup: caml_unix_cleanup, + caml_unix_startup: caml_unix_startup, + caml_unix_mktime: caml_unix_mktime, + caml_unix_localtime: caml_unix_localtime, + caml_unix_gmtime: caml_unix_gmtime, + caml_unix_time: caml_unix_time, + caml_unix_gettimeofday: caml_unix_gettimeofday, + caml_str_initialize: caml_str_initialize, + re_replacement_text: re_replacement_text, + re_partial_match: re_partial_match, + re_string_match: re_string_match, + re_search_backward: re_search_backward, + re_search_forward: re_search_forward, + re_match: re_match, + caml_sys_is_regular_file: caml_sys_is_regular_file, + caml_spacetime_only_works_for_native_code: + caml_spacetime_only_works_for_native_code, + caml_register_channel_for_spacetime: caml_register_channel_for_spacetime, + caml_sys_const_naked_pointers_checked: + caml_sys_const_naked_pointers_checked, + caml_spacetime_enabled: caml_spacetime_enabled, + caml_ml_runtime_warnings_enabled: caml_ml_runtime_warnings_enabled, + caml_ml_enable_runtime_warnings: caml_ml_enable_runtime_warnings, + caml_runtime_warnings: caml_runtime_warnings, + caml_install_signal_handler: caml_install_signal_handler, + caml_runtime_parameters: caml_runtime_parameters, + caml_runtime_variant: caml_runtime_variant, + caml_sys_isatty: caml_sys_isatty, + caml_sys_get_config: caml_sys_get_config, + os_type: os_type, + caml_sys_const_backend_type: caml_sys_const_backend_type, + caml_sys_const_ostype_cygwin: caml_sys_const_ostype_cygwin, + caml_sys_const_ostype_win32: caml_sys_const_ostype_win32, + caml_sys_const_ostype_unix: caml_sys_const_ostype_unix, + caml_sys_const_max_wosize: caml_sys_const_max_wosize, + caml_sys_const_int_size: caml_sys_const_int_size, + caml_sys_const_word_size: caml_sys_const_word_size, + caml_sys_const_big_endian: caml_sys_const_big_endian, + caml_sys_random_seed: caml_sys_random_seed, + caml_sys_time_include_children: caml_sys_time_include_children, + caml_sys_time: caml_sys_time, + caml_sys_system_command: caml_sys_system_command, + caml_sys_executable_name: caml_sys_executable_name, + caml_sys_modify_argv: caml_sys_modify_argv, + caml_sys_argv: caml_sys_argv, + caml_sys_get_argv: caml_sys_get_argv, + caml_executable_name: caml_executable_name, + caml_argv: caml_argv, + caml_sys_unsafe_getenv: caml_sys_unsafe_getenv, + caml_sys_getenv: caml_sys_getenv, + jsoo_sys_getenv: jsoo_sys_getenv, + caml_set_static_env: caml_set_static_env, + caml_fatal_uncaught_exception: caml_fatal_uncaught_exception, + caml_format_exception: caml_format_exception, + caml_is_special_exception: caml_is_special_exception, + caml_sys_exit: caml_sys_exit, + caml_raise_sys_error: caml_raise_sys_error, + caml_maybe_print_stats: caml_maybe_print_stats, + caml_is_printable: caml_is_printable, + caml_get_global_data: caml_get_global_data, + caml_register_global: caml_register_global, + caml_build_symbols: caml_build_symbols, + caml_global_data: caml_global_data, + caml_named_value: caml_named_value, + caml_register_named_value: caml_register_named_value, + caml_named_values: caml_named_values, + caml_call_gen: caml_call_gen, + caml_set_parser_trace: caml_set_parser_trace, + caml_parse_engine: caml_parse_engine, + caml_parser_trace: caml_parser_trace, + caml_is_continuation_tag: caml_is_continuation_tag, + caml_lazy_read_result: caml_lazy_read_result, + caml_lazy_reset_to_lazy: caml_lazy_reset_to_lazy, + caml_lazy_update_to_forward: caml_lazy_update_to_forward, + caml_lazy_update_to_forcing: caml_lazy_update_to_forcing, + caml_obj_update_tag: caml_obj_update_tag, + caml_obj_add_offset: caml_obj_add_offset, + caml_obj_reachable_words: caml_obj_reachable_words, + caml_obj_set_raw_field: caml_obj_set_raw_field, + caml_obj_raw_field: caml_obj_raw_field, + caml_fresh_oo_id: caml_fresh_oo_id, + caml_set_oo_id: caml_set_oo_id, + caml_oo_last_id: caml_oo_last_id, + caml_get_public_method: caml_get_public_method, + caml_lazy_make_forward: caml_lazy_make_forward, + caml_obj_is_shared: caml_obj_is_shared, + caml_obj_compare_and_swap: caml_obj_compare_and_swap, + caml_obj_make_forward: caml_obj_make_forward, + caml_obj_truncate: caml_obj_truncate, + caml_obj_dup: caml_obj_dup, + caml_obj_with_tag: caml_obj_with_tag, + caml_obj_block: caml_obj_block, + caml_obj_set_tag: caml_obj_set_tag, + caml_obj_tag: caml_obj_tag, + caml_obj_is_block: caml_obj_is_block, + caml_alloc_dummy_infix: caml_alloc_dummy_infix, + caml_update_dummy: caml_update_dummy, + deserialize_nat: deserialize_nat, + serialize_nat: serialize_nat, + lxor_digit_nat: lxor_digit_nat, + lor_digit_nat: lor_digit_nat, + land_digit_nat: land_digit_nat, + compare_nat_real: compare_nat_real, + compare_nat: compare_nat, + compare_digits_nat: compare_digits_nat, + shift_right_nat: shift_right_nat, + div_nat: div_nat, + div_digit_nat: div_digit_nat, + div_helper: div_helper, + shift_left_nat: shift_left_nat, + square_nat: square_nat, + mult_nat: mult_nat, + mult_digit_nat: mult_digit_nat, + sub_nat: sub_nat, + decr_nat: decr_nat, + complement_nat: complement_nat, + add_nat: add_nat, + incr_nat: incr_nat, + is_digit_odd: is_digit_odd, + is_digit_zero: is_digit_zero, + is_digit_int: is_digit_int, + num_leading_zero_bits_in_digit: num_leading_zero_bits_in_digit, + num_digits_nat: num_digits_nat, + nth_digit_nat_native: nth_digit_nat_native, + set_digit_nat_native: set_digit_nat_native, + nth_digit_nat: nth_digit_nat, + set_digit_nat: set_digit_nat, + blit_nat: blit_nat, + set_to_zero_nat: set_to_zero_nat, + create_nat: create_nat, + nat_of_array: nat_of_array, + length_nat: length_nat, + caml_hash_nat: caml_hash_nat, + MlNat: MlNat, + initialize_nat: initialize_nat, + caml_array_of_bytes: caml_array_of_bytes, + caml_array_of_string: caml_array_of_string, + caml_js_to_string: caml_js_to_string, + caml_to_js_string: caml_to_js_string, + caml_js_from_string: caml_js_from_string, + caml_new_string: caml_new_string, + caml_js_to_byte_string: caml_js_to_byte_string, + caml_is_ml_string: caml_is_ml_string, + caml_ml_bytes_content: caml_ml_bytes_content, + caml_is_ml_bytes: caml_is_ml_bytes, + caml_bytes_of_jsbytes: caml_bytes_of_jsbytes, + caml_string_of_jsstring: caml_string_of_jsstring, + caml_jsstring_of_string: caml_jsstring_of_string, + caml_jsbytes_of_string: caml_jsbytes_of_string, + caml_string_of_jsbytes: caml_string_of_jsbytes, + caml_bytes_of_string: caml_bytes_of_string, + caml_string_of_bytes: caml_string_of_bytes, + caml_string_lessthan: caml_string_lessthan, + caml_string_lessequal: caml_string_lessequal, + caml_string_equal: caml_string_equal, + caml_string_compare: caml_string_compare, + caml_ml_string_length: caml_ml_string_length, + caml_string_unsafe_set: caml_string_unsafe_set, + caml_string_unsafe_get: caml_string_unsafe_get, + caml_string_concat: caml_string_concat, + caml_ml_bytes_length: caml_ml_bytes_length, + caml_blit_string: caml_blit_string, + caml_blit_bytes: caml_blit_bytes, + caml_fill_bytes: caml_fill_bytes, + caml_bytes_greaterthan: caml_bytes_greaterthan, + caml_string_greaterthan: caml_string_greaterthan, + caml_bytes_greaterequal: caml_bytes_greaterequal, + caml_string_greaterequal: caml_string_greaterequal, + caml_bytes_lessthan: caml_bytes_lessthan, + caml_bytes_lessequal: caml_bytes_lessequal, + caml_bytes_notequal: caml_bytes_notequal, + caml_string_notequal: caml_string_notequal, + caml_bytes_equal: caml_bytes_equal, + caml_bytes_compare: caml_bytes_compare, + caml_bytes_of_array: caml_bytes_of_array, + caml_string_of_array: caml_string_of_array, + caml_create_bytes: caml_create_bytes, + caml_create_string: caml_create_string, + caml_uint8_array_of_string: caml_uint8_array_of_string, + caml_uint8_array_of_bytes: caml_uint8_array_of_bytes, + caml_convert_bytes_to_array: caml_convert_bytes_to_array, + caml_convert_string_to_bytes: caml_convert_string_to_bytes, + MlBytes: MlBytes, + caml_bytes_of_utf16_jsstring: caml_bytes_of_utf16_jsstring, + caml_bytes_set: caml_bytes_set, + caml_string_set64: caml_string_set64, + caml_bytes_set64: caml_bytes_set64, + caml_string_set32: caml_string_set32, + caml_bytes_set32: caml_bytes_set32, + caml_string_set16: caml_string_set16, + caml_bytes_set16: caml_bytes_set16, + caml_string_set: caml_string_set, + caml_bytes_get: caml_bytes_get, + caml_bytes_get64: caml_bytes_get64, + caml_string_get64: caml_string_get64, + caml_bytes_get32: caml_bytes_get32, + caml_string_get32: caml_string_get32, + caml_bytes_get16: caml_bytes_get16, + caml_string_get16: caml_string_get16, + caml_string_get: caml_string_get, + caml_bytes_bound_error: caml_bytes_bound_error, + caml_string_bound_error: caml_string_bound_error, + caml_bytes_unsafe_set: caml_bytes_unsafe_set, + caml_bytes_unsafe_get: caml_bytes_unsafe_get, + jsoo_is_ascii: jsoo_is_ascii, + caml_utf16_of_utf8: caml_utf16_of_utf8, + caml_utf8_of_utf16: caml_utf8_of_utf16, + caml_subarray_to_jsbytes: caml_subarray_to_jsbytes, + caml_str_repeat: caml_str_repeat, + caml_md5_bytes: caml_md5_bytes, + caml_MD5Final: caml_MD5Final, + caml_MD5Update: caml_MD5Update, + caml_MD5Init: caml_MD5Init, + caml_MD5Transform: caml_MD5Transform, + caml_md5_string: caml_md5_string, + caml_md5_chan: caml_md5_chan, + caml_output_value_to_buffer: caml_output_value_to_buffer, + caml_output_value_to_bytes: caml_output_value_to_bytes, + caml_output_value_to_string: caml_output_value_to_string, + caml_output_val: caml_output_val, + MlObjectTable: MlObjectTable, + caml_marshal_data_size: caml_marshal_data_size, + caml_marshal_header_size: caml_marshal_header_size, + caml_input_value_from_reader: caml_input_value_from_reader, + caml_custom_ops: caml_custom_ops, + caml_nativeint_unmarshal: caml_nativeint_unmarshal, + caml_int32_unmarshal: caml_int32_unmarshal, + caml_int64_marshal: caml_int64_marshal, + caml_int64_unmarshal: caml_int64_unmarshal, + caml_input_value_from_bytes: caml_input_value_from_bytes, + caml_input_value_from_string: caml_input_value_from_string, + caml_float_of_bytes: caml_float_of_bytes, + BigStringReader: BigStringReader, + MlStringReader: MlStringReader, + UInt8ArrayReader: UInt8ArrayReader, + caml_marshal_constants: caml_marshal_constants, + caml_new_lex_engine: caml_new_lex_engine, + caml_lex_engine: caml_lex_engine, + caml_lex_array: caml_lex_array, + caml_js_error_of_exception: caml_js_error_of_exception, + caml_xmlhttprequest_create: caml_xmlhttprequest_create, + caml_js_get_console: caml_js_get_console, + caml_js_html_entities: caml_js_html_entities, + caml_js_html_escape: caml_js_html_escape, + caml_js_on_ie: caml_js_on_ie, + caml_js_object: caml_js_object, + caml_pure_js_expr: caml_pure_js_expr, + caml_js_expr: caml_js_expr, + caml_js_eval_string: caml_js_eval_string, + caml_js_strict_equals: caml_js_strict_equals, + caml_js_equals: caml_js_equals, + caml_js_function_arity: caml_js_function_arity, + caml_js_wrap_meth_callback_unsafe: caml_js_wrap_meth_callback_unsafe, + caml_js_wrap_meth_callback_strict: caml_js_wrap_meth_callback_strict, + caml_js_wrap_meth_callback_arguments: + caml_js_wrap_meth_callback_arguments, + caml_js_wrap_meth_callback: caml_js_wrap_meth_callback, + caml_js_wrap_callback_unsafe: caml_js_wrap_callback_unsafe, + caml_js_wrap_callback_strict: caml_js_wrap_callback_strict, + caml_js_wrap_callback_arguments: caml_js_wrap_callback_arguments, + caml_js_wrap_callback: caml_js_wrap_callback, + caml_ojs_new_arr: caml_ojs_new_arr, + caml_js_new: caml_js_new, + caml_js_meth_call: caml_js_meth_call, + caml_js_fun_call: caml_js_fun_call, + caml_js_call: caml_js_call, + caml_js_var: caml_js_var, + caml_list_to_js_array: caml_list_to_js_array, + caml_list_of_js_array: caml_list_of_js_array, + caml_js_to_array: caml_js_to_array, + caml_js_from_array: caml_js_from_array, + caml_js_to_int32: caml_js_to_int32, + caml_js_to_float: caml_js_to_float, + caml_js_from_float: caml_js_from_float, + caml_js_to_bool: caml_js_to_bool, + caml_js_from_bool: caml_js_from_bool, + caml_js_error_option_of_exception: caml_js_error_option_of_exception, + caml_exn_with_js_backtrace: caml_exn_with_js_backtrace, + caml_maybe_attach_backtrace: caml_maybe_attach_backtrace, + caml_wrap_exception: caml_wrap_exception, + caml_jsoo_flags_effects: caml_jsoo_flags_effects, + caml_jsoo_flags_use_js_string: caml_jsoo_flags_use_js_string, + caml_is_js: caml_is_js, + caml_callback: caml_callback, + caml_trampoline_return: caml_trampoline_return, + caml_trampoline: caml_trampoline, + caml_js_typeof: caml_js_typeof, + caml_js_instanceof: caml_js_instanceof, + caml_js_delete: caml_js_delete, + caml_js_get: caml_js_get, + caml_js_set: caml_js_set, + caml_js_pure_expr: caml_js_pure_expr, + caml_ml_set_buffered: caml_ml_set_buffered, + caml_ml_is_buffered: caml_ml_is_buffered, + caml_ml_output_int: caml_ml_output_int, + caml_ml_pos_out_64: caml_ml_pos_out_64, + caml_ml_pos_out: caml_ml_pos_out, + caml_pos_out: caml_pos_out, + caml_ml_seek_out_64: caml_ml_seek_out_64, + caml_ml_seek_out: caml_ml_seek_out, + caml_seek_out: caml_seek_out, + caml_output_value: caml_output_value, + caml_ml_output_char: caml_ml_output_char, + caml_ml_output: caml_ml_output, + caml_ml_output_bigarray: caml_ml_output_bigarray, + caml_ml_output_bytes: caml_ml_output_bytes, + caml_ml_output_ta: caml_ml_output_ta, + caml_ml_flush: caml_ml_flush, + caml_ml_input_scan_line: caml_ml_input_scan_line, + caml_ml_pos_in_64: caml_ml_pos_in_64, + caml_ml_pos_in: caml_ml_pos_in, + caml_pos_in: caml_pos_in, + caml_ml_seek_in_64: caml_ml_seek_in_64, + caml_ml_seek_in: caml_ml_seek_in, + caml_seek_in: caml_seek_in, + caml_ml_input_int: caml_ml_input_int, + caml_ml_input_char: caml_ml_input_char, + caml_input_value_to_outside_heap: caml_input_value_to_outside_heap, + caml_input_value: caml_input_value, + caml_ml_input_block: caml_ml_input_block, + caml_ml_input_bigarray: caml_ml_input_bigarray, + caml_ml_input: caml_ml_input, + caml_refill: caml_refill, + caml_ml_set_channel_refill: caml_ml_set_channel_refill, + caml_ml_set_channel_output: caml_ml_set_channel_output, + caml_ml_channel_size_64: caml_ml_channel_size_64, + caml_ml_channel_size: caml_ml_channel_size, + caml_ml_close_channel: caml_ml_close_channel, + caml_ml_set_binary_mode: caml_ml_set_binary_mode, + caml_channel_descriptor: caml_channel_descriptor, + caml_ml_open_descriptor_in: caml_ml_open_descriptor_in, + caml_ml_open_descriptor_out: caml_ml_open_descriptor_out, + caml_ml_out_channels_list: caml_ml_out_channels_list, + caml_ml_channel_get: caml_ml_channel_get, + caml_ml_channel_restore: caml_ml_channel_restore, + caml_ml_channel_redirect: caml_ml_channel_redirect, + caml_ml_channels: caml_ml_channels, + caml_ml_set_channel_name: caml_ml_set_channel_name, + caml_sys_open: caml_sys_open, + caml_sys_close: caml_sys_close, + caml_sys_fds: caml_sys_fds, + caml_int64_bswap: caml_int64_bswap, + caml_int32_bswap: caml_int32_bswap, + caml_bswap16: caml_bswap16, + caml_mod: caml_mod, + caml_div: caml_div, + caml_mul: caml_mul, + caml_int_of_string: caml_int_of_string, + caml_parse_digit: caml_parse_digit, + caml_parse_sign_and_base: caml_parse_sign_and_base, + caml_format_int: caml_format_int, + caml_int64_hash: caml_int64_hash, + caml_int64_to_bytes: caml_int64_to_bytes, + caml_int64_of_bytes: caml_int64_of_bytes, + caml_int64_hi32: caml_int64_hi32, + caml_int64_lo32: caml_int64_lo32, + caml_int64_create_lo_hi: caml_int64_create_lo_hi, + caml_int64_create_lo_mi_hi: caml_int64_create_lo_mi_hi, + caml_int64_of_string: caml_int64_of_string, + caml_int64_format: caml_int64_format, + caml_int64_of_float: caml_int64_of_float, + caml_int64_to_float: caml_int64_to_float, + caml_int64_to_int32: caml_int64_to_int32, + caml_int64_of_int32: caml_int64_of_int32, + caml_int64_mod: caml_int64_mod, + caml_int64_div: caml_int64_div, + caml_int64_shift_right: caml_int64_shift_right, + caml_int64_shift_right_unsigned: caml_int64_shift_right_unsigned, + caml_int64_shift_left: caml_int64_shift_left, + caml_int64_xor: caml_int64_xor, + caml_int64_or: caml_int64_or, + caml_int64_and: caml_int64_and, + caml_int64_is_negative: caml_int64_is_negative, + caml_int64_is_zero: caml_int64_is_zero, + caml_int64_mul: caml_int64_mul, + caml_int64_sub: caml_int64_sub, + caml_int64_add: caml_int64_add, + caml_int64_neg: caml_int64_neg, + caml_int64_compare: caml_int64_compare, + caml_int64_ult: caml_int64_ult, + MlInt64: MlInt64, + caml_int64_offset: caml_int64_offset, + caml_float_of_string: caml_float_of_string, + caml_format_float: caml_format_float, + caml_fma_float: caml_fma_float, + caml_erfc_float: caml_erfc_float, + caml_erf_float: caml_erf_float, + caml_cbrt_float: caml_cbrt_float, + caml_round_float: caml_round_float, + caml_atanh_float: caml_atanh_float, + caml_tanh_float: caml_tanh_float, + caml_asinh_float: caml_asinh_float, + caml_sinh_float: caml_sinh_float, + caml_acosh_float: caml_acosh_float, + caml_cosh_float: caml_cosh_float, + caml_log10_float: caml_log10_float, + caml_hypot_float: caml_hypot_float, + caml_log2_float: caml_log2_float, + caml_log1p_float: caml_log1p_float, + caml_exp2_float: caml_exp2_float, + caml_expm1_float: caml_expm1_float, + caml_signbit_float: caml_signbit_float, + caml_copysign_float: caml_copysign_float, + caml_float_compare: caml_float_compare, + caml_frexp_float: caml_frexp_float, + caml_ldexp_float: caml_ldexp_float, + caml_modf_float: caml_modf_float, + caml_classify_float: caml_classify_float, + caml_int32_float_of_bits: caml_int32_float_of_bits, + caml_trunc_float: caml_trunc_float, + caml_nextafter_float: caml_nextafter_float, + caml_int64_float_of_bits: caml_int64_float_of_bits, + caml_hexstring_of_float: caml_hexstring_of_float, + caml_int32_bits_of_float: caml_int32_bits_of_float, + caml_int64_bits_of_float: caml_int64_bits_of_float, + jsoo_floor_log2: jsoo_floor_log2, + caml_string_hash: caml_string_hash, + caml_hash: caml_hash, + caml_hash_mix_string: caml_hash_mix_string, + caml_hash_mix_bytes: caml_hash_mix_bytes, + caml_hash_mix_bytes_arr: caml_hash_mix_bytes_arr, + caml_hash_mix_jsbytes: caml_hash_mix_jsbytes, + caml_hash_mix_int64: caml_hash_mix_int64, + caml_hash_mix_float: caml_hash_mix_float, + caml_hash_mix_final: caml_hash_mix_final, + caml_hash_mix_int: caml_hash_mix_int, + caml_gr_close_subwindow: caml_gr_close_subwindow, + caml_gr_open_subwindow: caml_gr_open_subwindow, + caml_gr_window_id: caml_gr_window_id, + caml_gr_display_mode: caml_gr_display_mode, + caml_gr_remember_mode: caml_gr_remember_mode, + caml_gr_synchronize: caml_gr_synchronize, + caml_gr_wait_event: caml_gr_wait_event, + caml_gr_sigio_signal: caml_gr_sigio_signal, + caml_gr_sigio_handler: caml_gr_sigio_handler, + caml_gr_blit_image: caml_gr_blit_image, + caml_gr_create_image: caml_gr_create_image, + caml_gr_draw_image: caml_gr_draw_image, + caml_gr_dump_image: caml_gr_dump_image, + caml_gr_make_image: caml_gr_make_image, + caml_gr_text_size: caml_gr_text_size, + caml_gr_set_text_size: caml_gr_set_text_size, + caml_gr_set_font: caml_gr_set_font, + caml_gr_draw_string: caml_gr_draw_string, + caml_gr_draw_char: caml_gr_draw_char, + caml_gr_draw_str: caml_gr_draw_str, + caml_gr_fill_arc: caml_gr_fill_arc, + caml_gr_fill_poly: caml_gr_fill_poly, + caml_gr_fill_rect: caml_gr_fill_rect, + caml_gr_set_line_width: caml_gr_set_line_width, + caml_gr_draw_arc: caml_gr_draw_arc, + caml_gr_arc_aux: caml_gr_arc_aux, + caml_gr_draw_rect: caml_gr_draw_rect, + caml_gr_lineto: caml_gr_lineto, + caml_gr_current_y: caml_gr_current_y, + caml_gr_current_x: caml_gr_current_x, + caml_gr_moveto: caml_gr_moveto, + caml_gr_point_color: caml_gr_point_color, + caml_gr_plot: caml_gr_plot, + caml_gr_set_color: caml_gr_set_color, + caml_gr_size_y: caml_gr_size_y, + caml_gr_size_x: caml_gr_size_x, + caml_gr_clear_graph: caml_gr_clear_graph, + caml_gr_resize_window: caml_gr_resize_window, + caml_gr_set_window_title: caml_gr_set_window_title, + caml_gr_close_graph: caml_gr_close_graph, + caml_gr_doc_of_state: caml_gr_doc_of_state, + caml_gr_state_create: caml_gr_state_create, + caml_gr_state_init: caml_gr_state_init, + caml_gr_open_graph: caml_gr_open_graph, + caml_gr_state_set: caml_gr_state_set, + caml_gr_state_get: caml_gr_state_get, + caml_gr_state: caml_gr_state, + caml_get_major_credit: caml_get_major_credit, + caml_get_major_bucket: caml_get_major_bucket, + caml_get_minor_free: caml_get_minor_free, + caml_gc_minor_words: caml_gc_minor_words, + caml_gc_major_slice: caml_gc_major_slice, + caml_gc_huge_fallback_count: caml_gc_huge_fallback_count, + caml_eventlog_pause: caml_eventlog_pause, + caml_eventlog_resume: caml_eventlog_resume, + caml_memprof_discard: caml_memprof_discard, + caml_memprof_stop: caml_memprof_stop, + caml_memprof_start: caml_memprof_start, + caml_final_release: caml_final_release, + caml_final_register_called_without_value: + caml_final_register_called_without_value, + caml_final_register: caml_final_register, + caml_memprof_set: caml_memprof_set, + caml_gc_get: caml_gc_get, + caml_gc_set: caml_gc_set, + caml_gc_stat: caml_gc_stat, + caml_gc_quick_stat: caml_gc_quick_stat, + caml_gc_counters: caml_gc_counters, + caml_gc_compaction: caml_gc_compaction, + caml_gc_full_major: caml_gc_full_major, + caml_gc_major: caml_gc_major, + caml_gc_minor: caml_gc_minor, + caml_sys_open_for_node: caml_sys_open_for_node, + MlNodeFd: MlNodeFd, + MlNodeDevice: MlNodeDevice, + fs_node_supported: fs_node_supported, + MlFakeFd: MlFakeFd, + MlFakeFd_out: MlFakeFd_out, + MlFakeFile: MlFakeFile, + MlFakeDevice: MlFakeDevice, + caml_read_file_content: caml_read_file_content, + jsoo_create_file: jsoo_create_file, + caml_create_file: caml_create_file, + caml_fs_init: caml_fs_init, + jsoo_create_file_extern: jsoo_create_file_extern, + caml_ba_map_file_bytecode: caml_ba_map_file_bytecode, + caml_ba_map_file: caml_ba_map_file, + caml_sys_rmdir: caml_sys_rmdir, + caml_sys_mkdir: caml_sys_mkdir, + caml_sys_rename: caml_sys_rename, + caml_sys_is_directory: caml_sys_is_directory, + caml_sys_remove: caml_sys_remove, + caml_sys_read_directory: caml_sys_read_directory, + caml_sys_file_exists: caml_sys_file_exists, + caml_raise_not_a_dir: caml_raise_not_a_dir, + caml_raise_no_such_file: caml_raise_no_such_file, + caml_sys_chdir: caml_sys_chdir, + caml_sys_getcwd: caml_sys_getcwd, + caml_unmount: caml_unmount, + caml_mount_autoload: caml_mount_autoload, + resolve_fs_device: resolve_fs_device, + caml_list_mount_point: caml_list_mount_point, + jsoo_mount_point: jsoo_mount_point, + caml_make_path: caml_make_path, + path_is_absolute: path_is_absolute, + MlFile: MlFile, + caml_root: caml_root, + caml_get_root: caml_get_root, + caml_current_dir: caml_current_dir, + caml_trailing_slash: caml_trailing_slash, + caml_finish_formatting: caml_finish_formatting, + caml_parse_format: caml_parse_format, + caml_array_bound_error: caml_array_bound_error, + caml_raise_not_found: caml_raise_not_found, + caml_raise_zero_divide: caml_raise_zero_divide, + caml_raise_end_of_file: caml_raise_end_of_file, + caml_invalid_argument: caml_invalid_argument, + caml_failwith: caml_failwith, + caml_raise_with_string: caml_raise_with_string, + caml_raise_with_args: caml_raise_with_args, + caml_raise_with_arg: caml_raise_with_arg, + caml_raise_constant: caml_raise_constant, + caml_lessthan: caml_lessthan, + caml_lessequal: caml_lessequal, + caml_greaterthan: caml_greaterthan, + caml_greaterequal: caml_greaterequal, + caml_notequal: caml_notequal, + caml_equal: caml_equal, + caml_int_compare: caml_int_compare, + caml_compare: caml_compare, + caml_compare_val: caml_compare_val, + caml_compare_val_number_custom: caml_compare_val_number_custom, + caml_compare_val_get_custom: caml_compare_val_get_custom, + caml_compare_val_tag: caml_compare_val_tag, + caml_bigstring_blit_ba_to_bytes: caml_bigstring_blit_ba_to_bytes, + caml_bigstring_blit_bytes_to_ba: caml_bigstring_blit_bytes_to_ba, + caml_bigstring_blit_string_to_ba: caml_bigstring_blit_string_to_ba, + caml_bigstring_blit_ba_to_ba: caml_bigstring_blit_ba_to_ba, + caml_bigstring_memcmp: caml_bigstring_memcmp, + bigstring_of_typed_array: bigstring_of_typed_array, + bigstring_of_array_buffer: bigstring_of_array_buffer, + bigstring_to_typed_array: bigstring_to_typed_array, + bigstring_to_array_buffer: bigstring_to_array_buffer, + caml_hash_mix_bigstring: caml_hash_mix_bigstring, + caml_ba_from_typed_array: caml_ba_from_typed_array, + caml_ba_kind_of_typed_array: caml_ba_kind_of_typed_array, + caml_ba_to_typed_array: caml_ba_to_typed_array, + caml_ba_hash: caml_ba_hash, + caml_ba_create_from: caml_ba_create_from, + caml_ba_deserialize: caml_ba_deserialize, + caml_ba_serialize: caml_ba_serialize, + caml_ba_reshape: caml_ba_reshape, + caml_ba_slice: caml_ba_slice, + caml_ba_sub: caml_ba_sub, + caml_ba_blit: caml_ba_blit, + caml_ba_fill: caml_ba_fill, + caml_ba_set_3: caml_ba_set_3, + caml_ba_set_2: caml_ba_set_2, + caml_ba_set_1: caml_ba_set_1, + caml_ba_uint8_set64: caml_ba_uint8_set64, + caml_ba_uint8_set32: caml_ba_uint8_set32, + caml_ba_uint8_set16: caml_ba_uint8_set16, + caml_ba_set_generic: caml_ba_set_generic, + caml_ba_get_3: caml_ba_get_3, + caml_ba_get_2: caml_ba_get_2, + caml_ba_get_1: caml_ba_get_1, + caml_ba_uint8_get64: caml_ba_uint8_get64, + caml_ba_uint8_get32: caml_ba_uint8_get32, + caml_ba_uint8_get16: caml_ba_uint8_get16, + caml_ba_get_generic: caml_ba_get_generic, + caml_ba_dim_3: caml_ba_dim_3, + caml_ba_dim_2: caml_ba_dim_2, + caml_ba_dim_1: caml_ba_dim_1, + caml_ba_dim: caml_ba_dim, + caml_ba_num_dims: caml_ba_num_dims, + caml_ba_layout: caml_ba_layout, + caml_ba_kind: caml_ba_kind, + caml_ba_change_layout: caml_ba_change_layout, + caml_ba_create: caml_ba_create, + caml_ba_create_unsafe: caml_ba_create_unsafe, + caml_ba_compare: caml_ba_compare, + Ml_Bigarray_c_1_1: Ml_Bigarray_c_1_1, + Ml_Bigarray: Ml_Bigarray, + caml_ba_custom_name: caml_ba_custom_name, + caml_ba_create_buffer: caml_ba_create_buffer, + caml_ba_get_size_per_element: caml_ba_get_size_per_element, + caml_ba_get_size: caml_ba_get_size, + caml_ba_init: caml_ba_init, + caml_convert_raw_backtrace_slot: caml_convert_raw_backtrace_slot, + caml_get_current_callstack: caml_get_current_callstack, + caml_restore_raw_backtrace: caml_restore_raw_backtrace, + caml_raw_backtrace_slot: caml_raw_backtrace_slot, + caml_raw_backtrace_next_slot: caml_raw_backtrace_next_slot, + caml_raw_backtrace_length: caml_raw_backtrace_length, + caml_convert_raw_backtrace: caml_convert_raw_backtrace, + caml_record_backtrace: caml_record_backtrace, + caml_get_exception_raw_backtrace: caml_get_exception_raw_backtrace, + caml_get_exception_backtrace: caml_get_exception_backtrace, + caml_backtrace_status: caml_backtrace_status, + caml_ml_debug_info_status: caml_ml_debug_info_status, + caml_record_backtrace_flag: caml_record_backtrace_flag, + caml_floatarray_create: caml_floatarray_create, + caml_make_float_vect: caml_make_float_vect, + caml_make_vect: caml_make_vect, + caml_check_bound: caml_check_bound, + caml_array_fill: caml_array_fill, + caml_array_get: caml_array_get, + caml_array_set: caml_array_set, + caml_floatarray_blit: caml_floatarray_blit, + caml_array_blit: caml_array_blit, + caml_array_concat: caml_array_concat, + caml_array_append: caml_array_append, + caml_array_sub: caml_array_sub}; + var + cst_Assert_failure = "Assert_failure", + cst_Division_by_zero = "Division_by_zero", + cst_End_of_file = "End_of_file", + cst_Failure = "Failure", + cst_Invalid_argument = "Invalid_argument", + cst_Match_failure = "Match_failure", + cst_Not_found = "Not_found", + cst_Out_of_memory = "Out_of_memory", + cst_Stack_overflow = "Stack_overflow", + cst_Sys_blocked_io = "Sys_blocked_io", + cst_Sys_error = "Sys_error", + cst_Undefined_recursive_module = "Undefined_recursive_module"; + caml_fs_init(); + caml_register_global(0, [248, cst_Out_of_memory, -1], cst_Out_of_memory); + caml_register_global(1, [248, cst_Sys_error, -2], cst_Sys_error); + caml_register_global(2, [248, cst_Failure, -3], cst_Failure); + caml_register_global + (3, [248, cst_Invalid_argument, -4], cst_Invalid_argument); + caml_register_global(4, [248, cst_End_of_file, -5], cst_End_of_file); + caml_register_global + (5, [248, cst_Division_by_zero, -6], cst_Division_by_zero); + caml_register_global(6, [248, cst_Not_found, -7], cst_Not_found); + caml_register_global(7, [248, cst_Match_failure, -8], cst_Match_failure); + caml_register_global(8, [248, cst_Stack_overflow, -9], cst_Stack_overflow); + caml_register_global(9, [248, cst_Sys_blocked_io, -10], cst_Sys_blocked_io); + caml_register_global + (10, [248, cst_Assert_failure, -11], cst_Assert_failure); + caml_register_global + (11, + [248, cst_Undefined_recursive_module, -12], + cst_Undefined_recursive_module); + return; + } + (globalThis)); + + +(function(a){"use strict";var +au="UIML__UIGL_basics",cD="Stdlib__Obj",cC="UIML__UIK_Canopy",dp=163,cA=169,cB=129,at="Stdlib__Map",as=146,dn="UIML__UIGL_LexSeq",ar="Stdlib__Format",cz="Q",dm="Js_of_ocaml__EventSource",dl="Stdlib__Bytes",aq="End_of_file",bD=148,dk="Out_of_memory",ap="Angstrom__Buffering",cy="UIML__List_lemmasT",dj="Failure",di="Stdlib__Printf",bB="Stdlib",bC="UIML__PeanoNat",cx=136,ao="Dune__exe__Uiml_demo",an=177,cw="Stdlib__Callback",bA="Stdlib__Filename",cv="Stdlib__Hashtbl",am="UIML__UIML_extraction",dh=170,cu=147,al="Stdlib__Option",bz=176,dg="Stdlib__ListLabels",ct="CamlinternalAtomic",df="UIML__PropQuantifiers",by=132,cq="Js_of_ocaml__IntersectionObserver",cr="Stdlib__MoreLabels",cs=125,de="UIML__KS_termination_ImpR",bx="Js_of_ocaml",dd="UIML__Base",cp="Js_of_ocaml__Jstable",dc="Match_failure",co="Js_of_ocaml__File",cn=156,db=109,cl=154,cm=175,bw="Stdlib__Int64",ak="UIML__Specif",ai="UIML__GLS_der_dec",aj="UIML__KS_termination_KR",bv="Angstrom__Exported_state",ag="Js_of_ocaml__Dom_svg",ah="UIML__KS_calc",bu=139,da="Stdlib__Digest",af=161,bt="UIML__UIGL_nodupseq",ae="Sys_error",bs=107,c$="Stdlib__Nativeint",c_="Stdlib__Stack",ad="CamlinternalFormat",br="Stdlib__Genlex",ck="UIML__Formulas",ac="Stdlib__Pervasives",cj="Stdlib__Printexc",ab="Js_of_ocaml__WebSockets",ci="Js_of_ocaml__Form",c9="UIML__UIK_basics",bq="Undefined_recursive_module",aa="Js_of_ocaml__ResizeObserver",bn="CamlinternalFormatBasics",bo="Js_of_ocaml__WebGL",bp="UIML__KS_termination_ImpL",bm="Stdlib__Queue",$="Jsoo_runtime",ch="Division_by_zero",bl="CamlinternalMod",bk="Big_int_Z",bj="UIML__Datatypes",bi=114,cg=158,bh="Stdlib__Parsing",ce="Stdlib__Weak",cf=119,c8="UIML__KS_dec",_=110,bg=113,cd=101,Y="Stdlib__StdLabels",Z=128,c6="Js_of_ocaml__Typed_array",c7="UIML__KS_termination_prelims",be="Stdlib__Bigarray",bf="Stdlib__List",cc="Angstrom__",bd="UIML__List0",X=155,bc="Js_of_ocaml__MutationObserver",cb=100,c5="UIML__Nat",W="UIML__GLS_calcs",bb=111,ca="UIML__UIK_braga",ba="UIML__List",V=102,a$="Js_of_ocaml__Json",b$=171,c4="Stdlib__Atomic",b_="UIML__String",a_=135,a9="Exenum_internals__Exen",a8="Stdlib__Set",a7=123,b9="Js_of_ocaml__Import",c3="Exenum_internals__ExtArray",b8=150,b7="Exenum_internals__Shuffle",U="Stdlib__Seq",S="Dune__exe__Printer",T="UIML",Q="UIML__GLS_termination_measure",R="Z",a6=127,a5="Sys_blocked_io",a4="Stdlib__Uchar",P="CamlinternalOO",O="Stdlib__Stream",N="Js_of_ocaml__Firebug",b6=172,b5="UIML__Environments",L="Stdlib__Gc",M="UIML__Simp",c1="Stdlib__Random",c2="UIML__GenT",J=116,K="UIML__UIGL_Canopy",a3="Js_of_ocaml__PerformanceObserver",b4="Stdlib__Either",c0="Js_of_ocaml__Intl",I="UIML__CML_Syntax",cY="Stdlib__Array",cZ=137,a2="Assert_failure",G=159,H="Stdlib__Lazy",cW="Js_of_ocaml__Lib_version",cX="Jsoo_runtime__",b3="UIML__UIGL_braga",a0="Stdlib__BytesLabels",a1=131,F="UIML__List_lems",aX="Stdlib__Marshal",aY=152,aZ=134,cV="Js_of_ocaml__CSS",cU=122,E=160,b2="UIML__Numbers",aW="Js_of_ocaml__Url",b1="Not_found",cT="Jsoo_runtime__Runtime_version",D=121,cS="Stdlib__String",B="Exenum_internals__Convenience",C=168,aV=173,cR="Js_of_ocaml__Geolocation",aU=124,A="Invalid_argument",aT=141,aS=120,cQ="Js_of_ocaml__Dom_html",aR="Js_of_ocaml__Js",aQ="UIML__Compare_dec",z="UIML__Gen_tacs",cP=166,y="Std_exit",b0="UIML__GLS_dec",x="UIML__DecisionProcedure",w="Stdlib__StringLabels",bZ=133,aP="Exenum_internals",v=157,bY="Js_of_ocaml__Regexp",u=112,cO="Stdlib__Complex",t=140,aO=118,cN="Stdlib__Sys",bW="CamlinternalLazy",bX="Exenum",s="Stdlib__Scanf",q="Dune__exe__Modal_expressions_parser",r=174,bV=167,aN="Js_of_ocaml__Worker",aM="Stdlib__Char",cM=144,aL="Stdlib__Int32",cL="UIML__Order",cK="UIML__Remove_list_lems",cJ="Stdlib__Unit",aK=151,bU=126,aJ="Stack_overflow",bT="Stdlib__ArrayLabels",p=108,aI="Stdlib__Arg",bS="Js_of_ocaml__",aH="Js_of_ocaml__Dom_events",aF="Angstrom",aG=153,n="Angstrom__More",o="Stdlib__Bool",m="Js_of_ocaml__Dom",bR=165,bQ="Zarith_version",bP="Exenum_internals__Parts",bO="Dune__exe",l="Stdlib__Int",bN="Angstrom__Input",k="Stdlib__Oo",bM="Stdlib__Ephemeron",i=130,j=138,aE=145,cI="UIML__Ascii",cH=164,bL="Exenum_internals__Tester",h=106,cG=178,bK="Stdlib__Fun",g=117,aD="Stdlib__Lexing",bJ="UIML__Univ_gen_ext",bI="UIML__UIGL_irred_short",aC="UIML__UIK_irred_short",bH="Stdlib__Result",cF=149,f="Js_of_ocaml__XmlHttpRequest",aB=162,aA="Bigstringaf",bG="Stdlib__Buffer",az="Dune__exe__Stringconversion",e=103,ay=115,d=142,ax="Stdlib__Float",bF=105,aw=143,cE="Angstrom__Parser",av=104,bE="Js_of_ocaml__Sys_js",c=a.jsoo_runtime,b=c.caml_get_global_data();b.prim_count=722;b.symbols=[0,[0,bQ,af],[0,R,aB],[0,bq,11],[0,bJ,p],[0,am,b8],[0,aC,as],[0,ca,cF],[0,c9,bD],[0,cC,cu],[0,bt,cM],[0,bI,t],[0,b3,aE],[0,au,aw],[0,dn,d],[0,K,aT],[0,b_,bi],[0,ak,aU],[0,M,bu],[0,cK,bU],[0,df,j],[0,bC,Z],[0,cL,cZ],[0,b2,aO],[0,c5,bg],[0,F,cs],[0,cy,a7],[0,bd,g],[0,ba,J],[0,c7,bZ],[0,aj,cx],[0,de,aZ],[0,bp,a_],[0,c8,by],[0,ah,a1],[0,z,cU],[0,c2,D],[0,Q,i],[0,ai,cB],[0,b0,a6],[0,W,aS],[0,ck,ay],[0,b5,cf],[0,x,aK],[0,bj,bb],[0,aQ,u],[0,I,_],[0,dd,db],[0,cI,aY],[0,T,bs],[0,ae,10],[0,a5,9],[0,ce,56],[0,cJ,28],[0,a4,22],[0,cN,23],[0,w,70],[0,cS,27],[0,O,44],[0,Y,72],[0,c_,40],[0,a8,38],[0,U,16],[0,s,58],[0,bH,19],[0,c1,54],[0,bm,41],[0,di,47],[0,cj,50],[0,ac,15],[0,bh,37],[0,al,17],[0,k,61],[0,cD,30],[0,c$,35],[0,cr,71],[0,aX,29],[0,at,39],[0,dg,68],[0,bf,24],[0,aD,36],[0,H,43],[0,bw,34],[0,aL,33],[0,l,25],[0,cv,55],[0,br,63],[0,L,52],[0,bK,51],[0,ar,57],[0,ax,32],[0,bA,65],[0,bM,64],[0,b4,18],[0,da,53],[0,cO,66],[0,aM,21],[0,cw,59],[0,a0,69],[0,dl,26],[0,bG,45],[0,o,20],[0,be,73],[0,c4,49],[0,bT,67],[0,cY,31],[0,aI,48],[0,bB,14],[0,y,cG],[0,aJ,8],[0,cz,dp],[0,dk,7],[0,b1,6],[0,dc,5],[0,cT,75],[0,cX,74],[0,$,76],[0,f,85],[0,aN,86],[0,ab,87],[0,bo,88],[0,aW,90],[0,c6,81],[0,bE,92],[0,aa,93],[0,bY,89],[0,a3,94],[0,bc,95],[0,cW,91],[0,cp,96],[0,a$,97],[0,aR,79],[0,c0,bF],[0,cq,av],[0,b9,78],[0,cR,e],[0,ci,84],[0,N,V],[0,co,82],[0,dm,cd],[0,ag,cb],[0,cQ,83],[0,aH,99],[0,m,80],[0,cV,98],[0,bS,77],[0,bx,h],[0,A,4],[0,dj,3],[0,bL,b$],[0,b7,C],[0,bP,cA],[0,c3,bV],[0,a9,dh],[0,B,cP],[0,aP,bR],[0,bX,b6],[0,aq,2],[0,ao,an],[0,az,r],[0,S,bz],[0,q,cm],[0,bO,aV],[0,ch,1],[0,P,60],[0,bl,62],[0,bW,42],[0,bn,12],[0,ad,46],[0,ct,13],[0,aA,aG],[0,bk,cH],[0,a2,0],[0,cE,cg],[0,n,X],[0,bN,v],[0,bv,cn],[0,ap,G],[0,cc,cl],[0,aF,E]];var +dq=[2,S],dr=[2,ao],ds=[2,dm],dt=[2,c0],du=[2,a$],dv=[2,a0],dw=[2,Y],dx=[2,ce],dy=[2,ae],dz=[2,cI],dA=[2,aQ],dB=[2,x],dC=[2,Q],dD=[2,bp],dE=[2,aj],dF=[2,cL],dG=[2,df],dH=[2,M],dI=[0,0,[2,b3],aE,0,1],dJ=[2,au],dK=[2,ca],dL=[2,bQ],dM=[0,0,[2,R],aB,0,1];b.sections=[0,[0,179,[0,[0,[0,[0,[0,[0,[0,0,[2,aF],E,0,1],[2,cc],cl,[0,0,[2,ap],G,0,1],2],[2,bv],cn,[0,[0,0,[2,bN],v,0,1],[2,n],X,[0,0,[2,cE],cg,0,1],2],3],[2,a2],0,[0,[0,[0,0,[2,bk],cH,0,1],[2,aA],aG,0,2],[2,ct],13,[0,0,[2,ad],46,0,1],3],4],[2,bn],12,[0,[0,0,[2,bW],42,[0,[0,0,[2,bl],62,0,1],[2,P],60,0,2],3],[2,ch],1,[0,[0,[0,[0,0,[2,bO],aV,0,1],[2,q],cm,[0,[0,0,dq,bz,0,1],[2,az],r,[0,0,dr,an,0,1],2],3],[2,aq],2,[0,0,[2,bX],b6,0,1],4],[2,aP],bR,[0,[0,0,[2,B],cP,[0,0,[2,a9],dh,0,1],2],[2,c3],bV,[0,[0,0,[2,bP],cA,0,1],[2,b7],C,[0,0,[2,bL],b$,0,1],2],3],5],6],7],[2,dj],3,[0,[0,[0,[0,[0,0,[2,A],4,[0,0,[2,bx],h,0,1],2],[2,bS],77,[0,0,[2,cV],98,0,1],3],[2,m],80,[0,[0,[0,0,[2,aH],99,0,1],[2,cQ],83,[0,0,[2,ag],cb,[0,0,ds,cd,0,1],2],3],[2,co],82,[0,[0,0,[2,N],V,0,1],[2,ci],84,[0,0,[2,cR],e,0,1],2],4],5],[2,b9],78,[0,[0,[0,[0,0,[2,cq],av,[0,0,dt,bF,0,1],2],[2,aR],79,[0,[0,0,du,97,0,1],[2,cp],96,0,2],3],[2,cW],91,[0,[0,0,[2,bc],95,0,1],[2,a3],94,0,2],4],[2,bY],89,[0,[0,0,[2,aa],93,0,1],[2,bE],92,0,2],5],6],[2,c6],81,[0,[0,[0,[0,[0,0,[2,aW],90,0,1],[2,bo],88,0,2],[2,ab],87,0,3],[2,aN],86,[0,0,[2,f],85,0,1],4],[2,$],76,[0,[0,0,[2,cX],74,[0,0,[2,cT],75,0,1],2],[2,dc],5,[0,[0,0,[2,b1],6,0,1],[2,dk],7,[0,[0,0,[2,cz],dp,0,1],[2,aJ],8,[0,0,[2,y],cG,0,1],2],3],4],5],7],8],[2,bB],14,[0,[0,[0,[0,[0,[0,0,[2,aI],48,0,1],[2,cY],31,[0,[0,0,[2,bT],67,0,1],[2,c4],49,[0,0,[2,be],73,0,1],2],3],[2,o],20,[0,[0,[0,0,[2,bG],45,0,1],[2,dl],26,[0,[0,0,dv,69,0,1],[2,cw],59,0,2],3],[2,aM],21,[0,[0,0,[2,cO],66,0,1],[2,da],53,0,2],4],5],[2,b4],18,[0,[0,[0,0,[2,bM],64,[0,0,[2,bA],65,0,1],2],[2,ax],32,[0,0,[2,ar],57,0,1],3],[2,bK],51,[0,[0,0,[2,L],52,[0,0,[2,br],63,0,1],2],[2,cv],55,[0,0,[2,l],25,0,1],3],4],6],[2,aL],33,[0,[0,[0,0,[2,bw],34,[0,[0,0,[2,H],43,0,1],[2,aD],36,0,2],3],[2,bf],24,[0,[0,0,[2,dg],68,0,1],[2,at],39,0,2],4],[2,aX],29,[0,[0,[0,[0,0,[2,cr],71,0,1],[2,c$],35,0,2],[2,cD],30,[0,0,[2,k],61,0,1],3],[2,al],17,[0,0,[2,bh],37,0,1],4],5],7],[2,ac],15,[0,[0,[0,[0,[0,[0,0,[2,cj],50,0,1],[2,di],47,0,2],[2,bm],41,[0,[0,0,[2,c1],54,0,1],[2,bH],19,[0,0,[2,s],58,0,1],2],3],[2,U],16,[0,[0,0,[2,a8],38,0,1],[2,c_],40,[0,[0,[0,0,dw,72,0,1],[2,O],44,0,2],[2,cS],27,[0,0,[2,w],70,0,1],3],4],5],[2,cN],23,[0,[0,[0,0,[2,a4],22,[0,0,[2,cJ],28,[0,0,dx,56,0,1],2],3],[2,a5],9,[0,[0,[0,0,dy,10,0,1],[2,T],bs,[0,0,dz,aY,0,1],2],[2,dd],db,[0,0,[2,I],_,[0,0,dA,u,0,1],2],3],4],[2,bj],bb,[0,[0,[0,[0,0,dB,aK,0,1],[2,b5],cf,0,2],[2,ck],ay,0,3],[2,W],aS,[0,0,[2,b0],a6,[0,0,[2,ai],cB,[0,0,dC,i,0,1],2],3],4],5],6],[2,c2],D,[0,[0,[0,[0,0,[2,z],cU,0,1],[2,ah],a1,[0,[0,0,[2,c8],by,[0,0,dD,a_,0,1],2],[2,de],aZ,[0,[0,0,dE,cx,0,1],[2,c7],bZ,0,2],3],4],[2,ba],J,[0,0,[2,bd],g,[0,0,[2,cy],a7,[0,0,[2,F],cs,0,1],2],3],5],[2,c5],bg,[0,[0,[0,[0,0,[2,b2],aO,[0,0,dF,cZ,0,1],2],[2,bC],Z,[0,[0,0,dG,j,0,1],[2,cK],bU,[0,0,dH,bu,0,1],2],3],[2,ak],aU,[0,[0,0,[2,b_],bi,0,1],[2,K],aT,[0,0,[2,dn],d,[0,0,dJ,aw,dI,2],3],4],5],[2,bI],t,[0,[0,[0,0,[2,bt],cM,0,1],[2,cC],cu,[0,0,[2,c9],bD,[0,0,dK,cF,0,1],2],3],[2,aC],as,[0,[0,0,[2,am],b8,0,1],[2,bJ],p,[0,0,[2,bq],11,[0,dM,dL,af,0,2],3],4],5],6],7],8],9],10]],0,c.caml_list_of_js_array(["BigStringReader","MlBytes","MlFakeDevice","MlFakeFd","MlFakeFd_out","MlFakeFile","MlFile","MlInt64","MlMutex","MlNat","MlNodeDevice","MlNodeFd","MlObjectTable","MlStringReader","Ml_Bigarray","Ml_Bigarray_c_1_1","UInt8ArrayReader","add_nat","bigstring_of_array_buffer","bigstring_of_typed_array","bigstring_to_array_buffer","bigstring_to_typed_array","bigstringaf_blit_from_bytes","bigstringaf_blit_to_bigstring","bigstringaf_blit_to_bytes","bigstringaf_memchr","bigstringaf_memcmp_bigstring","bigstringaf_memcmp_string","blit_nat","caml_MD5Final","caml_MD5Init","caml_MD5Transform","caml_MD5Update","caml_acosh_float","caml_alloc_dummy_infix","caml_alloc_stack","caml_argv","caml_array_append","caml_array_blit","caml_array_bound_error","caml_array_concat","caml_array_fill","caml_array_get","caml_array_of_bytes","caml_array_of_string","caml_array_set","caml_array_sub","caml_asinh_float","caml_atanh_float","caml_atomic_cas","caml_atomic_exchange","caml_atomic_fetch_add","caml_atomic_load","caml_atomic_make_contended","caml_ba_blit","caml_ba_change_layout","caml_ba_compare","caml_ba_create","caml_ba_create_buffer","caml_ba_create_from","caml_ba_create_unsafe","caml_ba_custom_name","caml_ba_deserialize","caml_ba_dim","caml_ba_dim_1","caml_ba_dim_2","caml_ba_dim_3","caml_ba_fill","caml_ba_from_typed_array","caml_ba_get_1","caml_ba_get_2","caml_ba_get_3","caml_ba_get_generic","caml_ba_get_size","caml_ba_get_size_per_element","caml_ba_hash","caml_ba_init","caml_ba_kind","caml_ba_kind_of_typed_array","caml_ba_layout","caml_ba_map_file","caml_ba_map_file_bytecode","caml_ba_num_dims","caml_ba_reshape","caml_ba_serialize","caml_ba_set_1","caml_ba_set_2","caml_ba_set_3","caml_ba_set_generic","caml_ba_slice","caml_ba_sub","caml_ba_to_typed_array","caml_ba_uint8_get16","caml_ba_uint8_get32","caml_ba_uint8_get64","caml_ba_uint8_set16","caml_ba_uint8_set32","caml_ba_uint8_set64","caml_backtrace_status","caml_bigstring_blit_ba_to_ba","caml_bigstring_blit_ba_to_bytes","caml_bigstring_blit_bytes_to_ba","caml_bigstring_blit_string_to_ba","caml_bigstring_memcmp","caml_blit_bytes","caml_blit_string","caml_bswap16","caml_build_symbols","caml_bytes_bound_error","caml_bytes_compare","caml_bytes_equal","caml_bytes_get","caml_bytes_get16","caml_bytes_get32","caml_bytes_get64","caml_bytes_greaterequal","caml_bytes_greaterthan","caml_bytes_lessequal","caml_bytes_lessthan","caml_bytes_notequal","caml_bytes_of_array","caml_bytes_of_jsbytes","caml_bytes_of_string","caml_bytes_of_utf16_jsstring","caml_bytes_set","caml_bytes_set16","caml_bytes_set32","caml_bytes_set64","caml_bytes_unsafe_get","caml_bytes_unsafe_set","caml_call_gen","caml_callback","caml_cbrt_float","caml_channel_descriptor","caml_check_bound","caml_classify_float","caml_compare","caml_compare_val","caml_compare_val_get_custom","caml_compare_val_number_custom","caml_compare_val_tag","caml_continuation_use_and_update_handler_noexc","caml_continuation_use_noexc","caml_convert_bytes_to_array","caml_convert_raw_backtrace","caml_convert_raw_backtrace_slot","caml_convert_string_to_bytes","caml_copysign_float","caml_cosh_float","caml_create_bytes","caml_create_file","caml_create_string","caml_current_dir","caml_custom_event_index","caml_custom_ops","caml_decompress_input","caml_div","caml_domain_dls","caml_domain_dls_get","caml_domain_dls_set","caml_domain_id","caml_domain_spawn","caml_ephe_blit_data","caml_ephe_blit_key","caml_ephe_check_data","caml_ephe_check_key","caml_ephe_create","caml_ephe_data_offset","caml_ephe_get_data","caml_ephe_get_data_copy","caml_ephe_get_key","caml_ephe_get_key_copy","caml_ephe_key_offset","caml_ephe_set_data","caml_ephe_set_key","caml_ephe_unset_data","caml_ephe_unset_key","caml_equal","caml_erf_float","caml_erfc_float","caml_eventlog_pause","caml_eventlog_resume","caml_executable_name","caml_exn_with_js_backtrace","caml_exp2_float","caml_expm1_float","caml_failwith","caml_fatal_uncaught_exception","caml_fill_bytes","caml_final_register","caml_final_register_called_without_value","caml_final_release","caml_finish_formatting","caml_float_compare","caml_float_of_bytes","caml_float_of_string","caml_floatarray_blit","caml_floatarray_create","caml_fma_float","caml_format_exception","caml_format_float","caml_format_int","caml_fresh_oo_id","caml_frexp_float","caml_fs_init","caml_gc_compaction","caml_gc_counters","caml_gc_full_major","caml_gc_get","caml_gc_huge_fallback_count","caml_gc_major","caml_gc_major_slice","caml_gc_minor","caml_gc_minor_words","caml_gc_quick_stat","caml_gc_set","caml_gc_stat","caml_get_continuation_callstack","caml_get_current_callstack","caml_get_exception_backtrace","caml_get_exception_raw_backtrace","caml_get_global_data","caml_get_major_bucket","caml_get_major_credit","caml_get_minor_free","caml_get_public_method","caml_get_root","caml_global_data","caml_gr_arc_aux","caml_gr_blit_image","caml_gr_clear_graph","caml_gr_close_graph","caml_gr_close_subwindow","caml_gr_create_image","caml_gr_current_x","caml_gr_current_y","caml_gr_display_mode","caml_gr_doc_of_state","caml_gr_draw_arc","caml_gr_draw_char","caml_gr_draw_image","caml_gr_draw_rect","caml_gr_draw_str","caml_gr_draw_string","caml_gr_dump_image","caml_gr_fill_arc","caml_gr_fill_poly","caml_gr_fill_rect","caml_gr_lineto","caml_gr_make_image","caml_gr_moveto","caml_gr_open_graph","caml_gr_open_subwindow","caml_gr_plot","caml_gr_point_color","caml_gr_remember_mode","caml_gr_resize_window","caml_gr_set_color","caml_gr_set_font","caml_gr_set_line_width","caml_gr_set_text_size","caml_gr_set_window_title","caml_gr_sigio_handler","caml_gr_sigio_signal","caml_gr_size_x","caml_gr_size_y","caml_gr_state","caml_gr_state_create","caml_gr_state_get","caml_gr_state_init","caml_gr_state_set","caml_gr_synchronize","caml_gr_text_size","caml_gr_wait_event","caml_gr_window_id","caml_greaterequal","caml_greaterthan","caml_hash","caml_hash_mix_bigstring","caml_hash_mix_bytes","caml_hash_mix_bytes_arr","caml_hash_mix_final","caml_hash_mix_float","caml_hash_mix_int","caml_hash_mix_int64","caml_hash_mix_jsbytes","caml_hash_mix_string","caml_hash_nat","caml_hexstring_of_float","caml_hypot_float","caml_input_value","caml_input_value_from_bytes","caml_input_value_from_reader","caml_input_value_from_string","caml_input_value_to_outside_heap","caml_install_signal_handler","caml_int32_bits_of_float","caml_int32_bswap","caml_int32_float_of_bits","caml_int32_unmarshal","caml_int64_add","caml_int64_and","caml_int64_bits_of_float","caml_int64_bswap","caml_int64_compare","caml_int64_create_lo_hi","caml_int64_create_lo_mi_hi","caml_int64_div","caml_int64_float_of_bits","caml_int64_format","caml_int64_hash","caml_int64_hi32","caml_int64_is_negative","caml_int64_is_zero","caml_int64_lo32","caml_int64_marshal","caml_int64_mod","caml_int64_mul","caml_int64_neg","caml_int64_of_bytes","caml_int64_of_float","caml_int64_of_int32","caml_int64_of_string","caml_int64_offset","caml_int64_or","caml_int64_shift_left","caml_int64_shift_right","caml_int64_shift_right_unsigned","caml_int64_sub","caml_int64_to_bytes","caml_int64_to_float","caml_int64_to_int32","caml_int64_ult","caml_int64_unmarshal","caml_int64_xor","caml_int_compare","caml_int_of_string","caml_invalid_argument","caml_is_continuation_tag","caml_is_js","caml_is_ml_bytes","caml_is_ml_string","caml_is_printable","caml_is_special_exception","caml_js_call","caml_js_delete","caml_js_equals","caml_js_error_of_exception","caml_js_error_option_of_exception","caml_js_eval_string","caml_js_expr","caml_js_from_array","caml_js_from_bool","caml_js_from_float","caml_js_from_string","caml_js_fun_call","caml_js_function_arity","caml_js_get","caml_js_get_console","caml_js_html_entities","caml_js_html_escape","caml_js_instanceof","caml_js_meth_call","caml_js_new","caml_js_object","caml_js_on_ie","caml_js_pure_expr","caml_js_set","caml_js_strict_equals","caml_js_to_array","caml_js_to_bool","caml_js_to_byte_string","caml_js_to_float","caml_js_to_int32","caml_js_to_string","caml_js_typeof","caml_js_var","caml_js_wrap_callback","caml_js_wrap_callback_arguments","caml_js_wrap_callback_strict","caml_js_wrap_callback_unsafe","caml_js_wrap_meth_callback","caml_js_wrap_meth_callback_arguments","caml_js_wrap_meth_callback_strict","caml_js_wrap_meth_callback_unsafe","caml_jsbytes_of_string","caml_jsoo_flags_effects","caml_jsoo_flags_use_js_string","caml_jsstring_of_string","caml_lazy_make_forward","caml_lazy_read_result","caml_lazy_reset_to_lazy","caml_lazy_update_to_forcing","caml_lazy_update_to_forward","caml_ldexp_float","caml_lessequal","caml_lessthan","caml_lex_array","caml_lex_engine","caml_list_mount_point","caml_list_of_js_array","caml_list_to_js_array","caml_log10_float","caml_log1p_float","caml_log2_float","caml_lxm_next","caml_make_float_vect","caml_make_path","caml_make_vect","caml_marshal_constants","caml_marshal_data_size","caml_marshal_header_size","caml_maybe_attach_backtrace","caml_maybe_print_stats","caml_md5_bytes","caml_md5_chan","caml_md5_string","caml_memprof_discard","caml_memprof_set","caml_memprof_start","caml_memprof_stop","caml_ml_bytes_content","caml_ml_bytes_length","caml_ml_channel_get","caml_ml_channel_redirect","caml_ml_channel_restore","caml_ml_channel_size","caml_ml_channel_size_64","caml_ml_channels","caml_ml_close_channel","caml_ml_condition_broadcast","caml_ml_condition_new","caml_ml_condition_signal","caml_ml_condition_wait","caml_ml_debug_info_status","caml_ml_domain_cpu_relax","caml_ml_domain_id","caml_ml_domain_set_name","caml_ml_domain_unique_token","caml_ml_enable_runtime_warnings","caml_ml_flush","caml_ml_input","caml_ml_input_bigarray","caml_ml_input_block","caml_ml_input_char","caml_ml_input_int","caml_ml_input_scan_line","caml_ml_is_buffered","caml_ml_mutex_lock","caml_ml_mutex_new","caml_ml_mutex_try_lock","caml_ml_mutex_unlock","caml_ml_open_descriptor_in","caml_ml_open_descriptor_out","caml_ml_out_channels_list","caml_ml_output","caml_ml_output_bigarray","caml_ml_output_bytes","caml_ml_output_char","caml_ml_output_int","caml_ml_output_ta","caml_ml_pos_in","caml_ml_pos_in_64","caml_ml_pos_out","caml_ml_pos_out_64","caml_ml_runtime_events_pause","caml_ml_runtime_events_resume","caml_ml_runtime_events_start","caml_ml_runtime_warnings_enabled","caml_ml_seek_in","caml_ml_seek_in_64","caml_ml_seek_out","caml_ml_seek_out_64","caml_ml_set_binary_mode","caml_ml_set_buffered","caml_ml_set_channel_name","caml_ml_set_channel_output","caml_ml_set_channel_refill","caml_ml_string_length","caml_mod","caml_modf_float","caml_mount_autoload","caml_mul","caml_named_value","caml_named_values","caml_nativeint_unmarshal","caml_new_lex_engine","caml_new_string","caml_nextafter_float","caml_notequal","caml_obj_add_offset","caml_obj_block","caml_obj_compare_and_swap","caml_obj_dup","caml_obj_is_block","caml_obj_is_shared","caml_obj_make_forward","caml_obj_raw_field","caml_obj_reachable_words","caml_obj_set_raw_field","caml_obj_set_tag","caml_obj_tag","caml_obj_truncate","caml_obj_update_tag","caml_obj_with_tag","caml_ojs_new_arr","caml_oo_last_id","caml_output_val","caml_output_value","caml_output_value_to_buffer","caml_output_value_to_bytes","caml_output_value_to_string","caml_parse_digit","caml_parse_engine","caml_parse_format","caml_parse_sign_and_base","caml_parser_trace","caml_pos_in","caml_pos_out","caml_pure_js_expr","caml_raise_constant","caml_raise_end_of_file","caml_raise_no_such_file","caml_raise_not_a_dir","caml_raise_not_found","caml_raise_sys_error","caml_raise_with_arg","caml_raise_with_args","caml_raise_with_string","caml_raise_zero_divide","caml_raw_backtrace_length","caml_raw_backtrace_next_slot","caml_raw_backtrace_slot","caml_read_file_content","caml_recommended_domain_count","caml_record_backtrace","caml_record_backtrace_flag","caml_refill","caml_register_channel_for_spacetime","caml_register_global","caml_register_named_value","caml_restore_raw_backtrace","caml_root","caml_round_float","caml_runtime_events_create_cursor","caml_runtime_events_free_cursor","caml_runtime_events_read_poll","caml_runtime_events_user_register","caml_runtime_events_user_resolve","caml_runtime_events_user_write","caml_runtime_parameters","caml_runtime_variant","caml_runtime_warnings","caml_seek_in","caml_seek_out","caml_set_oo_id","caml_set_parser_trace","caml_set_static_env","caml_signbit_float","caml_sinh_float","caml_spacetime_enabled","caml_spacetime_only_works_for_native_code","caml_str_initialize","caml_str_repeat","caml_string_bound_error","caml_string_compare","caml_string_concat","caml_string_equal","caml_string_get","caml_string_get16","caml_string_get32","caml_string_get64","caml_string_greaterequal","caml_string_greaterthan","caml_string_hash","caml_string_lessequal","caml_string_lessthan","caml_string_notequal","caml_string_of_array","caml_string_of_bytes","caml_string_of_jsbytes","caml_string_of_jsstring","caml_string_set","caml_string_set16","caml_string_set32","caml_string_set64","caml_string_unsafe_get","caml_string_unsafe_set","caml_subarray_to_jsbytes","caml_sys_argv","caml_sys_chdir","caml_sys_close","caml_sys_const_backend_type","caml_sys_const_big_endian","caml_sys_const_int_size","caml_sys_const_max_wosize","caml_sys_const_naked_pointers_checked","caml_sys_const_ostype_cygwin","caml_sys_const_ostype_unix","caml_sys_const_ostype_win32","caml_sys_const_word_size","caml_sys_executable_name","caml_sys_exit","caml_sys_fds","caml_sys_file_exists","caml_sys_get_argv","caml_sys_get_config","caml_sys_getcwd","caml_sys_getenv","caml_sys_is_directory","caml_sys_is_regular_file","caml_sys_isatty","caml_sys_mkdir","caml_sys_modify_argv","caml_sys_open","caml_sys_open_for_node","caml_sys_random_seed","caml_sys_read_directory","caml_sys_remove","caml_sys_rename","caml_sys_rmdir","caml_sys_system_command","caml_sys_time","caml_sys_time_include_children","caml_sys_unsafe_getenv","caml_tanh_float","caml_to_js_string","caml_trailing_slash","caml_trampoline","caml_trampoline_return","caml_trunc_float","caml_uint8_array_of_bytes","caml_uint8_array_of_string","caml_unix_cleanup","caml_unix_closedir","caml_unix_filedescr_of_fd","caml_unix_findclose","caml_unix_findfirst","caml_unix_findnext","caml_unix_getpwuid","caml_unix_gettimeofday","caml_unix_getuid","caml_unix_gmtime","caml_unix_has_symlink","caml_unix_inet_addr_of_string","caml_unix_isatty","caml_unix_localtime","caml_unix_lstat","caml_unix_lstat_64","caml_unix_mkdir","caml_unix_mktime","caml_unix_opendir","caml_unix_readdir","caml_unix_readlink","caml_unix_rewinddir","caml_unix_rmdir","caml_unix_startup","caml_unix_stat","caml_unix_stat_64","caml_unix_symlink","caml_unix_time","caml_unix_unlink","caml_unmount","caml_update_dummy","caml_utf16_of_utf8","caml_utf8_of_utf16","caml_weak_create","caml_weak_set","caml_wrap_exception","caml_xmlhttprequest_create","compare_digits_nat","compare_nat","compare_nat_real","complement_nat","create_nat","decr_nat","deserialize_nat","div_digit_nat","div_helper","div_nat","fs_node_supported","incr_nat","initialize_nat","is_digit_int","is_digit_odd","is_digit_zero","jsoo_create_file","jsoo_create_file_extern","jsoo_effect_not_supported","jsoo_floor_log2","jsoo_is_ascii","jsoo_mount_point","jsoo_sys_getenv","land_digit_nat","length_nat","lor_digit_nat","lxor_digit_nat","make_unix_err_args","mult_digit_nat","mult_nat","nat_of_array","nth_digit_nat","nth_digit_nat_native","num_digits_nat","num_leading_zero_bits_in_digit","os_type","path_is_absolute","re_match","re_partial_match","re_replacement_text","re_search_backward","re_search_forward","re_string_match","resolve_fs_device","serialize_nat","set_digit_nat","set_digit_nat_native","set_to_zero_nat","shift_left_nat","shift_right_nat","square_nat","sub_nat"]),0];return}(globalThis)); +//# 1 "../.js/default/stdlib/stdlib.cma.js" +// Generated by js_of_ocaml +//# 3 "../.js/default/stdlib/stdlib.cma.js" + +//# 5 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function erase_rel(param){ + if(typeof param === "number") return 0; + switch(param[0]){ + case 0: + var rest = param[1]; return [0, erase_rel(rest)]; + case 1: + var rest$0 = param[1]; return [1, erase_rel(rest$0)]; + case 2: + var rest$1 = param[1]; return [2, erase_rel(rest$1)]; + case 3: + var rest$2 = param[1]; return [3, erase_rel(rest$2)]; + case 4: + var rest$3 = param[1]; return [4, erase_rel(rest$3)]; + case 5: + var rest$4 = param[1]; return [5, erase_rel(rest$4)]; + case 6: + var rest$5 = param[1]; return [6, erase_rel(rest$5)]; + case 7: + var rest$6 = param[1]; return [7, erase_rel(rest$6)]; + case 8: + var rest$7 = param[2], ty = param[1]; + return [8, ty, erase_rel(rest$7)]; + case 9: + var rest$8 = param[3], ty1 = param[1]; + return [9, ty1, ty1, erase_rel(rest$8)]; + case 10: + var rest$9 = param[1]; return [10, erase_rel(rest$9)]; + case 11: + var rest$10 = param[1]; return [11, erase_rel(rest$10)]; + case 12: + var rest$11 = param[1]; return [12, erase_rel(rest$11)]; + case 13: + var rest$12 = param[1]; return [13, erase_rel(rest$12)]; + default: var rest$13 = param[1]; return [14, erase_rel(rest$13)]; + } + } + function concat_fmtty(fmtty1, fmtty2){ + if(typeof fmtty1 === "number") return fmtty2; + switch(fmtty1[0]){ + case 0: + var rest = fmtty1[1]; return [0, concat_fmtty(rest, fmtty2)]; + case 1: + var rest$0 = fmtty1[1]; return [1, concat_fmtty(rest$0, fmtty2)]; + case 2: + var rest$1 = fmtty1[1]; return [2, concat_fmtty(rest$1, fmtty2)]; + case 3: + var rest$2 = fmtty1[1]; return [3, concat_fmtty(rest$2, fmtty2)]; + case 4: + var rest$3 = fmtty1[1]; return [4, concat_fmtty(rest$3, fmtty2)]; + case 5: + var rest$4 = fmtty1[1]; return [5, concat_fmtty(rest$4, fmtty2)]; + case 6: + var rest$5 = fmtty1[1]; return [6, concat_fmtty(rest$5, fmtty2)]; + case 7: + var rest$6 = fmtty1[1]; return [7, concat_fmtty(rest$6, fmtty2)]; + case 8: + var rest$7 = fmtty1[2], ty = fmtty1[1]; + return [8, ty, concat_fmtty(rest$7, fmtty2)]; + case 9: + var rest$8 = fmtty1[3], ty2 = fmtty1[2], ty1 = fmtty1[1]; + return [9, ty1, ty2, concat_fmtty(rest$8, fmtty2)]; + case 10: + var rest$9 = fmtty1[1]; return [10, concat_fmtty(rest$9, fmtty2)]; + case 11: + var rest$10 = fmtty1[1]; return [11, concat_fmtty(rest$10, fmtty2)]; + case 12: + var rest$11 = fmtty1[1]; return [12, concat_fmtty(rest$11, fmtty2)]; + case 13: + var rest$12 = fmtty1[1]; return [13, concat_fmtty(rest$12, fmtty2)]; + default: + var rest$13 = fmtty1[1]; return [14, concat_fmtty(rest$13, fmtty2)]; + } + } + function concat_fmt(fmt1, fmt2){ + if(typeof fmt1 === "number") return fmt2; + switch(fmt1[0]){ + case 0: + var rest = fmt1[1]; return [0, concat_fmt(rest, fmt2)]; + case 1: + var rest$0 = fmt1[1]; return [1, concat_fmt(rest$0, fmt2)]; + case 2: + var rest$1 = fmt1[2], pad = fmt1[1]; + return [2, pad, concat_fmt(rest$1, fmt2)]; + case 3: + var rest$2 = fmt1[2], pad$0 = fmt1[1]; + return [3, pad$0, concat_fmt(rest$2, fmt2)]; + case 4: + var rest$3 = fmt1[4], prec = fmt1[3], pad$1 = fmt1[2], iconv = fmt1[1]; + return [4, iconv, pad$1, prec, concat_fmt(rest$3, fmt2)]; + case 5: + var + rest$4 = fmt1[4], + prec$0 = fmt1[3], + pad$2 = fmt1[2], + iconv$0 = fmt1[1]; + return [5, iconv$0, pad$2, prec$0, concat_fmt(rest$4, fmt2)]; + case 6: + var + rest$5 = fmt1[4], + prec$1 = fmt1[3], + pad$3 = fmt1[2], + iconv$1 = fmt1[1]; + return [6, iconv$1, pad$3, prec$1, concat_fmt(rest$5, fmt2)]; + case 7: + var + rest$6 = fmt1[4], + prec$2 = fmt1[3], + pad$4 = fmt1[2], + iconv$2 = fmt1[1]; + return [7, iconv$2, pad$4, prec$2, concat_fmt(rest$6, fmt2)]; + case 8: + var + rest$7 = fmt1[4], + prec$3 = fmt1[3], + pad$5 = fmt1[2], + fconv = fmt1[1]; + return [8, fconv, pad$5, prec$3, concat_fmt(rest$7, fmt2)]; + case 9: + var rest$8 = fmt1[2], pad$6 = fmt1[1]; + return [9, pad$6, concat_fmt(rest$8, fmt2)]; + case 10: + var rest$9 = fmt1[1]; return [10, concat_fmt(rest$9, fmt2)]; + case 11: + var rest$10 = fmt1[2], str = fmt1[1]; + return [11, str, concat_fmt(rest$10, fmt2)]; + case 12: + var rest$11 = fmt1[2], chr = fmt1[1]; + return [12, chr, concat_fmt(rest$11, fmt2)]; + case 13: + var rest$12 = fmt1[3], fmtty = fmt1[2], pad$7 = fmt1[1]; + return [13, pad$7, fmtty, concat_fmt(rest$12, fmt2)]; + case 14: + var rest$13 = fmt1[3], fmtty$0 = fmt1[2], pad$8 = fmt1[1]; + return [14, pad$8, fmtty$0, concat_fmt(rest$13, fmt2)]; + case 15: + var rest$14 = fmt1[1]; return [15, concat_fmt(rest$14, fmt2)]; + case 16: + var rest$15 = fmt1[1]; return [16, concat_fmt(rest$15, fmt2)]; + case 17: + var rest$16 = fmt1[2], fmting_lit = fmt1[1]; + return [17, fmting_lit, concat_fmt(rest$16, fmt2)]; + case 18: + var rest$17 = fmt1[2], fmting_gen = fmt1[1]; + return [18, fmting_gen, concat_fmt(rest$17, fmt2)]; + case 19: + var rest$18 = fmt1[1]; return [19, concat_fmt(rest$18, fmt2)]; + case 20: + var rest$19 = fmt1[3], char_set = fmt1[2], width_opt = fmt1[1]; + return [20, width_opt, char_set, concat_fmt(rest$19, fmt2)]; + case 21: + var rest$20 = fmt1[2], counter = fmt1[1]; + return [21, counter, concat_fmt(rest$20, fmt2)]; + case 22: + var rest$21 = fmt1[1]; return [22, concat_fmt(rest$21, fmt2)]; + case 23: + var rest$22 = fmt1[2], ign = fmt1[1]; + return [23, ign, concat_fmt(rest$22, fmt2)]; + default: + var rest$23 = fmt1[3], f = fmt1[2], arity = fmt1[1]; + return [24, arity, f, concat_fmt(rest$23, fmt2)]; + } + } + var CamlinternalFormatBasics = [0, concat_fmtty, erase_rel, concat_fmt]; + runtime.caml_register_global + (0, CamlinternalFormatBasics, "CamlinternalFormatBasics"); + return; + } + (globalThis)); + +//# 179 "../.js/default/stdlib/stdlib.cma.js" +(function(globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function make(v){return [0, v];} + function get(r){return r[1];} + function set(r, v){r[1] = v; return 0;} + function exchange(r, v){var cur = r[1]; r[1] = v; return cur;} + function compare_and_set(r, seen, v){ + var cur = r[1]; + return cur === seen ? (r[1] = v, 1) : 0; + } + function fetch_and_add(r, n){ + var cur = r[1]; + r[1] = cur + n | 0; + return cur; + } + function incr(r){fetch_and_add(r, 1); return 0;} + function decr(r){fetch_and_add(r, -1); return 0;} + var + CamlinternalAtomic = + [0, + make, + get, + set, + exchange, + compare_and_set, + fetch_and_add, + incr, + decr]; + runtime.caml_register_global(0, CamlinternalAtomic, "CamlinternalAtomic"); + return; + } + (globalThis)); + +//# 215 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_false$0 = "false", + cst_true$0 = "true", + caml_create_bytes = runtime.caml_create_bytes, + caml_float_of_string = runtime.caml_float_of_string, + caml_int64_float_of_bits = runtime.caml_int64_float_of_bits, + caml_int_of_string = runtime.caml_int_of_string, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace, + caml_ml_bytes_length = runtime.caml_ml_bytes_length, + caml_ml_channel_size = runtime.caml_ml_channel_size, + caml_ml_channel_size_64 = runtime.caml_ml_channel_size_64, + caml_ml_close_channel = runtime.caml_ml_close_channel, + caml_ml_flush = runtime.caml_ml_flush, + caml_ml_input = runtime.caml_ml_input, + caml_ml_input_char = runtime.caml_ml_input_char, + caml_ml_open_descriptor_in = runtime.caml_ml_open_descriptor_in, + caml_ml_open_descriptor_out = runtime.caml_ml_open_descriptor_out, + caml_ml_output = runtime.caml_ml_output, + caml_ml_output_bytes = runtime.caml_ml_output_bytes, + caml_ml_output_char = runtime.caml_ml_output_char, + caml_ml_set_binary_mode = runtime.caml_ml_set_binary_mode, + caml_ml_set_channel_name = runtime.caml_ml_set_channel_name, + caml_ml_string_length = runtime.caml_ml_string_length, + caml_string_concat = runtime.caml_string_concat, + caml_string_of_bytes = runtime.caml_string_of_bytes, + caml_sys_open = runtime.caml_sys_open, + caml_wrap_exception = runtime.caml_wrap_exception; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + CamlinternalAtomic = global_data.CamlinternalAtomic, + CamlinternalFormatBasics = global_data.CamlinternalFormatBasics, + Invalid_argument = global_data.Invalid_argument, + Failure = global_data.Failure, + Match_failure = global_data.Match_failure, + Assert_failure = global_data.Assert_failure, + Not_found = global_data.Not_found, + Out_of_memory = global_data.Out_of_memory, + Stack_overflow = global_data.Stack_overflow, + Sys_error = global_data.Sys_error, + End_of_file = global_data.End_of_file, + Division_by_zero = global_data.Division_by_zero, + Sys_blocked_io = global_data.Sys_blocked_io, + Undefined_recursive_module = global_data.Undefined_recursive_module; + function failwith(s){ + throw caml_maybe_attach_backtrace([0, Failure, s], 1); + } + function invalid_arg(s){ + throw caml_maybe_attach_backtrace([0, Invalid_argument, s], 1); + } + var Exit = [248, "Stdlib.Exit", runtime.caml_fresh_oo_id(0)]; + function min(x, y){return runtime.caml_lessequal(x, y) ? x : y;} + function max(x, y){return runtime.caml_greaterequal(x, y) ? x : y;} + function abs(x){return 0 <= x ? x : - x | 0;} + function lnot(x){return x ^ -1;} + var + infinity = + caml_int64_float_of_bits + (runtime.caml_int64_create_lo_mi_hi(0, 0, 32752)), + neg_infinity = + caml_int64_float_of_bits + (runtime.caml_int64_create_lo_mi_hi(0, 0, 65520)), + nan = + caml_int64_float_of_bits + (runtime.caml_int64_create_lo_mi_hi(1, 0, 32752)), + max_float = + caml_int64_float_of_bits + (runtime.caml_int64_create_lo_mi_hi(16777215, 16777215, 32751)), + min_float = + caml_int64_float_of_bits(runtime.caml_int64_create_lo_mi_hi(0, 0, 16)), + epsilon_float = + caml_int64_float_of_bits + (runtime.caml_int64_create_lo_mi_hi(0, 0, 15536)), + symbol_concat = caml_string_concat, + cst_char_of_int = "char_of_int", + cst_true = cst_true$0, + cst_false = cst_false$0, + cst_bool_of_string = "bool_of_string", + _a_ = [0, 1], + _b_ = [0, 0]; + function char_of_int(n){ + if(0 <= n && 255 >= n) return n; + return invalid_arg(cst_char_of_int); + } + function string_of_bool(b){return b ? cst_true : cst_false;} + function bool_of_string(param){ + return param !== cst_false$0 + ? param !== cst_true$0 ? invalid_arg(cst_bool_of_string) : 1 + : 0; + } + function bool_of_string_opt(param){ + return param !== cst_false$0 ? param !== cst_true$0 ? 0 : _a_ : _b_; + } + function string_of_int(n){return "" + n;} + function int_of_string_opt(s){ + try{var _u_ = [0, caml_int_of_string(s)]; return _u_;} + catch(_v_){ + var _t_ = caml_wrap_exception(_v_); + if(_t_[1] === Failure) return 0; + throw caml_maybe_attach_backtrace(_t_, 0); + } + } + function valid_float_lexem(s1){ + var l = caml_ml_string_length(s1), i = 0; + for(;;){ + if(l <= i) return s1 + "."; + var match = runtime.caml_string_get(s1, i); + a: + { + if(48 <= match){if(58 > match) break a;} else if(45 === match) break a; + return s1; + } + var i$0 = i + 1 | 0; + i = i$0; + } + } + function string_of_float(f){ + return valid_float_lexem(runtime.caml_format_float("%.12g", f)); + } + function float_of_string_opt(s){ + try{var _r_ = [0, caml_float_of_string(s)]; return _r_;} + catch(_s_){ + var _q_ = caml_wrap_exception(_s_); + if(_q_[1] === Failure) return 0; + throw caml_maybe_attach_backtrace(_q_, 0); + } + } + function symbol(l1, l2){ + if(! l1) return l2; + var tl = l1[2], hd = l1[1]; + return [0, hd, symbol(tl, l2)]; + } + var + stdin = caml_ml_open_descriptor_in(0), + stdout = caml_ml_open_descriptor_out(1), + stderr = caml_ml_open_descriptor_out(2), + _c_ = [0, 1, [0, 3, [0, 4, [0, 7, 0]]]], + _d_ = [0, 1, [0, 3, [0, 4, [0, 6, 0]]]], + cst_output = "output", + cst_output_substring = "output_substring", + _e_ = [0, 0, [0, 7, 0]], + _f_ = [0, 0, [0, 6, 0]], + cst_input = "input", + cst_really_input = "really_input"; + function open_out_gen(mode, perm, name){ + var c = caml_ml_open_descriptor_out(caml_sys_open(name, mode, perm)); + caml_ml_set_channel_name(c, name); + return c; + } + function open_out(name){return open_out_gen(_c_, 438, name);} + function open_out_bin(name){return open_out_gen(_d_, 438, name);} + function flush_all(param){ + var param$0 = runtime.caml_ml_out_channels_list(0); + for(;;){ + if(! param$0) return 0; + var l = param$0[2], a = param$0[1]; + try{caml_ml_flush(a);} + catch(_p_){ + var _o_ = caml_wrap_exception(_p_); + if(_o_[1] !== Sys_error) throw caml_maybe_attach_backtrace(_o_, 0); + } + param$0 = l; + } + } + function output_bytes(oc, s){ + return caml_ml_output_bytes(oc, s, 0, caml_ml_bytes_length(s)); + } + function output_string(oc, s){ + return caml_ml_output(oc, s, 0, caml_ml_string_length(s)); + } + function output(oc, s, ofs, len){ + if(0 <= ofs && 0 <= len && (caml_ml_bytes_length(s) - len | 0) >= ofs) + return caml_ml_output_bytes(oc, s, ofs, len); + return invalid_arg(cst_output); + } + function output_substring(oc, s, ofs, len){ + if(0 <= ofs && 0 <= len && (caml_ml_string_length(s) - len | 0) >= ofs) + return caml_ml_output(oc, s, ofs, len); + return invalid_arg(cst_output_substring); + } + function output_value(chan, v){ + return runtime.caml_output_value(chan, v, 0); + } + function close_out(oc){ + caml_ml_flush(oc); + return caml_ml_close_channel(oc); + } + function close_out_noerr(oc){ + try{caml_ml_flush(oc);}catch(_n_){} + try{var _l_ = caml_ml_close_channel(oc); return _l_;}catch(_m_){return 0;} + } + function open_in_gen(mode, perm, name){ + var c = caml_ml_open_descriptor_in(caml_sys_open(name, mode, perm)); + caml_ml_set_channel_name(c, name); + return c; + } + function open_in(name){return open_in_gen(_e_, 0, name);} + function open_in_bin(name){return open_in_gen(_f_, 0, name);} + function input(ic, s, ofs, len){ + if(0 <= ofs && 0 <= len && (caml_ml_bytes_length(s) - len | 0) >= ofs) + return caml_ml_input(ic, s, ofs, len); + return invalid_arg(cst_input); + } + function unsafe_really_input(ic, s, ofs, len){ + var ofs$0 = ofs, len$0 = len; + for(;;){ + if(0 >= len$0) return 0; + var r = caml_ml_input(ic, s, ofs$0, len$0); + if(0 === r) throw caml_maybe_attach_backtrace(End_of_file, 1); + var len$1 = len$0 - r | 0, ofs$1 = ofs$0 + r | 0; + ofs$0 = ofs$1; + len$0 = len$1; + } + } + function really_input(ic, s, ofs, len){ + if(0 <= ofs && 0 <= len && (caml_ml_bytes_length(s) - len | 0) >= ofs) + return unsafe_really_input(ic, s, ofs, len); + return invalid_arg(cst_really_input); + } + function really_input_string(ic, len){ + var s = caml_create_bytes(len); + really_input(ic, s, 0, len); + return caml_string_of_bytes(s); + } + function input_line(chan){ + function build_result(buf, pos, param){ + var pos$0 = pos, param$0 = param; + for(;;){ + if(! param$0) return buf; + var tl = param$0[2], hd = param$0[1], len = caml_ml_bytes_length(hd); + runtime.caml_blit_bytes(hd, 0, buf, pos$0 - len | 0, len); + var pos$1 = pos$0 - len | 0; + pos$0 = pos$1; + param$0 = tl; + } + } + var accu = 0, len = 0; + for(;;){ + var n = runtime.caml_ml_input_scan_line(chan); + if(0 === n){ + if(! accu) throw caml_maybe_attach_backtrace(End_of_file, 1); + var _k_ = build_result(caml_create_bytes(len), len, accu); + } + else{ + if(0 >= n){ + var beg = caml_create_bytes(- n | 0); + caml_ml_input(chan, beg, 0, - n | 0); + var len$1 = len - n | 0, accu$0 = [0, beg, accu]; + accu = accu$0; + len = len$1; + continue; + } + var res = caml_create_bytes(n - 1 | 0); + caml_ml_input(chan, res, 0, n - 1 | 0); + caml_ml_input_char(chan); + if(accu) + var + len$0 = (len + n | 0) - 1 | 0, + _k_ = build_result(caml_create_bytes(len$0), len$0, [0, res, accu]); + else + var _k_ = res; + } + return caml_string_of_bytes(_k_); + } + } + function close_in_noerr(ic){ + try{var _i_ = caml_ml_close_channel(ic); return _i_;}catch(_j_){return 0;} + } + function print_char(c){return caml_ml_output_char(stdout, c);} + function print_string(s){return output_string(stdout, s);} + function print_bytes(s){return output_bytes(stdout, s);} + function print_int(i){return output_string(stdout, "" + i);} + function print_float(f){return output_string(stdout, string_of_float(f));} + function print_endline(s){ + output_string(stdout, s); + caml_ml_output_char(stdout, 10); + return caml_ml_flush(stdout); + } + function print_newline(param){ + caml_ml_output_char(stdout, 10); + return caml_ml_flush(stdout); + } + function prerr_char(c){return caml_ml_output_char(stderr, c);} + function prerr_string(s){return output_string(stderr, s);} + function prerr_bytes(s){return output_bytes(stderr, s);} + function prerr_int(i){return output_string(stderr, "" + i);} + function prerr_float(f){return output_string(stderr, string_of_float(f));} + function prerr_endline(s){ + output_string(stderr, s); + caml_ml_output_char(stderr, 10); + return caml_ml_flush(stderr); + } + function prerr_newline(param){ + caml_ml_output_char(stderr, 10); + return caml_ml_flush(stderr); + } + function read_line(param){caml_ml_flush(stdout); return input_line(stdin);} + function read_int(param){return caml_int_of_string(read_line(0));} + function read_int_opt(param){return int_of_string_opt(read_line(0));} + function read_float(param){return caml_float_of_string(read_line(0));} + function read_float_opt(param){return float_of_string_opt(read_line(0));} + function string_of_format(param){var str = param[2]; return str;} + function symbol$0(param, _h_){ + var + str2 = _h_[2], + fmt2 = _h_[1], + str1 = param[2], + fmt1 = param[1], + s2 = "%," + str2; + return [0, caml_call2(CamlinternalFormatBasics[3], fmt1, fmt2), str1 + s2]; + } + var exit_function = caml_call1(CamlinternalAtomic[1], flush_all); + function at_exit(f){ + for(;;){ + var + f_yet_to_run = caml_call1(CamlinternalAtomic[1], 1), + old_exit = caml_call1(CamlinternalAtomic[2], exit_function); + let f_yet_to_run$0 = f_yet_to_run, old_exit$0 = old_exit; + var + new_exit = + function(param){ + if(caml_call3(CamlinternalAtomic[5], f_yet_to_run$0, 1, 0)) + caml_call1(f, 0); + return caml_call1(old_exit$0, 0); + }, + success = + caml_call3(CamlinternalAtomic[5], exit_function, old_exit, new_exit), + _g_ = 1 - success; + if(! _g_) return _g_; + } + } + function do_at_exit(param){ + return caml_call1(caml_call1(CamlinternalAtomic[2], exit_function), 0); + } + function exit(retcode){ + do_at_exit(0); + return runtime.caml_sys_exit(retcode); + } + runtime.caml_register_named_value("Pervasives.do_at_exit", do_at_exit); + var + Stdlib = + [0, + invalid_arg, + failwith, + Exit, + Match_failure, + Assert_failure, + Invalid_argument, + Failure, + Not_found, + Out_of_memory, + Stack_overflow, + Sys_error, + End_of_file, + Division_by_zero, + Sys_blocked_io, + Undefined_recursive_module, + min, + max, + abs, + 2147483647, + -2147483648, + lnot, + infinity, + neg_infinity, + nan, + max_float, + min_float, + epsilon_float, + symbol_concat, + char_of_int, + string_of_bool, + bool_of_string_opt, + bool_of_string, + string_of_int, + int_of_string_opt, + string_of_float, + float_of_string_opt, + symbol, + stdin, + stdout, + stderr, + print_char, + print_string, + print_bytes, + print_int, + print_float, + print_endline, + print_newline, + prerr_char, + prerr_string, + prerr_bytes, + prerr_int, + prerr_float, + prerr_endline, + prerr_newline, + read_line, + read_int_opt, + read_int, + read_float_opt, + read_float, + open_out, + open_out_bin, + open_out_gen, + caml_ml_flush, + flush_all, + caml_ml_output_char, + output_string, + output_bytes, + output, + output_substring, + caml_ml_output_char, + runtime.caml_ml_output_int, + output_value, + runtime.caml_ml_seek_out, + runtime.caml_ml_pos_out, + caml_ml_channel_size, + close_out, + close_out_noerr, + caml_ml_set_binary_mode, + open_in, + open_in_bin, + open_in_gen, + caml_ml_input_char, + input_line, + input, + really_input, + really_input_string, + caml_ml_input_char, + runtime.caml_ml_input_int, + runtime.caml_input_value, + runtime.caml_ml_seek_in, + runtime.caml_ml_pos_in, + caml_ml_channel_size, + caml_ml_close_channel, + close_in_noerr, + caml_ml_set_binary_mode, + [0, + runtime.caml_ml_seek_out_64, + runtime.caml_ml_pos_out_64, + caml_ml_channel_size_64, + runtime.caml_ml_seek_in_64, + runtime.caml_ml_pos_in_64, + caml_ml_channel_size_64], + string_of_format, + symbol$0, + exit, + at_exit, + valid_float_lexem, + unsafe_really_input, + do_at_exit]; + runtime.caml_register_global(46, Stdlib, "Stdlib"); + return; + } + (globalThis)); + +//# 884 "../.js/default/stdlib/stdlib.cma.js" +(function(globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function empty(param){return 0;} + function return$0(x, param){return [0, x, empty];} + function cons(x, next, param){return [0, x, next];} + function append(seq1, seq2, param){ + var match = caml_call1(seq1, 0); + if(! match) return caml_call1(seq2, 0); + var next = match[2], x = match[1]; + return [0, x, function(_g_){return append(next, seq2, _g_);}]; + } + function map(f, seq, param){ + var match = caml_call1(seq, 0); + if(! match) return 0; + var next = match[2], x = match[1]; + return [0, caml_call1(f, x), function(_f_){return map(f, next, _f_);}]; + } + function filter_map(f, seq, param){ + var seq$0 = seq; + for(;;){ + var match = caml_call1(seq$0, 0); + if(! match) return 0; + var next = match[2], x = match[1], match$0 = caml_call1(f, x); + if(match$0){ + var y = match$0[1]; + return [0, y, function(_e_){return filter_map(f, next, _e_);}]; + } + seq$0 = next; + } + } + function filter(f, seq, param){ + var seq$0 = seq; + for(;;){ + var match = caml_call1(seq$0, 0); + if(! match) return 0; + var next = match[2], x = match[1]; + if(caml_call1(f, x)) + return [0, x, function(_d_){return filter(f, next, _d_);}]; + seq$0 = next; + } + } + function concat(seq, param){ + var match = caml_call1(seq, 0); + if(! match) return 0; + var next = match[2], x = match[1]; + return append(x, function(_c_){return concat(next, _c_);}, 0); + } + function flat_map(f, seq, param){ + var match = caml_call1(seq, 0); + if(! match) return 0; + var next = match[2], x = match[1]; + return append + (caml_call1(f, x), + function(_b_){return flat_map(f, next, _b_);}, + 0); + } + function fold_left(f, acc, seq){ + var acc$0 = acc, seq$0 = seq; + for(;;){ + var match = caml_call1(seq$0, 0); + if(! match) return acc$0; + var next = match[2], x = match[1], acc$1 = caml_call2(f, acc$0, x); + acc$0 = acc$1; + seq$0 = next; + } + } + function iter(f, seq){ + var seq$0 = seq; + for(;;){ + var match = caml_call1(seq$0, 0); + if(! match) return 0; + var next = match[2], x = match[1]; + caml_call1(f, x); + seq$0 = next; + } + } + function unfold(f, u, param){ + var match = caml_call1(f, u); + if(! match) return 0; + var match$0 = match[1], u$0 = match$0[2], x = match$0[1]; + return [0, x, function(_a_){return unfold(f, u$0, _a_);}]; + } + var + Stdlib_Seq = + [0, + empty, + return$0, + cons, + append, + map, + filter, + filter_map, + concat, + flat_map, + flat_map, + fold_left, + iter, + unfold]; + runtime.caml_register_global(0, Stdlib_Seq, "Stdlib__Seq"); + return; + } + (globalThis)); + +//# 1363 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + caml_bytes_unsafe_set = runtime.caml_bytes_unsafe_set, + caml_create_bytes = runtime.caml_create_bytes, + caml_string_of_bytes = runtime.caml_string_of_bytes; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + var + global_data = runtime.caml_get_global_data(), + cst = "\\\\", + cst$0 = "\\'", + Stdlib = global_data.Stdlib, + cst_Char_chr = "Char.chr", + cst_b = "\\b", + cst_t = "\\t", + cst_n = "\\n", + cst_r = "\\r"; + function chr(n){ + if(0 <= n && 255 >= n) return n; + return caml_call1(Stdlib[1], cst_Char_chr); + } + function escaped(c){ + a: + { + if(40 <= c){ + if(92 === c) return cst; + if(127 > c) break a; + } + else{ + if(32 <= c){if(39 <= c) return cst$0; break a;} + if(14 > c) + switch(c){ + case 8: + return cst_b; + case 9: + return cst_t; + case 10: + return cst_n; + case 13: + return cst_r; + } + } + var s = caml_create_bytes(4); + caml_bytes_unsafe_set(s, 0, 92); + caml_bytes_unsafe_set(s, 1, 48 + (c / 100 | 0) | 0); + caml_bytes_unsafe_set(s, 2, 48 + ((c / 10 | 0) % 10 | 0) | 0); + caml_bytes_unsafe_set(s, 3, 48 + (c % 10 | 0) | 0); + return caml_string_of_bytes(s); + } + var s$0 = caml_create_bytes(1); + caml_bytes_unsafe_set(s$0, 0, c); + return caml_string_of_bytes(s$0); + } + function lowercase(c){ + var _b_ = c - 192 | 0; + a: + { + if(30 < _b_ >>> 0){ + if(25 < _b_ + 127 >>> 0) break a; + } + else if(23 === _b_) break a; + return c + 32 | 0; + } + return c; + } + function uppercase(c){ + var _a_ = c - 224 | 0; + a: + { + if(30 < _a_ >>> 0){ + if(25 < _a_ + 127 >>> 0) break a; + } + else if(23 === _a_) break a; + return c - 32 | 0; + } + return c; + } + function lowercase_ascii(c){return 25 < c - 65 >>> 0 ? c : c + 32 | 0;} + function uppercase_ascii(c){return 25 < c - 97 >>> 0 ? c : c - 32 | 0;} + function compare(c1, c2){return c1 - c2 | 0;} + function equal(c1, c2){return 0 === (c1 - c2 | 0) ? 1 : 0;} + var + Stdlib_Char = + [0, + chr, + escaped, + lowercase, + uppercase, + lowercase_ascii, + uppercase_ascii, + compare, + equal]; + runtime.caml_register_global(8, Stdlib_Char, "Stdlib__Char"); + return; + } + (globalThis)); + +//# 1468 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + caml_format_int = runtime.caml_format_int; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + err_no_pred = "U+0000 has no predecessor", + err_no_succ = "U+10FFFF has no successor", + Stdlib = global_data.Stdlib, + cst_is_not_an_Unicode_scalar_v = " is not an Unicode scalar value", + cst_is_not_a_latin1_character = " is not a latin1 character", + cst_U = "U+", + lo_bound = 55295, + hi_bound = 57344; + function succ(u){ + return u === 55295 + ? hi_bound + : u === 1114111 ? caml_call1(Stdlib[1], err_no_succ) : u + 1 | 0; + } + function pred(u){ + return u === 57344 + ? lo_bound + : u === 0 ? caml_call1(Stdlib[1], err_no_pred) : u - 1 | 0; + } + function is_valid(i){ + var _j_ = 0 <= i ? 1 : 0, _k_ = _j_ ? i <= 55295 ? 1 : 0 : _j_; + if(_k_) + var _l_ = _k_; + else + var _m_ = 57344 <= i ? 1 : 0, _l_ = _m_ ? i <= 1114111 ? 1 : 0 : _m_; + return _l_; + } + function of_int(i){ + if(is_valid(i)) return i; + var + _i_ = + caml_call2 + (Stdlib[28], caml_format_int("%X", i), cst_is_not_an_Unicode_scalar_v); + return caml_call1(Stdlib[1], _i_); + } + function is_char(u){return u < 256 ? 1 : 0;} + function of_char(c){return c;} + function to_char(u){ + if(255 >= u) return u; + var + _g_ = + caml_call2 + (Stdlib[28], + caml_format_int("%04X", u), + cst_is_not_a_latin1_character), + _h_ = caml_call2(Stdlib[28], cst_U, _g_); + return caml_call1(Stdlib[1], _h_); + } + function unsafe_to_char(_f_){return _f_;} + function equal(_e_, _d_){return _e_ === _d_ ? 1 : 0;} + var compare = runtime.caml_int_compare; + function hash(_c_){return _c_;} + var + Stdlib_Uchar = + [0, + 0, + 1114111, + 65279, + 65533, + succ, + pred, + is_valid, + of_int, + function(_b_){return _b_;}, + function(_a_){return _a_;}, + is_char, + of_char, + to_char, + unsafe_to_char, + equal, + compare, + hash]; + runtime.caml_register_global(8, Stdlib_Uchar, "Stdlib__Uchar"); + return; + } + (globalThis)); + +//# 1564 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace, + caml_wrap_exception = runtime.caml_wrap_exception, + global_data = runtime.caml_get_global_data(), + ocaml_version = "4.13.1", + Stdlib = global_data.Stdlib, + executable_name = runtime.caml_sys_executable_name(0), + os_type = runtime.caml_sys_get_config(0)[1], + backend_type = [0, "js_of_ocaml"], + unix = runtime.caml_sys_const_ostype_unix(0), + win32 = runtime.caml_sys_const_ostype_win32(0), + cygwin = runtime.caml_sys_const_ostype_cygwin(0), + max_array_length = runtime.caml_sys_const_max_wosize(0), + max_floatarray_length = max_array_length / 2 | 0, + max_string_length = (4 * max_array_length | 0) - 1 | 0; + function getenv_opt(s){ + try{var _d_ = [0, runtime.caml_sys_getenv(s)]; return _d_;} + catch(_e_){ + var _c_ = caml_wrap_exception(_e_); + if(_c_ === Stdlib[8]) return 0; + throw caml_maybe_attach_backtrace(_c_, 0); + } + } + var interactive = [0, 0]; + function set_signal(sig_num, sig_beh){return 0;} + var Break = [248, "Stdlib.Sys.Break", runtime.caml_fresh_oo_id(0)]; + function catch_break(on){return on ? 0 : 0;} + function Make(_b_, _a_){return [0, 1];} + var + Immediate64 = [0, Make], + Stdlib_Sys = + [0, + executable_name, + getenv_opt, + interactive, + os_type, + backend_type, + unix, + win32, + cygwin, + 32, + 32, + 0, + max_string_length, + max_array_length, + max_floatarray_length, + set_signal, + -1, + -2, + -3, + -4, + -5, + -6, + -7, + -8, + -9, + -10, + -11, + -12, + -13, + -14, + -15, + -16, + -17, + -18, + -19, + -20, + -21, + -22, + -23, + -24, + -25, + -26, + -27, + -28, + Break, + catch_break, + ocaml_version, + runtime.caml_ml_enable_runtime_warnings, + runtime.caml_ml_runtime_warnings_enabled, + Immediate64]; + runtime.caml_register_global(3, Stdlib_Sys, "Stdlib__Sys"); + return; + } + (globalThis)); + +//# 1656 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_List_nth$1 = "List.nth", + caml_compare = runtime.caml_compare, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + Stdlib = global_data.Stdlib, + Stdlib_Seq = global_data.Stdlib__Seq, + Stdlib_Sys = global_data.Stdlib__Sys, + cst_hd = "hd", + cst_tl = "tl", + cst_nth = "nth", + cst_List_nth = cst_List_nth$1, + cst_List_nth$0 = cst_List_nth$1; + function length(l$0){ + var len = 0, param = l$0; + for(;;){ + if(! param) return len; + var l = param[2], len$0 = len + 1 | 0; + len = len$0; + param = l; + } + } + function cons(a, l){return [0, a, l];} + function hd(param){ + if(! param) return caml_call1(Stdlib[2], cst_hd); + var a = param[1]; + return a; + } + function tl(param){ + if(! param) return caml_call1(Stdlib[2], cst_tl); + var l = param[2]; + return l; + } + function nth(l, n){ + if(0 > n) return caml_call1(Stdlib[1], cst_List_nth); + var l$0 = l, n$0 = n; + for(;;){ + if(! l$0) return caml_call1(Stdlib[2], cst_nth); + var l$1 = l$0[2], a = l$0[1]; + if(0 === n$0) return a; + var n$1 = n$0 - 1 | 0; + l$0 = l$1; + n$0 = n$1; + } + } + function nth_opt(l, n){ + if(0 > n) return caml_call1(Stdlib[1], cst_List_nth$0); + var l$0 = l, n$0 = n; + for(;;){ + if(! l$0) return 0; + var l$1 = l$0[2], a = l$0[1]; + if(0 === n$0) return [0, a]; + var n$1 = n$0 - 1 | 0; + l$0 = l$1; + n$0 = n$1; + } + } + var append = Stdlib[37]; + function rev_append(l1, l2){ + var l1$0 = l1, l2$0 = l2; + for(;;){ + if(! l1$0) return l2$0; + var l1$1 = l1$0[2], a = l1$0[1], l2$1 = [0, a, l2$0]; + l1$0 = l1$1; + l2$0 = l2$1; + } + } + function rev(l){return rev_append(l, 0);} + function init_aux(i, n, f){ + if(n <= i) return 0; + var r = caml_call1(f, i); + return [0, r, init_aux(i + 1 | 0, n, f)]; + } + var + cst_List_map2 = "List.map2", + cst_List_iter2 = "List.iter2", + cst_List_fold_left2 = "List.fold_left2", + cst_List_fold_right2 = "List.fold_right2", + cst_List_for_all2 = "List.for_all2", + cst_List_exists2 = "List.exists2", + _b_ = [0, 0, 0], + cst_List_combine = "List.combine", + cst_List_rev_map2 = "List.rev_map2", + cst_List_init = "List.init", + rev_init_threshold = typeof Stdlib_Sys[5] === "number" ? 10000 : 50; + function init(len, f){ + if(0 > len) return caml_call1(Stdlib[1], cst_List_init); + if(rev_init_threshold >= len) return init_aux(0, len, f); + var acc = 0, i = 0; + for(;;){ + if(len <= i) return rev(acc); + var i$0 = i + 1 | 0, acc$0 = [0, caml_call1(f, i), acc]; + acc = acc$0; + i = i$0; + } + } + function flatten(param){ + if(! param) return 0; + var r = param[2], l = param[1], _H_ = flatten(r); + return caml_call2(Stdlib[37], l, _H_); + } + function map(f, param){ + if(! param) return 0; + var l = param[2], a = param[1], r = caml_call1(f, a); + return [0, r, map(f, l)]; + } + function _a_(i, f, param){ + if(! param) return 0; + var l = param[2], a = param[1], r = caml_call2(f, i, a); + return [0, r, _a_(i + 1 | 0, f, l)]; + } + function mapi(f, l){return _a_(0, f, l);} + function rev_map(f, l){ + var accu = 0, param = l; + for(;;){ + if(! param) return accu; + var l$0 = param[2], a = param[1], accu$0 = [0, caml_call1(f, a), accu]; + accu = accu$0; + param = l$0; + } + } + function iter(f, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var l = param$0[2], a = param$0[1]; + caml_call1(f, a); + param$0 = l; + } + } + function iteri(f, l$0){ + var i = 0, param = l$0; + for(;;){ + if(! param) return 0; + var l = param[2], a = param[1]; + caml_call2(f, i, a); + var i$0 = i + 1 | 0; + i = i$0; + param = l; + } + } + function fold_left(f, accu, l){ + var accu$0 = accu, l$0 = l; + for(;;){ + if(! l$0) return accu$0; + var l$1 = l$0[2], a = l$0[1], accu$1 = caml_call2(f, accu$0, a); + accu$0 = accu$1; + l$0 = l$1; + } + } + function fold_right(f, l, accu){ + if(! l) return accu; + var l$0 = l[2], a = l[1]; + return caml_call2(f, a, fold_right(f, l$0, accu)); + } + function map2(f, l1, l2){ + if(l1){ + if(l2){ + var + l2$0 = l2[2], + a2 = l2[1], + l1$0 = l1[2], + a1 = l1[1], + r = caml_call2(f, a1, a2); + return [0, r, map2(f, l1$0, l2$0)]; + } + } + else if(! l2) return 0; + return caml_call1(Stdlib[1], cst_List_map2); + } + function rev_map2(f, l1, l2){ + var accu = 0, l1$0 = l1, l2$0 = l2; + for(;;){ + if(l1$0){ + if(l2$0){ + var + l2$1 = l2$0[2], + a2 = l2$0[1], + l1$1 = l1$0[2], + a1 = l1$0[1], + accu$0 = [0, caml_call2(f, a1, a2), accu]; + accu = accu$0; + l1$0 = l1$1; + l2$0 = l2$1; + continue; + } + } + else if(! l2$0) return accu; + return caml_call1(Stdlib[1], cst_List_rev_map2); + } + } + function iter2(f, l1, l2){ + var l1$0 = l1, l2$0 = l2; + for(;;){ + if(l1$0){ + if(l2$0){ + var l2$1 = l2$0[2], a2 = l2$0[1], l1$1 = l1$0[2], a1 = l1$0[1]; + caml_call2(f, a1, a2); + l1$0 = l1$1; + l2$0 = l2$1; + continue; + } + } + else if(! l2$0) return 0; + return caml_call1(Stdlib[1], cst_List_iter2); + } + } + function fold_left2(f, accu, l1, l2){ + var accu$0 = accu, l1$0 = l1, l2$0 = l2; + for(;;){ + if(l1$0){ + if(l2$0){ + var + l2$1 = l2$0[2], + a2 = l2$0[1], + l1$1 = l1$0[2], + a1 = l1$0[1], + accu$1 = caml_call3(f, accu$0, a1, a2); + accu$0 = accu$1; + l1$0 = l1$1; + l2$0 = l2$1; + continue; + } + } + else if(! l2$0) return accu$0; + return caml_call1(Stdlib[1], cst_List_fold_left2); + } + } + function fold_right2(f, l1, l2, accu){ + if(l1){ + if(l2){ + var l2$0 = l2[2], a2 = l2[1], l1$0 = l1[2], a1 = l1[1]; + return caml_call3(f, a1, a2, fold_right2(f, l1$0, l2$0, accu)); + } + } + else if(! l2) return accu; + return caml_call1(Stdlib[1], cst_List_fold_right2); + } + function for_all(p, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 1; + var l = param$0[2], a = param$0[1], _G_ = caml_call1(p, a); + if(! _G_) return _G_; + param$0 = l; + } + } + function exists(p, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var l = param$0[2], a = param$0[1], _F_ = caml_call1(p, a); + if(_F_) return _F_; + param$0 = l; + } + } + function for_all2(p, l1, l2){ + var l1$0 = l1, l2$0 = l2; + for(;;){ + if(l1$0){ + if(l2$0){ + var + l2$1 = l2$0[2], + a2 = l2$0[1], + l1$1 = l1$0[2], + a1 = l1$0[1], + _E_ = caml_call2(p, a1, a2); + if(! _E_) return _E_; + l1$0 = l1$1; + l2$0 = l2$1; + continue; + } + } + else if(! l2$0) return 1; + return caml_call1(Stdlib[1], cst_List_for_all2); + } + } + function exists2(p, l1, l2){ + var l1$0 = l1, l2$0 = l2; + for(;;){ + if(l1$0){ + if(l2$0){ + var + l2$1 = l2$0[2], + a2 = l2$0[1], + l1$1 = l1$0[2], + a1 = l1$0[1], + _D_ = caml_call2(p, a1, a2); + if(_D_) return _D_; + l1$0 = l1$1; + l2$0 = l2$1; + continue; + } + } + else if(! l2$0) return 0; + return caml_call1(Stdlib[1], cst_List_exists2); + } + } + function mem(x, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var + l = param$0[2], + a = param$0[1], + _C_ = 0 === caml_compare(a, x) ? 1 : 0; + if(_C_) return _C_; + param$0 = l; + } + } + function memq(x, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var l = param$0[2], a = param$0[1], _B_ = a === x ? 1 : 0; + if(_B_) return _B_; + param$0 = l; + } + } + function assoc(x, param){ + var param$0 = param; + for(;;){ + if(! param$0) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + var l = param$0[2], match = param$0[1], b = match[2], a = match[1]; + if(0 === caml_compare(a, x)) return b; + param$0 = l; + } + } + function assoc_opt(x, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var l = param$0[2], match = param$0[1], b = match[2], a = match[1]; + if(0 === caml_compare(a, x)) return [0, b]; + param$0 = l; + } + } + function assq(x, param){ + var param$0 = param; + for(;;){ + if(! param$0) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + var l = param$0[2], match = param$0[1], b = match[2], a = match[1]; + if(a === x) return b; + param$0 = l; + } + } + function assq_opt(x, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var l = param$0[2], match = param$0[1], b = match[2], a = match[1]; + if(a === x) return [0, b]; + param$0 = l; + } + } + function mem_assoc(x, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var + l = param$0[2], + a = param$0[1][1], + _A_ = 0 === caml_compare(a, x) ? 1 : 0; + if(_A_) return _A_; + param$0 = l; + } + } + function mem_assq(x, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var l = param$0[2], a = param$0[1][1], _z_ = a === x ? 1 : 0; + if(_z_) return _z_; + param$0 = l; + } + } + function remove_assoc(x, param){ + if(! param) return 0; + var l = param[2], pair = param[1], a = pair[1]; + return 0 === caml_compare(a, x) ? l : [0, pair, remove_assoc(x, l)]; + } + function remove_assq(x, param){ + if(! param) return 0; + var l = param[2], pair = param[1], a = pair[1]; + return a === x ? l : [0, pair, remove_assq(x, l)]; + } + function find(p, param){ + var param$0 = param; + for(;;){ + if(! param$0) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + var l = param$0[2], x = param$0[1]; + if(caml_call1(p, x)) return x; + param$0 = l; + } + } + function find_opt(p, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var l = param$0[2], x = param$0[1]; + if(caml_call1(p, x)) return [0, x]; + param$0 = l; + } + } + function find_map(f, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var l = param$0[2], x = param$0[1], result = caml_call1(f, x); + if(result) return result; + param$0 = l; + } + } + function find_all(p){ + var accu = 0; + return function(param$0){ + var accu$0 = accu, param = param$0; + for(;;){ + if(! param) return rev(accu$0); + var l = param[2], x = param[1]; + if(caml_call1(p, x)){ + var accu$1 = [0, x, accu$0]; + accu$0 = accu$1; + param = l; + } + else + param = l; + }}; + } + function filteri(p, l){ + var i = 0, acc = 0, param = l; + for(;;){ + if(! param) return rev(acc); + var + l$0 = param[2], + x = param[1], + acc$0 = caml_call2(p, i, x) ? [0, x, acc] : acc, + i$0 = i + 1 | 0; + i = i$0; + acc = acc$0; + param = l$0; + } + } + function filter_map(f){ + var accu = 0; + return function(param$0){ + var accu$0 = accu, param = param$0; + for(;;){ + if(! param) return rev(accu$0); + var l = param[2], x = param[1], match = caml_call1(f, x); + if(match){ + var v = match[1], accu$1 = [0, v, accu$0]; + accu$0 = accu$1; + param = l; + } + else + param = l; + }}; + } + function concat_map(f, l){ + var acc = 0, param = l; + for(;;){ + if(! param) return rev(acc); + var + l$0 = param[2], + x = param[1], + xs = caml_call1(f, x), + acc$0 = rev_append(xs, acc); + acc = acc$0; + param = l$0; + } + } + function fold_left_map(f, accu, l){ + var accu$0 = accu, l_accu = 0, param = l; + for(;;){ + if(! param) return [0, accu$0, rev(l_accu)]; + var + l$0 = param[2], + x = param[1], + match = caml_call2(f, accu$0, x), + x$0 = match[2], + accu$1 = match[1], + l_accu$0 = [0, x$0, l_accu]; + accu$0 = accu$1; + l_accu = l_accu$0; + param = l$0; + } + } + function partition(p, l){ + var yes = 0, no = 0, param = l; + for(;;){ + if(! param){var _y_ = rev(no); return [0, rev(yes), _y_];} + var l$0 = param[2], x = param[1]; + if(caml_call1(p, x)){ + var yes$0 = [0, x, yes]; + yes = yes$0; + param = l$0; + } + else{var no$0 = [0, x, no]; no = no$0; param = l$0;} + } + } + function partition_map(p, l){ + var left = 0, right = 0, param = l; + for(;;){ + if(! param){var _x_ = rev(right); return [0, rev(left), _x_];} + var l$0 = param[2], x = param[1], match = caml_call1(p, x); + if(0 === match[0]){ + var v = match[1], left$0 = [0, v, left]; + left = left$0; + param = l$0; + } + else{ + var v$0 = match[1], right$0 = [0, v$0, right]; + right = right$0; + param = l$0; + } + } + } + function split(param){ + if(! param) return _b_; + var + l = param[2], + match = param[1], + y = match[2], + x = match[1], + match$0 = split(l), + ry = match$0[2], + rx = match$0[1]; + return [0, [0, x, rx], [0, y, ry]]; + } + function combine(l1, l2){ + if(l1){ + if(l2){ + var l2$0 = l2[2], a2 = l2[1], l1$0 = l1[2], a1 = l1[1]; + return [0, [0, a1, a2], combine(l1$0, l2$0)]; + } + } + else if(! l2) return 0; + return caml_call1(Stdlib[1], cst_List_combine); + } + function merge(cmp, l1, l2){ + if(! l1) return l2; + if(! l2) return l1; + var t2 = l2[2], h2 = l2[1], t1 = l1[2], h1 = l1[1]; + return 0 < caml_call2(cmp, h1, h2) + ? [0, h2, merge(cmp, l1, t2)] + : [0, h1, merge(cmp, t1, l2)]; + } + function stable_sort(cmp, l){ + function sort(n, l){ + if(2 === n){ + if(l){ + var match = l[2]; + if(match){ + var + tl = match[2], + x2 = match[1], + x1 = l[1], + s = + 0 < caml_call2(cmp, x1, x2) + ? [0, x2, [0, x1, 0]] + : [0, x1, [0, x2, 0]]; + return [0, s, tl]; + } + } + } + else if(3 === n && l){ + var _w_ = l[2]; + if(_w_){ + var match$2 = _w_[2]; + if(match$2){ + var + tl$1 = match$2[2], + x3 = match$2[1], + x2$0 = _w_[1], + x1$0 = l[1], + s$0 = + 0 < caml_call2(cmp, x1$0, x2$0) + ? 0 + < caml_call2(cmp, x1$0, x3) + ? 0 + < caml_call2(cmp, x2$0, x3) + ? [0, x3, [0, x2$0, [0, x1$0, 0]]] + : [0, x2$0, [0, x3, [0, x1$0, 0]]] + : [0, x2$0, [0, x1$0, [0, x3, 0]]] + : 0 + < caml_call2(cmp, x2$0, x3) + ? 0 + < caml_call2(cmp, x1$0, x3) + ? [0, x3, [0, x1$0, [0, x2$0, 0]]] + : [0, x1$0, [0, x3, [0, x2$0, 0]]] + : [0, x1$0, [0, x2$0, [0, x3, 0]]]; + return [0, s$0, tl$1]; + } + } + } + var + n1 = n >> 1, + n2 = n - n1 | 0, + match$0 = rev_sort(n1, l), + l2$0 = match$0[2], + s1 = match$0[1], + match$1 = rev_sort(n2, l2$0), + tl$0 = match$1[2], + s2 = match$1[1], + l1 = s1, + l2 = s2, + accu = 0; + for(;;){ + if(l1){ + if(l2){ + var t2 = l2[2], h2 = l2[1], t1 = l1[2], h1 = l1[1]; + if(0 < caml_call2(cmp, h1, h2)){ + var accu$0 = [0, h1, accu]; + l1 = t1; + accu = accu$0; + continue; + } + var accu$1 = [0, h2, accu]; + l2 = t2; + accu = accu$1; + continue; + } + var _v_ = rev_append(l1, accu); + } + else + var _v_ = rev_append(l2, accu); + return [0, _v_, tl$0]; + } + } + function rev_sort(n, l){ + if(2 === n){ + if(l){ + var match = l[2]; + if(match){ + var + tl = match[2], + x2 = match[1], + x1 = l[1], + s = + 0 < caml_call2(cmp, x1, x2) + ? [0, x1, [0, x2, 0]] + : [0, x2, [0, x1, 0]]; + return [0, s, tl]; + } + } + } + else if(3 === n && l){ + var _u_ = l[2]; + if(_u_){ + var match$2 = _u_[2]; + if(match$2){ + var + tl$1 = match$2[2], + x3 = match$2[1], + x2$0 = _u_[1], + x1$0 = l[1], + s$0 = + 0 < caml_call2(cmp, x1$0, x2$0) + ? 0 + < caml_call2(cmp, x2$0, x3) + ? [0, x1$0, [0, x2$0, [0, x3, 0]]] + : 0 + < caml_call2(cmp, x1$0, x3) + ? [0, x1$0, [0, x3, [0, x2$0, 0]]] + : [0, x3, [0, x1$0, [0, x2$0, 0]]] + : 0 + < caml_call2(cmp, x1$0, x3) + ? [0, x2$0, [0, x1$0, [0, x3, 0]]] + : 0 + < caml_call2(cmp, x2$0, x3) + ? [0, x2$0, [0, x3, [0, x1$0, 0]]] + : [0, x3, [0, x2$0, [0, x1$0, 0]]]; + return [0, s$0, tl$1]; + } + } + } + var + n1 = n >> 1, + n2 = n - n1 | 0, + match$0 = sort(n1, l), + l2$0 = match$0[2], + s1 = match$0[1], + match$1 = sort(n2, l2$0), + tl$0 = match$1[2], + s2 = match$1[1], + l1 = s1, + l2 = s2, + accu = 0; + for(;;){ + if(l1){ + if(l2){ + var t2 = l2[2], h2 = l2[1], t1 = l1[2], h1 = l1[1]; + if(0 < caml_call2(cmp, h1, h2)){ + var accu$0 = [0, h2, accu]; + l2 = t2; + accu = accu$0; + continue; + } + var accu$1 = [0, h1, accu]; + l1 = t1; + accu = accu$1; + continue; + } + var _t_ = rev_append(l1, accu); + } + else + var _t_ = rev_append(l2, accu); + return [0, _t_, tl$0]; + } + } + var len = length(l); + return 2 <= len ? sort(len, l)[1] : l; + } + function sort_uniq(cmp, l){ + function sort(n, l){ + if(2 === n){ + if(l){ + var match = l[2]; + if(match){ + var + tl = match[2], + x2 = match[1], + x1 = l[1], + c$0 = caml_call2(cmp, x1, x2), + s = + 0 === c$0 + ? [0, x1, 0] + : 0 <= c$0 ? [0, x2, [0, x1, 0]] : [0, x1, [0, x2, 0]]; + return [0, s, tl]; + } + } + } + else if(3 === n && l){ + var _n_ = l[2]; + if(_n_){ + var match$2 = _n_[2]; + if(match$2){ + var + tl$1 = match$2[2], + x3 = match$2[1], + x2$0 = _n_[1], + x1$0 = l[1], + c$1 = caml_call2(cmp, x1$0, x2$0); + if(0 === c$1) + var + c$2 = caml_call2(cmp, x2$0, x3), + _o_ = + 0 === c$2 + ? [0, x2$0, 0] + : 0 <= c$2 ? [0, x3, [0, x2$0, 0]] : [0, x2$0, [0, x3, 0]], + s$0 = _o_; + else if(0 <= c$1){ + var c$3 = caml_call2(cmp, x1$0, x3); + if(0 === c$3) + var _p_ = [0, x2$0, [0, x1$0, 0]]; + else if(0 <= c$3) + var + c$4 = caml_call2(cmp, x2$0, x3), + _q_ = + 0 === c$4 + ? [0, x2$0, [0, x1$0, 0]] + : 0 + <= c$4 + ? [0, x3, [0, x2$0, [0, x1$0, 0]]] + : [0, x2$0, [0, x3, [0, x1$0, 0]]], + _p_ = _q_; + else + var _p_ = [0, x2$0, [0, x1$0, [0, x3, 0]]]; + var s$0 = _p_; + } + else{ + var c$5 = caml_call2(cmp, x2$0, x3); + if(0 === c$5) + var _r_ = [0, x1$0, [0, x2$0, 0]]; + else if(0 <= c$5) + var + c$6 = caml_call2(cmp, x1$0, x3), + _s_ = + 0 === c$6 + ? [0, x1$0, [0, x2$0, 0]] + : 0 + <= c$6 + ? [0, x3, [0, x1$0, [0, x2$0, 0]]] + : [0, x1$0, [0, x3, [0, x2$0, 0]]], + _r_ = _s_; + else + var _r_ = [0, x1$0, [0, x2$0, [0, x3, 0]]]; + var s$0 = _r_; + } + return [0, s$0, tl$1]; + } + } + } + var + n1 = n >> 1, + n2 = n - n1 | 0, + match$0 = rev_sort(n1, l), + l2$0 = match$0[2], + s1 = match$0[1], + match$1 = rev_sort(n2, l2$0), + tl$0 = match$1[2], + s2 = match$1[1], + l1 = s1, + l2 = s2, + accu = 0; + for(;;){ + if(l1){ + if(l2){ + var + t2 = l2[2], + h2 = l2[1], + t1 = l1[2], + h1 = l1[1], + c = caml_call2(cmp, h1, h2); + if(0 === c){ + var accu$0 = [0, h1, accu]; + l1 = t1; + l2 = t2; + accu = accu$0; + continue; + } + if(0 < c){ + var accu$1 = [0, h1, accu]; + l1 = t1; + accu = accu$1; + continue; + } + var accu$2 = [0, h2, accu]; + l2 = t2; + accu = accu$2; + continue; + } + var _m_ = rev_append(l1, accu); + } + else + var _m_ = rev_append(l2, accu); + return [0, _m_, tl$0]; + } + } + function rev_sort(n, l){ + if(2 === n){ + if(l){ + var match = l[2]; + if(match){ + var + tl = match[2], + x2 = match[1], + x1 = l[1], + c$0 = caml_call2(cmp, x1, x2), + s = + 0 === c$0 + ? [0, x1, 0] + : 0 < c$0 ? [0, x1, [0, x2, 0]] : [0, x2, [0, x1, 0]]; + return [0, s, tl]; + } + } + } + else if(3 === n && l){ + var _g_ = l[2]; + if(_g_){ + var match$2 = _g_[2]; + if(match$2){ + var + tl$1 = match$2[2], + x3 = match$2[1], + x2$0 = _g_[1], + x1$0 = l[1], + c$1 = caml_call2(cmp, x1$0, x2$0); + if(0 === c$1) + var + c$2 = caml_call2(cmp, x2$0, x3), + _h_ = + 0 === c$2 + ? [0, x2$0, 0] + : 0 < c$2 ? [0, x2$0, [0, x3, 0]] : [0, x3, [0, x2$0, 0]], + s$0 = _h_; + else if(0 < c$1){ + var c$3 = caml_call2(cmp, x2$0, x3); + if(0 === c$3) + var _i_ = [0, x1$0, [0, x2$0, 0]]; + else if(0 < c$3) + var _i_ = [0, x1$0, [0, x2$0, [0, x3, 0]]]; + else + var + c$4 = caml_call2(cmp, x1$0, x3), + _j_ = + 0 === c$4 + ? [0, x1$0, [0, x2$0, 0]] + : 0 + < c$4 + ? [0, x1$0, [0, x3, [0, x2$0, 0]]] + : [0, x3, [0, x1$0, [0, x2$0, 0]]], + _i_ = _j_; + var s$0 = _i_; + } + else{ + var c$5 = caml_call2(cmp, x1$0, x3); + if(0 === c$5) + var _k_ = [0, x2$0, [0, x1$0, 0]]; + else if(0 < c$5) + var _k_ = [0, x2$0, [0, x1$0, [0, x3, 0]]]; + else + var + c$6 = caml_call2(cmp, x2$0, x3), + _l_ = + 0 === c$6 + ? [0, x2$0, [0, x1$0, 0]] + : 0 + < c$6 + ? [0, x2$0, [0, x3, [0, x1$0, 0]]] + : [0, x3, [0, x2$0, [0, x1$0, 0]]], + _k_ = _l_; + var s$0 = _k_; + } + return [0, s$0, tl$1]; + } + } + } + var + n1 = n >> 1, + n2 = n - n1 | 0, + match$0 = sort(n1, l), + l2$0 = match$0[2], + s1 = match$0[1], + match$1 = sort(n2, l2$0), + tl$0 = match$1[2], + s2 = match$1[1], + l1 = s1, + l2 = s2, + accu = 0; + for(;;){ + if(l1){ + if(l2){ + var + t2 = l2[2], + h2 = l2[1], + t1 = l1[2], + h1 = l1[1], + c = caml_call2(cmp, h1, h2); + if(0 === c){ + var accu$0 = [0, h1, accu]; + l1 = t1; + l2 = t2; + accu = accu$0; + continue; + } + if(0 <= c){ + var accu$1 = [0, h2, accu]; + l2 = t2; + accu = accu$1; + continue; + } + var accu$2 = [0, h1, accu]; + l1 = t1; + accu = accu$2; + continue; + } + var _f_ = rev_append(l1, accu); + } + else + var _f_ = rev_append(l2, accu); + return [0, _f_, tl$0]; + } + } + var len = length(l); + return 2 <= len ? sort(len, l)[1] : l; + } + function compare_lengths(l1, l2){ + var l1$0 = l1, l2$0 = l2; + for(;;){ + if(! l1$0) return l2$0 ? -1 : 0; + if(! l2$0) return 1; + var l2$1 = l2$0[2], l1$1 = l1$0[2]; + l1$0 = l1$1; + l2$0 = l2$1; + } + } + function compare_length_with(l, n){ + var l$0 = l, n$0 = n; + for(;;){ + if(! l$0) return 0 === n$0 ? 0 : 0 < n$0 ? -1 : 1; + var l$1 = l$0[2]; + if(0 >= n$0) return 1; + var n$1 = n$0 - 1 | 0; + l$0 = l$1; + n$0 = n$1; + } + } + function equal(eq, l1, l2){ + var l1$0 = l1, l2$0 = l2; + for(;;){ + if(l1$0){ + if(l2$0){ + var + l2$1 = l2$0[2], + a2 = l2$0[1], + l1$1 = l1$0[2], + a1 = l1$0[1], + _e_ = caml_call2(eq, a1, a2); + if(! _e_) return _e_; + l1$0 = l1$1; + l2$0 = l2$1; + continue; + } + } + else if(! l2$0) return 1; + return 0; + } + } + function compare(cmp, l1, l2){ + var l1$0 = l1, l2$0 = l2; + for(;;){ + if(! l1$0) return l2$0 ? -1 : 0; + var l1$1 = l1$0[2], a1 = l1$0[1]; + if(! l2$0) return 1; + var l2$1 = l2$0[2], a2 = l2$0[1], c = caml_call2(cmp, a1, a2); + if(0 !== c) return c; + l1$0 = l1$1; + l2$0 = l2$1; + } + } + function to_seq(l){ + function aux(l, param){ + if(! l) return 0; + var tail = l[2], x = l[1]; + return [0, x, function(_d_){return aux(tail, _d_);}]; + } + return function(_c_){return aux(l, _c_);}; + } + function of_seq(seq){ + function direct(depth, seq){ + if(0 === depth) + return rev + (caml_call3 + (Stdlib_Seq[11], + function(acc, x){return [0, x, acc];}, + 0, + seq)); + var match = caml_call1(seq, 0); + if(! match) return 0; + var next = match[2], x = match[1]; + return [0, x, direct(depth - 1 | 0, next)]; + } + return direct(500, seq); + } + var + Stdlib_List = + [0, + length, + compare_lengths, + compare_length_with, + cons, + hd, + tl, + nth, + nth_opt, + rev, + init, + append, + rev_append, + flatten, + flatten, + equal, + compare, + iter, + iteri, + map, + mapi, + rev_map, + filter_map, + concat_map, + fold_left_map, + fold_left, + fold_right, + iter2, + map2, + rev_map2, + fold_left2, + fold_right2, + for_all, + exists, + for_all2, + exists2, + mem, + memq, + find, + find_opt, + find_map, + find_all, + find_all, + filteri, + partition, + partition_map, + assoc, + assoc_opt, + assq, + assq_opt, + mem_assoc, + mem_assq, + remove_assoc, + remove_assq, + split, + combine, + stable_sort, + stable_sort, + stable_sort, + sort_uniq, + merge, + to_seq, + of_seq]; + runtime.caml_register_global(18, Stdlib_List, "Stdlib__List"); + return; + } + (globalThis)); + +//# 2793 "../.js/default/stdlib/stdlib.cma.js" +(function(globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function abs(x){return 0 <= x ? x : - x | 0;} + function lognot(x){return x ^ -1;} + function equal(_b_, _a_){return _b_ === _a_ ? 1 : 0;} + var compare = runtime.caml_int_compare; + function min(x, y){return x <= y ? x : y;} + function max(x, y){return y <= x ? x : y;} + function to_string(x){return "" + x;} + var + Stdlib_Int = + [0, + 0, + 1, + -1, + abs, + 2147483647, + -2147483648, + lognot, + equal, + compare, + min, + max, + to_string]; + runtime.caml_register_global(1, Stdlib_Int, "Stdlib__Int"); + return; + } + (globalThis)); + +//# 2825 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + caml_blit_bytes = runtime.caml_blit_bytes, + caml_bswap16 = runtime.caml_bswap16, + caml_bytes_get = runtime.caml_bytes_get, + caml_bytes_get16 = runtime.caml_bytes_get16, + caml_bytes_get32 = runtime.caml_bytes_get32, + caml_bytes_get64 = runtime.caml_bytes_get64, + caml_bytes_of_string = runtime.caml_bytes_of_string, + caml_bytes_set = runtime.caml_bytes_set, + caml_bytes_set16 = runtime.caml_bytes_set16, + caml_bytes_set32 = runtime.caml_bytes_set32, + caml_bytes_set64 = runtime.caml_bytes_set64, + caml_bytes_unsafe_get = runtime.caml_bytes_unsafe_get, + caml_bytes_unsafe_set = runtime.caml_bytes_unsafe_set, + caml_create_bytes = runtime.caml_create_bytes, + caml_fill_bytes = runtime.caml_fill_bytes, + caml_int32_bswap = runtime.caml_int32_bswap, + caml_int64_bswap = runtime.caml_int64_bswap, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace, + caml_ml_bytes_length = runtime.caml_ml_bytes_length, + caml_string_of_bytes = runtime.caml_string_of_bytes, + caml_wrap_exception = runtime.caml_wrap_exception; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + Stdlib = global_data.Stdlib, + Stdlib_Sys = global_data.Stdlib__Sys, + Stdlib_Int = global_data.Stdlib__Int, + Stdlib_Seq = global_data.Stdlib__Seq, + Stdlib_Char = global_data.Stdlib__Char; + function make(n, c){ + var s = caml_create_bytes(n); + caml_fill_bytes(s, 0, n, c); + return s; + } + function init(n, f){ + var s = caml_create_bytes(n), _ad_ = n - 1 | 0, _ac_ = 0; + if(_ad_ >= 0){ + var i = _ac_; + for(;;){ + caml_bytes_unsafe_set(s, i, caml_call1(f, i)); + var _ae_ = i + 1 | 0; + if(_ad_ === i) break; + i = _ae_; + } + } + return s; + } + var + empty = caml_create_bytes(0), + cst_String_sub_Bytes_sub = "String.sub / Bytes.sub", + cst_Bytes_extend = "Bytes.extend", + cst_String_fill_Bytes_fill = "String.fill / Bytes.fill", + cst_Bytes_blit = "Bytes.blit", + cst_String_blit_Bytes_blit_str = "String.blit / Bytes.blit_string", + cst_Bytes_concat = "Bytes.concat", + cst_String_index_from_Bytes_in = "String.index_from / Bytes.index_from", + cst_String_index_from_opt_Byte = + "String.index_from_opt / Bytes.index_from_opt", + cst_String_rindex_from_Bytes_r = "String.rindex_from / Bytes.rindex_from", + cst_String_rindex_from_opt_Byt = + "String.rindex_from_opt / Bytes.rindex_from_opt", + cst_String_contains_from_Bytes = + "String.contains_from / Bytes.contains_from", + cst_String_rcontains_from_Byte = + "String.rcontains_from / Bytes.rcontains_from"; + function copy(s){ + var len = caml_ml_bytes_length(s), r = caml_create_bytes(len); + caml_blit_bytes(s, 0, r, 0, len); + return r; + } + function to_string(b){return caml_string_of_bytes(copy(b));} + function of_string(s){return copy(caml_bytes_of_string(s));} + function sub(s, ofs, len){ + if(0 <= ofs && 0 <= len && (caml_ml_bytes_length(s) - len | 0) >= ofs){ + var r = caml_create_bytes(len); + caml_blit_bytes(s, ofs, r, 0, len); + return r; + } + return caml_call1(Stdlib[1], cst_String_sub_Bytes_sub); + } + function sub_string(b, ofs, len){ + return caml_string_of_bytes(sub(b, ofs, len)); + } + function symbol(a, b){ + var c = a + b | 0, _ab_ = b < 0 ? 1 : 0, match = c < 0 ? 1 : 0; + a: + { + if(a < 0){if(_ab_ && ! match) break a;} else if(! _ab_ && match) break a; + return c; + } + return caml_call1(Stdlib[1], cst_Bytes_extend); + } + function extend(s, left, right){ + var + len = symbol(symbol(caml_ml_bytes_length(s), left), right), + r = caml_create_bytes(len); + if(0 <= left) + var dstoff = left, srcoff = 0; + else + var dstoff = 0, srcoff = - left | 0; + var + cpylen = + caml_call2 + (Stdlib_Int[10], + caml_ml_bytes_length(s) - srcoff | 0, + len - dstoff | 0); + if(0 < cpylen) caml_blit_bytes(s, srcoff, r, dstoff, cpylen); + return r; + } + function fill(s, ofs, len, c){ + if(0 <= ofs && 0 <= len && (caml_ml_bytes_length(s) - len | 0) >= ofs) + return caml_fill_bytes(s, ofs, len, c); + return caml_call1(Stdlib[1], cst_String_fill_Bytes_fill); + } + function blit(s1, ofs1, s2, ofs2, len){ + if + (0 <= len + && + 0 <= ofs1 + && + (caml_ml_bytes_length(s1) - len | 0) >= ofs1 + && 0 <= ofs2 && (caml_ml_bytes_length(s2) - len | 0) >= ofs2) + return caml_blit_bytes(s1, ofs1, s2, ofs2, len); + return caml_call1(Stdlib[1], cst_Bytes_blit); + } + function blit_string(s1, ofs1, s2, ofs2, len){ + if + (0 <= len + && + 0 <= ofs1 + && + (runtime.caml_ml_string_length(s1) - len | 0) >= ofs1 + && 0 <= ofs2 && (caml_ml_bytes_length(s2) - len | 0) >= ofs2) + return runtime.caml_blit_string(s1, ofs1, s2, ofs2, len); + return caml_call1(Stdlib[1], cst_String_blit_Bytes_blit_str); + } + function iter(f, a){ + var _$_ = caml_ml_bytes_length(a) - 1 | 0, ___ = 0; + if(_$_ >= 0){ + var i = ___; + for(;;){ + caml_call1(f, caml_bytes_unsafe_get(a, i)); + var _aa_ = i + 1 | 0; + if(_$_ === i) break; + i = _aa_; + } + } + return 0; + } + function iteri(f, a){ + var _Y_ = caml_ml_bytes_length(a) - 1 | 0, _X_ = 0; + if(_Y_ >= 0){ + var i = _X_; + for(;;){ + caml_call2(f, i, caml_bytes_unsafe_get(a, i)); + var _Z_ = i + 1 | 0; + if(_Y_ === i) break; + i = _Z_; + } + } + return 0; + } + function concat(sep, l){ + if(! l) return empty; + var seplen = caml_ml_bytes_length(sep); + a: + { + b: + { + var acc = 0, param = l, pos$1 = 0; + for(;;){ + if(! param) break; + var hd = param[1]; + if(! param[2]) break b; + var + tl = param[2], + x = (caml_ml_bytes_length(hd) + seplen | 0) + acc | 0, + acc$0 = acc <= x ? x : caml_call1(Stdlib[1], cst_Bytes_concat); + acc = acc$0; + param = tl; + } + var _W_ = acc; + break a; + } + var _W_ = caml_ml_bytes_length(hd) + acc | 0; + } + var dst = caml_create_bytes(_W_), pos = pos$1, param$0 = l; + for(;;){ + if(! param$0) return dst; + var hd$0 = param$0[1]; + if(! param$0[2]){ + caml_blit_bytes(hd$0, 0, dst, pos, caml_ml_bytes_length(hd$0)); + return dst; + } + var tl$0 = param$0[2]; + caml_blit_bytes(hd$0, 0, dst, pos, caml_ml_bytes_length(hd$0)); + caml_blit_bytes + (sep, 0, dst, pos + caml_ml_bytes_length(hd$0) | 0, seplen); + var pos$0 = (pos + caml_ml_bytes_length(hd$0) | 0) + seplen | 0; + pos = pos$0; + param$0 = tl$0; + } + } + function cat(s1, s2){ + var + l1 = caml_ml_bytes_length(s1), + l2 = caml_ml_bytes_length(s2), + r = caml_create_bytes(l1 + l2 | 0); + caml_blit_bytes(s1, 0, r, 0, l1); + caml_blit_bytes(s2, 0, r, l1, l2); + return r; + } + function is_space(param){ + var _V_ = param - 9 | 0; + a: + { + if(4 < _V_ >>> 0){if(23 !== _V_) break a;} else if(2 === _V_) break a; + return 1; + } + return 0; + } + function trim(s){ + var len = caml_ml_bytes_length(s), i = [0, 0]; + for(;;){ + if(i[1] >= len) break; + if(! is_space(caml_bytes_unsafe_get(s, i[1]))) break; + i[1]++; + } + var j = [0, len - 1 | 0]; + for(;;){ + if(i[1] <= j[1] && is_space(caml_bytes_unsafe_get(s, j[1]))){j[1]--; continue;} + return i[1] <= j[1] ? sub(s, i[1], (j[1] - i[1] | 0) + 1 | 0) : empty; + } + } + function escaped(s){ + var n = [0, 0], _O_ = caml_ml_bytes_length(s) - 1 | 0, _N_ = 0; + if(_O_ >= 0){ + var i$0 = _N_; + for(;;){ + var match = caml_bytes_unsafe_get(s, i$0); + a: + { + b: + { + c: + { + if(32 <= match){ + var _S_ = match - 34 | 0; + if(58 < _S_ >>> 0){ + if(93 <= _S_) break c; + } + else if(56 < _S_ - 1 >>> 0) break b; + var _T_ = 1; + break a; + } + if(11 <= match){ + if(13 === match) break b; + } + else if(8 <= match) break b; + } + var _T_ = 4; + break a; + } + var _T_ = 2; + } + n[1] = n[1] + _T_ | 0; + var _U_ = i$0 + 1 | 0; + if(_O_ === i$0) break; + i$0 = _U_; + } + } + if(n[1] === caml_ml_bytes_length(s)) return copy(s); + var s$0 = caml_create_bytes(n[1]); + n[1] = 0; + var _Q_ = caml_ml_bytes_length(s) - 1 | 0, _P_ = 0; + if(_Q_ >= 0){ + var i = _P_; + for(;;){ + var c = caml_bytes_unsafe_get(s, i); + a: + { + b: + { + c: + { + if(35 <= c){ + if(92 !== c){if(127 <= c) break c; break b;} + } + else{ + if(32 > c){ + if(14 <= c) break c; + switch(c){ + case 8: + caml_bytes_unsafe_set(s$0, n[1], 92); + n[1]++; + caml_bytes_unsafe_set(s$0, n[1], 98); + break a; + case 9: + caml_bytes_unsafe_set(s$0, n[1], 92); + n[1]++; + caml_bytes_unsafe_set(s$0, n[1], 116); + break a; + case 10: + caml_bytes_unsafe_set(s$0, n[1], 92); + n[1]++; + caml_bytes_unsafe_set(s$0, n[1], 110); + break a; + case 13: + caml_bytes_unsafe_set(s$0, n[1], 92); + n[1]++; + caml_bytes_unsafe_set(s$0, n[1], 114); + break a; + default: break c; + } + } + if(34 > c) break b; + } + caml_bytes_unsafe_set(s$0, n[1], 92); + n[1]++; + caml_bytes_unsafe_set(s$0, n[1], c); + break a; + } + caml_bytes_unsafe_set(s$0, n[1], 92); + n[1]++; + caml_bytes_unsafe_set(s$0, n[1], 48 + (c / 100 | 0) | 0); + n[1]++; + caml_bytes_unsafe_set(s$0, n[1], 48 + ((c / 10 | 0) % 10 | 0) | 0); + n[1]++; + caml_bytes_unsafe_set(s$0, n[1], 48 + (c % 10 | 0) | 0); + break a; + } + caml_bytes_unsafe_set(s$0, n[1], c); + } + n[1]++; + var _R_ = i + 1 | 0; + if(_Q_ === i) break; + i = _R_; + } + } + return s$0; + } + function map(f, s){ + var l = caml_ml_bytes_length(s); + if(0 === l) return s; + var r = caml_create_bytes(l), _L_ = l - 1 | 0, _K_ = 0; + if(_L_ >= 0){ + var i = _K_; + for(;;){ + caml_bytes_unsafe_set(r, i, caml_call1(f, caml_bytes_unsafe_get(s, i))); + var _M_ = i + 1 | 0; + if(_L_ === i) break; + i = _M_; + } + } + return r; + } + function mapi(f, s){ + var l = caml_ml_bytes_length(s); + if(0 === l) return s; + var r = caml_create_bytes(l), _I_ = l - 1 | 0, _H_ = 0; + if(_I_ >= 0){ + var i = _H_; + for(;;){ + caml_bytes_unsafe_set + (r, i, caml_call2(f, i, caml_bytes_unsafe_get(s, i))); + var _J_ = i + 1 | 0; + if(_I_ === i) break; + i = _J_; + } + } + return r; + } + function fold_left(f, x, a){ + var r = [0, x], _F_ = caml_ml_bytes_length(a) - 1 | 0, _E_ = 0; + if(_F_ >= 0){ + var i = _E_; + for(;;){ + r[1] = caml_call2(f, r[1], caml_bytes_unsafe_get(a, i)); + var _G_ = i + 1 | 0; + if(_F_ === i) break; + i = _G_; + } + } + return r[1]; + } + function fold_right(f, a, x){ + var r = [0, x], _C_ = caml_ml_bytes_length(a) - 1 | 0; + if(_C_ >= 0){ + var i = _C_; + for(;;){ + r[1] = caml_call2(f, caml_bytes_unsafe_get(a, i), r[1]); + var _D_ = i - 1 | 0; + if(0 === i) break; + i = _D_; + } + } + return r[1]; + } + function exists(p, s){ + var n = caml_ml_bytes_length(s), i = 0; + for(;;){ + if(i === n) return 0; + if(caml_call1(p, caml_bytes_unsafe_get(s, i))) return 1; + var i$0 = i + 1 | 0; + i = i$0; + } + } + function for_all(p, s){ + var n = caml_ml_bytes_length(s), i = 0; + for(;;){ + if(i === n) return 1; + if(! caml_call1(p, caml_bytes_unsafe_get(s, i))) return 0; + var i$0 = i + 1 | 0; + i = i$0; + } + } + function uppercase_ascii(s){return map(Stdlib_Char[6], s);} + function lowercase_ascii(s){return map(Stdlib_Char[5], s);} + function apply1(f, s){ + if(0 === caml_ml_bytes_length(s)) return s; + var r = copy(s); + caml_bytes_unsafe_set(r, 0, caml_call1(f, caml_bytes_unsafe_get(s, 0))); + return r; + } + function capitalize_ascii(s){return apply1(Stdlib_Char[6], s);} + function uncapitalize_ascii(s){return apply1(Stdlib_Char[5], s);} + function starts_with(prefix, s){ + var + len_s = caml_ml_bytes_length(s), + len_pre = caml_ml_bytes_length(prefix), + _B_ = len_pre <= len_s ? 1 : 0; + if(! _B_) return _B_; + var i = 0; + for(;;){ + if(i === len_pre) return 1; + if(caml_bytes_unsafe_get(s, i) !== caml_bytes_unsafe_get(prefix, i)) + return 0; + var i$0 = i + 1 | 0; + i = i$0; + } + } + function ends_with(suffix, s){ + var + len_s = caml_ml_bytes_length(s), + len_suf = caml_ml_bytes_length(suffix), + diff = len_s - len_suf | 0, + _A_ = 0 <= diff ? 1 : 0; + if(! _A_) return _A_; + var i = 0; + for(;;){ + if(i === len_suf) return 1; + if + (caml_bytes_unsafe_get(s, diff + i | 0) + !== caml_bytes_unsafe_get(suffix, i)) + return 0; + var i$0 = i + 1 | 0; + i = i$0; + } + } + function index_rec(s, lim, i, c){ + var i$0 = i; + for(;;){ + if(lim <= i$0) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + if(caml_bytes_unsafe_get(s, i$0) === c) return i$0; + var i$1 = i$0 + 1 | 0; + i$0 = i$1; + } + } + function index(s, c){return index_rec(s, caml_ml_bytes_length(s), 0, c);} + function index_rec_opt(s, lim, i, c){ + var i$0 = i; + for(;;){ + if(lim <= i$0) return 0; + if(caml_bytes_unsafe_get(s, i$0) === c) return [0, i$0]; + var i$1 = i$0 + 1 | 0; + i$0 = i$1; + } + } + function index_opt(s, c){ + return index_rec_opt(s, caml_ml_bytes_length(s), 0, c); + } + function index_from(s, i, c){ + var l = caml_ml_bytes_length(s); + if(0 <= i && l >= i) return index_rec(s, l, i, c); + return caml_call1(Stdlib[1], cst_String_index_from_Bytes_in); + } + function index_from_opt(s, i, c){ + var l = caml_ml_bytes_length(s); + if(0 <= i && l >= i) return index_rec_opt(s, l, i, c); + return caml_call1(Stdlib[1], cst_String_index_from_opt_Byte); + } + function rindex_rec(s, i, c){ + var i$0 = i; + for(;;){ + if(0 > i$0) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + if(caml_bytes_unsafe_get(s, i$0) === c) return i$0; + var i$1 = i$0 - 1 | 0; + i$0 = i$1; + } + } + function rindex(s, c){ + return rindex_rec(s, caml_ml_bytes_length(s) - 1 | 0, c); + } + function rindex_from(s, i, c){ + if(-1 <= i && caml_ml_bytes_length(s) > i) return rindex_rec(s, i, c); + return caml_call1(Stdlib[1], cst_String_rindex_from_Bytes_r); + } + function rindex_rec_opt(s, i, c){ + var i$0 = i; + for(;;){ + if(0 > i$0) return 0; + if(caml_bytes_unsafe_get(s, i$0) === c) return [0, i$0]; + var i$1 = i$0 - 1 | 0; + i$0 = i$1; + } + } + function rindex_opt(s, c){ + return rindex_rec_opt(s, caml_ml_bytes_length(s) - 1 | 0, c); + } + function rindex_from_opt(s, i, c){ + if(-1 <= i && caml_ml_bytes_length(s) > i) return rindex_rec_opt(s, i, c); + return caml_call1(Stdlib[1], cst_String_rindex_from_opt_Byt); + } + function contains_from(s, i, c){ + var l = caml_ml_bytes_length(s); + if(0 <= i && l >= i) + try{index_rec(s, l, i, c); var _y_ = 1; return _y_;} + catch(_z_){ + var _x_ = caml_wrap_exception(_z_); + if(_x_ === Stdlib[8]) return 0; + throw caml_maybe_attach_backtrace(_x_, 0); + } + return caml_call1(Stdlib[1], cst_String_contains_from_Bytes); + } + function contains(s, c){return contains_from(s, 0, c);} + function rcontains_from(s, i, c){ + if(0 <= i && caml_ml_bytes_length(s) > i) + try{rindex_rec(s, i, c); var _v_ = 1; return _v_;} + catch(_w_){ + var _u_ = caml_wrap_exception(_w_); + if(_u_ === Stdlib[8]) return 0; + throw caml_maybe_attach_backtrace(_u_, 0); + } + return caml_call1(Stdlib[1], cst_String_rcontains_from_Byte); + } + var + compare = runtime.caml_bytes_compare, + cst_Bytes_of_seq_cannot_grow_b = "Bytes.of_seq: cannot grow bytes"; + function split_on_char(sep, s){ + var + r = [0, 0], + j = [0, caml_ml_bytes_length(s)], + _q_ = caml_ml_bytes_length(s) - 1 | 0; + if(_q_ >= 0){ + var i = _q_; + for(;;){ + if(caml_bytes_unsafe_get(s, i) === sep){ + var _s_ = r[1]; + r[1] = [0, sub(s, i + 1 | 0, (j[1] - i | 0) - 1 | 0), _s_]; + j[1] = i; + } + var _t_ = i - 1 | 0; + if(0 === i) break; + i = _t_; + } + } + var _r_ = r[1]; + return [0, sub(s, 0, j[1]), _r_]; + } + function uppercase(s){return map(Stdlib_Char[4], s);} + function lowercase(s){return map(Stdlib_Char[3], s);} + function capitalize(s){return apply1(Stdlib_Char[4], s);} + function uncapitalize(s){return apply1(Stdlib_Char[3], s);} + function to_seq(s){ + function aux(i, param){ + if(i === caml_ml_bytes_length(s)) return 0; + var x = caml_bytes_get(s, i), _o_ = i + 1 | 0; + return [0, x, function(_p_){return aux(_o_, _p_);}]; + } + var _m_ = 0; + return function(_n_){return aux(_m_, _n_);}; + } + function to_seqi(s){ + function aux(i, param){ + if(i === caml_ml_bytes_length(s)) return 0; + var x = caml_bytes_get(s, i), _k_ = i + 1 | 0; + return [0, [0, i, x], function(_l_){return aux(_k_, _l_);}]; + } + var _i_ = 0; + return function(_j_){return aux(_i_, _j_);}; + } + function of_seq(i){ + var n = [0, 0], buf = [0, make(256, 0)]; + caml_call2 + (Stdlib_Seq[12], + function(c){ + if(n[1] === caml_ml_bytes_length(buf[1])){ + var + new_len = + caml_call2 + (Stdlib_Int[10], + 2 * caml_ml_bytes_length(buf[1]) | 0, + Stdlib_Sys[12]); + if(caml_ml_bytes_length(buf[1]) === new_len) + caml_call1(Stdlib[2], cst_Bytes_of_seq_cannot_grow_b); + var new_buf = make(new_len, 0); + blit(buf[1], 0, new_buf, 0, n[1]); + buf[1] = new_buf; + } + caml_bytes_set(buf[1], n[1], c); + n[1]++; + return 0; + }, + i); + return sub(buf[1], 0, n[1]); + } + function get_int8(b, i){ + var _g_ = Stdlib_Sys[10] - 8 | 0, _h_ = Stdlib_Sys[10] - 8 | 0; + return caml_bytes_get(b, i) << _h_ >> _g_; + } + function get_uint16_le(b, i){ + return Stdlib_Sys[11] + ? caml_bswap16(caml_bytes_get16(b, i)) + : caml_bytes_get16(b, i); + } + function get_uint16_be(b, i){ + return Stdlib_Sys[11] + ? caml_bytes_get16(b, i) + : caml_bswap16(caml_bytes_get16(b, i)); + } + function get_int16_ne(b, i){ + var _e_ = Stdlib_Sys[10] - 16 | 0, _f_ = Stdlib_Sys[10] - 16 | 0; + return caml_bytes_get16(b, i) << _f_ >> _e_; + } + function get_int16_le(b, i){ + var _c_ = Stdlib_Sys[10] - 16 | 0, _d_ = Stdlib_Sys[10] - 16 | 0; + return get_uint16_le(b, i) << _d_ >> _c_; + } + function get_int16_be(b, i){ + var _a_ = Stdlib_Sys[10] - 16 | 0, _b_ = Stdlib_Sys[10] - 16 | 0; + return get_uint16_be(b, i) << _b_ >> _a_; + } + function get_int32_le(b, i){ + return Stdlib_Sys[11] + ? caml_int32_bswap(caml_bytes_get32(b, i)) + : caml_bytes_get32(b, i); + } + function get_int32_be(b, i){ + return Stdlib_Sys[11] + ? caml_bytes_get32(b, i) + : caml_int32_bswap(caml_bytes_get32(b, i)); + } + function get_int64_le(b, i){ + return Stdlib_Sys[11] + ? caml_int64_bswap(caml_bytes_get64(b, i)) + : caml_bytes_get64(b, i); + } + function get_int64_be(b, i){ + return Stdlib_Sys[11] + ? caml_bytes_get64(b, i) + : caml_int64_bswap(caml_bytes_get64(b, i)); + } + function set_int16_le(b, i, x){ + return Stdlib_Sys[11] + ? caml_bytes_set16(b, i, caml_bswap16(x)) + : caml_bytes_set16(b, i, x); + } + function set_int16_be(b, i, x){ + return Stdlib_Sys[11] + ? caml_bytes_set16(b, i, x) + : caml_bytes_set16(b, i, caml_bswap16(x)); + } + function set_int32_le(b, i, x){ + return Stdlib_Sys[11] + ? caml_bytes_set32(b, i, caml_int32_bswap(x)) + : caml_bytes_set32(b, i, x); + } + function set_int32_be(b, i, x){ + return Stdlib_Sys[11] + ? caml_bytes_set32(b, i, x) + : caml_bytes_set32(b, i, caml_int32_bswap(x)); + } + function set_int64_le(b, i, x){ + return Stdlib_Sys[11] + ? caml_bytes_set64(b, i, caml_int64_bswap(x)) + : caml_bytes_set64(b, i, x); + } + function set_int64_be(b, i, x){ + return Stdlib_Sys[11] + ? caml_bytes_set64(b, i, x) + : caml_bytes_set64(b, i, caml_int64_bswap(x)); + } + var + set_uint8 = caml_bytes_set, + set_uint16_ne = caml_bytes_set16, + Stdlib_Bytes = + [0, + make, + init, + empty, + copy, + of_string, + to_string, + sub, + sub_string, + extend, + fill, + blit, + blit_string, + concat, + cat, + iter, + iteri, + map, + mapi, + fold_left, + fold_right, + for_all, + exists, + trim, + escaped, + index, + index_opt, + rindex, + rindex_opt, + index_from, + index_from_opt, + rindex_from, + rindex_from_opt, + contains, + contains_from, + rcontains_from, + uppercase, + lowercase, + capitalize, + uncapitalize, + uppercase_ascii, + lowercase_ascii, + capitalize_ascii, + uncapitalize_ascii, + compare, + runtime.caml_bytes_equal, + starts_with, + ends_with, + caml_string_of_bytes, + caml_bytes_of_string, + split_on_char, + to_seq, + to_seqi, + of_seq, + caml_bytes_get, + get_int8, + caml_bytes_get16, + get_uint16_be, + get_uint16_le, + get_int16_ne, + get_int16_be, + get_int16_le, + caml_bytes_get32, + get_int32_be, + get_int32_le, + caml_bytes_get64, + get_int64_be, + get_int64_le, + set_uint8, + caml_bytes_set, + set_uint16_ne, + set_int16_be, + set_int16_le, + caml_bytes_set16, + set_int16_be, + set_int16_le, + caml_bytes_set32, + set_int32_be, + set_int32_le, + caml_bytes_set64, + set_int64_be, + set_int64_le]; + runtime.caml_register_global(18, Stdlib_Bytes, "Stdlib__Bytes"); + return; + } + (globalThis)); + +//# 3624 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst$0 = "", + caml_blit_string = runtime.caml_blit_string, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace, + caml_ml_string_length = runtime.caml_ml_string_length, + caml_string_equal = runtime.caml_string_equal, + caml_string_unsafe_get = runtime.caml_string_unsafe_get, + caml_wrap_exception = runtime.caml_wrap_exception; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + cst = cst$0, + empty = cst$0, + Stdlib = global_data.Stdlib, + Stdlib_Bytes = global_data.Stdlib__Bytes, + bts = Stdlib_Bytes[48], + bos = Stdlib_Bytes[49]; + function make(n, c){ + return caml_call1(bts, caml_call2(Stdlib_Bytes[1], n, c)); + } + function init(n, f){ + return caml_call1(bts, caml_call2(Stdlib_Bytes[2], n, f)); + } + function copy(s){ + var _Y_ = caml_call1(bos, s); + return caml_call1(bts, caml_call1(Stdlib_Bytes[4], _Y_)); + } + var of_bytes = Stdlib_Bytes[6], to_bytes = Stdlib_Bytes[5]; + function sub(s, ofs, len){ + var _X_ = caml_call1(bos, s); + return caml_call1(bts, caml_call3(Stdlib_Bytes[7], _X_, ofs, len)); + } + var + fill = Stdlib_Bytes[10], + blit = Stdlib_Bytes[12], + cst_String_concat = "String.concat"; + function concat(sep, l){ + if(! l) return cst; + var seplen = caml_ml_string_length(sep); + a: + { + b: + { + var acc = 0, param = l, pos$1 = 0; + for(;;){ + if(! param) break; + var hd = param[1]; + if(! param[2]) break b; + var + tl = param[2], + x = (caml_ml_string_length(hd) + seplen | 0) + acc | 0, + acc$0 = acc <= x ? x : caml_call1(Stdlib[1], cst_String_concat); + acc = acc$0; + param = tl; + } + var _W_ = acc; + break a; + } + var _W_ = caml_ml_string_length(hd) + acc | 0; + } + var dst = runtime.caml_create_bytes(_W_), pos = pos$1, param$0 = l; + for(;;){ + if(param$0){ + var hd$0 = param$0[1]; + if(param$0[2]){ + var tl$0 = param$0[2]; + caml_blit_string(hd$0, 0, dst, pos, caml_ml_string_length(hd$0)); + caml_blit_string + (sep, 0, dst, pos + caml_ml_string_length(hd$0) | 0, seplen); + var pos$0 = (pos + caml_ml_string_length(hd$0) | 0) + seplen | 0; + pos = pos$0; + param$0 = tl$0; + continue; + } + caml_blit_string(hd$0, 0, dst, pos, caml_ml_string_length(hd$0)); + } + return caml_call1(bts, dst); + } + } + var + cat = Stdlib[28], + cst_String_index_from_Bytes_in = "String.index_from / Bytes.index_from", + cst_String_index_from_opt_Byte = + "String.index_from_opt / Bytes.index_from_opt", + cst_String_rindex_from_Bytes_r = "String.rindex_from / Bytes.rindex_from", + cst_String_rindex_from_opt_Byt = + "String.rindex_from_opt / Bytes.rindex_from_opt", + cst_String_contains_from_Bytes = + "String.contains_from / Bytes.contains_from", + cst_String_rcontains_from_Byte = + "String.rcontains_from / Bytes.rcontains_from"; + function iter(f, s){ + var _U_ = caml_ml_string_length(s) - 1 | 0, _T_ = 0; + if(_U_ >= 0){ + var i = _T_; + for(;;){ + caml_call1(f, caml_string_unsafe_get(s, i)); + var _V_ = i + 1 | 0; + if(_U_ === i) break; + i = _V_; + } + } + return 0; + } + function iteri(f, s){ + var _R_ = caml_ml_string_length(s) - 1 | 0, _Q_ = 0; + if(_R_ >= 0){ + var i = _Q_; + for(;;){ + caml_call2(f, i, caml_string_unsafe_get(s, i)); + var _S_ = i + 1 | 0; + if(_R_ === i) break; + i = _S_; + } + } + return 0; + } + function map(f, s){ + var _P_ = caml_call1(bos, s); + return caml_call1(bts, caml_call2(Stdlib_Bytes[17], f, _P_)); + } + function mapi(f, s){ + var _O_ = caml_call1(bos, s); + return caml_call1(bts, caml_call2(Stdlib_Bytes[18], f, _O_)); + } + function fold_right(f, x, a){ + var _N_ = caml_call1(bos, x); + return caml_call3(Stdlib_Bytes[20], f, _N_, a); + } + function fold_left(f, a, x){ + var _M_ = caml_call1(bos, x); + return caml_call3(Stdlib_Bytes[19], f, a, _M_); + } + function exists(f, s){ + var _L_ = caml_call1(bos, s); + return caml_call2(Stdlib_Bytes[22], f, _L_); + } + function for_all(f, s){ + var _K_ = caml_call1(bos, s); + return caml_call2(Stdlib_Bytes[21], f, _K_); + } + function is_space(param){ + var _J_ = param - 9 | 0; + a: + { + if(4 < _J_ >>> 0){if(23 !== _J_) break a;} else if(2 === _J_) break a; + return 1; + } + return 0; + } + function trim(s){ + if(s == cst$0) return s; + if + (! + is_space(caml_string_unsafe_get(s, 0)) + && + ! + is_space(caml_string_unsafe_get(s, caml_ml_string_length(s) - 1 | 0))) + return s; + var _I_ = caml_call1(bos, s); + return caml_call1(bts, caml_call1(Stdlib_Bytes[23], _I_)); + } + function escaped(s){ + var n = caml_ml_string_length(s), i = 0; + for(;;){ + if(n <= i) return s; + var _G_ = caml_string_unsafe_get(s, i) - 32 | 0; + a: + { + if(59 < _G_ >>> 0){ + if(33 < _G_ - 61 >>> 0) break a; + } + else if(2 === _G_) break a; + var i$0 = i + 1 | 0; + i = i$0; + continue; + } + var _H_ = caml_call1(bos, s); + return caml_call1(bts, caml_call1(Stdlib_Bytes[24], _H_)); + } + } + function index_rec(s, lim, i, c){ + var i$0 = i; + for(;;){ + if(lim <= i$0) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + if(caml_string_unsafe_get(s, i$0) === c) return i$0; + var i$1 = i$0 + 1 | 0; + i$0 = i$1; + } + } + function index(s, c){return index_rec(s, caml_ml_string_length(s), 0, c);} + function index_rec_opt(s, lim, i, c){ + var i$0 = i; + for(;;){ + if(lim <= i$0) return 0; + if(caml_string_unsafe_get(s, i$0) === c) return [0, i$0]; + var i$1 = i$0 + 1 | 0; + i$0 = i$1; + } + } + function index_opt(s, c){ + return index_rec_opt(s, caml_ml_string_length(s), 0, c); + } + function index_from(s, i, c){ + var l = caml_ml_string_length(s); + if(0 <= i && l >= i) return index_rec(s, l, i, c); + return caml_call1(Stdlib[1], cst_String_index_from_Bytes_in); + } + function index_from_opt(s, i, c){ + var l = caml_ml_string_length(s); + if(0 <= i && l >= i) return index_rec_opt(s, l, i, c); + return caml_call1(Stdlib[1], cst_String_index_from_opt_Byte); + } + function rindex_rec(s, i, c){ + var i$0 = i; + for(;;){ + if(0 > i$0) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + if(caml_string_unsafe_get(s, i$0) === c) return i$0; + var i$1 = i$0 - 1 | 0; + i$0 = i$1; + } + } + function rindex(s, c){ + return rindex_rec(s, caml_ml_string_length(s) - 1 | 0, c); + } + function rindex_from(s, i, c){ + if(-1 <= i && caml_ml_string_length(s) > i) return rindex_rec(s, i, c); + return caml_call1(Stdlib[1], cst_String_rindex_from_Bytes_r); + } + function rindex_rec_opt(s, i, c){ + var i$0 = i; + for(;;){ + if(0 > i$0) return 0; + if(caml_string_unsafe_get(s, i$0) === c) return [0, i$0]; + var i$1 = i$0 - 1 | 0; + i$0 = i$1; + } + } + function rindex_opt(s, c){ + return rindex_rec_opt(s, caml_ml_string_length(s) - 1 | 0, c); + } + function rindex_from_opt(s, i, c){ + if(-1 <= i && caml_ml_string_length(s) > i) + return rindex_rec_opt(s, i, c); + return caml_call1(Stdlib[1], cst_String_rindex_from_opt_Byt); + } + function contains_from(s, i, c){ + var l = caml_ml_string_length(s); + if(0 <= i && l >= i) + try{index_rec(s, l, i, c); var _E_ = 1; return _E_;} + catch(_F_){ + var _D_ = caml_wrap_exception(_F_); + if(_D_ === Stdlib[8]) return 0; + throw caml_maybe_attach_backtrace(_D_, 0); + } + return caml_call1(Stdlib[1], cst_String_contains_from_Bytes); + } + function contains(s, c){return contains_from(s, 0, c);} + function rcontains_from(s, i, c){ + if(0 <= i && caml_ml_string_length(s) > i) + try{rindex_rec(s, i, c); var _B_ = 1; return _B_;} + catch(_C_){ + var _A_ = caml_wrap_exception(_C_); + if(_A_ === Stdlib[8]) return 0; + throw caml_maybe_attach_backtrace(_A_, 0); + } + return caml_call1(Stdlib[1], cst_String_rcontains_from_Byte); + } + function uppercase_ascii(s){ + var _z_ = caml_call1(bos, s); + return caml_call1(bts, caml_call1(Stdlib_Bytes[40], _z_)); + } + function lowercase_ascii(s){ + var _y_ = caml_call1(bos, s); + return caml_call1(bts, caml_call1(Stdlib_Bytes[41], _y_)); + } + function capitalize_ascii(s){ + var _x_ = caml_call1(bos, s); + return caml_call1(bts, caml_call1(Stdlib_Bytes[42], _x_)); + } + function uncapitalize_ascii(s){ + var _w_ = caml_call1(bos, s); + return caml_call1(bts, caml_call1(Stdlib_Bytes[43], _w_)); + } + function starts_with(prefix, s){ + var + len_s = caml_ml_string_length(s), + len_pre = caml_ml_string_length(prefix), + _v_ = len_pre <= len_s ? 1 : 0; + if(! _v_) return _v_; + var i = 0; + for(;;){ + if(i === len_pre) return 1; + if(caml_string_unsafe_get(s, i) !== caml_string_unsafe_get(prefix, i)) + return 0; + var i$0 = i + 1 | 0; + i = i$0; + } + } + function ends_with(suffix, s){ + var + len_s = caml_ml_string_length(s), + len_suf = caml_ml_string_length(suffix), + diff = len_s - len_suf | 0, + _u_ = 0 <= diff ? 1 : 0; + if(! _u_) return _u_; + var i = 0; + for(;;){ + if(i === len_suf) return 1; + if + (caml_string_unsafe_get(s, diff + i | 0) + !== caml_string_unsafe_get(suffix, i)) + return 0; + var i$0 = i + 1 | 0; + i = i$0; + } + } + function split_on_char(sep, s){ + var + r = [0, 0], + j = [0, caml_ml_string_length(s)], + _q_ = caml_ml_string_length(s) - 1 | 0; + if(_q_ >= 0){ + var i = _q_; + for(;;){ + if(caml_string_unsafe_get(s, i) === sep){ + var _s_ = r[1]; + r[1] = [0, sub(s, i + 1 | 0, (j[1] - i | 0) - 1 | 0), _s_]; + j[1] = i; + } + var _t_ = i - 1 | 0; + if(0 === i) break; + i = _t_; + } + } + var _r_ = r[1]; + return [0, sub(s, 0, j[1]), _r_]; + } + function uppercase(s){ + var _p_ = caml_call1(bos, s); + return caml_call1(bts, caml_call1(Stdlib_Bytes[36], _p_)); + } + function lowercase(s){ + var _o_ = caml_call1(bos, s); + return caml_call1(bts, caml_call1(Stdlib_Bytes[37], _o_)); + } + function capitalize(s){ + var _n_ = caml_call1(bos, s); + return caml_call1(bts, caml_call1(Stdlib_Bytes[38], _n_)); + } + function uncapitalize(s){ + var _m_ = caml_call1(bos, s); + return caml_call1(bts, caml_call1(Stdlib_Bytes[39], _m_)); + } + var compare = runtime.caml_string_compare; + function to_seq(s){ + var _l_ = caml_call1(bos, s); + return caml_call1(Stdlib_Bytes[51], _l_); + } + function to_seqi(s){ + var _k_ = caml_call1(bos, s); + return caml_call1(Stdlib_Bytes[52], _k_); + } + function of_seq(g){ + return caml_call1(bts, caml_call1(Stdlib_Bytes[53], g)); + } + function get_int8(s, i){ + var _j_ = caml_call1(bos, s); + return caml_call2(Stdlib_Bytes[55], _j_, i); + } + function get_uint16_le(s, i){ + var _i_ = caml_call1(bos, s); + return caml_call2(Stdlib_Bytes[58], _i_, i); + } + function get_uint16_be(s, i){ + var _h_ = caml_call1(bos, s); + return caml_call2(Stdlib_Bytes[57], _h_, i); + } + function get_int16_ne(s, i){ + var _g_ = caml_call1(bos, s); + return caml_call2(Stdlib_Bytes[59], _g_, i); + } + function get_int16_le(s, i){ + var _f_ = caml_call1(bos, s); + return caml_call2(Stdlib_Bytes[61], _f_, i); + } + function get_int16_be(s, i){ + var _e_ = caml_call1(bos, s); + return caml_call2(Stdlib_Bytes[60], _e_, i); + } + function get_int32_le(s, i){ + var _d_ = caml_call1(bos, s); + return caml_call2(Stdlib_Bytes[64], _d_, i); + } + function get_int32_be(s, i){ + var _c_ = caml_call1(bos, s); + return caml_call2(Stdlib_Bytes[63], _c_, i); + } + function get_int64_le(s, i){ + var _b_ = caml_call1(bos, s); + return caml_call2(Stdlib_Bytes[67], _b_, i); + } + function get_int64_be(s, i){ + var _a_ = caml_call1(bos, s); + return caml_call2(Stdlib_Bytes[66], _a_, i); + } + var + Stdlib_String = + [0, + make, + init, + empty, + of_bytes, + to_bytes, + concat, + cat, + caml_string_equal, + compare, + starts_with, + ends_with, + contains_from, + rcontains_from, + contains, + sub, + split_on_char, + map, + mapi, + fold_left, + fold_right, + for_all, + exists, + trim, + escaped, + uppercase_ascii, + lowercase_ascii, + capitalize_ascii, + uncapitalize_ascii, + iter, + iteri, + index_from, + index_from_opt, + rindex_from, + rindex_from_opt, + index, + index_opt, + rindex, + rindex_opt, + to_seq, + to_seqi, + of_seq, + blit, + copy, + fill, + uppercase, + lowercase, + capitalize, + uncapitalize, + runtime.caml_string_get, + get_int8, + runtime.caml_string_get16, + get_uint16_be, + get_uint16_le, + get_int16_ne, + get_int16_be, + get_int16_le, + runtime.caml_string_get32, + get_int32_be, + get_int32_le, + runtime.caml_string_get64, + get_int64_be, + get_int64_le]; + runtime.caml_register_global(12, Stdlib_String, "Stdlib__String"); + return; + } + (globalThis)); + +//# 4133 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_Marshal_from_bytes$1 = "Marshal.from_bytes", + caml_marshal_data_size = runtime.caml_marshal_data_size, + caml_ml_bytes_length = runtime.caml_ml_bytes_length; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + var + global_data = runtime.caml_get_global_data(), + Stdlib_Bytes = global_data.Stdlib__Bytes, + Stdlib = global_data.Stdlib, + cst_Marshal_to_buffer_substrin = + "Marshal.to_buffer: substring out of bounds"; + function to_buffer(buff, ofs, len, v, flags){ + if(0 <= ofs && 0 <= len && (caml_ml_bytes_length(buff) - len | 0) >= ofs) + return runtime.caml_output_value_to_buffer(buff, ofs, len, v, flags); + return caml_call1(Stdlib[1], cst_Marshal_to_buffer_substrin); + } + var + cst_Marshal_data_size = "Marshal.data_size", + cst_Marshal_from_bytes = cst_Marshal_from_bytes$1, + cst_Marshal_from_bytes$0 = cst_Marshal_from_bytes$1; + function data_size(buff, ofs){ + if(0 <= ofs && (caml_ml_bytes_length(buff) - 20 | 0) >= ofs) + return caml_marshal_data_size(buff, ofs); + return caml_call1(Stdlib[1], cst_Marshal_data_size); + } + function total_size(buff, ofs){return 20 + data_size(buff, ofs) | 0;} + function from_bytes(buff, ofs){ + if(0 <= ofs && (caml_ml_bytes_length(buff) - 20 | 0) >= ofs){ + var len = caml_marshal_data_size(buff, ofs); + return (caml_ml_bytes_length(buff) - (20 + len | 0) | 0) < ofs + ? caml_call1(Stdlib[1], cst_Marshal_from_bytes$0) + : runtime.caml_input_value_from_bytes(buff, ofs); + } + return caml_call1(Stdlib[1], cst_Marshal_from_bytes); + } + function from_string(buff, ofs){ + return from_bytes(caml_call1(Stdlib_Bytes[49], buff), ofs); + } + var + Stdlib_Marshal = + [0, + runtime.caml_output_value, + to_buffer, + runtime.caml_input_value, + from_bytes, + from_string, + 20, + data_size, + total_size]; + runtime.caml_register_global(6, Stdlib_Marshal, "Stdlib__Marshal"); + return; + } + (globalThis)); + +//# 4197 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_Obj_extension_constructor$1 = "Obj.extension_constructor", + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace, + caml_obj_tag = runtime.caml_obj_tag; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + Stdlib = global_data.Stdlib, + Assert_failure = global_data.Assert_failure, + Stdlib_Sys = global_data.Stdlib__Sys, + Stdlib_Marshal = global_data.Stdlib__Marshal; + function is_block(a){return 1 - (typeof a === "number" ? 1 : 0);} + var + double_field = runtime.caml_array_get, + set_double_field = runtime.caml_array_set; + function marshal(obj){return runtime.caml_output_value_to_bytes(obj, 0);} + function unmarshal(str, pos){ + var _i_ = pos + caml_call2(Stdlib_Marshal[8], str, pos) | 0; + return [0, caml_call2(Stdlib_Marshal[4], str, pos), _i_]; + } + var + custom_tag = 255, + _a_ = [0, "obj.ml", 100, 4], + cst_Obj_extension_constructor = cst_Obj_extension_constructor$1, + cst_Obj_extension_constructor$0 = cst_Obj_extension_constructor$1; + function info(obj){ + if(caml_obj_tag(obj) !== 247) + throw caml_maybe_attach_backtrace([0, Assert_failure, _a_], 1); + var + info = runtime.caml_obj_raw_field(obj, 1), + arity = 64 === Stdlib_Sys[9] ? info >> 56 : info >> 24, + start_env = info << 8 >>> 9 | 0; + return [0, arity, start_env]; + } + function of_val(x){ + a: + { + if(is_block(x) && caml_obj_tag(x) !== 248 && 1 <= x.length - 1){var slot = x[1]; break a;} + var slot = x; + } + a: + { + if(is_block(slot) && caml_obj_tag(slot) === 248){var name = slot[1]; break a;} + var name = caml_call1(Stdlib[1], cst_Obj_extension_constructor$0); + } + return caml_obj_tag(name) === 252 + ? slot + : caml_call1(Stdlib[1], cst_Obj_extension_constructor); + } + function name(slot){return slot[1];} + function id(slot){return slot[2];} + var + Extension_constructor = [0, of_val, name, id], + extension_constructor = Extension_constructor[1], + extension_name = Extension_constructor[2], + extension_id = Extension_constructor[3], + max_ephe_length = Stdlib_Sys[13] - 2 | 0, + cst_Obj_Ephemeron_create = "Obj.Ephemeron.create", + cst_Obj_Ephemeron_get_key = "Obj.Ephemeron.get_key", + cst_Obj_Ephemeron_get_key_copy = "Obj.Ephemeron.get_key_copy", + cst_Obj_Ephemeron_set_key = "Obj.Ephemeron.set_key", + cst_Obj_Ephemeron_unset_key = "Obj.Ephemeron.unset_key", + cst_Obj_Ephemeron_check_key = "Obj.Ephemeron.check_key", + cst_Obj_Ephemeron_blit_key = "Obj.Ephemeron.blit_key"; + function create(l){ + var _g_ = 0 <= l ? 1 : 0, _h_ = _g_ ? l <= max_ephe_length ? 1 : 0 : _g_; + if(1 - _h_) caml_call1(Stdlib[1], cst_Obj_Ephemeron_create); + return runtime.caml_ephe_create(l); + } + function length(x){return x.length - 3 | 0;} + function raise_if_invalid_offset(e, o, msg){ + var + _d_ = 0 <= o ? 1 : 0, + _e_ = _d_ ? o < length(e) ? 1 : 0 : _d_, + _f_ = 1 - _e_; + return _f_ ? caml_call1(Stdlib[1], msg) : _f_; + } + function get_key(e, o){ + raise_if_invalid_offset(e, o, cst_Obj_Ephemeron_get_key); + return runtime.caml_ephe_get_key(e, o); + } + function get_key_copy(e, o){ + raise_if_invalid_offset(e, o, cst_Obj_Ephemeron_get_key_copy); + return runtime.caml_ephe_get_key_copy(e, o); + } + function set_key(e, o, x){ + raise_if_invalid_offset(e, o, cst_Obj_Ephemeron_set_key); + return runtime.caml_ephe_set_key(e, o, x); + } + function unset_key(e, o){ + raise_if_invalid_offset(e, o, cst_Obj_Ephemeron_unset_key); + return runtime.caml_ephe_unset_key(e, o); + } + function check_key(e, o){ + raise_if_invalid_offset(e, o, cst_Obj_Ephemeron_check_key); + return runtime.caml_ephe_check_key(e, o); + } + function blit_key(e1, o1, e2, o2, l){ + if + (0 <= l + && + 0 <= o1 + && (length(e1) - l | 0) >= o1 && 0 <= o2 && (length(e2) - l | 0) >= o2){ + var + _b_ = 0 !== l ? 1 : 0, + _c_ = _b_ ? runtime.caml_ephe_blit_key(e1, o1, e2, o2, l) : _b_; + return _c_; + } + return caml_call1(Stdlib[1], cst_Obj_Ephemeron_blit_key); + } + var + Stdlib_Obj = + [0, + is_block, + double_field, + set_double_field, + 0, + 245, + 246, + 247, + 248, + 249, + 250, + 251, + 251, + 252, + 253, + 254, + custom_tag, + custom_tag, + 1000, + 1001, + 1002, + [0, info], + Extension_constructor, + extension_constructor, + extension_name, + extension_id, + marshal, + unmarshal, + [0, + create, + length, + get_key, + get_key_copy, + set_key, + unset_key, + check_key, + blit_key, + runtime.caml_ephe_get_data, + runtime.caml_ephe_get_data_copy, + runtime.caml_ephe_set_data, + runtime.caml_ephe_unset_data, + runtime.caml_ephe_check_data, + runtime.caml_ephe_blit_data, + max_ephe_length]]; + runtime.caml_register_global(14, Stdlib_Obj, "Stdlib__Obj"); + return; + } + (globalThis)); + +//# 4373 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + caml_array_sub = runtime.caml_array_sub, + caml_check_bound = runtime.caml_check_bound, + caml_make_vect = runtime.caml_make_vect, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace, + caml_wrap_exception = runtime.caml_wrap_exception; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + Stdlib_Seq = global_data.Stdlib__Seq, + Assert_failure = global_data.Assert_failure, + Stdlib = global_data.Stdlib, + make_float = runtime.caml_make_float_vect, + Floatarray = [0], + cst_Array_init = "Array.init", + cst_Array_sub = "Array.sub", + cst_Array_fill = "Array.fill", + cst_Array_blit = "Array.blit", + cst_Array_iter2_arrays_must_ha = + "Array.iter2: arrays must have the same length", + cst_Array_map2_arrays_must_hav = + "Array.map2: arrays must have the same length", + cst_Array_for_all2 = "Array.for_all2", + cst_Array_exists2 = "Array.exists2", + cst_Array_combine = "Array.combine"; + function init(l, f){ + if(0 === l) return [0]; + if(0 > l) return caml_call1(Stdlib[1], cst_Array_init); + var res = caml_make_vect(l, caml_call1(f, 0)), _aq_ = l - 1 | 0, _ap_ = 1; + if(_aq_ >= 1){ + var i = _ap_; + for(;;){ + res[1 + i] = caml_call1(f, i); + var _ar_ = i + 1 | 0; + if(_aq_ === i) break; + i = _ar_; + } + } + return res; + } + function make_matrix(sx, sy, init){ + var res = caml_make_vect(sx, [0]), _an_ = sx - 1 | 0, _am_ = 0; + if(_an_ >= 0){ + var x = _am_; + for(;;){ + res[1 + x] = caml_make_vect(sy, init); + var _ao_ = x + 1 | 0; + if(_an_ === x) break; + x = _ao_; + } + } + return res; + } + function copy(a){ + var l = a.length - 1; + return 0 === l ? [0] : caml_array_sub(a, 0, l); + } + function append(a1, a2){ + var l1 = a1.length - 1; + return 0 === l1 + ? copy(a2) + : 0 + === a2.length - 1 + ? caml_array_sub(a1, 0, l1) + : runtime.caml_array_append(a1, a2); + } + function sub(a, ofs, len){ + if(0 <= ofs && 0 <= len && (a.length - 1 - len | 0) >= ofs) + return caml_array_sub(a, ofs, len); + return caml_call1(Stdlib[1], cst_Array_sub); + } + function fill(a, ofs, len, v){ + if(0 <= ofs && 0 <= len && (a.length - 1 - len | 0) >= ofs) + return runtime.caml_array_fill(a, ofs, len, v); + return caml_call1(Stdlib[1], cst_Array_fill); + } + function blit(a1, ofs1, a2, ofs2, len){ + if + (0 <= len + && + 0 <= ofs1 + && + (a1.length - 1 - len | 0) >= ofs1 + && 0 <= ofs2 && (a2.length - 1 - len | 0) >= ofs2) + return runtime.caml_array_blit(a1, ofs1, a2, ofs2, len); + return caml_call1(Stdlib[1], cst_Array_blit); + } + function iter(f, a){ + var _ak_ = a.length - 2 | 0, _aj_ = 0; + if(_ak_ >= 0){ + var i = _aj_; + for(;;){ + caml_call1(f, a[1 + i]); + var _al_ = i + 1 | 0; + if(_ak_ === i) break; + i = _al_; + } + } + return 0; + } + function iter2(f, a, b){ + if(a.length - 1 !== b.length - 1) + return caml_call1(Stdlib[1], cst_Array_iter2_arrays_must_ha); + var _ah_ = a.length - 2 | 0, _ag_ = 0; + if(_ah_ >= 0){ + var i = _ag_; + for(;;){ + caml_call2(f, a[1 + i], b[1 + i]); + var _ai_ = i + 1 | 0; + if(_ah_ === i) break; + i = _ai_; + } + } + return 0; + } + function map(f, a){ + var l = a.length - 1; + if(0 === l) return [0]; + var + r = caml_make_vect(l, caml_call1(f, a[1])), + _ae_ = l - 1 | 0, + _ad_ = 1; + if(_ae_ >= 1){ + var i = _ad_; + for(;;){ + r[1 + i] = caml_call1(f, a[1 + i]); + var _af_ = i + 1 | 0; + if(_ae_ === i) break; + i = _af_; + } + } + return r; + } + function map2(f, a, b){ + var la = a.length - 1, lb = b.length - 1; + if(la !== lb) + return caml_call1(Stdlib[1], cst_Array_map2_arrays_must_hav); + if(0 === la) return [0]; + var + r = caml_make_vect(la, caml_call2(f, a[1], b[1])), + _ab_ = la - 1 | 0, + _aa_ = 1; + if(_ab_ >= 1){ + var i = _aa_; + for(;;){ + r[1 + i] = caml_call2(f, a[1 + i], b[1 + i]); + var _ac_ = i + 1 | 0; + if(_ab_ === i) break; + i = _ac_; + } + } + return r; + } + function iteri(f, a){ + var ___ = a.length - 2 | 0, _Z_ = 0; + if(___ >= 0){ + var i = _Z_; + for(;;){ + caml_call2(f, i, a[1 + i]); + var _$_ = i + 1 | 0; + if(___ === i) break; + i = _$_; + } + } + return 0; + } + function mapi(f, a){ + var l = a.length - 1; + if(0 === l) return [0]; + var + r = caml_make_vect(l, caml_call2(f, 0, a[1])), + _X_ = l - 1 | 0, + _W_ = 1; + if(_X_ >= 1){ + var i = _W_; + for(;;){ + r[1 + i] = caml_call2(f, i, a[1 + i]); + var _Y_ = i + 1 | 0; + if(_X_ === i) break; + i = _Y_; + } + } + return r; + } + function to_list(a){ + var i$1 = a.length - 2 | 0, i = i$1, res = 0; + for(;;){ + if(0 > i) return res; + var res$0 = [0, a[1 + i], res], i$0 = i - 1 | 0; + i = i$0; + res = res$0; + } + } + function list_length(accu, param){ + var accu$0 = accu, param$0 = param; + for(;;){ + if(! param$0) return accu$0; + var t = param$0[2], accu$1 = accu$0 + 1 | 0; + accu$0 = accu$1; + param$0 = t; + } + } + function of_list(l){ + if(! l) return [0]; + var + tl = l[2], + hd = l[1], + a = caml_make_vect(list_length(0, l), hd), + i = 1, + param = tl; + for(;;){ + if(! param) return a; + var tl$0 = param[2], hd$0 = param[1]; + a[1 + i] = hd$0; + var i$0 = i + 1 | 0; + i = i$0; + param = tl$0; + } + } + function fold_left(f, x, a){ + var r = [0, x], _U_ = a.length - 2 | 0, _T_ = 0; + if(_U_ >= 0){ + var i = _T_; + for(;;){ + r[1] = caml_call2(f, r[1], a[1 + i]); + var _V_ = i + 1 | 0; + if(_U_ === i) break; + i = _V_; + } + } + return r[1]; + } + function fold_left_map(f, acc, input_array){ + var len = input_array.length - 1; + if(0 === len) return [0, acc, [0]]; + var + match = caml_call2(f, acc, input_array[1]), + elt = match[2], + acc$0 = match[1], + output_array = caml_make_vect(len, elt), + acc$1 = [0, acc$0], + _R_ = len - 1 | 0, + _Q_ = 1; + if(_R_ >= 1){ + var i = _Q_; + for(;;){ + var + match$0 = caml_call2(f, acc$1[1], input_array[1 + i]), + elt$0 = match$0[2], + acc$2 = match$0[1]; + acc$1[1] = acc$2; + output_array[1 + i] = elt$0; + var _S_ = i + 1 | 0; + if(_R_ === i) break; + i = _S_; + } + } + return [0, acc$1[1], output_array]; + } + function fold_right(f, a, x){ + var r = [0, x], _O_ = a.length - 2 | 0; + if(_O_ >= 0){ + var i = _O_; + for(;;){ + r[1] = caml_call2(f, a[1 + i], r[1]); + var _P_ = i - 1 | 0; + if(0 === i) break; + i = _P_; + } + } + return r[1]; + } + function exists(p, a){ + var n = a.length - 1, i = 0; + for(;;){ + if(i === n) return 0; + if(caml_call1(p, a[1 + i])) return 1; + var i$0 = i + 1 | 0; + i = i$0; + } + } + function for_all(p, a){ + var n = a.length - 1, i = 0; + for(;;){ + if(i === n) return 1; + if(! caml_call1(p, a[1 + i])) return 0; + var i$0 = i + 1 | 0; + i = i$0; + } + } + function for_all2(p, l1, l2){ + var n1 = l1.length - 1, n2 = l2.length - 1; + if(n1 !== n2) return caml_call1(Stdlib[1], cst_Array_for_all2); + var i = 0; + for(;;){ + if(i === n1) return 1; + if(! caml_call2(p, l1[1 + i], l2[1 + i])) return 0; + var i$0 = i + 1 | 0; + i = i$0; + } + } + function exists2(p, l1, l2){ + var n1 = l1.length - 1, n2 = l2.length - 1; + if(n1 !== n2) return caml_call1(Stdlib[1], cst_Array_exists2); + var i = 0; + for(;;){ + if(i === n1) return 0; + if(caml_call2(p, l1[1 + i], l2[1 + i])) return 1; + var i$0 = i + 1 | 0; + i = i$0; + } + } + function mem(x, a){ + var n = a.length - 1, i = 0; + for(;;){ + if(i === n) return 0; + if(0 === runtime.caml_compare(a[1 + i], x)) return 1; + var i$0 = i + 1 | 0; + i = i$0; + } + } + function memq(x, a){ + var n = a.length - 1, i = 0; + for(;;){ + if(i === n) return 0; + if(x === a[1 + i]) return 1; + var i$0 = i + 1 | 0; + i = i$0; + } + } + function find_opt(p, a){ + var n = a.length - 1, i = 0; + for(;;){ + if(i === n) return 0; + var x = a[1 + i]; + if(caml_call1(p, x)) return [0, x]; + var i$0 = i + 1 | 0; + i = i$0; + } + } + function find_map(f, a){ + var n = a.length - 1, i = 0; + for(;;){ + if(i === n) return 0; + var r = caml_call1(f, a[1 + i]); + if(r) return r; + var i$0 = i + 1 | 0; + i = i$0; + } + } + function split(x){ + if(runtime.caml_equal(x, [0])) return [0, [0], [0]]; + var + match = x[1], + b0 = match[2], + a0 = match[1], + n = x.length - 1, + a = caml_make_vect(n, a0), + b = caml_make_vect(n, b0), + _M_ = n - 1 | 0, + _L_ = 1; + if(_M_ >= 1){ + var i = _L_; + for(;;){ + var match$0 = x[1 + i], bi = match$0[2], ai = match$0[1]; + a[1 + i] = ai; + b[1 + i] = bi; + var _N_ = i + 1 | 0; + if(_M_ === i) break; + i = _N_; + } + } + return [0, a, b]; + } + function combine(a, b){ + var na = a.length - 1, nb = b.length - 1; + if(na !== nb) caml_call1(Stdlib[1], cst_Array_combine); + if(0 === na) return [0]; + var x = caml_make_vect(na, [0, a[1], b[1]]), _J_ = na - 1 | 0, _I_ = 1; + if(_J_ >= 1){ + var i = _I_; + for(;;){ + x[1 + i] = [0, a[1 + i], b[1 + i]]; + var _K_ = i + 1 | 0; + if(_J_ === i) break; + i = _K_; + } + } + return x; + } + var + Bottom = [248, "Stdlib.Array.Bottom", runtime.caml_fresh_oo_id(0)], + _a_ = [0, "array.ml", 322, 4]; + function sort(cmp, a){ + function maxson(l, i){ + var i31 = ((i + i | 0) + i | 0) + 1 | 0, x = [0, i31]; + if((i31 + 2 | 0) < l){ + var _B_ = i31 + 1 | 0, _C_ = caml_check_bound(a, _B_)[1 + _B_]; + if(caml_call2(cmp, caml_check_bound(a, i31)[1 + i31], _C_) < 0) + x[1] = i31 + 1 | 0; + var + _D_ = i31 + 2 | 0, + _E_ = caml_check_bound(a, _D_)[1 + _D_], + _F_ = x[1]; + if(caml_call2(cmp, caml_check_bound(a, _F_)[1 + _F_], _E_) < 0) + x[1] = i31 + 2 | 0; + return x[1]; + } + if((i31 + 1 | 0) < l){ + var _G_ = i31 + 1 | 0, _H_ = caml_check_bound(a, _G_)[1 + _G_]; + if(0 > caml_call2(cmp, caml_check_bound(a, i31)[1 + i31], _H_)) + return i31 + 1 | 0; + } + if(i31 < l) return i31; + throw caml_maybe_attach_backtrace([0, Bottom, i], 1); + } + var l = a.length - 1, _v_ = ((l + 1 | 0) / 3 | 0) - 1 | 0; + if(_v_ >= 0){ + var i$6 = _v_; + for(;;){ + var e$1 = caml_check_bound(a, i$6)[1 + i$6]; + try{ + var i = i$6; + for(;;){ + var j = maxson(l, i); + if(0 >= caml_call2(cmp, caml_check_bound(a, j)[1 + j], e$1)) break; + var _s_ = caml_check_bound(a, j)[1 + j]; + caml_check_bound(a, i)[1 + i] = _s_; + i = j; + } + caml_check_bound(a, i)[1 + i] = e$1; + } + catch(exn$0){ + var exn = caml_wrap_exception(exn$0); + if(exn[1] !== Bottom) throw caml_maybe_attach_backtrace(exn, 0); + var i$0 = exn[2]; + caml_check_bound(a, i$0)[1 + i$0] = e$1; + } + var _A_ = i$6 - 1 | 0; + if(0 === i$6) break; + i$6 = _A_; + } + } + var _w_ = l - 1 | 0; + if(_w_ >= 2){ + var i$4 = _w_; + for(;;){ + var e$0 = caml_check_bound(a, i$4)[1 + i$4]; + a[1 + i$4] = caml_check_bound(a, 0)[1]; + var i$5 = 0; + try{ + var i$1 = i$5; + for(;;){ + var j$0 = maxson(i$4, i$1), _t_ = caml_check_bound(a, j$0)[1 + j$0]; + caml_check_bound(a, i$1)[1 + i$1] = _t_; + i$1 = j$0; + } + } + catch(exn){ + var exn$0 = caml_wrap_exception(exn); + if(exn$0[1] !== Bottom) throw caml_maybe_attach_backtrace(exn$0, 0); + var i$2 = exn$0[2]; + a: + { + b: + { + var i$3 = i$2; + for(;;){ + var father = (i$3 - 1 | 0) / 3 | 0; + if(i$3 === father) + throw caml_maybe_attach_backtrace([0, Assert_failure, _a_], 1); + if + (0 <= caml_call2(cmp, caml_check_bound(a, father)[1 + father], e$0)) + break; + var _u_ = caml_check_bound(a, father)[1 + father]; + caml_check_bound(a, i$3)[1 + i$3] = _u_; + if(0 >= father) break b; + i$3 = father; + } + caml_check_bound(a, i$3)[1 + i$3] = e$0; + break a; + } + caml_check_bound(a, 0)[1] = e$0; + } + var _z_ = i$4 - 1 | 0; + if(2 === i$4) break; + i$4 = _z_; + } + } + } + var _x_ = 1 < l ? 1 : 0; + if(_x_){ + var e = caml_check_bound(a, 1)[2]; + a[2] = caml_check_bound(a, 0)[1]; + a[1] = e; + var _y_ = 0; + } + else + var _y_ = _x_; + return _y_; + } + function stable_sort(cmp, a){ + function merge(src1ofs, src1len, src2, src2ofs, src2len, dst, dstofs){ + var + src1r = src1ofs + src1len | 0, + src2r = src2ofs + src2len | 0, + s2$1 = caml_check_bound(src2, src2ofs)[1 + src2ofs], + s1$1 = caml_check_bound(a, src1ofs)[1 + src1ofs], + i1 = src1ofs, + s1 = s1$1, + i2 = src2ofs, + s2 = s2$1, + d = dstofs; + for(;;) + if(0 < caml_call2(cmp, s1, s2)){ + caml_check_bound(dst, d)[1 + d] = s2; + var i2$0 = i2 + 1 | 0; + if(i2$0 >= src2r) return blit(a, i1, dst, d + 1 | 0, src1r - i1 | 0); + var d$0 = d + 1 | 0, s2$0 = caml_check_bound(src2, i2$0)[1 + i2$0]; + i2 = i2$0; + s2 = s2$0; + d = d$0; + } + else{ + caml_check_bound(dst, d)[1 + d] = s1; + var i1$0 = i1 + 1 | 0; + if(i1$0 >= src1r) + return blit(src2, i2, dst, d + 1 | 0, src2r - i2 | 0); + var d$1 = d + 1 | 0, s1$0 = caml_check_bound(a, i1$0)[1 + i1$0]; + i1 = i1$0; + s1 = s1$0; + d = d$1; + } + } + function isortto(srcofs, dst, dstofs, len){ + var _k_ = len - 1 | 0, _j_ = 0; + if(_k_ >= 0){ + var i = _j_; + for(;;){ + var + _l_ = srcofs + i | 0, + e = caml_check_bound(a, _l_)[1 + _l_], + j = [0, (dstofs + i | 0) - 1 | 0]; + for(;;){ + if(dstofs > j[1]) break; + var _m_ = j[1]; + if(0 >= caml_call2(cmp, caml_check_bound(dst, _m_)[1 + _m_], e)) + break; + var + _n_ = j[1], + _o_ = caml_check_bound(dst, _n_)[1 + _n_], + _p_ = j[1] + 1 | 0; + caml_check_bound(dst, _p_)[1 + _p_] = _o_; + j[1]--; + } + var _q_ = j[1] + 1 | 0; + caml_check_bound(dst, _q_)[1 + _q_] = e; + var _r_ = i + 1 | 0; + if(_k_ === i) break; + i = _r_; + } + } + return 0; + } + function sortto(srcofs, dst, dstofs, len){ + if(len <= 5) return isortto(srcofs, dst, dstofs, len); + var l1 = len / 2 | 0, l2 = len - l1 | 0; + sortto(srcofs + l1 | 0, dst, dstofs + l1 | 0, l2); + sortto(srcofs, a, srcofs + l2 | 0, l1); + return merge(srcofs + l2 | 0, l1, dst, dstofs + l1 | 0, l2, dst, dstofs); + } + var l = a.length - 1; + if(l <= 5) return isortto(0, a, 0, l); + var + l1 = l / 2 | 0, + l2 = l - l1 | 0, + t = caml_make_vect(l2, caml_check_bound(a, 0)[1]); + sortto(l1, t, 0, l2); + sortto(0, a, l2, l1); + return merge(l2, l1, t, 0, l2, a, 0); + } + function to_seq(a){ + function aux(i, param){ + if(i >= a.length - 1) return 0; + var x = a[1 + i], _h_ = i + 1 | 0; + return [0, x, function(_i_){return aux(_h_, _i_);}]; + } + var _f_ = 0; + return function(_g_){return aux(_f_, _g_);}; + } + function to_seqi(a){ + function aux(i, param){ + if(i >= a.length - 1) return 0; + var x = a[1 + i], _d_ = i + 1 | 0; + return [0, [0, i, x], function(_e_){return aux(_d_, _e_);}]; + } + var _b_ = 0; + return function(_c_){return aux(_b_, _c_);}; + } + function of_seq(i$2){ + var + l = + caml_call3 + (Stdlib_Seq[11], function(acc, x){return [0, x, acc];}, 0, i$2); + if(! l) return [0]; + var + tl = l[2], + hd = l[1], + len = list_length(0, l), + a = caml_make_vect(len, hd), + i$1 = len - 2 | 0, + i = i$1, + param = tl; + for(;;){ + if(! param) return a; + var tl$0 = param[2], hd$0 = param[1]; + a[1 + i] = hd$0; + var i$0 = i - 1 | 0; + i = i$0; + param = tl$0; + } + } + var + Stdlib_Array = + [0, + make_float, + init, + make_matrix, + make_matrix, + append, + runtime.caml_array_concat, + sub, + copy, + fill, + blit, + to_list, + of_list, + iter, + iteri, + map, + mapi, + fold_left, + fold_left_map, + fold_right, + iter2, + map2, + for_all, + exists, + for_all2, + exists2, + mem, + memq, + find_opt, + find_map, + split, + combine, + sort, + stable_sort, + stable_sort, + to_seq, + to_seqi, + of_seq, + Floatarray]; + runtime.caml_register_global(14, Stdlib_Array, "Stdlib__Array"); + return; + } + (globalThis)); + +//# 5812 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + caml_greaterequal = runtime.caml_greaterequal, + caml_int_compare = runtime.caml_int_compare, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace, + caml_mul = runtime.caml_mul, + caml_wrap_exception = runtime.caml_wrap_exception, + global_data = runtime.caml_get_global_data(), + Stdlib = global_data.Stdlib, + Stdlib_Sys = global_data.Stdlib__Sys, + Assert_failure = global_data.Assert_failure, + zero = 0, + one = 1; + function succ(n){return n + 1 | 0;} + function pred(n){return n - 1 | 0;} + function abs(n){return caml_greaterequal(n, 0) ? n : - n | 0;} + function lognot(n){return n ^ -1;} + var + _a_ = Stdlib_Sys[9], + _b_ = [0, "int32.ml", 69, 6], + minus_one = -1, + min_int = -2147483648, + max_int = 2147483647; + if(32 === _a_) + var + max_int$0 = Stdlib[19], + unsigned_to_int = + function(n){ + if(0 >= caml_int_compare(0, n) && 0 >= caml_int_compare(n, max_int$0)) + return [0, n]; + return 0; + }; + else{ + if(64 !== _a_) + throw caml_maybe_attach_backtrace([0, Assert_failure, _b_], 1); + var unsigned_to_int = function(n){return [0, n & -1];}; + } + function to_string(n){return runtime.caml_format_int("%d", n);} + function of_string_opt(s){ + try{var _d_ = [0, runtime.caml_int_of_string(s)]; return _d_;} + catch(_e_){ + var _c_ = caml_wrap_exception(_e_); + if(_c_[1] === Stdlib[7]) return 0; + throw caml_maybe_attach_backtrace(_c_, 0); + } + } + var compare = caml_int_compare; + function equal(x, y){return 0 === caml_int_compare(x, y) ? 1 : 0;} + function unsigned_compare(n, m){ + var y = m + 2147483648 | 0, x = n + 2147483648 | 0; + return caml_int_compare(x, y); + } + function min(x, y){return runtime.caml_lessequal(x, y) ? x : y;} + function max(x, y){return caml_greaterequal(x, y) ? x : y;} + function unsigned_div(n, d){ + if(runtime.caml_lessthan(d, 0)) + return 0 <= unsigned_compare(n, d) ? one : zero; + var q = runtime.caml_div(n >>> 1 | 0, d) << 1, r = n - caml_mul(q, d) | 0; + return 0 <= unsigned_compare(r, d) ? q + 1 | 0 : q; + } + function unsigned_rem(n, d){ + return n - caml_mul(unsigned_div(n, d), d) | 0; + } + var + Stdlib_Int32 = + [0, + zero, + one, + minus_one, + unsigned_div, + unsigned_rem, + succ, + pred, + abs, + max_int, + min_int, + lognot, + unsigned_to_int, + of_string_opt, + to_string, + compare, + unsigned_compare, + equal, + min, + max]; + runtime.caml_register_global(14, Stdlib_Int32, "Stdlib__Int32"); + return; + } + (globalThis)); + +//# 5907 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + caml_greaterequal = runtime.caml_greaterequal, + caml_int64_add = runtime.caml_int64_add, + caml_int64_compare = runtime.caml_int64_compare, + caml_int64_mul = runtime.caml_int64_mul, + caml_int64_sub = runtime.caml_int64_sub, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace, + caml_wrap_exception = runtime.caml_wrap_exception, + global_data = runtime.caml_get_global_data(), + _a_ = runtime.caml_int64_create_lo_mi_hi(1, 0, 0), + zero = runtime.caml_int64_create_lo_mi_hi(0, 0, 0), + one = runtime.caml_int64_create_lo_mi_hi(1, 0, 0), + minus_one = runtime.caml_int64_create_lo_mi_hi(16777215, 16777215, 65535), + min_int = runtime.caml_int64_create_lo_mi_hi(0, 0, 32768), + max_int = runtime.caml_int64_create_lo_mi_hi(16777215, 16777215, 32767), + Stdlib = global_data.Stdlib, + _b_ = runtime.caml_int64_create_lo_mi_hi(1, 0, 0), + _c_ = runtime.caml_int64_create_lo_mi_hi(0, 0, 0), + _d_ = runtime.caml_int64_create_lo_mi_hi(16777215, 16777215, 65535); + function succ(n){return caml_int64_add(n, _a_);} + function pred(n){return caml_int64_sub(n, _b_);} + function abs(n){ + return caml_greaterequal(n, _c_) ? n : runtime.caml_int64_neg(n); + } + function lognot(n){return runtime.caml_int64_xor(n, _d_);} + var max_int$0 = runtime.caml_int64_of_int32(Stdlib[19]); + function unsigned_to_int(n){ + if + (0 >= caml_int64_compare(zero, n) + && 0 >= caml_int64_compare(n, max_int$0)) + return [0, runtime.caml_int64_to_int32(n)]; + return 0; + } + function to_string(n){return runtime.caml_int64_format("%d", n);} + function of_string_opt(s){ + try{var _f_ = [0, runtime.caml_int64_of_string(s)]; return _f_;} + catch(_g_){ + var _e_ = caml_wrap_exception(_g_); + if(_e_[1] === Stdlib[7]) return 0; + throw caml_maybe_attach_backtrace(_e_, 0); + } + } + function compare(x, y){return caml_int64_compare(x, y);} + function equal(x, y){return 0 === caml_int64_compare(x, y) ? 1 : 0;} + function unsigned_compare(n, m){ + var y = caml_int64_sub(m, min_int), x = caml_int64_sub(n, min_int); + return caml_int64_compare(x, y); + } + function min(x, y){return runtime.caml_lessequal(x, y) ? x : y;} + function max(x, y){return caml_greaterequal(x, y) ? x : y;} + function unsigned_div(n, d){ + if(runtime.caml_lessthan(d, zero)) + return 0 <= unsigned_compare(n, d) ? one : zero; + var + q = + runtime.caml_int64_shift_left + (runtime.caml_int64_div + (runtime.caml_int64_shift_right_unsigned(n, 1), d), + 1), + r = caml_int64_sub(n, caml_int64_mul(q, d)); + return 0 <= unsigned_compare(r, d) ? caml_int64_add(q, _a_) : q; + } + function unsigned_rem(n, d){ + return caml_int64_sub(n, caml_int64_mul(unsigned_div(n, d), d)); + } + var + Stdlib_Int64 = + [0, + zero, + one, + minus_one, + unsigned_div, + unsigned_rem, + succ, + pred, + abs, + max_int, + min_int, + lognot, + unsigned_to_int, + of_string_opt, + to_string, + compare, + unsigned_compare, + equal, + min, + max]; + runtime.caml_register_global(11, Stdlib_Int64, "Stdlib__Int64"); + return; + } + (globalThis)); + +//# 7383 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_Map_bal$3 = "Map.bal", + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + Stdlib = global_data.Stdlib, + Assert_failure = global_data.Assert_failure, + Stdlib_Seq = global_data.Stdlib__Seq, + cst_Map_bal = cst_Map_bal$3, + cst_Map_bal$0 = cst_Map_bal$3, + cst_Map_bal$1 = cst_Map_bal$3, + cst_Map_bal$2 = cst_Map_bal$3, + cst_Map_remove_min_elt = "Map.remove_min_elt", + _a_ = [0, 0, 0, 0], + _b_ = [0, "map.ml", 400, 10], + _c_ = [0, 0, 0], + Stdlib_Map = + [0, + function(Ord){ + function height(param){ + if(! param) return 0; + var h = param[5]; + return h; + } + function create(l, x, d, r){ + var + hl = height(l), + hr = height(r), + _K_ = hr <= hl ? hl + 1 | 0 : hr + 1 | 0; + return [0, l, x, d, r, _K_]; + } + function singleton(x, d){return [0, 0, x, d, 0, 1];} + function bal(l, x, d, r){ + if(l) var h = l[5], hl = h; else var hl = 0; + if(r) var h$0 = r[5], hr = h$0; else var hr = 0; + if((hr + 2 | 0) < hl){ + if(! l) return caml_call1(Stdlib[1], cst_Map_bal$0); + var lr = l[4], ld = l[3], lv = l[2], ll = l[1], _F_ = height(lr); + if(_F_ <= height(ll)) + return create(ll, lv, ld, create(lr, x, d, r)); + if(! lr) return caml_call1(Stdlib[1], cst_Map_bal); + var + lrr = lr[4], + lrd = lr[3], + lrv = lr[2], + lrl = lr[1], + _G_ = create(lrr, x, d, r); + return create(create(ll, lv, ld, lrl), lrv, lrd, _G_); + } + if((hl + 2 | 0) >= hr){ + var _J_ = hr <= hl ? hl + 1 | 0 : hr + 1 | 0; + return [0, l, x, d, r, _J_]; + } + if(! r) return caml_call1(Stdlib[1], cst_Map_bal$2); + var rr = r[4], rd = r[3], rv = r[2], rl = r[1], _H_ = height(rl); + if(_H_ <= height(rr)) return create(create(l, x, d, rl), rv, rd, rr); + if(! rl) return caml_call1(Stdlib[1], cst_Map_bal$1); + var + rlr = rl[4], + rld = rl[3], + rlv = rl[2], + rll = rl[1], + _I_ = create(rlr, rv, rd, rr); + return create(create(l, x, d, rll), rlv, rld, _I_); + } + var empty = 0; + function is_empty(param){return param ? 0 : 1;} + function add(x, data, m){ + if(! m) return [0, 0, x, data, 0, 1]; + var + h = m[5], + r = m[4], + d = m[3], + v = m[2], + l = m[1], + c = caml_call2(Ord[1], x, v); + if(0 === c) return d === data ? m : [0, l, x, data, r, h]; + if(0 <= c){ + var rr = add(x, data, r); + return r === rr ? m : bal(l, v, d, rr); + } + var ll = add(x, data, l); + return l === ll ? m : bal(ll, v, d, r); + } + function find(x, param){ + var param$0 = param; + for(;;){ + if(! param$0) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + var + r = param$0[4], + d = param$0[3], + v = param$0[2], + l = param$0[1], + c = caml_call2(Ord[1], x, v); + if(0 === c) return d; + var r$0 = 0 <= c ? r : l; + param$0 = r$0; + } + } + function find_first(f, param$0){ + var param$1 = param$0; + for(;;){ + if(! param$1) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + var + r$0 = param$1[4], + d0$1 = param$1[3], + v0$1 = param$1[2], + l$0 = param$1[1]; + if(caml_call1(f, v0$1)){ + var v0 = v0$1, d0 = d0$1, param = l$0; + for(;;){ + if(! param) return [0, v0, d0]; + var r = param[4], d0$0 = param[3], v0$0 = param[2], l = param[1]; + if(caml_call1(f, v0$0)){ + v0 = v0$0; + d0 = d0$0; + param = l; + } + else + param = r; + } + } + else + param$1 = r$0; + } + } + function find_first_opt(f, param$0){ + var param$1 = param$0; + for(;;){ + if(! param$1) return 0; + var + r$0 = param$1[4], + d0$1 = param$1[3], + v0$1 = param$1[2], + l$0 = param$1[1]; + if(caml_call1(f, v0$1)){ + var v0 = v0$1, d0 = d0$1, param = l$0; + for(;;){ + if(! param) return [0, [0, v0, d0]]; + var r = param[4], d0$0 = param[3], v0$0 = param[2], l = param[1]; + if(caml_call1(f, v0$0)){ + v0 = v0$0; + d0 = d0$0; + param = l; + } + else + param = r; + } + } + else + param$1 = r$0; + } + } + function find_last(f, param$0){ + var param$1 = param$0; + for(;;){ + if(! param$1) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + var + r$0 = param$1[4], + d0$1 = param$1[3], + v0$1 = param$1[2], + l$0 = param$1[1]; + if(caml_call1(f, v0$1)){ + var v0 = v0$1, d0 = d0$1, param = r$0; + for(;;){ + if(! param) return [0, v0, d0]; + var r = param[4], d0$0 = param[3], v0$0 = param[2], l = param[1]; + if(caml_call1(f, v0$0)){ + v0 = v0$0; + d0 = d0$0; + param = r; + } + else + param = l; + } + } + else + param$1 = l$0; + } + } + function find_last_opt(f, param$0){ + var param$1 = param$0; + for(;;){ + if(! param$1) return 0; + var + r$0 = param$1[4], + d0$1 = param$1[3], + v0$1 = param$1[2], + l$0 = param$1[1]; + if(caml_call1(f, v0$1)){ + var v0 = v0$1, d0 = d0$1, param = r$0; + for(;;){ + if(! param) return [0, [0, v0, d0]]; + var r = param[4], d0$0 = param[3], v0$0 = param[2], l = param[1]; + if(caml_call1(f, v0$0)){ + v0 = v0$0; + d0 = d0$0; + param = r; + } + else + param = l; + } + } + else + param$1 = l$0; + } + } + function find_opt(x, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var + r = param$0[4], + d = param$0[3], + v = param$0[2], + l = param$0[1], + c = caml_call2(Ord[1], x, v); + if(0 === c) return [0, d]; + var r$0 = 0 <= c ? r : l; + param$0 = r$0; + } + } + function mem(x, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var + r = param$0[4], + v = param$0[2], + l = param$0[1], + c = caml_call2(Ord[1], x, v), + _E_ = 0 === c ? 1 : 0; + if(_E_) return _E_; + var r$0 = 0 <= c ? r : l; + param$0 = r$0; + } + } + function min_binding(param){ + var param$0 = param; + for(;;){ + if(! param$0) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + var l = param$0[1]; + if(! l){var d = param$0[3], v = param$0[2]; return [0, v, d];} + param$0 = l; + } + } + function min_binding_opt(param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var l = param$0[1]; + if(! l){var d = param$0[3], v = param$0[2]; return [0, [0, v, d]];} + param$0 = l; + } + } + function max_binding(param){ + var param$0 = param; + for(;;){ + if(! param$0) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + if(! param$0[4]){ + var d = param$0[3], v = param$0[2]; + return [0, v, d]; + } + var r = param$0[4]; + param$0 = r; + } + } + function max_binding_opt(param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + if(! param$0[4]){ + var d = param$0[3], v = param$0[2]; + return [0, [0, v, d]]; + } + var r = param$0[4]; + param$0 = r; + } + } + function remove_min_binding(param){ + if(! param) return caml_call1(Stdlib[1], cst_Map_remove_min_elt); + var l = param[1]; + if(l){ + var r = param[4], d = param[3], v = param[2]; + return bal(remove_min_binding(l), v, d, r); + } + var r$0 = param[4]; + return r$0; + } + function _d_(t1, t2){ + if(! t1) return t2; + if(! t2) return t1; + var match = min_binding(t2), d = match[2], x = match[1]; + return bal(t1, x, d, remove_min_binding(t2)); + } + function remove(x, m){ + if(! m) return 0; + var + r = m[4], + d = m[3], + v = m[2], + l = m[1], + c = caml_call2(Ord[1], x, v); + if(0 === c) return _d_(l, r); + if(0 <= c){ + var rr = remove(x, r); + return r === rr ? m : bal(l, v, d, rr); + } + var ll = remove(x, l); + return l === ll ? m : bal(ll, v, d, r); + } + function update(x, f, m){ + if(! m){ + var match$0 = caml_call1(f, 0); + if(! match$0) return 0; + var data$0 = match$0[1]; + return [0, 0, x, data$0, 0, 1]; + } + var + h = m[5], + r = m[4], + d = m[3], + v = m[2], + l = m[1], + c = caml_call2(Ord[1], x, v); + if(0 === c){ + var match = caml_call1(f, [0, d]); + if(! match) return _d_(l, r); + var data = match[1]; + return d === data ? m : [0, l, x, data, r, h]; + } + if(0 <= c){ + var rr = update(x, f, r); + return r === rr ? m : bal(l, v, d, rr); + } + var ll = update(x, f, l); + return l === ll ? m : bal(ll, v, d, r); + } + function iter(f, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var r = param$0[4], d = param$0[3], v = param$0[2], l = param$0[1]; + iter(f, l); + caml_call2(f, v, d); + param$0 = r; + } + } + function map(f, param){ + if(! param) return 0; + var + h = param[5], + r = param[4], + d = param[3], + v = param[2], + l = param[1], + l$0 = map(f, l), + d$0 = caml_call1(f, d), + r$0 = map(f, r); + return [0, l$0, v, d$0, r$0, h]; + } + function mapi(f, param){ + if(! param) return 0; + var + h = param[5], + r = param[4], + d = param[3], + v = param[2], + l = param[1], + l$0 = mapi(f, l), + d$0 = caml_call2(f, v, d), + r$0 = mapi(f, r); + return [0, l$0, v, d$0, r$0, h]; + } + function fold(f, m, accu){ + var m$0 = m, accu$0 = accu; + for(;;){ + if(! m$0) return accu$0; + var + r = m$0[4], + d = m$0[3], + v = m$0[2], + l = m$0[1], + accu$1 = caml_call3(f, v, d, fold(f, l, accu$0)); + m$0 = r; + accu$0 = accu$1; + } + } + function for_all(p, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 1; + var + r = param$0[4], + d = param$0[3], + v = param$0[2], + l = param$0[1], + _B_ = caml_call2(p, v, d); + if(_B_){ + var _C_ = for_all(p, l); + if(_C_){param$0 = r; continue;} + var _D_ = _C_; + } + else + var _D_ = _B_; + return _D_; + } + } + function exists(p, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var + r = param$0[4], + d = param$0[3], + v = param$0[2], + l = param$0[1], + _y_ = caml_call2(p, v, d); + if(_y_) + var _z_ = _y_; + else{ + var _A_ = exists(p, l); + if(! _A_){param$0 = r; continue;} + var _z_ = _A_; + } + return _z_; + } + } + function add_min_binding(k, x, param){ + if(! param) return singleton(k, x); + var r = param[4], d = param[3], v = param[2], l = param[1]; + return bal(add_min_binding(k, x, l), v, d, r); + } + function add_max_binding(k, x, param){ + if(! param) return singleton(k, x); + var r = param[4], d = param[3], v = param[2], l = param[1]; + return bal(l, v, d, add_max_binding(k, x, r)); + } + function join(l, v, d, r){ + if(! l) return add_min_binding(v, d, r); + if(! r) return add_max_binding(v, d, l); + var + rh = r[5], + rr = r[4], + rd = r[3], + rv = r[2], + rl = r[1], + lh = l[5], + lr = l[4], + ld = l[3], + lv = l[2], + ll = l[1]; + return (rh + 2 | 0) < lh + ? bal(ll, lv, ld, join(lr, v, d, r)) + : (lh + + 2 + | 0) + < rh + ? bal(join(l, v, d, rl), rv, rd, rr) + : create(l, v, d, r); + } + function concat(t1, t2){ + if(! t1) return t2; + if(! t2) return t1; + var match = min_binding(t2), d = match[2], x = match[1]; + return join(t1, x, d, remove_min_binding(t2)); + } + function concat_or_join(t1, v, d, t2){ + if(! d) return concat(t1, t2); + var d$0 = d[1]; + return join(t1, v, d$0, t2); + } + function split(x, param){ + if(! param) return _a_; + var + r = param[4], + d = param[3], + v = param[2], + l = param[1], + c = caml_call2(Ord[1], x, v); + if(0 === c) return [0, l, [0, d], r]; + if(0 <= c){ + var + match = split(x, r), + rr = match[3], + pres = match[2], + lr = match[1]; + return [0, join(l, v, d, lr), pres, rr]; + } + var + match$0 = split(x, l), + rl = match$0[3], + pres$0 = match$0[2], + ll = match$0[1]; + return [0, ll, pres$0, join(rl, v, d, r)]; + } + function merge(f, s1, s2){ + if(s1){ + var h1 = s1[5], r1 = s1[4], d1 = s1[3], v1 = s1[2], l1 = s1[1]; + if(height(s2) <= h1){ + var + match = split(v1, s2), + r2 = match[3], + d2 = match[2], + l2 = match[1], + _u_ = merge(f, r1, r2), + _v_ = caml_call3(f, v1, [0, d1], d2); + return concat_or_join(merge(f, l1, l2), v1, _v_, _u_); + } + } + else if(! s2) return 0; + if(! s2) + throw caml_maybe_attach_backtrace([0, Assert_failure, _b_], 1); + var + r2$0 = s2[4], + d2$0 = s2[3], + v2 = s2[2], + l2$0 = s2[1], + match$0 = split(v2, s1), + r1$0 = match$0[3], + d1$0 = match$0[2], + l1$0 = match$0[1], + _w_ = merge(f, r1$0, r2$0), + _x_ = caml_call3(f, v2, d1$0, [0, d2$0]); + return concat_or_join(merge(f, l1$0, l2$0), v2, _x_, _w_); + } + function union(f, s1, s2){ + if(s1){ + if(s2){ + var + h2 = s2[5], + r2 = s2[4], + d2 = s2[3], + v2 = s2[2], + l2 = s2[1], + h1 = s1[5], + r1 = s1[4], + d1 = s1[3], + v1 = s1[2], + l1 = s1[1]; + if(h2 <= h1){ + var + match = split(v1, s2), + r2$0 = match[3], + d2$0 = match[2], + l2$0 = match[1], + l = union(f, l1, l2$0), + r = union(f, r1, r2$0); + if(! d2$0) return join(l, v1, d1, r); + var d2$1 = d2$0[1]; + return concat_or_join(l, v1, caml_call3(f, v1, d1, d2$1), r); + } + var + match$0 = split(v2, s1), + r1$0 = match$0[3], + d1$0 = match$0[2], + l1$0 = match$0[1], + l$0 = union(f, l1$0, l2), + r$0 = union(f, r1$0, r2); + if(! d1$0) return join(l$0, v2, d2, r$0); + var d1$1 = d1$0[1]; + return concat_or_join(l$0, v2, caml_call3(f, v2, d1$1, d2), r$0); + } + var s = s1; + } + else + var s = s2; + return s; + } + function filter(p, m){ + if(! m) return 0; + var + r = m[4], + d = m[3], + v = m[2], + l = m[1], + l$0 = filter(p, l), + pvd = caml_call2(p, v, d), + r$0 = filter(p, r); + if(! pvd) return concat(l$0, r$0); + if(l === l$0 && r === r$0) return m; + return join(l$0, v, d, r$0); + } + function filter_map(f, param){ + if(! param) return 0; + var + r = param[4], + d = param[3], + v = param[2], + l = param[1], + l$0 = filter_map(f, l), + fvd = caml_call2(f, v, d), + r$0 = filter_map(f, r); + if(! fvd) return concat(l$0, r$0); + var d$0 = fvd[1]; + return join(l$0, v, d$0, r$0); + } + function partition(p, param){ + if(! param) return _c_; + var + r = param[4], + d = param[3], + v = param[2], + l = param[1], + match = partition(p, l), + lf = match[2], + lt = match[1], + pvd = caml_call2(p, v, d), + match$0 = partition(p, r), + rf = match$0[2], + rt = match$0[1]; + if(pvd){ + var _s_ = concat(lf, rf); + return [0, join(lt, v, d, rt), _s_]; + } + var _t_ = join(lf, v, d, rf); + return [0, concat(lt, rt), _t_]; + } + function cons_enum(m, e){ + var m$0 = m, e$0 = e; + for(;;){ + if(! m$0) return e$0; + var + r = m$0[4], + d = m$0[3], + v = m$0[2], + l = m$0[1], + e$1 = [0, v, d, r, e$0]; + m$0 = l; + e$0 = e$1; + } + } + function compare(cmp, m1, m2){ + var + e2$2 = cons_enum(m2, 0), + e1$2 = cons_enum(m1, 0), + e1 = e1$2, + e2 = e2$2; + for(;;){ + if(! e1) return e2 ? -1 : 0; + if(! e2) return 1; + var + e2$0 = e2[4], + r2 = e2[3], + d2 = e2[2], + v2 = e2[1], + e1$0 = e1[4], + r1 = e1[3], + d1 = e1[2], + v1 = e1[1], + c = caml_call2(Ord[1], v1, v2); + if(0 !== c) return c; + var c$0 = caml_call2(cmp, d1, d2); + if(0 !== c$0) return c$0; + var e2$1 = cons_enum(r2, e2$0), e1$1 = cons_enum(r1, e1$0); + e1 = e1$1; + e2 = e2$1; + } + } + function equal(cmp, m1, m2){ + var + e2$2 = cons_enum(m2, 0), + e1$2 = cons_enum(m1, 0), + e1 = e1$2, + e2 = e2$2; + for(;;){ + if(! e1) return e2 ? 0 : 1; + if(! e2) return 0; + var + e2$0 = e2[4], + r2 = e2[3], + d2 = e2[2], + v2 = e2[1], + e1$0 = e1[4], + r1 = e1[3], + d1 = e1[2], + v1 = e1[1], + _p_ = 0 === caml_call2(Ord[1], v1, v2) ? 1 : 0; + if(_p_){ + var _q_ = caml_call2(cmp, d1, d2); + if(_q_){ + var e2$1 = cons_enum(r2, e2$0), e1$1 = cons_enum(r1, e1$0); + e1 = e1$1; + e2 = e2$1; + continue; + } + var _r_ = _q_; + } + else + var _r_ = _p_; + return _r_; + } + } + function cardinal(param){ + if(! param) return 0; + var r = param[4], l = param[1], _o_ = cardinal(r); + return (cardinal(l) + 1 | 0) + _o_ | 0; + } + function bindings_aux(accu, param){ + var accu$0 = accu, param$0 = param; + for(;;){ + if(! param$0) return accu$0; + var + r = param$0[4], + d = param$0[3], + v = param$0[2], + l = param$0[1], + accu$1 = [0, [0, v, d], bindings_aux(accu$0, r)]; + accu$0 = accu$1; + param$0 = l; + } + } + function bindings(s){return bindings_aux(0, s);} + function add_seq(i, m){ + return caml_call3 + (Stdlib_Seq[11], + function(m, param){ + var v = param[2], k = param[1]; + return add(k, v, m); + }, + m, + i); + } + function of_seq(i){return add_seq(i, empty);} + function seq_of_enum(c, param){ + if(! c) return 0; + var + rest = c[4], + t = c[3], + v = c[2], + k = c[1], + _m_ = cons_enum(t, rest); + return [0, [0, k, v], function(_n_){return seq_of_enum(_m_, _n_);}]; + } + function to_seq(m){ + var _k_ = cons_enum(m, 0); + return function(_l_){return seq_of_enum(_k_, _l_);}; + } + function snoc_enum(s, e){ + var s$0 = s, e$0 = e; + for(;;){ + if(! s$0) return e$0; + var + r = s$0[4], + d = s$0[3], + v = s$0[2], + l = s$0[1], + e$1 = [0, v, d, l, e$0]; + s$0 = r; + e$0 = e$1; + } + } + function rev_seq_of_enum(c, param){ + if(! c) return 0; + var + rest = c[4], + t = c[3], + v = c[2], + k = c[1], + _i_ = snoc_enum(t, rest); + return [0, + [0, k, v], + function(_j_){return rev_seq_of_enum(_i_, _j_);}]; + } + function to_rev_seq(c){ + var _g_ = snoc_enum(c, 0); + return function(_h_){return rev_seq_of_enum(_g_, _h_);}; + } + function to_seq_from(low, m){ + a: + { + b: + { + var m$0 = m, c = 0; + for(;;){ + if(! m$0) break; + var + r = m$0[4], + d = m$0[3], + v = m$0[2], + l = m$0[1], + n = caml_call2(Ord[1], v, low); + if(0 === n) break b; + if(0 <= n){ + var c$0 = [0, v, d, r, c]; + m$0 = l; + c = c$0; + } + else + m$0 = r; + } + var _e_ = c; + break a; + } + var _e_ = [0, v, d, r, c]; + } + return function(_f_){return seq_of_enum(_e_, _f_);}; + } + return [0, + empty, + is_empty, + mem, + add, + update, + singleton, + remove, + merge, + union, + compare, + equal, + iter, + fold, + for_all, + exists, + filter, + filter_map, + partition, + cardinal, + bindings, + min_binding, + min_binding_opt, + max_binding, + max_binding_opt, + min_binding, + min_binding_opt, + split, + find, + find_opt, + find_first, + find_first_opt, + find_last, + find_last_opt, + map, + mapi, + to_seq, + to_rev_seq, + to_seq_from, + add_seq, + of_seq]; + }]; + runtime.caml_register_global(11, Stdlib_Map, "Stdlib__Map"); + return; + } + (globalThis)); + +//# 8497 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace, + caml_obj_make_forward = runtime.caml_obj_make_forward, + caml_obj_tag = runtime.caml_obj_tag, + caml_wrap_exception = runtime.caml_wrap_exception; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + var + global_data = runtime.caml_get_global_data(), + Stdlib_Obj = global_data.Stdlib__Obj, + Undefined = + [248, "CamlinternalLazy.Undefined", runtime.caml_fresh_oo_id(0)]; + function raise_undefined(param){ + throw caml_maybe_attach_backtrace(Undefined, 1); + } + function force_lazy_block(blk){ + var closure = blk[1]; + blk[1] = raise_undefined; + try{ + var result = caml_call1(closure, 0); + caml_obj_make_forward(blk, result); + return result; + } + catch(e$0){ + var e = caml_wrap_exception(e$0); + blk[1] = function(param){throw caml_maybe_attach_backtrace(e, 0);}; + throw caml_maybe_attach_backtrace(e, 0); + } + } + function force_val_lazy_block(blk){ + var closure = blk[1]; + blk[1] = raise_undefined; + var result = caml_call1(closure, 0); + caml_obj_make_forward(blk, result); + return result; + } + function force(lzv){ + var t = caml_obj_tag(lzv); + return t === Stdlib_Obj[10] + ? lzv[1] + : t !== Stdlib_Obj[6] ? lzv : force_lazy_block(lzv); + } + function force_val(lzv){ + var t = caml_obj_tag(lzv); + return t === Stdlib_Obj[10] + ? lzv[1] + : t !== Stdlib_Obj[6] ? lzv : force_val_lazy_block(lzv); + } + var + CamlinternalLazy = + [0, Undefined, force_lazy_block, force_val_lazy_block, force, force_val]; + runtime.caml_register_global(2, CamlinternalLazy, "CamlinternalLazy"); + return; + } + (globalThis)); + +//# 9012 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_buffer_ml = "buffer.ml", + caml_blit_string = runtime.caml_blit_string, + caml_bswap16 = runtime.caml_bswap16, + caml_bytes_unsafe_get = runtime.caml_bytes_unsafe_get, + caml_bytes_unsafe_set = runtime.caml_bytes_unsafe_set, + caml_create_bytes = runtime.caml_create_bytes, + caml_int32_bswap = runtime.caml_int32_bswap, + caml_int64_bswap = runtime.caml_int64_bswap, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace, + caml_ml_bytes_length = runtime.caml_ml_bytes_length, + caml_ml_string_length = runtime.caml_ml_string_length, + caml_string_get = runtime.caml_string_get; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + function caml_call4(f, a0, a1, a2, a3){ + return (f.l >= 0 ? f.l : f.l = f.length) == 4 + ? f(a0, a1, a2, a3) + : runtime.caml_call_gen(f, [a0, a1, a2, a3]); + } + function caml_call5(f, a0, a1, a2, a3, a4){ + return (f.l >= 0 ? f.l : f.l = f.length) == 5 + ? f(a0, a1, a2, a3, a4) + : runtime.caml_call_gen(f, [a0, a1, a2, a3, a4]); + } + var + undef = undefined, + global_data = runtime.caml_get_global_data(), + Stdlib_Sys = global_data.Stdlib__Sys, + Stdlib_Seq = global_data.Stdlib__Seq, + Stdlib = global_data.Stdlib, + Stdlib_String = global_data.Stdlib__String, + Assert_failure = global_data.Assert_failure, + Stdlib_Bytes = global_data.Stdlib__Bytes, + Stdlib_Uchar = global_data.Stdlib__Uchar, + cst_Buffer_sub = "Buffer.sub", + cst_Buffer_blit = "Buffer.blit", + cst_Buffer_nth = "Buffer.nth", + _a_ = [0, cst_buffer_ml, 94, 2], + _b_ = [0, cst_buffer_ml, 93, 2], + cst_Buffer_add_cannot_grow_buf = "Buffer.add: cannot grow buffer", + _c_ = [0, cst_buffer_ml, 171, 8], + _d_ = [0, cst_buffer_ml, 138, 19], + _e_ = [0, cst_buffer_ml, 192, 8], + _f_ = [0, cst_buffer_ml, 174, 19], + _g_ = [0, cst_buffer_ml, 213, 8], + _h_ = [0, cst_buffer_ml, 195, 19], + cst_Buffer_add_substring_add_s = "Buffer.add_substring/add_subbytes", + _i_ = [0, cst_buffer_ml, 263, 2], + cst_Buffer_add_channel = "Buffer.add_channel", + _j_ = [0, cst_buffer_ml, 282, 9], + cst_Buffer_truncate = "Buffer.truncate"; + function create(n){ + var + n$0 = 1 <= n ? n : 1, + n$1 = Stdlib_Sys[12] < n$0 ? Stdlib_Sys[12] : n$0, + s = caml_create_bytes(n$1); + return [0, s, 0, n$1, s]; + } + function contents(b){return caml_call3(Stdlib_Bytes[8], b[1], 0, b[2]);} + function to_bytes(b){return caml_call3(Stdlib_Bytes[7], b[1], 0, b[2]);} + function sub(b, ofs, len){ + if(0 <= ofs && 0 <= len && (b[2] - len | 0) >= ofs) + return caml_call3(Stdlib_Bytes[8], b[1], ofs, len); + return caml_call1(Stdlib[1], cst_Buffer_sub); + } + function blit(src, srcoff, dst, dstoff, len){ + if + (0 <= len + && + 0 <= srcoff + && + (src[2] - len | 0) >= srcoff + && 0 <= dstoff && (caml_ml_bytes_length(dst) - len | 0) >= dstoff) + return runtime.caml_blit_bytes(src[1], srcoff, dst, dstoff, len); + return caml_call1(Stdlib[1], cst_Buffer_blit); + } + function nth(b, ofs){ + if(0 <= ofs && b[2] > ofs) return caml_bytes_unsafe_get(b[1], ofs); + return caml_call1(Stdlib[1], cst_Buffer_nth); + } + function length(b){return b[2];} + function clear(b){b[2] = 0; return 0;} + function reset(b){ + b[2] = 0; + b[1] = b[4]; + b[3] = caml_ml_bytes_length(b[1]); + return 0; + } + function resize(b, more){ + var old_pos = b[2], old_len = b[3], new_len = [0, old_len]; + for(;;){ + if(new_len[1] >= (old_pos + more | 0)) break; + new_len[1] = 2 * new_len[1] | 0; + } + if(Stdlib_Sys[12] < new_len[1]) + if((old_pos + more | 0) <= Stdlib_Sys[12]) + new_len[1] = Stdlib_Sys[12]; + else + caml_call1(Stdlib[2], cst_Buffer_add_cannot_grow_buf); + var new_buffer = caml_create_bytes(new_len[1]); + caml_call5(Stdlib_Bytes[11], b[1], 0, new_buffer, 0, b[2]); + b[1] = new_buffer; + b[3] = new_len[1]; + if((b[2] + more | 0) > b[3]) + throw caml_maybe_attach_backtrace([0, Assert_failure, _b_], 1); + if((old_pos + more | 0) <= b[3]) return; + throw caml_maybe_attach_backtrace([0, Assert_failure, _a_], 1); + } + function add_char(b, c){ + var pos = b[2]; + if(b[3] <= pos) resize(b, 1); + caml_bytes_unsafe_set(b[1], pos, c); + b[2] = pos + 1 | 0; + return 0; + } + function add_utf_8_uchar(b, u){ + var u$0 = caml_call1(Stdlib_Uchar[10], u); + if(0 > u$0) + throw caml_maybe_attach_backtrace([0, Assert_failure, _d_], 1); + if(127 >= u$0) return add_char(b, u$0); + if(2047 >= u$0){ + var pos$1 = b[2]; + if(b[3] < (pos$1 + 2 | 0)) resize(b, 2); + caml_bytes_unsafe_set(b[1], pos$1, 192 | u$0 >>> 6 | 0); + caml_bytes_unsafe_set(b[1], pos$1 + 1 | 0, 128 | u$0 & 63); + b[2] = pos$1 + 2 | 0; + return 0; + } + if(65535 < u$0){ + if(1114111 < u$0) + throw caml_maybe_attach_backtrace([0, Assert_failure, _c_], 1); + var pos = b[2]; + if(b[3] < (pos + 4 | 0)) resize(b, 4); + caml_bytes_unsafe_set(b[1], pos, 240 | u$0 >>> 18 | 0); + caml_bytes_unsafe_set(b[1], pos + 1 | 0, 128 | (u$0 >>> 12 | 0) & 63); + caml_bytes_unsafe_set(b[1], pos + 2 | 0, 128 | (u$0 >>> 6 | 0) & 63); + caml_bytes_unsafe_set(b[1], pos + 3 | 0, 128 | u$0 & 63); + b[2] = pos + 4 | 0; + return 0; + } + var pos$0 = b[2]; + if(b[3] < (pos$0 + 3 | 0)) resize(b, 3); + caml_bytes_unsafe_set(b[1], pos$0, 224 | u$0 >>> 12 | 0); + caml_bytes_unsafe_set(b[1], pos$0 + 1 | 0, 128 | (u$0 >>> 6 | 0) & 63); + caml_bytes_unsafe_set(b[1], pos$0 + 2 | 0, 128 | u$0 & 63); + b[2] = pos$0 + 3 | 0; + return 0; + } + function add_utf_16be_uchar(b, u){ + var u$0 = caml_call1(Stdlib_Uchar[10], u); + if(0 > u$0) + throw caml_maybe_attach_backtrace([0, Assert_failure, _f_], 1); + if(65535 < u$0){ + if(1114111 < u$0) + throw caml_maybe_attach_backtrace([0, Assert_failure, _e_], 1); + var + u$1 = u$0 - 65536 | 0, + hi = 55296 | u$1 >>> 10 | 0, + lo = 56320 | u$1 & 1023, + pos = b[2]; + if(b[3] < (pos + 4 | 0)) resize(b, 4); + caml_bytes_unsafe_set(b[1], pos, hi >>> 8 | 0); + caml_bytes_unsafe_set(b[1], pos + 1 | 0, hi & 255); + caml_bytes_unsafe_set(b[1], pos + 2 | 0, lo >>> 8 | 0); + caml_bytes_unsafe_set(b[1], pos + 3 | 0, lo & 255); + b[2] = pos + 4 | 0; + return 0; + } + var pos$0 = b[2]; + if(b[3] < (pos$0 + 2 | 0)) resize(b, 2); + caml_bytes_unsafe_set(b[1], pos$0, u$0 >>> 8 | 0); + caml_bytes_unsafe_set(b[1], pos$0 + 1 | 0, u$0 & 255); + b[2] = pos$0 + 2 | 0; + return 0; + } + function add_utf_16le_uchar(b, u){ + var u$0 = caml_call1(Stdlib_Uchar[10], u); + if(0 > u$0) + throw caml_maybe_attach_backtrace([0, Assert_failure, _h_], 1); + if(65535 < u$0){ + if(1114111 < u$0) + throw caml_maybe_attach_backtrace([0, Assert_failure, _g_], 1); + var + u$1 = u$0 - 65536 | 0, + hi = 55296 | u$1 >>> 10 | 0, + lo = 56320 | u$1 & 1023, + pos = b[2]; + if(b[3] < (pos + 4 | 0)) resize(b, 4); + caml_bytes_unsafe_set(b[1], pos, hi & 255); + caml_bytes_unsafe_set(b[1], pos + 1 | 0, hi >>> 8 | 0); + caml_bytes_unsafe_set(b[1], pos + 2 | 0, lo & 255); + caml_bytes_unsafe_set(b[1], pos + 3 | 0, lo >>> 8 | 0); + b[2] = pos + 4 | 0; + return 0; + } + var pos$0 = b[2]; + if(b[3] < (pos$0 + 2 | 0)) resize(b, 2); + caml_bytes_unsafe_set(b[1], pos$0, u$0 & 255); + caml_bytes_unsafe_set(b[1], pos$0 + 1 | 0, u$0 >>> 8 | 0); + b[2] = pos$0 + 2 | 0; + return 0; + } + function add_substring(b, s, offset, len){ + var _z_ = offset < 0 ? 1 : 0; + if(_z_) + var _A_ = _z_; + else + var + _B_ = len < 0 ? 1 : 0, + _A_ = _B_ || ((caml_ml_string_length(s) - len | 0) < offset ? 1 : 0); + if(_A_) caml_call1(Stdlib[1], cst_Buffer_add_substring_add_s); + var new_position = b[2] + len | 0; + if(b[3] < new_position) resize(b, len); + caml_blit_string(s, offset, b[1], b[2], len); + b[2] = new_position; + return 0; + } + function add_subbytes(b, s, offset, len){ + return add_substring(b, caml_call1(Stdlib_Bytes[48], s), offset, len); + } + function add_string(b, s){ + var len = caml_ml_string_length(s), new_position = b[2] + len | 0; + if(b[3] < new_position) resize(b, len); + caml_blit_string(s, 0, b[1], b[2], len); + b[2] = new_position; + return 0; + } + function add_bytes(b, s){ + return add_string(b, caml_call1(Stdlib_Bytes[48], s)); + } + function add_buffer(b, bs){return add_subbytes(b, bs[1], 0, bs[2]);} + function add_channel(b, ic, to_read$1){ + var + _x_ = to_read$1 < 0 ? 1 : 0, + _y_ = _x_ || (Stdlib_Sys[12] < to_read$1 ? 1 : 0); + if(_y_) caml_call1(Stdlib[1], cst_Buffer_add_channel); + if(b[3] < (b[2] + to_read$1 | 0)) resize(b, to_read$1); + var + ofs$1 = b[2], + buf = b[1], + already_read = 0, + ofs = ofs$1, + to_read = to_read$1; + for(;;){ + if(0 !== to_read){ + var r = caml_call4(Stdlib[84], ic, buf, ofs, to_read); + if(0 !== r){ + var + already_read$0 = already_read + r | 0, + ofs$0 = ofs + r | 0, + to_read$0 = to_read - r | 0; + already_read = already_read$0; + ofs = ofs$0; + to_read = to_read$0; + continue; + } + } + if((b[2] + already_read | 0) > b[3]) + throw caml_maybe_attach_backtrace([0, Assert_failure, _i_], 1); + b[2] = b[2] + already_read | 0; + if(already_read < to_read$1) + throw caml_maybe_attach_backtrace(Stdlib[12], 1); + return 0; + } + } + function output_buffer(oc, b){ + return caml_call4(Stdlib[68], oc, b[1], 0, b[2]); + } + function add_substitute(b, f, s){ + var lim$1 = caml_ml_string_length(s), previous = 32, i$4 = 0; + for(;;){ + if(i$4 >= lim$1){ + var _w_ = 92 === previous ? 1 : 0; + return _w_ ? add_char(b, previous) : _w_; + } + var previous$0 = caml_string_get(s, i$4); + if(36 === previous$0) + if(92 === previous){ + add_char(b, previous$0); + var i$5 = i$4 + 1 | 0; + previous = 32; + i$4 = i$5; + } + else{ + var start$0 = i$4 + 1 | 0; + if(lim$1 <= start$0) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + var opening = caml_string_get(s, start$0); + a: + { + if(40 !== opening && 123 !== opening){ + var start = start$0 + 1 | 0, lim$0 = caml_ml_string_length(s); + b: + { + c: + { + d: + { + var i$2 = start; + for(;;){ + if(lim$0 <= i$2) break c; + var match = caml_string_get(s, i$2); + if(91 <= match){ + if(97 <= match){ + if(123 <= match) break d; + } + else if(95 !== match) break d; + } + else + if(58 <= match){ + if(65 > match) break; + } + else if(48 > match) break d; + var i$3 = i$2 + 1 | 0; + i$2 = i$3; + } + } + var stop$0 = i$2; + break b; + } + var stop$0 = lim$0; + } + var + match$0 = + [0, + caml_call3(Stdlib_String[15], s, start$0, stop$0 - start$0 | 0), + stop$0]; + break a; + } + var new_start = start$0 + 1 | 0, k$2 = 0; + if(40 === opening) + var closing = 41; + else{ + if(123 !== opening) + throw caml_maybe_attach_backtrace([0, Assert_failure, _j_], 1); + var closing = 125; + } + var lim = caml_ml_string_length(s), k = k$2, stop = new_start; + for(;;){ + if(lim <= stop) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + if(caml_string_get(s, stop) === opening){ + var i = stop + 1 | 0, k$0 = k + 1 | 0; + k = k$0; + stop = i; + } + else if(caml_string_get(s, stop) === closing){ + if(0 === k) break; + var i$0 = stop + 1 | 0, k$1 = k - 1 | 0; + k = k$1; + stop = i$0; + } + else{var i$1 = stop + 1 | 0; stop = i$1;} + } + var + match$0 = + [0, + caml_call3 + (Stdlib_String[15], s, new_start, (stop - start$0 | 0) - 1 | 0), + stop + 1 | 0]; + } + var next_i = match$0[2], ident = match$0[1]; + add_string(b, caml_call1(f, ident)); + previous = 32; + i$4 = next_i; + } + else if(92 === previous){ + add_char(b, 92); + add_char(b, previous$0); + var i$6 = i$4 + 1 | 0; + previous = 32; + i$4 = i$6; + } + else if(92 === previous$0){ + var i$7 = i$4 + 1 | 0; + previous = previous$0; + i$4 = i$7; + } + else{ + add_char(b, previous$0); + var i$8 = i$4 + 1 | 0; + previous = previous$0; + i$4 = i$8; + } + } + } + function truncate(b, len){ + if(0 <= len && b[2] >= len){b[2] = len; return 0;} + return caml_call1(Stdlib[1], cst_Buffer_truncate); + } + function to_seq(b){ + function aux(i, param){ + if(b[2] <= i) return 0; + var x = caml_bytes_unsafe_get(b[1], i), _u_ = i + 1 | 0; + return [0, x, function(_v_){return aux(_u_, _v_);}]; + } + var _s_ = 0; + return function(_t_){return aux(_s_, _t_);}; + } + function to_seqi(b){ + function aux(i, param){ + if(b[2] <= i) return 0; + var x = caml_bytes_unsafe_get(b[1], i), _q_ = i + 1 | 0; + return [0, [0, i, x], function(_r_){return aux(_q_, _r_);}]; + } + var _o_ = 0; + return function(_p_){return aux(_o_, _p_);}; + } + function add_seq(b, seq){ + return caml_call2 + (Stdlib_Seq[12], function(_n_){return add_char(b, _n_);}, seq); + } + function of_seq(i){var b = create(32); add_seq(b, i); return b;} + function add_int8(b, x){ + var new_position = b[2] + 1 | 0; + if(b[3] < new_position) resize(b, 1); + caml_bytes_unsafe_set(b[1], b[2], x); + b[2] = new_position; + return 0; + } + function add_int16_ne(b, x){ + var new_position = b[2] + 2 | 0; + if(b[3] < new_position) resize(b, 2); + runtime.caml_bytes_set16(b[1], b[2], x); + b[2] = new_position; + return 0; + } + function add_int32_ne(b, x){ + var new_position = b[2] + 4 | 0; + if(b[3] < new_position) resize(b, 4); + runtime.caml_bytes_set32(b[1], b[2], x); + b[2] = new_position; + return 0; + } + function add_int64_ne(b, x){ + var new_position = b[2] + 8 | 0; + if(b[3] < new_position) resize(b, 8); + runtime.caml_bytes_set64(b[1], b[2], x); + b[2] = new_position; + return 0; + } + function add_int16_le(b, x){ + var _m_ = Stdlib_Sys[11] ? caml_bswap16(x) : x; + return add_int16_ne(b, _m_); + } + function add_int16_be(b, x){ + var x$0 = Stdlib_Sys[11] ? x : caml_bswap16(x); + return add_int16_ne(b, x$0); + } + function add_int32_le(b, x){ + var _l_ = Stdlib_Sys[11] ? caml_int32_bswap(x) : x; + return add_int32_ne(b, _l_); + } + function add_int32_be(b, x){ + var x$0 = Stdlib_Sys[11] ? x : caml_int32_bswap(x); + return add_int32_ne(b, x$0); + } + function add_int64_le(b, x){ + var _k_ = Stdlib_Sys[11] ? caml_int64_bswap(x) : x; + return add_int64_ne(b, _k_); + } + function add_int64_be(b, x){ + var x$0 = Stdlib_Sys[11] ? x : caml_int64_bswap(x); + return add_int64_ne(b, x$0); + } + var + Stdlib_Buffer = + [0, + create, + contents, + to_bytes, + sub, + blit, + nth, + length, + clear, + reset, + output_buffer, + truncate, + add_char, + add_utf_8_uchar, + add_utf_16le_uchar, + add_utf_16be_uchar, + add_string, + add_bytes, + add_substring, + add_subbytes, + add_substitute, + add_buffer, + add_channel, + to_seq, + to_seqi, + add_seq, + of_seq, + add_int8, + add_int8, + add_int16_ne, + add_int16_be, + add_int16_le, + add_int16_ne, + add_int16_be, + add_int16_le, + add_int32_ne, + add_int32_be, + add_int32_le, + add_int64_ne, + add_int64_be, + add_int64_le]; + runtime.caml_register_global(24, Stdlib_Buffer, "Stdlib__Buffer"); + return; + } + (globalThis)); + +//# 9543 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst$43 = "", + cst_and = " and ", + cst_Li$3 = "%Li", + cst_i$3 = "%i", + cst_li$3 = "%li", + cst_ni$3 = "%ni", + cst_u$0 = "%u", + cst$42 = "' '", + cst$41 = "'#'", + cst$39 = "'*'", + cst$40 = "'+'", + cst$44 = ", ", + cst_0$3 = "0", + cst_at_character_number = ": at character number ", + cst$38 = "@[", + cst$37 = "@{", + cst_bad_input_format_type_mism = + "bad input: format type mismatch between ", + cst_bad_input_format_type_mism$0 = + "bad input: format type mismatch between %S and %S", + cst_camlinternalFormat_ml = "camlinternalFormat.ml", + cst_invalid_format = "invalid format ", + cst_precision$3 = "precision", + caml_blit_string = runtime.caml_blit_string, + caml_bytes_set = runtime.caml_bytes_set, + caml_create_bytes = runtime.caml_create_bytes, + caml_format_float = runtime.caml_format_float, + caml_format_int = runtime.caml_format_int, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace, + caml_ml_string_length = runtime.caml_ml_string_length, + caml_notequal = runtime.caml_notequal, + caml_string_get = runtime.caml_string_get, + caml_string_unsafe_get = runtime.caml_string_unsafe_get, + caml_trampoline = runtime.caml_trampoline, + caml_trampoline_return = runtime.caml_trampoline_return, + caml_wrap_exception = runtime.caml_wrap_exception; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + function caml_call4(f, a0, a1, a2, a3){ + return (f.l >= 0 ? f.l : f.l = f.length) == 4 + ? f(a0, a1, a2, a3) + : runtime.caml_call_gen(f, [a0, a1, a2, a3]); + } + function caml_call5(f, a0, a1, a2, a3, a4){ + return (f.l >= 0 ? f.l : f.l = f.length) == 5 + ? f(a0, a1, a2, a3, a4) + : runtime.caml_call_gen(f, [a0, a1, a2, a3, a4]); + } + var + undef = undefined, + global_data = runtime.caml_get_global_data(), + cst$9 = "%{", + cst$10 = "%}", + cst$11 = "%(", + cst$12 = "%)", + cst$13 = "%?", + cst$18 = cst$37, + cst$19 = cst$38, + cst$20 = cst$37, + cst$21 = cst$38, + cst$22 = cst$37, + cst$23 = cst$38, + cst$26 = cst$39, + cst$24 = "'-'", + cst$25 = cst$39, + cst$27 = cst$40, + cst$28 = cst$41, + cst$29 = cst$42, + cst$30 = cst$40, + cst$31 = "'_'", + sub_format = [0, 0, cst$43], + formatting_lit = [0, "@;", 1, 0], + cst$35 = cst$41, + cst$32 = cst$40, + cst$33 = cst$40, + cst$34 = cst$42, + cst$36 = cst$40, + cst_unexpected_end_of_format = "unexpected end of format", + cst$17 = ".", + cst$14 = "%!", + cst$15 = cst$37, + cst$16 = cst$38, + cst$8 = "%%", + cst$0 = "@]", + cst$1 = "@}", + cst$2 = "@?", + cst$3 = "@\n", + cst$4 = "@.", + cst$5 = "@@", + cst$6 = "@%", + cst$7 = "@", + cst = ".*", + Assert_failure = global_data.Assert_failure, + CamlinternalFormatBasics = global_data.CamlinternalFormatBasics, + Stdlib = global_data.Stdlib, + Stdlib_Buffer = global_data.Stdlib__Buffer, + Stdlib_String = global_data.Stdlib__String, + Stdlib_Sys = global_data.Stdlib__Sys, + Stdlib_Char = global_data.Stdlib__Char, + Stdlib_Bytes = global_data.Stdlib__Bytes, + Stdlib_Int = global_data.Stdlib__Int, + _a_ = [0, 0, 0], + cst_c = "%c", + cst_s = "%s", + cst_i = cst_i$3, + cst_li = cst_li$3, + cst_ni = cst_ni$3, + cst_Li = cst_Li$3, + cst_f = "%f", + cst_B = "%B", + cst_a = "%a", + cst_t = "%t", + cst_r = "%r", + cst_r$0 = "%_r", + cst_0c = "0c", + _b_ = [0, cst_camlinternalFormat_ml, 850, 23], + _c_ = [0, cst_camlinternalFormat_ml, 837, 26], + _d_ = [0, cst_camlinternalFormat_ml, 847, 28], + _e_ = [0, cst_camlinternalFormat_ml, 815, 21], + _f_ = [0, cst_camlinternalFormat_ml, 819, 21], + _g_ = [0, cst_camlinternalFormat_ml, 823, 19], + _h_ = [0, cst_camlinternalFormat_ml, 827, 22], + _i_ = [0, cst_camlinternalFormat_ml, 832, 30], + _j_ = [0, cst_camlinternalFormat_ml, 851, 23], + _k_ = [0, cst_camlinternalFormat_ml, 836, 26], + _l_ = [0, cst_camlinternalFormat_ml, 846, 28], + _m_ = [0, cst_camlinternalFormat_ml, 814, 21], + _n_ = [0, cst_camlinternalFormat_ml, 818, 21], + _o_ = [0, cst_camlinternalFormat_ml, 822, 19], + _p_ = [0, cst_camlinternalFormat_ml, 826, 22], + _q_ = [0, cst_camlinternalFormat_ml, 831, 30]; + function create_char_set(param){return caml_call2(Stdlib_Bytes[1], 32, 0);} + function add_in_char_set(char_set, c){ + var + str_ind = c >>> 3 | 0, + mask = 1 << (c & 7), + _cU_ = runtime.caml_bytes_get(char_set, str_ind) | mask; + return caml_bytes_set(char_set, str_ind, caml_call1(Stdlib[29], _cU_)); + } + function freeze_char_set(char_set){ + return caml_call1(Stdlib_Bytes[6], char_set); + } + function rev_char_set(char_set){ + var char_set$0 = create_char_set(0), i = 0; + for(;;){ + var _cS_ = caml_string_get(char_set, i) ^ 255; + caml_bytes_set(char_set$0, i, caml_call1(Stdlib[29], _cS_)); + var _cT_ = i + 1 | 0; + if(31 === i) return caml_call1(Stdlib_Bytes[48], char_set$0); + i = _cT_; + } + } + function is_in_char_set(char_set, c){ + var str_ind = c >>> 3 | 0, mask = 1 << (c & 7); + return 0 !== (caml_string_get(char_set, str_ind) & mask) ? 1 : 0; + } + function pad_of_pad_opt(pad_opt){ + if(! pad_opt) return 0; + var width = pad_opt[1]; + return [0, 1, width]; + } + function param_format_of_ignored_format(ign, fmt){ + if(typeof ign === "number") + switch(ign){ + case 0: + return [0, [0, fmt]]; + case 1: + return [0, [1, fmt]]; + case 2: + return [0, [19, fmt]]; + default: return [0, [22, fmt]]; + } + switch(ign[0]){ + case 0: + var pad_opt = ign[1]; return [0, [2, pad_of_pad_opt(pad_opt), fmt]]; + case 1: + var pad_opt$0 = ign[1]; + return [0, [3, pad_of_pad_opt(pad_opt$0), fmt]]; + case 2: + var pad_opt$1 = ign[2], iconv = ign[1]; + return [0, [4, iconv, pad_of_pad_opt(pad_opt$1), 0, fmt]]; + case 3: + var pad_opt$2 = ign[2], iconv$0 = ign[1]; + return [0, [5, iconv$0, pad_of_pad_opt(pad_opt$2), 0, fmt]]; + case 4: + var pad_opt$3 = ign[2], iconv$1 = ign[1]; + return [0, [6, iconv$1, pad_of_pad_opt(pad_opt$3), 0, fmt]]; + case 5: + var pad_opt$4 = ign[2], iconv$2 = ign[1]; + return [0, [7, iconv$2, pad_of_pad_opt(pad_opt$4), 0, fmt]]; + case 6: + var prec_opt = ign[2], pad_opt$5 = ign[1]; + if(prec_opt) + var ndec = prec_opt[1], _cR_ = [0, ndec]; + else + var _cR_ = 0; + return [0, [8, _a_, pad_of_pad_opt(pad_opt$5), _cR_, fmt]]; + case 7: + var pad_opt$6 = ign[1]; + return [0, [9, pad_of_pad_opt(pad_opt$6), fmt]]; + case 8: + var fmtty = ign[2], pad_opt$7 = ign[1]; + return [0, [13, pad_opt$7, fmtty, fmt]]; + case 9: + var fmtty$0 = ign[2], pad_opt$8 = ign[1]; + return [0, [14, pad_opt$8, fmtty$0, fmt]]; + case 10: + var char_set = ign[2], width_opt = ign[1]; + return [0, [20, width_opt, char_set, fmt]]; + default: var counter = ign[1]; return [0, [21, counter, fmt]]; + } + } + function default_float_precision(fconv){return 5 === fconv[2] ? 12 : -6;} + function buffer_create(init_size){ + return [0, 0, caml_create_bytes(init_size)]; + } + function buffer_check_size(buf, overhead){ + var + len = runtime.caml_ml_bytes_length(buf[2]), + min_len = buf[1] + overhead | 0; + if(len < min_len){ + var + new_len = caml_call2(Stdlib_Int[11], len * 2 | 0, min_len), + new_str = caml_create_bytes(new_len); + caml_call5(Stdlib_Bytes[11], buf[2], 0, new_str, 0, len); + buf[2] = new_str; + } + return; + } + function buffer_add_char(buf, c){ + buffer_check_size(buf, 1); + caml_bytes_set(buf[2], buf[1], c); + buf[1] = buf[1] + 1 | 0; + return; + } + function buffer_add_string(buf, s){ + var str_len = caml_ml_string_length(s); + buffer_check_size(buf, str_len); + caml_call5(Stdlib_String[42], s, 0, buf[2], buf[1], str_len); + buf[1] = buf[1] + str_len | 0; + return; + } + function buffer_contents(buf){ + return caml_call3(Stdlib_Bytes[8], buf[2], 0, buf[1]); + } + function char_of_iconv(iconv){ + switch(iconv){ + case 6: + case 7: + return 120; + case 8: + case 9: + return 88; + case 10: + case 11: + return 111; + case 12: + case 15: + return 117; + case 0: + case 1: + case 2: + case 13: + return 100; + default: return 105; + } + } + function char_of_fconv(opt, fconv){ + if(opt) var sth = opt[1], cF = sth; else var cF = 70; + switch(fconv[2]){ + case 0: + return 102; + case 1: + return 101; + case 2: + return 69; + case 3: + return 103; + case 4: + return 71; + case 5: + return cF; + case 6: + return 104; + case 7: + return 72; + default: return 70; + } + } + function bprint_padty(buf, padty){ + switch(padty){ + case 0: + return buffer_add_char(buf, 45); + case 1: + return; + default: return buffer_add_char(buf, 48); + } + } + function bprint_ignored_flag(buf, ign_flag){ + return ign_flag ? buffer_add_char(buf, 95) : ign_flag; + } + function bprint_pad_opt(buf, pad_opt){ + if(! pad_opt) return; + var width = pad_opt[1]; + return buffer_add_string(buf, caml_call1(Stdlib_Int[12], width)); + } + function bprint_padding(buf, pad){ + if(typeof pad === "number") return; + if(0 === pad[0]){ + var n = pad[2], padty = pad[1]; + bprint_padty(buf, padty); + return buffer_add_string(buf, caml_call1(Stdlib_Int[12], n)); + } + var padty$0 = pad[1]; + bprint_padty(buf, padty$0); + return buffer_add_char(buf, 42); + } + function bprint_precision(buf, prec){ + if(typeof prec !== "number"){ + var n = prec[1]; + buffer_add_char(buf, 46); + return buffer_add_string(buf, caml_call1(Stdlib_Int[12], n)); + } + if(prec) return buffer_add_string(buf, cst); + return; + } + function bprint_iconv_flag(buf, iconv){ + switch(iconv){ + case 1: + case 4: + return buffer_add_char(buf, 43); + case 2: + case 5: + return buffer_add_char(buf, 32); + case 7: + case 9: + case 11: + case 13: + case 14: + case 15: + return buffer_add_char(buf, 35); + default: return; + } + } + function bprint_altint_fmt(buf, ign_flag, iconv, pad, prec, c){ + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag); + bprint_iconv_flag(buf, iconv); + bprint_padding(buf, pad); + bprint_precision(buf, prec); + buffer_add_char(buf, c); + return buffer_add_char(buf, char_of_iconv(iconv)); + } + function bprint_fconv_flag(buf, fconv){ + switch(fconv[1]){ + case 0: break; + case 1: + buffer_add_char(buf, 43); break; + default: buffer_add_char(buf, 32); + } + if(8 <= fconv[2]) return buffer_add_char(buf, 35); + return; + } + function string_of_formatting_lit(formatting_lit){ + if(typeof formatting_lit === "number") + switch(formatting_lit){ + case 0: + return cst$0; + case 1: + return cst$1; + case 2: + return cst$2; + case 3: + return cst$3; + case 4: + return cst$4; + case 5: + return cst$5; + default: return cst$6; + } + switch(formatting_lit[0]){ + case 0: + var str = formatting_lit[1]; return str; + case 1: + var str$0 = formatting_lit[1]; return str$0; + default: + var c = formatting_lit[1], _cQ_ = caml_call2(Stdlib_String[1], 1, c); + return caml_call2(Stdlib[28], cst$7, _cQ_); + } + } + function bprint_char_literal(buf, chr){ + return 37 === chr + ? buffer_add_string(buf, cst$8) + : buffer_add_char(buf, chr); + } + function bprint_string_literal(buf, str){ + var _cO_ = caml_ml_string_length(str) - 1 | 0, _cN_ = 0; + if(_cO_ >= 0){ + var i = _cN_; + for(;;){ + bprint_char_literal(buf, caml_string_get(str, i)); + var _cP_ = i + 1 | 0; + if(_cO_ === i) break; + i = _cP_; + } + } + return; + } + function bprint_fmtty(buf, fmtty){ + var fmtty$0 = fmtty; + for(;;){ + if(typeof fmtty$0 === "number") return; + switch(fmtty$0[0]){ + case 0: + var fmtty$1 = fmtty$0[1]; + buffer_add_string(buf, cst_c); + fmtty$0 = fmtty$1; + break; + case 1: + var fmtty$2 = fmtty$0[1]; + buffer_add_string(buf, cst_s); + fmtty$0 = fmtty$2; + break; + case 2: + var fmtty$3 = fmtty$0[1]; + buffer_add_string(buf, cst_i); + fmtty$0 = fmtty$3; + break; + case 3: + var fmtty$4 = fmtty$0[1]; + buffer_add_string(buf, cst_li); + fmtty$0 = fmtty$4; + break; + case 4: + var fmtty$5 = fmtty$0[1]; + buffer_add_string(buf, cst_ni); + fmtty$0 = fmtty$5; + break; + case 5: + var fmtty$6 = fmtty$0[1]; + buffer_add_string(buf, cst_Li); + fmtty$0 = fmtty$6; + break; + case 6: + var fmtty$7 = fmtty$0[1]; + buffer_add_string(buf, cst_f); + fmtty$0 = fmtty$7; + break; + case 7: + var fmtty$8 = fmtty$0[1]; + buffer_add_string(buf, cst_B); + fmtty$0 = fmtty$8; + break; + case 8: + var fmtty$9 = fmtty$0[2], sub_fmtty = fmtty$0[1]; + buffer_add_string(buf, cst$9); + bprint_fmtty(buf, sub_fmtty); + buffer_add_string(buf, cst$10); + fmtty$0 = fmtty$9; + break; + case 9: + var fmtty$10 = fmtty$0[3], sub_fmtty$0 = fmtty$0[1]; + buffer_add_string(buf, cst$11); + bprint_fmtty(buf, sub_fmtty$0); + buffer_add_string(buf, cst$12); + fmtty$0 = fmtty$10; + break; + case 10: + var fmtty$11 = fmtty$0[1]; + buffer_add_string(buf, cst_a); + fmtty$0 = fmtty$11; + break; + case 11: + var fmtty$12 = fmtty$0[1]; + buffer_add_string(buf, cst_t); + fmtty$0 = fmtty$12; + break; + case 12: + var fmtty$13 = fmtty$0[1]; + buffer_add_string(buf, cst$13); + fmtty$0 = fmtty$13; + break; + case 13: + var fmtty$14 = fmtty$0[1]; + buffer_add_string(buf, cst_r); + fmtty$0 = fmtty$14; + break; + default: + var fmtty$15 = fmtty$0[1]; + buffer_add_string(buf, cst_r$0); + fmtty$0 = fmtty$15; + } + } + } + function int_of_custom_arity(param){ + if(! param) return 0; + var x = param[1]; + return 1 + int_of_custom_arity(x) | 0; + } + function string_of_fmt(fmt){ + var buf = buffer_create(16); + function fmtiter(fmt, ign_flag){ + var fmt$0 = fmt, ign_flag$0 = ign_flag; + for(;;){ + if(typeof fmt$0 === "number") return; + switch(fmt$0[0]){ + case 0: + var rest = fmt$0[1]; + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + buffer_add_char(buf, 99); + fmt$0 = rest; + ign_flag$0 = 0; + break; + case 1: + var rest$0 = fmt$0[1]; + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + buffer_add_char(buf, 67); + fmt$0 = rest$0; + ign_flag$0 = 0; + break; + case 2: + var rest$1 = fmt$0[2], pad = fmt$0[1]; + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + bprint_padding(buf, pad); + buffer_add_char(buf, 115); + fmt$0 = rest$1; + ign_flag$0 = 0; + break; + case 3: + var rest$2 = fmt$0[2], pad$0 = fmt$0[1]; + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + bprint_padding(buf, pad$0); + buffer_add_char(buf, 83); + fmt$0 = rest$2; + ign_flag$0 = 0; + break; + case 4: + var + rest$3 = fmt$0[4], + prec = fmt$0[3], + pad$1 = fmt$0[2], + iconv = fmt$0[1]; + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + bprint_iconv_flag(buf, iconv); + bprint_padding(buf, pad$1); + bprint_precision(buf, prec); + buffer_add_char(buf, char_of_iconv(iconv)); + fmt$0 = rest$3; + ign_flag$0 = 0; + break; + case 5: + var + rest$4 = fmt$0[4], + prec$0 = fmt$0[3], + pad$2 = fmt$0[2], + iconv$0 = fmt$0[1]; + bprint_altint_fmt(buf, ign_flag$0, iconv$0, pad$2, prec$0, 108); + fmt$0 = rest$4; + ign_flag$0 = 0; + break; + case 6: + var + rest$5 = fmt$0[4], + prec$1 = fmt$0[3], + pad$3 = fmt$0[2], + iconv$1 = fmt$0[1]; + bprint_altint_fmt(buf, ign_flag$0, iconv$1, pad$3, prec$1, 110); + fmt$0 = rest$5; + ign_flag$0 = 0; + break; + case 7: + var + rest$6 = fmt$0[4], + prec$2 = fmt$0[3], + pad$4 = fmt$0[2], + iconv$2 = fmt$0[1]; + bprint_altint_fmt(buf, ign_flag$0, iconv$2, pad$4, prec$2, 76); + fmt$0 = rest$6; + ign_flag$0 = 0; + break; + case 8: + var + rest$7 = fmt$0[4], + prec$3 = fmt$0[3], + pad$5 = fmt$0[2], + fconv = fmt$0[1]; + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + bprint_fconv_flag(buf, fconv); + bprint_padding(buf, pad$5); + bprint_precision(buf, prec$3); + buffer_add_char(buf, char_of_fconv(0, fconv)); + fmt$0 = rest$7; + ign_flag$0 = 0; + break; + case 9: + var rest$8 = fmt$0[2], pad$6 = fmt$0[1]; + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + bprint_padding(buf, pad$6); + buffer_add_char(buf, 66); + fmt$0 = rest$8; + ign_flag$0 = 0; + break; + case 10: + var rest$9 = fmt$0[1]; + buffer_add_string(buf, cst$14); + fmt$0 = rest$9; + break; + case 11: + var rest$10 = fmt$0[2], str = fmt$0[1]; + bprint_string_literal(buf, str); + fmt$0 = rest$10; + break; + case 12: + var rest$11 = fmt$0[2], chr = fmt$0[1]; + bprint_char_literal(buf, chr); + fmt$0 = rest$11; + break; + case 13: + var rest$12 = fmt$0[3], fmtty = fmt$0[2], pad_opt = fmt$0[1]; + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + bprint_pad_opt(buf, pad_opt); + buffer_add_char(buf, 123); + bprint_fmtty(buf, fmtty); + buffer_add_char(buf, 37); + buffer_add_char(buf, 125); + fmt$0 = rest$12; + ign_flag$0 = 0; + break; + case 14: + var rest$13 = fmt$0[3], fmtty$0 = fmt$0[2], pad_opt$0 = fmt$0[1]; + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + bprint_pad_opt(buf, pad_opt$0); + buffer_add_char(buf, 40); + bprint_fmtty(buf, fmtty$0); + buffer_add_char(buf, 37); + buffer_add_char(buf, 41); + fmt$0 = rest$13; + ign_flag$0 = 0; + break; + case 15: + var rest$14 = fmt$0[1]; + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + buffer_add_char(buf, 97); + fmt$0 = rest$14; + ign_flag$0 = 0; + break; + case 16: + var rest$15 = fmt$0[1]; + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + buffer_add_char(buf, 116); + fmt$0 = rest$15; + ign_flag$0 = 0; + break; + case 17: + var rest$16 = fmt$0[2], fmting_lit = fmt$0[1]; + bprint_string_literal(buf, string_of_formatting_lit(fmting_lit)); + fmt$0 = rest$16; + break; + case 18: + var rest$17 = fmt$0[2], fmting_gen = fmt$0[1]; + if(0 === fmting_gen[0]){ + var str$0 = fmting_gen[1][2]; + buffer_add_string(buf, cst$15); + buffer_add_string(buf, str$0); + } + else{ + var str$1 = fmting_gen[1][2]; + buffer_add_string(buf, cst$16); + buffer_add_string(buf, str$1); + } + fmt$0 = rest$17; + break; + case 19: + var rest$18 = fmt$0[1]; + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + buffer_add_char(buf, 114); + fmt$0 = rest$18; + ign_flag$0 = 0; + break; + case 20: + var rest$19 = fmt$0[3], char_set = fmt$0[2], width_opt = fmt$0[1]; + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + bprint_pad_opt(buf, width_opt); + var + print_char = + function(buf, i){ + var c = caml_call1(Stdlib[29], i); + return 37 === c + ? (buffer_add_char(buf, 37), buffer_add_char(buf, 37)) + : 64 + === c + ? (buffer_add_char(buf, 37), buffer_add_char(buf, 64)) + : buffer_add_char(buf, c); + }; + buffer_add_char(buf, 91); + var + set = + is_in_char_set(char_set, 0) + ? (buffer_add_char(buf, 94), rev_char_set(char_set)) + : char_set; + let set$0 = set; + var + is_alone = + function(c){ + var + after = caml_call1(Stdlib_Char[1], c + 1 | 0), + before = caml_call1(Stdlib_Char[1], c - 1 | 0), + _cJ_ = is_in_char_set(set$0, c); + if(_cJ_) + var + _cK_ = is_in_char_set(set$0, before), + _cL_ = _cK_ ? is_in_char_set(set$0, after) : _cK_, + _cM_ = 1 - _cL_; + else + var _cM_ = _cJ_; + return _cM_; + }; + if(is_alone(93)) buffer_add_char(buf, 93); + a: + b: + { + c: + { + d: + { + var i = 1; + for(;;){ + if(i >= 256) break; + if(is_in_char_set(set, caml_call1(Stdlib[29], i))){ + var switcher = caml_call1(Stdlib[29], i) - 45 | 0; + if(48 < switcher >>> 0){ + if(210 <= switcher) break d; + } + else if(46 < switcher - 1 >>> 0){ + var i$2 = i + 1 | 0; + i = i$2; + continue; + } + var i$1 = i + 1 | 0; + if(is_in_char_set(set, caml_call1(Stdlib[29], i$1))){ + var switcher$0 = caml_call1(Stdlib[29], i$1) - 45 | 0; + if(48 < switcher$0 >>> 0){ + if(210 <= switcher$0) break c; + } + else if + (46 < switcher$0 - 1 >>> 0 + && ! is_in_char_set(set, caml_call1(Stdlib[29], i$1 + 1 | 0))){ + print_char(buf, i$1 - 1 | 0); + var i$5 = i$1 + 1 | 0; + i = i$5; + continue; + } + if(is_in_char_set(set, caml_call1(Stdlib[29], i$1 + 1 | 0))){ + var j = i$1 + 2 | 0, i$3 = i$1 - 1 | 0, j$0 = j; + for(;;){ + if(256 === j$0) break; + if(! is_in_char_set(set, caml_call1(Stdlib[29], j$0))) break; + var j$1 = j$0 + 1 | 0; + j$0 = j$1; + } + print_char(buf, i$3); + print_char(buf, 45); + print_char(buf, j$0 - 1 | 0); + if(j$0 >= 256) break b; + var i$7 = j$0 + 1 | 0; + i = i$7; + } + else{ + print_char(buf, i$1 - 1 | 0); + print_char(buf, i$1); + var i$4 = i$1 + 2 | 0; + i = i$4; + } + } + else{ + print_char(buf, i$1 - 1 | 0); + var i$6 = i$1 + 1 | 0; + i = i$6; + } + } + else{var i$0 = i + 1 | 0; i = i$0;} + } + break a; + } + print_char(buf, 255); + break a; + } + print_char(buf, 254); + print_char(buf, 255); + break a; + } + if(is_alone(45)) buffer_add_char(buf, 45); + buffer_add_char(buf, 93); + fmt$0 = rest$19; + ign_flag$0 = 0; + break; + case 21: + var rest$20 = fmt$0[2], counter = fmt$0[1]; + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + switch(counter){ + case 0: + var _cF_ = 108; break; + case 1: + var _cF_ = 110; break; + default: var _cF_ = 78; + } + buffer_add_char(buf, _cF_); + fmt$0 = rest$20; + ign_flag$0 = 0; + break; + case 22: + var rest$21 = fmt$0[1]; + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + bprint_string_literal(buf, cst_0c); + fmt$0 = rest$21; + ign_flag$0 = 0; + break; + case 23: + var + rest$22 = fmt$0[2], + ign = fmt$0[1], + fmt$1 = param_format_of_ignored_format(ign, rest$22)[1]; + fmt$0 = fmt$1; + ign_flag$0 = 1; + break; + default: + var + rest$23 = fmt$0[3], + arity = fmt$0[1], + _cH_ = int_of_custom_arity(arity), + _cG_ = 1; + if(_cH_ >= 1){ + var i$8 = _cG_; + for(;;){ + buffer_add_char(buf, 37); + bprint_ignored_flag(buf, ign_flag$0); + buffer_add_char(buf, 63); + var _cI_ = i$8 + 1 | 0; + if(_cH_ === i$8) break; + i$8 = _cI_; + } + } + fmt$0 = rest$23; + ign_flag$0 = 0; + } + } + } + fmtiter(fmt, 0); + return buffer_contents(buf); + } + function symm(param){ + if(typeof param === "number") return 0; + switch(param[0]){ + case 0: + var rest = param[1]; return [0, symm(rest)]; + case 1: + var rest$0 = param[1]; return [1, symm(rest$0)]; + case 2: + var rest$1 = param[1]; return [2, symm(rest$1)]; + case 3: + var rest$2 = param[1]; return [3, symm(rest$2)]; + case 4: + var rest$3 = param[1]; return [4, symm(rest$3)]; + case 5: + var rest$4 = param[1]; return [5, symm(rest$4)]; + case 6: + var rest$5 = param[1]; return [6, symm(rest$5)]; + case 7: + var rest$6 = param[1]; return [7, symm(rest$6)]; + case 8: + var rest$7 = param[2], ty = param[1]; return [8, ty, symm(rest$7)]; + case 9: + var rest$8 = param[3], ty2 = param[2], ty1 = param[1]; + return [9, ty2, ty1, symm(rest$8)]; + case 10: + var rest$9 = param[1]; return [10, symm(rest$9)]; + case 11: + var rest$10 = param[1]; return [11, symm(rest$10)]; + case 12: + var rest$11 = param[1]; return [12, symm(rest$11)]; + case 13: + var rest$12 = param[1]; return [13, symm(rest$12)]; + default: var rest$13 = param[1]; return [14, symm(rest$13)]; + } + } + function fmtty_rel_det(param){ + if(typeof param === "number") + return [0, + function(param){return;}, + function(param){return;}, + function(param){return;}, + function(param){return;}]; + switch(param[0]){ + case 0: + var + rest = param[1], + match = fmtty_rel_det(rest), + de = match[4], + ed = match[3], + af = match[2], + fa = match[1]; + return [0, + function(param){fa(0); return;}, + function(param){af(0); return;}, + ed, + de]; + case 1: + var + rest$0 = param[1], + match$0 = fmtty_rel_det(rest$0), + de$0 = match$0[4], + ed$0 = match$0[3], + af$0 = match$0[2], + fa$0 = match$0[1]; + return [0, + function(param){fa$0(0); return;}, + function(param){af$0(0); return;}, + ed$0, + de$0]; + case 2: + var + rest$1 = param[1], + match$1 = fmtty_rel_det(rest$1), + de$1 = match$1[4], + ed$1 = match$1[3], + af$1 = match$1[2], + fa$1 = match$1[1]; + return [0, + function(param){fa$1(0); return;}, + function(param){af$1(0); return;}, + ed$1, + de$1]; + case 3: + var + rest$2 = param[1], + match$2 = fmtty_rel_det(rest$2), + de$2 = match$2[4], + ed$2 = match$2[3], + af$2 = match$2[2], + fa$2 = match$2[1]; + return [0, + function(param){fa$2(0); return;}, + function(param){af$2(0); return;}, + ed$2, + de$2]; + case 4: + var + rest$3 = param[1], + match$3 = fmtty_rel_det(rest$3), + de$3 = match$3[4], + ed$3 = match$3[3], + af$3 = match$3[2], + fa$3 = match$3[1]; + return [0, + function(param){fa$3(0); return;}, + function(param){af$3(0); return;}, + ed$3, + de$3]; + case 5: + var + rest$4 = param[1], + match$4 = fmtty_rel_det(rest$4), + de$4 = match$4[4], + ed$4 = match$4[3], + af$4 = match$4[2], + fa$4 = match$4[1]; + return [0, + function(param){fa$4(0); return;}, + function(param){af$4(0); return;}, + ed$4, + de$4]; + case 6: + var + rest$5 = param[1], + match$5 = fmtty_rel_det(rest$5), + de$5 = match$5[4], + ed$5 = match$5[3], + af$5 = match$5[2], + fa$5 = match$5[1]; + return [0, + function(param){fa$5(0); return;}, + function(param){af$5(0); return;}, + ed$5, + de$5]; + case 7: + var + rest$6 = param[1], + match$6 = fmtty_rel_det(rest$6), + de$6 = match$6[4], + ed$6 = match$6[3], + af$6 = match$6[2], + fa$6 = match$6[1]; + return [0, + function(param){fa$6(0); return;}, + function(param){af$6(0); return;}, + ed$6, + de$6]; + case 8: + var + rest$7 = param[2], + match$7 = fmtty_rel_det(rest$7), + de$7 = match$7[4], + ed$7 = match$7[3], + af$7 = match$7[2], + fa$7 = match$7[1]; + return [0, + function(param){fa$7(0); return;}, + function(param){af$7(0); return;}, + ed$7, + de$7]; + case 9: + var + rest$8 = param[3], + ty2 = param[2], + ty1 = param[1], + match$8 = fmtty_rel_det(rest$8), + de$8 = match$8[4], + ed$8 = match$8[3], + af$8 = match$8[2], + fa$8 = match$8[1], + ty = trans(symm(ty1), ty2), + match$9 = fmtty_rel_det(ty), + jd = match$9[4], + dj = match$9[3], + ga = match$9[2], + ag = match$9[1]; + return [0, + function(param){fa$8(0); ag(0); return;}, + function(param){ga(0); af$8(0); return;}, + function(param){ed$8(0); dj(0); return;}, + function(param){jd(0); de$8(0); return;}]; + case 10: + var + rest$9 = param[1], + match$10 = fmtty_rel_det(rest$9), + de$9 = match$10[4], + ed$9 = match$10[3], + af$9 = match$10[2], + fa$9 = match$10[1]; + return [0, + function(param){fa$9(0); return;}, + function(param){af$9(0); return;}, + ed$9, + de$9]; + case 11: + var + rest$10 = param[1], + match$11 = fmtty_rel_det(rest$10), + de$10 = match$11[4], + ed$10 = match$11[3], + af$10 = match$11[2], + fa$10 = match$11[1]; + return [0, + function(param){fa$10(0); return;}, + function(param){af$10(0); return;}, + ed$10, + de$10]; + case 12: + var + rest$11 = param[1], + match$12 = fmtty_rel_det(rest$11), + de$11 = match$12[4], + ed$11 = match$12[3], + af$11 = match$12[2], + fa$11 = match$12[1]; + return [0, + function(param){fa$11(0); return;}, + function(param){af$11(0); return;}, + ed$11, + de$11]; + case 13: + var + rest$12 = param[1], + match$13 = fmtty_rel_det(rest$12), + de$12 = match$13[4], + ed$12 = match$13[3], + af$12 = match$13[2], + fa$12 = match$13[1]; + return [0, + function(param){fa$12(0); return;}, + function(param){af$12(0); return;}, + function(param){ed$12(0); return;}, + function(param){de$12(0); return;}]; + default: + var + rest$13 = param[1], + match$14 = fmtty_rel_det(rest$13), + de$13 = match$14[4], + ed$13 = match$14[3], + af$13 = match$14[2], + fa$13 = match$14[1]; + return [0, + function(param){fa$13(0); return;}, + function(param){af$13(0); return;}, + function(param){ed$13(0); return;}, + function(param){de$13(0); return;}]; + } + } + function trans(ty1, ty2){ + a: + { + b: + { + c: + { + d: + { + e: + { + f: + { + g: + { + if(typeof ty1 !== "number"){ + switch(ty1[0]){ + case 0: + var rest1 = ty1[1]; + if(typeof ty2 !== "number") + switch(ty2[0]){ + case 0: + var rest2 = ty2[1]; return [0, trans(rest1, rest2)]; + case 8: + break f; + case 9: + break g; + case 10: + break a; + case 11: + break b; + case 12: + break c; + case 13: + break d; + case 14: + break e; + } + break; + case 1: + var rest1$0 = ty1[1]; + if(typeof ty2 !== "number") + switch(ty2[0]){ + case 1: + var rest2$0 = ty2[1]; return [1, trans(rest1$0, rest2$0)]; + case 8: + break f; + case 9: + break g; + case 10: + break a; + case 11: + break b; + case 12: + break c; + case 13: + break d; + case 14: + break e; + } + break; + case 2: + var rest1$1 = ty1[1]; + if(typeof ty2 !== "number") + switch(ty2[0]){ + case 2: + var rest2$1 = ty2[1]; return [2, trans(rest1$1, rest2$1)]; + case 8: + break f; + case 9: + break g; + case 10: + break a; + case 11: + break b; + case 12: + break c; + case 13: + break d; + case 14: + break e; + } + break; + case 3: + var rest1$2 = ty1[1]; + if(typeof ty2 !== "number") + switch(ty2[0]){ + case 3: + var rest2$2 = ty2[1]; return [3, trans(rest1$2, rest2$2)]; + case 8: + break f; + case 9: + break g; + case 10: + break a; + case 11: + break b; + case 12: + break c; + case 13: + break d; + case 14: + break e; + } + break; + case 4: + var rest1$3 = ty1[1]; + if(typeof ty2 !== "number") + switch(ty2[0]){ + case 4: + var rest2$3 = ty2[1]; return [4, trans(rest1$3, rest2$3)]; + case 8: + break f; + case 9: + break g; + case 10: + break a; + case 11: + break b; + case 12: + break c; + case 13: + break d; + case 14: + break e; + } + break; + case 5: + var rest1$4 = ty1[1]; + if(typeof ty2 !== "number") + switch(ty2[0]){ + case 5: + var rest2$4 = ty2[1]; return [5, trans(rest1$4, rest2$4)]; + case 8: + break f; + case 9: + break g; + case 10: + break a; + case 11: + break b; + case 12: + break c; + case 13: + break d; + case 14: + break e; + } + break; + case 6: + var rest1$5 = ty1[1]; + if(typeof ty2 !== "number") + switch(ty2[0]){ + case 6: + var rest2$5 = ty2[1]; return [6, trans(rest1$5, rest2$5)]; + case 8: + break f; + case 9: + break g; + case 10: + break a; + case 11: + break b; + case 12: + break c; + case 13: + break d; + case 14: + break e; + } + break; + case 7: + var rest1$6 = ty1[1]; + if(typeof ty2 !== "number") + switch(ty2[0]){ + case 7: + var rest2$6 = ty2[1]; return [7, trans(rest1$6, rest2$6)]; + case 8: + break f; + case 9: + break g; + case 10: + break a; + case 11: + break b; + case 12: + break c; + case 13: + break d; + case 14: + break e; + } + break; + case 8: + var rest1$7 = ty1[2], ty1$0 = ty1[1]; + if(typeof ty2 !== "number") + switch(ty2[0]){ + case 8: + var + rest2$7 = ty2[2], + ty2$0 = ty2[1], + _cE_ = trans(rest1$7, rest2$7); + return [8, trans(ty1$0, ty2$0), _cE_]; + case 10: + break a; + case 11: + break b; + case 12: + break c; + case 13: + break d; + case 14: + break e; + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _k_], 1); + case 9: + var rest1$8 = ty1[3], ty12 = ty1[2], ty11 = ty1[1]; + if(typeof ty2 !== "number") + switch(ty2[0]){ + case 8: + break f; + case 9: + var + rest2$8 = ty2[3], + ty22 = ty2[2], + ty21 = ty2[1], + ty = trans(symm(ty12), ty21), + match = fmtty_rel_det(ty), + f4 = match[4], + f2 = match[2]; + f2(0); + f4(0); + return [9, ty11, ty22, trans(rest1$8, rest2$8)]; + case 10: + break a; + case 11: + break b; + case 12: + break c; + case 13: + break d; + case 14: + break e; + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _l_], 1); + case 10: + var rest1$9 = ty1[1]; + if(typeof ty2 !== "number" && 10 === ty2[0]){ + var rest2$9 = ty2[1]; + return [10, trans(rest1$9, rest2$9)]; + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _m_], 1); + case 11: + var rest1$10 = ty1[1]; + if(typeof ty2 !== "number") + switch(ty2[0]){ + case 10: + break a; + case 11: + var rest2$10 = ty2[1]; + return [11, trans(rest1$10, rest2$10)]; + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _n_], 1); + case 12: + var rest1$11 = ty1[1]; + if(typeof ty2 !== "number") + switch(ty2[0]){ + case 10: + break a; + case 11: + break b; + case 12: + var rest2$11 = ty2[1]; + return [12, trans(rest1$11, rest2$11)]; + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _o_], 1); + case 13: + var rest1$12 = ty1[1]; + if(typeof ty2 !== "number") + switch(ty2[0]){ + case 10: + break a; + case 11: + break b; + case 12: + break c; + case 13: + var rest2$12 = ty2[1]; + return [13, trans(rest1$12, rest2$12)]; + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _p_], 1); + default: + var rest1$13 = ty1[1]; + if(typeof ty2 !== "number") + switch(ty2[0]){ + case 10: + break a; + case 11: + break b; + case 12: + break c; + case 13: + break d; + case 14: + var rest2$13 = ty2[1]; + return [14, trans(rest1$13, rest2$13)]; + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _q_], 1); + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _j_], 1); + } + if(typeof ty2 === "number") return 0; + switch(ty2[0]){ + case 10: + break a; + case 11: + break b; + case 12: + break c; + case 13: + break d; + case 14: + break e; + case 8: + break f; + case 9: break; + default: + throw caml_maybe_attach_backtrace([0, Assert_failure, _b_], 1); + } + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _d_], 1); + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _c_], 1); + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _i_], 1); + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _h_], 1); + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _g_], 1); + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _f_], 1); + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _e_], 1); + } + function fmtty_of_fmt(fmtty){ + var fmtty$0 = fmtty; + for(;;){ + if(typeof fmtty$0 === "number") return 0; + switch(fmtty$0[0]){ + case 0: + var rest = fmtty$0[1]; return [0, fmtty_of_fmt(rest)]; + case 1: + var rest$0 = fmtty$0[1]; return [0, fmtty_of_fmt(rest$0)]; + case 2: + var rest$1 = fmtty$0[2], pad = fmtty$0[1]; + return fmtty_of_padding_fmtty(pad, [1, fmtty_of_fmt(rest$1)]); + case 3: + var rest$2 = fmtty$0[2], pad$0 = fmtty$0[1]; + return fmtty_of_padding_fmtty(pad$0, [1, fmtty_of_fmt(rest$2)]); + case 4: + var + rest$3 = fmtty$0[4], + prec = fmtty$0[3], + pad$1 = fmtty$0[2], + ty_rest = fmtty_of_fmt(rest$3), + prec_ty = fmtty_of_precision_fmtty(prec, [2, ty_rest]); + return fmtty_of_padding_fmtty(pad$1, prec_ty); + case 5: + var + rest$4 = fmtty$0[4], + prec$0 = fmtty$0[3], + pad$2 = fmtty$0[2], + ty_rest$0 = fmtty_of_fmt(rest$4), + prec_ty$0 = fmtty_of_precision_fmtty(prec$0, [3, ty_rest$0]); + return fmtty_of_padding_fmtty(pad$2, prec_ty$0); + case 6: + var + rest$5 = fmtty$0[4], + prec$1 = fmtty$0[3], + pad$3 = fmtty$0[2], + ty_rest$1 = fmtty_of_fmt(rest$5), + prec_ty$1 = fmtty_of_precision_fmtty(prec$1, [4, ty_rest$1]); + return fmtty_of_padding_fmtty(pad$3, prec_ty$1); + case 7: + var + rest$6 = fmtty$0[4], + prec$2 = fmtty$0[3], + pad$4 = fmtty$0[2], + ty_rest$2 = fmtty_of_fmt(rest$6), + prec_ty$2 = fmtty_of_precision_fmtty(prec$2, [5, ty_rest$2]); + return fmtty_of_padding_fmtty(pad$4, prec_ty$2); + case 8: + var + rest$7 = fmtty$0[4], + prec$3 = fmtty$0[3], + pad$5 = fmtty$0[2], + ty_rest$3 = fmtty_of_fmt(rest$7), + prec_ty$3 = fmtty_of_precision_fmtty(prec$3, [6, ty_rest$3]); + return fmtty_of_padding_fmtty(pad$5, prec_ty$3); + case 9: + var rest$8 = fmtty$0[2], pad$6 = fmtty$0[1]; + return fmtty_of_padding_fmtty(pad$6, [7, fmtty_of_fmt(rest$8)]); + case 10: + var fmtty$1 = fmtty$0[1]; fmtty$0 = fmtty$1; break; + case 11: + var fmtty$2 = fmtty$0[2]; fmtty$0 = fmtty$2; break; + case 12: + var fmtty$3 = fmtty$0[2]; fmtty$0 = fmtty$3; break; + case 13: + var rest$9 = fmtty$0[3], ty = fmtty$0[2]; + return [8, ty, fmtty_of_fmt(rest$9)]; + case 14: + var rest$10 = fmtty$0[3], ty$0 = fmtty$0[2]; + return [9, ty$0, ty$0, fmtty_of_fmt(rest$10)]; + case 15: + var rest$11 = fmtty$0[1]; return [10, fmtty_of_fmt(rest$11)]; + case 16: + var rest$12 = fmtty$0[1]; return [11, fmtty_of_fmt(rest$12)]; + case 17: + var fmtty$4 = fmtty$0[2]; fmtty$0 = fmtty$4; break; + case 18: + var + rest$13 = fmtty$0[2], + formatting_gen = fmtty$0[1], + _cB_ = fmtty_of_fmt(rest$13); + if(0 === formatting_gen[0]) + var fmt = formatting_gen[1][1], _cC_ = fmtty_of_fmt(fmt); + else + var fmt$0 = formatting_gen[1][1], _cC_ = fmtty_of_fmt(fmt$0); + return caml_call2(CamlinternalFormatBasics[1], _cC_, _cB_); + case 19: + var rest$14 = fmtty$0[1]; return [13, fmtty_of_fmt(rest$14)]; + case 20: + var rest$15 = fmtty$0[3]; return [1, fmtty_of_fmt(rest$15)]; + case 21: + var rest$16 = fmtty$0[2]; return [2, fmtty_of_fmt(rest$16)]; + case 22: + var rest$17 = fmtty$0[1]; return [0, fmtty_of_fmt(rest$17)]; + case 23: + var fmtty$5 = fmtty$0[2], ign = fmtty$0[1]; + if(typeof ign === "number") + switch(ign){ + case 0: + fmtty$0 = fmtty$5; break; + case 1: + fmtty$0 = fmtty$5; break; + case 2: + return [14, fmtty_of_fmt(fmtty$5)]; + default: fmtty$0 = fmtty$5; + } + else + switch(ign[0]){ + case 0: + fmtty$0 = fmtty$5; break; + case 1: + fmtty$0 = fmtty$5; break; + case 2: + fmtty$0 = fmtty$5; break; + case 3: + fmtty$0 = fmtty$5; break; + case 4: + fmtty$0 = fmtty$5; break; + case 5: + fmtty$0 = fmtty$5; break; + case 6: + fmtty$0 = fmtty$5; break; + case 7: + fmtty$0 = fmtty$5; break; + case 8: + fmtty$0 = fmtty$5; break; + case 9: + var fmtty$6 = ign[2], _cD_ = fmtty_of_fmt(fmtty$5); + return caml_call2(CamlinternalFormatBasics[1], fmtty$6, _cD_); + case 10: + fmtty$0 = fmtty$5; break; + default: fmtty$0 = fmtty$5; + } + break; + default: + var rest$18 = fmtty$0[3], arity = fmtty$0[1]; + return fmtty_of_custom(arity, fmtty_of_fmt(rest$18)); + } + } + } + function fmtty_of_custom(arity, fmtty){ + if(! arity) return fmtty; + var arity$0 = arity[1]; + return [12, fmtty_of_custom(arity$0, fmtty)]; + } + function fmtty_of_padding_fmtty(pad, fmtty){ + return typeof pad === "number" ? fmtty : 0 === pad[0] ? fmtty : [2, fmtty]; + } + function fmtty_of_precision_fmtty(prec, fmtty){ + return typeof prec === "number" ? prec ? [2, fmtty] : fmtty : fmtty; + } + var + Type_mismatch = + [248, "CamlinternalFormat.Type_mismatch", runtime.caml_fresh_oo_id(0)], + cst_d = "%d", + cst_d$0 = "%+d", + cst_d$1 = "% d", + cst_i$0 = cst_i$3, + cst_i$1 = "%+i", + cst_i$2 = "% i", + cst_x = "%x", + cst_x$0 = "%#x", + cst_X = "%X", + cst_X$0 = "%#X", + cst_o = "%o", + cst_o$0 = "%#o", + cst_u = cst_u$0, + cst_Ld = "%Ld", + cst_Ld$0 = "%+Ld", + cst_Ld$1 = "% Ld", + cst_Li$0 = cst_Li$3, + cst_Li$1 = "%+Li", + cst_Li$2 = "% Li", + cst_Lx = "%Lx", + cst_Lx$0 = "%#Lx", + cst_LX = "%LX", + cst_LX$0 = "%#LX", + cst_Lo = "%Lo", + cst_Lo$0 = "%#Lo", + cst_Lu = "%Lu", + cst_ld = "%ld", + cst_ld$0 = "%+ld", + cst_ld$1 = "% ld", + cst_li$0 = cst_li$3, + cst_li$1 = "%+li", + cst_li$2 = "% li", + cst_lx = "%lx", + cst_lx$0 = "%#lx", + cst_lX = "%lX", + cst_lX$0 = "%#lX", + cst_lo = "%lo", + cst_lo$0 = "%#lo", + cst_lu = "%lu", + cst_nd = "%nd", + cst_nd$0 = "%+nd", + cst_nd$1 = "% nd", + cst_ni$0 = cst_ni$3, + cst_ni$1 = "%+ni", + cst_ni$2 = "% ni", + cst_nx = "%nx", + cst_nx$0 = "%#nx", + cst_nX = "%nX", + cst_nX$0 = "%#nX", + cst_no = "%no", + cst_no$0 = "%#no", + cst_nu = "%nu", + _r_ = [0, 103], + cst_neg_infinity = "neg_infinity", + cst_infinity = "infinity", + cst_nan = "nan", + _s_ = [0, cst_camlinternalFormat_ml, 1558, 4], + cst_Printf_bad_conversion = "Printf: bad conversion %[", + _t_ = [0, cst_camlinternalFormat_ml, 1626, 39], + _u_ = [0, cst_camlinternalFormat_ml, 1649, 31], + _v_ = [0, cst_camlinternalFormat_ml, 1650, 31], + cst_Printf_bad_conversion$0 = "Printf: bad conversion %_", + _w_ = [0, cst_camlinternalFormat_ml, 1830, 8], + _x_ = [0, 0, 4], + _y_ = + [0, + [11, "invalid box description ", [3, 0, 0]], + "invalid box description %S"], + _z_ = + [0, + [11, + cst_invalid_format, + [3, + 0, + [11, cst_at_character_number, [4, 0, 0, 0, [11, cst$44, [2, 0, 0]]]]]], + "invalid format %S: at character number %d, %s"], + cst_non_zero_widths_are_unsupp = + "non-zero widths are unsupported for %c conversions", + _A_ = + [0, + [11, + cst_invalid_format, + [3, + 0, + [11, + cst_at_character_number, + [4, 0, 0, 0, [11, ", '", [0, [11, "' without ", [2, 0, 0]]]]]]]], + "invalid format %S: at character number %d, '%c' without %s"], + _B_ = + [0, + [11, + cst_invalid_format, + [3, + 0, + [11, + cst_at_character_number, + [4, 0, 0, 0, [11, cst$44, [2, 0, [11, " expected, read ", [1, 0]]]]]]]], + "invalid format %S: at character number %d, %s expected, read %C"], + _C_ = + [0, + [11, + cst_invalid_format, + [3, + 0, + [11, + cst_at_character_number, + [4, 0, 0, 0, [11, ", duplicate flag ", [1, 0]]]]]], + "invalid format %S: at character number %d, duplicate flag %C"], + cst_padding = "padding", + _D_ = [0, 1, 0], + cst_0 = cst_0$3, + _E_ = [0, 0], + cst_precision = cst_precision$3, + _F_ = [1, 0], + _G_ = [1, 1], + cst_precision$0 = cst_precision$3, + _H_ = [1, 1], + cst_precision$1 = cst_precision$3, + cst_0$0 = cst_0$3, + _I_ = [1, 1], + cst_0$1 = cst_0$3, + cst_0$2 = "'0'", + _J_ = + [0, + [11, + cst_invalid_format, + [3, + 0, + [11, + cst_at_character_number, + [4, + 0, + 0, + 0, + [11, ', invalid conversion "', [12, 37, [0, [12, 34, 0]]]]]]]], + 'invalid format %S: at character number %d, invalid conversion "%%%c"'], + _K_ = [0, 0], + cst_padding$0 = "`padding'", + _L_ = [0, 0], + cst_precision$2 = "`precision'", + _M_ = + [0, + [11, + cst_invalid_format, + [3, + 0, + [11, + cst_at_character_number, + [4, + 0, + 0, + 0, + [11, + ", flag ", + [1, + [11, + " is only allowed after the '", + [12, 37, [11, "', before padding and precision", 0]]]]]]]]], + "invalid format %S: at character number %d, flag %C is only allowed after the '%%', before padding and precision"], + _N_ = [0, [12, 64, 0]], + _O_ = [0, "@ ", 1, 0], + _P_ = [0, "@,", 0, 0], + _Q_ = [2, 60], + _R_ = + [0, + [11, + cst_invalid_format, + [3, + 0, + [11, + ": '", + [12, + 37, + [11, + "' alone is not accepted in character sets, use ", + [12, + 37, + [12, + 37, + [11, " instead at position ", [4, 0, 0, 0, [12, 46, 0]]]]]]]]]], + "invalid format %S: '%%' alone is not accepted in character sets, use %%%% instead at position %d."], + _S_ = + [0, + [11, + cst_invalid_format, + [3, + 0, + [11, + ": integer ", + [4, 0, 0, 0, [11, " is greater than the limit ", [4, 0, 0, 0, 0]]]]]], + "invalid format %S: integer %d is greater than the limit %d"], + _T_ = [0, cst_camlinternalFormat_ml, 2837, 11], + cst_digit = "digit", + _U_ = + [0, + [11, + cst_invalid_format, + [3, + 0, + [11, + ': unclosed sub-format, expected "', + [12, 37, [0, [11, '" at character number ', [4, 0, 0, 0, 0]]]]]]], + 'invalid format %S: unclosed sub-format, expected "%%%c" at character number %d'], + cst_character = "character ')'", + cst_character$0 = "character '}'", + _V_ = [0, cst_camlinternalFormat_ml, 2899, 34], + _W_ = [0, cst_camlinternalFormat_ml, 2935, 28], + _X_ = [0, cst_camlinternalFormat_ml, 2957, 11], + _Y_ = + [0, + [11, + cst_invalid_format, + [3, + 0, + [11, + cst_at_character_number, + [4, + 0, + 0, + 0, + [11, + cst$44, + [2, + 0, + [11, + " is incompatible with '", + [0, [11, "' in sub-format ", [3, 0, 0]]]]]]]]]], + "invalid format %S: at character number %d, %s is incompatible with '%c' in sub-format %S"], + _Z_ = + [0, + [11, cst_bad_input_format_type_mism, [3, 0, [11, cst_and, [3, 0, 0]]]], + cst_bad_input_format_type_mism$0], + ___ = + [0, + [11, cst_bad_input_format_type_mism, [3, 0, [11, cst_and, [3, 0, 0]]]], + cst_bad_input_format_type_mism$0]; + function type_padding(pad, fmtty){ + if(typeof pad === "number") return [0, 0, fmtty]; + if(0 === pad[0]){ + var w = pad[2], padty = pad[1]; + return [0, [0, padty, w], fmtty]; + } + if(typeof fmtty !== "number" && 2 === fmtty[0]){ + var rest = fmtty[1], padty$0 = pad[1]; + return [0, [1, padty$0], rest]; + } + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + } + function type_padprec(pad, prec, fmtty){ + var match = type_padding(pad, fmtty); + if(typeof prec !== "number"){ + var rest$1 = match[2], pad$2 = match[1], p = prec[1]; + return [0, pad$2, [0, p], rest$1]; + } + if(! prec){ + var rest$0 = match[2], pad$1 = match[1]; + return [0, pad$1, 0, rest$0]; + } + var match$0 = match[2]; + if(typeof match$0 !== "number" && 2 === match$0[0]){ + var rest = match$0[1], pad$0 = match[1]; + return [0, pad$0, 1, rest]; + } + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + } + function type_format(fmt, fmtty){ + var _cA_ = type_format_gen(fmt, fmtty); + if(typeof _cA_[2] !== "number") + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + var fmt$0 = _cA_[1]; + return fmt$0; + } + function type_format_gen(fmt, fmtty0){ + if(typeof fmt === "number") return [0, 0, fmtty0]; + switch(fmt[0]){ + case 0: + if(typeof fmtty0 !== "number" && 0 === fmtty0[0]){ + var + fmtty_rest = fmtty0[1], + fmt_rest = fmt[1], + match = type_format_gen(fmt_rest, fmtty_rest), + fmtty = match[2], + fmt$0 = match[1]; + return [0, [0, fmt$0], fmtty]; + } + break; + case 1: + if(typeof fmtty0 !== "number" && 0 === fmtty0[0]){ + var + fmtty_rest$0 = fmtty0[1], + fmt_rest$0 = fmt[1], + match$0 = type_format_gen(fmt_rest$0, fmtty_rest$0), + fmtty$0 = match$0[2], + fmt$1 = match$0[1]; + return [0, [1, fmt$1], fmtty$0]; + } + break; + case 2: + var + fmt_rest$1 = fmt[2], + pad = fmt[1], + match$1 = type_padding(pad, fmtty0), + pad$0 = match$1[1], + match$2 = match$1[2]; + if(typeof match$2 !== "number" && 1 === match$2[0]){ + var + fmtty_rest$1 = match$2[1], + match$3 = type_format_gen(fmt_rest$1, fmtty_rest$1), + fmtty$1 = match$3[2], + fmt$2 = match$3[1]; + return [0, [2, pad$0, fmt$2], fmtty$1]; + } + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + case 3: + var + fmt_rest$2 = fmt[2], + pad$1 = fmt[1], + match$4 = type_padding(pad$1, fmtty0), + pad$2 = match$4[1], + match$5 = match$4[2]; + if(typeof match$5 !== "number" && 1 === match$5[0]){ + var + fmtty_rest$2 = match$5[1], + match$6 = type_format_gen(fmt_rest$2, fmtty_rest$2), + fmtty$2 = match$6[2], + fmt$3 = match$6[1]; + return [0, [3, pad$2, fmt$3], fmtty$2]; + } + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + case 4: + var + fmt_rest$3 = fmt[4], + prec = fmt[3], + pad$3 = fmt[2], + iconv = fmt[1], + match$7 = type_padprec(pad$3, prec, fmtty0), + pad$4 = match$7[1], + match$8 = match$7[3]; + if(typeof match$8 !== "number" && 2 === match$8[0]){ + var + fmtty_rest$3 = match$8[1], + prec$0 = match$7[2], + match$9 = type_format_gen(fmt_rest$3, fmtty_rest$3), + fmtty$3 = match$9[2], + fmt$4 = match$9[1]; + return [0, [4, iconv, pad$4, prec$0, fmt$4], fmtty$3]; + } + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + case 5: + var + fmt_rest$4 = fmt[4], + prec$1 = fmt[3], + pad$5 = fmt[2], + iconv$0 = fmt[1], + match$10 = type_padprec(pad$5, prec$1, fmtty0), + pad$6 = match$10[1], + match$11 = match$10[3]; + if(typeof match$11 !== "number" && 3 === match$11[0]){ + var + fmtty_rest$4 = match$11[1], + prec$2 = match$10[2], + match$12 = type_format_gen(fmt_rest$4, fmtty_rest$4), + fmtty$4 = match$12[2], + fmt$5 = match$12[1]; + return [0, [5, iconv$0, pad$6, prec$2, fmt$5], fmtty$4]; + } + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + case 6: + var + fmt_rest$5 = fmt[4], + prec$3 = fmt[3], + pad$7 = fmt[2], + iconv$1 = fmt[1], + match$13 = type_padprec(pad$7, prec$3, fmtty0), + pad$8 = match$13[1], + match$14 = match$13[3]; + if(typeof match$14 !== "number" && 4 === match$14[0]){ + var + fmtty_rest$5 = match$14[1], + prec$4 = match$13[2], + match$15 = type_format_gen(fmt_rest$5, fmtty_rest$5), + fmtty$5 = match$15[2], + fmt$6 = match$15[1]; + return [0, [6, iconv$1, pad$8, prec$4, fmt$6], fmtty$5]; + } + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + case 7: + var + fmt_rest$6 = fmt[4], + prec$5 = fmt[3], + pad$9 = fmt[2], + iconv$2 = fmt[1], + match$16 = type_padprec(pad$9, prec$5, fmtty0), + pad$10 = match$16[1], + match$17 = match$16[3]; + if(typeof match$17 !== "number" && 5 === match$17[0]){ + var + fmtty_rest$6 = match$17[1], + prec$6 = match$16[2], + match$18 = type_format_gen(fmt_rest$6, fmtty_rest$6), + fmtty$6 = match$18[2], + fmt$7 = match$18[1]; + return [0, [7, iconv$2, pad$10, prec$6, fmt$7], fmtty$6]; + } + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + case 8: + var + fmt_rest$7 = fmt[4], + prec$7 = fmt[3], + pad$11 = fmt[2], + fconv = fmt[1], + match$19 = type_padprec(pad$11, prec$7, fmtty0), + pad$12 = match$19[1], + match$20 = match$19[3]; + if(typeof match$20 !== "number" && 6 === match$20[0]){ + var + fmtty_rest$7 = match$20[1], + prec$8 = match$19[2], + match$21 = type_format_gen(fmt_rest$7, fmtty_rest$7), + fmtty$7 = match$21[2], + fmt$8 = match$21[1]; + return [0, [8, fconv, pad$12, prec$8, fmt$8], fmtty$7]; + } + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + case 9: + var + fmt_rest$8 = fmt[2], + pad$13 = fmt[1], + match$22 = type_padding(pad$13, fmtty0), + pad$14 = match$22[1], + match$23 = match$22[2]; + if(typeof match$23 !== "number" && 7 === match$23[0]){ + var + fmtty_rest$8 = match$23[1], + match$24 = type_format_gen(fmt_rest$8, fmtty_rest$8), + fmtty$8 = match$24[2], + fmt$9 = match$24[1]; + return [0, [9, pad$14, fmt$9], fmtty$8]; + } + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + case 10: + var + fmt_rest$9 = fmt[1], + match$25 = type_format_gen(fmt_rest$9, fmtty0), + fmtty$9 = match$25[2], + fmt$10 = match$25[1]; + return [0, [10, fmt$10], fmtty$9]; + case 11: + var + fmt_rest$10 = fmt[2], + str = fmt[1], + match$26 = type_format_gen(fmt_rest$10, fmtty0), + fmtty$10 = match$26[2], + fmt$11 = match$26[1]; + return [0, [11, str, fmt$11], fmtty$10]; + case 12: + var + fmt_rest$11 = fmt[2], + chr = fmt[1], + match$27 = type_format_gen(fmt_rest$11, fmtty0), + fmtty$11 = match$27[2], + fmt$12 = match$27[1]; + return [0, [12, chr, fmt$12], fmtty$11]; + case 13: + if(typeof fmtty0 !== "number" && 8 === fmtty0[0]){ + var + fmtty_rest$9 = fmtty0[2], + sub_fmtty = fmtty0[1], + fmt_rest$12 = fmt[3], + sub_fmtty$0 = fmt[2], + pad_opt = fmt[1]; + if(caml_notequal([0, sub_fmtty$0], [0, sub_fmtty])) + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + var + match$28 = type_format_gen(fmt_rest$12, fmtty_rest$9), + fmtty$12 = match$28[2], + fmt$13 = match$28[1]; + return [0, [13, pad_opt, sub_fmtty, fmt$13], fmtty$12]; + } + break; + case 14: + if(typeof fmtty0 !== "number" && 9 === fmtty0[0]){ + var + fmtty_rest$10 = fmtty0[3], + sub_fmtty1 = fmtty0[1], + fmt_rest$13 = fmt[3], + sub_fmtty$1 = fmt[2], + pad_opt$0 = fmt[1], + _cy_ = [0, caml_call1(CamlinternalFormatBasics[2], sub_fmtty1)]; + if + (caml_notequal + ([0, caml_call1(CamlinternalFormatBasics[2], sub_fmtty$1)], _cy_)) + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + var + match$29 = + type_format_gen + (fmt_rest$13, + caml_call1(CamlinternalFormatBasics[2], fmtty_rest$10)), + fmtty$13 = match$29[2], + fmt$14 = match$29[1]; + return [0, [14, pad_opt$0, sub_fmtty1, fmt$14], fmtty$13]; + } + break; + case 15: + if(typeof fmtty0 !== "number" && 10 === fmtty0[0]){ + var + fmtty_rest$11 = fmtty0[1], + fmt_rest$14 = fmt[1], + match$30 = type_format_gen(fmt_rest$14, fmtty_rest$11), + fmtty$14 = match$30[2], + fmt$15 = match$30[1]; + return [0, [15, fmt$15], fmtty$14]; + } + break; + case 16: + if(typeof fmtty0 !== "number" && 11 === fmtty0[0]){ + var + fmtty_rest$12 = fmtty0[1], + fmt_rest$15 = fmt[1], + match$31 = type_format_gen(fmt_rest$15, fmtty_rest$12), + fmtty$15 = match$31[2], + fmt$16 = match$31[1]; + return [0, [16, fmt$16], fmtty$15]; + } + break; + case 17: + var + fmt_rest$16 = fmt[2], + formatting_lit = fmt[1], + match$32 = type_format_gen(fmt_rest$16, fmtty0), + fmtty$16 = match$32[2], + fmt$17 = match$32[1]; + return [0, [17, formatting_lit, fmt$17], fmtty$16]; + case 18: + var fmt_rest$17 = fmt[2], formatting_gen = fmt[1]; + if(0 === formatting_gen[0]){ + var + match$36 = formatting_gen[1], + str$0 = match$36[2], + fmt1 = match$36[1], + match$37 = type_format_gen(fmt1, fmtty0), + fmtty2 = match$37[2], + fmt2 = match$37[1], + match$38 = type_format_gen(fmt_rest$17, fmtty2), + fmtty3 = match$38[2], + fmt3 = match$38[1]; + return [0, [18, [0, [0, fmt2, str$0]], fmt3], fmtty3]; + } + var + match$39 = formatting_gen[1], + str$1 = match$39[2], + fmt1$0 = match$39[1], + match$40 = type_format_gen(fmt1$0, fmtty0), + fmtty2$0 = match$40[2], + fmt2$0 = match$40[1], + match$41 = type_format_gen(fmt_rest$17, fmtty2$0), + fmtty3$0 = match$41[2], + fmt3$0 = match$41[1]; + return [0, [18, [1, [0, fmt2$0, str$1]], fmt3$0], fmtty3$0]; + case 19: + if(typeof fmtty0 !== "number" && 13 === fmtty0[0]){ + var + fmtty_rest$13 = fmtty0[1], + fmt_rest$18 = fmt[1], + match$33 = type_format_gen(fmt_rest$18, fmtty_rest$13), + fmtty$17 = match$33[2], + fmt$18 = match$33[1]; + return [0, [19, fmt$18], fmtty$17]; + } + break; + case 20: + if(typeof fmtty0 !== "number" && 1 === fmtty0[0]){ + var + fmtty_rest$14 = fmtty0[1], + fmt_rest$19 = fmt[3], + char_set = fmt[2], + width_opt = fmt[1], + match$34 = type_format_gen(fmt_rest$19, fmtty_rest$14), + fmtty$18 = match$34[2], + fmt$19 = match$34[1]; + return [0, [20, width_opt, char_set, fmt$19], fmtty$18]; + } + break; + case 21: + if(typeof fmtty0 !== "number" && 2 === fmtty0[0]){ + var + fmtty_rest$15 = fmtty0[1], + fmt_rest$20 = fmt[2], + counter = fmt[1], + match$35 = type_format_gen(fmt_rest$20, fmtty_rest$15), + fmtty$19 = match$35[2], + fmt$20 = match$35[1]; + return [0, [21, counter, fmt$20], fmtty$19]; + } + break; + case 23: + var rest = fmt[2], ign = fmt[1]; + if(typeof ign !== "number") + switch(ign[0]){ + case 0: + return type_ignored_param_one(ign, rest, fmtty0); + case 1: + return type_ignored_param_one(ign, rest, fmtty0); + case 2: + return type_ignored_param_one(ign, rest, fmtty0); + case 3: + return type_ignored_param_one(ign, rest, fmtty0); + case 4: + return type_ignored_param_one(ign, rest, fmtty0); + case 5: + return type_ignored_param_one(ign, rest, fmtty0); + case 6: + return type_ignored_param_one(ign, rest, fmtty0); + case 7: + return type_ignored_param_one(ign, rest, fmtty0); + case 8: + var sub_fmtty$2 = ign[2], pad_opt$1 = ign[1]; + return type_ignored_param_one + ([8, pad_opt$1, sub_fmtty$2], rest, fmtty0); + case 9: + var + sub_fmtty$3 = ign[2], + pad_opt$2 = ign[1], + _cz_ = type_ignored_format_substituti(sub_fmtty$3, rest, fmtty0), + match$43 = _cz_[2], + fmtty$21 = match$43[2], + fmt$22 = match$43[1], + sub_fmtty$4 = _cz_[1]; + return [0, [23, [9, pad_opt$2, sub_fmtty$4], fmt$22], fmtty$21]; + case 10: + return type_ignored_param_one(ign, rest, fmtty0); + default: return type_ignored_param_one(ign, rest, fmtty0); + } + switch(ign){ + case 0: + return type_ignored_param_one(ign, rest, fmtty0); + case 1: + return type_ignored_param_one(ign, rest, fmtty0); + case 2: + if(typeof fmtty0 !== "number" && 14 === fmtty0[0]){ + var + fmtty_rest$16 = fmtty0[1], + match$42 = type_format_gen(rest, fmtty_rest$16), + fmtty$20 = match$42[2], + fmt$21 = match$42[1]; + return [0, [23, 2, fmt$21], fmtty$20]; + } + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + default: return type_ignored_param_one(ign, rest, fmtty0); + } + } + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + } + function type_ignored_param_one(ign, fmt, fmtty){ + var + match = type_format_gen(fmt, fmtty), + fmtty$0 = match[2], + fmt$0 = match[1]; + return [0, [23, ign, fmt$0], fmtty$0]; + } + function type_ignored_format_substituti(sub_fmtty, fmt, fmtty){ + if(typeof sub_fmtty === "number") + return [0, 0, type_format_gen(fmt, fmtty)]; + switch(sub_fmtty[0]){ + case 0: + if(typeof fmtty !== "number" && 0 === fmtty[0]){ + var + fmtty_rest = fmtty[1], + sub_fmtty_rest = sub_fmtty[1], + match = + type_ignored_format_substituti(sub_fmtty_rest, fmt, fmtty_rest), + fmt$0 = match[2], + sub_fmtty_rest$0 = match[1]; + return [0, [0, sub_fmtty_rest$0], fmt$0]; + } + break; + case 1: + if(typeof fmtty !== "number" && 1 === fmtty[0]){ + var + fmtty_rest$0 = fmtty[1], + sub_fmtty_rest$1 = sub_fmtty[1], + match$0 = + type_ignored_format_substituti(sub_fmtty_rest$1, fmt, fmtty_rest$0), + fmt$1 = match$0[2], + sub_fmtty_rest$2 = match$0[1]; + return [0, [1, sub_fmtty_rest$2], fmt$1]; + } + break; + case 2: + if(typeof fmtty !== "number" && 2 === fmtty[0]){ + var + fmtty_rest$1 = fmtty[1], + sub_fmtty_rest$3 = sub_fmtty[1], + match$1 = + type_ignored_format_substituti(sub_fmtty_rest$3, fmt, fmtty_rest$1), + fmt$2 = match$1[2], + sub_fmtty_rest$4 = match$1[1]; + return [0, [2, sub_fmtty_rest$4], fmt$2]; + } + break; + case 3: + if(typeof fmtty !== "number" && 3 === fmtty[0]){ + var + fmtty_rest$2 = fmtty[1], + sub_fmtty_rest$5 = sub_fmtty[1], + match$2 = + type_ignored_format_substituti(sub_fmtty_rest$5, fmt, fmtty_rest$2), + fmt$3 = match$2[2], + sub_fmtty_rest$6 = match$2[1]; + return [0, [3, sub_fmtty_rest$6], fmt$3]; + } + break; + case 4: + if(typeof fmtty !== "number" && 4 === fmtty[0]){ + var + fmtty_rest$3 = fmtty[1], + sub_fmtty_rest$7 = sub_fmtty[1], + match$3 = + type_ignored_format_substituti(sub_fmtty_rest$7, fmt, fmtty_rest$3), + fmt$4 = match$3[2], + sub_fmtty_rest$8 = match$3[1]; + return [0, [4, sub_fmtty_rest$8], fmt$4]; + } + break; + case 5: + if(typeof fmtty !== "number" && 5 === fmtty[0]){ + var + fmtty_rest$4 = fmtty[1], + sub_fmtty_rest$9 = sub_fmtty[1], + match$4 = + type_ignored_format_substituti(sub_fmtty_rest$9, fmt, fmtty_rest$4), + fmt$5 = match$4[2], + sub_fmtty_rest$10 = match$4[1]; + return [0, [5, sub_fmtty_rest$10], fmt$5]; + } + break; + case 6: + if(typeof fmtty !== "number" && 6 === fmtty[0]){ + var + fmtty_rest$5 = fmtty[1], + sub_fmtty_rest$11 = sub_fmtty[1], + match$5 = + type_ignored_format_substituti + (sub_fmtty_rest$11, fmt, fmtty_rest$5), + fmt$6 = match$5[2], + sub_fmtty_rest$12 = match$5[1]; + return [0, [6, sub_fmtty_rest$12], fmt$6]; + } + break; + case 7: + if(typeof fmtty !== "number" && 7 === fmtty[0]){ + var + fmtty_rest$6 = fmtty[1], + sub_fmtty_rest$13 = sub_fmtty[1], + match$6 = + type_ignored_format_substituti + (sub_fmtty_rest$13, fmt, fmtty_rest$6), + fmt$7 = match$6[2], + sub_fmtty_rest$14 = match$6[1]; + return [0, [7, sub_fmtty_rest$14], fmt$7]; + } + break; + case 8: + if(typeof fmtty !== "number" && 8 === fmtty[0]){ + var + fmtty_rest$7 = fmtty[2], + sub2_fmtty = fmtty[1], + sub_fmtty_rest$15 = sub_fmtty[2], + sub2_fmtty$0 = sub_fmtty[1]; + if(caml_notequal([0, sub2_fmtty$0], [0, sub2_fmtty])) + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + var + match$7 = + type_ignored_format_substituti + (sub_fmtty_rest$15, fmt, fmtty_rest$7), + fmt$8 = match$7[2], + sub_fmtty_rest$16 = match$7[1]; + return [0, [8, sub2_fmtty, sub_fmtty_rest$16], fmt$8]; + } + break; + case 9: + if(typeof fmtty !== "number" && 9 === fmtty[0]){ + var + fmtty_rest$8 = fmtty[3], + sub2_fmtty$1 = fmtty[2], + sub1_fmtty = fmtty[1], + sub_fmtty_rest$17 = sub_fmtty[3], + sub2_fmtty$2 = sub_fmtty[2], + sub1_fmtty$0 = sub_fmtty[1], + _cw_ = [0, caml_call1(CamlinternalFormatBasics[2], sub1_fmtty)]; + if + (caml_notequal + ([0, caml_call1(CamlinternalFormatBasics[2], sub1_fmtty$0)], _cw_)) + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + var _cx_ = [0, caml_call1(CamlinternalFormatBasics[2], sub2_fmtty$1)]; + if + (caml_notequal + ([0, caml_call1(CamlinternalFormatBasics[2], sub2_fmtty$2)], _cx_)) + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + var + sub_fmtty$0 = trans(symm(sub1_fmtty), sub2_fmtty$1), + match$8 = fmtty_rel_det(sub_fmtty$0), + f4 = match$8[4], + f2 = match$8[2]; + f2(0); + f4(0); + var + match$9 = + type_ignored_format_substituti + (caml_call1(CamlinternalFormatBasics[2], sub_fmtty_rest$17), + fmt, + fmtty_rest$8), + fmt$9 = match$9[2], + sub_fmtty_rest$18 = match$9[1]; + return [0, + [9, sub1_fmtty, sub2_fmtty$1, symm(sub_fmtty_rest$18)], + fmt$9]; + } + break; + case 10: + if(typeof fmtty !== "number" && 10 === fmtty[0]){ + var + fmtty_rest$9 = fmtty[1], + sub_fmtty_rest$19 = sub_fmtty[1], + match$10 = + type_ignored_format_substituti + (sub_fmtty_rest$19, fmt, fmtty_rest$9), + fmt$10 = match$10[2], + sub_fmtty_rest$20 = match$10[1]; + return [0, [10, sub_fmtty_rest$20], fmt$10]; + } + break; + case 11: + if(typeof fmtty !== "number" && 11 === fmtty[0]){ + var + fmtty_rest$10 = fmtty[1], + sub_fmtty_rest$21 = sub_fmtty[1], + match$11 = + type_ignored_format_substituti + (sub_fmtty_rest$21, fmt, fmtty_rest$10), + fmt$11 = match$11[2], + sub_fmtty_rest$22 = match$11[1]; + return [0, [11, sub_fmtty_rest$22], fmt$11]; + } + break; + case 13: + if(typeof fmtty !== "number" && 13 === fmtty[0]){ + var + fmtty_rest$11 = fmtty[1], + sub_fmtty_rest$23 = sub_fmtty[1], + match$12 = + type_ignored_format_substituti + (sub_fmtty_rest$23, fmt, fmtty_rest$11), + fmt$12 = match$12[2], + sub_fmtty_rest$24 = match$12[1]; + return [0, [13, sub_fmtty_rest$24], fmt$12]; + } + break; + case 14: + if(typeof fmtty !== "number" && 14 === fmtty[0]){ + var + fmtty_rest$12 = fmtty[1], + sub_fmtty_rest$25 = sub_fmtty[1], + match$13 = + type_ignored_format_substituti + (sub_fmtty_rest$25, fmt, fmtty_rest$12), + fmt$13 = match$13[2], + sub_fmtty_rest$26 = match$13[1]; + return [0, [14, sub_fmtty_rest$26], fmt$13]; + } + break; + } + throw caml_maybe_attach_backtrace(Type_mismatch, 1); + } + function recast(fmt, fmtty){ + var _cv_ = symm(fmtty); + return type_format(fmt, caml_call1(CamlinternalFormatBasics[2], _cv_)); + } + function fix_padding(padty, width, str){ + var + len = caml_ml_string_length(str), + padty$0 = 0 <= width ? padty : 0, + width$0 = caml_call1(Stdlib[18], width); + if(width$0 <= len) return str; + var + _cu_ = 2 === padty$0 ? 48 : 32, + res = caml_call2(Stdlib_Bytes[1], width$0, _cu_); + switch(padty$0){ + case 0: + caml_call5(Stdlib_String[42], str, 0, res, 0, len); break; + case 1: + caml_call5(Stdlib_String[42], str, 0, res, width$0 - len | 0, len); + break; + default: + a: + if(0 < len){ + if + (43 !== caml_string_get(str, 0) + && 45 !== caml_string_get(str, 0) && 32 !== caml_string_get(str, 0)) + break a; + caml_bytes_set(res, 0, caml_string_get(str, 0)); + caml_call5 + (Stdlib_String[42], + str, + 1, + res, + (width$0 - len | 0) + 1 | 0, + len - 1 | 0); + break; + } + a: + if(1 < len && 48 === caml_string_get(str, 0)){ + if(120 !== caml_string_get(str, 1) && 88 !== caml_string_get(str, 1)) + break a; + caml_bytes_set(res, 1, caml_string_get(str, 1)); + caml_call5 + (Stdlib_String[42], + str, + 2, + res, + (width$0 - len | 0) + 2 | 0, + len - 2 | 0); + break; + } + caml_call5(Stdlib_String[42], str, 0, res, width$0 - len | 0, len); + } + return caml_call1(Stdlib_Bytes[48], res); + } + function fix_int_precision(prec, str){ + var + prec$0 = caml_call1(Stdlib[18], prec), + len = caml_ml_string_length(str), + c = caml_string_get(str, 0); + a: + { + b: + { + if(58 > c){ + if(32 !== c){ + if(43 > c) break a; + switch(c - 43 | 0){ + case 5: + c: + if(len < (prec$0 + 2 | 0) && 1 < len){ + if + (120 !== caml_string_get(str, 1) + && 88 !== caml_string_get(str, 1)) + break c; + var res$1 = caml_call2(Stdlib_Bytes[1], prec$0 + 2 | 0, 48); + caml_bytes_set(res$1, 1, caml_string_get(str, 1)); + caml_call5 + (Stdlib_String[42], + str, + 2, + res$1, + (prec$0 - len | 0) + 4 | 0, + len - 2 | 0); + return caml_call1(Stdlib_Bytes[48], res$1); + } + break b; + case 0: + case 2: break; + case 1: + case 3: + case 4: + break a; + default: break b; + } + } + if(len >= (prec$0 + 1 | 0)) break a; + var res$0 = caml_call2(Stdlib_Bytes[1], prec$0 + 1 | 0, 48); + caml_bytes_set(res$0, 0, c); + caml_call5 + (Stdlib_String[42], + str, + 1, + res$0, + (prec$0 - len | 0) + 2 | 0, + len - 1 | 0); + return caml_call1(Stdlib_Bytes[48], res$0); + } + if(71 <= c){if(5 < c - 97 >>> 0) break a;} else if(65 > c) break a; + } + if(len < prec$0){ + var res = caml_call2(Stdlib_Bytes[1], prec$0, 48); + caml_call5(Stdlib_String[42], str, 0, res, prec$0 - len | 0, len); + return caml_call1(Stdlib_Bytes[48], res); + } + } + return str; + } + function string_to_caml_string(str){ + var + str$0 = caml_call1(Stdlib_String[24], str), + l = caml_ml_string_length(str$0), + res = caml_call2(Stdlib_Bytes[1], l + 2 | 0, 34); + caml_blit_string(str$0, 0, res, 1, l); + return caml_call1(Stdlib_Bytes[48], res); + } + function format_of_fconv(fconv, prec){ + var + prec$0 = caml_call1(Stdlib[18], prec), + symb = char_of_fconv(_r_, fconv), + buf = buffer_create(16); + buffer_add_char(buf, 37); + bprint_fconv_flag(buf, fconv); + buffer_add_char(buf, 46); + buffer_add_string(buf, caml_call1(Stdlib_Int[12], prec$0)); + buffer_add_char(buf, symb); + return buffer_contents(buf); + } + function transform_int_alt(iconv, s){ + if(13 > iconv) return s; + var n = [0, 0], _cp_ = caml_ml_string_length(s) - 1 | 0, _co_ = 0; + if(_cp_ >= 0){ + var i$0 = _co_; + for(;;){ + if(9 >= caml_string_unsafe_get(s, i$0) - 48 >>> 0) n[1]++; + var _ct_ = i$0 + 1 | 0; + if(_cp_ === i$0) break; + i$0 = _ct_; + } + } + var + digits = n[1], + buf = + caml_create_bytes + (caml_ml_string_length(s) + ((digits - 1 | 0) / 3 | 0) | 0), + pos = [0, 0]; + function put(c){caml_bytes_set(buf, pos[1], c); pos[1]++; return;} + var + left = [0, ((digits - 1 | 0) % 3 | 0) + 1 | 0], + _cr_ = caml_ml_string_length(s) - 1 | 0, + _cq_ = 0; + if(_cr_ >= 0){ + var i = _cq_; + for(;;){ + var c = caml_string_unsafe_get(s, i); + if(9 < c - 48 >>> 0) + put(c); + else{if(0 === left[1]){put(95); left[1] = 3;} left[1]--; put(c);} + var _cs_ = i + 1 | 0; + if(_cr_ === i) break; + i = _cs_; + } + } + return caml_call1(Stdlib_Bytes[48], buf); + } + function convert_int(iconv, n){ + switch(iconv){ + case 1: + var _cn_ = cst_d$0; break; + case 2: + var _cn_ = cst_d$1; break; + case 4: + var _cn_ = cst_i$1; break; + case 5: + var _cn_ = cst_i$2; break; + case 6: + var _cn_ = cst_x; break; + case 7: + var _cn_ = cst_x$0; break; + case 8: + var _cn_ = cst_X; break; + case 9: + var _cn_ = cst_X$0; break; + case 10: + var _cn_ = cst_o; break; + case 11: + var _cn_ = cst_o$0; break; + case 0: + case 13: + var _cn_ = cst_d; break; + case 3: + case 14: + var _cn_ = cst_i$0; break; + default: var _cn_ = cst_u; + } + return transform_int_alt(iconv, caml_format_int(_cn_, n)); + } + function convert_int32(iconv, n){ + switch(iconv){ + case 1: + var _cm_ = cst_ld$0; break; + case 2: + var _cm_ = cst_ld$1; break; + case 4: + var _cm_ = cst_li$1; break; + case 5: + var _cm_ = cst_li$2; break; + case 6: + var _cm_ = cst_lx; break; + case 7: + var _cm_ = cst_lx$0; break; + case 8: + var _cm_ = cst_lX; break; + case 9: + var _cm_ = cst_lX$0; break; + case 10: + var _cm_ = cst_lo; break; + case 11: + var _cm_ = cst_lo$0; break; + case 0: + case 13: + var _cm_ = cst_ld; break; + case 3: + case 14: + var _cm_ = cst_li$0; break; + default: var _cm_ = cst_lu; + } + return transform_int_alt(iconv, caml_format_int(_cm_, n)); + } + function convert_nativeint(iconv, n){ + switch(iconv){ + case 1: + var _cl_ = cst_nd$0; break; + case 2: + var _cl_ = cst_nd$1; break; + case 4: + var _cl_ = cst_ni$1; break; + case 5: + var _cl_ = cst_ni$2; break; + case 6: + var _cl_ = cst_nx; break; + case 7: + var _cl_ = cst_nx$0; break; + case 8: + var _cl_ = cst_nX; break; + case 9: + var _cl_ = cst_nX$0; break; + case 10: + var _cl_ = cst_no; break; + case 11: + var _cl_ = cst_no$0; break; + case 0: + case 13: + var _cl_ = cst_nd; break; + case 3: + case 14: + var _cl_ = cst_ni$0; break; + default: var _cl_ = cst_nu; + } + return transform_int_alt(iconv, caml_format_int(_cl_, n)); + } + function convert_int64(iconv, n){ + switch(iconv){ + case 1: + var _ck_ = cst_Ld$0; break; + case 2: + var _ck_ = cst_Ld$1; break; + case 4: + var _ck_ = cst_Li$1; break; + case 5: + var _ck_ = cst_Li$2; break; + case 6: + var _ck_ = cst_Lx; break; + case 7: + var _ck_ = cst_Lx$0; break; + case 8: + var _ck_ = cst_LX; break; + case 9: + var _ck_ = cst_LX$0; break; + case 10: + var _ck_ = cst_Lo; break; + case 11: + var _ck_ = cst_Lo$0; break; + case 0: + case 13: + var _ck_ = cst_Ld; break; + case 3: + case 14: + var _ck_ = cst_Li$0; break; + default: var _ck_ = cst_Lu; + } + return transform_int_alt(iconv, runtime.caml_int64_format(_ck_, n)); + } + function convert_float(fconv, prec, x){ + function hex(param){ + switch(fconv[1]){ + case 0: + var sign = 45; break; + case 1: + var sign = 43; break; + default: var sign = 32; + } + return runtime.caml_hexstring_of_float(x, prec, sign); + } + function caml_special_val(str){ + var match = runtime.caml_classify_float(x); + return 3 === match + ? x < 0. ? cst_neg_infinity : cst_infinity + : 4 <= match ? cst_nan : str; + } + switch(fconv[2]){ + case 5: + var + str = caml_format_float(format_of_fconv(fconv, prec), x), + len = caml_ml_string_length(str), + i = 0; + for(;;){ + if(i === len) + var _ch_ = 0; + else{ + var _cg_ = caml_string_get(str, i) - 46 | 0; + a: + { + if(23 < _cg_ >>> 0){ + if(55 === _cg_) break a; + } + else if(21 < _cg_ - 1 >>> 0) break a; + var i$0 = i + 1 | 0; + i = i$0; + continue; + } + var _ch_ = 1; + } + var _ci_ = _ch_ ? str : caml_call2(Stdlib[28], str, cst$17); + return caml_special_val(_ci_); + } + case 6: + return hex(0); + case 7: + var _cj_ = hex(0); return caml_call1(Stdlib_String[25], _cj_); + case 8: + return caml_special_val(hex(0)); + default: return caml_format_float(format_of_fconv(fconv, prec), x); + } + } + function string_of_fmtty(fmtty){ + var buf = buffer_create(16); + bprint_fmtty(buf, fmtty); + return buffer_contents(buf); + } + function make_printf$0(counter, k, acc, fmt){ + var k$0 = k, acc$0 = acc, fmt$0 = fmt; + for(;;){ + if(typeof fmt$0 === "number") return caml_call1(k$0, acc$0); + switch(fmt$0[0]){ + case 0: + var rest = fmt$0[1]; + return function(c){ + var new_acc = [5, acc$0, c]; + return make_printf(k$0, new_acc, rest);}; + case 1: + var rest$0 = fmt$0[1]; + return function(c){ + var + str = caml_call1(Stdlib_Char[2], c), + l = caml_ml_string_length(str), + res = caml_call2(Stdlib_Bytes[1], l + 2 | 0, 39); + caml_blit_string(str, 0, res, 1, l); + var new_acc = [4, acc$0, caml_call1(Stdlib_Bytes[48], res)]; + return make_printf(k$0, new_acc, rest$0);}; + case 2: + var rest$1 = fmt$0[2], pad = fmt$0[1]; + return make_padding + (k$0, acc$0, rest$1, pad, function(str){return str;}); + case 3: + var rest$2 = fmt$0[2], pad$0 = fmt$0[1]; + return make_padding(k$0, acc$0, rest$2, pad$0, string_to_caml_string); + case 4: + var + rest$3 = fmt$0[4], + prec = fmt$0[3], + pad$1 = fmt$0[2], + iconv = fmt$0[1]; + return make_int_padding_precision + (k$0, acc$0, rest$3, pad$1, prec, convert_int, iconv); + case 5: + var + rest$4 = fmt$0[4], + prec$0 = fmt$0[3], + pad$2 = fmt$0[2], + iconv$0 = fmt$0[1]; + return make_int_padding_precision + (k$0, acc$0, rest$4, pad$2, prec$0, convert_int32, iconv$0); + case 6: + var + rest$5 = fmt$0[4], + prec$1 = fmt$0[3], + pad$3 = fmt$0[2], + iconv$1 = fmt$0[1]; + return make_int_padding_precision + (k$0, + acc$0, + rest$5, + pad$3, + prec$1, + convert_nativeint, + iconv$1); + case 7: + var + rest$6 = fmt$0[4], + prec$2 = fmt$0[3], + pad$4 = fmt$0[2], + iconv$2 = fmt$0[1]; + return make_int_padding_precision + (k$0, acc$0, rest$6, pad$4, prec$2, convert_int64, iconv$2); + case 8: + var + rest$7 = fmt$0[4], + prec$3 = fmt$0[3], + pad$5 = fmt$0[2], + fconv = fmt$0[1]; + if(typeof pad$5 === "number"){ + if(typeof prec$3 === "number") + return prec$3 + ? function + (p, x){ + var str = convert_float(fconv, p, x); + return make_printf(k$0, [4, acc$0, str], rest$7); + } + : function + (x){ + var + str = + convert_float(fconv, default_float_precision(fconv), x); + return make_printf(k$0, [4, acc$0, str], rest$7); + }; + var p = prec$3[1]; + return function(x){ + var str = convert_float(fconv, p, x); + return make_printf(k$0, [4, acc$0, str], rest$7);}; + } + if(0 === pad$5[0]){ + var w = pad$5[2], padty = pad$5[1]; + if(typeof prec$3 === "number") + return prec$3 + ? function + (p, x){ + var str = fix_padding(padty, w, convert_float(fconv, p, x)); + return make_printf(k$0, [4, acc$0, str], rest$7); + } + : function + (x){ + var + str = + convert_float(fconv, default_float_precision(fconv), x), + str$0 = fix_padding(padty, w, str); + return make_printf(k$0, [4, acc$0, str$0], rest$7); + }; + var p$0 = prec$3[1]; + return function(x){ + var str = fix_padding(padty, w, convert_float(fconv, p$0, x)); + return make_printf(k$0, [4, acc$0, str], rest$7);}; + } + var padty$0 = pad$5[1]; + if(typeof prec$3 === "number") + return prec$3 + ? function + (w, p, x){ + var + str = fix_padding(padty$0, w, convert_float(fconv, p, x)); + return make_printf(k$0, [4, acc$0, str], rest$7); + } + : function + (w, x){ + var + str = + convert_float(fconv, default_float_precision(fconv), x), + str$0 = fix_padding(padty$0, w, str); + return make_printf(k$0, [4, acc$0, str$0], rest$7); + }; + var p$1 = prec$3[1]; + return function(w, x){ + var str = fix_padding(padty$0, w, convert_float(fconv, p$1, x)); + return make_printf(k$0, [4, acc$0, str], rest$7);}; + case 9: + var rest$8 = fmt$0[2], pad$6 = fmt$0[1]; + return make_padding(k$0, acc$0, rest$8, pad$6, Stdlib[30]); + case 10: + var rest$9 = fmt$0[1], acc$1 = [7, acc$0]; + acc$0 = acc$1; + fmt$0 = rest$9; + break; + case 11: + var rest$10 = fmt$0[2], str = fmt$0[1], acc$2 = [2, acc$0, str]; + acc$0 = acc$2; + fmt$0 = rest$10; + break; + case 12: + var rest$11 = fmt$0[2], chr = fmt$0[1], acc$3 = [3, acc$0, chr]; + acc$0 = acc$3; + fmt$0 = rest$11; + break; + case 13: + var + rest$12 = fmt$0[3], + sub_fmtty = fmt$0[2], + ty = string_of_fmtty(sub_fmtty); + return function(str){ + return make_printf(k$0, [4, acc$0, ty], rest$12);}; + case 14: + var rest$13 = fmt$0[3], fmtty = fmt$0[2]; + return function(param){ + var fmt = param[1], _cf_ = recast(fmt, fmtty); + return make_printf + (k$0, + acc$0, + caml_call2(CamlinternalFormatBasics[3], _cf_, rest$13));}; + case 15: + var rest$14 = fmt$0[1]; + return function(f, x){ + return make_printf + (k$0, + [6, acc$0, function(o){return caml_call2(f, o, x);}], + rest$14);}; + case 16: + var rest$15 = fmt$0[1]; + return function(f){return make_printf(k$0, [6, acc$0, f], rest$15);}; + case 17: + var + rest$16 = fmt$0[2], + fmting_lit = fmt$0[1], + acc$4 = [0, acc$0, fmting_lit]; + acc$0 = acc$4; + fmt$0 = rest$16; + break; + case 18: + var _cd_ = fmt$0[1]; + if(0 === _cd_[0]){ + var rest$17 = fmt$0[2], fmt$1 = _cd_[1][1]; + let acc = acc$0, k = k$0, rest = rest$17; + var + k$1 = + function(kacc){return make_printf(k, [1, acc, [0, kacc]], rest);}; + k$0 = k$1; + acc$0 = 0; + fmt$0 = fmt$1; + } + else{ + var rest$18 = fmt$0[2], fmt$2 = _cd_[1][1]; + let acc = acc$0, k = k$0, rest = rest$18; + var + k$2 = + function(kacc){return make_printf(k, [1, acc, [1, kacc]], rest);}; + k$0 = k$2; + acc$0 = 0; + fmt$0 = fmt$2; + } + break; + case 19: + throw caml_maybe_attach_backtrace([0, Assert_failure, _s_], 1); + case 20: + var + rest$19 = fmt$0[3], + new_acc = [8, acc$0, cst_Printf_bad_conversion]; + return function(param){return make_printf(k$0, new_acc, rest$19);}; + case 21: + var rest$20 = fmt$0[2]; + return function(n){ + var new_acc = [4, acc$0, caml_format_int(cst_u$0, n)]; + return make_printf(k$0, new_acc, rest$20);}; + case 22: + var rest$21 = fmt$0[1]; + return function(c){ + var new_acc = [5, acc$0, c]; + return make_printf(k$0, new_acc, rest$21);}; + case 23: + var rest$22 = fmt$0[2], ign = fmt$0[1]; + if(counter >= 50) + return caml_trampoline_return + (make_ignored_param$0, [0, k$0, acc$0, ign, rest$22]); + var counter$1 = counter + 1 | 0; + return make_ignored_param$0(counter$1, k$0, acc$0, ign, rest$22); + default: + var + rest$23 = fmt$0[3], + f = fmt$0[2], + arity = fmt$0[1], + _ce_ = caml_call1(f, 0); + if(counter >= 50) + return caml_trampoline_return + (make_custom$0, [0, k$0, acc$0, rest$23, arity, _ce_]); + var counter$0 = counter + 1 | 0; + return make_custom$0(counter$0, k$0, acc$0, rest$23, arity, _ce_); + } + } + } + function make_printf(k, acc, fmt){ + return caml_trampoline(make_printf$0(0, k, acc, fmt)); + } + function make_ignored_param$0(counter, k, acc, ign, fmt){ + if(typeof ign === "number") + switch(ign){ + case 0: + if(counter >= 50) + return caml_trampoline_return(make_invalid_arg, [0, k, acc, fmt]); + var counter$0 = counter + 1 | 0; + return make_invalid_arg(counter$0, k, acc, fmt); + case 1: + if(counter >= 50) + return caml_trampoline_return(make_invalid_arg, [0, k, acc, fmt]); + var counter$1 = counter + 1 | 0; + return make_invalid_arg(counter$1, k, acc, fmt); + case 2: + throw caml_maybe_attach_backtrace([0, Assert_failure, _t_], 1); + default: + if(counter >= 50) + return caml_trampoline_return(make_invalid_arg, [0, k, acc, fmt]); + var counter$2 = counter + 1 | 0; + return make_invalid_arg(counter$2, k, acc, fmt); + } + switch(ign[0]){ + case 0: + if(counter >= 50) + return caml_trampoline_return(make_invalid_arg, [0, k, acc, fmt]); + var counter$3 = counter + 1 | 0; + return make_invalid_arg(counter$3, k, acc, fmt); + case 1: + if(counter >= 50) + return caml_trampoline_return(make_invalid_arg, [0, k, acc, fmt]); + var counter$4 = counter + 1 | 0; + return make_invalid_arg(counter$4, k, acc, fmt); + case 2: + if(counter >= 50) + return caml_trampoline_return(make_invalid_arg, [0, k, acc, fmt]); + var counter$5 = counter + 1 | 0; + return make_invalid_arg(counter$5, k, acc, fmt); + case 3: + if(counter >= 50) + return caml_trampoline_return(make_invalid_arg, [0, k, acc, fmt]); + var counter$6 = counter + 1 | 0; + return make_invalid_arg(counter$6, k, acc, fmt); + case 4: + if(counter >= 50) + return caml_trampoline_return(make_invalid_arg, [0, k, acc, fmt]); + var counter$7 = counter + 1 | 0; + return make_invalid_arg(counter$7, k, acc, fmt); + case 5: + if(counter >= 50) + return caml_trampoline_return(make_invalid_arg, [0, k, acc, fmt]); + var counter$8 = counter + 1 | 0; + return make_invalid_arg(counter$8, k, acc, fmt); + case 6: + if(counter >= 50) + return caml_trampoline_return(make_invalid_arg, [0, k, acc, fmt]); + var counter$9 = counter + 1 | 0; + return make_invalid_arg(counter$9, k, acc, fmt); + case 7: + if(counter >= 50) + return caml_trampoline_return(make_invalid_arg, [0, k, acc, fmt]); + var counter$10 = counter + 1 | 0; + return make_invalid_arg(counter$10, k, acc, fmt); + case 8: + if(counter >= 50) + return caml_trampoline_return(make_invalid_arg, [0, k, acc, fmt]); + var counter$11 = counter + 1 | 0; + return make_invalid_arg(counter$11, k, acc, fmt); + case 9: + var fmtty = ign[2]; + if(counter >= 50) + return caml_trampoline_return + (make_from_fmtty$0, [0, k, acc, fmtty, fmt]); + var counter$14 = counter + 1 | 0; + return make_from_fmtty$0(counter$14, k, acc, fmtty, fmt); + case 10: + if(counter >= 50) + return caml_trampoline_return(make_invalid_arg, [0, k, acc, fmt]); + var counter$12 = counter + 1 | 0; + return make_invalid_arg(counter$12, k, acc, fmt); + default: + if(counter >= 50) + return caml_trampoline_return(make_invalid_arg, [0, k, acc, fmt]); + var counter$13 = counter + 1 | 0; + return make_invalid_arg(counter$13, k, acc, fmt); + } + } + function make_ignored_param(k, acc, ign, fmt){ + return caml_trampoline(make_ignored_param$0(0, k, acc, ign, fmt)); + } + function make_from_fmtty$0(counter, k, acc, fmtty, fmt){ + if(typeof fmtty !== "number") + switch(fmtty[0]){ + case 0: + var rest = fmtty[1]; + return function(param){return make_from_fmtty(k, acc, rest, fmt);}; + case 1: + var rest$0 = fmtty[1]; + return function(param){return make_from_fmtty(k, acc, rest$0, fmt);}; + case 2: + var rest$1 = fmtty[1]; + return function(param){return make_from_fmtty(k, acc, rest$1, fmt);}; + case 3: + var rest$2 = fmtty[1]; + return function(param){return make_from_fmtty(k, acc, rest$2, fmt);}; + case 4: + var rest$3 = fmtty[1]; + return function(param){return make_from_fmtty(k, acc, rest$3, fmt);}; + case 5: + var rest$4 = fmtty[1]; + return function(param){return make_from_fmtty(k, acc, rest$4, fmt);}; + case 6: + var rest$5 = fmtty[1]; + return function(param){return make_from_fmtty(k, acc, rest$5, fmt);}; + case 7: + var rest$6 = fmtty[1]; + return function(param){return make_from_fmtty(k, acc, rest$6, fmt);}; + case 8: + var rest$7 = fmtty[2]; + return function(param){return make_from_fmtty(k, acc, rest$7, fmt);}; + case 9: + var + rest$8 = fmtty[3], + ty2 = fmtty[2], + ty1 = fmtty[1], + ty = trans(symm(ty1), ty2); + return function(param){ + return make_from_fmtty + (k, + acc, + caml_call2(CamlinternalFormatBasics[1], ty, rest$8), + fmt);}; + case 10: + var rest$9 = fmtty[1]; + return function(param, _cc_){ + return make_from_fmtty(k, acc, rest$9, fmt);}; + case 11: + var rest$10 = fmtty[1]; + return function(param){return make_from_fmtty(k, acc, rest$10, fmt);}; + case 12: + var rest$11 = fmtty[1]; + return function(param){return make_from_fmtty(k, acc, rest$11, fmt);}; + case 13: + throw caml_maybe_attach_backtrace([0, Assert_failure, _u_], 1); + default: + throw caml_maybe_attach_backtrace([0, Assert_failure, _v_], 1); + } + if(counter >= 50) + return caml_trampoline_return(make_invalid_arg, [0, k, acc, fmt]); + var counter$0 = counter + 1 | 0; + return make_invalid_arg(counter$0, k, acc, fmt); + } + function make_from_fmtty(k, acc, fmtty, fmt){ + return caml_trampoline(make_from_fmtty$0(0, k, acc, fmtty, fmt)); + } + function make_invalid_arg(counter, k, acc, fmt){ + var _cb_ = [8, acc, cst_Printf_bad_conversion$0]; + if(counter >= 50) + return caml_trampoline_return(make_printf$0, [0, k, _cb_, fmt]); + var counter$0 = counter + 1 | 0; + return make_printf$0(counter$0, k, _cb_, fmt); + } + function make_padding(k, acc, fmt, pad, trans){ + if(typeof pad === "number") + return function(x){ + var new_acc = [4, acc, caml_call1(trans, x)]; + return make_printf(k, new_acc, fmt);}; + if(0 === pad[0]){ + var width = pad[2], padty = pad[1]; + return function(x){ + var new_acc = [4, acc, fix_padding(padty, width, caml_call1(trans, x))]; + return make_printf(k, new_acc, fmt);}; + } + var padty$0 = pad[1]; + return function(w, x){ + var new_acc = [4, acc, fix_padding(padty$0, w, caml_call1(trans, x))]; + return make_printf(k, new_acc, fmt);}; + } + function make_int_padding_precision(k, acc, fmt, pad, prec, trans, iconv){ + if(typeof pad === "number"){ + if(typeof prec === "number") + return prec + ? function + (p, x){ + var str = fix_int_precision(p, caml_call2(trans, iconv, x)); + return make_printf(k, [4, acc, str], fmt); + } + : function + (x){ + var str = caml_call2(trans, iconv, x); + return make_printf(k, [4, acc, str], fmt); + }; + var p = prec[1]; + return function(x){ + var str = fix_int_precision(p, caml_call2(trans, iconv, x)); + return make_printf(k, [4, acc, str], fmt);}; + } + if(0 === pad[0]){ + var w = pad[2], padty = pad[1]; + if(typeof prec === "number") + return prec + ? function + (p, x){ + var + str = + fix_padding + (padty, + w, + fix_int_precision(p, caml_call2(trans, iconv, x))); + return make_printf(k, [4, acc, str], fmt); + } + : function + (x){ + var str = fix_padding(padty, w, caml_call2(trans, iconv, x)); + return make_printf(k, [4, acc, str], fmt); + }; + var p$0 = prec[1]; + return function(x){ + var + str = + fix_padding + (padty, w, fix_int_precision(p$0, caml_call2(trans, iconv, x))); + return make_printf(k, [4, acc, str], fmt);}; + } + var padty$0 = pad[1]; + if(typeof prec === "number") + return prec + ? function + (w, p, x){ + var + str = + fix_padding + (padty$0, + w, + fix_int_precision(p, caml_call2(trans, iconv, x))); + return make_printf(k, [4, acc, str], fmt); + } + : function + (w, x){ + var str = fix_padding(padty$0, w, caml_call2(trans, iconv, x)); + return make_printf(k, [4, acc, str], fmt); + }; + var p$1 = prec[1]; + return function(w, x){ + var + str = + fix_padding + (padty$0, w, fix_int_precision(p$1, caml_call2(trans, iconv, x))); + return make_printf(k, [4, acc, str], fmt);}; + } + function make_custom$0(counter, k, acc, rest, arity, f){ + if(arity){ + var arity$0 = arity[1]; + return function(x){ + return make_custom(k, acc, rest, arity$0, caml_call1(f, x));}; + } + var _ca_ = [4, acc, f]; + if(counter >= 50) + return caml_trampoline_return(make_printf$0, [0, k, _ca_, rest]); + var counter$0 = counter + 1 | 0; + return make_printf$0(counter$0, k, _ca_, rest); + } + function make_custom(k, acc, rest, arity, f){ + return caml_trampoline(make_custom$0(0, k, acc, rest, arity, f)); + } + function make_iprintf$0(counter, k, o, fmt){ + var k$0 = k, fmt$0 = fmt; + for(;;){ + if(typeof fmt$0 === "number") return caml_call1(k$0, o); + switch(fmt$0[0]){ + case 0: + var rest = fmt$0[1], x = make_iprintf(k$0, o, rest); + return function(_b$_){return x;}; + case 1: + var rest$0 = fmt$0[1], x$0 = make_iprintf(k$0, o, rest$0); + return function(_b__){return x$0;}; + case 2: + var _bM_ = fmt$0[1]; + if(typeof _bM_ === "number"){ + var rest$1 = fmt$0[2], x$1 = make_iprintf(k$0, o, rest$1); + return function(_b9_){return x$1;}; + } + if(0 === _bM_[0]){ + var rest$2 = fmt$0[2], x$2 = make_iprintf(k$0, o, rest$2); + return function(_b8_){return x$2;}; + } + var + rest$3 = fmt$0[2], + x$3 = make_iprintf(k$0, o, rest$3), + x$4 = function(_b7_){return x$3;}; + return function(_b6_){return x$4;}; + case 3: + var _bN_ = fmt$0[1]; + if(typeof _bN_ === "number"){ + var rest$4 = fmt$0[2], x$5 = make_iprintf(k$0, o, rest$4); + return function(_b5_){return x$5;}; + } + if(0 === _bN_[0]){ + var rest$5 = fmt$0[2], x$6 = make_iprintf(k$0, o, rest$5); + return function(_b4_){return x$6;}; + } + var + rest$6 = fmt$0[2], + x$7 = make_iprintf(k$0, o, rest$6), + x$8 = function(_b3_){return x$7;}; + return function(_b2_){return x$8;}; + case 4: + var rest$7 = fmt$0[4], prec = fmt$0[3], pad = fmt$0[2]; + return fn_of_padding_precision(k$0, o, rest$7, pad, prec); + case 5: + var rest$8 = fmt$0[4], prec$0 = fmt$0[3], pad$0 = fmt$0[2]; + return fn_of_padding_precision(k$0, o, rest$8, pad$0, prec$0); + case 6: + var rest$9 = fmt$0[4], prec$1 = fmt$0[3], pad$1 = fmt$0[2]; + return fn_of_padding_precision(k$0, o, rest$9, pad$1, prec$1); + case 7: + var rest$10 = fmt$0[4], prec$2 = fmt$0[3], pad$2 = fmt$0[2]; + return fn_of_padding_precision(k$0, o, rest$10, pad$2, prec$2); + case 8: + var rest$11 = fmt$0[4], prec$3 = fmt$0[3], pad$3 = fmt$0[2]; + return fn_of_padding_precision(k$0, o, rest$11, pad$3, prec$3); + case 9: + var _bO_ = fmt$0[1]; + if(typeof _bO_ === "number"){ + var rest$12 = fmt$0[2], x$9 = make_iprintf(k$0, o, rest$12); + return function(_b1_){return x$9;}; + } + if(0 === _bO_[0]){ + var rest$13 = fmt$0[2], x$10 = make_iprintf(k$0, o, rest$13); + return function(_b0_){return x$10;}; + } + var + rest$14 = fmt$0[2], + x$11 = make_iprintf(k$0, o, rest$14), + x$12 = function(_bZ_){return x$11;}; + return function(_bY_){return x$12;}; + case 10: + var rest$15 = fmt$0[1]; fmt$0 = rest$15; break; + case 11: + var rest$16 = fmt$0[2]; fmt$0 = rest$16; break; + case 12: + var rest$17 = fmt$0[2]; fmt$0 = rest$17; break; + case 13: + var rest$18 = fmt$0[3], x$13 = make_iprintf(k$0, o, rest$18); + return function(_bX_){return x$13;}; + case 14: + var rest$19 = fmt$0[3], fmtty = fmt$0[2]; + return function(param){ + var fmt = param[1], _bW_ = recast(fmt, fmtty); + return make_iprintf + (k$0, + o, + caml_call2(CamlinternalFormatBasics[3], _bW_, rest$19));}; + case 15: + var + rest$20 = fmt$0[1], + x$14 = make_iprintf(k$0, o, rest$20), + x$15 = function(_bV_){return x$14;}; + return function(_bU_){return x$15;}; + case 16: + var rest$21 = fmt$0[1], x$16 = make_iprintf(k$0, o, rest$21); + return function(_bT_){return x$16;}; + case 17: + var rest$22 = fmt$0[2]; fmt$0 = rest$22; break; + case 18: + var _bP_ = fmt$0[1]; + if(0 === _bP_[0]){ + var rest$23 = fmt$0[2], fmt$1 = _bP_[1][1]; + let k = k$0, rest = rest$23; + var k$1 = function(koc){return make_iprintf(k, koc, rest);}; + k$0 = k$1; + fmt$0 = fmt$1; + } + else{ + var rest$24 = fmt$0[2], fmt$2 = _bP_[1][1]; + let k = k$0, rest = rest$24; + var k$2 = function(koc){return make_iprintf(k, koc, rest);}; + k$0 = k$2; + fmt$0 = fmt$2; + } + break; + case 19: + throw caml_maybe_attach_backtrace([0, Assert_failure, _w_], 1); + case 20: + var rest$25 = fmt$0[3], x$17 = make_iprintf(k$0, o, rest$25); + return function(_bS_){return x$17;}; + case 21: + var rest$26 = fmt$0[2], x$18 = make_iprintf(k$0, o, rest$26); + return function(_bR_){return x$18;}; + case 22: + var rest$27 = fmt$0[1], x$19 = make_iprintf(k$0, o, rest$27); + return function(_bQ_){return x$19;}; + case 23: + var rest$28 = fmt$0[2], ign = fmt$0[1]; + return make_ignored_param + (function(param){return caml_call1(k$0, o);}, 0, ign, rest$28); + default: + var rest$29 = fmt$0[3], arity = fmt$0[1]; + if(counter >= 50) + return caml_trampoline_return + (fn_of_custom_arity$0, [0, k$0, o, rest$29, arity]); + var counter$0 = counter + 1 | 0; + return fn_of_custom_arity$0(counter$0, k$0, o, rest$29, arity); + } + } + } + function make_iprintf(k, o, fmt){ + return caml_trampoline(make_iprintf$0(0, k, o, fmt)); + } + function fn_of_padding_precision(k, o, fmt, pad, prec){ + if(typeof pad === "number"){ + if(typeof prec !== "number"){ + var x$2 = make_iprintf(k, o, fmt); + return function(_bL_){return x$2;}; + } + if(prec){ + var x = make_iprintf(k, o, fmt), x$0 = function(_bK_){return x;}; + return function(_bJ_){return x$0;}; + } + var x$1 = make_iprintf(k, o, fmt); + return function(_bI_){return x$1;}; + } + if(0 === pad[0]){ + if(typeof prec !== "number"){ + var x$6 = make_iprintf(k, o, fmt); + return function(_bH_){return x$6;}; + } + if(prec){ + var x$3 = make_iprintf(k, o, fmt), x$4 = function(_bG_){return x$3;}; + return function(_bF_){return x$4;}; + } + var x$5 = make_iprintf(k, o, fmt); + return function(_bE_){return x$5;}; + } + if(typeof prec !== "number"){ + var x$12 = make_iprintf(k, o, fmt), x$13 = function(_bD_){return x$12;}; + return function(_bC_){return x$13;}; + } + if(prec){ + var + x$7 = make_iprintf(k, o, fmt), + x$8 = function(_bB_){return x$7;}, + x$9 = function(_bA_){return x$8;}; + return function(_bz_){return x$9;}; + } + var x$10 = make_iprintf(k, o, fmt); + function x$11(_by_){return x$10;} + return function(_bx_){return x$11;}; + } + function fn_of_custom_arity$0(counter, k, o, fmt, param){ + if(param){ + var arity = param[1], x = fn_of_custom_arity(k, o, fmt, arity); + return function(_bw_){return x;}; + } + if(counter >= 50) + return caml_trampoline_return(make_iprintf$0, [0, k, o, fmt]); + var counter$0 = counter + 1 | 0; + return make_iprintf$0(counter$0, k, o, fmt); + } + function fn_of_custom_arity(k, o, fmt, param){ + return caml_trampoline(fn_of_custom_arity$0(0, k, o, fmt, param)); + } + function output_acc(o, acc){ + var acc$0 = acc; + for(;;){ + if(typeof acc$0 === "number") return 0; + switch(acc$0[0]){ + case 0: + var + fmting_lit = acc$0[2], + p = acc$0[1], + s = string_of_formatting_lit(fmting_lit); + output_acc(o, p); + return caml_call2(Stdlib[66], o, s); + case 1: + var match = acc$0[2], p$0 = acc$0[1]; + if(0 === match[0]){ + var acc$1 = match[1]; + output_acc(o, p$0); + caml_call2(Stdlib[66], o, cst$18); + acc$0 = acc$1; + } + else{ + var acc$2 = match[1]; + output_acc(o, p$0); + caml_call2(Stdlib[66], o, cst$19); + acc$0 = acc$2; + } + break; + case 6: + var f = acc$0[2], p$3 = acc$0[1]; + output_acc(o, p$3); + return caml_call1(f, o); + case 7: + var p$4 = acc$0[1]; + output_acc(o, p$4); + return caml_call1(Stdlib[63], o); + case 8: + var msg = acc$0[2], p$5 = acc$0[1]; + output_acc(o, p$5); + return caml_call1(Stdlib[1], msg); + case 2: + case 4: + var s$0 = acc$0[2], p$1 = acc$0[1]; + output_acc(o, p$1); + return caml_call2(Stdlib[66], o, s$0); + default: + var c = acc$0[2], p$2 = acc$0[1]; + output_acc(o, p$2); + return caml_call2(Stdlib[65], o, c); + } + } + } + function bufput_acc(b, acc){ + var acc$0 = acc; + for(;;){ + if(typeof acc$0 === "number") return 0; + switch(acc$0[0]){ + case 0: + var + fmting_lit = acc$0[2], + p = acc$0[1], + s = string_of_formatting_lit(fmting_lit); + bufput_acc(b, p); + return caml_call2(Stdlib_Buffer[16], b, s); + case 1: + var match = acc$0[2], p$0 = acc$0[1]; + if(0 === match[0]){ + var acc$1 = match[1]; + bufput_acc(b, p$0); + caml_call2(Stdlib_Buffer[16], b, cst$20); + acc$0 = acc$1; + } + else{ + var acc$2 = match[1]; + bufput_acc(b, p$0); + caml_call2(Stdlib_Buffer[16], b, cst$21); + acc$0 = acc$2; + } + break; + case 6: + var f = acc$0[2], p$3 = acc$0[1]; + bufput_acc(b, p$3); + return caml_call1(f, b); + case 7: + var acc$3 = acc$0[1]; acc$0 = acc$3; break; + case 8: + var msg = acc$0[2], p$4 = acc$0[1]; + bufput_acc(b, p$4); + return caml_call1(Stdlib[1], msg); + case 2: + case 4: + var s$0 = acc$0[2], p$1 = acc$0[1]; + bufput_acc(b, p$1); + return caml_call2(Stdlib_Buffer[16], b, s$0); + default: + var c = acc$0[2], p$2 = acc$0[1]; + bufput_acc(b, p$2); + return caml_call2(Stdlib_Buffer[12], b, c); + } + } + } + function strput_acc(b, acc){ + var acc$0 = acc; + for(;;){ + if(typeof acc$0 === "number") return 0; + switch(acc$0[0]){ + case 0: + var + fmting_lit = acc$0[2], + p = acc$0[1], + s = string_of_formatting_lit(fmting_lit); + strput_acc(b, p); + return caml_call2(Stdlib_Buffer[16], b, s); + case 1: + var match = acc$0[2], p$0 = acc$0[1]; + if(0 === match[0]){ + var acc$1 = match[1]; + strput_acc(b, p$0); + caml_call2(Stdlib_Buffer[16], b, cst$22); + acc$0 = acc$1; + } + else{ + var acc$2 = match[1]; + strput_acc(b, p$0); + caml_call2(Stdlib_Buffer[16], b, cst$23); + acc$0 = acc$2; + } + break; + case 6: + var f = acc$0[2], p$3 = acc$0[1]; + strput_acc(b, p$3); + var _bv_ = caml_call1(f, 0); + return caml_call2(Stdlib_Buffer[16], b, _bv_); + case 7: + var acc$3 = acc$0[1]; acc$0 = acc$3; break; + case 8: + var msg = acc$0[2], p$4 = acc$0[1]; + strput_acc(b, p$4); + return caml_call1(Stdlib[1], msg); + case 2: + case 4: + var s$0 = acc$0[2], p$1 = acc$0[1]; + strput_acc(b, p$1); + return caml_call2(Stdlib_Buffer[16], b, s$0); + default: + var c = acc$0[2], p$2 = acc$0[1]; + strput_acc(b, p$2); + return caml_call2(Stdlib_Buffer[12], b, c); + } + } + } + function failwith_message(param){ + var fmt = param[1], buf = caml_call1(Stdlib_Buffer[1], 256); + function k(acc){ + strput_acc(buf, acc); + var _bu_ = caml_call1(Stdlib_Buffer[2], buf); + return caml_call1(Stdlib[2], _bu_); + } + return make_printf(k, 0, fmt); + } + function open_box_of_string(str){ + if(str == cst$43) return _x_; + var len = caml_ml_string_length(str); + function invalid_box(param){ + return caml_call1(failwith_message(_y_), str); + } + function parse_spaces(i){ + var i$0 = i; + for(;;){ + if(i$0 === len) return i$0; + var match = caml_string_get(str, i$0); + if(9 !== match && 32 !== match) return i$0; + var i$1 = i$0 + 1 | 0; + i$0 = i$1; + } + } + var wstart = parse_spaces(0); + a: + b: + { + var wend = wstart; + for(;;){ + if(wend === len) break b; + if(25 < caml_string_get(str, wend) - 97 >>> 0) break; + var j = wend + 1 | 0; + wend = j; + } + break a; + } + var + box_name = caml_call3(Stdlib_String[15], str, wstart, wend - wstart | 0), + nstart = parse_spaces(wend); + a: + b: + { + var nend = nstart; + for(;;){ + if(nend === len) break b; + var match = caml_string_get(str, nend); + if(48 <= match){if(58 <= match) break;} else if(45 !== match) break; + var j$0 = nend + 1 | 0; + nend = j$0; + } + break a; + } + if(nstart === nend) + var indent = 0; + else + try{ + var + _bs_ = + runtime.caml_int_of_string + (caml_call3(Stdlib_String[15], str, nstart, nend - nstart | 0)), + indent = _bs_; + } + catch(_bt_){ + var _br_ = caml_wrap_exception(_bt_); + if(_br_[1] !== Stdlib[7]) throw caml_maybe_attach_backtrace(_br_, 0); + var indent = invalid_box(0); + } + var exp_end = parse_spaces(nend); + if(exp_end !== len) invalid_box(0); + a: + { + if(box_name !== cst$43 && box_name !== "b"){ + if(box_name === "h"){var box_type = 0; break a;} + if(box_name === "hov"){var box_type = 3; break a;} + if(box_name === "hv"){var box_type = 2; break a;} + if(box_name !== "v"){var box_type = invalid_box(0); break a;} + var box_type = 1; + break a; + } + var box_type = 4; + } + return [0, indent, box_type]; + } + function make_padding_fmt_ebb(pad, fmt){ + if(typeof pad === "number") return [0, 0, fmt]; + if(0 === pad[0]){var w = pad[2], s = pad[1]; return [0, [0, s, w], fmt];} + var s$0 = pad[1]; + return [0, [1, s$0], fmt]; + } + function make_padprec_fmt_ebb(pad, prec, fmt){ + if(typeof prec === "number") + var match = prec ? [0, 1] : [0, 0]; + else + var p = prec[1], match = [0, [0, p]]; + var prec$0 = match[1]; + if(typeof pad === "number") return [0, 0, prec$0, fmt]; + if(0 === pad[0]){ + var w = pad[2], s = pad[1]; + return [0, [0, s, w], prec$0, fmt]; + } + var s$0 = pad[1]; + return [0, [1, s$0], prec$0, fmt]; + } + function fmt_ebb_of_string(legacy_behavior, str){ + if(legacy_behavior) + var flag = legacy_behavior[1], legacy_behavior$0 = flag; + else + var legacy_behavior$0 = 1; + function invalid_format_message(str_ind, msg){ + return caml_call3(failwith_message(_z_), str, str_ind, msg); + } + function invalid_format_without(str_ind, c, s){ + return caml_call4(failwith_message(_A_), str, str_ind, c, s); + } + function expected_character(str_ind, expected, read){ + return caml_call4(failwith_message(_B_), str, str_ind, expected, read); + } + function parse(lit_start, end_ind){ + a: + { + var str_ind = lit_start; + for(;;){ + if(str_ind === end_ind) return add_literal(lit_start, str_ind, 0); + var match = caml_string_get(str, str_ind); + if(37 === match) break; + if(64 === match) break a; + var str_ind$1 = str_ind + 1 | 0; + str_ind = str_ind$1; + } + var str_ind$2 = str_ind + 1 | 0; + if(str_ind$2 === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + var + match$1 = + 95 === caml_string_get(str, str_ind$2) + ? parse_flags(str_ind, str_ind$2 + 1 | 0, end_ind, 1) + : parse_flags(str_ind, str_ind$2, end_ind, 0), + fmt_rest = match$1[1]; + return add_literal(lit_start, str_ind, fmt_rest); + } + var str_ind$0 = str_ind + 1 | 0; + a: + if(str_ind$0 === end_ind) + var match$0 = _N_; + else{ + var c = caml_string_get(str, str_ind$0); + if(65 <= c){ + if(94 <= c){ + var switcher = c - 123 | 0; + if(2 >= switcher >>> 0) + switch(switcher){ + case 0: + var match$0 = parse_tag(1, str_ind$0 + 1 | 0, end_ind); break a; + case 1: break; + default: + var + fmt_rest$2 = parse(str_ind$0 + 1 | 0, end_ind)[1], + match$0 = [0, [17, 1, fmt_rest$2]]; + break a; + } + } + else if(91 <= c) + switch(c - 91 | 0){ + case 0: + var match$0 = parse_tag(0, str_ind$0 + 1 | 0, end_ind); break a; + case 1: break; + default: + var + fmt_rest$3 = parse(str_ind$0 + 1 | 0, end_ind)[1], + match$0 = [0, [17, 0, fmt_rest$3]]; + break a; + } + } + else{ + if(10 === c){ + var + fmt_rest$4 = parse(str_ind$0 + 1 | 0, end_ind)[1], + match$0 = [0, [17, 3, fmt_rest$4]]; + break a; + } + if(32 <= c) + switch(c - 32 | 0){ + case 0: + var + fmt_rest$5 = parse(str_ind$0 + 1 | 0, end_ind)[1], + match$0 = [0, [17, _O_, fmt_rest$5]]; + break a; + case 5: + if + ((str_ind$0 + 1 | 0) < end_ind + && 37 === caml_string_get(str, str_ind$0 + 1 | 0)){ + var + fmt_rest$6 = parse(str_ind$0 + 2 | 0, end_ind)[1], + match$0 = [0, [17, 6, fmt_rest$6]]; + break a; + } + var + fmt_rest$7 = parse(str_ind$0, end_ind)[1], + match$0 = [0, [12, 64, fmt_rest$7]]; + break a; + case 12: + var + fmt_rest$8 = parse(str_ind$0 + 1 | 0, end_ind)[1], + match$0 = [0, [17, _P_, fmt_rest$8]]; + break a; + case 14: + var + fmt_rest$9 = parse(str_ind$0 + 1 | 0, end_ind)[1], + match$0 = [0, [17, 4, fmt_rest$9]]; + break a; + case 27: + var str_ind$3 = str_ind$0 + 1 | 0; + b: + try{ + var + _bg_ = str_ind$3 === end_ind ? 1 : 0, + _bh_ = _bg_ || (60 !== caml_string_get(str, str_ind$3) ? 1 : 0); + if(_bh_) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + var + str_ind_1 = parse_spaces(str_ind$3 + 1 | 0, end_ind), + match$2 = caml_string_get(str, str_ind_1); + c: + { + if(48 <= match$2){ + if(58 > match$2) break c; + } + else if(45 === match$2) break c; + throw caml_maybe_attach_backtrace(Stdlib[8], 1); + } + var + match$3 = parse_integer(str_ind_1, end_ind), + width = match$3[2], + str_ind_2 = match$3[1], + str_ind_3 = parse_spaces(str_ind_2, end_ind), + switcher$0 = caml_string_get(str, str_ind_3) - 45 | 0; + if(12 < switcher$0 >>> 0){ + if(17 === switcher$0){ + var + s = + caml_call3 + (Stdlib_String[15], + str, + str_ind$3 - 2 | 0, + (str_ind_3 - str_ind$3 | 0) + 3 | 0), + _bi_ = [0, s, width, 0], + _bj_ = str_ind_3 + 1 | 0, + formatting_lit$0 = _bi_, + next_ind = _bj_; + break b; + } + } + else if(1 < switcher$0 - 1 >>> 0){ + var + match$4 = parse_integer(str_ind_3, end_ind), + offset = match$4[2], + str_ind_4 = match$4[1], + str_ind_5 = parse_spaces(str_ind_4, end_ind); + if(62 !== caml_string_get(str, str_ind_5)) + throw caml_maybe_attach_backtrace(Stdlib[8], 1); + var + s$0 = + caml_call3 + (Stdlib_String[15], + str, + str_ind$3 - 2 | 0, + (str_ind_5 - str_ind$3 | 0) + 3 | 0), + _bk_ = [0, s$0, width, offset], + _bl_ = str_ind_5 + 1 | 0, + formatting_lit$0 = _bk_, + next_ind = _bl_; + break b; + } + throw caml_maybe_attach_backtrace(Stdlib[8], 1); + } + catch(_bq_){ + var _bf_ = caml_wrap_exception(_bq_); + if(_bf_ !== Stdlib[8] && _bf_[1] !== Stdlib[7]) + throw caml_maybe_attach_backtrace(_bf_, 0); + var formatting_lit$0 = formatting_lit, next_ind = str_ind$3; + } + var + fmt_rest$12 = parse(next_ind, end_ind)[1], + match$0 = [0, [17, formatting_lit$0, fmt_rest$12]]; + break a; + case 28: + var str_ind$4 = str_ind$0 + 1 | 0; + try{ + var + str_ind_1$0 = parse_spaces(str_ind$4, end_ind), + match$6 = caml_string_get(str, str_ind_1$0); + b: + { + c: + { + if(48 <= match$6){ + if(58 > match$6) break c; + } + else if(45 === match$6) break c; + var _bo_ = 0; + break b; + } + var + match$7 = parse_integer(str_ind_1$0, end_ind), + size = match$7[2], + str_ind_2$0 = match$7[1], + str_ind_3$0 = parse_spaces(str_ind_2$0, end_ind); + if(62 !== caml_string_get(str, str_ind_3$0)) + throw caml_maybe_attach_backtrace(Stdlib[8], 1); + var + s$1 = + caml_call3 + (Stdlib_String[15], + str, + str_ind$4 - 2 | 0, + (str_ind_3$0 - str_ind$4 | 0) + 3 | 0), + _bo_ = [0, [0, str_ind_3$0 + 1 | 0, [1, s$1, size]]]; + } + var _bn_ = _bo_; + } + catch(_bp_){ + var _bm_ = caml_wrap_exception(_bp_); + if(_bm_ !== Stdlib[8] && _bm_[1] !== Stdlib[7]) + throw caml_maybe_attach_backtrace(_bm_, 0); + var _bn_ = 0; + } + if(_bn_) + var + match$5 = _bn_[1], + formatting_lit$1 = match$5[2], + next_ind$0 = match$5[1], + fmt_rest$13 = parse(next_ind$0, end_ind)[1], + _be_ = [0, [17, formatting_lit$1, fmt_rest$13]]; + else + var + fmt_rest$14 = parse(str_ind$4, end_ind)[1], + _be_ = [0, [17, _Q_, fmt_rest$14]]; + var match$0 = _be_; + break a; + case 31: + var + fmt_rest$10 = parse(str_ind$0 + 1 | 0, end_ind)[1], + match$0 = [0, [17, 2, fmt_rest$10]]; + break a; + case 32: + var + fmt_rest$11 = parse(str_ind$0 + 1 | 0, end_ind)[1], + match$0 = [0, [17, 5, fmt_rest$11]]; + break a; + } + } + var + fmt_rest$1 = parse(str_ind$0 + 1 | 0, end_ind)[1], + match$0 = [0, [17, [2, c], fmt_rest$1]]; + } + var fmt_rest$0 = match$0[1]; + return add_literal(lit_start, str_ind, fmt_rest$0); + } + function parse_flags(pct_ind, str_ind, end_ind, ign){ + var + zero = [0, 0], + minus = [0, 0], + plus = [0, 0], + space = [0, 0], + hash = [0, 0]; + function set_flag(str_ind, flag){ + var _bb_ = flag[1], _bc_ = _bb_ ? 1 - legacy_behavior$0 : _bb_; + if(_bc_){ + var _bd_ = caml_string_get(str, str_ind); + caml_call3(failwith_message(_C_), str, str_ind, _bd_); + } + flag[1] = 1; + return; + } + a: + b: + { + var str_ind$0 = str_ind; + c: + for(;;){ + if(str_ind$0 === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + var switcher = caml_string_get(str, str_ind$0) - 32 | 0; + if(16 < switcher >>> 0) break b; + switch(switcher){ + case 0: + set_flag(str_ind$0, space); + var str_ind$1 = str_ind$0 + 1 | 0; + str_ind$0 = str_ind$1; + break; + case 3: + set_flag(str_ind$0, hash); + var str_ind$2 = str_ind$0 + 1 | 0; + str_ind$0 = str_ind$2; + break; + case 11: + set_flag(str_ind$0, plus); + var str_ind$3 = str_ind$0 + 1 | 0; + str_ind$0 = str_ind$3; + break; + case 13: + set_flag(str_ind$0, minus); + var str_ind$4 = str_ind$0 + 1 | 0; + str_ind$0 = str_ind$4; + break; + case 16: + set_flag(str_ind$0, zero); + var str_ind$5 = str_ind$0 + 1 | 0; + str_ind$0 = str_ind$5; + break; + default: break c; + } + } + break a; + } + var + space$0 = space[1], + hash$0 = hash[1], + plus$0 = plus[1], + minus$0 = minus[1], + zero$0 = zero[1]; + if(str_ind$0 === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + var + padty = + zero$0 + ? minus$0 + ? legacy_behavior$0 + ? 0 + : incompatible_flag(pct_ind, str_ind$0, 45, cst_0) + : 2 + : minus$0 ? 0 : 1, + match = caml_string_get(str, str_ind$0); + if(48 <= match){ + if(58 > match){ + var + match$0 = parse_positive(str_ind$0, end_ind, 0), + width = match$0[2], + new_ind = match$0[1]; + return parse_after_padding + (pct_ind, + new_ind, + end_ind, + minus$0, + plus$0, + hash$0, + space$0, + ign, + [0, padty, width]); + } + } + else if(42 === match) + return parse_after_padding + (pct_ind, + str_ind$0 + 1 | 0, + end_ind, + minus$0, + plus$0, + hash$0, + space$0, + ign, + [1, padty]); + switch(padty){ + case 0: + if(1 - legacy_behavior$0) + invalid_format_without(str_ind$0 - 1 | 0, 45, cst_padding); + return parse_after_padding + (pct_ind, + str_ind$0, + end_ind, + minus$0, + plus$0, + hash$0, + space$0, + ign, + 0); + case 1: + return parse_after_padding + (pct_ind, + str_ind$0, + end_ind, + minus$0, + plus$0, + hash$0, + space$0, + ign, + 0); + default: + return parse_after_padding + (pct_ind, + str_ind$0, + end_ind, + minus$0, + plus$0, + hash$0, + space$0, + ign, + _D_); + } + } + function parse_after_padding + (pct_ind, str_ind, end_ind, minus, plus, hash, space, ign, pad){ + if(str_ind === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + var symb = caml_string_get(str, str_ind); + if(46 !== symb) + return parse_conversion + (pct_ind, + str_ind + 1 | 0, + end_ind, + plus, + hash, + space, + ign, + pad, + 0, + pad, + symb); + var str_ind$0 = str_ind + 1 | 0; + if(str_ind$0 === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + function parse_literal(minus, str_ind){ + var + match = parse_positive(str_ind, end_ind, 0), + prec = match[2], + new_ind = match[1]; + return parse_after_precision + (pct_ind, + new_ind, + end_ind, + minus, + plus, + hash, + space, + ign, + pad, + [0, prec]); + } + var symb$0 = caml_string_get(str, str_ind$0); + if(48 <= symb$0){ + if(58 > symb$0) return parse_literal(minus, str_ind$0); + } + else if(42 <= symb$0) + switch(symb$0 - 42 | 0){ + case 0: + return parse_after_precision + (pct_ind, + str_ind$0 + 1 | 0, + end_ind, + minus, + plus, + hash, + space, + ign, + pad, + 1); + case 1: + case 3: + if(legacy_behavior$0){ + var + _ba_ = str_ind$0 + 1 | 0, + minus$0 = minus || (45 === symb$0 ? 1 : 0); + return parse_literal(minus$0, _ba_); + } + break; + } + return legacy_behavior$0 + ? parse_after_precision + (pct_ind, + str_ind$0, + end_ind, + minus, + plus, + hash, + space, + ign, + pad, + _E_) + : invalid_format_without(str_ind$0 - 1 | 0, 46, cst_precision); + } + function parse_after_precision + (pct_ind, str_ind, end_ind, minus, plus, hash, space, ign, pad, prec){ + if(str_ind === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + function parse_conv(padprec){ + return parse_conversion + (pct_ind, + str_ind + 1 | 0, + end_ind, + plus, + hash, + space, + ign, + pad, + prec, + padprec, + caml_string_get(str, str_ind)); + } + if(typeof pad !== "number") return parse_conv(pad); + if(typeof prec === "number" && ! prec) return parse_conv(0); + if(minus){ + if(typeof prec === "number") return parse_conv(_F_); + var n = prec[1]; + return parse_conv([0, 0, n]); + } + if(typeof prec === "number") return parse_conv(_G_); + var n$0 = prec[1]; + return parse_conv([0, 1, n$0]); + } + function parse_conversion + (pct_ind, + str_ind, + end_ind, + plus, + hash, + space, + ign, + pad, + prec, + padprec, + symb){ + var + plus_used = [0, 0], + hash_used = [0, 0], + space_used = [0, 0], + ign_used = [0, 0], + pad_used = [0, 0], + prec_used = [0, 0]; + function get_plus(param){plus_used[1] = 1; return plus;} + function get_hash(param){hash_used[1] = 1; return hash;} + function get_space(param){space_used[1] = 1; return space;} + function get_ign(param){ign_used[1] = 1; return ign;} + function get_pad(param){pad_used[1] = 1; return pad;} + function get_prec(param){prec_used[1] = 1; return prec;} + function get_padprec(param){pad_used[1] = 1; return padprec;} + function get_int_pad(param){ + var pad = get_pad(0), match = get_prec(0); + if(typeof match === "number" && ! match) return pad; + if(typeof pad === "number") return 0; + if(0 !== pad[0]) + return 2 <= pad[1] + ? legacy_behavior$0 + ? _H_ + : incompatible_flag(pct_ind, str_ind, 48, cst_precision$1) + : pad; + if(2 > pad[1]) return pad; + var n = pad[2]; + return legacy_behavior$0 + ? [0, 1, n] + : incompatible_flag(pct_ind, str_ind, 48, cst_precision$0); + } + function check_no_0(symb, pad){ + if(typeof pad === "number") return pad; + if(0 !== pad[0]) + return 2 <= pad[1] + ? legacy_behavior$0 + ? _I_ + : incompatible_flag(pct_ind, str_ind, symb, cst_0$1) + : pad; + if(2 > pad[1]) return pad; + var width = pad[2]; + return legacy_behavior$0 + ? [0, 1, width] + : incompatible_flag(pct_ind, str_ind, symb, cst_0$0); + } + function opt_of_pad(c, pad){ + if(typeof pad === "number") return 0; + if(0 === pad[0]) + switch(pad[1]){ + case 0: + var width = pad[2]; + return legacy_behavior$0 + ? [0, width] + : incompatible_flag(pct_ind, str_ind, c, cst$24); + case 1: + var width$0 = pad[2]; return [0, width$0]; + default: + var width$1 = pad[2]; + return legacy_behavior$0 + ? [0, width$1] + : incompatible_flag(pct_ind, str_ind, c, cst_0$2); + } + return incompatible_flag(pct_ind, str_ind, c, cst$25); + } + function get_pad_opt(c){return opt_of_pad(c, get_pad(0));} + function get_padprec_opt(c){return opt_of_pad(c, get_padprec(0));} + a: + { + if(124 > symb) + switch(symb){ + case 33: + var + fmt_rest$5 = parse(str_ind, end_ind)[1], + fmt_result = [0, [10, fmt_rest$5]]; + break a; + case 40: + var + sub_end = search_subformat_end(str_ind, end_ind, 41), + fmt_rest$7 = parse(sub_end + 2 | 0, end_ind)[1], + sub_fmt = parse(str_ind, sub_end)[1], + sub_fmtty = fmtty_of_fmt(sub_fmt); + if(get_ign(0)) + var + ignored$2 = [9, get_pad_opt(95), sub_fmtty], + _aJ_ = [0, [23, ignored$2, fmt_rest$7]]; + else + var _aJ_ = [0, [14, get_pad_opt(40), sub_fmtty, fmt_rest$7]]; + var fmt_result = _aJ_; + break a; + case 44: + var fmt_result = parse(str_ind, end_ind); break a; + case 67: + var + fmt_rest$10 = parse(str_ind, end_ind)[1], + _aL_ = + get_ign(0) ? [0, [23, 1, fmt_rest$10]] : [0, [1, fmt_rest$10]], + fmt_result = _aL_; + break a; + case 78: + var fmt_rest$14 = parse(str_ind, end_ind)[1], counter$0 = 2; + if(get_ign(0)) + var + ignored$6 = [11, counter$0], + _aR_ = [0, [23, ignored$6, fmt_rest$14]]; + else + var _aR_ = [0, [21, counter$0, fmt_rest$14]]; + var fmt_result = _aR_; + break a; + case 83: + var + pad$6 = check_no_0(symb, get_padprec(0)), + fmt_rest$15 = parse(str_ind, end_ind)[1]; + if(get_ign(0)) + var + ignored$7 = [1, get_padprec_opt(95)], + _aS_ = [0, [23, ignored$7, fmt_rest$15]]; + else + var + match$5 = make_padding_fmt_ebb(pad$6, fmt_rest$15), + fmt_rest$16 = match$5[2], + pad$7 = match$5[1], + _aS_ = [0, [3, pad$7, fmt_rest$16]]; + var fmt_result = _aS_; + break a; + case 91: + if(str_ind === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + var + char_set = create_char_set(0), + add_range = + function(c$0, c){ + if(c >= c$0){ + var i = c$0; + for(;;){ + add_in_char_set(char_set, caml_call1(Stdlib[29], i)); + var _a$_ = i + 1 | 0; + if(c === i) break; + i = _a$_; + } + } + return; + }, + fail_single_percent = + function(str_ind){ + return caml_call2(failwith_message(_R_), str, str_ind); + }, + parse_char_set_content = + function(counter, str_ind, end_ind){ + var str_ind$0 = str_ind; + for(;;){ + if(str_ind$0 === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + var c = caml_string_get(str, str_ind$0); + if(45 !== c){ + if(93 === c) return str_ind$0 + 1 | 0; + var _a__ = str_ind$0 + 1 | 0; + if(counter >= 50) + return caml_trampoline_return + (parse_char_set_after_char$0, [0, _a__, end_ind, c]); + var counter$0 = counter + 1 | 0; + return parse_char_set_after_char$0 + (counter$0, _a__, end_ind, c); + } + add_in_char_set(char_set, 45); + var str_ind$1 = str_ind$0 + 1 | 0; + str_ind$0 = str_ind$1; + } + }, + parse_char_set_after_char$0 = + function(counter, str_ind, end_ind, c){ + var str_ind$0 = str_ind, c$0 = c; + for(;;){ + if(str_ind$0 === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + var c$1 = caml_string_get(str, str_ind$0); + a: + { + if(46 <= c$1){ + if(64 !== c$1){ + if(93 !== c$1) break a; + add_in_char_set(char_set, c$0); + return str_ind$0 + 1 | 0; + } + } + else if(37 !== c$1){ + if(45 > c$1) break a; + var str_ind$2 = str_ind$0 + 1 | 0; + if(str_ind$2 === end_ind) + invalid_format_message + (end_ind, cst_unexpected_end_of_format); + var c$2 = caml_string_get(str, str_ind$2); + if(37 === c$2){ + if((str_ind$2 + 1 | 0) === end_ind) + invalid_format_message + (end_ind, cst_unexpected_end_of_format); + var c$3 = caml_string_get(str, str_ind$2 + 1 | 0); + if(37 !== c$3 && 64 !== c$3) + return fail_single_percent(str_ind$2); + add_range(c$0, c$3); + var _a8_ = str_ind$2 + 2 | 0; + if(counter >= 50) + return caml_trampoline_return + (parse_char_set_content, [0, _a8_, end_ind]); + var counter$1 = counter + 1 | 0; + return parse_char_set_content(counter$1, _a8_, end_ind); + } + if(93 === c$2){ + add_in_char_set(char_set, c$0); + add_in_char_set(char_set, 45); + return str_ind$2 + 1 | 0; + } + add_range(c$0, c$2); + var _a9_ = str_ind$2 + 1 | 0; + if(counter >= 50) + return caml_trampoline_return + (parse_char_set_content, [0, _a9_, end_ind]); + var counter$0 = counter + 1 | 0; + return parse_char_set_content(counter$0, _a9_, end_ind); + } + if(37 === c$0){ + add_in_char_set(char_set, c$1); + var _a7_ = str_ind$0 + 1 | 0; + if(counter >= 50) + return caml_trampoline_return + (parse_char_set_content, [0, _a7_, end_ind]); + var counter$2 = counter + 1 | 0; + return parse_char_set_content(counter$2, _a7_, end_ind); + } + } + if(37 === c$0) fail_single_percent(str_ind$0); + add_in_char_set(char_set, c$0); + var str_ind$1 = str_ind$0 + 1 | 0; + str_ind$0 = str_ind$1; + c$0 = c$1; + } + }, + parse_char_set_after_char = + function(str_ind, end_ind, c){ + return caml_trampoline + (parse_char_set_after_char$0(0, str_ind, end_ind, c)); + }; + if(str_ind === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + if(94 === caml_string_get(str, str_ind)) + var + str_ind$0 = str_ind + 1 | 0, + reverse = 1, + str_ind$1 = str_ind$0; + else + var reverse = 0, str_ind$1 = str_ind; + if(str_ind$1 === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + var + c = caml_string_get(str, str_ind$1), + next_ind = parse_char_set_after_char(str_ind$1 + 1 | 0, end_ind, c), + char_set$0 = freeze_char_set(char_set), + char_set$1 = reverse ? rev_char_set(char_set$0) : char_set$0, + fmt_rest$19 = parse(next_ind, end_ind)[1]; + if(get_ign(0)) + var + ignored$9 = [10, get_pad_opt(95), char_set$1], + _aX_ = [0, [23, ignored$9, fmt_rest$19]]; + else + var _aX_ = [0, [20, get_pad_opt(91), char_set$1, fmt_rest$19]]; + var fmt_result = _aX_; + break a; + case 97: + var + fmt_rest$20 = parse(str_ind, end_ind)[1], + fmt_result = [0, [15, fmt_rest$20]]; + break a; + case 99: + var + char_format = + function(fmt_rest){ + return get_ign(0) ? [0, [23, 0, fmt_rest]] : [0, [0, fmt_rest]]; + }, + fmt_rest$21 = parse(str_ind, end_ind)[1], + match$7 = get_pad_opt(99); + if(match$7){ + if(0 === match$7[1]) + var + _aY_ = + get_ign(0) ? [0, [23, 3, fmt_rest$21]] : [0, [22, fmt_rest$21]], + _aZ_ = _aY_; + else + var + _aZ_ = + legacy_behavior$0 + ? char_format(fmt_rest$21) + : invalid_format_message + (str_ind, cst_non_zero_widths_are_unsupp); + var _a0_ = _aZ_; + } + else + var _a0_ = char_format(fmt_rest$21); + var fmt_result = _a0_; + break a; + case 114: + var + fmt_rest$22 = parse(str_ind, end_ind)[1], + _a1_ = + get_ign(0) ? [0, [23, 2, fmt_rest$22]] : [0, [19, fmt_rest$22]], + fmt_result = _a1_; + break a; + case 115: + var + pad$9 = check_no_0(symb, get_padprec(0)), + fmt_rest$23 = parse(str_ind, end_ind)[1]; + if(get_ign(0)) + var + ignored$10 = [0, get_padprec_opt(95)], + _a2_ = [0, [23, ignored$10, fmt_rest$23]]; + else + var + match$8 = make_padding_fmt_ebb(pad$9, fmt_rest$23), + fmt_rest$24 = match$8[2], + pad$10 = match$8[1], + _a2_ = [0, [2, pad$10, fmt_rest$24]]; + var fmt_result = _a2_; + break a; + case 116: + var + fmt_rest$25 = parse(str_ind, end_ind)[1], + fmt_result = [0, [16, fmt_rest$25]]; + break a; + case 123: + var + sub_end$0 = search_subformat_end(str_ind, end_ind, 125), + sub_fmt$0 = parse(str_ind, sub_end$0)[1], + fmt_rest$26 = parse(sub_end$0 + 2 | 0, end_ind)[1], + sub_fmtty$0 = fmtty_of_fmt(sub_fmt$0); + if(get_ign(0)) + var + ignored$11 = [8, get_pad_opt(95), sub_fmtty$0], + _a3_ = [0, [23, ignored$11, fmt_rest$26]]; + else + var _a3_ = [0, [13, get_pad_opt(123), sub_fmtty$0, fmt_rest$26]]; + var fmt_result = _a3_; + break a; + case 66: + case 98: + var + pad$3 = check_no_0(symb, get_padprec(0)), + fmt_rest$8 = parse(str_ind, end_ind)[1]; + if(get_ign(0)) + var + ignored$3 = [7, get_padprec_opt(95)], + _aK_ = [0, [23, ignored$3, fmt_rest$8]]; + else + var + match$3 = make_padding_fmt_ebb(pad$3, fmt_rest$8), + fmt_rest$9 = match$3[2], + pad$4 = match$3[1], + _aK_ = [0, [9, pad$4, fmt_rest$9]]; + var fmt_result = _aK_; + break a; + case 37: + case 64: + var + fmt_rest$6 = parse(str_ind, end_ind)[1], + fmt_result = [0, [12, symb, fmt_rest$6]]; + break a; + case 76: + case 108: + case 110: + if(str_ind !== end_ind){ + var symb$0 = caml_string_get(str, str_ind), _a4_ = symb$0 - 88 | 0; + b: + { + if(32 >= _a4_ >>> 0) + switch(_a4_){ + case 0: + case 12: + case 17: + case 23: + case 29: + case 32: + var _aQ_ = 1; break b; + } + var _aQ_ = 0; + } + if(_aQ_) break; + } + var fmt_rest$13 = parse(str_ind, end_ind)[1]; + b: + { + if(108 <= symb){ + if(111 > symb) + switch(symb - 108 | 0){ + case 0: + var counter = 0; break b; + case 1: break; + default: var counter = 1; break b; + } + } + else if(76 === symb){var counter = 2; break b;} + throw caml_maybe_attach_backtrace([0, Assert_failure, _V_], 1); + } + if(get_ign(0)) + var + ignored$5 = [11, counter], + _aP_ = [0, [23, ignored$5, fmt_rest$13]]; + else + var _aP_ = [0, [21, counter, fmt_rest$13]]; + var fmt_result = _aP_; + break a; + case 32: + case 35: + case 43: + case 45: + case 95: + var + fmt_result = caml_call3(failwith_message(_M_), str, pct_ind, symb); + break a; + case 88: + case 100: + case 105: + case 111: + case 117: + case 120: + var + _aT_ = get_space(0), + _aU_ = get_hash(0), + iconv$2 = + compute_int_conv(pct_ind, str_ind, get_plus(0), _aU_, _aT_, symb), + fmt_rest$17 = parse(str_ind, end_ind)[1]; + if(get_ign(0)) + var + ignored$8 = [2, iconv$2, get_pad_opt(95)], + _aV_ = [0, [23, ignored$8, fmt_rest$17]]; + else + var + _aW_ = get_prec(0), + match$6 = make_padprec_fmt_ebb(get_int_pad(0), _aW_, fmt_rest$17), + fmt_rest$18 = match$6[3], + prec$4 = match$6[2], + pad$8 = match$6[1], + _aV_ = [0, [4, iconv$2, pad$8, prec$4, fmt_rest$18]]; + var fmt_result = _aV_; + break a; + case 69: + case 70: + case 71: + case 72: + case 101: + case 102: + case 103: + case 104: + var + space$1 = get_space(0), + hash$1 = get_hash(0), + plus$2 = get_plus(0), + flag = + plus$2 + ? space$1 + ? legacy_behavior$0 + ? 1 + : incompatible_flag(pct_ind, str_ind, 32, cst$36) + : 1 + : space$1 ? 2 : 0; + b: + { + c: + if(73 <= symb){ + var switcher = symb - 101 | 0; + if(3 >= switcher >>> 0){ + switch(switcher){ + case 0: + var _a5_ = 1; break; + case 1: + var _a5_ = 0; break; + case 2: + var _a5_ = 3; break; + default: var _a5_ = 6; + } + var kind = _a5_; + break b; + } + } + else if(69 <= symb){ + switch(symb - 69 | 0){ + case 0: + var _a6_ = 2; break; + case 1: + break c; + case 2: + var _a6_ = 4; break; + default: var _a6_ = 7; + } + var kind = _a6_; + break b; + } + if(hash$1){ + if(70 === symb){var kind = 8; break b;} + } + else if(70 === symb){var kind = 5; break b;} + throw caml_maybe_attach_backtrace([0, Assert_failure, _X_], 1); + } + var + fconv = [0, flag, kind], + fmt_rest$11 = parse(str_ind, end_ind)[1]; + if(get_ign(0)){ + var match = get_prec(0); + if(typeof match === "number") + var + _aM_ = + match ? incompatible_flag(pct_ind, str_ind, 95, cst$26) : 0; + else + var ndec = match[1], _aM_ = [0, ndec]; + var + ignored$4 = [6, get_pad_opt(95), _aM_], + _aN_ = [0, [23, ignored$4, fmt_rest$11]]; + } + else + var + _aO_ = get_prec(0), + match$4 = make_padprec_fmt_ebb(get_pad(0), _aO_, fmt_rest$11), + fmt_rest$12 = match$4[3], + prec$3 = match$4[2], + pad$5 = match$4[1], + _aN_ = [0, [8, fconv, pad$5, prec$3, fmt_rest$12]]; + var fmt_result = _aN_; + break a; + } + b: + if(108 <= symb){ + if(111 > symb){ + switch(symb - 108 | 0){ + case 0: + var + _at_ = caml_string_get(str, str_ind), + _au_ = get_space(0), + _av_ = get_hash(0), + iconv = + compute_int_conv + (pct_ind, str_ind + 1 | 0, get_plus(0), _av_, _au_, _at_), + fmt_rest = parse(str_ind + 1 | 0, end_ind)[1]; + if(get_ign(0)) + var + ignored = [3, iconv, get_pad_opt(95)], + _aw_ = [0, [23, ignored, fmt_rest]]; + else + var + _ay_ = get_prec(0), + match$0 = make_padprec_fmt_ebb(get_int_pad(0), _ay_, fmt_rest), + fmt_rest$0 = match$0[3], + prec$0 = match$0[2], + pad$0 = match$0[1], + _aw_ = [0, [5, iconv, pad$0, prec$0, fmt_rest$0]]; + var _ax_ = _aw_; + break; + case 1: + break b; + default: + var + _az_ = caml_string_get(str, str_ind), + _aA_ = get_space(0), + _aB_ = get_hash(0), + iconv$0 = + compute_int_conv + (pct_ind, str_ind + 1 | 0, get_plus(0), _aB_, _aA_, _az_), + fmt_rest$1 = parse(str_ind + 1 | 0, end_ind)[1]; + if(get_ign(0)) + var + ignored$0 = [4, iconv$0, get_pad_opt(95)], + _aC_ = [0, [23, ignored$0, fmt_rest$1]]; + else + var + _aD_ = get_prec(0), + match$1 = make_padprec_fmt_ebb(get_int_pad(0), _aD_, fmt_rest$1), + fmt_rest$2 = match$1[3], + prec$1 = match$1[2], + pad$1 = match$1[1], + _aC_ = [0, [6, iconv$0, pad$1, prec$1, fmt_rest$2]]; + var _ax_ = _aC_; + } + var fmt_result = _ax_; + break a; + } + } + else if(76 === symb){ + var + _aE_ = caml_string_get(str, str_ind), + _aF_ = get_space(0), + _aG_ = get_hash(0), + iconv$1 = + compute_int_conv + (pct_ind, str_ind + 1 | 0, get_plus(0), _aG_, _aF_, _aE_), + fmt_rest$3 = parse(str_ind + 1 | 0, end_ind)[1]; + if(get_ign(0)) + var + ignored$1 = [5, iconv$1, get_pad_opt(95)], + _aH_ = [0, [23, ignored$1, fmt_rest$3]]; + else + var + _aI_ = get_prec(0), + match$2 = make_padprec_fmt_ebb(get_int_pad(0), _aI_, fmt_rest$3), + fmt_rest$4 = match$2[3], + prec$2 = match$2[2], + pad$2 = match$2[1], + _aH_ = [0, [7, iconv$1, pad$2, prec$2, fmt_rest$4]]; + var fmt_result = _aH_; + break a; + } + var + fmt_result = + caml_call3(failwith_message(_J_), str, str_ind - 1 | 0, symb); + } + if(1 - legacy_behavior$0){ + var _ak_ = 1 - plus_used[1], plus$0 = _ak_ ? plus : _ak_; + if(plus$0) incompatible_flag(pct_ind, str_ind, symb, cst$27); + var _al_ = 1 - hash_used[1], hash$0 = _al_ ? hash : _al_; + if(hash$0) incompatible_flag(pct_ind, str_ind, symb, cst$28); + var _am_ = 1 - space_used[1], space$0 = _am_ ? space : _am_; + if(space$0) incompatible_flag(pct_ind, str_ind, symb, cst$29); + var + _an_ = 1 - pad_used[1], + _ao_ = _an_ ? caml_notequal([0, pad], _K_) : _an_; + if(_ao_) incompatible_flag(pct_ind, str_ind, symb, cst_padding$0); + var + _ap_ = 1 - prec_used[1], + _aq_ = _ap_ ? caml_notequal([0, prec], _L_) : _ap_; + if(_aq_){ + var _ar_ = ign ? 95 : symb; + incompatible_flag(pct_ind, str_ind, _ar_, cst_precision$2); + } + var plus$1 = ign ? plus : ign; + if(plus$1) incompatible_flag(pct_ind, str_ind, 95, cst$30); + } + var _as_ = 1 - ign_used[1], ign$0 = _as_ ? ign : _as_; + a: + if(ign$0){ + b: + { + if(38 <= symb){ + if(44 !== symb && 64 !== symb) break b; + } + else if(33 !== symb && 37 > symb) break b; + if(legacy_behavior$0) break a; + } + incompatible_flag(pct_ind, str_ind, symb, cst$31); + } + return fmt_result; + } + function parse_tag(is_open_tag, str_ind, end_ind){ + try{ + if(str_ind === end_ind) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + if(60 !== caml_string_get(str, str_ind)) + throw caml_maybe_attach_backtrace(Stdlib[8], 1); + var ind = caml_call3(Stdlib_String[31], str, str_ind + 1 | 0, 62); + if(end_ind <= ind) throw caml_maybe_attach_backtrace(Stdlib[8], 1); + var + sub_str = + caml_call3 + (Stdlib_String[15], str, str_ind, (ind - str_ind | 0) + 1 | 0), + fmt_rest$0 = parse(ind + 1 | 0, end_ind)[1], + sub_fmt = parse(str_ind, ind + 1 | 0)[1], + sub_format$0 = [0, sub_fmt, sub_str], + formatting$0 = is_open_tag ? [0, sub_format$0] : [1, sub_format$0], + _ai_ = [0, [18, formatting$0, fmt_rest$0]]; + return _ai_; + } + catch(_aj_){ + var _ah_ = caml_wrap_exception(_aj_); + if(_ah_ !== Stdlib[8]) throw caml_maybe_attach_backtrace(_ah_, 0); + var + fmt_rest = parse(str_ind, end_ind)[1], + formatting = is_open_tag ? [0, sub_format] : [1, sub_format]; + return [0, [18, formatting, fmt_rest]]; + } + } + function parse_spaces(str_ind, end_ind){ + var str_ind$0 = str_ind; + for(;;){ + if(str_ind$0 === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + if(32 !== caml_string_get(str, str_ind$0)) return str_ind$0; + var str_ind$1 = str_ind$0 + 1 | 0; + str_ind$0 = str_ind$1; + } + } + function parse_positive(str_ind, end_ind, acc){ + var str_ind$0 = str_ind, acc$0 = acc; + for(;;){ + if(str_ind$0 === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + var c = caml_string_get(str, str_ind$0); + if(9 < c - 48 >>> 0) return [0, str_ind$0, acc$0]; + var new_acc = (acc$0 * 10 | 0) + (c - 48 | 0) | 0; + if(Stdlib_Sys[12] < new_acc){ + var _ag_ = Stdlib_Sys[12]; + return caml_call3(failwith_message(_S_), str, new_acc, _ag_); + } + var str_ind$1 = str_ind$0 + 1 | 0; + str_ind$0 = str_ind$1; + acc$0 = new_acc; + } + } + function parse_integer(str_ind, end_ind){ + if(str_ind === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + var match = caml_string_get(str, str_ind); + if(48 <= match){ + if(58 > match) return parse_positive(str_ind, end_ind, 0); + } + else if(45 === match){ + if((str_ind + 1 | 0) === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + var c = caml_string_get(str, str_ind + 1 | 0); + if(9 < c - 48 >>> 0) + return expected_character(str_ind + 1 | 0, cst_digit, c); + var + match$0 = parse_positive(str_ind + 1 | 0, end_ind, 0), + n = match$0[2], + next_ind = match$0[1]; + return [0, next_ind, - n | 0]; + } + throw caml_maybe_attach_backtrace([0, Assert_failure, _T_], 1); + } + function add_literal(lit_start, str_ind, fmt){ + var size = str_ind - lit_start | 0; + return 0 === size + ? [0, fmt] + : 1 + === size + ? [0, [12, caml_string_get(str, lit_start), fmt]] + : [0, + [11, + caml_call3(Stdlib_String[15], str, lit_start, size), + fmt]]; + } + function search_subformat_end(str_ind, end_ind, c){ + var str_ind$0 = str_ind; + for(;;){ + if(str_ind$0 === end_ind) + caml_call3(failwith_message(_U_), str, c, end_ind); + if(37 === caml_string_get(str, str_ind$0)){ + if((str_ind$0 + 1 | 0) === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + if(caml_string_get(str, str_ind$0 + 1 | 0) === c) return str_ind$0; + var match = caml_string_get(str, str_ind$0 + 1 | 0); + if(95 <= match){ + if(123 <= match){ + if(126 > match) + switch(match - 123 | 0){ + case 0: + var + sub_end = search_subformat_end(str_ind$0 + 2 | 0, end_ind, 125), + str_ind$2 = sub_end + 2 | 0; + str_ind$0 = str_ind$2; + continue; + case 1: break; + default: + return expected_character(str_ind$0 + 1 | 0, cst_character, 125); + } + } + else if(96 > match){ + if((str_ind$0 + 2 | 0) === end_ind) + invalid_format_message(end_ind, cst_unexpected_end_of_format); + var match$0 = caml_string_get(str, str_ind$0 + 2 | 0); + if(40 === match$0){ + var + sub_end$0 = search_subformat_end(str_ind$0 + 3 | 0, end_ind, 41), + str_ind$3 = sub_end$0 + 2 | 0; + str_ind$0 = str_ind$3; + continue; + } + if(123 === match$0){ + var + sub_end$1 = search_subformat_end(str_ind$0 + 3 | 0, end_ind, 125), + str_ind$4 = sub_end$1 + 2 | 0; + str_ind$0 = str_ind$4; + continue; + } + var str_ind$5 = str_ind$0 + 3 | 0; + str_ind$0 = str_ind$5; + continue; + } + } + else{ + if(40 === match){ + var + sub_end$2 = search_subformat_end(str_ind$0 + 2 | 0, end_ind, 41), + str_ind$6 = sub_end$2 + 2 | 0; + str_ind$0 = str_ind$6; + continue; + } + if(41 === match) + return expected_character(str_ind$0 + 1 | 0, cst_character$0, 41); + } + var str_ind$1 = str_ind$0 + 2 | 0; + str_ind$0 = str_ind$1; + } + else{var str_ind$7 = str_ind$0 + 1 | 0; str_ind$0 = str_ind$7;} + } + } + function compute_int_conv(pct_ind, str_ind, plus, hash, space, symb){ + var plus$0 = plus, hash$0 = hash, space$0 = space; + for(;;){ + a: + { + if(plus$0){ + if(! hash$0){ + if(space$0) break a; + if(100 === symb) return 1; + if(105 === symb) return 4; + break a; + } + } + else{ + if(! hash$0){ + if(space$0){ + if(100 === symb) return 2; + if(105 === symb) return 5; + break a; + } + var switcher$1 = symb - 88 | 0; + if(32 < switcher$1 >>> 0) break a; + switch(switcher$1){ + case 0: + return 8; + case 12: + return 0; + case 17: + return 3; + case 23: + return 10; + case 29: + return 12; + case 32: + return 6; + default: break a; + } + } + if(! space$0){ + var switcher$0 = symb - 88 | 0; + if(32 >= switcher$0 >>> 0) + switch(switcher$0){ + case 0: + return 9; + case 12: + return 13; + case 17: + return 14; + case 23: + return 11; + case 29: + return 15; + case 32: + return 7; + } + } + } + var switcher = symb - 88 | 0; + if(32 >= switcher >>> 0) + switch(switcher){ + case 0: + if(legacy_behavior$0) return 9; break; + case 23: + if(legacy_behavior$0) return 11; break; + case 32: + if(legacy_behavior$0) return 7; break; + case 12: + case 17: + case 29: + if(! legacy_behavior$0) + return incompatible_flag(pct_ind, str_ind, symb, cst$35); + hash$0 = 0; + continue; + } + } + if(plus$0) + if(space$0){ + if(! legacy_behavior$0) + return incompatible_flag(pct_ind, str_ind, 32, cst$32); + space$0 = 0; + } + else{ + if(! legacy_behavior$0) + return incompatible_flag(pct_ind, str_ind, symb, cst$33); + plus$0 = 0; + } + else{ + if(! space$0) + throw caml_maybe_attach_backtrace([0, Assert_failure, _W_], 1); + if(! legacy_behavior$0) + return incompatible_flag(pct_ind, str_ind, symb, cst$34); + space$0 = 0; + } + } + } + function incompatible_flag(pct_ind, str_ind, symb, option){ + var + subfmt = + caml_call3(Stdlib_String[15], str, pct_ind, str_ind - pct_ind | 0); + return caml_call5 + (failwith_message(_Y_), str, pct_ind, option, symb, subfmt); + } + return parse(0, caml_ml_string_length(str)); + } + function format_of_string_fmtty(str, fmtty){ + var fmt = fmt_ebb_of_string(0, str)[1]; + try{var _ae_ = [0, type_format(fmt, fmtty), str]; return _ae_;} + catch(_af_){ + var _ac_ = caml_wrap_exception(_af_); + if(_ac_ !== Type_mismatch) throw caml_maybe_attach_backtrace(_ac_, 0); + var _ad_ = string_of_fmtty(fmtty); + return caml_call2(failwith_message(_Z_), str, _ad_); + } + } + function format_of_string_format(str, param){ + var + str$0 = param[2], + fmt = param[1], + fmt$0 = fmt_ebb_of_string(0, str)[1]; + try{ + var _aa_ = [0, type_format(fmt$0, fmtty_of_fmt(fmt)), str]; + return _aa_; + } + catch(_ab_){ + var _$_ = caml_wrap_exception(_ab_); + if(_$_ === Type_mismatch) + return caml_call2(failwith_message(___), str, str$0); + throw caml_maybe_attach_backtrace(_$_, 0); + } + } + var + CamlinternalFormat = + [0, + is_in_char_set, + rev_char_set, + create_char_set, + add_in_char_set, + freeze_char_set, + param_format_of_ignored_format, + make_printf, + make_iprintf, + output_acc, + bufput_acc, + strput_acc, + type_format, + fmt_ebb_of_string, + format_of_string_fmtty, + format_of_string_format, + char_of_iconv, + string_of_formatting_lit, + string_of_fmtty, + string_of_fmt, + open_box_of_string, + symm, + trans, + recast]; + runtime.caml_register_global(197, CamlinternalFormat, "CamlinternalFormat"); + return; + } + (globalThis)); + +//# 14846 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + Stdlib_Buffer = global_data.Stdlib__Buffer, + CamlinternalFormat = global_data.CamlinternalFormat, + Stdlib = global_data.Stdlib; + function kfprintf(k, o, param){ + var fmt = param[1]; + return caml_call3 + (CamlinternalFormat[7], + function(acc){ + caml_call2(CamlinternalFormat[9], o, acc); + return caml_call1(k, o); + }, + 0, + fmt); + } + function kbprintf(k, b, param){ + var fmt = param[1]; + return caml_call3 + (CamlinternalFormat[7], + function(acc){ + caml_call2(CamlinternalFormat[10], b, acc); + return caml_call1(k, b); + }, + 0, + fmt); + } + function ikfprintf(k, oc, param){ + var fmt = param[1]; + return caml_call3(CamlinternalFormat[8], k, oc, fmt); + } + function fprintf(oc, fmt){ + return kfprintf(function(_d_){return 0;}, oc, fmt); + } + function bprintf(b, fmt){ + return kbprintf(function(_c_){return 0;}, b, fmt); + } + function ifprintf(oc, fmt){ + return ikfprintf(function(_b_){return 0;}, oc, fmt); + } + function ibprintf(b, fmt){ + return ikfprintf(function(_a_){return 0;}, b, fmt); + } + function printf(fmt){return fprintf(Stdlib[39], fmt);} + function eprintf(fmt){return fprintf(Stdlib[40], fmt);} + function ksprintf(k, param){ + var fmt = param[1]; + function k$0(acc){ + var buf = caml_call1(Stdlib_Buffer[1], 64); + caml_call2(CamlinternalFormat[11], buf, acc); + return caml_call1(k, caml_call1(Stdlib_Buffer[2], buf)); + } + return caml_call3(CamlinternalFormat[7], k$0, 0, fmt); + } + function sprintf(fmt){return ksprintf(function(s){return s;}, fmt);} + var + Stdlib_Printf = + [0, + fprintf, + printf, + eprintf, + sprintf, + bprintf, + ifprintf, + ibprintf, + kfprintf, + ikfprintf, + ksprintf, + kbprintf, + ikfprintf, + ksprintf]; + runtime.caml_register_global(3, Stdlib_Printf, "Stdlib__Printf"); + return; + } + (globalThis)); + +//# 15656 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + global_data = runtime.caml_get_global_data(), + CamlinternalAtomic = global_data.CamlinternalAtomic, + make = CamlinternalAtomic[1], + get = CamlinternalAtomic[2], + set = CamlinternalAtomic[3], + exchange = CamlinternalAtomic[4], + compare_and_set = CamlinternalAtomic[5], + fetch_and_add = CamlinternalAtomic[6], + incr = CamlinternalAtomic[7], + decr = CamlinternalAtomic[8], + Stdlib_Atomic = + [0, + make, + get, + set, + exchange, + compare_and_set, + fetch_and_add, + incr, + decr]; + runtime.caml_register_global(1, Stdlib_Atomic, "Stdlib__Atomic"); + return; + } + (globalThis)); + +//# 15688 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst$4 = "", + cst_s = "%s\n", + cst_Program_not_linked_with_g_$0 = + "(Program not linked with -g, cannot print stack backtrace)\n", + cst_characters = ", characters ", + cst_Fatal_error_exception = "Fatal error: exception ", + cst_Fatal_error_exception_s = "Fatal error: exception %s\n", + cst_Uncaught_exception = "Uncaught exception: ", + cst_Uncaught_exception_s = "Uncaught exception: %s\n", + caml_check_bound = runtime.caml_check_bound, + caml_get_exception_raw_backtra = runtime.caml_get_exception_raw_backtrace, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace, + caml_obj_tag = runtime.caml_obj_tag, + caml_wrap_exception = runtime.caml_wrap_exception; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + function caml_call6(f, a0, a1, a2, a3, a4, a5){ + return (f.l >= 0 ? f.l : f.l = f.length) == 6 + ? f(a0, a1, a2, a3, a4, a5) + : runtime.caml_call_gen(f, [a0, a1, a2, a3, a4, a5]); + } + function caml_call8(f, a0, a1, a2, a3, a4, a5, a6, a7){ + return (f.l >= 0 ? f.l : f.l = f.length) == 8 + ? f(a0, a1, a2, a3, a4, a5, a6, a7) + : runtime.caml_call_gen(f, [a0, a1, a2, a3, a4, a5, a6, a7]); + } + var + global_data = runtime.caml_get_global_data(), + cst$0 = cst$4, + cst$3 = cst$4, + partial = [4, 0, 0, 0, [12, 45, [4, 0, 0, 0, 0]]], + cst$1 = cst$4, + cst$2 = cst$4, + cst = "_", + locfmt = + [0, + [11, + 'File "', + [2, + 0, + [11, + '", line ', + [4, + 0, + 0, + 0, + [11, + cst_characters, + [4, 0, 0, 0, [12, 45, [4, 0, 0, 0, [11, ": ", [2, 0, 0]]]]]]]]]], + 'File "%s", line %d, characters %d-%d: %s'], + Stdlib_Printf = global_data.Stdlib__Printf, + Stdlib_Atomic = global_data.Stdlib__Atomic, + Stdlib = global_data.Stdlib, + Stdlib_Buffer = global_data.Stdlib__Buffer, + Stdlib_Obj = global_data.Stdlib__Obj, + printers = caml_call1(Stdlib_Atomic[1], 0), + _a_ = [0, [3, 0, 0], "%S"], + _b_ = [0, [4, 0, 0, 0, 0], "%d"], + _c_ = [0, [11, ", ", [2, 0, [2, 0, 0]]], ", %s%s"], + _d_ = [0, [12, 40, [2, 0, [2, 0, [12, 41, 0]]]], "(%s%s)"], + _e_ = [0, [12, 40, [2, 0, [12, 41, 0]]], "(%s)"], + cst_Out_of_memory = "Out of memory", + cst_Stack_overflow = "Stack overflow", + cst_Pattern_matching_failed = "Pattern matching failed", + cst_Assertion_failed = "Assertion failed", + cst_Undefined_recursive_module = "Undefined recursive module", + _f_ = + [0, + [11, cst_Uncaught_exception, [2, 0, [12, 10, 0]]], + cst_Uncaught_exception_s], + _g_ = + [0, + [11, cst_Uncaught_exception, [2, 0, [12, 10, 0]]], + cst_Uncaught_exception_s], + cst_Raised_at = "Raised at", + cst_Re_raised_at = "Re-raised at", + cst_Raised_by_primitive_operat = "Raised by primitive operation at", + cst_Called_from = "Called from", + cst_inlined = " (inlined)", + _h_ = + [0, + [2, + 0, + [12, + 32, + [2, + 0, + [11, + ' in file "', + [2, + 0, + [12, + 34, + [2, + 0, + [11, ", line ", [4, 0, 0, 0, [11, cst_characters, partial]]]]]]]]]], + '%s %s in file "%s"%s, line %d, characters %d-%d'], + _i_ = [0, [2, 0, [11, " unknown location", 0]], "%s unknown location"], + _j_ = [0, [2, 0, [12, 10, 0]], cst_s], + _k_ = + [0, + [11, cst_Program_not_linked_with_g_$0, 0], + cst_Program_not_linked_with_g_$0], + _l_ = [0, [2, 0, [12, 10, 0]], cst_s], + cst_Program_not_linked_with_g_ = cst_Program_not_linked_with_g_$0; + function field(x, i){ + var f = x[1 + i]; + if(! caml_call1(Stdlib_Obj[1], f)) + return caml_call2(Stdlib_Printf[4], _b_, f); + var _ag_ = Stdlib_Obj[13]; + if(caml_obj_tag(f) === _ag_) return caml_call2(Stdlib_Printf[4], _a_, f); + var _ah_ = Stdlib_Obj[14]; + return caml_obj_tag(f) === _ah_ ? caml_call1(Stdlib[35], f) : cst; + } + function other_fields(x, i){ + if(x.length - 1 <= i) return cst$0; + var _ae_ = other_fields(x, i + 1 | 0), _af_ = field(x, i); + return caml_call3(Stdlib_Printf[4], _c_, _af_, _ae_); + } + function use_printers(x){ + var param = caml_call1(Stdlib_Atomic[2], printers); + for(;;){ + if(! param) return 0; + var tl = param[2], hd = param[1]; + a: + { + try{var val = caml_call1(hd, x);}catch(_ad_){break a;} + if(val){var s = val[1]; return [0, s];} + } + param = tl; + } + } + function to_string_default(x){ + if(x === Stdlib[9]) return cst_Out_of_memory; + if(x === Stdlib[10]) return cst_Stack_overflow; + if(x[1] === Stdlib[4]){ + var + match$0 = x[2], + char$0 = match$0[3], + line = match$0[2], + file = match$0[1]; + return caml_call6 + (Stdlib_Printf[4], + locfmt, + file, + line, + char$0, + char$0 + 5 | 0, + cst_Pattern_matching_failed); + } + if(x[1] === Stdlib[5]){ + var + match$1 = x[2], + char$1 = match$1[3], + line$0 = match$1[2], + file$0 = match$1[1]; + return caml_call6 + (Stdlib_Printf[4], + locfmt, + file$0, + line$0, + char$1, + char$1 + 6 | 0, + cst_Assertion_failed); + } + if(x[1] === Stdlib[15]){ + var + match$2 = x[2], + char$2 = match$2[3], + line$1 = match$2[2], + file$1 = match$2[1]; + return caml_call6 + (Stdlib_Printf[4], + locfmt, + file$1, + line$1, + char$2, + char$2 + 6 | 0, + cst_Undefined_recursive_module); + } + if(0 !== caml_obj_tag(x)) return x[1]; + var constructor = x[1][1], match = x.length - 1; + if(2 < match >>> 0) + var + _$_ = other_fields(x, 2), + _aa_ = field(x, 1), + _ac_ = caml_call3(Stdlib_Printf[4], _d_, _aa_, _$_); + else + switch(match){ + case 0: + var _ac_ = cst$1; break; + case 1: + var _ac_ = cst$2; break; + default: + var + _ab_ = field(x, 1), + _ac_ = caml_call2(Stdlib_Printf[4], _e_, _ab_); + } + return caml_call2(Stdlib[28], constructor, _ac_); + } + function to_string(e){ + var match = use_printers(e); + if(! match) return to_string_default(e); + var s = match[1]; + return s; + } + function print(fct, arg){ + try{var ___ = caml_call1(fct, arg); return ___;} + catch(x$0){ + var x = caml_wrap_exception(x$0), _Z_ = to_string(x); + caml_call2(Stdlib_Printf[3], _f_, _Z_); + caml_call1(Stdlib[63], Stdlib[40]); + throw caml_maybe_attach_backtrace(x, 0); + } + } + function catch$0(fct, arg){ + try{var _Y_ = caml_call1(fct, arg); return _Y_;} + catch(x$0){ + var x = caml_wrap_exception(x$0); + caml_call1(Stdlib[63], Stdlib[39]); + var _X_ = to_string(x); + caml_call2(Stdlib_Printf[3], _g_, _X_); + return caml_call1(Stdlib[99], 2); + } + } + function raw_backtrace_entries(bt){return bt;} + function convert_raw_backtrace(bt){ + return [0, runtime.caml_convert_raw_backtrace(bt)]; + } + function format_backtrace_slot(pos, slot){ + function info(is_raise){ + return is_raise + ? 0 === pos ? cst_Raised_at : cst_Re_raised_at + : 0 === pos ? cst_Raised_by_primitive_operat : cst_Called_from; + } + if(0 === slot[0]){ + var + _P_ = slot[5], + _Q_ = slot[4], + _R_ = slot[3], + _S_ = slot[6] ? cst_inlined : cst$3, + _T_ = slot[2], + _U_ = slot[7], + _V_ = info(slot[1]); + return [0, + caml_call8 + (Stdlib_Printf[4], _h_, _V_, _U_, _T_, _S_, _R_, _Q_, _P_)]; + } + if(slot[1]) return 0; + var _W_ = info(0); + return [0, caml_call2(Stdlib_Printf[4], _i_, _W_)]; + } + function print_raw_backtrace(outchan, raw_backtrace){ + var backtrace = convert_raw_backtrace(raw_backtrace); + if(! backtrace) return caml_call2(Stdlib_Printf[1], outchan, _k_); + var a = backtrace[1], _N_ = a.length - 2 | 0, _M_ = 0; + if(_N_ >= 0){ + var i = _M_; + for(;;){ + var match = format_backtrace_slot(i, caml_check_bound(a, i)[1 + i]); + if(match){ + var str = match[1]; + caml_call3(Stdlib_Printf[1], outchan, _j_, str); + } + var _O_ = i + 1 | 0; + if(_N_ === i) break; + i = _O_; + } + } + return 0; + } + function print_backtrace(outchan){ + return print_raw_backtrace(outchan, caml_get_exception_raw_backtra(0)); + } + function raw_backtrace_to_string(raw_backtrace){ + var backtrace = convert_raw_backtrace(raw_backtrace); + if(! backtrace) return cst_Program_not_linked_with_g_; + var + a = backtrace[1], + b = caml_call1(Stdlib_Buffer[1], 1024), + _K_ = a.length - 2 | 0, + _J_ = 0; + if(_K_ >= 0){ + var i = _J_; + for(;;){ + var match = format_backtrace_slot(i, caml_check_bound(a, i)[1 + i]); + if(match){ + var str = match[1]; + caml_call3(Stdlib_Printf[5], b, _l_, str); + } + var _L_ = i + 1 | 0; + if(_K_ === i) break; + i = _L_; + } + } + return caml_call1(Stdlib_Buffer[2], b); + } + function backtrace_slot_is_raise(param){ + return 0 === param[0] ? param[1] : param[1]; + } + function backtrace_slot_is_inline(param){return 0 === param[0] ? param[6] : 0; + } + function backtrace_slot_location(param){ + return 0 === param[0] + ? [0, [0, param[2], param[3], param[4], param[5]]] + : 0; + } + function backtrace_slot_defname(param){ + if(0 === param[0] && param[7] !== cst$4) return [0, param[7]]; + return 0; + } + function backtrace_slots(raw_backtrace){ + var match = convert_raw_backtrace(raw_backtrace); + if(! match) return 0; + var backtrace = match[1], i$1 = backtrace.length - 2 | 0, i = i$1; + for(;;){ + if(-1 === i) + var _I_ = 0; + else{ + var _H_ = 0 === caml_check_bound(backtrace, i)[1 + i][0] ? 1 : 0; + if(! _H_){var i$0 = i - 1 | 0; i = i$0; continue;} + var _I_ = _H_; + } + return _I_ ? [0, backtrace] : 0; + } + } + function backtrace_slots_of_raw_entry(entry){return backtrace_slots([0, entry]); + } + function raw_backtrace_length(bt){return bt.length - 1;} + function get_backtrace(param){ + return raw_backtrace_to_string(caml_get_exception_raw_backtra(0)); + } + function register_printer(fn){ + for(;;){ + var + old_printers = caml_call1(Stdlib_Atomic[2], printers), + new_printers = [0, fn, old_printers], + success = + caml_call3(Stdlib_Atomic[5], printers, old_printers, new_printers), + _G_ = 1 - success; + if(! _G_) return _G_; + } + } + function exn_slot(x){return 0 === caml_obj_tag(x) ? x[1] : x;} + function exn_slot_id(x){var slot = exn_slot(x); return slot[2];} + function exn_slot_name(x){var slot = exn_slot(x); return slot[1];} + var + errors = + [0, + cst$4, + "(Cannot print locations:\n bytecode executable program file not found)", + "(Cannot print locations:\n bytecode executable program file appears to be corrupt)", + "(Cannot print locations:\n bytecode executable program file has wrong magic number)", + "(Cannot print locations:\n bytecode executable program file cannot be opened;\n -- too many open files. Try running with OCAMLRUNPARAM=b=2)"].slice + (), + _m_ = + [0, + [11, cst_Fatal_error_exception, [2, 0, [12, 10, 0]]], + cst_Fatal_error_exception_s]; + function default_uncaught_exception_han(exn, raw_backtrace){ + var _D_ = to_string(exn); + caml_call2(Stdlib_Printf[3], _m_, _D_); + print_raw_backtrace(Stdlib[40], raw_backtrace); + var status = runtime.caml_ml_debug_info_status(0); + if(status < 0){ + var + _E_ = caml_call1(Stdlib[18], status), + _F_ = caml_check_bound(errors, _E_)[1 + _E_]; + caml_call1(Stdlib[53], _F_); + } + return caml_call1(Stdlib[63], Stdlib[40]); + } + var uncaught_exception_handler = [0, default_uncaught_exception_han]; + function set_uncaught_exception_handler(fn){ + uncaught_exception_handler[1] = fn; + return 0; + } + var + empty_backtrace = [0], + cst_Fatal_error_out_of_memory_ = + "Fatal error: out of memory in uncaught exception handler", + _n_ = + [0, + [11, cst_Fatal_error_exception, [2, 0, [12, 10, 0]]], + cst_Fatal_error_exception_s], + _o_ = + [0, + [11, + "Fatal error in uncaught exception handler: exception ", + [2, 0, [12, 10, 0]]], + "Fatal error in uncaught exception handler: exception %s\n"]; + function handle_uncaught_exception(exn$0, debugger_in_use){ + try{ + try{ + var + raw_backtrace = + debugger_in_use ? empty_backtrace : caml_get_exception_raw_backtra(0); + try{caml_call1(Stdlib[103], 0);}catch(_C_){} + try{ + var + _y_ = caml_call2(uncaught_exception_handler[1], exn$0, raw_backtrace), + _x_ = _y_; + } + catch(exn$1){ + var + exn = caml_wrap_exception(exn$1), + raw_backtrace$0 = caml_get_exception_raw_backtra(0), + _v_ = to_string(exn$0); + caml_call2(Stdlib_Printf[3], _n_, _v_); + print_raw_backtrace(Stdlib[40], raw_backtrace); + var _w_ = to_string(exn); + caml_call2(Stdlib_Printf[3], _o_, _w_); + print_raw_backtrace(Stdlib[40], raw_backtrace$0); + var _x_ = caml_call1(Stdlib[63], Stdlib[40]); + } + var _z_ = _x_; + } + catch(_B_){ + var _u_ = caml_wrap_exception(_B_); + if(_u_ !== Stdlib[9]) throw caml_maybe_attach_backtrace(_u_, 0); + var _z_ = caml_call1(Stdlib[53], cst_Fatal_error_out_of_memory_); + } + return _z_; + } + catch(_A_){return 0;} + } + runtime.caml_register_named_value + ("Printexc.handle_uncaught_exception", handle_uncaught_exception); + var + Stdlib_Printexc = + [0, + to_string, + to_string_default, + print, + catch$0, + print_backtrace, + get_backtrace, + runtime.caml_record_backtrace, + runtime.caml_backtrace_status, + register_printer, + use_printers, + raw_backtrace_entries, + function(_t_){return caml_get_exception_raw_backtra(_t_);}, + print_raw_backtrace, + raw_backtrace_to_string, + default_uncaught_exception_han, + set_uncaught_exception_handler, + backtrace_slots, + backtrace_slots_of_raw_entry, + [0, + backtrace_slot_is_raise, + backtrace_slot_is_inline, + backtrace_slot_location, + backtrace_slot_defname, + format_backtrace_slot], + raw_backtrace_length, + function(_s_, _r_){return runtime.caml_raw_backtrace_slot(_s_, _r_);}, + function(_q_){return runtime.caml_convert_raw_backtrace_slot(_q_);}, + function(_p_){return runtime.caml_raw_backtrace_next_slot(_p_);}, + exn_slot_id, + exn_slot_name]; + runtime.caml_register_global(42, Stdlib_Printexc, "Stdlib__Printexc"); + return; + } + (globalThis)); + +//# 21391 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + caml_register_named_value = runtime.caml_register_named_value, + global_data = runtime.caml_get_global_data(), + Stdlib_Obj = global_data.Stdlib__Obj, + register = caml_register_named_value; + function register_exception(name, exn){ + var + _a_ = Stdlib_Obj[8], + slot = runtime.caml_obj_tag(exn) === _a_ ? exn : exn[1]; + return caml_register_named_value(name, slot); + } + var Stdlib_Callback = [0, register, register_exception]; + runtime.caml_register_global(1, Stdlib_Callback, "Stdlib__Callback"); + return; + } + (globalThis)); + +//# 21414 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_camlinternalOO_ml = "camlinternalOO.ml", + caml_check_bound = runtime.caml_check_bound, + caml_div = runtime.caml_div, + caml_get_public_method = runtime.caml_get_public_method, + caml_make_vect = runtime.caml_make_vect, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace, + caml_obj_block = runtime.caml_obj_block, + caml_set_oo_id = runtime.caml_set_oo_id, + caml_string_compare = runtime.caml_string_compare, + caml_wrap_exception = runtime.caml_wrap_exception; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + function caml_call5(f, a0, a1, a2, a3, a4){ + return (f.l >= 0 ? f.l : f.l = f.length) == 5 + ? f(a0, a1, a2, a3, a4) + : runtime.caml_call_gen(f, [a0, a1, a2, a3, a4]); + } + var + global_data = runtime.caml_get_global_data(), + Assert_failure = global_data.Assert_failure, + Stdlib_Sys = global_data.Stdlib__Sys, + Stdlib_Obj = global_data.Stdlib__Obj, + Stdlib = global_data.Stdlib, + Stdlib_Array = global_data.Stdlib__Array, + Stdlib_List = global_data.Stdlib__List, + Stdlib_Map = global_data.Stdlib__Map; + function copy(o){var o$0 = o.slice(); return caml_set_oo_id(o$0);} + var params = [0, 1, 1, 1, 3, 16]; + function public_method_label(s){ + var + accu = [0, 0], + _al_ = runtime.caml_ml_string_length(s) - 1 | 0, + _ak_ = 0; + if(_al_ >= 0){ + var i = _ak_; + for(;;){ + var _am_ = runtime.caml_string_get(s, i); + accu[1] = (223 * accu[1] | 0) + _am_ | 0; + var _an_ = i + 1 | 0; + if(_al_ === i) break; + i = _an_; + } + } + accu[1] = accu[1] & 2147483647; + var tag = 1073741823 < accu[1] ? accu[1] + 2147483648 | 0 : accu[1]; + return tag; + } + var + compare = caml_string_compare, + Vars = caml_call1(Stdlib_Map[1], [0, compare]), + compare$0 = caml_string_compare, + Meths = caml_call1(Stdlib_Map[1], [0, compare$0]), + compare$1 = runtime.caml_int_compare, + Labs = caml_call1(Stdlib_Map[1], [0, compare$1]), + dummy_table = [0, 0, [0, 0], Meths[1], Labs[1], 0, 0, Vars[1], 0], + table_count = [0, 0], + dummy_met = caml_obj_block(0, 0), + initial_object_size = 2; + function fit_size(n){ + return 2 < n ? fit_size((n + 1 | 0) / 2 | 0) * 2 | 0 : n; + } + function new_table(pub_labels){ + table_count[1]++; + var + len = pub_labels.length - 1, + methods = caml_make_vect((len * 2 | 0) + 2 | 0, dummy_met); + caml_check_bound(methods, 0)[1] = len; + var + _ad_ = Stdlib_Sys[9], + _ae_ = (runtime.caml_mul(fit_size(len), _ad_) / 8 | 0) - 1 | 0; + caml_check_bound(methods, 1)[2] = _ae_; + var _ag_ = len - 1 | 0, _af_ = 0; + if(_ag_ >= 0){ + var i = _af_; + for(;;){ + var + _ai_ = (i * 2 | 0) + 3 | 0, + _ah_ = caml_check_bound(pub_labels, i)[1 + i]; + caml_check_bound(methods, _ai_)[1 + _ai_] = _ah_; + var _aj_ = i + 1 | 0; + if(_ag_ === i) break; + i = _aj_; + } + } + return [0, + initial_object_size, + methods, + Meths[1], + Labs[1], + 0, + 0, + Vars[1], + 0]; + } + function resize(array, new_size){ + var old_size = array[2].length - 1, _ab_ = old_size < new_size ? 1 : 0; + if(_ab_){ + var new_buck = caml_make_vect(new_size, dummy_met); + caml_call5(Stdlib_Array[10], array[2], 0, new_buck, 0, old_size); + array[2] = new_buck; + var _ac_ = 0; + } + else + var _ac_ = _ab_; + return _ac_; + } + var + method_count = [0, 0], + inst_var_count = [0, 0], + _a_ = [0, cst_camlinternalOO_ml, 281, 50], + _b_ = [0, cst_camlinternalOO_ml, 409, 13], + _c_ = [0, cst_camlinternalOO_ml, 412, 13], + _d_ = [0, cst_camlinternalOO_ml, 415, 13], + _e_ = [0, cst_camlinternalOO_ml, 418, 13], + _f_ = [0, cst_camlinternalOO_ml, 421, 13], + _g_ = [0, cst_camlinternalOO_ml, 439, 17]; + function new_method(table){ + var index = table[2].length - 1; + resize(table, index + 1 | 0); + return index; + } + function get_method_label(table, name){ + try{var _$_ = caml_call2(Meths[28], name, table[3]); return _$_;} + catch(_aa_){ + var ___ = caml_wrap_exception(_aa_); + if(___ !== Stdlib[8]) throw caml_maybe_attach_backtrace(___, 0); + var label = new_method(table); + table[3] = caml_call3(Meths[4], name, label, table[3]); + table[4] = caml_call3(Labs[4], label, 1, table[4]); + return label; + } + } + function get_method_labels(table, names){ + return caml_call2 + (Stdlib_Array[15], + function(_Z_){return get_method_label(table, _Z_);}, + names); + } + function set_method(table, label, element){ + method_count[1]++; + return caml_call2(Labs[28], label, table[4]) + ? (resize + (table, label + 1 | 0), + caml_check_bound(table[2], label)[1 + label] = element, + 0) + : (table[6] = [0, [0, label, element], table[6]], 0); + } + function get_method(table, label){ + try{var _X_ = caml_call2(Stdlib_List[46], label, table[6]); return _X_;} + catch(_Y_){ + var _W_ = caml_wrap_exception(_Y_); + if(_W_ === Stdlib[8]) + return caml_check_bound(table[2], label)[1 + label]; + throw caml_maybe_attach_backtrace(_W_, 0); + } + } + function to_list(arr){ + return 0 === arr ? 0 : caml_call1(Stdlib_Array[11], arr); + } + function narrow(table, vars, virt_meths, concr_meths){ + var + vars$0 = to_list(vars), + virt_meths$0 = to_list(virt_meths), + concr_meths$0 = to_list(concr_meths), + virt_meth_labs = + caml_call2 + (Stdlib_List[19], + function(_V_){return get_method_label(table, _V_);}, + virt_meths$0), + concr_meth_labs = + caml_call2 + (Stdlib_List[19], + function(_U_){return get_method_label(table, _U_);}, + concr_meths$0); + table[5] = + [0, + [0, table[3], table[4], table[6], table[7], virt_meth_labs, vars$0], + table[5]]; + table[7] = + caml_call3 + (Vars[13], + function(lab, info, tvars){ + return caml_call2(Stdlib_List[36], lab, vars$0) + ? caml_call3(Vars[4], lab, info, tvars) + : tvars; + }, + table[7], + Vars[1]); + var by_name = [0, Meths[1]], by_label = [0, Labs[1]]; + caml_call3 + (Stdlib_List[27], + function(met, label){ + by_name[1] = caml_call3(Meths[4], met, label, by_name[1]); + var _P_ = by_label[1]; + try{var _S_ = caml_call2(Labs[28], label, table[4]), _R_ = _S_;} + catch(_T_){ + var _Q_ = caml_wrap_exception(_T_); + if(_Q_ !== Stdlib[8]) throw caml_maybe_attach_backtrace(_Q_, 0); + var _R_ = 1; + } + by_label[1] = caml_call3(Labs[4], label, _R_, _P_); + return 0; + }, + concr_meths$0, + concr_meth_labs); + caml_call3 + (Stdlib_List[27], + function(met, label){ + by_name[1] = caml_call3(Meths[4], met, label, by_name[1]); + by_label[1] = caml_call3(Labs[4], label, 0, by_label[1]); + return 0; + }, + virt_meths$0, + virt_meth_labs); + table[3] = by_name[1]; + table[4] = by_label[1]; + table[6] = + caml_call3 + (Stdlib_List[26], + function(met, hm){ + var lab = met[1]; + return caml_call2(Stdlib_List[36], lab, virt_meth_labs) + ? hm + : [0, met, hm]; + }, + table[6], + 0); + return 0; + } + function widen(table){ + var + match = caml_call1(Stdlib_List[5], table[5]), + vars = match[6], + virt_meths = match[5], + saved_vars = match[4], + saved_hidden_meths = match[3], + by_label = match[2], + by_name = match[1]; + table[5] = caml_call1(Stdlib_List[6], table[5]); + table[7] = + caml_call3 + (Stdlib_List[25], + function(s, v){ + var _O_ = caml_call2(Vars[28], v, table[7]); + return caml_call3(Vars[4], v, _O_, s); + }, + saved_vars, + vars); + table[3] = by_name; + table[4] = by_label; + table[6] = + caml_call3 + (Stdlib_List[26], + function(met, hm){ + var lab = met[1]; + return caml_call2(Stdlib_List[36], lab, virt_meths) + ? hm + : [0, met, hm]; + }, + table[6], + saved_hidden_meths); + return 0; + } + function new_variable(table, name){ + try{var _M_ = caml_call2(Vars[28], name, table[7]); return _M_;} + catch(_N_){ + var _L_ = caml_wrap_exception(_N_); + if(_L_ !== Stdlib[8]) throw caml_maybe_attach_backtrace(_L_, 0); + var index = table[1]; + table[1] = index + 1 | 0; + if(name !== "") table[7] = caml_call3(Vars[4], name, index, table[7]); + return index; + } + } + function to_array(arr){return runtime.caml_equal(arr, 0) ? [0] : arr;} + function new_methods_variables(table, meths, vals){ + var + meths$0 = to_array(meths), + nmeths = meths$0.length - 1, + nvals = vals.length - 1, + res = caml_make_vect(nmeths + nvals | 0, 0), + _D_ = nmeths - 1 | 0, + _C_ = 0; + if(_D_ >= 0){ + var i$0 = _C_; + for(;;){ + var + _J_ = get_method_label(table, caml_check_bound(meths$0, i$0)[1 + i$0]); + caml_check_bound(res, i$0)[1 + i$0] = _J_; + var _K_ = i$0 + 1 | 0; + if(_D_ === i$0) break; + i$0 = _K_; + } + } + var _F_ = nvals - 1 | 0, _E_ = 0; + if(_F_ >= 0){ + var i = _E_; + for(;;){ + var + _H_ = i + nmeths | 0, + _G_ = new_variable(table, caml_check_bound(vals, i)[1 + i]); + caml_check_bound(res, _H_)[1 + _H_] = _G_; + var _I_ = i + 1 | 0; + if(_F_ === i) break; + i = _I_; + } + } + return res; + } + function get_variable(table, name){ + try{var _A_ = caml_call2(Vars[28], name, table[7]); return _A_;} + catch(_B_){ + var _z_ = caml_wrap_exception(_B_); + if(_z_ === Stdlib[8]) + throw caml_maybe_attach_backtrace([0, Assert_failure, _a_], 1); + throw caml_maybe_attach_backtrace(_z_, 0); + } + } + function get_variables(table, names){ + return caml_call2 + (Stdlib_Array[15], + function(_y_){return get_variable(table, _y_);}, + names); + } + function add_initializer(table, f){table[8] = [0, f, table[8]]; return 0;} + function create_table(public_methods){ + if(0 === public_methods) return new_table([0]); + var + tags = caml_call2(Stdlib_Array[15], public_method_label, public_methods), + table = new_table(tags); + caml_call2 + (Stdlib_Array[14], + function(i, met){ + var lab = (i * 2 | 0) + 2 | 0; + table[3] = caml_call3(Meths[4], met, lab, table[3]); + table[4] = caml_call3(Labs[4], lab, 1, table[4]); + return 0; + }, + public_methods); + return table; + } + function init_class(table){ + inst_var_count[1] = (inst_var_count[1] + table[1] | 0) - 1 | 0; + table[8] = caml_call1(Stdlib_List[9], table[8]); + var _x_ = Stdlib_Sys[9]; + return resize + (table, + 3 + caml_div(caml_check_bound(table[2], 1)[2] * 16 | 0, _x_) | 0); + } + function inherits(cla, vals, virt_meths, concr_meths, param, top){ + var env = param[4], super$0 = param[2]; + narrow(cla, vals, virt_meths, concr_meths); + var init = top ? caml_call2(super$0, cla, env) : caml_call1(super$0, cla); + widen(cla); + var + _s_ = to_array(concr_meths), + _t_ = + [0, + caml_call2 + (Stdlib_Array[15], + function(nm){return get_method(cla, get_method_label(cla, nm));}, + _s_), + 0], + _u_ = to_array(vals), + _v_ = + [0, + [0, init], + [0, + caml_call2 + (Stdlib_Array[15], + function(_w_){return get_variable(cla, _w_);}, + _u_), + _t_]]; + return caml_call1(Stdlib_Array[6], _v_); + } + function make_class(pub_meths, class_init){ + var + table = create_table(pub_meths), + env_init = caml_call1(class_init, table); + init_class(table); + return [0, caml_call1(env_init, 0), class_init, env_init, 0]; + } + function make_class_store(pub_meths, class_init, init_table){ + var + table = create_table(pub_meths), + env_init = caml_call1(class_init, table); + init_class(table); + init_table[2] = class_init; + init_table[1] = env_init; + return 0; + } + function dummy_class(loc){ + function undef(param){ + throw caml_maybe_attach_backtrace([0, Stdlib[15], loc], 1); + } + return [0, undef, undef, undef, 0]; + } + function create_object(table){ + var obj = caml_obj_block(Stdlib_Obj[8], table[1]); + obj[1] = table[2]; + return caml_set_oo_id(obj); + } + function create_object_opt(obj_0, table){ + if(obj_0) return obj_0; + var obj = caml_obj_block(Stdlib_Obj[8], table[1]); + obj[1] = table[2]; + return caml_set_oo_id(obj); + } + function iter_f(obj, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var l = param$0[2], f = param$0[1]; + caml_call1(f, obj); + param$0 = l; + } + } + function run_initializers(obj, table){ + var inits = table[8], _r_ = 0 !== inits ? 1 : 0; + return _r_ ? iter_f(obj, inits) : _r_; + } + function run_initializers_opt(obj_0, obj, table){ + if(obj_0) return obj; + var inits = table[8]; + if(0 !== inits) iter_f(obj, inits); + return obj; + } + function create_object_and_run_initiali(obj_0, table){ + if(obj_0) return obj_0; + var obj = create_object(table); + run_initializers(obj, table); + return obj; + } + function get_data(param){ + if(param) return param[2]; + throw caml_maybe_attach_backtrace([0, Assert_failure, _e_], 1); + } + function build_path(n, keys, tables){ + var res = [0, 0, 0, 0], r = [0, res], _o_ = 0; + if(n >= 0){ + var i = _o_; + for(;;){ + var _p_ = r[1]; + r[1] = [0, caml_check_bound(keys, i)[1 + i], _p_, 0]; + var _q_ = i + 1 | 0; + if(n === i) break; + i = _q_; + } + } + var v = r[1]; + if(! tables) + throw caml_maybe_attach_backtrace([0, Assert_failure, _b_], 1); + tables[2] = v; + return res; + } + function lookup_tables(root, keys){ + var root_data = get_data(root); + if(! root_data) return build_path(keys.length - 2 | 0, keys, root); + var i$1 = keys.length - 2 | 0, i = i$1, tables$0 = root_data; + for(;;){ + if(0 > i) return tables$0; + var key = caml_check_bound(keys, i)[1 + i], tables$1 = tables$0; + for(;;){ + if(! tables$1) + throw caml_maybe_attach_backtrace([0, Assert_failure, _d_], 1); + if(tables$1[1] === key) break; + if(! tables$1) + throw caml_maybe_attach_backtrace([0, Assert_failure, _f_], 1); + var tables = tables$1[3]; + if(! tables){ + var next = [0, key, 0, 0]; + if(! tables$1) + throw caml_maybe_attach_backtrace([0, Assert_failure, _c_], 1); + tables$1[3] = next; + return build_path(i - 1 | 0, keys, next); + } + tables$1 = tables; + } + var tables_data = get_data(tables$1); + if(! tables_data) + throw caml_maybe_attach_backtrace([0, Assert_failure, _g_], 1); + var i$0 = i - 1 | 0; + i = i$0; + tables$0 = tables_data; + } + } + function new_cache(table){ + var n = new_method(table); + a: + { + if(0 !== (n % 2 | 0)){ + var _n_ = Stdlib_Sys[9]; + if + ((2 + caml_div(caml_check_bound(table[2], 1)[2] * 16 | 0, _n_) | 0) + >= n){ + var n$0 = new_method(table); + break a; + } + } + var n$0 = n; + } + caml_check_bound(table[2], n$0)[1 + n$0] = 0; + return n$0; + } + function set_methods(table, methods){ + var len = methods.length - 1, i = [0, 0]; + for(;;){ + if(i[1] >= len) return 0; + var + _h_ = i[1], + label = caml_check_bound(methods, _h_)[1 + _h_], + next = + function(param){ + i[1]++; + var _m_ = i[1]; + return caml_check_bound(methods, _m_)[1 + _m_]; + }, + clo = next(0); + if(typeof clo === "number") + switch(clo){ + case 0: + var x = next(0); + let x$20 = x; + var clo$0 = function(obj){return x$20;}; + break; + case 1: + var n = next(0); + let n$38 = n; + var clo$0 = function(obj){return obj[1 + n$38];}; + break; + case 2: + var e = next(0), n$0 = next(0); + let e$10 = e, n$37 = n$0; + var clo$0 = function(obj){return obj[1 + e$10][1 + n$37];}; + break; + case 3: + var n$1 = next(0); + let n$36 = n$1; + var clo$0 = function(obj){return caml_call1(obj[1][1 + n$36], obj);}; + break; + case 4: + var n$2 = next(0); + let n$35 = n$2; + var clo$0 = function(obj, x){obj[1 + n$35] = x; return 0;}; + break; + case 5: + var f = next(0), x$0 = next(0); + let f$20 = f, x$19 = x$0; + var clo$0 = function(obj){return caml_call1(f$20, x$19);}; + break; + case 6: + var f$0 = next(0), n$3 = next(0); + let f$19 = f$0, n$34 = n$3; + var clo$0 = function(obj){return caml_call1(f$19, obj[1 + n$34]);}; + break; + case 7: + var f$1 = next(0), e$0 = next(0), n$4 = next(0); + let f$18 = f$1, e$9 = e$0, n$33 = n$4; + var + clo$0 = + function(obj){return caml_call1(f$18, obj[1 + e$9][1 + n$33]);}; + break; + case 8: + var f$2 = next(0), n$5 = next(0); + let f$17 = f$2, n$32 = n$5; + var + clo$0 = + function(obj){ + return caml_call1(f$17, caml_call1(obj[1][1 + n$32], obj)); + }; + break; + case 9: + var f$3 = next(0), x$1 = next(0), y = next(0); + let f$16 = f$3, x$18 = x$1, y$0 = y; + var clo$0 = function(obj){return caml_call2(f$16, x$18, y$0);}; + break; + case 10: + var f$4 = next(0), x$2 = next(0), n$6 = next(0); + let f$15 = f$4, x$17 = x$2, n$31 = n$6; + var + clo$0 = function(obj){return caml_call2(f$15, x$17, obj[1 + n$31]);}; + break; + case 11: + var f$5 = next(0), x$3 = next(0), e$1 = next(0), n$7 = next(0); + let f$14 = f$5, x$16 = x$3, e$8 = e$1, n$30 = n$7; + var + clo$0 = + function(obj){ + return caml_call2(f$14, x$16, obj[1 + e$8][1 + n$30]); + }; + break; + case 12: + var f$6 = next(0), x$4 = next(0), n$8 = next(0); + let f$13 = f$6, x$15 = x$4, n$29 = n$8; + var + clo$0 = + function(obj){ + return caml_call2(f$13, x$15, caml_call1(obj[1][1 + n$29], obj)); + }; + break; + case 13: + var f$7 = next(0), n$9 = next(0), x$5 = next(0); + let f$12 = f$7, n$28 = n$9, x$14 = x$5; + var + clo$0 = function(obj){return caml_call2(f$12, obj[1 + n$28], x$14);}; + break; + case 14: + var f$8 = next(0), e$2 = next(0), n$10 = next(0), x$6 = next(0); + let f$11 = f$8, e$7 = e$2, n$27 = n$10, x$13 = x$6; + var + clo$0 = + function(obj){ + return caml_call2(f$11, obj[1 + e$7][1 + n$27], x$13); + }; + break; + case 15: + var f$9 = next(0), n$11 = next(0), x$7 = next(0); + let f$10 = f$9, n$26 = n$11, x$12 = x$7; + var + clo$0 = + function(obj){ + return caml_call2(f$10, caml_call1(obj[1][1 + n$26], obj), x$12); + }; + break; + case 16: + var n$12 = next(0), x$8 = next(0); + let n$25 = n$12, x$11 = x$8; + var + clo$0 = + function(obj){return caml_call2(obj[1][1 + n$25], obj, x$11);}; + break; + case 17: + var n$13 = next(0), m = next(0); + let n$24 = n$13, m$12 = m; + var + clo$0 = + function(obj){ + return caml_call2(obj[1][1 + n$24], obj, obj[1 + m$12]); + }; + break; + case 18: + var n$14 = next(0), e$3 = next(0), m$0 = next(0); + let n$23 = n$14, e$6 = e$3, m$11 = m$0; + var + clo$0 = + function(obj){ + return caml_call2(obj[1][1 + n$23], obj, obj[1 + e$6][1 + m$11]); + }; + break; + case 19: + var n$15 = next(0), m$1 = next(0); + let n$22 = n$15, m$10 = m$1; + var + clo$0 = + function(obj){ + var _l_ = caml_call1(obj[1][1 + m$10], obj); + return caml_call2(obj[1][1 + n$22], obj, _l_); + }; + break; + case 20: + var m$2 = next(0), x$9 = next(0); + new_cache(table); + let m$9 = m$2, x$10 = x$9; + var + clo$0 = + function(obj){ + return caml_call1(caml_get_public_method(x$10, m$9, 0), x$10); + }; + break; + case 21: + var m$3 = next(0), n$16 = next(0); + new_cache(table); + let m$8 = m$3, n$21 = n$16; + var + clo$0 = + function(obj){ + var _k_ = obj[1 + n$21]; + return caml_call1(caml_get_public_method(_k_, m$8, 0), _k_); + }; + break; + case 22: + var m$4 = next(0), e$4 = next(0), n$17 = next(0); + new_cache(table); + let m$7 = m$4, e$5 = e$4, n$20 = n$17; + var + clo$0 = + function(obj){ + var _j_ = obj[1 + e$5][1 + n$20]; + return caml_call1(caml_get_public_method(_j_, m$7, 0), _j_); + }; + break; + default: + var m$5 = next(0), n$18 = next(0); + new_cache(table); + let m$6 = m$5, n$19 = n$18; + var + clo$0 = + function(obj){ + var _i_ = caml_call1(obj[1][1 + n$19], obj); + return caml_call1(caml_get_public_method(_i_, m$6, 0), _i_); + }; + } + else + var clo$0 = clo; + set_method(table, label, clo$0); + i[1]++; + } + } + function stats(param){ + return [0, table_count[1], method_count[1], inst_var_count[1]]; + } + var + CamlinternalOO = + [0, + public_method_label, + new_method, + new_variable, + new_methods_variables, + get_variable, + get_variables, + get_method_label, + get_method_labels, + get_method, + set_method, + set_methods, + narrow, + widen, + add_initializer, + dummy_table, + create_table, + init_class, + inherits, + make_class, + make_class_store, + dummy_class, + copy, + create_object, + create_object_opt, + run_initializers, + run_initializers_opt, + create_object_and_run_initiali, + lookup_tables, + params, + stats]; + runtime.caml_register_global(17, CamlinternalOO, "CamlinternalOO"); + return; + } + (globalThis)); + +//# 25359 "../.js/default/stdlib/stdlib.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_Bigarray_Array3_of_array_n$1 = + "Bigarray.Array3.of_array: non-cubic data", + caml_ba_change_layout = runtime.caml_ba_change_layout, + caml_ba_create = runtime.caml_ba_create, + caml_ba_dim_1 = runtime.caml_ba_dim_1, + caml_ba_dim_2 = runtime.caml_ba_dim_2, + caml_ba_kind = runtime.caml_ba_kind, + caml_ba_num_dims = runtime.caml_ba_num_dims, + caml_ba_reshape = runtime.caml_ba_reshape, + caml_ba_set_1 = runtime.caml_ba_set_1, + caml_ba_set_2 = runtime.caml_ba_set_2, + caml_ba_set_3 = runtime.caml_ba_set_3, + caml_ba_set_generic = runtime.caml_ba_set_generic, + caml_ba_slice = runtime.caml_ba_slice, + caml_check_bound = runtime.caml_check_bound, + caml_make_vect = runtime.caml_make_vect, + caml_mul = runtime.caml_mul; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + undef = undefined, + global_data = runtime.caml_get_global_data(), + Stdlib = global_data.Stdlib, + Stdlib_Array = global_data.Stdlib__Array, + Stdlib_Sys = global_data.Stdlib__Sys; + function kind_size_in_bytes(param){ + switch(param){ + case 0: + return 4; + case 1: + return 8; + case 2: + return 1; + case 3: + return 1; + case 4: + return 2; + case 5: + return 2; + case 6: + return 4; + case 7: + return 8; + case 8: + return Stdlib_Sys[9] / 8 | 0; + case 9: + return Stdlib_Sys[9] / 8 | 0; + case 10: + return 8; + case 11: + return 16; + default: return 1; + } + } + var + cst_Bigarray_Array2_of_array_n = + "Bigarray.Array2.of_array: non-rectangular data", + cst_Bigarray_Array3_of_array_n = cst_Bigarray_Array3_of_array_n$1, + cst_Bigarray_Array3_of_array_n$0 = cst_Bigarray_Array3_of_array_n$1, + cst_Bigarray_array0_of_genarra = "Bigarray.array0_of_genarray", + cst_Bigarray_array1_of_genarra = "Bigarray.array1_of_genarray", + cst_Bigarray_array2_of_genarra = "Bigarray.array2_of_genarray", + cst_Bigarray_array3_of_genarra = "Bigarray.array3_of_genarray"; + function cloop(arr, idx, f, col, max){ + if(col === idx.length - 1){ + caml_ba_set_generic(arr, idx, caml_call1(f, idx)); + return; + } + var _am_ = caml_check_bound(max, col)[1 + col] - 1 | 0, _al_ = 0; + if(_am_ >= 0){ + var j = _al_; + for(;;){ + caml_check_bound(idx, col)[1 + col] = j; + cloop(arr, idx, f, col + 1 | 0, max); + var _an_ = j + 1 | 0; + if(_am_ === j) break; + j = _an_; + } + } + return; + } + function floop(arr, idx, f, col, max){ + if(0 > col){caml_ba_set_generic(arr, idx, caml_call1(f, idx)); return;} + var _aj_ = caml_check_bound(max, col)[1 + col], _ai_ = 1; + if(_aj_ >= 1){ + var j = _ai_; + for(;;){ + caml_check_bound(idx, col)[1 + col] = j; + floop(arr, idx, f, col - 1 | 0, max); + var _ak_ = j + 1 | 0; + if(_aj_ === j) break; + j = _ak_; + } + } + return; + } + function init(kind, layout, dims, f){ + var arr = caml_ba_create(kind, layout, dims), match = dims.length - 1; + return 0 === match + ? arr + : layout + ? (floop + (arr, caml_make_vect(match, 1), f, match - 1 | 0, dims), + arr) + : (cloop(arr, caml_make_vect(match, 0), f, 0, dims), arr); + } + function dims(a){ + var + n = caml_ba_num_dims(a), + d = caml_make_vect(n, 0), + _af_ = n - 1 | 0, + _ae_ = 0; + if(_af_ >= 0){ + var i = _ae_; + for(;;){ + var _ag_ = runtime.caml_ba_dim(a, i); + caml_check_bound(d, i)[1 + i] = _ag_; + var _ah_ = i + 1 | 0; + if(_af_ === i) break; + i = _ah_; + } + } + return d; + } + function size_in_bytes(arr){ + var + _ac_ = dims(arr), + _ad_ = caml_call3(Stdlib_Array[17], caml_mul, 1, _ac_); + return caml_mul(kind_size_in_bytes(caml_ba_kind(arr)), _ad_); + } + function create(kind, layout){return caml_ba_create(kind, layout, [0]);} + function get(arr){return runtime.caml_ba_get_generic(arr, [0]);} + function set(arr){ + var _aa_ = [0]; + return function(_ab_){return caml_ba_set_generic(arr, _aa_, _ab_);}; + } + function size_in_bytes$0(arr){ + return kind_size_in_bytes(caml_ba_kind(arr)); + } + function of_value(kind, layout, v){ + var a = create(kind, layout); + set(a)(v); + return a; + } + function create$0(kind, layout, dim){ + return caml_ba_create(kind, layout, [0, dim]); + } + function size_in_bytes$1(arr){ + var _$_ = caml_ba_dim_1(arr); + return caml_mul(kind_size_in_bytes(caml_ba_kind(arr)), _$_); + } + function slice(a, n){ + return runtime.caml_ba_layout(a) + ? caml_ba_slice(a, [0, n]) + : caml_ba_slice(a, [0, n]); + } + function init$0(kind, layout, dim, f){ + var arr = create$0(kind, layout, dim); + if(layout){ + var _Z_ = 1; + if(dim >= 1){ + var i$0 = _Z_; + for(;;){ + caml_ba_set_1(arr, i$0, caml_call1(f, i$0)); + var ___ = i$0 + 1 | 0; + if(dim === i$0) break; + i$0 = ___; + } + } + return arr; + } + var _X_ = dim - 1 | 0, _W_ = 0; + if(_X_ >= 0){ + var i = _W_; + for(;;){ + caml_ba_set_1(arr, i, caml_call1(f, i)); + var _Y_ = i + 1 | 0; + if(_X_ === i) break; + i = _Y_; + } + } + return arr; + } + function of_array(kind, layout, data){ + var + ba = create$0(kind, layout, data.length - 1), + ofs = layout ? 1 : 0, + _U_ = data.length - 2 | 0, + _T_ = 0; + if(_U_ >= 0){ + var i = _T_; + for(;;){ + caml_ba_set_1(ba, i + ofs | 0, caml_check_bound(data, i)[1 + i]); + var _V_ = i + 1 | 0; + if(_U_ === i) break; + i = _V_; + } + } + return ba; + } + function create$1(kind, layout, dim1, dim2){ + return caml_ba_create(kind, layout, [0, dim1, dim2]); + } + function size_in_bytes$2(arr){ + var _R_ = caml_ba_dim_2(arr), _S_ = caml_ba_dim_1(arr); + return caml_mul(caml_mul(kind_size_in_bytes(caml_ba_kind(arr)), _S_), _R_); + } + function slice_left(a, n){return caml_ba_slice(a, [0, n]);} + function slice_right(a, n){return caml_ba_slice(a, [0, n]);} + function init$1(kind, layout, dim1, dim2, f){ + var arr = create$1(kind, layout, dim1, dim2); + if(layout){ + var _N_ = 1; + if(dim2 >= 1){ + var j$0 = _N_; + for(;;){ + var _O_ = 1; + if(dim1 >= 1){ + var i$0 = _O_; + for(;;){ + caml_ba_set_2(arr, i$0, j$0, caml_call2(f, i$0, j$0)); + var _Q_ = i$0 + 1 | 0; + if(dim1 === i$0) break; + i$0 = _Q_; + } + } + var _P_ = j$0 + 1 | 0; + if(dim2 === j$0) break; + j$0 = _P_; + } + } + return arr; + } + var _I_ = dim1 - 1 | 0, _H_ = 0; + if(_I_ >= 0){ + var i = _H_; + for(;;){ + var _K_ = dim2 - 1 | 0, _J_ = 0; + if(_K_ >= 0){ + var j = _J_; + for(;;){ + caml_ba_set_2(arr, i, j, caml_call2(f, i, j)); + var _M_ = j + 1 | 0; + if(_K_ === j) break; + j = _M_; + } + } + var _L_ = i + 1 | 0; + if(_I_ === i) break; + i = _L_; + } + } + return arr; + } + function of_array$0(kind, layout, data){ + var + dim1 = data.length - 1, + dim2 = 0 === dim1 ? 0 : caml_check_bound(data, 0)[1].length - 1, + ba = create$1(kind, layout, dim1, dim2), + ofs = layout ? 1 : 0, + _C_ = dim1 - 1 | 0, + _B_ = 0; + if(_C_ >= 0){ + var i = _B_; + for(;;){ + var row = caml_check_bound(data, i)[1 + i]; + if(row.length - 1 !== dim2) + caml_call1(Stdlib[1], cst_Bigarray_Array2_of_array_n); + var _E_ = dim2 - 1 | 0, _D_ = 0; + if(_E_ >= 0){ + var j = _D_; + for(;;){ + caml_ba_set_2 + (ba, i + ofs | 0, j + ofs | 0, caml_check_bound(row, j)[1 + j]); + var _G_ = j + 1 | 0; + if(_E_ === j) break; + j = _G_; + } + } + var _F_ = i + 1 | 0; + if(_C_ === i) break; + i = _F_; + } + } + return ba; + } + function create$2(kind, layout, dim1, dim2, dim3){ + return caml_ba_create(kind, layout, [0, dim1, dim2, dim3]); + } + function size_in_bytes$3(arr){ + var + _y_ = runtime.caml_ba_dim_3(arr), + _z_ = caml_ba_dim_2(arr), + _A_ = caml_ba_dim_1(arr); + return caml_mul + (caml_mul + (caml_mul(kind_size_in_bytes(caml_ba_kind(arr)), _A_), _z_), + _y_); + } + function slice_left_1(a, n, m){return caml_ba_slice(a, [0, n, m]);} + function slice_right_1(a, n, m){return caml_ba_slice(a, [0, n, m]);} + function slice_left_2(a, n){return caml_ba_slice(a, [0, n]);} + function slice_right_2(a, n){return caml_ba_slice(a, [0, n]);} + function init$2(kind, layout, dim1, dim2, dim3, f){ + var arr = create$2(kind, layout, dim1, dim2, dim3); + if(layout){ + var _s_ = 1; + if(dim3 >= 1){ + var k$0 = _s_; + for(;;){ + var _t_ = 1; + if(dim2 >= 1){ + var j$0 = _t_; + for(;;){ + var _v_ = 1; + if(dim1 >= 1){ + var i$0 = _v_; + for(;;){ + caml_ba_set_3(arr, i$0, j$0, k$0, caml_call3(f, i$0, j$0, k$0)); + var _x_ = i$0 + 1 | 0; + if(dim1 === i$0) break; + i$0 = _x_; + } + } + var _w_ = j$0 + 1 | 0; + if(dim2 === j$0) break; + j$0 = _w_; + } + } + var _u_ = k$0 + 1 | 0; + if(dim3 === k$0) break; + k$0 = _u_; + } + } + return arr; + } + var _k_ = dim1 - 1 | 0, _j_ = 0; + if(_k_ >= 0){ + var i = _j_; + for(;;){ + var _m_ = dim2 - 1 | 0, _l_ = 0; + if(_m_ >= 0){ + var j = _l_; + for(;;){ + var _p_ = dim3 - 1 | 0, _o_ = 0; + if(_p_ >= 0){ + var k = _o_; + for(;;){ + caml_ba_set_3(arr, i, j, k, caml_call3(f, i, j, k)); + var _r_ = k + 1 | 0; + if(_p_ === k) break; + k = _r_; + } + } + var _q_ = j + 1 | 0; + if(_m_ === j) break; + j = _q_; + } + } + var _n_ = i + 1 | 0; + if(_k_ === i) break; + i = _n_; + } + } + return arr; + } + function of_array$1(kind, layout, data){ + var + dim1 = data.length - 1, + dim2 = 0 === dim1 ? 0 : caml_check_bound(data, 0)[1].length - 1, + dim3 = + 0 === dim2 + ? 0 + : caml_check_bound(caml_check_bound(data, 0)[1], 0)[1].length - 1, + ba = create$2(kind, layout, dim1, dim2, dim3), + ofs = layout ? 1 : 0, + _b_ = dim1 - 1 | 0, + _a_ = 0; + if(_b_ >= 0){ + var i = _a_; + for(;;){ + var row = caml_check_bound(data, i)[1 + i]; + if(row.length - 1 !== dim2) + caml_call1(Stdlib[1], cst_Bigarray_Array3_of_array_n); + var _d_ = dim2 - 1 | 0, _c_ = 0; + if(_d_ >= 0){ + var j = _c_; + for(;;){ + var col = caml_check_bound(row, j)[1 + j]; + if(col.length - 1 !== dim3) + caml_call1(Stdlib[1], cst_Bigarray_Array3_of_array_n$0); + var _g_ = dim3 - 1 | 0, _f_ = 0; + if(_g_ >= 0){ + var k = _f_; + for(;;){ + caml_ba_set_3 + (ba, + i + ofs | 0, + j + ofs | 0, + k + ofs | 0, + caml_check_bound(col, k)[1 + k]); + var _i_ = k + 1 | 0; + if(_g_ === k) break; + k = _i_; + } + } + var _h_ = j + 1 | 0; + if(_d_ === j) break; + j = _h_; + } + } + var _e_ = i + 1 | 0; + if(_b_ === i) break; + i = _e_; + } + } + return ba; + } + function array0_of_genarray(a){ + return 0 === caml_ba_num_dims(a) + ? a + : caml_call1(Stdlib[1], cst_Bigarray_array0_of_genarra); + } + function array1_of_genarray(a){ + return 1 === caml_ba_num_dims(a) + ? a + : caml_call1(Stdlib[1], cst_Bigarray_array1_of_genarra); + } + function array2_of_genarray(a){ + return 2 === caml_ba_num_dims(a) + ? a + : caml_call1(Stdlib[1], cst_Bigarray_array2_of_genarra); + } + function array3_of_genarray(a){ + return 3 === caml_ba_num_dims(a) + ? a + : caml_call1(Stdlib[1], cst_Bigarray_array3_of_genarra); + } + function reshape_0(a){return caml_ba_reshape(a, [0]);} + function reshape_1(a, dim1){return caml_ba_reshape(a, [0, dim1]);} + function reshape_2(a, dim1, dim2){ + return caml_ba_reshape(a, [0, dim1, dim2]); + } + function reshape_3(a, dim1, dim2, dim3){ + return caml_ba_reshape(a, [0, dim1, dim2, dim3]); + } + var + Stdlib_Bigarray = + [0, + 0, + 1, + 10, + 11, + 2, + 3, + 4, + 5, + 8, + 6, + 7, + 9, + 12, + kind_size_in_bytes, + 0, + 1, + [0, init, dims, size_in_bytes], + [0, + create, + of_value, + caml_ba_change_layout, + size_in_bytes$0, + get, + set, + of_value], + [0, + create$0, + init$0, + caml_ba_change_layout, + size_in_bytes$1, + slice, + of_array], + [0, + create$1, + init$1, + caml_ba_change_layout, + size_in_bytes$2, + slice_left, + slice_right, + of_array$0], + [0, + create$2, + init$2, + caml_ba_change_layout, + size_in_bytes$3, + slice_left_1, + slice_right_1, + slice_left_2, + slice_right_2, + of_array$1], + array0_of_genarray, + array1_of_genarray, + array2_of_genarray, + array3_of_genarray, + caml_ba_reshape, + reshape_0, + reshape_1, + reshape_2, + reshape_3]; + runtime.caml_register_global(10, Stdlib_Bigarray, "Stdlib__Bigarray"); + return; + } + (globalThis)); + + +//# 1 "../.js/default/js_of_ocaml-compiler.runtime/jsoo_runtime.cma.js" +// Generated by js_of_ocaml +//# 3 "../.js/default/js_of_ocaml-compiler.runtime/jsoo_runtime.cma.js" + +//# 18 "../.js/default/js_of_ocaml-compiler.runtime/jsoo_runtime.cma.js" +(function(globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + s = "5.8.2", + git_version = "", + Jsoo_runtime_Runtime_version = [0, s, git_version]; + runtime.caml_register_global + (2, Jsoo_runtime_Runtime_version, "Jsoo_runtime__Runtime_version"); + return; + } + (globalThis)); + +//# 33 "../.js/default/js_of_ocaml-compiler.runtime/jsoo_runtime.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + Jsoo_runtime_Runtime_version = global_data.Jsoo_runtime__Runtime_version, + Stdlib_Callback = global_data.Stdlib__Callback, + Js = [0], + Config = [0], + version = Jsoo_runtime_Runtime_version[1], + git_version = Jsoo_runtime_Runtime_version[2], + Sys = [0, Config, version, git_version], + Exn = [248, "Jsoo_runtime.Error.Exn", runtime.caml_fresh_oo_id(0)]; + caml_call2(Stdlib_Callback[2], "jsError", [0, Exn, [0]]); + function raise(exn){throw exn;} + var + Error = + [0, + raise, + runtime.caml_exn_with_js_backtrace, + runtime.caml_js_error_option_of_exception, + Exn], + For_compatibility_only = [0], + Bigstring = [0], + Typed_array = [0, Bigstring], + Int64 = [0], + Jsoo_runtime = + [0, Js, Sys, Error, For_compatibility_only, Typed_array, Int64]; + runtime.caml_register_global(5, Jsoo_runtime, "Jsoo_runtime"); + return; + } + (globalThis)); + + +//# 1 "../.js/default/js_of_ocaml/js_of_ocaml.cma.js" +// Generated by js_of_ocaml +//# 3 "../.js/default/js_of_ocaml/js_of_ocaml.cma.js" + +//# 19 "../.js/default/js_of_ocaml/js_of_ocaml.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + global_data = runtime.caml_get_global_data(), + Stdlib_String = global_data.Stdlib__String, + Stdlib_Char = global_data.Stdlib__Char, + Poly = [0]; + function max(x, y){return y <= x ? x : y;} + function min(x, y){return x <= y ? x : y;} + var + Int_replace_polymorphic_compar = [0, max, min], + make = Stdlib_String[1], + init = Stdlib_String[2], + empty = Stdlib_String[3], + of_bytes = Stdlib_String[4], + to_bytes = Stdlib_String[5], + concat = Stdlib_String[6], + cat = Stdlib_String[7], + compare = Stdlib_String[9], + starts_with = Stdlib_String[10], + ends_with = Stdlib_String[11], + contains_from = Stdlib_String[12], + rcontains_from = Stdlib_String[13], + contains = Stdlib_String[14], + sub = Stdlib_String[15], + split_on_char = Stdlib_String[16], + map = Stdlib_String[17], + mapi = Stdlib_String[18], + fold_left = Stdlib_String[19], + fold_right = Stdlib_String[20], + for_all = Stdlib_String[21], + exists = Stdlib_String[22], + trim = Stdlib_String[23], + escaped = Stdlib_String[24], + uppercase_ascii = Stdlib_String[25], + lowercase_ascii = Stdlib_String[26], + capitalize_ascii = Stdlib_String[27], + uncapitalize_ascii = Stdlib_String[28], + iter = Stdlib_String[29], + iteri = Stdlib_String[30], + index_from = Stdlib_String[31], + index_from_opt = Stdlib_String[32], + rindex_from = Stdlib_String[33], + rindex_from_opt = Stdlib_String[34], + index = Stdlib_String[35], + index_opt = Stdlib_String[36], + rindex = Stdlib_String[37], + rindex_opt = Stdlib_String[38], + to_seq = Stdlib_String[39], + to_seqi = Stdlib_String[40], + of_seq = Stdlib_String[41], + blit = Stdlib_String[42], + copy = Stdlib_String[43], + fill = Stdlib_String[44], + uppercase = Stdlib_String[45], + lowercase = Stdlib_String[46], + capitalize = Stdlib_String[47], + uncapitalize = Stdlib_String[48], + get_uint8 = Stdlib_String[49], + get_int8 = Stdlib_String[50], + get_uint16_ne = Stdlib_String[51], + get_uint16_be = Stdlib_String[52], + get_uint16_le = Stdlib_String[53], + get_int16_ne = Stdlib_String[54], + get_int16_be = Stdlib_String[55], + get_int16_le = Stdlib_String[56], + get_int32_ne = Stdlib_String[57], + get_int32_be = Stdlib_String[58], + get_int32_le = Stdlib_String[59], + get_int64_ne = Stdlib_String[60], + get_int64_be = Stdlib_String[61], + get_int64_le = Stdlib_String[62], + equal = runtime.caml_string_equal, + String = + [0, + make, + init, + empty, + of_bytes, + to_bytes, + concat, + cat, + compare, + starts_with, + ends_with, + contains_from, + rcontains_from, + contains, + sub, + split_on_char, + map, + mapi, + fold_left, + fold_right, + for_all, + exists, + trim, + escaped, + uppercase_ascii, + lowercase_ascii, + capitalize_ascii, + uncapitalize_ascii, + iter, + iteri, + index_from, + index_from_opt, + rindex_from, + rindex_from_opt, + index, + index_opt, + rindex, + rindex_opt, + to_seq, + to_seqi, + of_seq, + blit, + copy, + fill, + uppercase, + lowercase, + capitalize, + uncapitalize, + get_uint8, + get_int8, + get_uint16_ne, + get_uint16_be, + get_uint16_le, + get_int16_ne, + get_int16_be, + get_int16_le, + get_int32_ne, + get_int32_be, + get_int32_le, + get_int64_ne, + get_int64_be, + get_int64_le, + equal], + chr = Stdlib_Char[1], + escaped$0 = Stdlib_Char[2], + lowercase$0 = Stdlib_Char[3], + uppercase$0 = Stdlib_Char[4], + lowercase_ascii$0 = Stdlib_Char[5], + uppercase_ascii$0 = Stdlib_Char[6], + compare$0 = Stdlib_Char[7]; + function equal$0(x, y){return x === y ? 1 : 0;} + var + Char = + [0, + chr, + escaped$0, + lowercase$0, + uppercase$0, + lowercase_ascii$0, + uppercase_ascii$0, + compare$0, + equal$0], + max$0 = Int_replace_polymorphic_compar[1], + min$0 = Int_replace_polymorphic_compar[2], + Js_of_ocaml_Import = + [0, Poly, Int_replace_polymorphic_compar, String, Char, max$0, min$0]; + runtime.caml_register_global(2, Js_of_ocaml_Import, "Js_of_ocaml__Import"); + return; + } + (globalThis)); + +//# 188 "../.js/default/js_of_ocaml/js_of_ocaml.cma.js" +(function + (globalThis){ + "use strict"; + var + jsoo_exports = typeof module === "object" && module.exports || globalThis, + runtime = globalThis.jsoo_runtime, + cst_parseFloat$0 = "parseFloat", + cst_parseInt$0 = "parseInt", + caml_js_get = runtime.caml_js_get, + caml_js_set = runtime.caml_js_set, + caml_js_wrap_callback = runtime.caml_js_wrap_callback, + caml_string_of_jsstring = runtime.caml_string_of_jsstring; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + Js_of_ocaml_Import = global_data.Js_of_ocaml__Import, + Stdlib = global_data.Stdlib, + Jsoo_runtime = global_data.Jsoo_runtime, + Stdlib_Printexc = global_data.Stdlib__Printexc, + global = globalThis, + Unsafe = [0, global], + null$0 = null, + undefined$0 = undefined; + function return$0(_p_){return _p_;} + function map(x, f){return x == null$0 ? null$0 : caml_call1(f, x);} + function bind(x, f){return x == null$0 ? null$0 : caml_call1(f, x);} + function test(x){return 1 - (x == null$0 ? 1 : 0);} + function iter(x, f){ + var _o_ = 1 - (x == null$0 ? 1 : 0); + return _o_ ? caml_call1(f, x) : _o_; + } + function case$0(x, f, g){ + return x == null$0 ? caml_call1(f, 0) : caml_call1(g, x); + } + function get(x, f){return x == null$0 ? caml_call1(f, 0) : x;} + function option(x){if(! x) return null$0; var x$0 = x[1]; return x$0;} + function to_option(x){return x == null$0 ? 0 : [0, x];} + var + Opt = + [0, + null$0, + return$0, + map, + bind, + test, + iter, + case$0, + get, + option, + to_option]; + function return$1(_n_){return _n_;} + function map$0(x, f){ + return x === undefined$0 ? undefined$0 : caml_call1(f, x); + } + function bind$0(x, f){ + return x === undefined$0 ? undefined$0 : caml_call1(f, x); + } + function test$0(x){return 1 - (x === undefined$0 ? 1 : 0);} + function iter$0(x, f){ + var _m_ = 1 - (x === undefined$0 ? 1 : 0); + return _m_ ? caml_call1(f, x) : _m_; + } + function case$1(x, f, g){ + return x === undefined$0 ? caml_call1(f, 0) : caml_call1(g, x); + } + function get$0(x, f){return x === undefined$0 ? caml_call1(f, 0) : x;} + function option$0(x){ + if(! x) return undefined$0; + var x$0 = x[1]; + return x$0; + } + function to_option$0(x){return x === undefined$0 ? 0 : [0, x];} + var + Optdef = + [0, + undefined$0, + return$1, + map$0, + bind$0, + test$0, + iter$0, + case$1, + get$0, + option$0, + to_option$0]; + function coerce(x, f, g){ + var _l_ = caml_call1(f, x); + return caml_call2(Opt[8], _l_, function(param){return caml_call1(g, x);}); + } + function coerce_opt(x, f, g){ + var _k_ = caml_call2(Opt[4], x, f); + return caml_call2(Opt[8], _k_, function(param){return caml_call1(g, x);}); + } + var + true$0 = true, + false$0 = false, + nfc = "NFC", + nfd = "NFD", + nfkc = "NFKC", + nfkd = "NFKD", + t0 = Unsafe[1], + string_constr = t0.String, + t1 = Unsafe[1], + regExp = t1.RegExp, + t2 = Unsafe[1], + object_constructor = t2.Object; + function object_keys(t3){return object_constructor.keys(t3);} + var + t5 = Unsafe[1], + array_constructor = t5.Array, + array_get = caml_js_get, + array_set = caml_js_set; + function array_map(f, t7){ + var + cb = + caml_js_wrap_callback + (function(x, idx, param){return caml_call1(f, x);}); + return t7.map(cb); + } + function array_mapi(f, t7){ + var + cb = + caml_js_wrap_callback + (function(x, idx, param){return caml_call2(f, idx, x);}); + return t7.map(cb); + } + function str_array(_j_){return _j_;} + function match_result(_i_){return _i_;} + var + t8 = Unsafe[1], + date_constr = t8.Date, + t9 = Unsafe[1], + math = t9.Math, + t10 = Unsafe[1], + error_constr = t10.Error, + include = Jsoo_runtime[3], + raise = include[1], + exn_with_js_backtrace = include[2], + of_exn = include[3], + Error = include[4]; + function name(t11){return caml_string_of_jsstring(t11.name);} + function message(t12){return caml_string_of_jsstring(t12.message);} + function stack(t13){ + var _h_ = caml_call2(Opt[3], t13.stack, caml_string_of_jsstring); + return caml_call1(Opt[10], _h_); + } + function to_string(t14){return caml_string_of_jsstring(t14.toString());} + function raise_js_error(e){return caml_call1(raise, e);} + function string_of_error(e){return to_string(e);} + var + t15 = Unsafe[1], + JSON = t15.JSON, + cst_parseInt = cst_parseInt$0, + cst_parseFloat = cst_parseFloat$0; + function decodeURI(s){var t16 = Unsafe[1]; return t16.decodeURI(s);} + function decodeURIComponent(s){ + var t17 = Unsafe[1]; + return t17.decodeURIComponent(s); + } + function encodeURI(s){var t18 = Unsafe[1]; return t18.encodeURI(s);} + function encodeURIComponent(s){ + var t19 = Unsafe[1]; + return t19.encodeURIComponent(s); + } + function escape(s){var t20 = Unsafe[1]; return t20.escape(s);} + function unescape(s){var t21 = Unsafe[1]; return t21.unescape(s);} + function isNaN(i){var t22 = Unsafe[1]; return t22.isNaN(i) | 0;} + function parseInt(s){ + var t23 = Unsafe[1], s$0 = t23.parseInt(s); + return isNaN(s$0) ? caml_call1(Stdlib[2], cst_parseInt) : s$0; + } + function parseFloat(s){ + var t24 = Unsafe[1], s$0 = t24.parseFloat(s); + return isNaN(s$0) ? caml_call1(Stdlib[2], cst_parseFloat) : s$0; + } + caml_call1 + (Stdlib_Printexc[9], + function(param){ + if(param[1] !== Error) return 0; + var e = param[2]; + return [0, to_string(e)]; + }); + caml_call1 + (Stdlib_Printexc[9], + function(t25){ + return t25 instanceof array_constructor + ? 0 + : [0, caml_string_of_jsstring(t25.toString())]; + }); + var cst_function = "function"; + function export_js(field, x){ + var _f_ = caml_string_of_jsstring(typeof x); + a: + { + if + (caml_call2(Js_of_ocaml_Import[3][62], _f_, cst_function) + && 0 < x.length){ + var _g_ = caml_js_wrap_callback(x); + break a; + } + var _g_ = x; + } + return jsoo_exports[field] = _g_; + } + function export$0(field, x){ + return export_js(runtime.caml_jsstring_of_string(field), x); + } + function export_all(obj){ + var + keys = object_constructor.keys(obj), + t26 = + caml_js_wrap_callback + (function(key, param, _e_){return export_js(key, obj[key]);}); + return keys.forEach(t26); + } + var + Js_of_ocaml_Js = + [0, + null$0, + function(_d_){return _d_;}, + undefined$0, + function(_c_){return _c_;}, + Opt, + Optdef, + true$0, + false$0, + nfd, + nfc, + nfkd, + nfkc, + string_constr, + regExp, + regExp, + regExp, + object_keys, + array_constructor, + array_constructor, + array_get, + array_set, + array_map, + array_mapi, + str_array, + match_result, + date_constr, + date_constr, + date_constr, + date_constr, + date_constr, + date_constr, + date_constr, + date_constr, + date_constr, + math, + error_constr, + [0, + to_string, + name, + message, + stack, + raise, + exn_with_js_backtrace, + of_exn, + Error, + function(_b_){return _b_;}, + function(_a_){return _a_;}], + JSON, + decodeURI, + decodeURIComponent, + encodeURI, + encodeURIComponent, + escape, + unescape, + isNaN, + parseInt, + parseFloat, + coerce, + coerce_opt, + export$0, + export_all, + Unsafe, + string_of_error, + raise_js_error, + exn_with_js_backtrace, + runtime.caml_js_error_of_exception, + Error]; + runtime.caml_register_global(43, Js_of_ocaml_Js, "Js_of_ocaml__Js"); + return; + } + (globalThis)); + + +//# 1 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +// Generated by js_of_ocaml +//# 3 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" + +//# 24 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function(globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function decide(decision){return decision;} + function decide_rel(relDecision){return relDecision;} + function top(top0){return top0;} + function bottom(bottom0){return bottom0;} + var UIML_Base = [0, decide, decide_rel, top, bottom]; + runtime.caml_register_global(0, UIML_Base, "UIML__Base"); + return; + } + (globalThis)); + +//# 38 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function(globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime, coq_Top = [1, 0, 0]; + function coq_Neg(a){return [1, a, 0];} + function coq_And(a, b){return coq_Neg([1, a, coq_Neg(b)]);} + function coq_Or(a, b){return [1, coq_Neg(a), b];} + function coq_Diam(a){return coq_Neg([2, coq_Neg(a)]);} + function eq_dec_form(m, x0){ + var m$0 = m, x0$0 = x0; + for(;;){ + if(typeof m$0 === "number") return typeof x0$0 === "number" ? 1 : 0; + switch(m$0[0]){ + case 0: + var s = m$0[1]; + if(typeof x0$0 !== "number" && 0 === x0$0[0]){ + var + s0 = x0$0[1], + f = + function(s1, x1){ + if(! s1) return x1 ? 0 : 1; + var s2 = s1[2], a = s1[1]; + if(! x1) return 0; + var s3 = x1[2], a0 = x1[1]; + function h$0(i){return 0 !== (a & 1 << i) ? 1 : 0;} + var + b6 = h$0(7), + b5 = h$0(6), + b4 = h$0(5), + b3 = h$0(4), + b2 = h$0(3), + b1 = h$0(2), + b0 = h$0(1), + b = h$0(0); + function f$0(b7, b8, b9, b10, b11, b12, b13, b14){ + return b + ? b7 + ? b0 + ? b8 + ? b1 + ? b9 + ? b2 + ? b10 + ? b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b10 + ? 0 + : b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b9 + ? 0 + : b2 + ? b10 + ? b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b10 + ? 0 + : b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b8 + ? 0 + : b1 + ? b9 + ? b2 + ? b10 + ? b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b10 + ? 0 + : b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b9 + ? 0 + : b2 + ? b10 + ? b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b10 + ? 0 + : b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b7 + ? 0 + : b0 + ? b8 + ? b1 + ? b9 + ? b2 + ? b10 + ? b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b10 + ? 0 + : b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b9 + ? 0 + : b2 + ? b10 + ? b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b10 + ? 0 + : b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b8 + ? 0 + : b1 + ? b9 + ? b2 + ? b10 + ? b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b10 + ? 0 + : b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b9 + ? 0 + : b2 + ? b10 + ? b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b10 + ? 0 + : b3 + ? b11 + ? b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b11 + ? 0 + : b4 + ? b12 + ? b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) + : 0 + : b12 + ? 0 + : b5 + ? b13 ? b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3) : 0 + : b13 ? 0 : b6 ? b14 ? f(s2, s3) : 0 : b14 ? 0 : f(s2, s3); + } + function h(i){return 0 !== (a0 & 1 << i) ? 1 : 0;} + var + _b_ = h(7), + _c_ = h(6), + _d_ = h(5), + _e_ = h(4), + _f_ = h(3), + _g_ = h(2), + _h_ = h(1); + return f$0(h(0), _h_, _g_, _f_, _e_, _d_, _c_, _b_); + }; + return f(s, s0); + } + return 0; + case 1: + var m1 = m$0[2], m0 = m$0[1]; + if(typeof x0$0 !== "number" && 1 === x0$0[0]){ + var m3 = x0$0[2], m2 = x0$0[1]; + if(! eq_dec_form(m0, m2)) return 0; + m$0 = m1; + x0$0 = m3; + break; + } + return 0; + default: + var m0$0 = m$0[1]; + if(typeof x0$0 !== "number" && 2 === x0$0[0]){ + var m1$0 = x0$0[1]; + m$0 = m0$0; + x0$0 = m1$0; + break; + } + return 0; + } + } + } + function unBox_formula(x){ + if(typeof x !== "number" && 2 === x[0]){var a0 = x[1]; return a0;} + return x; + } + function unboxed_list(param){ + if(! param) return 0; + var t = param[2], h = param[1], _a_ = unboxed_list(t); + return [0, unBox_formula(h), _a_]; + } + function top_boxes(param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var t = param$0[2], h = param$0[1]; + if(typeof h !== "number" && 2 === h[0]){ + var a = h[1]; + return [0, [2, a], top_boxes(t)]; + } + param$0 = t; + } + } + var + UIML_CML_Syntax = + [0, + coq_Top, + coq_Neg, + coq_And, + coq_Or, + coq_Diam, + eq_dec_form, + unBox_formula, + unboxed_list, + top_boxes]; + runtime.caml_register_global(1, UIML_CML_Syntax, "UIML__CML_Syntax"); + return; + } + (globalThis)); + +//# 655 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function(globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function fst(param){var x = param[1]; return x;} + function snd(param){var y = param[2]; return y;} + function length(param){ + if(! param) return 0; + var l = param[2]; + return [0, length(l)]; + } + function app(l, m){ + if(! l) return m; + var l1 = l[2], a = l[1]; + return [0, a, app(l1, m)]; + } + var UIML_Datatypes = [0, fst, snd, length, app]; + runtime.caml_register_global(0, UIML_Datatypes, "UIML__Datatypes"); + return; + } + (globalThis)); + +//# 677 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function(globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function le_lt_dec(n, m){ + var n$0 = n, m$0 = m; + for(;;){ + if(! n$0) return 1; + var n0 = n$0[1]; + if(! m$0) return 0; + var n1 = m$0[1]; + n$0 = n0; + m$0 = n1; + } + } + function lt_dec(n, m){return le_lt_dec([0, n], m);} + var UIML_Compare_dec = [0, le_lt_dec, le_lt_dec, le_lt_dec, lt_dec]; + runtime.caml_register_global(0, UIML_Compare_dec, "UIML__Compare_dec"); + return; + } + (globalThis)); + +//# 699 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function(globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function add(n, m){if(! n) return m; var p = n[1]; return [0, add(p, m)];} + var UIML_Nat = [0, add]; + runtime.caml_register_global(0, UIML_Nat, "UIML__Nat"); + return; + } + (globalThis)); + +//# 710 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function(globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function string_dec(s, x){ + var s$0 = s, x$0 = x; + for(;;){ + if(! s$0) return x$0 ? 0 : 1; + var s0 = s$0[2], a = s$0[1]; + if(! x$0) return 0; + var s1 = x$0[2], a0 = x$0[1]; + if(! runtime.caml_equal(a, a0)) return 0; + s$0 = s0; + x$0 = s1; + } + } + var UIML_String = [0, string_dec]; + runtime.caml_register_global(0, UIML_String, "UIML__String"); + return; + } + (globalThis)); + +//# 733 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + form_top = [3, 0, 0], + UIML_Base = global_data.UIML__Base, + UIML_Nat = global_data.UIML__Nat, + UIML_String = global_data.UIML__String, + string_dec = UIML_String[1], + _a_ = [0, 0], + _b_ = [0, [0, 0]], + _c_ = [0, [0, [0, 0]]], + _d_ = [0, 0], + _e_ = [0, 0]; + function form_eq_dec(f, x0){ + var f$0 = f, x0$0 = x0; + for(;;){ + if(typeof f$0 === "number") return typeof x0$0 === "number" ? 1 : 0; + switch(f$0[0]){ + case 0: + var v = f$0[1]; + if(typeof x0$0 !== "number" && 0 === x0$0[0]){ + var v0 = x0$0[1]; + return caml_call3(UIML_Base[2], string_dec, v, v0); + } + return 0; + case 1: + var f1 = f$0[2], f0 = f$0[1]; + if(typeof x0$0 !== "number" && 1 === x0$0[0]){ + var f3 = x0$0[2], f2 = x0$0[1]; + if(! form_eq_dec(f0, f2)) return 0; + f$0 = f1; + x0$0 = f3; + break; + } + return 0; + case 2: + var f1$0 = f$0[2], f0$0 = f$0[1]; + if(typeof x0$0 !== "number" && 2 === x0$0[0]){ + var f3$0 = x0$0[2], f2$0 = x0$0[1]; + if(! form_eq_dec(f0$0, f2$0)) return 0; + f$0 = f1$0; + x0$0 = f3$0; + break; + } + return 0; + case 3: + var f1$1 = f$0[2], f0$1 = f$0[1]; + if(typeof x0$0 !== "number" && 3 === x0$0[0]){ + var f3$1 = x0$0[2], f2$1 = x0$0[1]; + if(! form_eq_dec(f0$1, f2$1)) return 0; + f$0 = f1$1; + x0$0 = f3$1; + break; + } + return 0; + default: + var f0$2 = f$0[1]; + if(typeof x0$0 !== "number" && 4 === x0$0[0]){ + var f1$2 = x0$0[1]; + f$0 = f0$2; + x0$0 = f1$2; + break; + } + return 0; + } + } + } + function weight(param){ + if(typeof param !== "number") + switch(param[0]){ + case 1: + var + UU03c8 = param[2], + UU03c6_0 = param[1], + _f_ = weight(UU03c8), + _g_ = weight(UU03c6_0), + _h_ = caml_call2(UIML_Nat[1], _b_, _g_); + return caml_call2(UIML_Nat[1], _h_, _f_); + case 2: + var + UU03c8$0 = param[2], + UU03c6_0$0 = param[1], + _i_ = weight(UU03c8$0), + _j_ = weight(UU03c6_0$0), + _k_ = caml_call2(UIML_Nat[1], _c_, _j_); + return caml_call2(UIML_Nat[1], _k_, _i_); + case 3: + var + UU03c8$1 = param[2], + UU03c6_0$1 = param[1], + _l_ = weight(UU03c8$1), + _m_ = weight(UU03c6_0$1), + _n_ = caml_call2(UIML_Nat[1], _d_, _m_); + return caml_call2(UIML_Nat[1], _n_, _l_); + case 4: + var UU03c6_0$2 = param[1], _o_ = weight(UU03c6_0$2); + return caml_call2(UIML_Nat[1], _e_, _o_); + } + return _a_; + } + var UIML_Formulas = [0, 0, form_top, string_dec, form_eq_dec, weight]; + runtime.caml_register_global(9, UIML_Formulas, "UIML__Formulas"); + return; + } + (globalThis)); + +//# 853 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function(globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function in_dec(h, a, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var l0 = param$0[2], y = param$0[1], s = caml_call2(h, y, a); + if(s) return 1; + param$0 = l0; + } + } + function remove(eq_dec, x, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var tl = param$0[2], y = param$0[1]; + if(! caml_call2(eq_dec, x, y)) return [0, y, remove(eq_dec, x, tl)]; + param$0 = tl; + } + } + function list_eq_dec(eq_dec, l$0, l){ + var l$2 = l$0, l$1 = l; + for(;;){ + if(! l$2) return l$1 ? 0 : 1; + var l0 = l$2[2], y = l$2[1]; + if(! l$1) return 0; + var l1 = l$1[2], a = l$1[1]; + if(! caml_call2(eq_dec, y, a)) return 0; + l$2 = l0; + l$1 = l1; + } + } + function map(f, param){ + if(! param) return 0; + var t = param[2], a = param[1], _a_ = map(f, t); + return [0, caml_call1(f, a), _a_]; + } + function nodup(decA, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var xs = param$0[2], x = param$0[1]; + if(! in_dec(decA, x, xs)) return [0, x, nodup(decA, xs)]; + param$0 = xs; + } + } + var UIML_List = [0, in_dec, remove, list_eq_dec, map, nodup]; + runtime.caml_register_global(0, UIML_List, "UIML__List"); + return; + } + (globalThis)); + +//# 918 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_Base = global_data.UIML__Base; + function foldl(f, a, param){ + var a$0 = a, param$0 = param; + for(;;){ + if(! param$0) return a$0; + var l0 = param$0[2], x = param$0[1], a$1 = caml_call2(f, a$0, x); + a$0 = a$1; + param$0 = l0; + } + } + function elem_of_list_dec(dec, x, param){ + var param$0 = param; + for(;;){ + if(! param$0) return 0; + var + l0 = param$0[2], + y = param$0[1], + _a_ = caml_call3(UIML_Base[2], dec, x, y); + if(caml_call1(UIML_Base[1], _a_)) return 1; + param$0 = l0; + } + } + var UIML_List0 = [0, foldl, elem_of_list_dec]; + runtime.caml_register_global(1, UIML_List0, "UIML__List0"); + return; + } + (globalThis)); + +//# 968 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function(globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function comparison_eq_dec(x, y){ + switch(x){ + case 0: + return y ? 0 : 1; + case 1: + return 1 === y ? 1 : 0; + default: return 2 <= y ? 1 : 0; + } + } + var UIML_Numbers = [0, comparison_eq_dec]; + runtime.caml_register_global(0, UIML_Numbers, "UIML__Numbers"); + return; + } + (globalThis)); + +//# 988 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_Formulas = global_data.UIML__Formulas, + UIML_Base = global_data.UIML__Base, + UIML_Numbers = global_data.UIML__Numbers, + UIML_List = global_data.UIML__List, + UIML_List0 = global_data.UIML__List0, + _a_ = [3, 0, 0], + _b_ = [3, 0, 0], + _c_ = [3, 0, 0], + _d_ = [3, 0, 0], + _e_ = [3, 0, 0], + _f_ = [3, 0, 0]; + function symbol(param){return symbol;} + function decidable_is_implication(UU03c6, UU03c8){ + if(typeof UU03c6 !== "number" && 3 === UU03c6[0]){ + var + f = UU03c6[2], + _aE_ = caml_call3(UIML_Base[2], UIML_Formulas[4], f, UU03c8); + return caml_call1(UIML_Base[1], _aE_); + } + return 0; + } + function decidable_is_negation(UU03c6, UU03c8){ + var + _aD_ = caml_call3(UIML_Base[2], UIML_Formulas[4], UU03c6, [3, UU03c8, 0]); + return caml_call1(UIML_Base[1], _aD_); + } + function obviously_smaller(UU03c6, UU03c8){ + if(typeof UU03c6 === "number") return 1; + switch(UU03c6[0]){ + case 0: + if(typeof UU03c8 === "number") return 2; + if(3 === UU03c8[0]){ + var f = UU03c8[1]; + if(typeof f === "number") return 1; + var _M_ = caml_call3(UIML_Base[2], UIML_Formulas[4], UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _M_)) return 1; + var _N_ = decidable_is_negation(UU03c6, [3, UU03c8, 0]); + if(caml_call1(UIML_Base[1], _N_)) return 2; + var _O_ = decidable_is_negation(UU03c8, [3, UU03c6, 0]); + if(caml_call1(UIML_Base[1], _O_)) return 1; + var _P_ = decidable_is_implication(UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _P_)) return 2; + var _Q_ = decidable_is_implication(UU03c8, UU03c6); + return caml_call1(UIML_Base[1], _Q_) ? 1 : 0; + } + var _H_ = caml_call3(UIML_Base[2], UIML_Formulas[4], UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _H_)) return 1; + var _I_ = decidable_is_negation(UU03c6, [3, UU03c8, 0]); + if(caml_call1(UIML_Base[1], _I_)) return 2; + var _J_ = decidable_is_negation(UU03c8, [3, UU03c6, 0]); + if(caml_call1(UIML_Base[1], _J_)) return 1; + var _K_ = decidable_is_implication(UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _K_)) return 2; + var _L_ = decidable_is_implication(UU03c8, UU03c6); + return caml_call1(UIML_Base[1], _L_) ? 1 : 0; + case 1: + var UU03c8_0 = UU03c6[2], UU03c6_0 = UU03c6[1]; + if(typeof UU03c8 === "number") return 2; + if(3 !== UU03c8[0]){ + var + c = obviously_smaller(UU03c6_0, UU03c8), + c0 = obviously_smaller(UU03c8_0, UU03c8); + switch(c){ + case 0: + return 1 === c0 ? 1 : 0; + case 1: + return 1; + default: return c0; + } + } + var f$0 = UU03c8[1]; + if(typeof f$0 === "number") return 1; + var + c$0 = obviously_smaller(UU03c6_0, UU03c8), + c0$0 = obviously_smaller(UU03c8_0, UU03c8); + switch(c$0){ + case 0: + return 1 === c0$0 ? 1 : 0; + case 1: + return 1; + default: return c0$0; + } + case 2: + var UU03c8_0$0 = UU03c6[2], UU03c6_0$0 = UU03c6[1]; + if(typeof UU03c8 === "number") return 2; + if(3 !== UU03c8[0]){ + var + c$1 = obviously_smaller(UU03c6_0$0, UU03c8), + c0$1 = obviously_smaller(UU03c8_0$0, UU03c8); + switch(c$1){ + case 0: + return 2 <= c0$1 ? 2 : 0; + case 1: + return c0$1; + default: return 2; + } + } + var f$1 = UU03c8[1]; + if(typeof f$1 === "number") return 1; + var + c$2 = obviously_smaller(UU03c6_0$0, UU03c8), + c0$2 = obviously_smaller(UU03c8_0$0, UU03c8); + switch(c$2){ + case 0: + return 2 <= c0$2 ? 2 : 0; + case 1: + return c0$2; + default: return 2; + } + case 3: + var f$2 = UU03c6[1]; + if(typeof f$2 === "number") return 2; + switch(f$2[0]){ + case 0: + if(typeof UU03c8 === "number") return 2; + if(3 === UU03c8[0]){ + var f1 = UU03c8[1]; + if(typeof f1 === "number") return 1; + var + _W_ = caml_call3(UIML_Base[2], UIML_Formulas[4], UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _W_)) return 1; + var _X_ = decidable_is_negation(UU03c6, [3, UU03c8, 0]); + if(caml_call1(UIML_Base[1], _X_)) return 2; + var _Y_ = decidable_is_negation(UU03c8, [3, UU03c6, 0]); + if(caml_call1(UIML_Base[1], _Y_)) return 1; + var _Z_ = decidable_is_implication(UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _Z_)) return 2; + var ___ = decidable_is_implication(UU03c8, UU03c6); + return caml_call1(UIML_Base[1], ___) ? 1 : 0; + } + var + _R_ = caml_call3(UIML_Base[2], UIML_Formulas[4], UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _R_)) return 1; + var _S_ = decidable_is_negation(UU03c6, [3, UU03c8, 0]); + if(caml_call1(UIML_Base[1], _S_)) return 2; + var _T_ = decidable_is_negation(UU03c8, [3, UU03c6, 0]); + if(caml_call1(UIML_Base[1], _T_)) return 1; + var _U_ = decidable_is_implication(UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _U_)) return 2; + var _V_ = decidable_is_implication(UU03c8, UU03c6); + return caml_call1(UIML_Base[1], _V_) ? 1 : 0; + case 4: + if(typeof UU03c8 === "number") return 2; + if(3 === UU03c8[0]){ + var f2 = UU03c8[1]; + if(typeof f2 === "number") return 1; + var + _ao_ = caml_call3(UIML_Base[2], UIML_Formulas[4], UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _ao_)) return 1; + var _ap_ = decidable_is_negation(UU03c6, [3, UU03c8, 0]); + if(caml_call1(UIML_Base[1], _ap_)) return 2; + var _aq_ = decidable_is_negation(UU03c8, [3, UU03c6, 0]); + if(caml_call1(UIML_Base[1], _aq_)) return 1; + var _ar_ = decidable_is_implication(UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _ar_)) return 2; + var _as_ = decidable_is_implication(UU03c8, UU03c6); + return caml_call1(UIML_Base[1], _as_) ? 1 : 0; + } + var + _aj_ = caml_call3(UIML_Base[2], UIML_Formulas[4], UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _aj_)) return 1; + var _ak_ = decidable_is_negation(UU03c6, [3, UU03c8, 0]); + if(caml_call1(UIML_Base[1], _ak_)) return 2; + var _al_ = decidable_is_negation(UU03c8, [3, UU03c6, 0]); + if(caml_call1(UIML_Base[1], _al_)) return 1; + var _am_ = decidable_is_implication(UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _am_)) return 2; + var _an_ = decidable_is_implication(UU03c8, UU03c6); + return caml_call1(UIML_Base[1], _an_) ? 1 : 0; + default: + if(typeof UU03c8 === "number") return 2; + if(3 === UU03c8[0]){ + var f3 = UU03c8[1]; + if(typeof f3 === "number") return 1; + var + _ae_ = caml_call3(UIML_Base[2], UIML_Formulas[4], UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _ae_)) return 1; + var _af_ = decidable_is_negation(UU03c6, [3, UU03c8, 0]); + if(caml_call1(UIML_Base[1], _af_)) return 2; + var _ag_ = decidable_is_negation(UU03c8, [3, UU03c6, 0]); + if(caml_call1(UIML_Base[1], _ag_)) return 1; + var _ah_ = decidable_is_implication(UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _ah_)) return 2; + var _ai_ = decidable_is_implication(UU03c8, UU03c6); + return caml_call1(UIML_Base[1], _ai_) ? 1 : 0; + } + var + _$_ = caml_call3(UIML_Base[2], UIML_Formulas[4], UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _$_)) return 1; + var _aa_ = decidable_is_negation(UU03c6, [3, UU03c8, 0]); + if(caml_call1(UIML_Base[1], _aa_)) return 2; + var _ab_ = decidable_is_negation(UU03c8, [3, UU03c6, 0]); + if(caml_call1(UIML_Base[1], _ab_)) return 1; + var _ac_ = decidable_is_implication(UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _ac_)) return 2; + var _ad_ = decidable_is_implication(UU03c8, UU03c6); + return caml_call1(UIML_Base[1], _ad_) ? 1 : 0; + } + default: + if(typeof UU03c8 === "number") return 2; + if(3 === UU03c8[0]){ + var f0 = UU03c8[1]; + if(typeof f0 === "number") return 1; + var _ay_ = caml_call3(UIML_Base[2], UIML_Formulas[4], UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _ay_)) return 1; + var _az_ = decidable_is_negation(UU03c6, [3, UU03c8, 0]); + if(caml_call1(UIML_Base[1], _az_)) return 2; + var _aA_ = decidable_is_negation(UU03c8, [3, UU03c6, 0]); + if(caml_call1(UIML_Base[1], _aA_)) return 1; + var _aB_ = decidable_is_implication(UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _aB_)) return 2; + var _aC_ = decidable_is_implication(UU03c8, UU03c6); + return caml_call1(UIML_Base[1], _aC_) ? 1 : 0; + } + var _at_ = caml_call3(UIML_Base[2], UIML_Formulas[4], UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _at_)) return 1; + var _au_ = decidable_is_negation(UU03c6, [3, UU03c8, 0]); + if(caml_call1(UIML_Base[1], _au_)) return 2; + var _av_ = decidable_is_negation(UU03c8, [3, UU03c6, 0]); + if(caml_call1(UIML_Base[1], _av_)) return 1; + var _aw_ = decidable_is_implication(UU03c6, UU03c8); + if(caml_call1(UIML_Base[1], _aw_)) return 2; + var _ax_ = decidable_is_implication(UU03c8, UU03c6); + return caml_call1(UIML_Base[1], _ax_) ? 1 : 0; + } + } + function choose_conj(UU03c6, UU03c8){ + switch(obviously_smaller(UU03c6, UU03c8)){ + case 0: + return [1, UU03c6, UU03c8]; + case 1: + return UU03c6; + default: return UU03c8; + } + } + function make_conj(UU03c6, UU03c8){ + if(typeof UU03c8 !== "number") + switch(UU03c8[0]){ + case 1: + var UU03c8_2 = UU03c8[2], UU03c8_1 = UU03c8[1]; + switch(obviously_smaller(UU03c6, UU03c8_1)){ + case 0: + return [1, UU03c6, [1, UU03c8_1, UU03c8_2]]; + case 1: + return [1, UU03c6, UU03c8_2]; + default: return [1, UU03c8_1, UU03c8_2]; + } + case 2: + var + UU03c8_2$0 = UU03c8[2], + UU03c8_1$0 = UU03c8[1], + _B_ = obviously_smaller(UU03c6, UU03c8_1$0), + _C_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _B_, 1); + if(caml_call1(UIML_Base[1], _C_)) return UU03c6; + var + _D_ = obviously_smaller(UU03c6, UU03c8_2$0), + _E_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _D_, 1); + return caml_call1(UIML_Base[1], _E_) + ? UU03c6 + : choose_conj(UU03c6, [2, UU03c8_1$0, UU03c8_2$0]); + case 3: + var + UU03c8_2$1 = UU03c8[2], + UU03c8_1$1 = UU03c8[1], + _F_ = obviously_smaller(UU03c6, UU03c8_1$1), + _G_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _F_, 1); + return caml_call1(UIML_Base[1], _G_) + ? choose_conj(UU03c6, UU03c8_2$1) + : choose_conj(UU03c6, UU03c8); + } + if(typeof UU03c6 !== "number" && 3 === UU03c6[0]){ + var + UU03c6_2 = UU03c6[2], + UU03c6_1 = UU03c6[1], + _z_ = obviously_smaller(UU03c8, UU03c6_1), + _A_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _z_, 1); + return caml_call1(UIML_Base[1], _A_) + ? choose_conj(UU03c6_2, UU03c8) + : choose_conj(UU03c6, UU03c8); + } + return choose_conj(UU03c6, UU03c8); + } + function choose_disj(UU03c6, UU03c8){ + switch(obviously_smaller(UU03c6, UU03c8)){ + case 0: + switch(obviously_smaller(UU03c8, UU03c6)){ + case 0: + return [2, UU03c6, UU03c8]; + case 1: + return UU03c6; + default: return UU03c8; + } + case 1: + return UU03c8; + default: return UU03c6; + } + } + function make_disj(UU03c6, UU03c8){ + if(typeof UU03c8 !== "number") + switch(UU03c8[0]){ + case 1: + var + UU03c8_2 = UU03c8[2], + UU03c8_1 = UU03c8[1], + _v_ = obviously_smaller(UU03c6, UU03c8_1), + _w_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _v_, 2); + if(caml_call1(UIML_Base[1], _w_)) return UU03c6; + var + _x_ = obviously_smaller(UU03c6, UU03c8_2), + _y_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _x_, 2); + return caml_call1(UIML_Base[1], _y_) + ? UU03c6 + : choose_disj(UU03c6, [1, UU03c8_1, UU03c8_2]); + case 2: + var UU03c8_2$0 = UU03c8[2], UU03c8_1$0 = UU03c8[1]; + switch(obviously_smaller(UU03c6, UU03c8_1$0)){ + case 0: + return [2, UU03c6, [2, UU03c8_1$0, UU03c8_2$0]]; + case 1: + return [2, UU03c8_1$0, UU03c8_2$0]; + default: return [2, UU03c6, UU03c8_2$0]; + } + } + return choose_disj(UU03c6, UU03c8); + } + function make_impl(UU03c6, UU03c8){ + var UU03c6$0 = UU03c6, UU03c8$0 = UU03c8; + for(;;){ + if(typeof UU03c8$0 !== "number" && 3 === UU03c8$0[0]){ + var + UU03c8_2 = UU03c8$0[2], + UU03c8_1 = UU03c8$0[1], + UU03c6$1 = make_conj(UU03c6$0, UU03c8_1); + UU03c6$0 = UU03c6$1; + UU03c8$0 = UU03c8_2; + continue; + } + var + _j_ = obviously_smaller(UU03c6$0, UU03c8$0), + _k_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _j_, 1); + if(caml_call1(UIML_Base[1], _k_)) return _a_; + var + _l_ = obviously_smaller(UU03c6$0, 0), + _m_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _l_, 1); + if(caml_call1(UIML_Base[1], _m_)) return _b_; + var + _n_ = obviously_smaller(UU03c8$0, _c_), + _o_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _n_, 2); + if(caml_call1(UIML_Base[1], _o_)) return _d_; + var + _p_ = obviously_smaller(UU03c6$0, _e_), + _q_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _p_, 2); + if(caml_call1(UIML_Base[1], _q_)) return UU03c8$0; + var + _r_ = obviously_smaller(UU03c8$0, 0), + _s_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _r_, 1); + if(caml_call1(UIML_Base[1], _s_)) return [3, UU03c6$0, 0]; + var _t_ = decidable_is_negation(UU03c6$0, UU03c8$0); + if(caml_call1(UIML_Base[1], _t_)) return [3, UU03c6$0, 0]; + var _u_ = decidable_is_negation(UU03c8$0, UU03c6$0); + return caml_call1(UIML_Base[1], _u_) ? UU03c8$0 : [3, UU03c6$0, UU03c8$0]; + } + } + function conjunction(l){ + var _i_ = caml_call2(UIML_List[5], UIML_Formulas[4], l); + return caml_call3(UIML_List0[1], make_conj, _f_, _i_); + } + function disjunction(l){ + var _h_ = caml_call2(UIML_List[5], UIML_Formulas[4], l); + return caml_call3(UIML_List0[1], make_disj, 0, _h_); + } + function in_map_aux(UU0393, f, param){ + if(! param) return 0; + var + UU0393_0 = param[2], + a = param[1], + _g_ = in_map_aux(UU0393, f, UU0393_0); + return [0, caml_call2(f, a, symbol), _g_]; + } + function in_map(UU0393, f){return in_map_aux(UU0393, f, UU0393);} + function rm(x, param){ + if(! param) return 0; + var t = param[2], h = param[1]; + return caml_call2(UIML_Formulas[4], x, h) ? t : [0, h, rm(x, t)]; + } + function open_box(UU03c6){ + if(typeof UU03c6 !== "number" && 4 === UU03c6[0]){var UU03c6_0 = UU03c6[1]; return UU03c6_0;} + return UU03c6; + } + var + UIML_Environments = + [0, + decidable_is_implication, + decidable_is_negation, + obviously_smaller, + choose_conj, + make_conj, + choose_disj, + make_disj, + make_impl, + conjunction, + disjunction, + in_map_aux, + in_map, + rm, + open_box]; + runtime.caml_register_global(11, UIML_Environments, "UIML__Environments"); + return; + } + (globalThis)); + +//# 1422 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_CML_Syntax = global_data.UIML__CML_Syntax; + function coq_XBoxed_list(param){ + if(! param) return 0; + var t = param[2], h = param[1], _a_ = [0, h, coq_XBoxed_list(t)]; + return [0, caml_call1(UIML_CML_Syntax[7], h), _a_]; + } + var UIML_GLS_calcs = [0, coq_XBoxed_list]; + runtime.caml_register_global(1, UIML_GLS_calcs, "UIML__GLS_calcs"); + return; + } + (globalThis)); + +//# 1446 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function(globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function coq_InT_eq(a, l){return [0, a, l];} + var UIML_GenT = [0, coq_InT_eq]; + runtime.caml_register_global(0, UIML_GenT, "UIML__GenT"); + return; + } + (globalThis)); + +//# 1467 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace; + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_GenT = global_data.UIML__GenT, + UIML_Datatypes = global_data.UIML__Datatypes, + Assert_failure = global_data.Assert_failure, + _a_ = [0, "extraction/List_lemmasT.ml", 28, 20]; + function coq_InT_app_or(l, l2, a, x){ + if(! l) return [1, x]; + var l0 = l[2], y = l[1]; + if(0 === x[0]) return [0, caml_call2(UIML_GenT[1], y, l0)]; + var i = x[3], x0 = coq_InT_app_or(l0, l2, a, i); + if(0 === x0[0]){var i0 = x0[1]; return [0, [1, y, l0, i0]];} + var i0$0 = x0[1]; + return [1, i0$0]; + } + function coq_InT_or_app(l, l2, a, x){ + if(! l){ + if(0 === x[0]) + throw caml_maybe_attach_backtrace([0, Assert_failure, _a_], 1); + var i$1 = x[1]; + return i$1; + } + var l0 = l[2], y = l[1]; + if(0 !== x[0]){ + var i$0 = x[1], _d_ = coq_InT_or_app(l0, l2, a, [1, i$0]); + return [1, y, caml_call2(UIML_Datatypes[4], l0, l2), _d_]; + } + var i = x[1]; + if(0 === i[0]){ + var + app0 = + function(l1, m){ + if(! l1) return m; + var l3 = l1[2], a0 = l1[1]; + return [0, a0, app0(l3, m)]; + }, + _b_ = app0(l0, l2); + return caml_call2(UIML_GenT[1], y, _b_); + } + var i0 = i[3], _c_ = coq_InT_or_app(l0, l2, a, [0, i0]); + return [1, y, caml_call2(UIML_Datatypes[4], l0, l2), _c_]; + } + var UIML_List_lemmasT = [0, coq_InT_app_or, coq_InT_or_app]; + runtime.caml_register_global(4, UIML_List_lemmasT, "UIML__List_lemmasT"); + return; + } + (globalThis)); + +//# 1537 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_extraction_list_lems_ml = "extraction/list_lems.ml", + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call4(f, a0, a1, a2, a3){ + return (f.l >= 0 ? f.l : f.l = f.length) == 4 + ? f(a0, a1, a2, a3) + : runtime.caml_call_gen(f, [a0, a1, a2, a3]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_CML_Syntax = global_data.UIML__CML_Syntax, + UIML_Datatypes = global_data.UIML__Datatypes, + Assert_failure = global_data.Assert_failure, + UIML_GenT = global_data.UIML__GenT, + UIML_List_lemmasT = global_data.UIML__List_lemmasT, + UIML_List = global_data.UIML__List, + _a_ = [0, cst_extraction_list_lems_ml, 17, 8]; + function symbol(param){return symbol;} + function in_splitT(x, param){ + if(! param) + throw caml_maybe_attach_backtrace([0, Assert_failure, _a_], 1); + var l0 = param[2], y = param[1], s = caml_call2(UIML_CML_Syntax[6], x, y); + if(s) return [0, 0, [0, l0, symbol]]; + var h0 = in_splitT(x, l0), s0 = h0[2], x0 = h0[1], x1 = s0[1]; + return [0, caml_call2(UIML_Datatypes[4], [0, y, 0], x0), [0, x1, symbol]]; + } + var + eq_dec_listsF = caml_call1(UIML_List[3], UIML_CML_Syntax[6]), + _b_ = [0, cst_extraction_list_lems_ml, 44, 8], + _c_ = [0, cst_extraction_list_lems_ml, 59, 8]; + function eq_dec_seqs(s0, s1){ + var + l0 = s0[2], + l = s0[1], + l2 = s1[2], + l1 = s1[1], + s = caml_call2(eq_dec_listsF, l, l1); + return s ? caml_call2(eq_dec_listsF, l0, l2) : 0; + } + function seqs_in_splitT(x, param){ + if(! param) + throw caml_maybe_attach_backtrace([0, Assert_failure, _b_], 1); + var l0 = param[2], y = param[1], s = eq_dec_seqs(x, y); + if(s) return [0, 0, [0, l0, symbol]]; + var h0 = seqs_in_splitT(x, l0), s0 = h0[2], x0 = h0[1], x1 = s0[1]; + return [0, caml_call2(UIML_Datatypes[4], [0, y, 0], x0), [0, x1, symbol]]; + } + function coq_In_InT_seqs(seq, param){ + if(! param) + throw caml_maybe_attach_backtrace([0, Assert_failure, _c_], 1); + var + l = param[2], + y = param[1], + h = seqs_in_splitT(seq, [0, y, l]), + s = h[2], + x = h[1], + x0 = s[1], + _d_ = [1, caml_call2(UIML_GenT[1], seq, x0)]; + return caml_call4(UIML_List_lemmasT[2], x, [0, seq, x0], seq, _d_); + } + var + UIML_List_lems = + [0, + in_splitT, + eq_dec_listsF, + eq_dec_seqs, + seqs_in_splitT, + coq_In_InT_seqs]; + runtime.caml_register_global(9, UIML_List_lems, "UIML__List_lems"); + return; + } + (globalThis)); + +//# 1626 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_CML_Syntax = global_data.UIML__CML_Syntax, + UIML_List = global_data.UIML__List; + function coq_In_dec(l, a){ + return caml_call3(UIML_List[1], UIML_CML_Syntax[6], a, l); + } + function remove_list(l1, l2){ + if(! l1) return l2; + var t1 = l1[2], h1 = l1[1], _a_ = remove_list(t1, l2); + return caml_call3(UIML_List[2], UIML_CML_Syntax[6], h1, _a_); + } + var UIML_Remove_list_lems = [0, coq_In_dec, remove_list]; + runtime.caml_register_global + (2, UIML_Remove_list_lems, "UIML__Remove_list_lems"); + return; + } + (globalThis)); + +//# 1656 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_List_lems = global_data.UIML__List_lems, + UIML_Remove_list_lems = global_data.UIML__Remove_list_lems, + UIML_Datatypes = global_data.UIML__Datatypes; + function symbol(param){return symbol;} + function dec_prop_var_in(param){ + var l0 = param[2], l = param[1]; + function f(param){ + if(! param) return [1, symbol]; + var l2 = param[2], y = param[1], match = f(l2); + if(0 === match[0]){ + var s0 = match[1], x = s0[1]; + return [0, [0, x, symbol]]; + } + if(typeof y !== "number" && 0 === y[0]){ + var + s0$0 = y[1], + s1 = caml_call2(UIML_Remove_list_lems[1], l0, [0, s0$0]); + return s1 ? [0, [0, s0$0, symbol]] : [1, symbol]; + } + return [1, symbol]; + } + return f(l); + } + function dec_is_box(param){ + if(typeof param !== "number" && 2 === param[0]){var m = param[1]; return [0, [0, m, symbol]];} + return [1, symbol]; + } + function dec_box_in(param){ + var l0 = param[2], l = param[1]; + function f(param){ + if(! param) return [1, symbol]; + var l2 = param[2], y = param[1], match = f(l2); + if(0 === match[0]){ + var s0 = match[1], x = s0[1]; + return [0, [0, x, symbol]]; + } + var s0$0 = dec_is_box(y); + if(0 !== s0$0[0]) return [1, symbol]; + var s1 = s0$0[1], s2 = caml_call2(UIML_Remove_list_lems[1], l0, y); + if(! s2) return [1, symbol]; + var x$0 = s1[1]; + return [0, [0, x$0, symbol]]; + } + return f(l); + } + function dec_init_rules(param){ + var l0 = param[2], l = param[1], s0 = dec_prop_var_in([0, l, l0]); + if(0 === s0[0]){ + var + s1 = s0[1], + x = s1[1], + h = caml_call2(UIML_List_lems[1], [0, x], l), + s2 = h[2], + x0 = h[1], + x1 = s2[1], + h0 = caml_call2(UIML_List_lems[1], [0, x], l0), + s3 = h0[2], + x2 = h0[1], + x3 = s3[1]; + return [0, [0, [0, [0, x, x0, x1, x2, x3]]]]; + } + var s1$0 = caml_call2(UIML_Remove_list_lems[1], l, 0); + if(s1$0){ + var + i = caml_call2(UIML_List_lems[1], 0, l), + s2$0 = i[2], + x$0 = i[1], + x0$0 = s2$0[1]; + return [0, [1, [0, x$0, x0$0, l0]]]; + } + var s2$1 = dec_box_in([0, l, l0]); + if(0 !== s2$1[0]) return [1, symbol]; + var + s3$0 = s2$1[1], + x$1 = s3$0[1], + _a_ = caml_call1(UIML_Datatypes[1], [0, l, l0]), + h$0 = caml_call2(UIML_List_lems[1], [2, x$1], _a_), + s4 = h$0[2], + x0$1 = h$0[1], + x1$0 = s4[1], + _b_ = caml_call1(UIML_Datatypes[2], [0, l, l0]), + h0$0 = caml_call2(UIML_List_lems[1], [2, x$1], _b_), + s5 = h0$0[2], + x2$0 = h0$0[1], + x3$0 = s5[1]; + return [0, [0, [1, [0, x$1, x0$1, x1$0, x2$0, x3$0]]]]; + } + var + UIML_GLS_dec = + [0, dec_prop_var_in, dec_is_box, dec_box_in, dec_init_rules]; + runtime.caml_register_global(3, UIML_GLS_dec, "UIML__GLS_dec"); + return; + } + (globalThis)); + +//# 1768 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function(globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function eq_dec(n, m){ + var n$0 = n, m$0 = m; + for(;;){ + if(! n$0) return m$0 ? 0 : 1; + var n0 = n$0[1]; + if(! m$0) return 0; + var n1 = m$0[1]; + n$0 = n0; + m$0 = n1; + } + } + var Nat = [0, eq_dec], UIML_PeanoNat = [0, Nat]; + runtime.caml_register_global(0, UIML_PeanoNat, "UIML__PeanoNat"); + return; + } + (globalThis)); + +//# 1790 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_extraction_GLS_der_dec_ml = "extraction/GLS_der_dec.ml", + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call4(f, a0, a1, a2, a3){ + return (f.l >= 0 ? f.l : f.l = f.length) == 4 + ? f(a0, a1, a2, a3) + : runtime.caml_call_gen(f, [a0, a1, a2, a3]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_CML_Syntax = global_data.UIML__CML_Syntax, + UIML_PeanoNat = global_data.UIML__PeanoNat, + UIML_GenT = global_data.UIML__GenT, + Assert_failure = global_data.Assert_failure, + UIML_List = global_data.UIML__List, + UIML_Datatypes = global_data.UIML__Datatypes, + UIML_List_lemmasT = global_data.UIML__List_lemmasT, + UIML_GLS_calcs = global_data.UIML__GLS_calcs, + UIML_List_lems = global_data.UIML__List_lems, + _a_ = [0, cst_extraction_GLS_der_dec_ml, 29, 8], + _b_ = [0, cst_extraction_GLS_der_dec_ml, 46, 4], + _c_ = [0, cst_extraction_GLS_der_dec_ml, 45, 23], + _d_ = [0, 0], + _e_ = [0, cst_extraction_GLS_der_dec_ml, 105, 10], + _f_ = [0, cst_extraction_GLS_der_dec_ml, 122, 10], + _g_ = [0, [0, 0, 0], 0], + _h_ = [0, 0, 0], + _i_ = [0, 0, 0], + _j_ = [0, cst_extraction_GLS_der_dec_ml, 238, 15], + _k_ = [0, 0], + _l_ = [0, cst_extraction_GLS_der_dec_ml, 230, 18], + _m_ = [0, cst_extraction_GLS_der_dec_ml, 218, 10], + _n_ = [0, cst_extraction_GLS_der_dec_ml, 254, 12], + _o_ = [0, cst_extraction_GLS_der_dec_ml, 522, 28], + _p_ = [0, cst_extraction_GLS_der_dec_ml, 428, 18], + _q_ = [0, cst_extraction_GLS_der_dec_ml, 407, 10], + _r_ = [0, cst_extraction_GLS_der_dec_ml, 931, 28], + _s_ = [0, cst_extraction_GLS_der_dec_ml, 839, 23], + _t_ = [0, cst_extraction_GLS_der_dec_ml, 665, 10], + _u_ = [0, cst_extraction_GLS_der_dec_ml, 1200, 40], + _v_ = [0, cst_extraction_GLS_der_dec_ml, 955, 12], + _w_ = [0, cst_extraction_GLS_der_dec_ml, 1291, 10], + _x_ = [0, cst_extraction_GLS_der_dec_ml, 1361, 28], + _y_ = [0, cst_extraction_GLS_der_dec_ml, 1325, 10]; + function symbol(param){return symbol;} + function proj1_sigT2(param){var a = param[1]; return a;} + function proj2_sigT2(param){var b = param[2]; return b;} + function coq_In_InT_pair(a, n, param){ + if(! param) + throw caml_maybe_attach_backtrace([0, Assert_failure, _a_], 1); + var + l0 = param[2], + y = param[1], + n0 = y[2], + m = y[1], + s = caml_call2(UIML_CML_Syntax[6], a, m), + h0 = s ? caml_call2(UIML_PeanoNat[1][1], n, n0) : 0; + return h0 + ? caml_call2(UIML_GenT[1], [0, a, n], l0) + : [1, y, l0, coq_In_InT_pair(a, n, l0)]; + } + function coq_InT_map_iff(f, param){ + if(! param) + return function(param){ + return [0, + function(param){ + throw caml_maybe_attach_backtrace([0, Assert_failure, _c_], 1); + }, + function(param){ + throw caml_maybe_attach_backtrace([0, Assert_failure, _b_], 1); + }];}; + var l0 = param[2], y = param[1], iHl = coq_InT_map_iff(f, l0); + return function(y0){ + return [0, + function(x){ + if(0 === x[0]) + return [0, y, [0, symbol, caml_call2(UIML_GenT[1], y, l0)]]; + var + x0 = x[3], + p = iHl(y0), + s = p[1], + x1 = caml_call1(s, x0), + p0 = x1[2], + x2 = x1[1], + i = p0[2]; + return [0, x2, [0, symbol, [1, y, l0, i]]]; + }, + function(x){ + var p = iHl(y0), i = p[2], p0 = x[2], i0 = p0[2]; + if(0 === i0[0]){ + var + _gF_ = caml_call2(UIML_List[4], f, l0), + _gG_ = caml_call1(f, y); + return caml_call2(UIML_GenT[1], _gG_, _gF_); + } + var + x0 = i0[3], + a = x[1], + x1 = [0, a, [0, symbol, x0]], + x2 = caml_call1(i, x1), + _gH_ = caml_call2(UIML_List[4], f, l0); + return [1, caml_call1(f, y), _gH_, x2]; + }];}; + } + function pos_top_imps(param){ + if(! param) return 0; + var t = param[2], h = param[1]; + if(typeof h !== "number" && 1 === h[0]){ + var b = h[2], a = h[1], _gC_ = pos_top_imps(t); + return [0, + [0, [1, a, b], _d_], + caml_call2 + (UIML_List[4], + function(y){ + var _gE_ = [0, caml_call1(UIML_Datatypes[2], y)]; + return [0, caml_call1(UIML_Datatypes[1], y), _gE_]; + }, + _gC_)]; + } + var _gB_ = pos_top_imps(t); + return caml_call2 + (UIML_List[4], + function(y){ + var _gD_ = [0, caml_call1(UIML_Datatypes[2], y)]; + return [0, caml_call1(UIML_Datatypes[1], y), _gD_]; + }, + _gB_); + } + function top_boxes_nobox_gen_ext(param){ + if(! param) return 0; + var l0 = param[2], y = param[1]; + if(typeof y !== "number" && 2 === y[0]){ + var m = y[1], _gA_ = top_boxes_nobox_gen_ext(l0); + return [0, [2, m], caml_call1(UIML_CML_Syntax[9], l0), l0, _gA_]; + } + var _gz_ = top_boxes_nobox_gen_ext(l0); + return [1, y, caml_call1(UIML_CML_Syntax[9], l0), l0, symbol, _gz_]; + } + function flatten_list(param){ + if(! param) return 0; + var t = param[2], h = param[1], _gy_ = flatten_list(t); + return caml_call2(UIML_Datatypes[4], h, _gy_); + } + function coq_InT_flatten_list_InT_elem(l, b, x){ + if(! l) throw caml_maybe_attach_backtrace([0, Assert_failure, _e_], 1); + var + l0 = l[2], + y = l[1], + _gx_ = flatten_list(l0), + x0 = caml_call4(UIML_List_lemmasT[1], y, _gx_, b, x); + if(0 === x0[0]){ + var i = x0[1]; + return [0, y, [0, i, caml_call2(UIML_GenT[1], y, l0)]]; + } + var + i$0 = x0[1], + i0 = coq_InT_flatten_list_InT_elem(l0, b, i$0), + p = i0[2], + x1 = i0[1], + i2 = p[2], + i1 = p[1]; + return [0, x1, [0, i1, [1, y, l0, i2]]]; + } + function coq_InT_trans_flatten_list(l, bs, b, x, x0){ + if(! l) throw caml_maybe_attach_backtrace([0, Assert_failure, _f_], 1); + var l0 = l[2], y = l[1]; + if(0 === x0[0]){ + var _gu_ = flatten_list(l0); + return caml_call4(UIML_List_lemmasT[2], bs, _gu_, b, [0, x]); + } + var + x1 = x0[3], + _gv_ = [1, coq_InT_trans_flatten_list(l0, bs, b, x, x1)], + _gw_ = flatten_list(l0); + return caml_call4(UIML_List_lemmasT[2], y, _gw_, b, _gv_); + } + function list_of_splits(param){ + if(! param) return [0, _g_, symbol]; + var + l0 = param[2], + y = param[1], + x = list_of_splits(l0)[1], + _gs_ = + caml_call2 + (UIML_List[4], + function(y0){ + var _gt_ = caml_call1(UIML_Datatypes[2], y0); + return [0, [0, y, caml_call1(UIML_Datatypes[1], y0)], _gt_]; + }, + x); + return [0, + caml_call2(UIML_Datatypes[4], [0, [0, 0, [0, y, l0]], 0], _gs_), + symbol]; + } + function listInserts(l, a){ + var a$0 = list_of_splits(l)[1]; + return caml_call2 + (UIML_List[4], + function(y){ + var + _gq_ = [0, a, caml_call1(UIML_Datatypes[2], y)], + _gr_ = caml_call1(UIML_Datatypes[1], y); + return caml_call2(UIML_Datatypes[4], _gr_, _gq_); + }, + a$0); + } + function listInsertsR_Seqs(UU0393, UU0394, a){ + var _gp_ = listInserts(UU0393, a); + return caml_call2(UIML_List[4], function(y){return [0, y, UU0394];}, _gp_); + } + function listInsertsL_Seqs(UU0393, UU0394, a){ + var _go_ = listInserts(UU0394, a); + return caml_call2(UIML_List[4], function(y){return [0, UU0393, y];}, _go_); + } + function remove_nth(n, a, l){ + if(! n) return l; + var m = n[1]; + if(m){ + if(! l) return 0; + var tl = l[2], b = l[1]; + return [0, b, remove_nth(m, a, tl)]; + } + if(! l) return 0; + var tl$0 = l[2], b$0 = l[1]; + return caml_call2(UIML_CML_Syntax[6], a, b$0) ? tl$0 : [0, b$0, tl$0]; + } + function nth_split(n, l){ + if(! n) return [0, 0, l]; + var m = n[1]; + if(m){ + if(! l) return _h_; + var + tl = l[2], + b = l[1], + _gl_ = nth_split(m, tl), + _gm_ = caml_call1(UIML_Datatypes[2], _gl_), + _gn_ = nth_split(m, tl); + return [0, [0, b, caml_call1(UIML_Datatypes[1], _gn_)], _gm_]; + } + if(! l) return _i_; + var tl$0 = l[2], b$0 = l[1]; + return [0, [0, b$0, 0], tl$0]; + } + function prems_Imp_R(l, s){ + var l$0 = l; + for(;;){ + if(! l$0) return 0; + var t = l$0[2], p = l$0[1], n = p[2], c = p[1]; + if(n){ + var m = n[1]; + if(typeof c !== "number" && 1 === c[0]){ + var + b = c[2], + a = c[1], + _ge_ = prems_Imp_R(t, s), + _gf_ = + nth_split + (m, remove_nth([0, m], c, caml_call1(UIML_Datatypes[2], s))), + _gg_ = [0, b, caml_call1(UIML_Datatypes[2], _gf_)], + _gh_ = + nth_split + (m, remove_nth([0, m], c, caml_call1(UIML_Datatypes[2], s))), + _gi_ = caml_call1(UIML_Datatypes[1], _gh_), + _gj_ = caml_call2(UIML_Datatypes[4], _gi_, _gg_), + _gk_ = listInsertsR_Seqs(caml_call1(UIML_Datatypes[1], s), _gj_, a); + return caml_call2(UIML_Datatypes[4], _gk_, _ge_); + } + l$0 = t; + } + else + l$0 = t; + } + } + function coq_In_pos_top_imps_split_l(l, a, n){ + if(! l) throw caml_maybe_attach_backtrace([0, Assert_failure, _m_], 1); + var l0 = l[2], y = l[1]; + if(typeof y !== "number" && 1 === y[0]){ + var + m0 = y[2], + m = y[1], + _gc_ = pos_top_imps(l0), + h = + coq_In_InT_pair + (a, + [0, n], + [0, + [0, [1, m, m0], _k_], + caml_call2 + (UIML_List[4], + function(y0){ + var _gd_ = [0, caml_call1(UIML_Datatypes[2], y0)]; + return [0, caml_call1(UIML_Datatypes[1], y0), _gd_]; + }, + _gc_)]); + if(0 === h[0]) return [0, 0, [0, l0, symbol]]; + if(! n) throw caml_maybe_attach_backtrace([0, Assert_failure, _l_], 1); + var + n0$0 = n[1], + s$0 = coq_In_pos_top_imps_split_l(l0, a, n0$0), + s0$0 = s$0[2], + x = s$0[1], + x0$0 = s0$0[1]; + return [0, [0, [1, m, m0], x], [0, x0$0, symbol]]; + } + if(! n) throw caml_maybe_attach_backtrace([0, Assert_failure, _j_], 1); + var + n0 = n[1], + s = coq_In_pos_top_imps_split_l(l0, a, n0), + s0 = s[2], + x0 = s[1], + x1 = s0[1]; + return [0, [0, y, x0], [0, x1, symbol]]; + } + function coq_ImpR_help01(prem, s, l3){ + var l0 = s[2], l = s[1]; + function f(l1, x){ + if(! l1) throw caml_maybe_attach_backtrace([0, Assert_failure, _n_], 1); + var l2 = l1[2], y = l1[1], n = y[2], m = y[1]; + if(typeof m !== "number" && 1 === m[0]){ + var m1 = m[2], m0 = m[1]; + if(! n){ + var + s0$1 = f(l2, x), + s1$1 = s0$1[2], + x0$1 = s0$1[1], + s2$1 = s1$1[2], + x1$2 = s1$1[1], + s3$1 = s2$1[2], + x2$2 = s2$1[1], + s4$1 = s3$1[2], + x3$2 = s3$1[1], + s5$1 = s4$1[2], + x4$2 = s4$1[1], + s6$1 = s5$1[2], + x5$1 = s5$1[1], + x6$1 = s6$1[1]; + return [0, + x0$1, + [0, + x1$2, + [0, x2$2, [0, x3$2, [0, x4$2, [0, x5$1, [0, x6$1, symbol]]]]]]]; + } + var + n0 = n[1], + prems_Imp_R0 = + function(l4, s0){ + var l4$0 = l4; + for(;;){ + if(! l4$0) return 0; + var l4$1 = l4$0[2], p = l4$0[1], n1 = p[2], c = p[1]; + if(n1){ + var m2 = n1[1]; + if(typeof c !== "number" && 1 === c[0]){ + var + b = c[2], + a = c[1], + _f7_ = prems_Imp_R0(l4$1, s0), + _f8_ = + nth_split + (m2, + remove_nth([0, m2], c, caml_call1(UIML_Datatypes[2], s0))), + _f9_ = [0, b, caml_call1(UIML_Datatypes[2], _f8_)], + _f__ = + nth_split + (m2, + remove_nth([0, m2], c, caml_call1(UIML_Datatypes[2], s0))), + _f$_ = caml_call1(UIML_Datatypes[1], _f__), + _ga_ = caml_call2(UIML_Datatypes[4], _f$_, _f9_), + _gb_ = + listInsertsR_Seqs(caml_call1(UIML_Datatypes[1], s0), _ga_, a); + return caml_call2(UIML_Datatypes[4], _gb_, _f7_); + } + l4$0 = l4$1; + } + else + l4$0 = l4$1; + } + }, + _fR_ = prems_Imp_R0(l2, [0, l, l0]), + _fS_ = + nth_split + (n0, + remove_nth + ([0, n0], [1, m0, m1], caml_call1(UIML_Datatypes[2], [0, l, l0]))), + _fT_ = [0, m1, caml_call1(UIML_Datatypes[2], _fS_)], + _fU_ = + nth_split + (n0, + remove_nth + ([0, n0], [1, m0, m1], caml_call1(UIML_Datatypes[2], [0, l, l0]))), + _fV_ = caml_call1(UIML_Datatypes[1], _fU_), + _fW_ = caml_call2(UIML_Datatypes[4], _fV_, _fT_), + _fX_ = + listInsertsR_Seqs + (caml_call1(UIML_Datatypes[1], [0, l, l0]), _fW_, m0), + x0$0 = caml_call4(UIML_List_lemmasT[1], _fX_, _fR_, prem, x); + if(0 === x0$0[0]){ + var + i = x0$0[1], + l4 = listInserts(l, m0), + f0 = + function(y0){ + var + _f3_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l0)), + _f4_ = [0, m1, caml_call1(UIML_Datatypes[2], _f3_)], + _f5_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l0)), + _f6_ = caml_call1(UIML_Datatypes[1], _f5_); + return [0, y0, caml_call2(UIML_Datatypes[4], _f6_, _f4_)]; + }, + x1$0 = coq_InT_map_iff(f0, l4)(prem)[1], + i0 = caml_call1(x1$0, i), + p = i0[2], + x2$0 = i0[1], + i1 = p[2], + l4$1 = list_of_splits(l)[1], + f0$0 = + function(y0){ + var + _f1_ = [0, m0, caml_call1(UIML_Datatypes[2], y0)], + _f2_ = caml_call1(UIML_Datatypes[1], y0); + return caml_call2(UIML_Datatypes[4], _f2_, _f1_); + }, + x3$0 = coq_InT_map_iff(f0$0, l4$1)(x2$0)[1], + i2 = caml_call1(x3$0, i1), + x4$0 = i2[1], + l5 = x4$0[2], + l4$0 = x4$0[1], + _fY_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l0)), + _fZ_ = [0, caml_call1(UIML_Datatypes[2], _fY_), symbol], + _f0_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l0)); + return [0, + n0, + [0, + m0, + [0, + m1, + [0, + l4$0, + [0, l5, [0, caml_call1(UIML_Datatypes[1], _f0_), _fZ_]]]]]]; + } + var + i$0 = x0$0[1], + s0$0 = f(l2, i$0), + s1$0 = s0$0[2], + x1$1 = s0$0[1], + s2$0 = s1$0[2], + x2$1 = s1$0[1], + s3$0 = s2$0[2], + x3$1 = s2$0[1], + s4$0 = s3$0[2], + x4$1 = s3$0[1], + s5$0 = s4$0[2], + x5$0 = s4$0[1], + s6$0 = s5$0[2], + x6$0 = s5$0[1], + x7 = s6$0[1]; + return [0, + x1$1, + [0, + x2$1, + [0, x3$1, [0, x4$1, [0, x5$0, [0, x6$0, [0, x7, symbol]]]]]]]; + } + var + s0 = f(l2, x), + s1 = s0[2], + x0 = s0[1], + s2 = s1[2], + x1 = s1[1], + s3 = s2[2], + x2 = s2[1], + s4 = s3[2], + x3 = s3[1], + s5 = s4[2], + x4 = s4[1], + s6 = s5[2], + x5 = s5[1], + x6 = s6[1]; + return [0, + x0, + [0, x1, [0, x2, [0, x3, [0, x4, [0, x5, [0, x6, symbol]]]]]]]; + } + return function(_fQ_){return f(l3, _fQ_);}; + } + function coq_ImpR_help1(prem, s, x){ + var + s0 = + coq_ImpR_help01 + (prem, s, pos_top_imps(caml_call1(UIML_Datatypes[2], s))) + (x), + s1 = s0[2], + x0 = s0[1], + l = s[2], + s2 = s1[2], + x1 = s1[1], + s3 = s2[2], + x2 = s2[1], + s4 = s3[2], + x3 = s3[1], + x4 = s4[1], + i = coq_In_pos_top_imps_split_l(l, [1, x1, x2], x0), + s5 = i[2], + x5 = i[1], + x6 = s5[1]; + return [0, x1, x2, x3, x4, x5, x6]; + } + function coq_ImpR_help002(UU0393_0, UU0393_1, UU0394_0, UU0394_1, a, b){ + function f(y){ + return [0, y, caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1])]; + } + var + l = listInserts(caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), a), + _fM_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1]), + y = [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), _fM_], + x = coq_InT_map_iff(f, l)(y)[2]; + function f0(y0){ + var + _fO_ = [0, a, caml_call1(UIML_Datatypes[2], y0)], + _fP_ = caml_call1(UIML_Datatypes[1], y0); + return caml_call2(UIML_Datatypes[4], _fP_, _fO_); + } + var + l0 = list_of_splits(caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1))[1], + y0 = caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + x0 = coq_InT_map_iff(f0, l0)(y0)[2], + s = list_of_splits(caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1)), + x1 = s[1], + _fN_ = + [0, + symbol, + caml_call1 + (x0, + [0, + [0, UU0393_0, UU0393_1], + [0, + symbol, + caml_call2(UIML_List_lems[5], [0, UU0393_0, UU0393_1], x1)]])]; + return caml_call1 + (x, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + _fN_]); + } + function coq_ImpR_help02 + (UU0393_0, UU0393_1, UU0394_0, UU0394_1, a, b, l, n, x){ + var l$0 = l, n$0 = n; + for(;;){ + if(! l$0) throw caml_maybe_attach_backtrace([0, Assert_failure, _q_], 1); + var l0 = l$0[2], y = l$0[1], n0 = y[2], m = y[1]; + if(typeof m !== "number" && 1 === m[0]){ + var + m1 = m[2], + m0 = m[1], + h1$0 = + coq_In_InT_pair([1, a, b], [0, n$0], [0, [0, [1, m0, m1], n0], l0]); + if(0 === h1$0[0]){ + if(UU0394_0){ + var + l1 = UU0394_0[2], + m2 = UU0394_0[1], + _e4_ = + [0, + coq_ImpR_help002(UU0393_0, UU0393_1, [0, m2, l1], UU0394_1, a, b)], + _e5_ = caml_call2(UIML_Datatypes[4], [0, m2, l1], [0, b, UU0394_1]), + prems_Imp_R0 = + function(l2, s){ + var l2$0 = l2; + for(;;){ + if(! l2$0) return 0; + var l2$1 = l2$0[2], p = l2$0[1], n1 = p[2], c = p[1]; + if(n1){ + var m3 = n1[1]; + if(typeof c !== "number" && 1 === c[0]){ + var + b0 = c[2], + a0 = c[1], + _fF_ = prems_Imp_R0(l2$1, s), + _fG_ = + nth_split + (m3, + remove_nth([0, m3], c, caml_call1(UIML_Datatypes[2], s))), + _fH_ = [0, b0, caml_call1(UIML_Datatypes[2], _fG_)], + _fI_ = + nth_split + (m3, + remove_nth([0, m3], c, caml_call1(UIML_Datatypes[2], s))), + _fJ_ = caml_call1(UIML_Datatypes[1], _fI_), + _fK_ = caml_call2(UIML_Datatypes[4], _fJ_, _fH_), + _fL_ = + listInsertsR_Seqs + (caml_call1(UIML_Datatypes[1], s), _fK_, a0); + return caml_call2(UIML_Datatypes[4], _fL_, _fF_); + } + l2$0 = l2$1; + } + else + l2$0 = l2$1; + } + }, + _e6_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + _e5_], + _e7_ = + caml_call2 + (UIML_Datatypes[4], [0, m2, l1], [0, [1, a, b], UU0394_1]), + _e8_ = + prems_Imp_R0 + (l0, [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _e7_]), + _e9_ = + caml_call2 + (UIML_Datatypes[4], [0, m2, l1], [0, [1, a, b], UU0394_1]), + _e__ = [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _e9_], + _e$_ = caml_call1(UIML_Datatypes[2], _e__), + _fa_ = + remove_nth + ([0, caml_call1(UIML_Datatypes[3], [0, m2, l1])], [1, a, b], _e$_), + _fb_ = nth_split(caml_call1(UIML_Datatypes[3], [0, m2, l1]), _fa_), + _fc_ = [0, b, caml_call1(UIML_Datatypes[2], _fb_)], + _fd_ = + caml_call2 + (UIML_Datatypes[4], [0, m2, l1], [0, [1, a, b], UU0394_1]), + _fe_ = [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _fd_], + _ff_ = caml_call1(UIML_Datatypes[2], _fe_), + _fg_ = + remove_nth + ([0, caml_call1(UIML_Datatypes[3], [0, m2, l1])], [1, a, b], _ff_), + _fh_ = nth_split(caml_call1(UIML_Datatypes[3], [0, m2, l1]), _fg_), + _fi_ = caml_call1(UIML_Datatypes[1], _fh_), + _fj_ = caml_call2(UIML_Datatypes[4], _fi_, _fc_), + _fk_ = + caml_call2 + (UIML_Datatypes[4], [0, m2, l1], [0, [1, a, b], UU0394_1]), + _fl_ = [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _fk_], + _fm_ = + listInsertsR_Seqs(caml_call1(UIML_Datatypes[1], _fl_), _fj_, a); + return caml_call4(UIML_List_lemmasT[2], _fm_, _e8_, _e6_, _e4_); + } + var + i = coq_ImpR_help002(UU0393_0, UU0393_1, 0, UU0394_1, a, b), + s = caml_call2(UIML_CML_Syntax[6], [1, a, b], [1, a, b]); + if(! s) throw caml_maybe_attach_backtrace([0, Assert_failure, _p_], 1); + var + _fn_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + [0, b, UU0394_1]], + _fo_ = + prems_Imp_R + (l0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), + [0, [1, a, b], UU0394_1]]), + _fp_ = + listInsertsR_Seqs + (caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), + [0, b, UU0394_1], + a); + return caml_call4(UIML_List_lemmasT[2], _fp_, _fo_, _fn_, [0, i]); + } + var + i$0 = + coq_ImpR_help02 + (UU0393_0, + UU0393_1, + UU0394_0, + UU0394_1, + a, + b, + l0, + caml_call1(UIML_Datatypes[3], UU0394_0), + x); + if(! n0) return i$0; + var + n1 = n0[1], + _fr_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1]), + _fs_ = + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), _fr_], + _ft_ = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]), + _fq_ = [1, i$0], + _fu_ = + prems_Imp_R + (l0, [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _ft_]); + if(n1){ + var + match = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]); + if(match) + var + tl = match[2], + b0 = match[1], + _fv_ = [0, b0, remove_nth(n1, [1, m0, m1], tl)]; + else + var _fv_ = 0; + var _fw_ = _fv_; + } + else{ + var + match$2 = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]); + if(match$2) + var + tl$4 = match$2[2], + b0$2 = match$2[1], + tl$5 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$2) + ? tl$4 + : [0, b0$2, tl$4], + tl$6 = tl$5; + else + var tl$6 = 0; + var _fw_ = tl$6; + } + var + _fx_ = nth_split(n1, _fw_), + _fy_ = [0, m1, caml_call1(UIML_Datatypes[2], _fx_)]; + if(n1){ + var + match$0 = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]); + if(match$0) + var + tl$0 = match$0[2], + b0$0 = match$0[1], + _fz_ = [0, b0$0, remove_nth(n1, [1, m0, m1], tl$0)]; + else + var _fz_ = 0; + var _fA_ = _fz_; + } + else{ + var + match$1 = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]); + if(match$1) + var + tl$1 = match$1[2], + b0$1 = match$1[1], + tl$2 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$1) + ? tl$1 + : [0, b0$1, tl$1], + tl$3 = tl$2; + else + var tl$3 = 0; + var _fA_ = tl$3; + } + var + _fB_ = nth_split(n1, _fA_), + _fC_ = caml_call1(UIML_Datatypes[1], _fB_), + _fD_ = caml_call2(UIML_Datatypes[4], _fC_, _fy_), + _fE_ = + listInsertsR_Seqs + (caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _fD_, m0); + return caml_call4(UIML_List_lemmasT[2], _fE_, _fu_, _fs_, _fq_); + } + var h1 = coq_In_InT_pair([1, a, b], [0, n$0], [0, [0, m, n0], l0]); + if(0 === h1[0]) + throw caml_maybe_attach_backtrace([0, Assert_failure, _o_], 1); + var n$1 = caml_call1(UIML_Datatypes[3], UU0394_0); + l$0 = l0; + n$0 = n$1; + } + } + function coq_ImpR_help2(param, _e2_, x){ + var + UU0394_1 = x[6], + UU0394_0 = x[5], + UU0393_1 = x[4], + UU0393_0 = x[3], + b = x[2], + a = x[1], + _e3_ = caml_call1(UIML_Datatypes[3], UU0394_0); + return coq_ImpR_help02 + (UU0393_0, + UU0393_1, + UU0394_0, + UU0394_1, + a, + b, + pos_top_imps + (caml_call2 + (UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1])), + _e3_, + x); + } + function finite_ImpR_premises_of_S(param){ + var + l0 = param[2], + l = param[1], + _eT_ = prems_Imp_R(pos_top_imps(l0), [0, l, l0]); + return [0, + caml_call2(UIML_List[4], function(y){return [0, y, 0];}, _eT_), + function(prems){ + return [0, + function(h){ + var + UU0394_1 = h[6], + UU0394_0 = h[5], + UU0393_1 = h[4], + UU0393_0 = h[3], + b = h[2], + a = h[1]; + function f(y){return [0, y, 0];} + var + _eU_ = + caml_call2 + (UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]), + _eV_ = + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _eU_], + l1 = + prems_Imp_R + (pos_top_imps + (caml_call2 + (UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1])), + _eV_), + _eW_ = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1]), + y = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + _eW_], + 0], + x = coq_InT_map_iff(f, l1)(y)[2], + _eX_ = + caml_call2 + (UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]), + _eY_ = + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _eX_], + _eZ_ = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1]), + _e0_ = + [0, + symbol, + coq_ImpR_help2 + ([0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + _eZ_], + _eY_, + h)], + _e1_ = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1]); + return caml_call1 + (x, + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + _e1_], + _e0_]); + }, + function(h){ + var l1 = prems_Imp_R(pos_top_imps(l0), [0, l, l0]); + function f(y){return [0, y, 0];} + var + x = coq_InT_map_iff(f, l1)(prems)[1], + h0 = caml_call1(x, h), + p = h0[2], + x0 = h0[1], + i = p[2]; + return coq_ImpR_help1(x0, [0, l, l0], i); + }]; + }]; + } + function prems_Imp_L(l, s){ + var l$0 = l; + for(;;){ + if(! l$0) return 0; + var t = l$0[2], p = l$0[1], n = p[2], c = p[1]; + if(n){ + var m = n[1]; + if(typeof c !== "number" && 1 === c[0]){ + var + b = c[2], + a = c[1], + _eF_ = prems_Imp_L(t, s), + _eG_ = caml_call1(UIML_Datatypes[2], s), + _eH_ = + nth_split + (m, remove_nth([0, m], c, caml_call1(UIML_Datatypes[1], s))), + _eI_ = [0, b, caml_call1(UIML_Datatypes[2], _eH_)], + _eJ_ = + nth_split + (m, remove_nth([0, m], c, caml_call1(UIML_Datatypes[1], s))), + _eK_ = caml_call1(UIML_Datatypes[1], _eJ_), + _eL_ = [0, [0, caml_call2(UIML_Datatypes[4], _eK_, _eI_), _eG_], 0], + _eM_ = + flatten_list + (caml_call2 + (UIML_List[4], + function(y){ + var + _eN_ = caml_call1(UIML_Datatypes[2], s), + _eO_ = + nth_split + (m, remove_nth([0, m], c, caml_call1(UIML_Datatypes[1], s))), + _eP_ = caml_call1(UIML_Datatypes[2], _eO_), + _eQ_ = + nth_split + (m, remove_nth([0, m], c, caml_call1(UIML_Datatypes[1], s))), + _eR_ = caml_call1(UIML_Datatypes[1], _eQ_), + _eS_ = + listInsertsL_Seqs + (caml_call2(UIML_Datatypes[4], _eR_, _eP_), _eN_, a); + return caml_call2 + (UIML_List[4], function(z){return [0, z, [0, y, 0]];}, _eS_); + }, + _eL_)); + return caml_call2(UIML_Datatypes[4], _eM_, _eF_); + } + l$0 = t; + } + else + l$0 = t; + } + } + function coq_ImpL_help002(UU0393_0, UU0393_1, UU0394_0, UU0394_1, a, b){ + var + _d4_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _d5_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _d4_], + 0], + _d6_ = + caml_call2 + (UIML_List[4], + function(z){ + var + _eE_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]); + return [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _eE_], + [0, z, 0]]; + }, + _d5_), + _d7_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + p = + coq_InT_map_iff + (function(y){ + var + _eC_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _eD_ = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _eC_], + 0]; + return caml_call2 + (UIML_List[4], function(z){return [0, y, [0, z, 0]];}, _eD_); + }, + listInsertsL_Seqs + (caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _d7_, a)) + (_d6_), + i = p[2], + _d8_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + _d9_ = [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _d8_], + p0 = + coq_InT_map_iff + (function(y){ + return [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), y]; + }, + listInserts(caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), a)) + (_d9_), + i0 = p0[2], + _d__ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + a$0 = + list_of_splits(caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1))[1], + p1 = + coq_InT_map_iff + (function(y){ + var + _eA_ = [0, a, caml_call1(UIML_Datatypes[2], y)], + _eB_ = caml_call1(UIML_Datatypes[1], y); + return caml_call2(UIML_Datatypes[4], _eB_, _eA_); + }, + a$0) + (_d__), + i1 = p1[2], + s = list_of_splits(caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1)), + x = s[1], + _d$_ = + [0, + symbol, + caml_call1 + (i1, + [0, + [0, UU0394_0, UU0394_1], + [0, + symbol, + caml_call2(UIML_List_lems[5], [0, UU0394_0, UU0394_1], x)]])], + _ea_ = + [0, + symbol, + caml_call1 + (i0, + [0, caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), _d$_])], + _eb_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + _ec_ = + caml_call1 + (i, + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _eb_], + _ea_]), + _ed_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _ee_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _ed_], + 0], + _ef_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + _eg_ = + [0, [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _ef_], _ee_], + _eh_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + p$0 = + coq_InT_map_iff + (function(z){ + var + _ez_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]); + return [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _ez_], + [0, z, 0]]; + }, + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _eh_], + 0]) + (_eg_), + i$0 = p$0[2], + _ei_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _ej_ = + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _ei_], + _ek_ = [0, symbol, caml_call2(UIML_GenT[1], _ej_, 0)], + _el_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _em_ = + caml_call1 + (i$0, + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _el_], + _ek_]), + _en_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _eo_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _en_], + 0], + _ep_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + _eq_ = + [0, [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _ep_], _eo_], + _er_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _es_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _er_], + 0], + _et_ = + caml_call2 + (UIML_List[4], + function(z){ + var + _ey_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]); + return [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _ey_], + [0, z, 0]]; + }, + _es_), + _eu_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _ev_ = + listInsertsL_Seqs + (caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _eu_, a); + return coq_InT_trans_flatten_list + (caml_call2 + (UIML_List[4], + function(y){ + var + _ew_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _ex_ = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _ew_], + 0]; + return caml_call2 + (UIML_List[4], function(z){return [0, y, [0, z, 0]];}, _ex_); + }, + _ev_), + _et_, + _eq_, + _em_, + _ec_); + } + function coq_ImpL_help02 + (UU0393_0, UU0393_1, UU0394_0, UU0394_1, a, b, l, n, x){ + var l$0 = l, n$0 = n; + for(;;){ + if(! l$0) throw caml_maybe_attach_backtrace([0, Assert_failure, _t_], 1); + var l0 = l$0[2], y = l$0[1], n0 = y[2], m = y[1]; + if(typeof m !== "number" && 1 === m[0]){ + var + m1 = m[2], + m0 = m[1], + h1$0 = + coq_In_InT_pair([1, a, b], [0, n$0], [0, [0, [1, m0, m1], n0], l0]); + if(0 === h1$0[0]){ + var + i = coq_ImpL_help002(UU0393_0, UU0393_1, UU0394_0, UU0394_1, a, b), + f = + function(y0){ + var + _dO_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _dP_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _dO_], + _dQ_ = caml_call1(UIML_Datatypes[2], _dP_), + _dR_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _dS_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _dR_], + _dT_ = caml_call1(UIML_Datatypes[1], _dS_), + _dU_ = + remove_nth + ([0, caml_call1(UIML_Datatypes[3], UU0393_0)], [1, a, b], _dT_), + _dV_ = nth_split(caml_call1(UIML_Datatypes[3], UU0393_0), _dU_), + _dW_ = caml_call1(UIML_Datatypes[2], _dV_), + _dX_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _dY_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _dX_], + _dZ_ = caml_call1(UIML_Datatypes[1], _dY_), + _d0_ = + remove_nth + ([0, caml_call1(UIML_Datatypes[3], UU0393_0)], [1, a, b], _dZ_), + _d1_ = nth_split(caml_call1(UIML_Datatypes[3], UU0393_0), _d0_), + _d2_ = caml_call1(UIML_Datatypes[1], _d1_), + _d3_ = + listInsertsL_Seqs + (caml_call2(UIML_Datatypes[4], _d2_, _dW_), _dQ_, a); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _d3_); + }, + _bv_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _bw_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _bv_], + _bx_ = caml_call1(UIML_Datatypes[2], _bw_), + _by_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _bz_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _by_], + _bA_ = caml_call1(UIML_Datatypes[1], _bz_), + _bB_ = + remove_nth + ([0, caml_call1(UIML_Datatypes[3], UU0393_0)], [1, a, b], _bA_), + _bC_ = nth_split(caml_call1(UIML_Datatypes[3], UU0393_0), _bB_), + _bD_ = [0, b, caml_call1(UIML_Datatypes[2], _bC_)], + _bE_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _bF_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _bE_], + _bG_ = caml_call1(UIML_Datatypes[1], _bF_), + _bH_ = + remove_nth + ([0, caml_call1(UIML_Datatypes[3], UU0393_0)], [1, a, b], _bG_), + _bI_ = nth_split(caml_call1(UIML_Datatypes[3], UU0393_0), _bH_), + _bJ_ = caml_call1(UIML_Datatypes[1], _bI_), + l1 = [0, [0, caml_call2(UIML_Datatypes[4], _bJ_, _bD_), _bx_], 0], + _bK_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _bL_ = + listInsertsL_Seqs + (caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _bK_, a), + y0 = + flatten_list + (caml_call2 + (UIML_List[4], + function(y0){ + var _dN_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1); + return [0, + [0, + y0, + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _dN_], + 0]], + 0]; + }, + _bL_)), + x0 = coq_InT_map_iff(f, l1)(y0)[2], + s = caml_call2(UIML_CML_Syntax[6], [1, a, b], [1, a, b]); + if(! s) throw caml_maybe_attach_backtrace([0, Assert_failure, _s_], 1); + var + _bM_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _bN_ = + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _bM_], + _bO_ = [0, symbol, caml_call2(UIML_GenT[1], _bN_, 0)], + _bP_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _bQ_ = + caml_call1 + (x0, + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _bP_], + _bO_]), + _bR_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _bS_ = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _bR_], + 0], + _bT_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + _bU_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _bT_], + _bS_], + _bV_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _bW_ = + listInsertsL_Seqs + (caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _bV_, a), + _bX_ = + flatten_list + (caml_call2 + (UIML_List[4], + function(y0){ + var _dM_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1); + return [0, + [0, + y0, + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _dM_], + 0]], + 0]; + }, + _bW_)), + _bY_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _bZ_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _bY_], + _b0_ = caml_call1(UIML_Datatypes[2], _bZ_), + _b1_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _b2_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _b1_], + _b3_ = caml_call1(UIML_Datatypes[1], _b2_), + _b4_ = + remove_nth + ([0, caml_call1(UIML_Datatypes[3], UU0393_0)], [1, a, b], _b3_), + _b5_ = nth_split(caml_call1(UIML_Datatypes[3], UU0393_0), _b4_), + _b6_ = [0, b, caml_call1(UIML_Datatypes[2], _b5_)], + _b7_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _b8_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _b7_], + _b9_ = caml_call1(UIML_Datatypes[1], _b8_), + _b__ = + remove_nth + ([0, caml_call1(UIML_Datatypes[3], UU0393_0)], [1, a, b], _b9_), + _b$_ = nth_split(caml_call1(UIML_Datatypes[3], UU0393_0), _b__), + _ca_ = caml_call1(UIML_Datatypes[1], _b$_), + _cb_ = [0, [0, caml_call2(UIML_Datatypes[4], _ca_, _b6_), _b0_], 0], + _cc_ = + [0, + coq_InT_trans_flatten_list + (caml_call2 + (UIML_List[4], + function(y0){ + var + _dw_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _dx_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _dw_], + _dy_ = caml_call1(UIML_Datatypes[2], _dx_), + _dz_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _dA_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _dz_], + _dB_ = caml_call1(UIML_Datatypes[1], _dA_), + _dC_ = + remove_nth + ([0, caml_call1(UIML_Datatypes[3], UU0393_0)], + [1, a, b], + _dB_), + _dD_ = + nth_split(caml_call1(UIML_Datatypes[3], UU0393_0), _dC_), + _dE_ = caml_call1(UIML_Datatypes[2], _dD_), + _dF_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _dG_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _dF_], + _dH_ = caml_call1(UIML_Datatypes[1], _dG_), + _dI_ = + remove_nth + ([0, caml_call1(UIML_Datatypes[3], UU0393_0)], + [1, a, b], + _dH_), + _dJ_ = + nth_split(caml_call1(UIML_Datatypes[3], UU0393_0), _dI_), + _dK_ = caml_call1(UIML_Datatypes[1], _dJ_), + _dL_ = + listInsertsL_Seqs + (caml_call2(UIML_Datatypes[4], _dK_, _dE_), _dy_, a); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _dL_); + }, + _cb_), + _bX_, + _bU_, + i, + _bQ_)], + _cd_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _ce_ = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _cd_], + 0], + _cf_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + prems_Imp_L0 = + function(l1, s){ + var l1$0 = l1; + for(;;){ + if(! l1$0) return 0; + var l1$1 = l1$0[2], p = l1$0[1], n1 = p[2], c = p[1]; + if(n1){ + var m2 = n1[1]; + if(typeof c !== "number" && 1 === c[0]){ + var + b0 = c[2], + a0 = c[1], + _di_ = prems_Imp_L0(l1$1, s), + _dj_ = caml_call1(UIML_Datatypes[2], s), + _dk_ = + nth_split + (m2, + remove_nth([0, m2], c, caml_call1(UIML_Datatypes[1], s))), + _dl_ = [0, b0, caml_call1(UIML_Datatypes[2], _dk_)], + _dm_ = + nth_split + (m2, + remove_nth([0, m2], c, caml_call1(UIML_Datatypes[1], s))), + _dn_ = caml_call1(UIML_Datatypes[1], _dm_), + _do_ = + [0, [0, caml_call2(UIML_Datatypes[4], _dn_, _dl_), _dj_], 0], + _dp_ = + flatten_list + (caml_call2 + (UIML_List[4], + function(y0){ + var + _dq_ = caml_call1(UIML_Datatypes[2], s), + _dr_ = + nth_split + (m2, + remove_nth([0, m2], c, caml_call1(UIML_Datatypes[1], s))), + _ds_ = caml_call1(UIML_Datatypes[2], _dr_), + _dt_ = + nth_split + (m2, + remove_nth([0, m2], c, caml_call1(UIML_Datatypes[1], s))), + _du_ = caml_call1(UIML_Datatypes[1], _dt_), + _dv_ = + listInsertsL_Seqs + (caml_call2(UIML_Datatypes[4], _du_, _ds_), _dq_, a0); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _dv_); + }, + _do_)); + return caml_call2(UIML_Datatypes[4], _dp_, _di_); + } + l1$0 = l1$1; + } + else + l1$0 = l1$1; + } + }, + _cg_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _cf_], + _ce_], + _ch_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _ci_ = + prems_Imp_L0 + (l0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _ch_]), + _cj_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _ck_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _cj_], + _cl_ = caml_call1(UIML_Datatypes[2], _ck_), + _cm_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _cn_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _cm_], + _co_ = caml_call1(UIML_Datatypes[1], _cn_), + _cp_ = + remove_nth + ([0, caml_call1(UIML_Datatypes[3], UU0393_0)], [1, a, b], _co_), + _cq_ = nth_split(caml_call1(UIML_Datatypes[3], UU0393_0), _cp_), + _cr_ = [0, b, caml_call1(UIML_Datatypes[2], _cq_)], + _cs_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _ct_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _cs_], + _cu_ = caml_call1(UIML_Datatypes[1], _ct_), + _cv_ = + remove_nth + ([0, caml_call1(UIML_Datatypes[3], UU0393_0)], [1, a, b], _cu_), + _cw_ = nth_split(caml_call1(UIML_Datatypes[3], UU0393_0), _cv_), + _cx_ = caml_call1(UIML_Datatypes[1], _cw_), + _cy_ = [0, [0, caml_call2(UIML_Datatypes[4], _cx_, _cr_), _cl_], 0], + _cz_ = + flatten_list + (caml_call2 + (UIML_List[4], + function(y0){ + var + _c4_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _c5_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _c4_], + _c6_ = caml_call1(UIML_Datatypes[2], _c5_), + _c7_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _c8_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _c7_], + _c9_ = caml_call1(UIML_Datatypes[1], _c8_), + _c__ = + remove_nth + ([0, caml_call1(UIML_Datatypes[3], UU0393_0)], + [1, a, b], + _c9_), + _c$_ = + nth_split(caml_call1(UIML_Datatypes[3], UU0393_0), _c__), + _da_ = caml_call1(UIML_Datatypes[2], _c$_), + _db_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _dc_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _db_], + _dd_ = caml_call1(UIML_Datatypes[1], _dc_), + _de_ = + remove_nth + ([0, caml_call1(UIML_Datatypes[3], UU0393_0)], + [1, a, b], + _dd_), + _df_ = + nth_split(caml_call1(UIML_Datatypes[3], UU0393_0), _de_), + _dg_ = caml_call1(UIML_Datatypes[1], _df_), + _dh_ = + listInsertsL_Seqs + (caml_call2(UIML_Datatypes[4], _dg_, _da_), _c6_, a); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _dh_); + }, + _cy_)); + return caml_call4(UIML_List_lemmasT[2], _cz_, _ci_, _cg_, _cc_); + } + var + i$0 = + coq_ImpL_help02 + (UU0393_0, + UU0393_1, + UU0394_0, + UU0394_1, + a, + b, + l0, + caml_call1(UIML_Datatypes[3], UU0393_0), + x); + if(! n0) return i$0; + var + n1 = n0[1], + _cB_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _cC_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _cB_], + 0], + _cD_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + _cE_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _cD_], + _cC_], + _cF_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _cG_ = + prems_Imp_L + (l0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _cF_]), + _cA_ = [1, i$0], + _cH_ = 0, + _cI_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1); + if(n1){ + var + match = + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match) + var + tl = match[2], + b0 = match[1], + _cJ_ = [0, b0, remove_nth(n1, [1, m0, m1], tl)]; + else + var _cJ_ = 0; + var _cK_ = _cJ_; + } + else{ + var + match$2 = + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match$2) + var + tl$4 = match$2[2], + b0$2 = match$2[1], + tl$5 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$2) + ? tl$4 + : [0, b0$2, tl$4], + tl$6 = tl$5; + else + var tl$6 = 0; + var _cK_ = tl$6; + } + var + _cL_ = nth_split(n1, _cK_), + _cM_ = caml_call1(UIML_Datatypes[2], _cL_); + if(n1){ + var + match$0 = + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match$0) + var + tl$0 = match$0[2], + b0$0 = match$0[1], + _cN_ = [0, b0$0, remove_nth(n1, [1, m0, m1], tl$0)]; + else + var _cN_ = 0; + var _cO_ = _cN_; + } + else{ + var + match$1 = + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match$1) + var + tl$1 = match$1[2], + b0$1 = match$1[1], + tl$2 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$1) + ? tl$1 + : [0, b0$1, tl$1], + tl$3 = tl$2; + else + var tl$3 = 0; + var _cO_ = tl$3; + } + var + _cP_ = nth_split(n1, _cO_), + _cQ_ = caml_call1(UIML_Datatypes[1], _cP_), + _cR_ = + listInsertsL_Seqs + (caml_call2(UIML_Datatypes[4], _cQ_, _cM_), _cI_, m0), + _cS_ = + caml_call2 + (UIML_List[4], + function(z){ + var + _cU_ = 0, + _cV_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1); + if(n1){ + var + match = + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match) + var + tl = match[2], + b0 = match[1], + _cW_ = [0, b0, remove_nth(n1, [1, m0, m1], tl)]; + else + var _cW_ = 0; + var _cX_ = _cW_; + } + else{ + var + match$2 = + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match$2) + var + tl$4 = match$2[2], + b0$2 = match$2[1], + tl$5 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$2) + ? tl$4 + : [0, b0$2, tl$4], + tl$6 = tl$5; + else + var tl$6 = 0; + var _cX_ = tl$6; + } + var + _cY_ = nth_split(n1, _cX_), + _cZ_ = [0, m1, caml_call1(UIML_Datatypes[2], _cY_)]; + if(n1){ + var + match$0 = + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match$0) + var + tl$0 = match$0[2], + b0$0 = match$0[1], + _c0_ = [0, b0$0, remove_nth(n1, [1, m0, m1], tl$0)]; + else + var _c0_ = 0; + var _c1_ = _c0_; + } + else{ + var + match$1 = + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match$1) + var + tl$1 = match$1[2], + b0$1 = match$1[1], + tl$2 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$1) + ? tl$1 + : [0, b0$1, tl$1], + tl$3 = tl$2; + else + var tl$3 = 0; + var _c1_ = tl$3; + } + var + _c2_ = nth_split(n1, _c1_), + _c3_ = caml_call1(UIML_Datatypes[1], _c2_); + return [0, + z, + [0, + [0, caml_call2(UIML_Datatypes[4], _c3_, _cZ_), _cV_], + _cU_]]; + }, + _cR_), + _cT_ = caml_call2(UIML_Datatypes[4], _cS_, _cH_); + return caml_call4(UIML_List_lemmasT[2], _cT_, _cG_, _cE_, _cA_); + } + var + h1 = + coq_In_InT_pair + ([1, a, b], + [0, caml_call1(UIML_Datatypes[3], UU0393_0)], + [0, [0, m, n0], l0]); + if(0 === h1[0]) + throw caml_maybe_attach_backtrace([0, Assert_failure, _r_], 1); + var n$1 = caml_call1(UIML_Datatypes[3], UU0393_0); + l$0 = l0; + n$0 = n$1; + } + } + function coq_ImpL_help2(param, _bt_, _bs_, x){ + var + UU0394_1 = x[6], + UU0394_0 = x[5], + UU0393_1 = x[4], + UU0393_0 = x[3], + b = x[2], + a = x[1], + _bu_ = caml_call1(UIML_Datatypes[3], UU0393_0); + return coq_ImpL_help02 + (UU0393_0, + UU0393_1, + UU0394_0, + UU0394_1, + a, + b, + pos_top_imps + (caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1])), + _bu_, + x); + } + function coq_ImpL_help01(prems, s, l1){ + var l0 = s[2], l = s[1]; + function f(l2, x){ + if(! l2) throw caml_maybe_attach_backtrace([0, Assert_failure, _v_], 1); + var l3 = l2[2], y = l2[1], n = y[2], m = y[1]; + if(typeof m !== "number" && 1 === m[0]){ + var m1 = m[2], m0 = m[1]; + if(! n){ + var + s0$1 = f(l3, x), + s1$1 = s0$1[2], + x0$1 = s0$1[1], + s2$1 = s1$1[2], + x1$2 = s1$1[1], + s3$1 = s2$1[2], + x2$2 = s2$1[1], + s4$1 = s3$1[2], + x3$2 = s3$1[1], + s5$1 = s4$1[2], + x4$2 = s4$1[1], + s6$1 = s5$1[2], + x5$2 = s5$1[1], + s7$1 = s6$1[2], + x6$2 = s6$1[1], + s8$1 = s7$1[2], + x7$2 = s7$1[1], + x8$2 = s8$1[1]; + return [0, + x0$1, + [0, + x1$2, + [0, + x2$2, + [0, + x3$2, + [0, + x4$2, + [0, x5$2, [0, x6$2, [0, x7$2, [0, x8$2, symbol]]]]]]]]]; + } + var + n0 = n[1], + prems_Imp_L0 = + function(l4, s0){ + var l4$0 = l4; + for(;;){ + if(! l4$0) return 0; + var l4$1 = l4$0[2], p = l4$0[1], n1 = p[2], c = p[1]; + if(n1){ + var m2 = n1[1]; + if(typeof c !== "number" && 1 === c[0]){ + var + b = c[2], + a = c[1], + _be_ = prems_Imp_L0(l4$1, s0), + _bf_ = caml_call1(UIML_Datatypes[2], s0), + _bg_ = + nth_split + (m2, + remove_nth([0, m2], c, caml_call1(UIML_Datatypes[1], s0))), + _bh_ = [0, b, caml_call1(UIML_Datatypes[2], _bg_)], + _bi_ = + nth_split + (m2, + remove_nth([0, m2], c, caml_call1(UIML_Datatypes[1], s0))), + _bj_ = caml_call1(UIML_Datatypes[1], _bi_), + _bk_ = + [0, [0, caml_call2(UIML_Datatypes[4], _bj_, _bh_), _bf_], 0], + _bl_ = + flatten_list + (caml_call2 + (UIML_List[4], + function(y0){ + var + _bm_ = caml_call1(UIML_Datatypes[2], s0), + _bn_ = + nth_split + (m2, + remove_nth([0, m2], c, caml_call1(UIML_Datatypes[1], s0))), + _bo_ = caml_call1(UIML_Datatypes[2], _bn_), + _bp_ = + nth_split + (m2, + remove_nth([0, m2], c, caml_call1(UIML_Datatypes[1], s0))), + _bq_ = caml_call1(UIML_Datatypes[1], _bp_), + _br_ = + listInsertsL_Seqs + (caml_call2(UIML_Datatypes[4], _bq_, _bo_), _bm_, a); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _br_); + }, + _bk_)); + return caml_call2(UIML_Datatypes[4], _bl_, _be_); + } + l4$0 = l4$1; + } + else + l4$0 = l4$1; + } + }, + _ac_ = prems_Imp_L0(l3, [0, l, l0]), + _ad_ = caml_call1(UIML_Datatypes[2], [0, l, l0]), + _ae_ = + nth_split + (n0, + remove_nth + ([0, n0], [1, m0, m1], caml_call1(UIML_Datatypes[1], [0, l, l0]))), + _af_ = [0, m1, caml_call1(UIML_Datatypes[2], _ae_)], + _ag_ = + nth_split + (n0, + remove_nth + ([0, n0], [1, m0, m1], caml_call1(UIML_Datatypes[1], [0, l, l0]))), + _ah_ = caml_call1(UIML_Datatypes[1], _ag_), + _ai_ = [0, [0, caml_call2(UIML_Datatypes[4], _ah_, _af_), _ad_], 0], + _aj_ = + flatten_list + (caml_call2 + (UIML_List[4], + function(y0){ + var + _a__ = caml_call1(UIML_Datatypes[2], [0, l, l0]), + _a$_ = + nth_split + (n0, + remove_nth + ([0, n0], + [1, m0, m1], + caml_call1(UIML_Datatypes[1], [0, l, l0]))), + _ba_ = caml_call1(UIML_Datatypes[2], _a$_), + _bb_ = + nth_split + (n0, + remove_nth + ([0, n0], + [1, m0, m1], + caml_call1(UIML_Datatypes[1], [0, l, l0]))), + _bc_ = caml_call1(UIML_Datatypes[1], _bb_), + _bd_ = + listInsertsL_Seqs + (caml_call2(UIML_Datatypes[4], _bc_, _ba_), _a__, m0); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _bd_); + }, + _ai_)), + x0$0 = caml_call4(UIML_List_lemmasT[1], _aj_, _ac_, prems, x); + if(0 !== x0$0[0]){ + var + i$0 = x0$0[1], + s0$0 = f(l3, i$0), + s1$0 = s0$0[2], + x1$1 = s0$0[1], + s2$0 = s1$0[2], + x2$1 = s1$0[1], + s3$0 = s2$0[2], + x3$1 = s2$0[1], + s4$0 = s3$0[2], + x4$1 = s3$0[1], + s5$0 = s4$0[2], + x5$1 = s4$0[1], + s6$0 = s5$0[2], + x6$1 = s5$0[1], + s7$0 = s6$0[2], + x7$1 = s6$0[1], + s8$0 = s7$0[2], + x8$1 = s7$0[1], + x9 = s8$0[1]; + return [0, + x1$1, + [0, + x2$1, + [0, + x3$1, + [0, + x4$1, + [0, x5$1, [0, x6$1, [0, x7$1, [0, x8$1, [0, x9, symbol]]]]]]]]]; + } + var + i = x0$0[1], + _ak_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _al_ = [0, m1, caml_call1(UIML_Datatypes[2], _ak_)], + _am_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _an_ = caml_call1(UIML_Datatypes[1], _am_), + _ao_ = [0, [0, caml_call2(UIML_Datatypes[4], _an_, _al_), l0], 0], + i0 = + coq_InT_flatten_list_InT_elem + (caml_call2 + (UIML_List[4], + function(y0){ + var + _a5_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _a6_ = caml_call1(UIML_Datatypes[2], _a5_), + _a7_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _a8_ = caml_call1(UIML_Datatypes[1], _a7_), + _a9_ = + listInsertsL_Seqs + (caml_call2(UIML_Datatypes[4], _a8_, _a6_), l0, m0); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _a9_); + }, + _ao_), + prems, + i), + p = i0[2], + x1$0 = i0[1], + i2 = p[2], + i1 = p[1], + _ap_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _aq_ = [0, m1, caml_call1(UIML_Datatypes[2], _ap_)], + _ar_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _as_ = caml_call1(UIML_Datatypes[1], _ar_), + l4 = [0, [0, caml_call2(UIML_Datatypes[4], _as_, _aq_), l0], 0], + f0 = + function(y0){ + var + _a0_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _a1_ = caml_call1(UIML_Datatypes[2], _a0_), + _a2_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _a3_ = caml_call1(UIML_Datatypes[1], _a2_), + _a4_ = + listInsertsL_Seqs + (caml_call2(UIML_Datatypes[4], _a3_, _a1_), l0, m0); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _a4_); + }, + x2$0 = coq_InT_map_iff(f0, l4)(x1$0)[1], + i3 = caml_call1(x2$0, i2), + p0 = i3[2], + i4 = p0[2]; + if(0 !== i4[0]) + throw caml_maybe_attach_backtrace([0, Assert_failure, _u_], 1); + var + _at_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _au_ = caml_call1(UIML_Datatypes[2], _at_), + _av_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _aw_ = caml_call1(UIML_Datatypes[1], _av_), + l4$0 = + listInsertsL_Seqs(caml_call2(UIML_Datatypes[4], _aw_, _au_), l0, m0), + f0$0 = + function(z){ + var _aT_ = 0; + if(n0) + if(l) + var + tl = l[2], + b = l[1], + _aU_ = [0, b, remove_nth(n0, [1, m0, m1], tl)]; + else + var _aU_ = 0; + else if(l) + var + tl$3 = l[2], + b$2 = l[1], + tl$4 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b$2) + ? tl$3 + : [0, b$2, tl$3], + _aU_ = tl$4; + else + var _aU_ = 0; + var + _aV_ = nth_split(n0, _aU_), + _aW_ = [0, m1, caml_call1(UIML_Datatypes[2], _aV_)]; + if(n0) + if(l) + var + tl$0 = l[2], + b$0 = l[1], + _aX_ = [0, b$0, remove_nth(n0, [1, m0, m1], tl$0)]; + else + var _aX_ = 0; + else if(l) + var + tl$1 = l[2], + b$1 = l[1], + tl$2 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b$1) + ? tl$1 + : [0, b$1, tl$1], + _aX_ = tl$2; + else + var _aX_ = 0; + var + _aY_ = nth_split(n0, _aX_), + _aZ_ = caml_call1(UIML_Datatypes[1], _aY_); + return [0, + z, + [0, + [0, caml_call2(UIML_Datatypes[4], _aZ_, _aW_), l0], + _aT_]]; + }, + x3$0 = coq_InT_map_iff(f0$0, l4$0)(prems)[1], + i5 = caml_call1(x3$0, i1), + p1 = i5[2], + x4$0 = i5[1], + i6 = p1[2], + l4$1 = listInserts(l0, m0), + f0$1 = + function(y0){ + var + _aP_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _aQ_ = caml_call1(UIML_Datatypes[2], _aP_), + _aR_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _aS_ = caml_call1(UIML_Datatypes[1], _aR_); + return [0, caml_call2(UIML_Datatypes[4], _aS_, _aQ_), y0]; + }, + x5$0 = coq_InT_map_iff(f0$1, l4$1)(x4$0)[1], + i7 = caml_call1(x5$0, i6), + p2 = i7[2], + x6$0 = i7[1], + i8 = p2[2], + l4$3 = list_of_splits(l0)[1], + f0$2 = + function(y0){ + var + _aN_ = [0, m0, caml_call1(UIML_Datatypes[2], y0)], + _aO_ = caml_call1(UIML_Datatypes[1], y0); + return caml_call2(UIML_Datatypes[4], _aO_, _aN_); + }, + x7$0 = coq_InT_map_iff(f0$2, l4$3)(x6$0)[1], + i9 = caml_call1(x7$0, i8), + x8$0 = i9[1], + l5 = x8$0[2], + l4$2 = x8$0[1], + _ax_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _ay_ = + [0, caml_call1(UIML_Datatypes[2], _ax_), [0, l4$2, [0, l5, symbol]]], + _az_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _aA_ = [0, m0, [0, m1, [0, caml_call1(UIML_Datatypes[1], _az_), _ay_]]]; + if(n0) + if(l) + var + tl = l[2], + b0 = l[1], + _aB_ = [0, b0, remove_nth(n0, [1, m0, m1], tl)]; + else + var _aB_ = 0; + else if(l) + var + tl$3 = l[2], + b0$2 = l[1], + tl$4 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$2) + ? tl$3 + : [0, b0$2, tl$3], + _aB_ = tl$4; + else + var _aB_ = 0; + var + _aC_ = nth_split(n0, _aB_), + _aD_ = [0, m1, caml_call1(UIML_Datatypes[2], _aC_)]; + if(n0) + if(l) + var + tl$0 = l[2], + b0$0 = l[1], + _aE_ = [0, b0$0, remove_nth(n0, [1, m0, m1], tl$0)]; + else + var _aE_ = 0; + else if(l) + var + tl$1 = l[2], + b0$1 = l[1], + tl$2 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$1) + ? tl$1 + : [0, b0$1, tl$1], + _aE_ = tl$2; + else + var _aE_ = 0; + var + _aF_ = nth_split(n0, _aE_), + _aG_ = caml_call1(UIML_Datatypes[1], _aF_), + _aH_ = [0, [0, caml_call2(UIML_Datatypes[4], _aG_, _aD_), l0], _aA_], + _aI_ = caml_call2(UIML_Datatypes[4], l4$2, [0, m0, l5]), + _aJ_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _aK_ = caml_call1(UIML_Datatypes[2], _aJ_), + _aL_ = nth_split(n0, remove_nth([0, n0], [1, m0, m1], l)), + _aM_ = caml_call1(UIML_Datatypes[1], _aL_); + return [0, + n0, + [0, [0, caml_call2(UIML_Datatypes[4], _aM_, _aK_), _aI_], _aH_]]; + } + var + s0 = f(l3, x), + s1 = s0[2], + x0 = s0[1], + s2 = s1[2], + x1 = s1[1], + s3 = s2[2], + x2 = s2[1], + s4 = s3[2], + x3 = s3[1], + s5 = s4[2], + x4 = s4[1], + s6 = s5[2], + x5 = s5[1], + s7 = s6[2], + x6 = s6[1], + s8 = s7[2], + x7 = s7[1], + x8 = s8[1]; + return [0, + x0, + [0, + x1, + [0, + x2, + [0, x3, [0, x4, [0, x5, [0, x6, [0, x7, [0, x8, symbol]]]]]]]]]; + } + return function(_ab_){return f(l1, _ab_);}; + } + function coq_ImpL_help1(prem, s, x){ + var + s0 = + coq_ImpL_help01 + (prem, s, pos_top_imps(caml_call1(UIML_Datatypes[1], s))) + (x), + s1 = s0[2], + x0 = s0[1], + s2 = s1[2], + s3 = s2[2], + s4 = s3[2], + x1 = s3[1], + s5 = s4[2], + x2 = s4[1], + s6 = s5[2], + s7 = s6[2], + s8 = s7[2], + x3 = s7[1], + x4 = s8[1], + l0 = s[2], + l = s[1], + i = + coq_In_pos_top_imps_split_l + (caml_call1(UIML_Datatypes[1], [0, l, l0]), [1, x1, x2], x0), + x5 = i[1], + _Z_ = remove_nth([0, caml_call1(UIML_Datatypes[3], x5)], [1, x1, x2], l), + ___ = nth_split(caml_call1(UIML_Datatypes[3], x5), _Z_), + UU0393_0 = caml_call1(UIML_Datatypes[1], ___), + _$_ = remove_nth([0, caml_call1(UIML_Datatypes[3], x5)], [1, x1, x2], l), + _aa_ = nth_split(caml_call1(UIML_Datatypes[3], x5), _$_), + UU0393_1 = caml_call1(UIML_Datatypes[2], _aa_); + return [0, x1, x2, UU0393_0, UU0393_1, x3, x4]; + } + function finite_ImpL_premises_of_S(param){ + var l0 = param[2], l = param[1]; + return [0, + prems_Imp_L(pos_top_imps(l), [0, l, l0]), + function(prems){ + return [0, + function(h){ + var + UU0394_1 = h[6], + UU0394_0 = h[5], + UU0393_1 = h[4], + UU0393_0 = h[3], + b = h[2], + a = h[1], + _U_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _V_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _U_], + _W_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _X_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _W_], + _Y_ = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]); + return coq_ImpL_help2 + ([0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _Y_], + _X_, + _V_, + h); + }, + function(h){return coq_ImpL_help1(prems, [0, l, l0], h);}]; + }]; + } + function prems_Box_R(l, s){ + var l$0 = l; + for(;;){ + if(! l$0) return 0; + var t = l$0[2], h = l$0[1]; + if(typeof h !== "number" && 2 === h[0]){ + var + a = h[1], + _Q_ = prems_Box_R(t, s), + _R_ = caml_call1(UIML_Datatypes[1], s), + _S_ = caml_call1(UIML_CML_Syntax[9], _R_), + _T_ = caml_call1(UIML_GLS_calcs[1], _S_); + return [0, + [0, + [0, + caml_call2(UIML_Datatypes[4], _T_, [0, [2, a], 0]), + [0, a, 0]], + 0], + _Q_]; + } + l$0 = t; + } + } + function coq_GLR_help01(prems, s, l1, x){ + if(! l1) throw caml_maybe_attach_backtrace([0, Assert_failure, _w_], 1); + var l = l1[2], y = l1[1]; + if(typeof y !== "number" && 2 === y[0]){ + var m = y[1]; + if(0 === x[0]) return [0, m, symbol]; + var x0$0 = x[3], h0 = coq_GLR_help01(prems, s, l, x0$0), x1$0 = h0[1]; + return [0, x1$0, symbol]; + } + var x0 = coq_GLR_help01(prems, s, l, x), x1 = x0[1]; + return [0, x1, symbol]; + } + function coq_GLR_help1(prems, s, x){ + var + _M_ = caml_call1(UIML_Datatypes[2], s), + s0 = coq_GLR_help01(prems, s, caml_call1(UIML_CML_Syntax[9], _M_), x), + x0 = s0[1], + l0 = s[2], + l = s[1], + h = caml_call2(UIML_List_lems[1], [2, x0], l0), + s1 = h[2], + x1 = h[1], + x2 = s1[1], + _N_ = top_boxes_nobox_gen_ext(l), + _O_ = [0, l, caml_call2(UIML_Datatypes[4], x1, [0, [2, x0], x2])], + _P_ = caml_call1(UIML_Datatypes[1], _O_); + return [0, x0, caml_call1(UIML_CML_Syntax[9], _P_), l, x1, x2, _N_]; + } + function coq_GLR_help02(UU0393, UU0394_0, UU0394_1, b_UU0393, a, l, x, x0){ + var l$0 = l; + for(;;){ + if(! l$0) throw caml_maybe_attach_backtrace([0, Assert_failure, _y_], 1); + var l0 = l$0[2], y = l$0[1]; + if(typeof y !== "number" && 2 === y[0]){ + var + m = y[1], + h0$0 = caml_call2(UIML_List_lems[1], [2, a], [0, [2, m], l0]), + s$0 = h0$0[2], + x1 = h0$0[1], + x2$0 = s$0[1], + _E_ = [1, caml_call2(UIML_GenT[1], [2, a], x2$0)], + h1$0 = + caml_call4(UIML_List_lemmasT[2], x1, [0, [2, a], x2$0], [2, a], _E_); + if(0 === h1$0[0]){ + var + _F_ = + prems_Box_R + (l0, + [0, + UU0393, + caml_call2(UIML_Datatypes[4], UU0394_0, [0, [2, a], UU0394_1])]), + _G_ = caml_call1(UIML_CML_Syntax[9], UU0393), + _H_ = caml_call1(UIML_GLS_calcs[1], _G_), + _I_ = + [0, + [0, caml_call2(UIML_Datatypes[4], _H_, [0, [2, a], 0]), [0, a, 0]], + 0]; + return caml_call2(UIML_GenT[1], _I_, _F_); + } + var + i = coq_GLR_help02(UU0393, UU0394_0, UU0394_1, b_UU0393, a, l0, x, x0), + _J_ = + prems_Box_R + (l0, + [0, + UU0393, + caml_call2(UIML_Datatypes[4], UU0394_0, [0, [2, a], UU0394_1])]), + _K_ = caml_call1(UIML_CML_Syntax[9], UU0393), + _L_ = caml_call1(UIML_GLS_calcs[1], _K_); + return [1, + [0, + [0, + caml_call2(UIML_Datatypes[4], _L_, [0, [2, m], 0]), + [0, m, 0]], + 0], + _J_, + i]; + } + var + h0 = caml_call2(UIML_List_lems[1], [2, a], [0, y, l0]), + s = h0[2], + x2 = h0[1], + x3 = s[1], + _D_ = [1, caml_call2(UIML_GenT[1], [2, a], x3)], + h1 = caml_call4(UIML_List_lemmasT[2], x2, [0, [2, a], x3], [2, a], _D_); + if(0 === h1[0]) + throw caml_maybe_attach_backtrace([0, Assert_failure, _x_], 1); + l$0 = l0; + } + } + function coq_GLR_help2(param, _B_, x){ + var + x0 = x[6], + UU0394_1 = x[5], + UU0394_0 = x[4], + UU0393_0 = x[3], + b_UU0393 = x[2], + a = x[1], + _C_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, [2, a], UU0394_1]); + return coq_GLR_help02 + (UU0393_0, + UU0394_0, + UU0394_1, + b_UU0393, + a, + caml_call1(UIML_CML_Syntax[9], _C_), + x, + x0); + } + function finite_GLR_premises_of_S(param){ + var l0 = param[2], l = param[1]; + return [0, + prems_Box_R(caml_call1(UIML_CML_Syntax[9], l0), [0, l, l0]), + function(prems){ + return [0, + function(x){ + var + UU0394_1 = x[5], + UU0394_0 = x[4], + b_UU0393 = x[2], + a = x[1], + _z_ = + [0, + l, + caml_call2 + (UIML_Datatypes[4], UU0394_0, [0, [2, a], UU0394_1])], + _A_ = caml_call1(UIML_GLS_calcs[1], b_UU0393); + return coq_GLR_help2 + ([0, + caml_call2(UIML_Datatypes[4], _A_, [0, [2, a], 0]), + [0, a, 0]], + _z_, + x); + }, + function(h){return coq_GLR_help1(prems, [0, l, l0], h);}]; + }]; + } + var + UIML_GLS_der_dec = + [0, + proj1_sigT2, + proj2_sigT2, + coq_In_InT_pair, + coq_InT_map_iff, + pos_top_imps, + top_boxes_nobox_gen_ext, + flatten_list, + coq_InT_flatten_list_InT_elem, + coq_InT_trans_flatten_list, + list_of_splits, + listInserts, + listInsertsR_Seqs, + listInsertsL_Seqs, + remove_nth, + nth_split, + prems_Imp_R, + coq_In_pos_top_imps_split_l, + coq_ImpR_help01, + coq_ImpR_help1, + coq_ImpR_help002, + coq_ImpR_help02, + coq_ImpR_help2, + finite_ImpR_premises_of_S, + prems_Imp_L, + coq_ImpL_help002, + coq_ImpL_help02, + coq_ImpL_help2, + coq_ImpL_help01, + coq_ImpL_help1, + finite_ImpL_premises_of_S, + prems_Box_R, + coq_GLR_help01, + coq_GLR_help1, + coq_GLR_help02, + coq_GLR_help2, + finite_GLR_premises_of_S]; + runtime.caml_register_global(34, UIML_GLS_der_dec, "UIML__GLS_der_dec"); + return; + } + (globalThis)); + +//# 4215 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_Remove_list_lems = global_data.UIML__Remove_list_lems, + UIML_Datatypes = global_data.UIML__Datatypes, + UIML_CML_Syntax = global_data.UIML__CML_Syntax; + function subform_boxesF(param){ + if(typeof param !== "number") + switch(param[0]){ + case 1: + var + c = param[2], + b = param[1], + _l_ = subform_boxesF(c), + _m_ = subform_boxesF(b), + _n_ = caml_call2(UIML_Remove_list_lems[2], _m_, _l_), + _o_ = subform_boxesF(b); + return caml_call2(UIML_Datatypes[4], _o_, _n_); + case 2: + var b$0 = param[1]; return [0, [2, b$0], subform_boxesF(b$0)]; + } + return 0; + } + function subform_boxesLF(param){ + if(! param) return 0; + var + t = param[2], + h = param[1], + _h_ = subform_boxesLF(t), + _i_ = subform_boxesF(h), + _j_ = caml_call2(UIML_Remove_list_lems[2], _i_, _h_), + _k_ = subform_boxesF(h); + return caml_call2(UIML_Datatypes[4], _k_, _j_); + } + function subform_boxesS(s){ + var + _d_ = subform_boxesLF(caml_call1(UIML_Datatypes[2], s)), + _e_ = subform_boxesLF(caml_call1(UIML_Datatypes[1], s)), + _f_ = caml_call2(UIML_Remove_list_lems[2], _e_, _d_), + _g_ = subform_boxesLF(caml_call1(UIML_Datatypes[1], s)); + return caml_call2(UIML_Datatypes[4], _g_, _f_); + } + function usable_boxes(s){ + var + _a_ = subform_boxesS(s), + _b_ = caml_call1(UIML_Datatypes[1], s), + _c_ = caml_call1(UIML_CML_Syntax[9], _b_); + return caml_call2(UIML_Remove_list_lems[2], _c_, _a_); + } + var + UIML_GLS_termination_measure = + [0, subform_boxesF, subform_boxesLF, subform_boxesS, usable_boxes]; + runtime.caml_register_global + (3, UIML_GLS_termination_measure, "UIML__GLS_termination_measure"); + return; + } + (globalThis)); + +//# 4297 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_List_lems = global_data.UIML__List_lems, + UIML_Remove_list_lems = global_data.UIML__Remove_list_lems; + function symbol(param){return symbol;} + function dec_is_PropVar(param){ + if(typeof param !== "number" && 0 === param[0]){var s = param[1]; return [0, [0, s, symbol]];} + return [1, symbol]; + } + function dec_prop_var_in(param){ + var l0 = param[2], l = param[1]; + function f(param){ + if(! param) return [1, symbol]; + var l2 = param[2], y = param[1], match = f(l2); + if(0 === match[0]){ + var s0 = match[1], x = s0[1]; + return [0, [0, x, symbol]]; + } + var s0$0 = dec_is_PropVar(y); + if(0 !== s0$0[0]) return [1, symbol]; + var s1 = s0$0[1], s2 = caml_call2(UIML_Remove_list_lems[1], l0, y); + if(! s2) return [1, symbol]; + var x$0 = s1[1]; + return [0, [0, x$0, symbol]]; + } + return f(l); + } + function dec_KS_init_rules(param){ + var l0 = param[2], l = param[1], s0 = dec_prop_var_in([0, l, l0]); + if(0 === s0[0]){ + var + s1 = s0[1], + x = s1[1], + h = caml_call2(UIML_List_lems[1], [0, x], l), + s2 = h[2], + x0 = h[1], + x1 = s2[1], + h0 = caml_call2(UIML_List_lems[1], [0, x], l0), + s3 = h0[2], + x2 = h0[1], + x3 = s3[1]; + return [0, [0, [0, x, x0, x1, x2, x3]]]; + } + var s1$0 = caml_call2(UIML_Remove_list_lems[1], l, 0); + if(! s1$0) return [1, symbol]; + var + i = caml_call2(UIML_List_lems[1], 0, l), + s2$0 = i[2], + x$0 = i[1], + x0$0 = s2$0[1]; + return [0, [1, [0, x$0, x0$0, l0]]]; + } + var UIML_KS_dec = [0, dec_is_PropVar, dec_prop_var_in, dec_KS_init_rules]; + runtime.caml_register_global(2, UIML_KS_dec, "UIML__KS_dec"); + return; + } + (globalThis)); + +//# 4366 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_extraction_KS_termination_ = "extraction/KS_termination_prelims.ml", + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call4(f, a0, a1, a2, a3){ + return (f.l >= 0 ? f.l : f.l = f.length) == 4 + ? f(a0, a1, a2, a3) + : runtime.caml_call_gen(f, [a0, a1, a2, a3]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_CML_Syntax = global_data.UIML__CML_Syntax, + UIML_PeanoNat = global_data.UIML__PeanoNat, + UIML_GenT = global_data.UIML__GenT, + Assert_failure = global_data.Assert_failure, + UIML_List = global_data.UIML__List, + UIML_Datatypes = global_data.UIML__Datatypes, + UIML_List_lemmasT = global_data.UIML__List_lemmasT, + _a_ = [0, cst_extraction_KS_termination_, 27, 8], + _b_ = [0, cst_extraction_KS_termination_, 44, 4], + _c_ = [0, cst_extraction_KS_termination_, 43, 23], + _d_ = [0, 0], + _e_ = [0, cst_extraction_KS_termination_, 103, 10], + _f_ = [0, cst_extraction_KS_termination_, 120, 10], + _g_ = [0, [0, 0, 0], 0], + _h_ = [0, 0, 0], + _i_ = [0, 0, 0]; + function symbol(param){return symbol;} + function proj1_sigT2(param){var a = param[1]; return a;} + function proj2_sigT2(param){var b = param[2]; return b;} + function coq_In_InT_pair(a, n, param){ + if(! param) + throw caml_maybe_attach_backtrace([0, Assert_failure, _a_], 1); + var + l0 = param[2], + y = param[1], + n0 = y[2], + m = y[1], + s = caml_call2(UIML_CML_Syntax[6], a, m), + h0 = s ? caml_call2(UIML_PeanoNat[1][1], n, n0) : 0; + return h0 + ? caml_call2(UIML_GenT[1], [0, a, n], l0) + : [1, y, l0, coq_In_InT_pair(a, n, l0)]; + } + function coq_InT_map_iff(f, param){ + if(! param) + return function(param){ + return [0, + function(param){ + throw caml_maybe_attach_backtrace([0, Assert_failure, _c_], 1); + }, + function(param){ + throw caml_maybe_attach_backtrace([0, Assert_failure, _b_], 1); + }];}; + var l0 = param[2], y = param[1], iHl = coq_InT_map_iff(f, l0); + return function(y0){ + return [0, + function(x){ + if(0 === x[0]) + return [0, y, [0, symbol, caml_call2(UIML_GenT[1], y, l0)]]; + var + x0 = x[3], + p = iHl(y0), + s = p[1], + x1 = caml_call1(s, x0), + p0 = x1[2], + x2 = x1[1], + i = p0[2]; + return [0, x2, [0, symbol, [1, y, l0, i]]]; + }, + function(x){ + var p = iHl(y0), i = p[2], p0 = x[2], i0 = p0[2]; + if(0 === i0[0]){ + var + _D_ = caml_call2(UIML_List[4], f, l0), + _E_ = caml_call1(f, y); + return caml_call2(UIML_GenT[1], _E_, _D_); + } + var + x0 = i0[3], + a = x[1], + x1 = [0, a, [0, symbol, x0]], + x2 = caml_call1(i, x1), + _F_ = caml_call2(UIML_List[4], f, l0); + return [1, caml_call1(f, y), _F_, x2]; + }];}; + } + function pos_top_imps(param){ + if(! param) return 0; + var t = param[2], h = param[1]; + if(typeof h !== "number" && 1 === h[0]){ + var b = h[2], a = h[1], _A_ = pos_top_imps(t); + return [0, + [0, [1, a, b], _d_], + caml_call2 + (UIML_List[4], + function(y){ + var _C_ = [0, caml_call1(UIML_Datatypes[2], y)]; + return [0, caml_call1(UIML_Datatypes[1], y), _C_]; + }, + _A_)]; + } + var _z_ = pos_top_imps(t); + return caml_call2 + (UIML_List[4], + function(y){ + var _B_ = [0, caml_call1(UIML_Datatypes[2], y)]; + return [0, caml_call1(UIML_Datatypes[1], y), _B_]; + }, + _z_); + } + function top_boxes_nobox_gen_ext(param){ + if(! param) return 0; + var l0 = param[2], y = param[1]; + if(typeof y !== "number" && 2 === y[0]){ + var m = y[1], _y_ = top_boxes_nobox_gen_ext(l0); + return [0, [2, m], caml_call1(UIML_CML_Syntax[9], l0), l0, _y_]; + } + var _x_ = top_boxes_nobox_gen_ext(l0); + return [1, y, caml_call1(UIML_CML_Syntax[9], l0), l0, symbol, _x_]; + } + function flatten_list(param){ + if(! param) return 0; + var t = param[2], h = param[1], _w_ = flatten_list(t); + return caml_call2(UIML_Datatypes[4], h, _w_); + } + function coq_InT_flatten_list_InT_elem(l, b, x){ + if(! l) throw caml_maybe_attach_backtrace([0, Assert_failure, _e_], 1); + var + l0 = l[2], + y = l[1], + _v_ = flatten_list(l0), + x0 = caml_call4(UIML_List_lemmasT[1], y, _v_, b, x); + if(0 === x0[0]){ + var i = x0[1]; + return [0, y, [0, i, caml_call2(UIML_GenT[1], y, l0)]]; + } + var + i$0 = x0[1], + i0 = coq_InT_flatten_list_InT_elem(l0, b, i$0), + p = i0[2], + x1 = i0[1], + i2 = p[2], + i1 = p[1]; + return [0, x1, [0, i1, [1, y, l0, i2]]]; + } + function coq_InT_trans_flatten_list(l, bs, b, x, x0){ + if(! l) throw caml_maybe_attach_backtrace([0, Assert_failure, _f_], 1); + var l0 = l[2], y = l[1]; + if(0 === x0[0]){ + var _s_ = flatten_list(l0); + return caml_call4(UIML_List_lemmasT[2], bs, _s_, b, [0, x]); + } + var + x1 = x0[3], + _t_ = [1, coq_InT_trans_flatten_list(l0, bs, b, x, x1)], + _u_ = flatten_list(l0); + return caml_call4(UIML_List_lemmasT[2], y, _u_, b, _t_); + } + function list_of_splits(param){ + if(! param) return [0, _g_, symbol]; + var + l0 = param[2], + y = param[1], + x = list_of_splits(l0)[1], + _q_ = + caml_call2 + (UIML_List[4], + function(y0){ + var _r_ = caml_call1(UIML_Datatypes[2], y0); + return [0, [0, y, caml_call1(UIML_Datatypes[1], y0)], _r_]; + }, + x); + return [0, + caml_call2(UIML_Datatypes[4], [0, [0, 0, [0, y, l0]], 0], _q_), + symbol]; + } + function listInserts(l, a){ + var a$0 = list_of_splits(l)[1]; + return caml_call2 + (UIML_List[4], + function(y){ + var + _o_ = [0, a, caml_call1(UIML_Datatypes[2], y)], + _p_ = caml_call1(UIML_Datatypes[1], y); + return caml_call2(UIML_Datatypes[4], _p_, _o_); + }, + a$0); + } + function listInsertsR_Seqs(UU0393, UU0394, a){ + var _n_ = listInserts(UU0393, a); + return caml_call2(UIML_List[4], function(y){return [0, y, UU0394];}, _n_); + } + function listInsertsL_Seqs(UU0393, UU0394, a){ + var _m_ = listInserts(UU0394, a); + return caml_call2(UIML_List[4], function(y){return [0, UU0393, y];}, _m_); + } + function remove_nth(n, a, l){ + if(! n) return l; + var m = n[1]; + if(m){ + if(! l) return 0; + var tl = l[2], b = l[1]; + return [0, b, remove_nth(m, a, tl)]; + } + if(! l) return 0; + var tl$0 = l[2], b$0 = l[1]; + return caml_call2(UIML_CML_Syntax[6], a, b$0) ? tl$0 : [0, b$0, tl$0]; + } + function nth_split(n, l){ + if(! n) return [0, 0, l]; + var m = n[1]; + if(m){ + if(! l) return _h_; + var + tl = l[2], + b = l[1], + _j_ = nth_split(m, tl), + _k_ = caml_call1(UIML_Datatypes[2], _j_), + _l_ = nth_split(m, tl); + return [0, [0, b, caml_call1(UIML_Datatypes[1], _l_)], _k_]; + } + if(! l) return _i_; + var tl$0 = l[2], b$0 = l[1]; + return [0, [0, b$0, 0], tl$0]; + } + var + UIML_KS_termination_prelims = + [0, + proj1_sigT2, + proj2_sigT2, + coq_In_InT_pair, + coq_InT_map_iff, + pos_top_imps, + top_boxes_nobox_gen_ext, + flatten_list, + coq_InT_flatten_list_InT_elem, + coq_InT_trans_flatten_list, + list_of_splits, + listInserts, + listInsertsR_Seqs, + listInsertsL_Seqs, + remove_nth, + nth_split]; + runtime.caml_register_global + (16, UIML_KS_termination_prelims, "UIML__KS_termination_prelims"); + return; + } + (globalThis)); + +//# 4631 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_extraction_KS_termination_ = "extraction/KS_termination_ImpR.ml", + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + function caml_call4(f, a0, a1, a2, a3){ + return (f.l >= 0 ? f.l : f.l = f.length) == 4 + ? f(a0, a1, a2, a3) + : runtime.caml_call_gen(f, [a0, a1, a2, a3]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_Datatypes = global_data.UIML__Datatypes, + UIML_KS_termination_prelims = global_data.UIML__KS_termination_prelims, + UIML_List = global_data.UIML__List, + Assert_failure = global_data.Assert_failure, + UIML_List_lemmasT = global_data.UIML__List_lemmasT, + UIML_CML_Syntax = global_data.UIML__CML_Syntax, + UIML_List_lems = global_data.UIML__List_lems, + _a_ = [0, cst_extraction_KS_termination_, 59, 15], + _b_ = [0, 0], + _c_ = [0, cst_extraction_KS_termination_, 51, 18], + _d_ = [0, cst_extraction_KS_termination_, 39, 10], + _e_ = [0, cst_extraction_KS_termination_, 75, 12], + _f_ = [0, cst_extraction_KS_termination_, 343, 28], + _g_ = [0, cst_extraction_KS_termination_, 249, 18], + _h_ = [0, cst_extraction_KS_termination_, 228, 10]; + function symbol(param){return symbol;} + function prems_Imp_R(l, s){ + var l$0 = l; + for(;;){ + if(! l$0) return 0; + var t = l$0[2], p = l$0[1], n = p[2], c = p[1]; + if(n){ + var m = n[1]; + if(typeof c !== "number" && 1 === c[0]){ + var + b = c[2], + a = c[1], + _bm_ = prems_Imp_R(t, s), + _bn_ = caml_call1(UIML_Datatypes[2], s), + _bo_ = caml_call3(UIML_KS_termination_prelims[14], [0, m], c, _bn_), + _bp_ = caml_call2(UIML_KS_termination_prelims[15], m, _bo_), + _bq_ = [0, b, caml_call1(UIML_Datatypes[2], _bp_)], + _br_ = caml_call1(UIML_Datatypes[2], s), + _bs_ = caml_call3(UIML_KS_termination_prelims[14], [0, m], c, _br_), + _bt_ = caml_call2(UIML_KS_termination_prelims[15], m, _bs_), + _bu_ = caml_call1(UIML_Datatypes[1], _bt_), + _bv_ = caml_call2(UIML_Datatypes[4], _bu_, _bq_), + _bw_ = caml_call1(UIML_Datatypes[1], s), + _bx_ = caml_call3(UIML_KS_termination_prelims[12], _bw_, _bv_, a); + return caml_call2(UIML_Datatypes[4], _bx_, _bm_); + } + l$0 = t; + } + else + l$0 = t; + } + } + function coq_In_pos_top_imps_split_l(l, a, n){ + if(! l) throw caml_maybe_attach_backtrace([0, Assert_failure, _d_], 1); + var l0 = l[2], y = l[1]; + if(typeof y !== "number" && 1 === y[0]){ + var + m0 = y[2], + m = y[1], + _bj_ = caml_call1(UIML_KS_termination_prelims[5], l0), + _bk_ = + [0, + [0, [1, m, m0], _b_], + caml_call2 + (UIML_List[4], + function(y0){ + var _bl_ = [0, caml_call1(UIML_Datatypes[2], y0)]; + return [0, caml_call1(UIML_Datatypes[1], y0), _bl_]; + }, + _bj_)], + h = caml_call3(UIML_KS_termination_prelims[3], a, [0, n], _bk_); + if(0 === h[0]) return [0, 0, [0, l0, symbol]]; + if(! n) throw caml_maybe_attach_backtrace([0, Assert_failure, _c_], 1); + var + n0$0 = n[1], + s$0 = coq_In_pos_top_imps_split_l(l0, a, n0$0), + s0$0 = s$0[2], + x = s$0[1], + x0$0 = s0$0[1]; + return [0, [0, [1, m, m0], x], [0, x0$0, symbol]]; + } + if(! n) throw caml_maybe_attach_backtrace([0, Assert_failure, _a_], 1); + var + n0 = n[1], + s = coq_In_pos_top_imps_split_l(l0, a, n0), + s0 = s[2], + x0 = s[1], + x1 = s0[1]; + return [0, [0, y, x0], [0, x1, symbol]]; + } + function coq_ImpR_help01(prem, s, l3){ + var l0 = s[2], l = s[1]; + function f(l1, x){ + if(! l1) throw caml_maybe_attach_backtrace([0, Assert_failure, _e_], 1); + var l2 = l1[2], y = l1[1], n = y[2], m = y[1]; + if(typeof m !== "number" && 1 === m[0]){ + var m1 = m[2], m0 = m[1]; + if(! n){ + var + s0$1 = f(l2, x), + s1$1 = s0$1[2], + x0$1 = s0$1[1], + s2$1 = s1$1[2], + x1$2 = s1$1[1], + s3$1 = s2$1[2], + x2$2 = s2$1[1], + s4$1 = s3$1[2], + x3$2 = s3$1[1], + s5$1 = s4$1[2], + x4$2 = s4$1[1], + s6$1 = s5$1[2], + x5$1 = s5$1[1], + x6$1 = s6$1[1]; + return [0, + x0$1, + [0, + x1$2, + [0, x2$2, [0, x3$2, [0, x4$2, [0, x5$1, [0, x6$1, symbol]]]]]]]; + } + var + n0 = n[1], + prems_Imp_R0 = + function(l4, s0){ + var l4$0 = l4; + for(;;){ + if(! l4$0) return 0; + var l4$1 = l4$0[2], p = l4$0[1], n1 = p[2], c = p[1]; + if(n1){ + var m2 = n1[1]; + if(typeof c !== "number" && 1 === c[0]){ + var + b = c[2], + a = c[1], + _a9_ = prems_Imp_R0(l4$1, s0), + _a__ = caml_call1(UIML_Datatypes[2], s0), + _a$_ = + caml_call3(UIML_KS_termination_prelims[14], [0, m2], c, _a__), + _ba_ = caml_call2(UIML_KS_termination_prelims[15], m2, _a$_), + _bb_ = [0, b, caml_call1(UIML_Datatypes[2], _ba_)], + _bc_ = caml_call1(UIML_Datatypes[2], s0), + _bd_ = + caml_call3(UIML_KS_termination_prelims[14], [0, m2], c, _bc_), + _be_ = caml_call2(UIML_KS_termination_prelims[15], m2, _bd_), + _bf_ = caml_call1(UIML_Datatypes[1], _be_), + _bg_ = caml_call2(UIML_Datatypes[4], _bf_, _bb_), + _bh_ = caml_call1(UIML_Datatypes[1], s0), + _bi_ = + caml_call3(UIML_KS_termination_prelims[12], _bh_, _bg_, a); + return caml_call2(UIML_Datatypes[4], _bi_, _a9_); + } + l4$0 = l4$1; + } + else + l4$0 = l4$1; + } + }, + _aJ_ = prems_Imp_R0(l2, [0, l, l0]), + _aK_ = caml_call1(UIML_Datatypes[2], [0, l, l0]), + _aL_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], _aK_), + _aM_ = caml_call2(UIML_KS_termination_prelims[15], n0, _aL_), + _aN_ = [0, m1, caml_call1(UIML_Datatypes[2], _aM_)], + _aO_ = caml_call1(UIML_Datatypes[2], [0, l, l0]), + _aP_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], _aO_), + _aQ_ = caml_call2(UIML_KS_termination_prelims[15], n0, _aP_), + _aR_ = caml_call1(UIML_Datatypes[1], _aQ_), + _aS_ = caml_call2(UIML_Datatypes[4], _aR_, _aN_), + _aT_ = caml_call1(UIML_Datatypes[1], [0, l, l0]), + _aU_ = caml_call3(UIML_KS_termination_prelims[12], _aT_, _aS_, m0), + x0$0 = caml_call4(UIML_List_lemmasT[1], _aU_, _aJ_, prem, x); + if(0 === x0$0[0]){ + var + i = x0$0[1], + l4 = caml_call2(UIML_KS_termination_prelims[11], l, m0), + f0 = + function(y0){ + var + _a3_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l0), + _a4_ = caml_call2(UIML_KS_termination_prelims[15], n0, _a3_), + _a5_ = [0, m1, caml_call1(UIML_Datatypes[2], _a4_)], + _a6_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l0), + _a7_ = caml_call2(UIML_KS_termination_prelims[15], n0, _a6_), + _a8_ = caml_call1(UIML_Datatypes[1], _a7_); + return [0, y0, caml_call2(UIML_Datatypes[4], _a8_, _a5_)]; + }, + x1$0 = caml_call3(UIML_KS_termination_prelims[4], f0, l4, prem)[1], + i0 = caml_call1(x1$0, i), + p = i0[2], + x2$0 = i0[1], + i1 = p[2], + _aV_ = caml_call1(UIML_KS_termination_prelims[10], l), + l4$0 = caml_call1(UIML_KS_termination_prelims[1], _aV_), + f0$0 = + function(y0){ + var + _a1_ = [0, m0, caml_call1(UIML_Datatypes[2], y0)], + _a2_ = caml_call1(UIML_Datatypes[1], y0); + return caml_call2(UIML_Datatypes[4], _a2_, _a1_); + }, + x3$0 = caml_call3(UIML_KS_termination_prelims[4], f0$0, l4$0, x2$0)[1], + i2 = caml_call1(x3$0, i1), + x4$0 = i2[1], + l5 = x4$0[2], + l4$1 = x4$0[1], + _aW_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l0), + _aX_ = caml_call2(UIML_KS_termination_prelims[15], n0, _aW_), + _aY_ = [0, caml_call1(UIML_Datatypes[2], _aX_), symbol], + _aZ_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l0), + _a0_ = caml_call2(UIML_KS_termination_prelims[15], n0, _aZ_); + return [0, + n0, + [0, + m0, + [0, + m1, + [0, + l4$1, + [0, l5, [0, caml_call1(UIML_Datatypes[1], _a0_), _aY_]]]]]]; + } + var + i$0 = x0$0[1], + s0$0 = f(l2, i$0), + s1$0 = s0$0[2], + x1$1 = s0$0[1], + s2$0 = s1$0[2], + x2$1 = s1$0[1], + s3$0 = s2$0[2], + x3$1 = s2$0[1], + s4$0 = s3$0[2], + x4$1 = s3$0[1], + s5$0 = s4$0[2], + x5$0 = s4$0[1], + s6$0 = s5$0[2], + x6$0 = s5$0[1], + x7 = s6$0[1]; + return [0, + x1$1, + [0, + x2$1, + [0, x3$1, [0, x4$1, [0, x5$0, [0, x6$0, [0, x7, symbol]]]]]]]; + } + var + s0 = f(l2, x), + s1 = s0[2], + x0 = s0[1], + s2 = s1[2], + x1 = s1[1], + s3 = s2[2], + x2 = s2[1], + s4 = s3[2], + x3 = s3[1], + s5 = s4[2], + x4 = s4[1], + s6 = s5[2], + x5 = s5[1], + x6 = s6[1]; + return [0, + x0, + [0, x1, [0, x2, [0, x3, [0, x4, [0, x5, [0, x6, symbol]]]]]]]; + } + return function(_aI_){return f(l3, _aI_);}; + } + function coq_ImpR_help1(prem, s, x){ + var + _aH_ = caml_call1(UIML_Datatypes[2], s), + s0 = + coq_ImpR_help01 + (prem, s, caml_call1(UIML_KS_termination_prelims[5], _aH_)) + (x), + s1 = s0[2], + x0 = s0[1], + l = s[2], + s2 = s1[2], + x1 = s1[1], + s3 = s2[2], + x2 = s2[1], + s4 = s3[2], + x3 = s3[1], + x4 = s4[1], + i = coq_In_pos_top_imps_split_l(l, [1, x1, x2], x0), + s5 = i[2], + x5 = i[1], + x6 = s5[1]; + return [0, x1, x2, x3, x4, x5, x6]; + } + function coq_ImpR_help002(UU0393_0, UU0393_1, UU0394_0, UU0394_1, a, b){ + function f(y){ + return [0, y, caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1])]; + } + var + _az_ = caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), + l = caml_call2(UIML_KS_termination_prelims[11], _az_, a), + _aA_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1]), + y = [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), _aA_], + x = caml_call3(UIML_KS_termination_prelims[4], f, l, y)[2]; + function f0(y0){ + var + _aF_ = [0, a, caml_call1(UIML_Datatypes[2], y0)], + _aG_ = caml_call1(UIML_Datatypes[1], y0); + return caml_call2(UIML_Datatypes[4], _aG_, _aF_); + } + var + _aB_ = caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), + _aC_ = caml_call1(UIML_KS_termination_prelims[10], _aB_), + l0 = caml_call1(UIML_KS_termination_prelims[1], _aC_), + y0 = caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + x0 = caml_call3(UIML_KS_termination_prelims[4], f0, l0, y0)[2], + _aD_ = caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), + s = caml_call1(UIML_KS_termination_prelims[10], _aD_), + x1 = s[1], + _aE_ = + [0, + symbol, + caml_call1 + (x0, + [0, + [0, UU0393_0, UU0393_1], + [0, + symbol, + caml_call2(UIML_List_lems[5], [0, UU0393_0, UU0393_1], x1)]])]; + return caml_call1 + (x, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + _aE_]); + } + function coq_ImpR_help02 + (UU0393_0, UU0393_1, UU0394_0, UU0394_1, a, b, l, n, x){ + var l$0 = l, n$0 = n; + for(;;){ + if(! l$0) throw caml_maybe_attach_backtrace([0, Assert_failure, _h_], 1); + var l0 = l$0[2], y = l$0[1], n0 = y[2], m = y[1]; + if(typeof m !== "number" && 1 === m[0]){ + var + m1 = m[2], + m0 = m[1], + h1$0 = + caml_call3 + (UIML_KS_termination_prelims[3], + [1, a, b], + [0, n$0], + [0, [0, [1, m0, m1], n0], l0]); + if(0 === h1$0[0]){ + if(UU0394_0){ + var + l1 = UU0394_0[2], + m2 = UU0394_0[1], + _v_ = + [0, + coq_ImpR_help002(UU0393_0, UU0393_1, [0, m2, l1], UU0394_1, a, b)], + _w_ = caml_call2(UIML_Datatypes[4], [0, m2, l1], [0, b, UU0394_1]), + prems_Imp_R0 = + function(l2, s){ + var l2$0 = l2; + for(;;){ + if(! l2$0) return 0; + var l2$1 = l2$0[2], p = l2$0[1], n1 = p[2], c = p[1]; + if(n1){ + var m3 = n1[1]; + if(typeof c !== "number" && 1 === c[0]){ + var + b0 = c[2], + a0 = c[1], + _an_ = prems_Imp_R0(l2$1, s), + _ao_ = caml_call1(UIML_Datatypes[2], s), + _ap_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, m3], c, _ao_), + _aq_ = caml_call2(UIML_KS_termination_prelims[15], m3, _ap_), + _ar_ = [0, b0, caml_call1(UIML_Datatypes[2], _aq_)], + _as_ = caml_call1(UIML_Datatypes[2], s), + _at_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, m3], c, _as_), + _au_ = caml_call2(UIML_KS_termination_prelims[15], m3, _at_), + _av_ = caml_call1(UIML_Datatypes[1], _au_), + _aw_ = caml_call2(UIML_Datatypes[4], _av_, _ar_), + _ax_ = caml_call1(UIML_Datatypes[1], s), + _ay_ = + caml_call3(UIML_KS_termination_prelims[12], _ax_, _aw_, a0); + return caml_call2(UIML_Datatypes[4], _ay_, _an_); + } + l2$0 = l2$1; + } + else + l2$0 = l2$1; + } + }, + _x_ = + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), _w_], + _y_ = + caml_call2 + (UIML_Datatypes[4], [0, m2, l1], [0, [1, a, b], UU0394_1]), + _z_ = + prems_Imp_R0 + (l0, [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _y_]), + _A_ = + caml_call2 + (UIML_Datatypes[4], [0, m2, l1], [0, [1, a, b], UU0394_1]), + _B_ = [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _A_], + _C_ = caml_call1(UIML_Datatypes[2], _B_), + _D_ = [0, caml_call1(UIML_Datatypes[3], [0, m2, l1])], + _E_ = + caml_call3(UIML_KS_termination_prelims[14], _D_, [1, a, b], _C_), + _F_ = caml_call1(UIML_Datatypes[3], [0, m2, l1]), + _G_ = caml_call2(UIML_KS_termination_prelims[15], _F_, _E_), + _H_ = [0, b, caml_call1(UIML_Datatypes[2], _G_)], + _I_ = + caml_call2 + (UIML_Datatypes[4], [0, m2, l1], [0, [1, a, b], UU0394_1]), + _J_ = [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _I_], + _K_ = caml_call1(UIML_Datatypes[2], _J_), + _L_ = [0, caml_call1(UIML_Datatypes[3], [0, m2, l1])], + _M_ = + caml_call3(UIML_KS_termination_prelims[14], _L_, [1, a, b], _K_), + _N_ = caml_call1(UIML_Datatypes[3], [0, m2, l1]), + _O_ = caml_call2(UIML_KS_termination_prelims[15], _N_, _M_), + _P_ = caml_call1(UIML_Datatypes[1], _O_), + _Q_ = caml_call2(UIML_Datatypes[4], _P_, _H_), + _R_ = + caml_call2 + (UIML_Datatypes[4], [0, m2, l1], [0, [1, a, b], UU0394_1]), + _S_ = [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _R_], + _T_ = caml_call1(UIML_Datatypes[1], _S_), + _U_ = caml_call3(UIML_KS_termination_prelims[12], _T_, _Q_, a); + return caml_call4(UIML_List_lemmasT[2], _U_, _z_, _x_, _v_); + } + var + i = coq_ImpR_help002(UU0393_0, UU0393_1, 0, UU0394_1, a, b), + s = caml_call2(UIML_CML_Syntax[6], [1, a, b], [1, a, b]); + if(! s) throw caml_maybe_attach_backtrace([0, Assert_failure, _g_], 1); + var + _V_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + [0, b, UU0394_1]], + _W_ = + prems_Imp_R + (l0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), + [0, [1, a, b], UU0394_1]]), + _X_ = caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), + _Y_ = + caml_call3 + (UIML_KS_termination_prelims[12], _X_, [0, b, UU0394_1], a); + return caml_call4(UIML_List_lemmasT[2], _Y_, _W_, _V_, [0, i]); + } + var + i$0 = + coq_ImpR_help02 + (UU0393_0, + UU0393_1, + UU0394_0, + UU0394_1, + a, + b, + l0, + caml_call1(UIML_Datatypes[3], UU0394_0), + x); + if(! n0) return i$0; + var + n1 = n0[1], + ___ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1]), + _$_ = + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), ___], + _aa_ = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]), + _Z_ = [1, i$0], + _ab_ = + prems_Imp_R + (l0, [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _aa_]); + if(n1){ + var + match = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]); + if(match) + var + tl = match[2], + b0 = match[1], + _ac_ = + [0, + b0, + caml_call3(UIML_KS_termination_prelims[14], n1, [1, m0, m1], tl)]; + else + var _ac_ = 0; + var _ad_ = _ac_; + } + else{ + var + match$2 = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]); + if(match$2) + var + tl$4 = match$2[2], + b0$2 = match$2[1], + tl$5 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$2) + ? tl$4 + : [0, b0$2, tl$4], + tl$6 = tl$5; + else + var tl$6 = 0; + var _ad_ = tl$6; + } + var + _ae_ = caml_call2(UIML_KS_termination_prelims[15], n1, _ad_), + _af_ = [0, m1, caml_call1(UIML_Datatypes[2], _ae_)]; + if(n1){ + var + match$0 = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]); + if(match$0) + var + tl$0 = match$0[2], + b0$0 = match$0[1], + _ag_ = + [0, + b0$0, + caml_call3(UIML_KS_termination_prelims[14], n1, [1, m0, m1], tl$0)]; + else + var _ag_ = 0; + var _ah_ = _ag_; + } + else{ + var + match$1 = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]); + if(match$1) + var + tl$1 = match$1[2], + b0$1 = match$1[1], + tl$2 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$1) + ? tl$1 + : [0, b0$1, tl$1], + tl$3 = tl$2; + else + var tl$3 = 0; + var _ah_ = tl$3; + } + var + _ai_ = caml_call2(UIML_KS_termination_prelims[15], n1, _ah_), + _aj_ = caml_call1(UIML_Datatypes[1], _ai_), + _ak_ = caml_call2(UIML_Datatypes[4], _aj_, _af_), + _al_ = caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), + _am_ = caml_call3(UIML_KS_termination_prelims[12], _al_, _ak_, m0); + return caml_call4(UIML_List_lemmasT[2], _am_, _ab_, _$_, _Z_); + } + var + h1 = + caml_call3 + (UIML_KS_termination_prelims[3], + [1, a, b], + [0, n$0], + [0, [0, m, n0], l0]); + if(0 === h1[0]) + throw caml_maybe_attach_backtrace([0, Assert_failure, _f_], 1); + var n$1 = caml_call1(UIML_Datatypes[3], UU0394_0); + l$0 = l0; + n$0 = n$1; + } + } + function coq_ImpR_help2(param, _s_, x){ + var + UU0394_1 = x[6], + UU0394_0 = x[5], + UU0393_1 = x[4], + UU0393_0 = x[3], + b = x[2], + a = x[1], + _t_ = caml_call1(UIML_Datatypes[3], UU0394_0), + _u_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]); + return coq_ImpR_help02 + (UU0393_0, + UU0393_1, + UU0394_0, + UU0394_1, + a, + b, + caml_call1(UIML_KS_termination_prelims[5], _u_), + _t_, + x); + } + function finite_ImpR_premises_of_S(param){ + var + l0 = param[2], + l = param[1], + _i_ = + prems_Imp_R(caml_call1(UIML_KS_termination_prelims[5], l0), [0, l, l0]); + return [0, + caml_call2(UIML_List[4], function(y){return [0, y, 0];}, _i_), + function(prems){ + return [0, + function(h){ + var + UU0394_1 = h[6], + UU0394_0 = h[5], + UU0393_1 = h[4], + UU0393_0 = h[3], + b = h[2], + a = h[1]; + function f(y){return [0, y, 0];} + var + _j_ = + caml_call2 + (UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]), + _k_ = + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _j_], + _l_ = + caml_call2 + (UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]), + l1 = + prems_Imp_R + (caml_call1(UIML_KS_termination_prelims[5], _l_), _k_), + _m_ = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1]), + y = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + _m_], + 0], + x = caml_call3(UIML_KS_termination_prelims[4], f, l1, y)[2], + _n_ = + caml_call2 + (UIML_Datatypes[4], UU0394_0, [0, [1, a, b], UU0394_1]), + _o_ = + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _n_], + _p_ = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1]), + _q_ = + [0, + symbol, + coq_ImpR_help2 + ([0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + _p_], + _o_, + h)], + _r_ = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1]); + return caml_call1 + (x, + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + _r_], + _q_]); + }, + function(h){ + var + l1 = + prems_Imp_R + (caml_call1(UIML_KS_termination_prelims[5], l0), [0, l, l0]); + function f(y){return [0, y, 0];} + var + x = + caml_call3(UIML_KS_termination_prelims[4], f, l1, prems)[1], + h0 = caml_call1(x, h), + p = h0[2], + x0 = h0[1], + i = p[2]; + return coq_ImpR_help1(x0, [0, l, l0], i); + }]; + }]; + } + var + UIML_KS_termination_ImpR = + [0, + prems_Imp_R, + coq_In_pos_top_imps_split_l, + coq_ImpR_help01, + coq_ImpR_help1, + coq_ImpR_help002, + coq_ImpR_help02, + coq_ImpR_help2, + finite_ImpR_premises_of_S]; + runtime.caml_register_global + (15, UIML_KS_termination_ImpR, "UIML__KS_termination_ImpR"); + return; + } + (globalThis)); + +//# 5352 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_extraction_KS_termination_ = "extraction/KS_termination_ImpL.ml", + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + function caml_call4(f, a0, a1, a2, a3){ + return (f.l >= 0 ? f.l : f.l = f.length) == 4 + ? f(a0, a1, a2, a3) + : runtime.caml_call_gen(f, [a0, a1, a2, a3]); + } + function caml_call5(f, a0, a1, a2, a3, a4){ + return (f.l >= 0 ? f.l : f.l = f.length) == 5 + ? f(a0, a1, a2, a3, a4) + : runtime.caml_call_gen(f, [a0, a1, a2, a3, a4]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_Datatypes = global_data.UIML__Datatypes, + UIML_KS_termination_prelims = global_data.UIML__KS_termination_prelims, + UIML_List = global_data.UIML__List, + UIML_CML_Syntax = global_data.UIML__CML_Syntax, + UIML_GenT = global_data.UIML__GenT, + Assert_failure = global_data.Assert_failure, + UIML_List_lemmasT = global_data.UIML__List_lemmasT, + UIML_KS_termination_ImpR = global_data.UIML__KS_termination_ImpR, + UIML_List_lems = global_data.UIML__List_lems, + _a_ = [0, cst_extraction_KS_termination_, 378, 28], + _b_ = [0, cst_extraction_KS_termination_, 286, 23], + _c_ = [0, cst_extraction_KS_termination_, 112, 10], + _d_ = [0, cst_extraction_KS_termination_, 647, 40], + _e_ = [0, cst_extraction_KS_termination_, 402, 12]; + function symbol(param){return symbol;} + function prems_Imp_L(l, s){ + var l$0 = l; + for(;;){ + if(! l$0) return 0; + var t = l$0[2], p = l$0[1], n = p[2], c = p[1]; + if(n){ + var m = n[1]; + if(typeof c !== "number" && 1 === c[0]){ + var + b = c[2], + a = c[1], + _fE_ = prems_Imp_L(t, s), + _fF_ = caml_call1(UIML_Datatypes[2], s), + _fG_ = caml_call1(UIML_Datatypes[1], s), + _fH_ = caml_call3(UIML_KS_termination_prelims[14], [0, m], c, _fG_), + _fI_ = caml_call2(UIML_KS_termination_prelims[15], m, _fH_), + _fJ_ = [0, b, caml_call1(UIML_Datatypes[2], _fI_)], + _fK_ = caml_call1(UIML_Datatypes[1], s), + _fL_ = caml_call3(UIML_KS_termination_prelims[14], [0, m], c, _fK_), + _fM_ = caml_call2(UIML_KS_termination_prelims[15], m, _fL_), + _fN_ = caml_call1(UIML_Datatypes[1], _fM_), + _fO_ = [0, [0, caml_call2(UIML_Datatypes[4], _fN_, _fJ_), _fF_], 0], + _fP_ = + caml_call2 + (UIML_List[4], + function(y){ + var + _fR_ = caml_call1(UIML_Datatypes[2], s), + _fS_ = caml_call1(UIML_Datatypes[1], s), + _fT_ = + caml_call3(UIML_KS_termination_prelims[14], [0, m], c, _fS_), + _fU_ = caml_call2(UIML_KS_termination_prelims[15], m, _fT_), + _fV_ = caml_call1(UIML_Datatypes[2], _fU_), + _fW_ = caml_call1(UIML_Datatypes[1], s), + _fX_ = + caml_call3(UIML_KS_termination_prelims[14], [0, m], c, _fW_), + _fY_ = caml_call2(UIML_KS_termination_prelims[15], m, _fX_), + _fZ_ = caml_call1(UIML_Datatypes[1], _fY_), + _f0_ = caml_call2(UIML_Datatypes[4], _fZ_, _fV_), + _f1_ = + caml_call3(UIML_KS_termination_prelims[13], _f0_, _fR_, a); + return caml_call2 + (UIML_List[4], function(z){return [0, z, [0, y, 0]];}, _f1_); + }, + _fO_), + _fQ_ = caml_call1(UIML_KS_termination_prelims[7], _fP_); + return caml_call2(UIML_Datatypes[4], _fQ_, _fE_); + } + l$0 = t; + } + else + l$0 = t; + } + } + function coq_ImpL_help002(UU0393_0, UU0393_1, UU0394_0, UU0394_1, a, b){ + var + _eS_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _eT_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _eS_], + 0], + _eU_ = + caml_call2 + (UIML_List[4], + function(z){ + var + _fD_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]); + return [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _fD_], + [0, z, 0]]; + }, + _eT_), + _eV_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _eW_ = caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), + _eX_ = caml_call3(UIML_KS_termination_prelims[13], _eW_, _eV_, a), + p = + caml_call3 + (UIML_KS_termination_prelims[4], + function(y){ + var + _fB_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _fC_ = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _fB_], + 0]; + return caml_call2 + (UIML_List[4], function(z){return [0, y, [0, z, 0]];}, _fC_); + }, + _eX_, + _eU_), + i = p[2], + _eY_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + _eZ_ = [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _eY_], + _e0_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _e1_ = caml_call2(UIML_KS_termination_prelims[11], _e0_, a), + p0 = + caml_call3 + (UIML_KS_termination_prelims[4], + function(y){ + return [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), y]; + }, + _e1_, + _eZ_), + i0 = p0[2], + _e2_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + _e3_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _e4_ = caml_call1(UIML_KS_termination_prelims[10], _e3_), + _e5_ = caml_call1(UIML_KS_termination_prelims[1], _e4_), + p1 = + caml_call3 + (UIML_KS_termination_prelims[4], + function(y){ + var + _fz_ = [0, a, caml_call1(UIML_Datatypes[2], y)], + _fA_ = caml_call1(UIML_Datatypes[1], y); + return caml_call2(UIML_Datatypes[4], _fA_, _fz_); + }, + _e5_, + _e2_), + i1 = p1[2], + _e6_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + s = caml_call1(UIML_KS_termination_prelims[10], _e6_), + x = s[1], + _e7_ = + [0, + symbol, + caml_call1 + (i1, + [0, + [0, UU0394_0, UU0394_1], + [0, + symbol, + caml_call2(UIML_List_lems[5], [0, UU0394_0, UU0394_1], x)]])], + _e8_ = + [0, + symbol, + caml_call1 + (i0, + [0, caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), _e7_])], + _e9_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + _e__ = + caml_call1 + (i, + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _e9_], + _e8_]), + _e$_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _fa_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _e$_], + 0], + _fb_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + _fc_ = + [0, [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _fb_], _fa_], + _fd_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _fe_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _fd_], + 0], + p$0 = + caml_call3 + (UIML_KS_termination_prelims[4], + function(z){ + var + _fy_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]); + return [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _fy_], + [0, z, 0]]; + }, + _fe_, + _fc_), + i$0 = p$0[2], + _ff_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _fg_ = + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _ff_], + _fh_ = [0, symbol, caml_call2(UIML_GenT[1], _fg_, 0)], + _fi_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _fj_ = + caml_call1 + (i$0, + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _fi_], + _fh_]), + _fk_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _fl_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _fk_], + 0], + _fm_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + _fn_ = + [0, [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _fm_], _fl_], + _fo_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _fp_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _fo_], + 0], + _fq_ = + caml_call2 + (UIML_List[4], + function(z){ + var + _fx_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]); + return [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _fx_], + [0, z, 0]]; + }, + _fp_), + _fr_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _fs_ = caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), + _ft_ = caml_call3(UIML_KS_termination_prelims[13], _fs_, _fr_, a), + _fu_ = + caml_call2 + (UIML_List[4], + function(y){ + var + _fv_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _fw_ = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _fv_], + 0]; + return caml_call2 + (UIML_List[4], function(z){return [0, y, [0, z, 0]];}, _fw_); + }, + _ft_); + return caml_call5 + (UIML_KS_termination_prelims[9], _fu_, _fq_, _fn_, _fj_, _e__); + } + function coq_ImpL_help02 + (UU0393_0, UU0393_1, UU0394_0, UU0394_1, a, b, l, n, x){ + var l$0 = l, n$0 = n; + for(;;){ + if(! l$0) throw caml_maybe_attach_backtrace([0, Assert_failure, _c_], 1); + var l0 = l$0[2], y = l$0[1], n0 = y[2], m = y[1]; + if(typeof m !== "number" && 1 === m[0]){ + var + m1 = m[2], + m0 = m[1], + h1$0 = + caml_call3 + (UIML_KS_termination_prelims[3], + [1, a, b], + [0, n$0], + [0, [0, [1, m0, m1], n0], l0]); + if(0 === h1$0[0]){ + var + i = coq_ImpL_help002(UU0393_0, UU0393_1, UU0394_0, UU0394_1, a, b), + f = + function(y0){ + var + _ex_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _ey_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _ex_], + _ez_ = caml_call1(UIML_Datatypes[2], _ey_), + _eA_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _eB_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _eA_], + _eC_ = caml_call1(UIML_Datatypes[1], _eB_), + _eD_ = [0, caml_call1(UIML_Datatypes[3], UU0393_0)], + _eE_ = + caml_call3 + (UIML_KS_termination_prelims[14], _eD_, [1, a, b], _eC_), + _eF_ = caml_call1(UIML_Datatypes[3], UU0393_0), + _eG_ = caml_call2(UIML_KS_termination_prelims[15], _eF_, _eE_), + _eH_ = caml_call1(UIML_Datatypes[2], _eG_), + _eI_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _eJ_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _eI_], + _eK_ = caml_call1(UIML_Datatypes[1], _eJ_), + _eL_ = [0, caml_call1(UIML_Datatypes[3], UU0393_0)], + _eM_ = + caml_call3 + (UIML_KS_termination_prelims[14], _eL_, [1, a, b], _eK_), + _eN_ = caml_call1(UIML_Datatypes[3], UU0393_0), + _eO_ = caml_call2(UIML_KS_termination_prelims[15], _eN_, _eM_), + _eP_ = caml_call1(UIML_Datatypes[1], _eO_), + _eQ_ = caml_call2(UIML_Datatypes[4], _eP_, _eH_), + _eR_ = caml_call3(UIML_KS_termination_prelims[13], _eQ_, _ez_, a); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _eR_); + }, + _bD_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _bE_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _bD_], + _bF_ = caml_call1(UIML_Datatypes[2], _bE_), + _bG_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _bH_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _bG_], + _bI_ = caml_call1(UIML_Datatypes[1], _bH_), + _bJ_ = [0, caml_call1(UIML_Datatypes[3], UU0393_0)], + _bK_ = + caml_call3(UIML_KS_termination_prelims[14], _bJ_, [1, a, b], _bI_), + _bL_ = caml_call1(UIML_Datatypes[3], UU0393_0), + _bM_ = caml_call2(UIML_KS_termination_prelims[15], _bL_, _bK_), + _bN_ = [0, b, caml_call1(UIML_Datatypes[2], _bM_)], + _bO_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _bP_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _bO_], + _bQ_ = caml_call1(UIML_Datatypes[1], _bP_), + _bR_ = [0, caml_call1(UIML_Datatypes[3], UU0393_0)], + _bS_ = + caml_call3(UIML_KS_termination_prelims[14], _bR_, [1, a, b], _bQ_), + _bT_ = caml_call1(UIML_Datatypes[3], UU0393_0), + _bU_ = caml_call2(UIML_KS_termination_prelims[15], _bT_, _bS_), + _bV_ = caml_call1(UIML_Datatypes[1], _bU_), + l1 = [0, [0, caml_call2(UIML_Datatypes[4], _bV_, _bN_), _bF_], 0], + _bW_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _bX_ = caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), + _bY_ = caml_call3(UIML_KS_termination_prelims[13], _bX_, _bW_, a), + _bZ_ = + caml_call2 + (UIML_List[4], + function(y0){ + var _ew_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1); + return [0, + [0, + y0, + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _ew_], + 0]], + 0]; + }, + _bY_), + y0 = caml_call1(UIML_KS_termination_prelims[7], _bZ_), + x0 = caml_call3(UIML_KS_termination_prelims[4], f, l1, y0)[2], + s = caml_call2(UIML_CML_Syntax[6], [1, a, b], [1, a, b]); + if(! s) throw caml_maybe_attach_backtrace([0, Assert_failure, _b_], 1); + var + _b0_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _b1_ = + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _b0_], + _b2_ = [0, symbol, caml_call2(UIML_GenT[1], _b1_, 0)], + _b3_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _b4_ = + caml_call1 + (x0, + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _b3_], + _b2_]), + _b5_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _b6_ = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _b5_], + 0], + _b7_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + _b8_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _b7_], + _b6_], + _b9_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _b__ = caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), + _b$_ = caml_call3(UIML_KS_termination_prelims[13], _b__, _b9_, a), + _ca_ = + caml_call2 + (UIML_List[4], + function(y0){ + var _ev_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1); + return [0, + [0, + y0, + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _ev_], + 0]], + 0]; + }, + _b$_), + _cb_ = caml_call1(UIML_KS_termination_prelims[7], _ca_), + _cc_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _cd_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _cc_], + _ce_ = caml_call1(UIML_Datatypes[2], _cd_), + _cf_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _cg_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _cf_], + _ch_ = caml_call1(UIML_Datatypes[1], _cg_), + _ci_ = [0, caml_call1(UIML_Datatypes[3], UU0393_0)], + _cj_ = + caml_call3(UIML_KS_termination_prelims[14], _ci_, [1, a, b], _ch_), + _ck_ = caml_call1(UIML_Datatypes[3], UU0393_0), + _cl_ = caml_call2(UIML_KS_termination_prelims[15], _ck_, _cj_), + _cm_ = [0, b, caml_call1(UIML_Datatypes[2], _cl_)], + _cn_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _co_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _cn_], + _cp_ = caml_call1(UIML_Datatypes[1], _co_), + _cq_ = [0, caml_call1(UIML_Datatypes[3], UU0393_0)], + _cr_ = + caml_call3(UIML_KS_termination_prelims[14], _cq_, [1, a, b], _cp_), + _cs_ = caml_call1(UIML_Datatypes[3], UU0393_0), + _ct_ = caml_call2(UIML_KS_termination_prelims[15], _cs_, _cr_), + _cu_ = caml_call1(UIML_Datatypes[1], _ct_), + _cv_ = [0, [0, caml_call2(UIML_Datatypes[4], _cu_, _cm_), _ce_], 0], + _cw_ = + caml_call2 + (UIML_List[4], + function(y0){ + var + _ea_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _eb_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _ea_], + _ec_ = caml_call1(UIML_Datatypes[2], _eb_), + _ed_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _ee_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _ed_], + _ef_ = caml_call1(UIML_Datatypes[1], _ee_), + _eg_ = [0, caml_call1(UIML_Datatypes[3], UU0393_0)], + _eh_ = + caml_call3 + (UIML_KS_termination_prelims[14], _eg_, [1, a, b], _ef_), + _ei_ = caml_call1(UIML_Datatypes[3], UU0393_0), + _ej_ = caml_call2(UIML_KS_termination_prelims[15], _ei_, _eh_), + _ek_ = caml_call1(UIML_Datatypes[2], _ej_), + _el_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _em_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _el_], + _en_ = caml_call1(UIML_Datatypes[1], _em_), + _eo_ = [0, caml_call1(UIML_Datatypes[3], UU0393_0)], + _ep_ = + caml_call3 + (UIML_KS_termination_prelims[14], _eo_, [1, a, b], _en_), + _eq_ = caml_call1(UIML_Datatypes[3], UU0393_0), + _er_ = caml_call2(UIML_KS_termination_prelims[15], _eq_, _ep_), + _es_ = caml_call1(UIML_Datatypes[1], _er_), + _et_ = caml_call2(UIML_Datatypes[4], _es_, _ek_), + _eu_ = + caml_call3(UIML_KS_termination_prelims[13], _et_, _ec_, a); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _eu_); + }, + _cv_), + _cx_ = + [0, + caml_call5 + (UIML_KS_termination_prelims[9], _cw_, _cb_, _b8_, i, _b4_)], + _cy_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _cz_ = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _cy_], + 0], + _cA_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + prems_Imp_L0 = + function(l1, s){ + var l1$0 = l1; + for(;;){ + if(! l1$0) return 0; + var l1$1 = l1$0[2], p = l1$0[1], n1 = p[2], c = p[1]; + if(n1){ + var m2 = n1[1]; + if(typeof c !== "number" && 1 === c[0]){ + var + b0 = c[2], + a0 = c[1], + _dO_ = prems_Imp_L0(l1$1, s), + _dP_ = caml_call1(UIML_Datatypes[2], s), + _dQ_ = caml_call1(UIML_Datatypes[1], s), + _dR_ = + caml_call3(UIML_KS_termination_prelims[14], [0, m2], c, _dQ_), + _dS_ = caml_call2(UIML_KS_termination_prelims[15], m2, _dR_), + _dT_ = [0, b0, caml_call1(UIML_Datatypes[2], _dS_)], + _dU_ = caml_call1(UIML_Datatypes[1], s), + _dV_ = + caml_call3(UIML_KS_termination_prelims[14], [0, m2], c, _dU_), + _dW_ = caml_call2(UIML_KS_termination_prelims[15], m2, _dV_), + _dX_ = caml_call1(UIML_Datatypes[1], _dW_), + _dY_ = + [0, [0, caml_call2(UIML_Datatypes[4], _dX_, _dT_), _dP_], 0], + _dZ_ = + caml_call2 + (UIML_List[4], + function(y0){ + var + _d1_ = caml_call1(UIML_Datatypes[2], s), + _d2_ = caml_call1(UIML_Datatypes[1], s), + _d3_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, m2], c, _d2_), + _d4_ = caml_call2(UIML_KS_termination_prelims[15], m2, _d3_), + _d5_ = caml_call1(UIML_Datatypes[2], _d4_), + _d6_ = caml_call1(UIML_Datatypes[1], s), + _d7_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, m2], c, _d6_), + _d8_ = caml_call2(UIML_KS_termination_prelims[15], m2, _d7_), + _d9_ = caml_call1(UIML_Datatypes[1], _d8_), + _d__ = caml_call2(UIML_Datatypes[4], _d9_, _d5_), + _d$_ = + caml_call3(UIML_KS_termination_prelims[13], _d__, _d1_, a0); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _d$_); + }, + _dY_), + _d0_ = caml_call1(UIML_KS_termination_prelims[7], _dZ_); + return caml_call2(UIML_Datatypes[4], _d0_, _dO_); + } + l1$0 = l1$1; + } + else + l1$0 = l1$1; + } + }, + _cB_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _cA_], + _cz_], + _cC_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _cD_ = + prems_Imp_L0 + (l0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _cC_]), + _cE_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _cF_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _cE_], + _cG_ = caml_call1(UIML_Datatypes[2], _cF_), + _cH_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _cI_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _cH_], + _cJ_ = caml_call1(UIML_Datatypes[1], _cI_), + _cK_ = [0, caml_call1(UIML_Datatypes[3], UU0393_0)], + _cL_ = + caml_call3(UIML_KS_termination_prelims[14], _cK_, [1, a, b], _cJ_), + _cM_ = caml_call1(UIML_Datatypes[3], UU0393_0), + _cN_ = caml_call2(UIML_KS_termination_prelims[15], _cM_, _cL_), + _cO_ = [0, b, caml_call1(UIML_Datatypes[2], _cN_)], + _cP_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _cQ_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _cP_], + _cR_ = caml_call1(UIML_Datatypes[1], _cQ_), + _cS_ = [0, caml_call1(UIML_Datatypes[3], UU0393_0)], + _cT_ = + caml_call3(UIML_KS_termination_prelims[14], _cS_, [1, a, b], _cR_), + _cU_ = caml_call1(UIML_Datatypes[3], UU0393_0), + _cV_ = caml_call2(UIML_KS_termination_prelims[15], _cU_, _cT_), + _cW_ = caml_call1(UIML_Datatypes[1], _cV_), + _cX_ = [0, [0, caml_call2(UIML_Datatypes[4], _cW_, _cO_), _cG_], 0], + _cY_ = + caml_call2 + (UIML_List[4], + function(y0){ + var + _dt_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _du_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _dt_], + _dv_ = caml_call1(UIML_Datatypes[2], _du_), + _dw_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _dx_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _dw_], + _dy_ = caml_call1(UIML_Datatypes[1], _dx_), + _dz_ = [0, caml_call1(UIML_Datatypes[3], UU0393_0)], + _dA_ = + caml_call3 + (UIML_KS_termination_prelims[14], _dz_, [1, a, b], _dy_), + _dB_ = caml_call1(UIML_Datatypes[3], UU0393_0), + _dC_ = caml_call2(UIML_KS_termination_prelims[15], _dB_, _dA_), + _dD_ = caml_call1(UIML_Datatypes[2], _dC_), + _dE_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _dF_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _dE_], + _dG_ = caml_call1(UIML_Datatypes[1], _dF_), + _dH_ = [0, caml_call1(UIML_Datatypes[3], UU0393_0)], + _dI_ = + caml_call3 + (UIML_KS_termination_prelims[14], _dH_, [1, a, b], _dG_), + _dJ_ = caml_call1(UIML_Datatypes[3], UU0393_0), + _dK_ = caml_call2(UIML_KS_termination_prelims[15], _dJ_, _dI_), + _dL_ = caml_call1(UIML_Datatypes[1], _dK_), + _dM_ = caml_call2(UIML_Datatypes[4], _dL_, _dD_), + _dN_ = + caml_call3(UIML_KS_termination_prelims[13], _dM_, _dv_, a); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _dN_); + }, + _cX_), + _cZ_ = caml_call1(UIML_KS_termination_prelims[7], _cY_); + return caml_call4(UIML_List_lemmasT[2], _cZ_, _cD_, _cB_, _cx_); + } + var + i$0 = + coq_ImpL_help02 + (UU0393_0, + UU0393_1, + UU0394_0, + UU0394_1, + a, + b, + l0, + caml_call1(UIML_Datatypes[3], UU0393_0), + x); + if(! n0) return i$0; + var + n1 = n0[1], + _c1_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _c2_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), _c1_], + 0], + _c3_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]), + _c4_ = + [0, + [0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _c3_], + _c2_], + _c5_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _c6_ = + prems_Imp_L + (l0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _c5_]), + _c0_ = [1, i$0], + _c7_ = 0, + _c8_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1); + if(n1){ + var + match = + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match) + var + tl = match[2], + b0 = match[1], + _c9_ = + [0, + b0, + caml_call3(UIML_KS_termination_prelims[14], n1, [1, m0, m1], tl)]; + else + var _c9_ = 0; + var _c__ = _c9_; + } + else{ + var + match$2 = + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match$2) + var + tl$4 = match$2[2], + b0$2 = match$2[1], + tl$5 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$2) + ? tl$4 + : [0, b0$2, tl$4], + tl$6 = tl$5; + else + var tl$6 = 0; + var _c__ = tl$6; + } + var + _c$_ = caml_call2(UIML_KS_termination_prelims[15], n1, _c__), + _da_ = caml_call1(UIML_Datatypes[2], _c$_); + if(n1){ + var + match$0 = + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match$0) + var + tl$0 = match$0[2], + b0$0 = match$0[1], + _db_ = + [0, + b0$0, + caml_call3(UIML_KS_termination_prelims[14], n1, [1, m0, m1], tl$0)]; + else + var _db_ = 0; + var _dc_ = _db_; + } + else{ + var + match$1 = + caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match$1) + var + tl$1 = match$1[2], + b0$1 = match$1[1], + tl$2 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$1) + ? tl$1 + : [0, b0$1, tl$1], + tl$3 = tl$2; + else + var tl$3 = 0; + var _dc_ = tl$3; + } + var + _dd_ = caml_call2(UIML_KS_termination_prelims[15], n1, _dc_), + _de_ = caml_call1(UIML_Datatypes[1], _dd_), + _df_ = caml_call2(UIML_Datatypes[4], _de_, _da_), + _dg_ = caml_call3(UIML_KS_termination_prelims[13], _df_, _c8_, m0), + _dh_ = + caml_call2 + (UIML_List[4], + function(z){ + var + _dj_ = 0, + _dk_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1); + if(n1){ + var + match = + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match) + var + tl = match[2], + b0 = match[1], + _dl_ = + [0, + b0, + caml_call3 + (UIML_KS_termination_prelims[14], n1, [1, m0, m1], tl)]; + else + var _dl_ = 0; + var _dm_ = _dl_; + } + else{ + var + match$2 = + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match$2) + var + tl$4 = match$2[2], + b0$2 = match$2[1], + tl$5 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$2) + ? tl$4 + : [0, b0$2, tl$4], + tl$6 = tl$5; + else + var tl$6 = 0; + var _dm_ = tl$6; + } + var + _dn_ = caml_call2(UIML_KS_termination_prelims[15], n1, _dm_), + _do_ = [0, m1, caml_call1(UIML_Datatypes[2], _dn_)]; + if(n1){ + var + match$0 = + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match$0) + var + tl$0 = match$0[2], + b0$0 = match$0[1], + _dp_ = + [0, + b0$0, + caml_call3 + (UIML_KS_termination_prelims[14], n1, [1, m0, m1], tl$0)]; + else + var _dp_ = 0; + var _dq_ = _dp_; + } + else{ + var + match$1 = + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + if(match$1) + var + tl$1 = match$1[2], + b0$1 = match$1[1], + tl$2 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$1) + ? tl$1 + : [0, b0$1, tl$1], + tl$3 = tl$2; + else + var tl$3 = 0; + var _dq_ = tl$3; + } + var + _dr_ = caml_call2(UIML_KS_termination_prelims[15], n1, _dq_), + _ds_ = caml_call1(UIML_Datatypes[1], _dr_); + return [0, + z, + [0, + [0, caml_call2(UIML_Datatypes[4], _ds_, _do_), _dk_], + _dj_]]; + }, + _dg_), + _di_ = caml_call2(UIML_Datatypes[4], _dh_, _c7_); + return caml_call4(UIML_List_lemmasT[2], _di_, _c6_, _c4_, _c0_); + } + var + _bC_ = [0, caml_call1(UIML_Datatypes[3], UU0393_0)], + h1 = + caml_call3 + (UIML_KS_termination_prelims[3], + [1, a, b], + _bC_, + [0, [0, m, n0], l0]); + if(0 === h1[0]) + throw caml_maybe_attach_backtrace([0, Assert_failure, _a_], 1); + var n$1 = caml_call1(UIML_Datatypes[3], UU0393_0); + l$0 = l0; + n$0 = n$1; + } + } + function coq_ImpL_help2(param, _bz_, _by_, x){ + var + UU0394_1 = x[6], + UU0394_0 = x[5], + UU0393_1 = x[4], + UU0393_0 = x[3], + b = x[2], + a = x[1], + _bA_ = caml_call1(UIML_Datatypes[3], UU0393_0), + _bB_ = caml_call2(UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]); + return coq_ImpL_help02 + (UU0393_0, + UU0393_1, + UU0394_0, + UU0394_1, + a, + b, + caml_call1(UIML_KS_termination_prelims[5], _bB_), + _bA_, + x); + } + function coq_ImpL_help01(prems, s, l1){ + var l0 = s[2], l = s[1]; + function f(l2, x){ + if(! l2) throw caml_maybe_attach_backtrace([0, Assert_failure, _e_], 1); + var l3 = l2[2], y = l2[1], n = y[2], m = y[1]; + if(typeof m !== "number" && 1 === m[0]){ + var m1 = m[2], m0 = m[1]; + if(! n){ + var + s0$1 = f(l3, x), + s1$1 = s0$1[2], + x0$1 = s0$1[1], + s2$1 = s1$1[2], + x1$2 = s1$1[1], + s3$1 = s2$1[2], + x2$2 = s2$1[1], + s4$1 = s3$1[2], + x3$2 = s3$1[1], + s5$1 = s4$1[2], + x4$2 = s4$1[1], + s6$1 = s5$1[2], + x5$2 = s5$1[1], + s7$1 = s6$1[2], + x6$2 = s6$1[1], + s8$1 = s7$1[2], + x7$2 = s7$1[1], + x8$2 = s8$1[1]; + return [0, + x0$1, + [0, + x1$2, + [0, + x2$2, + [0, + x3$2, + [0, + x4$2, + [0, x5$2, [0, x6$2, [0, x7$2, [0, x8$2, symbol]]]]]]]]]; + } + var + n0 = n[1], + prems_Imp_L0 = + function(l4, s0){ + var l4$0 = l4; + for(;;){ + if(! l4$0) return 0; + var l4$1 = l4$0[2], p = l4$0[1], n1 = p[2], c = p[1]; + if(n1){ + var m2 = n1[1]; + if(typeof c !== "number" && 1 === c[0]){ + var + b = c[2], + a = c[1], + _ba_ = prems_Imp_L0(l4$1, s0), + _bb_ = caml_call1(UIML_Datatypes[2], s0), + _bc_ = caml_call1(UIML_Datatypes[1], s0), + _bd_ = + caml_call3(UIML_KS_termination_prelims[14], [0, m2], c, _bc_), + _be_ = caml_call2(UIML_KS_termination_prelims[15], m2, _bd_), + _bf_ = [0, b, caml_call1(UIML_Datatypes[2], _be_)], + _bg_ = caml_call1(UIML_Datatypes[1], s0), + _bh_ = + caml_call3(UIML_KS_termination_prelims[14], [0, m2], c, _bg_), + _bi_ = caml_call2(UIML_KS_termination_prelims[15], m2, _bh_), + _bj_ = caml_call1(UIML_Datatypes[1], _bi_), + _bk_ = + [0, [0, caml_call2(UIML_Datatypes[4], _bj_, _bf_), _bb_], 0], + _bl_ = + caml_call2 + (UIML_List[4], + function(y0){ + var + _bn_ = caml_call1(UIML_Datatypes[2], s0), + _bo_ = caml_call1(UIML_Datatypes[1], s0), + _bp_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, m2], c, _bo_), + _bq_ = caml_call2(UIML_KS_termination_prelims[15], m2, _bp_), + _br_ = caml_call1(UIML_Datatypes[2], _bq_), + _bs_ = caml_call1(UIML_Datatypes[1], s0), + _bt_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, m2], c, _bs_), + _bu_ = caml_call2(UIML_KS_termination_prelims[15], m2, _bt_), + _bv_ = caml_call1(UIML_Datatypes[1], _bu_), + _bw_ = caml_call2(UIML_Datatypes[4], _bv_, _br_), + _bx_ = + caml_call3(UIML_KS_termination_prelims[13], _bw_, _bn_, a); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _bx_); + }, + _bk_), + _bm_ = caml_call1(UIML_KS_termination_prelims[7], _bl_); + return caml_call2(UIML_Datatypes[4], _bm_, _ba_); + } + l4$0 = l4$1; + } + else + l4$0 = l4$1; + } + }, + _v_ = prems_Imp_L0(l3, [0, l, l0]), + _w_ = caml_call1(UIML_Datatypes[2], [0, l, l0]), + _x_ = caml_call1(UIML_Datatypes[1], [0, l, l0]), + _y_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], _x_), + _z_ = caml_call2(UIML_KS_termination_prelims[15], n0, _y_), + _A_ = [0, m1, caml_call1(UIML_Datatypes[2], _z_)], + _B_ = caml_call1(UIML_Datatypes[1], [0, l, l0]), + _C_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], _B_), + _D_ = caml_call2(UIML_KS_termination_prelims[15], n0, _C_), + _E_ = caml_call1(UIML_Datatypes[1], _D_), + _F_ = [0, [0, caml_call2(UIML_Datatypes[4], _E_, _A_), _w_], 0], + _G_ = + caml_call2 + (UIML_List[4], + function(y0){ + var + _a1_ = caml_call1(UIML_Datatypes[2], [0, l, l0]), + _a2_ = caml_call1(UIML_Datatypes[1], [0, l, l0]), + _a3_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], _a2_), + _a4_ = caml_call2(UIML_KS_termination_prelims[15], n0, _a3_), + _a5_ = caml_call1(UIML_Datatypes[2], _a4_), + _a6_ = caml_call1(UIML_Datatypes[1], [0, l, l0]), + _a7_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], _a6_), + _a8_ = caml_call2(UIML_KS_termination_prelims[15], n0, _a7_), + _a9_ = caml_call1(UIML_Datatypes[1], _a8_), + _a__ = caml_call2(UIML_Datatypes[4], _a9_, _a5_), + _a$_ = + caml_call3(UIML_KS_termination_prelims[13], _a__, _a1_, m0); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _a$_); + }, + _F_), + _H_ = caml_call1(UIML_KS_termination_prelims[7], _G_), + x0$0 = caml_call4(UIML_List_lemmasT[1], _H_, _v_, prems, x); + if(0 !== x0$0[0]){ + var + i$0 = x0$0[1], + s0$0 = f(l3, i$0), + s1$0 = s0$0[2], + x1$1 = s0$0[1], + s2$0 = s1$0[2], + x2$1 = s1$0[1], + s3$0 = s2$0[2], + x3$1 = s2$0[1], + s4$0 = s3$0[2], + x4$1 = s3$0[1], + s5$0 = s4$0[2], + x5$1 = s4$0[1], + s6$0 = s5$0[2], + x6$1 = s5$0[1], + s7$0 = s6$0[2], + x7$1 = s6$0[1], + s8$0 = s7$0[2], + x8$1 = s7$0[1], + x9 = s8$0[1]; + return [0, + x1$1, + [0, + x2$1, + [0, + x3$1, + [0, + x4$1, + [0, x5$1, [0, x6$1, [0, x7$1, [0, x8$1, [0, x9, symbol]]]]]]]]]; + } + var + i = x0$0[1], + _I_ = + caml_call3(UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + _J_ = caml_call2(UIML_KS_termination_prelims[15], n0, _I_), + _K_ = [0, m1, caml_call1(UIML_Datatypes[2], _J_)], + _L_ = + caml_call3(UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + _M_ = caml_call2(UIML_KS_termination_prelims[15], n0, _L_), + _N_ = caml_call1(UIML_Datatypes[1], _M_), + _O_ = [0, [0, caml_call2(UIML_Datatypes[4], _N_, _K_), l0], 0], + _P_ = + caml_call2 + (UIML_List[4], + function(y0){ + var + _aT_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + _aU_ = caml_call2(UIML_KS_termination_prelims[15], n0, _aT_), + _aV_ = caml_call1(UIML_Datatypes[2], _aU_), + _aW_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + _aX_ = caml_call2(UIML_KS_termination_prelims[15], n0, _aW_), + _aY_ = caml_call1(UIML_Datatypes[1], _aX_), + _aZ_ = caml_call2(UIML_Datatypes[4], _aY_, _aV_), + _a0_ = caml_call3(UIML_KS_termination_prelims[13], _aZ_, l0, m0); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _a0_); + }, + _O_), + i0 = caml_call3(UIML_KS_termination_prelims[8], _P_, prems, i), + p = i0[2], + x1$0 = i0[1], + i2 = p[2], + i1 = p[1], + _Q_ = + caml_call3(UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + _R_ = caml_call2(UIML_KS_termination_prelims[15], n0, _Q_), + _S_ = [0, m1, caml_call1(UIML_Datatypes[2], _R_)], + _T_ = + caml_call3(UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + _U_ = caml_call2(UIML_KS_termination_prelims[15], n0, _T_), + _V_ = caml_call1(UIML_Datatypes[1], _U_), + l4 = [0, [0, caml_call2(UIML_Datatypes[4], _V_, _S_), l0], 0], + f0 = + function(y0){ + var + _aL_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + _aM_ = caml_call2(UIML_KS_termination_prelims[15], n0, _aL_), + _aN_ = caml_call1(UIML_Datatypes[2], _aM_), + _aO_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + _aP_ = caml_call2(UIML_KS_termination_prelims[15], n0, _aO_), + _aQ_ = caml_call1(UIML_Datatypes[1], _aP_), + _aR_ = caml_call2(UIML_Datatypes[4], _aQ_, _aN_), + _aS_ = caml_call3(UIML_KS_termination_prelims[13], _aR_, l0, m0); + return caml_call2 + (UIML_List[4], + function(z){return [0, z, [0, y0, 0]];}, + _aS_); + }, + x2$0 = caml_call3(UIML_KS_termination_prelims[4], f0, l4, x1$0)[1], + i3 = caml_call1(x2$0, i2), + p0 = i3[2], + i4 = p0[2]; + if(0 !== i4[0]) + throw caml_maybe_attach_backtrace([0, Assert_failure, _d_], 1); + var + _W_ = + caml_call3(UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + _X_ = caml_call2(UIML_KS_termination_prelims[15], n0, _W_), + _Y_ = caml_call1(UIML_Datatypes[2], _X_), + _Z_ = + caml_call3(UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + ___ = caml_call2(UIML_KS_termination_prelims[15], n0, _Z_), + _$_ = caml_call1(UIML_Datatypes[1], ___), + _aa_ = caml_call2(UIML_Datatypes[4], _$_, _Y_), + l4$0 = caml_call3(UIML_KS_termination_prelims[13], _aa_, l0, m0), + f0$0 = + function(z){ + var _aE_ = 0; + if(n0) + if(l) + var + tl = l[2], + b = l[1], + _aF_ = + [0, + b, + caml_call3 + (UIML_KS_termination_prelims[14], n0, [1, m0, m1], tl)]; + else + var _aF_ = 0; + else if(l) + var + tl$3 = l[2], + b$2 = l[1], + tl$4 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b$2) + ? tl$3 + : [0, b$2, tl$3], + _aF_ = tl$4; + else + var _aF_ = 0; + var + _aG_ = caml_call2(UIML_KS_termination_prelims[15], n0, _aF_), + _aH_ = [0, m1, caml_call1(UIML_Datatypes[2], _aG_)]; + if(n0) + if(l) + var + tl$0 = l[2], + b$0 = l[1], + _aI_ = + [0, + b$0, + caml_call3 + (UIML_KS_termination_prelims[14], n0, [1, m0, m1], tl$0)]; + else + var _aI_ = 0; + else if(l) + var + tl$1 = l[2], + b$1 = l[1], + tl$2 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b$1) + ? tl$1 + : [0, b$1, tl$1], + _aI_ = tl$2; + else + var _aI_ = 0; + var + _aJ_ = caml_call2(UIML_KS_termination_prelims[15], n0, _aI_), + _aK_ = caml_call1(UIML_Datatypes[1], _aJ_); + return [0, + z, + [0, + [0, caml_call2(UIML_Datatypes[4], _aK_, _aH_), l0], + _aE_]]; + }, + x3$0 = caml_call3(UIML_KS_termination_prelims[4], f0$0, l4$0, prems)[1], + i5 = caml_call1(x3$0, i1), + p1 = i5[2], + x4$0 = i5[1], + i6 = p1[2], + l4$1 = caml_call2(UIML_KS_termination_prelims[11], l0, m0), + f0$1 = + function(y0){ + var + _ay_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + _az_ = caml_call2(UIML_KS_termination_prelims[15], n0, _ay_), + _aA_ = caml_call1(UIML_Datatypes[2], _az_), + _aB_ = + caml_call3 + (UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + _aC_ = caml_call2(UIML_KS_termination_prelims[15], n0, _aB_), + _aD_ = caml_call1(UIML_Datatypes[1], _aC_); + return [0, caml_call2(UIML_Datatypes[4], _aD_, _aA_), y0]; + }, + x5$0 = caml_call3(UIML_KS_termination_prelims[4], f0$1, l4$1, x4$0)[1], + i7 = caml_call1(x5$0, i6), + p2 = i7[2], + x6$0 = i7[1], + i8 = p2[2], + _ab_ = caml_call1(UIML_KS_termination_prelims[10], l0), + l4$2 = caml_call1(UIML_KS_termination_prelims[1], _ab_), + f0$2 = + function(y0){ + var + _aw_ = [0, m0, caml_call1(UIML_Datatypes[2], y0)], + _ax_ = caml_call1(UIML_Datatypes[1], y0); + return caml_call2(UIML_Datatypes[4], _ax_, _aw_); + }, + x7$0 = caml_call3(UIML_KS_termination_prelims[4], f0$2, l4$2, x6$0)[1], + i9 = caml_call1(x7$0, i8), + x8$0 = i9[1], + l5 = x8$0[2], + l4$3 = x8$0[1], + _ac_ = + caml_call3(UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + _ad_ = caml_call2(UIML_KS_termination_prelims[15], n0, _ac_), + _ae_ = + [0, caml_call1(UIML_Datatypes[2], _ad_), [0, l4$3, [0, l5, symbol]]], + _af_ = + caml_call3(UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + _ag_ = caml_call2(UIML_KS_termination_prelims[15], n0, _af_), + _ah_ = [0, m0, [0, m1, [0, caml_call1(UIML_Datatypes[1], _ag_), _ae_]]]; + if(n0) + if(l) + var + tl = l[2], + b0 = l[1], + _ai_ = + [0, + b0, + caml_call3(UIML_KS_termination_prelims[14], n0, [1, m0, m1], tl)]; + else + var _ai_ = 0; + else if(l) + var + tl$3 = l[2], + b0$2 = l[1], + tl$4 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$2) + ? tl$3 + : [0, b0$2, tl$3], + _ai_ = tl$4; + else + var _ai_ = 0; + var + _aj_ = caml_call2(UIML_KS_termination_prelims[15], n0, _ai_), + _ak_ = [0, m1, caml_call1(UIML_Datatypes[2], _aj_)]; + if(n0) + if(l) + var + tl$0 = l[2], + b0$0 = l[1], + _al_ = + [0, + b0$0, + caml_call3(UIML_KS_termination_prelims[14], n0, [1, m0, m1], tl$0)]; + else + var _al_ = 0; + else if(l) + var + tl$1 = l[2], + b0$1 = l[1], + tl$2 = + caml_call2(UIML_CML_Syntax[6], [1, m0, m1], b0$1) + ? tl$1 + : [0, b0$1, tl$1], + _al_ = tl$2; + else + var _al_ = 0; + var + _am_ = caml_call2(UIML_KS_termination_prelims[15], n0, _al_), + _an_ = caml_call1(UIML_Datatypes[1], _am_), + _ao_ = [0, [0, caml_call2(UIML_Datatypes[4], _an_, _ak_), l0], _ah_], + _ap_ = caml_call2(UIML_Datatypes[4], l4$3, [0, m0, l5]), + _aq_ = + caml_call3(UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + _ar_ = caml_call2(UIML_KS_termination_prelims[15], n0, _aq_), + _as_ = caml_call1(UIML_Datatypes[2], _ar_), + _at_ = + caml_call3(UIML_KS_termination_prelims[14], [0, n0], [1, m0, m1], l), + _au_ = caml_call2(UIML_KS_termination_prelims[15], n0, _at_), + _av_ = caml_call1(UIML_Datatypes[1], _au_); + return [0, + n0, + [0, [0, caml_call2(UIML_Datatypes[4], _av_, _as_), _ap_], _ao_]]; + } + var + s0 = f(l3, x), + s1 = s0[2], + x0 = s0[1], + s2 = s1[2], + x1 = s1[1], + s3 = s2[2], + x2 = s2[1], + s4 = s3[2], + x3 = s3[1], + s5 = s4[2], + x4 = s4[1], + s6 = s5[2], + x5 = s5[1], + s7 = s6[2], + x6 = s6[1], + s8 = s7[2], + x7 = s7[1], + x8 = s8[1]; + return [0, + x0, + [0, + x1, + [0, + x2, + [0, x3, [0, x4, [0, x5, [0, x6, [0, x7, [0, x8, symbol]]]]]]]]]; + } + return function(_u_){return f(l1, _u_);}; + } + function coq_ImpL_help1(prem, s, x){ + var + _k_ = caml_call1(UIML_Datatypes[1], s), + s0 = + coq_ImpL_help01 + (prem, s, caml_call1(UIML_KS_termination_prelims[5], _k_)) + (x), + s1 = s0[2], + x0 = s0[1], + s2 = s1[2], + s3 = s2[2], + s4 = s3[2], + x1 = s3[1], + s5 = s4[2], + x2 = s4[1], + s6 = s5[2], + s7 = s6[2], + s8 = s7[2], + x3 = s7[1], + x4 = s8[1], + l0 = s[2], + l = s[1], + _l_ = caml_call1(UIML_Datatypes[1], [0, l, l0]), + i = caml_call3(UIML_KS_termination_ImpR[2], _l_, [1, x1, x2], x0), + x5 = i[1], + _m_ = [0, caml_call1(UIML_Datatypes[3], x5)], + _n_ = caml_call3(UIML_KS_termination_prelims[14], _m_, [1, x1, x2], l), + _o_ = caml_call1(UIML_Datatypes[3], x5), + _p_ = caml_call2(UIML_KS_termination_prelims[15], _o_, _n_), + UU0393_0 = caml_call1(UIML_Datatypes[1], _p_), + _q_ = [0, caml_call1(UIML_Datatypes[3], x5)], + _r_ = caml_call3(UIML_KS_termination_prelims[14], _q_, [1, x1, x2], l), + _s_ = caml_call1(UIML_Datatypes[3], x5), + _t_ = caml_call2(UIML_KS_termination_prelims[15], _s_, _r_), + UU0393_1 = caml_call1(UIML_Datatypes[2], _t_); + return [0, x1, x2, UU0393_0, UU0393_1, x3, x4]; + } + function finite_ImpL_premises_of_S(param){ + var l0 = param[2], l = param[1]; + return [0, + prems_Imp_L + (caml_call1(UIML_KS_termination_prelims[5], l), [0, l, l0]), + function(prems){ + return [0, + function(h){ + var + UU0394_1 = h[6], + UU0394_0 = h[5], + UU0393_1 = h[4], + UU0393_0 = h[3], + b = h[2], + a = h[1], + _f_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _g_ = + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0, [0, [1, a, b], UU0393_1]), + _f_], + _h_ = caml_call2(UIML_Datatypes[4], UU0394_0, UU0394_1), + _i_ = + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, b, UU0393_1]), + _h_], + _j_ = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, a, UU0394_1]); + return coq_ImpL_help2 + ([0, caml_call2(UIML_Datatypes[4], UU0393_0, UU0393_1), _j_], + _i_, + _g_, + h); + }, + function(h){return coq_ImpL_help1(prems, [0, l, l0], h);}]; + }]; + } + var + UIML_KS_termination_ImpL = + [0, + prems_Imp_L, + coq_ImpL_help002, + coq_ImpL_help02, + coq_ImpL_help2, + coq_ImpL_help01, + coq_ImpL_help1, + finite_ImpL_premises_of_S]; + runtime.caml_register_global + (14, UIML_KS_termination_ImpL, "UIML__KS_termination_ImpL"); + return; + } + (globalThis)); + +//# 6842 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_extraction_KS_termination_ = "extraction/KS_termination_KR.ml", + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call4(f, a0, a1, a2, a3){ + return (f.l >= 0 ? f.l : f.l = f.length) == 4 + ? f(a0, a1, a2, a3) + : runtime.caml_call_gen(f, [a0, a1, a2, a3]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_Datatypes = global_data.UIML__Datatypes, + UIML_CML_Syntax = global_data.UIML__CML_Syntax, + Assert_failure = global_data.Assert_failure, + UIML_List_lems = global_data.UIML__List_lems, + UIML_GenT = global_data.UIML__GenT, + UIML_List_lemmasT = global_data.UIML__List_lemmasT, + UIML_KS_termination_prelims = global_data.UIML__KS_termination_prelims, + _a_ = [0, cst_extraction_KS_termination_, 31, 10], + _b_ = [0, cst_extraction_KS_termination_, 96, 28], + _c_ = [0, cst_extraction_KS_termination_, 64, 10]; + function symbol(param){return symbol;} + function prems_Box_R(l, s){ + var l$0 = l; + for(;;){ + if(! l$0) return 0; + var t = l$0[2], h = l$0[1]; + if(typeof h !== "number" && 2 === h[0]){ + var + a = h[1], + _p_ = prems_Box_R(t, s), + _q_ = caml_call1(UIML_Datatypes[1], s), + _r_ = caml_call1(UIML_CML_Syntax[9], _q_); + return [0, + [0, [0, caml_call1(UIML_CML_Syntax[8], _r_), [0, a, 0]], 0], + _p_]; + } + l$0 = t; + } + } + function coq_KR_help01(prems, s, l1, x){ + if(! l1) throw caml_maybe_attach_backtrace([0, Assert_failure, _a_], 1); + var l = l1[2], y = l1[1]; + if(typeof y !== "number" && 2 === y[0]){ + var m = y[1]; + if(0 === x[0]) return [0, m, symbol]; + var x0$0 = x[3], h0 = coq_KR_help01(prems, s, l, x0$0), x1$0 = h0[1]; + return [0, x1$0, symbol]; + } + var x0 = coq_KR_help01(prems, s, l, x), x1 = x0[1]; + return [0, x1, symbol]; + } + function coq_KR_help1(prems, s, x){ + var + _n_ = caml_call1(UIML_Datatypes[2], s), + s0 = coq_KR_help01(prems, s, caml_call1(UIML_CML_Syntax[9], _n_), x), + x0 = s0[1], + l0 = s[2], + l = s[1], + h = caml_call2(UIML_List_lems[1], [2, x0], l0), + s1 = h[2], + x1 = h[1], + x2 = s1[1], + _o_ = caml_call1(UIML_KS_termination_prelims[6], l); + return [0, x0, caml_call1(UIML_CML_Syntax[9], l), l, x1, x2, _o_]; + } + function coq_KR_help02(UU0393, UU0394_0, UU0394_1, b_UU0393, a, l, x, x0){ + var l$0 = l; + for(;;){ + if(! l$0) throw caml_maybe_attach_backtrace([0, Assert_failure, _c_], 1); + var l0 = l$0[2], y = l$0[1]; + if(typeof y !== "number" && 2 === y[0]){ + var + m = y[1], + h0$0 = caml_call2(UIML_List_lems[1], [2, a], [0, [2, m], l0]), + s$0 = h0$0[2], + x1 = h0$0[1], + x2$0 = s$0[1], + _h_ = [1, caml_call2(UIML_GenT[1], [2, a], x2$0)], + h1$0 = + caml_call4(UIML_List_lemmasT[2], x1, [0, [2, a], x2$0], [2, a], _h_); + if(0 === h1$0[0]){ + var + _i_ = + prems_Box_R + (l0, + [0, + UU0393, + caml_call2(UIML_Datatypes[4], UU0394_0, [0, [2, a], UU0394_1])]), + _j_ = caml_call1(UIML_CML_Syntax[9], UU0393), + _k_ = [0, [0, caml_call1(UIML_CML_Syntax[8], _j_), [0, a, 0]], 0]; + return caml_call2(UIML_GenT[1], _k_, _i_); + } + var + i = coq_KR_help02(UU0393, UU0394_0, UU0394_1, b_UU0393, a, l0, x, x0), + _l_ = + prems_Box_R + (l0, + [0, + UU0393, + caml_call2(UIML_Datatypes[4], UU0394_0, [0, [2, a], UU0394_1])]), + _m_ = caml_call1(UIML_CML_Syntax[9], UU0393); + return [1, + [0, [0, caml_call1(UIML_CML_Syntax[8], _m_), [0, m, 0]], 0], + _l_, + i]; + } + var + h0 = caml_call2(UIML_List_lems[1], [2, a], [0, y, l0]), + s = h0[2], + x2 = h0[1], + x3 = s[1], + _g_ = [1, caml_call2(UIML_GenT[1], [2, a], x3)], + h1 = caml_call4(UIML_List_lemmasT[2], x2, [0, [2, a], x3], [2, a], _g_); + if(0 === h1[0]) + throw caml_maybe_attach_backtrace([0, Assert_failure, _b_], 1); + l$0 = l0; + } + } + function coq_KR_help2(param, _e_, x){ + var + x0 = x[6], + UU0394_1 = x[5], + UU0394_0 = x[4], + UU0393_0 = x[3], + b_UU0393 = x[2], + a = x[1], + _f_ = caml_call2(UIML_Datatypes[4], UU0394_0, [0, [2, a], UU0394_1]); + return coq_KR_help02 + (UU0393_0, + UU0394_0, + UU0394_1, + b_UU0393, + a, + caml_call1(UIML_CML_Syntax[9], _f_), + x, + x0); + } + function finite_KR_premises_of_S(param){ + var l0 = param[2], l = param[1]; + return [0, + prems_Box_R(caml_call1(UIML_CML_Syntax[9], l0), [0, l, l0]), + function(prems){ + return [0, + function(x){ + var + UU0394_1 = x[5], + UU0394_0 = x[4], + b_UU0393 = x[2], + a = x[1], + _d_ = + [0, + l, + caml_call2 + (UIML_Datatypes[4], UU0394_0, [0, [2, a], UU0394_1])]; + return coq_KR_help2 + ([0, caml_call1(UIML_CML_Syntax[8], b_UU0393), [0, a, 0]], + _d_, + x); + }, + function(h){return coq_KR_help1(prems, [0, l, l0], h);}]; + }]; + } + var + UIML_KS_termination_KR = + [0, + prems_Box_R, + coq_KR_help01, + coq_KR_help1, + coq_KR_help02, + coq_KR_help2, + finite_KR_premises_of_S]; + runtime.caml_register_global + (10, UIML_KS_termination_KR, "UIML__KS_termination_KR"); + return; + } + (globalThis)); + +//# 7044 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_Datatypes = global_data.UIML__Datatypes, + UIML_Environments = global_data.UIML__Environments, + UIML_Formulas = global_data.UIML__Formulas, + UIML_Base = global_data.UIML__Base, + UIML_List = global_data.UIML__List, + UIML_List0 = global_data.UIML__List0, + _a_ = [3, 0, 0], + _b_ = [3, 0, 0], + _c_ = [3, 0, 0], + _d_ = [3, 0, 0]; + function symbol(param){return symbol;} + function e_rule(p, UU0394, UU03d5, eA0, UU03b8){ + function e(UU0394_0){ + var _ai_ = caml_call2(eA0, [0, UU0394_0, UU03d5], symbol); + return caml_call1(UIML_Datatypes[1], _ai_); + } + function a(pe0){ + var _ah_ = caml_call2(eA0, pe0, symbol); + return caml_call1(UIML_Datatypes[2], _ah_); + } + var UU0394$0 = caml_call2(UIML_Environments[13], UU03b8, UU0394); + if(typeof UU03b8 === "number") return 0; + switch(UU03b8[0]){ + case 0: + var + q = UU03b8[1], + _U_ = caml_call3(UIML_Base[2], UIML_Formulas[3], p, q); + return caml_call1(UIML_Base[1], _U_) ? _a_ : [0, q]; + case 1: + var UU03b4_UU2082 = UU03b8[2], UU03b4_UU2081 = UU03b8[1]; + return e([0, UU03b4_UU2082, [0, UU03b4_UU2081, UU0394$0]]); + case 2: + var + UU03b4_UU2082$0 = UU03b8[2], + UU03b4_UU2081$0 = UU03b8[1], + _V_ = e([0, UU03b4_UU2082$0, UU0394$0]), + _W_ = e([0, UU03b4_UU2081$0, UU0394$0]); + return caml_call2(UIML_Environments[7], _W_, _V_); + case 3: + var UU03b4_2 = UU03b8[2], f = UU03b8[1]; + if(typeof f === "number") return _b_; + switch(f[0]){ + case 0: + var + q$0 = f[1], + _X_ = caml_call1(UIML_List0[2], UIML_Formulas[4]), + _Y_ = caml_call3(UIML_Base[2], _X_, [0, q$0], UU0394); + if(caml_call1(UIML_Base[1], _Y_)) return e([0, UU03b4_2, UU0394$0]); + var _Z_ = caml_call3(UIML_Base[2], UIML_Formulas[3], p, q$0); + if(caml_call1(UIML_Base[1], _Z_)) return _c_; + var ___ = e([0, UU03b4_2, UU0394$0]); + return caml_call2(UIML_Environments[8], [0, q$0], ___); + case 1: + var UU03b4_UU2082$1 = f[2], UU03b4_UU2081$1 = f[1]; + return e + ([0, + [3, UU03b4_UU2081$1, [3, UU03b4_UU2082$1, UU03b4_2]], + UU0394$0]); + case 2: + var UU03b4_UU2082$2 = f[2], UU03b4_UU2081$2 = f[1]; + return e + ([0, + [3, UU03b4_UU2082$2, UU03b4_2], + [0, [3, UU03b4_UU2081$2, UU03b4_2], UU0394$0]]); + case 3: + var + UU03b4_UU2082$3 = f[2], + UU03b4_UU2081$3 = f[1], + _$_ = e([0, UU03b4_2, UU0394$0]), + _aa_ = + a + ([0, + [0, + UU03b4_UU2081$3, + [0, [3, UU03b4_UU2082$3, UU03b4_2], UU0394$0]], + UU03b4_UU2082$3]), + _ab_ = + e + ([0, + UU03b4_UU2081$3, + [0, [3, UU03b4_UU2082$3, UU03b4_2], UU0394$0]]), + _ac_ = caml_call2(UIML_Environments[8], _ab_, _aa_); + return caml_call2(UIML_Environments[8], _ac_, _$_); + default: + var + UU03b4_1 = f[1], + _ad_ = e([0, UU03b4_2, UU0394$0]), + _ae_ = + a + ([0, + [0, + [4, UU03b4_1], + [0, + UU03b4_2, + caml_call2(UIML_List[4], UIML_Environments[14], UU0394$0)]], + UU03b4_1]), + _af_ = + e + ([0, + [4, UU03b4_1], + [0, + UU03b4_2, + caml_call2(UIML_List[4], UIML_Environments[14], UU0394$0)]]), + _ag_ = [4, caml_call2(UIML_Environments[8], _af_, _ae_)]; + return caml_call2(UIML_Environments[8], _ag_, _ad_); + } + default: + var UU03c6 = UU03b8[1]; + return [4, + e + ([0, + UU03c6, + caml_call2(UIML_List[4], UIML_Environments[14], UU0394$0)])]; + } + } + function a_rule_env(p, UU0394, UU03d5, eA0, UU03b8){ + function e(UU0394_0){ + var _T_ = caml_call2(eA0, [0, UU0394_0, UU03d5], symbol); + return caml_call1(UIML_Datatypes[1], _T_); + } + function a(pe0){ + var _S_ = caml_call2(eA0, pe0, symbol); + return caml_call1(UIML_Datatypes[2], _S_); + } + var UU0394$0 = caml_call2(UIML_Environments[13], UU03b8, UU0394); + if(typeof UU03b8 !== "number") + switch(UU03b8[0]){ + case 0: + var + q = UU03b8[1], + _z_ = caml_call3(UIML_Base[2], UIML_Formulas[3], p, q); + if(! caml_call1(UIML_Base[1], _z_)) return 0; + var _A_ = caml_call3(UIML_Base[2], UIML_Formulas[4], [0, p], UU03d5); + return caml_call1(UIML_Base[1], _A_) ? _d_ : 0; + case 1: + var UU03b4_UU2082 = UU03b8[2], UU03b4_UU2081 = UU03b8[1]; + return a + ([0, [0, UU03b4_UU2082, [0, UU03b4_UU2081, UU0394$0]], UU03d5]); + case 2: + var + UU03b4_UU2082$0 = UU03b8[2], + UU03b4_UU2081$0 = UU03b8[1], + _B_ = a([0, [0, UU03b4_UU2082$0, UU0394$0], UU03d5]), + _C_ = e([0, UU03b4_UU2082$0, UU0394$0]), + _D_ = caml_call2(UIML_Environments[8], _C_, _B_), + _E_ = a([0, [0, UU03b4_UU2081$0, UU0394$0], UU03d5]), + _F_ = e([0, UU03b4_UU2081$0, UU0394$0]), + _G_ = caml_call2(UIML_Environments[8], _F_, _E_); + return caml_call2(UIML_Environments[5], _G_, _D_); + case 3: + var UU03b4_2 = UU03b8[2], f = UU03b8[1]; + if(typeof f === "number") return 0; + switch(f[0]){ + case 0: + var + q$0 = f[1], + _H_ = caml_call1(UIML_List0[2], UIML_Formulas[4]), + _I_ = caml_call3(UIML_Base[2], _H_, [0, q$0], UU0394); + if(caml_call1(UIML_Base[1], _I_)) + return a([0, [0, UU03b4_2, UU0394$0], UU03d5]); + var _J_ = caml_call3(UIML_Base[2], UIML_Formulas[3], p, q$0); + if(caml_call1(UIML_Base[1], _J_)) return 0; + var _K_ = a([0, [0, UU03b4_2, UU0394$0], UU03d5]); + return caml_call2(UIML_Environments[5], [0, q$0], _K_); + case 1: + var UU03b4_UU2082$1 = f[2], UU03b4_UU2081$1 = f[1]; + return a + ([0, + [0, + [3, UU03b4_UU2081$1, [3, UU03b4_UU2082$1, UU03b4_2]], + UU0394$0], + UU03d5]); + case 2: + var UU03b4_UU2082$2 = f[2], UU03b4_UU2081$2 = f[1]; + return a + ([0, + [0, + [3, UU03b4_UU2082$2, UU03b4_2], + [0, [3, UU03b4_UU2081$2, UU03b4_2], UU0394$0]], + UU03d5]); + case 3: + var + UU03b4_UU2082$3 = f[2], + UU03b4_UU2081$3 = f[1], + _L_ = a([0, [0, UU03b4_2, UU0394$0], UU03d5]), + _M_ = + a + ([0, + [0, + UU03b4_UU2081$3, + [0, [3, UU03b4_UU2082$3, UU03b4_2], UU0394$0]], + UU03b4_UU2082$3]), + _N_ = + e + ([0, + UU03b4_UU2081$3, + [0, [3, UU03b4_UU2082$3, UU03b4_2], UU0394$0]]), + _O_ = caml_call2(UIML_Environments[8], _N_, _M_); + return caml_call2(UIML_Environments[5], _O_, _L_); + default: + var + UU03b4_1 = f[1], + _P_ = a([0, [0, UU03b4_2, UU0394$0], UU03d5]), + _Q_ = + a + ([0, + [0, + [4, UU03b4_1], + [0, + UU03b4_2, + caml_call2(UIML_List[4], UIML_Environments[14], UU0394$0)]], + UU03b4_1]), + _R_ = + e + ([0, + [4, UU03b4_1], + [0, + UU03b4_2, + caml_call2(UIML_List[4], UIML_Environments[14], UU0394$0)]]); + return [1, [4, caml_call2(UIML_Environments[8], _R_, _Q_)], _P_]; + } + } + return 0; + } + function a_rule_form(p, UU0394, UU03d5, eA0){ + function e(pe0){ + var _y_ = caml_call2(eA0, pe0, symbol); + return caml_call1(UIML_Datatypes[1], _y_); + } + function a(pe0){ + var _x_ = caml_call2(eA0, pe0, symbol); + return caml_call1(UIML_Datatypes[2], _x_); + } + if(typeof UU03d5 === "number") return 0; + switch(UU03d5[0]){ + case 0: + var + q = UU03d5[1], + _o_ = caml_call3(UIML_Base[2], UIML_Formulas[3], p, q); + return caml_call1(UIML_Base[1], _o_) ? 0 : [0, q]; + case 1: + var + UU03d5_UU2082 = UU03d5[2], + UU03d5_UU2081 = UU03d5[1], + _p_ = a([0, UU0394, UU03d5_UU2082]), + _q_ = a([0, UU0394, UU03d5_UU2081]); + return caml_call2(UIML_Environments[5], _q_, _p_); + case 2: + var + UU03d5_UU2082$0 = UU03d5[2], + UU03d5_UU2081$0 = UU03d5[1], + _r_ = a([0, UU0394, UU03d5_UU2082$0]), + _s_ = a([0, UU0394, UU03d5_UU2081$0]); + return caml_call2(UIML_Environments[7], _s_, _r_); + case 3: + var + UU03d5_UU2082$1 = UU03d5[2], + UU03d5_UU2081$1 = UU03d5[1], + _t_ = a([0, [0, UU03d5_UU2081$1, UU0394], UU03d5_UU2082$1]), + _u_ = e([0, [0, UU03d5_UU2081$1, UU0394], UU03d5_UU2082$1]); + return caml_call2(UIML_Environments[8], _u_, _t_); + default: + var + UU03b4 = UU03d5[1], + _v_ = + a + ([0, + [0, + [4, UU03b4], + caml_call2(UIML_List[4], UIML_Environments[14], UU0394)], + UU03b4]), + _w_ = + e + ([0, + [0, + [4, UU03b4], + caml_call2(UIML_List[4], UIML_Environments[14], UU0394)], + UU03b4]); + return [4, caml_call2(UIML_Environments[8], _w_, _v_)]; + } + } + function coq_EA(p, x){ + var + UU0394 = caml_call1(UIML_Datatypes[1], x), + _g_ = caml_call1(UIML_Datatypes[2], x), + _h_ = + a_rule_form + (p, + caml_call1(UIML_Datatypes[1], x), + _g_, + function(pe, param){return coq_EA(p, pe);}), + _i_ = + caml_call2 + (UIML_Environments[12], + UU0394, + function(x0, param){ + var _n_ = caml_call1(UIML_Datatypes[2], x); + return a_rule_env + (p, + caml_call1(UIML_Datatypes[1], x), + _n_, + function(pe, param){return coq_EA(p, pe);}, + x0); + }), + _j_ = caml_call1(UIML_Environments[10], _i_), + _k_ = caml_call2(UIML_Environments[7], _j_, _h_), + _l_ = + caml_call2 + (UIML_Environments[12], + UU0394, + function(x0, param){ + var _m_ = caml_call1(UIML_Datatypes[2], x); + return e_rule + (p, + caml_call1(UIML_Datatypes[1], x), + _m_, + function(pe, param){return coq_EA(p, pe);}, + x0); + }); + return [0, caml_call1(UIML_Environments[9], _l_), _k_]; + } + function coq_E(p, pe){ + var _f_ = coq_EA(p, pe); + return caml_call1(UIML_Datatypes[1], _f_); + } + function coq_A(p, pe){ + var _e_ = coq_EA(p, pe); + return caml_call1(UIML_Datatypes[2], _e_); + } + function coq_Ef(p, UU03c8){return coq_E(p, [0, [0, UU03c8, 0], 0]);} + function coq_Af(p, UU03c8){return coq_A(p, [0, 0, UU03c8]);} + var + UIML_PropQuantifiers = + [0, + e_rule, + a_rule_env, + a_rule_form, + coq_EA, + coq_E, + coq_A, + coq_Ef, + coq_Af]; + runtime.caml_register_global + (10, UIML_PropQuantifiers, "UIML__PropQuantifiers"); + return; + } + (globalThis)); + +//# 7415 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_Environments = global_data.UIML__Environments, + UIML_PropQuantifiers = global_data.UIML__PropQuantifiers, + UIML_Formulas = global_data.UIML__Formulas, + UIML_Base = global_data.UIML__Base, + UIML_Numbers = global_data.UIML__Numbers; + function simp_ors(UU03c6, UU03c8){ + if(typeof UU03c6 !== "number" && 2 === UU03c6[0]){ + var UU03c6_2 = UU03c6[2], UU03c6_1 = UU03c6[1]; + if(typeof UU03c8 !== "number" && 2 === UU03c8[0]){ + var + UU03c8_2$0 = UU03c8[2], + UU03c8_1$0 = UU03c8[1], + _u_ = simp_ors(UU03c6_2, UU03c8_2$0), + _v_ = caml_call2(UIML_Environments[7], UU03c8_1$0, _u_); + return caml_call2(UIML_Environments[7], UU03c6_1, _v_); + } + return caml_call2(UIML_Environments[7], UU03c8, [2, UU03c6_1, UU03c6_2]); + } + if(typeof UU03c8 !== "number" && 2 === UU03c8[0]){ + var UU03c8_2 = UU03c8[2], UU03c8_1 = UU03c8[1]; + return caml_call2(UIML_Environments[7], UU03c6, [2, UU03c8_1, UU03c8_2]); + } + return caml_call2(UIML_Environments[7], UU03c6, UU03c8); + } + function simp_ands(UU03c6, UU03c8){ + if(typeof UU03c6 !== "number" && 1 === UU03c6[0]){ + var UU03c6_2 = UU03c6[2], UU03c6_1 = UU03c6[1]; + if(typeof UU03c8 !== "number" && 1 === UU03c8[0]){ + var + UU03c8_2$0 = UU03c8[2], + UU03c8_1$0 = UU03c8[1], + _s_ = simp_ands(UU03c6_2, UU03c8_2$0), + _t_ = caml_call2(UIML_Environments[5], UU03c8_1$0, _s_); + return caml_call2(UIML_Environments[5], UU03c6_1, _t_); + } + return caml_call2(UIML_Environments[5], UU03c8, [1, UU03c6_1, UU03c6_2]); + } + if(typeof UU03c8 !== "number" && 1 === UU03c8[0]){ + var UU03c8_2 = UU03c8[2], UU03c8_1 = UU03c8[1]; + return caml_call2(UIML_Environments[5], UU03c6, [1, UU03c8_1, UU03c8_2]); + } + return caml_call2(UIML_Environments[5], UU03c6, UU03c8); + } + function simp_imp(UU03c6, UU03c8){ + var + _e_ = caml_call2(UIML_Environments[3], UU03c6, UU03c8), + _f_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _e_, 1); + if(caml_call1(UIML_Base[1], _f_)) + return caml_call1(UIML_Base[3], UIML_Formulas[2]); + var + _g_ = caml_call1(UIML_Base[4], UIML_Formulas[1]), + _h_ = caml_call2(UIML_Environments[3], UU03c6, _g_), + _i_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _h_, 1); + if(caml_call1(UIML_Base[1], _i_)) + return caml_call1(UIML_Base[3], UIML_Formulas[2]); + var + _j_ = caml_call1(UIML_Base[3], UIML_Formulas[2]), + _k_ = caml_call2(UIML_Environments[3], UU03c8, _j_), + _l_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _k_, 2); + if(caml_call1(UIML_Base[1], _l_)) + return caml_call1(UIML_Base[3], UIML_Formulas[2]); + var + _m_ = caml_call1(UIML_Base[3], UIML_Formulas[2]), + _n_ = caml_call2(UIML_Environments[3], UU03c6, _m_), + _o_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _n_, 2); + if(caml_call1(UIML_Base[1], _o_)) return UU03c8; + var + _p_ = caml_call1(UIML_Base[4], UIML_Formulas[1]), + _q_ = caml_call2(UIML_Environments[3], UU03c8, _p_), + _r_ = caml_call3(UIML_Base[2], UIML_Numbers[1], _q_, 1); + return caml_call1(UIML_Base[1], _r_) + ? [3, UU03c6, 0] + : [3, UU03c6, UU03c8]; + } + function simp_imps(UU03c6, UU03c8){ + var UU03c6$0 = UU03c6, UU03c8$0 = UU03c8; + for(;;){ + if(typeof UU03c8$0 !== "number" && 3 === UU03c8$0[0]){ + var + UU03c8_2 = UU03c8$0[2], + UU03c8_1 = UU03c8$0[1], + UU03c6$1 = simp_ands(UU03c6$0, UU03c8_1); + UU03c6$0 = UU03c6$1; + UU03c8$0 = UU03c8_2; + continue; + } + return simp_imp(UU03c6$0, UU03c8$0); + } + } + function simp(UU03c6){ + if(typeof UU03c6 !== "number") + switch(UU03c6[0]){ + case 1: + var UU03c8 = UU03c6[2], UU03c6_0 = UU03c6[1], _b_ = simp(UU03c8); + return simp_ands(simp(UU03c6_0), _b_); + case 2: + var + UU03c8$0 = UU03c6[2], + UU03c6_0$0 = UU03c6[1], + _c_ = simp(UU03c8$0); + return simp_ors(simp(UU03c6_0$0), _c_); + case 3: + var + UU03c8$1 = UU03c6[2], + UU03c6_0$1 = UU03c6[1], + _d_ = simp(UU03c8$1); + return simp_imps(simp(UU03c6_0$1), _d_); + case 4: + var UU03c6_0$2 = UU03c6[1]; return [4, simp(UU03c6_0$2)]; + } + return UU03c6; + } + function coq_E_simplified(p, UU03c8){ + var _a_ = [0, [0, UU03c8, 0], caml_call1(UIML_Base[4], UIML_Formulas[1])]; + return simp(caml_call2(UIML_PropQuantifiers[5], p, _a_)); + } + function coq_A_simplified(p, UU03c8){ + return simp(caml_call2(UIML_PropQuantifiers[8], p, UU03c8)); + } + var + UIML_Simp = + [0, + simp_ors, + simp_ands, + simp_imp, + simp_imps, + simp, + coq_E_simplified, + coq_A_simplified]; + runtime.caml_register_global(5, UIML_Simp, "UIML__Simp"); + return; + } + (globalThis)); + +//# 7572 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_Datatypes = global_data.UIML__Datatypes; + function symbol(param){return symbol;} + function list_is_nil(param){return param ? 0 : 1;} + function flatmap(f, param){ + if(! param) return 0; + var + l0 = param[2], + x = param[1], + _a_ = flatmap(f, l0), + _b_ = caml_call2(f, x, symbol); + return caml_call2(UIML_Datatypes[4], _b_, _a_); + } + function irred(f, x){ + return list_is_nil(caml_call1(f, x)) + ? [0, x, 0] + : flatmap + (function(y, param){return irred(f, y);}, caml_call1(f, x)); + } + var UIML_UIGL_irred_short = [0, list_is_nil, flatmap, irred]; + runtime.caml_register_global + (1, UIML_UIGL_irred_short, "UIML__UIGL_irred_short"); + return; + } + (globalThis)); + +//# 7615 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call4(f, a0, a1, a2, a3){ + return (f.l >= 0 ? f.l : f.l = f.length) == 4 + ? f(a0, a1, a2, a3) + : runtime.caml_call_gen(f, [a0, a1, a2, a3]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_Datatypes = global_data.UIML__Datatypes, + UIML_GLS_der_dec = global_data.UIML__GLS_der_dec, + UIML_List_lemmasT = global_data.UIML__List_lemmasT, + UIML_UIGL_irred_short = global_data.UIML__UIGL_irred_short; + function symbol(param){return symbol;} + function finite_ImpRules_premises_of_S(s){ + var + s0 = caml_call1(UIML_GLS_der_dec[23], s), + p = s0[2], + x = s0[1], + s1 = caml_call1(UIML_GLS_der_dec[30], s), + p0 = s1[2], + x0 = s1[1]; + return [0, + caml_call2(UIML_Datatypes[4], x, x0), + function(prems){ + return [0, + function(h){ + if(0 === h[0]){ + var + i = h[1], + UU0394_1 = i[6], + UU0394_0 = i[5], + UU0393_1 = i[4], + UU0393_0 = i[3], + b = i[2], + a = i[1], + _c_ = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1]), + prems0 = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + _c_], + 0], + x1 = caml_call1(p, prems0)[1], + _d_ = + [0, + caml_call1 + (x1, [0, a, b, UU0393_0, UU0393_1, UU0394_0, UU0394_1])], + _e_ = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1]), + _f_ = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + _e_], + 0]; + return caml_call4(UIML_List_lemmasT[2], x, x0, _f_, _d_); + } + var + i$0 = h[1], + UU0394_1$0 = i$0[6], + UU0394_0$0 = i$0[5], + UU0393_1$0 = i$0[4], + UU0393_0$0 = i$0[3], + b$0 = i$0[2], + a$0 = i$0[1], + _g_ = caml_call2(UIML_Datatypes[4], UU0394_0$0, UU0394_1$0), + _h_ = + [0, + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0$0, [0, b$0, UU0393_1$0]), + _g_], + 0], + _i_ = + caml_call2 + (UIML_Datatypes[4], UU0394_0$0, [0, a$0, UU0394_1$0]), + prems0$0 = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0$0, UU0393_1$0), + _i_], + _h_], + x1$0 = caml_call1(p0, prems0$0)[1], + _j_ = + [1, + caml_call1 + (x1$0, + [0, + a$0, + b$0, + UU0393_0$0, + UU0393_1$0, + UU0394_0$0, + UU0394_1$0])], + _k_ = caml_call2(UIML_Datatypes[4], UU0394_0$0, UU0394_1$0), + _l_ = + [0, + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0$0, [0, b$0, UU0393_1$0]), + _k_], + 0], + _m_ = + caml_call2 + (UIML_Datatypes[4], UU0394_0$0, [0, a$0, UU0394_1$0]), + _n_ = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0$0, UU0393_1$0), + _m_], + _l_]; + return caml_call4(UIML_List_lemmasT[2], x, x0, _n_, _j_); + }, + function(h){ + var h0 = caml_call4(UIML_List_lemmasT[1], x, x0, prems, h); + if(0 === h0[0]){ + var i = h0[1], x1 = caml_call1(p, prems)[2]; + return [0, caml_call1(x1, i)]; + } + var i$0 = h0[1], x1$0 = caml_call1(p0, prems)[2]; + return [1, caml_call1(x1$0, i$0)]; + }]; + }]; + } + function inv_prems(s){ + var + _a_ = finite_ImpRules_premises_of_S(s), + _b_ = caml_call1(UIML_GLS_der_dec[1], _a_); + return caml_call1(UIML_GLS_der_dec[7], _b_); + } + var coq_Canopy = caml_call1(UIML_UIGL_irred_short[3], inv_prems); + function is_Prime_dec(param){ + if(! param) return [0, symbol]; + var l0 = param[2], y = param[1]; + if(0 !== is_Prime_dec(l0)[0]) return [1, symbol]; + if(typeof y !== "number" && 1 === y[0]) return [1, symbol]; + return [0, symbol]; + } + function critical_Seq_dec(param){ + var l0 = param[2], l = param[1]; + return is_Prime_dec(caml_call2(UIML_Datatypes[4], l, l0)); + } + var + UIML_UIGL_Canopy = + [0, + finite_ImpRules_premises_of_S, + inv_prems, + coq_Canopy, + is_Prime_dec, + critical_Seq_dec]; + runtime.caml_register_global(4, UIML_UIGL_Canopy, "UIML__UIGL_Canopy"); + return; + } + (globalThis)); + +//# 7786 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_GLS_der_dec = global_data.UIML__GLS_der_dec; + function symbol(param){return symbol;} + function coq_GLR_prems(s){ + var + _a_ = caml_call1(UIML_GLS_der_dec[36], s), + _b_ = caml_call1(UIML_GLS_der_dec[1], _a_); + return caml_call1(UIML_GLS_der_dec[7], _b_); + } + function coq_LexSeq_ind(x, s){ + return caml_call2 + (x, s, function(s1, param){return coq_LexSeq_ind(x, s1);}); + } + function empty_seq_dec(param){ + var l0 = param[2], l = param[1]; + return l ? [1, symbol] : l0 ? [1, symbol] : [0, symbol]; + } + var UIML_UIGL_LexSeq = [0, coq_GLR_prems, coq_LexSeq_ind, empty_seq_dec]; + runtime.caml_register_global(1, UIML_UIGL_LexSeq, "UIML__UIGL_LexSeq"); + return; + } + (globalThis)); + +//# 7826 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_CML_Syntax = global_data.UIML__CML_Syntax, + UIML_Datatypes = global_data.UIML__Datatypes, + UIML_List = global_data.UIML__List; + function list_conj(param){ + if(! param) return UIML_CML_Syntax[1]; + var t = param[2], h = param[1], _e_ = list_conj(t); + return caml_call2(UIML_CML_Syntax[3], h, _e_); + } + function list_disj(param){ + if(! param) return 0; + var t = param[2], h = param[1], _d_ = list_disj(t); + return caml_call2(UIML_CML_Syntax[4], h, _d_); + } + function list_prop_F(param){ + if(typeof param !== "number" && 0 === param[0]){var p = param[1]; return [0, [0, p], 0];} + return 0; + } + function list_prop_LF(param){ + if(! param) return 0; + var + t = param[2], + h = param[1], + _b_ = list_prop_LF(t), + _c_ = list_prop_F(h); + return caml_call2(UIML_Datatypes[4], _c_, _b_); + } + function restr_list_prop(p, l){ + var _a_ = list_prop_LF(l); + return caml_call3(UIML_List[2], UIML_CML_Syntax[6], [0, p], _a_); + } + var + UIML_UIGL_basics = + [0, list_conj, list_disj, list_prop_F, list_prop_LF, restr_list_prop]; + runtime.caml_register_global(3, UIML_UIGL_basics, "UIML__UIGL_basics"); + return; + } + (globalThis)); + +//# 7882 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_Datatypes = global_data.UIML__Datatypes, + UIML_CML_Syntax = global_data.UIML__CML_Syntax, + UIML_List = global_data.UIML__List; + function nodupseq(s){ + var + _a_ = caml_call1(UIML_Datatypes[2], s), + _b_ = caml_call2(UIML_List[5], UIML_CML_Syntax[6], _a_), + _c_ = caml_call1(UIML_Datatypes[1], s); + return [0, caml_call2(UIML_List[5], UIML_CML_Syntax[6], _c_), _b_]; + } + var UIML_UIGL_nodupseq = [0, nodupseq]; + runtime.caml_register_global(3, UIML_UIGL_nodupseq, "UIML__UIGL_nodupseq"); + return; + } + (globalThis)); + +//# 7916 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_UIGL_nodupseq = global_data.UIML__UIGL_nodupseq, + UIML_UIGL_Canopy = global_data.UIML__UIGL_Canopy, + UIML_Datatypes = global_data.UIML__Datatypes, + UIML_CML_Syntax = global_data.UIML__CML_Syntax, + UIML_GLS_calcs = global_data.UIML__GLS_calcs, + UIML_UIGL_LexSeq = global_data.UIML__UIGL_LexSeq, + UIML_GLS_dec = global_data.UIML__GLS_dec, + UIML_GLS_termination_measure = global_data.UIML__GLS_termination_measure, + UIML_Compare_dec = global_data.UIML__Compare_dec, + UIML_List = global_data.UIML__List, + UIML_UIGL_basics = global_data.UIML__UIGL_basics; + function symbol(param){return symbol;} + function imap(f, param){ + if(! param) return 0; + var l0 = param[2], x = param[1], _I_ = imap(f, l0); + return [0, caml_call2(f, x, symbol), _I_]; + } + function coq_GUI_tot(p){ + return caml_call1 + (UIML_UIGL_LexSeq[2], + function(s, iH){ + var s0 = caml_call1(UIML_UIGL_LexSeq[3], s); + if(0 === s0[0]) return 0; + var s1 = caml_call1(UIML_UIGL_Canopy[5], s); + if(0 !== s1[0]){ + var + _s_ = caml_call1(UIML_UIGL_nodupseq[1], s), + s3 = + imap + (function(x, param){return caml_call2(iH, x, symbol);}, + caml_call1(UIML_UIGL_Canopy[3], _s_)); + return caml_call1(UIML_UIGL_basics[1], s3); + } + var s2 = caml_call1(UIML_GLS_dec[4], s); + if(0 === s2[0]) return UIML_CML_Syntax[1]; + var + _a_ = caml_call1(UIML_UIGL_nodupseq[1], s), + s4 = + imap + (function(x, param){return caml_call2(iH, x, symbol);}, + caml_call1(UIML_UIGL_LexSeq[1], _a_)), + _b_ = caml_call1(UIML_Datatypes[1], s), + _c_ = caml_call1(UIML_CML_Syntax[9], _b_), + _d_ = [0, caml_call1(UIML_GLS_calcs[1], _c_), 0], + _e_ = caml_call1(UIML_UIGL_nodupseq[1], _d_), + s6 = + imap + (function(z, param){ + var s5 = caml_call1(UIML_GLS_dec[4], z); + if(0 === s5[0]) return UIML_CML_Syntax[1]; + var + _t_ = caml_call1(UIML_GLS_termination_measure[4], s), + _u_ = caml_call1(UIML_Datatypes[3], _t_), + _v_ = caml_call1(UIML_GLS_termination_measure[4], z), + _w_ = caml_call1(UIML_Datatypes[3], _v_), + s6 = caml_call2(UIML_Compare_dec[4], _w_, _u_); + if(s6) return caml_call2(iH, z, symbol); + var + _x_ = caml_call1(UIML_UIGL_nodupseq[1], z), + s8 = + imap + (function(x0, param){return caml_call2(iH, x0, symbol);}, + caml_call1(UIML_UIGL_LexSeq[1], _x_)), + _y_ = + caml_call2(UIML_List[4], function(x){return [2, x];}, s8), + _z_ = caml_call1(UIML_UIGL_basics[2], _y_), + _A_ = caml_call1(UIML_Datatypes[1], z), + _B_ = caml_call2(UIML_UIGL_basics[5], p, _A_), + _C_ = caml_call2(UIML_List[4], UIML_CML_Syntax[2], _B_), + _D_ = caml_call1(UIML_UIGL_basics[2], _C_), + _E_ = caml_call2(UIML_CML_Syntax[4], _D_, _z_), + _F_ = caml_call1(UIML_Datatypes[2], z), + _G_ = caml_call2(UIML_UIGL_basics[5], p, _F_), + _H_ = caml_call1(UIML_UIGL_basics[2], _G_); + return caml_call2(UIML_CML_Syntax[4], _H_, _E_); + }, + caml_call1(UIML_UIGL_Canopy[3], _e_)), + _f_ = caml_call1(UIML_UIGL_basics[1], s6), + _g_ = caml_call1(UIML_CML_Syntax[5], _f_), + _h_ = caml_call2(UIML_List[4], function(x){return [2, x];}, s4), + _i_ = caml_call1(UIML_UIGL_basics[2], _h_), + _j_ = caml_call2(UIML_CML_Syntax[4], _i_, _g_), + _k_ = caml_call1(UIML_Datatypes[1], s), + _l_ = caml_call2(UIML_UIGL_basics[5], p, _k_), + _m_ = caml_call2(UIML_List[4], UIML_CML_Syntax[2], _l_), + _n_ = caml_call1(UIML_UIGL_basics[2], _m_), + _o_ = caml_call2(UIML_CML_Syntax[4], _n_, _j_), + _p_ = caml_call1(UIML_Datatypes[2], s), + _q_ = caml_call2(UIML_UIGL_basics[5], p, _p_), + _r_ = caml_call1(UIML_UIGL_basics[2], _q_); + return caml_call2(UIML_CML_Syntax[4], _r_, _o_); + }); + } + var UIML_UIGL_braga = [0, imap, coq_GUI_tot]; + runtime.caml_register_global(11, UIML_UIGL_braga, "UIML__UIGL_braga"); + return; + } + (globalThis)); + +//# 8033 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_Datatypes = global_data.UIML__Datatypes; + function symbol(param){return symbol;} + function list_is_nil(param){return param ? 0 : 1;} + function flatmap(f, param){ + if(! param) return 0; + var + l0 = param[2], + x = param[1], + _a_ = flatmap(f, l0), + _b_ = caml_call2(f, x, symbol); + return caml_call2(UIML_Datatypes[4], _b_, _a_); + } + function irred(f, x){ + return list_is_nil(caml_call1(f, x)) + ? [0, x, 0] + : flatmap + (function(y, param){return irred(f, y);}, caml_call1(f, x)); + } + var UIML_UIK_irred_short = [0, list_is_nil, flatmap, irred]; + runtime.caml_register_global + (1, UIML_UIK_irred_short, "UIML__UIK_irred_short"); + return; + } + (globalThis)); + +//# 8076 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call4(f, a0, a1, a2, a3){ + return (f.l >= 0 ? f.l : f.l = f.length) == 4 + ? f(a0, a1, a2, a3) + : runtime.caml_call_gen(f, [a0, a1, a2, a3]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_Datatypes = global_data.UIML__Datatypes, + UIML_KS_termination_prelims = global_data.UIML__KS_termination_prelims, + UIML_List_lemmasT = global_data.UIML__List_lemmasT, + UIML_KS_termination_ImpR = global_data.UIML__KS_termination_ImpR, + UIML_KS_termination_ImpL = global_data.UIML__KS_termination_ImpL, + UIML_UIK_irred_short = global_data.UIML__UIK_irred_short; + function symbol(param){return symbol;} + function finite_ImpRules_premises_of_S(s){ + var + s0 = caml_call1(UIML_KS_termination_ImpR[8], s), + p = s0[2], + x = s0[1], + s1 = caml_call1(UIML_KS_termination_ImpL[7], s), + p0 = s1[2], + x0 = s1[1]; + return [0, + caml_call2(UIML_Datatypes[4], x, x0), + function(prems){ + return [0, + function(h){ + if(0 === h[0]){ + var + i = h[1], + UU0394_1 = i[6], + UU0394_0 = i[5], + UU0393_1 = i[4], + UU0393_0 = i[3], + b = i[2], + a = i[1], + _c_ = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1]), + prems0 = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + _c_], + 0], + x1 = caml_call1(p, prems0)[1], + _d_ = + [0, + caml_call1 + (x1, [0, a, b, UU0393_0, UU0393_1, UU0394_0, UU0394_1])], + _e_ = + caml_call2(UIML_Datatypes[4], UU0394_0, [0, b, UU0394_1]), + _f_ = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0, [0, a, UU0393_1]), + _e_], + 0]; + return caml_call4(UIML_List_lemmasT[2], x, x0, _f_, _d_); + } + var + i$0 = h[1], + UU0394_1$0 = i$0[6], + UU0394_0$0 = i$0[5], + UU0393_1$0 = i$0[4], + UU0393_0$0 = i$0[3], + b$0 = i$0[2], + a$0 = i$0[1], + _g_ = caml_call2(UIML_Datatypes[4], UU0394_0$0, UU0394_1$0), + _h_ = + [0, + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0$0, [0, b$0, UU0393_1$0]), + _g_], + 0], + _i_ = + caml_call2 + (UIML_Datatypes[4], UU0394_0$0, [0, a$0, UU0394_1$0]), + prems0$0 = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0$0, UU0393_1$0), + _i_], + _h_], + x1$0 = caml_call1(p0, prems0$0)[1], + _j_ = + [1, + caml_call1 + (x1$0, + [0, + a$0, + b$0, + UU0393_0$0, + UU0393_1$0, + UU0394_0$0, + UU0394_1$0])], + _k_ = caml_call2(UIML_Datatypes[4], UU0394_0$0, UU0394_1$0), + _l_ = + [0, + [0, + caml_call2 + (UIML_Datatypes[4], UU0393_0$0, [0, b$0, UU0393_1$0]), + _k_], + 0], + _m_ = + caml_call2 + (UIML_Datatypes[4], UU0394_0$0, [0, a$0, UU0394_1$0]), + _n_ = + [0, + [0, + caml_call2(UIML_Datatypes[4], UU0393_0$0, UU0393_1$0), + _m_], + _l_]; + return caml_call4(UIML_List_lemmasT[2], x, x0, _n_, _j_); + }, + function(h){ + var h0 = caml_call4(UIML_List_lemmasT[1], x, x0, prems, h); + if(0 === h0[0]){ + var i = h0[1], x1 = caml_call1(p, prems)[2]; + return [0, caml_call1(x1, i)]; + } + var i$0 = h0[1], x1$0 = caml_call1(p0, prems)[2]; + return [1, caml_call1(x1$0, i$0)]; + }]; + }]; + } + function inv_prems(s){ + var + _a_ = finite_ImpRules_premises_of_S(s), + _b_ = caml_call1(UIML_KS_termination_prelims[1], _a_); + return caml_call1(UIML_KS_termination_prelims[7], _b_); + } + var coq_Canopy = caml_call1(UIML_UIK_irred_short[3], inv_prems); + function is_Prime_dec(param){ + if(! param) return [0, symbol]; + var l0 = param[2], y = param[1]; + if(0 !== is_Prime_dec(l0)[0]) return [1, symbol]; + if(typeof y !== "number" && 1 === y[0]) return [1, symbol]; + return [0, symbol]; + } + function critical_Seq_dec(param){ + var l0 = param[2], l = param[1]; + return is_Prime_dec(caml_call2(UIML_Datatypes[4], l, l0)); + } + var + UIML_UIK_Canopy = + [0, + finite_ImpRules_premises_of_S, + inv_prems, + coq_Canopy, + is_Prime_dec, + critical_Seq_dec]; + runtime.caml_register_global(6, UIML_UIK_Canopy, "UIML__UIK_Canopy"); + return; + } + (globalThis)); + +//# 8249 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_CML_Syntax = global_data.UIML__CML_Syntax, + UIML_Datatypes = global_data.UIML__Datatypes, + UIML_KS_termination_KR = global_data.UIML__KS_termination_KR, + UIML_KS_termination_prelims = global_data.UIML__KS_termination_prelims, + UIML_List = global_data.UIML__List; + function symbol(param){return symbol;} + function list_conj(param){ + if(! param) return UIML_CML_Syntax[1]; + var t = param[2], h = param[1], _g_ = list_conj(t); + return caml_call2(UIML_CML_Syntax[3], h, _g_); + } + function list_disj(param){ + if(! param) return 0; + var t = param[2], h = param[1], _f_ = list_disj(t); + return caml_call2(UIML_CML_Syntax[4], h, _f_); + } + function list_prop_F(param){ + if(typeof param !== "number" && 0 === param[0]){var p = param[1]; return [0, [0, p], 0];} + return 0; + } + function list_prop_LF(param){ + if(! param) return 0; + var + t = param[2], + h = param[1], + _d_ = list_prop_LF(t), + _e_ = list_prop_F(h); + return caml_call2(UIML_Datatypes[4], _e_, _d_); + } + function restr_list_prop(p, l){ + var _c_ = list_prop_LF(l); + return caml_call3(UIML_List[2], UIML_CML_Syntax[6], [0, p], _c_); + } + function coq_KR_prems(s){ + var + _a_ = caml_call1(UIML_KS_termination_KR[6], s), + _b_ = caml_call1(UIML_KS_termination_prelims[1], _a_); + return caml_call1(UIML_KS_termination_prelims[7], _b_); + } + function coq_LtSeq_ind(x, s){ + return caml_call2(x, s, function(s1, param){return coq_LtSeq_ind(x, s1);}); + } + function empty_seq_dec(param){ + var l0 = param[2], l = param[1]; + return l ? [1, symbol] : l0 ? [1, symbol] : [0, symbol]; + } + var + UIML_UIK_basics = + [0, + list_conj, + list_disj, + list_prop_F, + list_prop_LF, + restr_list_prop, + coq_KR_prems, + coq_LtSeq_ind, + empty_seq_dec]; + runtime.caml_register_global(5, UIML_UIK_basics, "UIML__UIK_basics"); + return; + } + (globalThis)); + +//# 8334 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_UIK_Canopy = global_data.UIML__UIK_Canopy, + UIML_UIK_basics = global_data.UIML__UIK_basics, + UIML_KS_dec = global_data.UIML__KS_dec, + UIML_CML_Syntax = global_data.UIML__CML_Syntax, + UIML_Datatypes = global_data.UIML__Datatypes, + UIML_List_lems = global_data.UIML__List_lems, + UIML_List = global_data.UIML__List; + function symbol(param){return symbol;} + function imap(f, param){ + if(! param) return 0; + var l0 = param[2], x = param[1], _B_ = imap(f, l0); + return [0, caml_call2(f, x, symbol), _B_]; + } + function coq_GUI_tot(p){ + return caml_call1 + (UIML_UIK_basics[7], + function(s, iH){ + var s0 = caml_call1(UIML_UIK_basics[8], s); + if(0 === s0[0]) return 0; + var s1 = caml_call1(UIML_UIK_Canopy[5], s); + if(0 !== s1[0]){ + var + s3 = + imap + (function(x, param){return caml_call2(iH, x, symbol);}, + caml_call1(UIML_UIK_Canopy[3], s)); + return caml_call1(UIML_UIK_basics[1], s3); + } + var s2 = caml_call1(UIML_KS_dec[3], s); + if(0 === s2[0]) return UIML_CML_Syntax[1]; + var + s4 = + imap + (function(x, param){return caml_call2(iH, x, symbol);}, + caml_call1(UIML_UIK_basics[6], s)), + _a_ = caml_call1(UIML_Datatypes[1], s), + s5 = caml_call2(UIML_List_lems[2], _a_, 0); + if(s5){ + var + _b_ = caml_call1(UIML_CML_Syntax[5], 0), + _c_ = + caml_call2(UIML_List[4], function(x){return [2, x];}, s4), + _d_ = caml_call1(UIML_UIK_basics[2], _c_), + _e_ = caml_call2(UIML_CML_Syntax[4], _d_, _b_), + _f_ = caml_call1(UIML_Datatypes[1], s), + _g_ = caml_call2(UIML_UIK_basics[5], p, _f_), + _h_ = caml_call2(UIML_List[4], UIML_CML_Syntax[2], _g_), + _i_ = caml_call1(UIML_UIK_basics[2], _h_), + _j_ = caml_call2(UIML_CML_Syntax[4], _i_, _e_), + _k_ = caml_call1(UIML_Datatypes[2], s), + _l_ = caml_call2(UIML_UIK_basics[5], p, _k_), + _m_ = caml_call1(UIML_UIK_basics[2], _l_); + return caml_call2(UIML_CML_Syntax[4], _m_, _j_); + } + var + _n_ = caml_call1(UIML_Datatypes[1], s), + _o_ = caml_call1(UIML_CML_Syntax[9], _n_), + j10 = + caml_call2 + (iH, [0, caml_call1(UIML_CML_Syntax[8], _o_), 0], symbol), + _p_ = caml_call1(UIML_CML_Syntax[5], j10), + _q_ = caml_call2(UIML_List[4], function(x){return [2, x];}, s4), + _r_ = caml_call1(UIML_UIK_basics[2], _q_), + _s_ = caml_call2(UIML_CML_Syntax[4], _r_, _p_), + _t_ = caml_call1(UIML_Datatypes[1], s), + _u_ = caml_call2(UIML_UIK_basics[5], p, _t_), + _v_ = caml_call2(UIML_List[4], UIML_CML_Syntax[2], _u_), + _w_ = caml_call1(UIML_UIK_basics[2], _v_), + _x_ = caml_call2(UIML_CML_Syntax[4], _w_, _s_), + _y_ = caml_call1(UIML_Datatypes[2], s), + _z_ = caml_call2(UIML_UIK_basics[5], p, _y_), + _A_ = caml_call1(UIML_UIK_basics[2], _z_); + return caml_call2(UIML_CML_Syntax[4], _A_, _x_); + }); + } + var UIML_UIK_braga = [0, imap, coq_GUI_tot]; + runtime.caml_register_global(7, UIML_UIK_braga, "UIML__UIK_braga"); + return; + } + (globalThis)); + +//# 8433 "../extraction/.UIML.objs/jsoo/default/UIML.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + UIML_UIK_braga = global_data.UIML__UIK_braga, + UIML_UIGL_braga = global_data.UIML__UIGL_braga, + UIML_PropQuantifiers = global_data.UIML__PropQuantifiers, + UIML_Simp = global_data.UIML__Simp; + function coq_MPropF_of_form(param){ + if(typeof param === "number") return 0; + switch(param[0]){ + case 0: + var n = param[1]; return [0, n]; + case 1: + var f2 = param[2], f1 = param[1], _d_ = [1, coq_MPropF_of_form(f2), 0]; + return [1, [1, coq_MPropF_of_form(f1), _d_], 0]; + case 2: + var f2$0 = param[2], f1$0 = param[1], _e_ = coq_MPropF_of_form(f2$0); + return [1, [1, coq_MPropF_of_form(f1$0), 0], _e_]; + case 3: + var f2$1 = param[2], f1$1 = param[1], _f_ = coq_MPropF_of_form(f2$1); + return [1, coq_MPropF_of_form(f1$1), _f_]; + default: var f0 = param[1]; return [2, coq_MPropF_of_form(f0)]; + } + } + function form_of_MPropF(param){ + if(typeof param === "number") return 0; + switch(param[0]){ + case 0: + var n = param[1]; return [0, n]; + case 1: + var f2 = param[2], f1 = param[1], _c_ = form_of_MPropF(f2); + return [3, form_of_MPropF(f1), _c_]; + default: var f0 = param[1]; return [4, form_of_MPropF(f0)]; + } + } + function gl_UI(p, s){ + var _b_ = [0, 0, [0, coq_MPropF_of_form(s), 0]]; + return form_of_MPropF(caml_call2(UIML_UIGL_braga[2], p, _b_)); + } + function k_UI(p, s){ + var _a_ = [0, 0, [0, coq_MPropF_of_form(s), 0]]; + return form_of_MPropF(caml_call2(UIML_UIK_braga[2], p, _a_)); + } + var + isl_E = UIML_PropQuantifiers[7], + isl_A = UIML_PropQuantifiers[8], + isl_simp = UIML_Simp[5], + isl_simplified_E = UIML_Simp[6], + isl_simplified_A = UIML_Simp[7], + UIML_UIML_extraction = + [0, + coq_MPropF_of_form, + form_of_MPropF, + gl_UI, + k_UI, + isl_E, + isl_A, + isl_simp, + isl_simplified_E, + isl_simplified_A]; + runtime.caml_register_global + (4, UIML_UIML_extraction, "UIML__UIML_extraction"); + return; + } + (globalThis)); + + +//# 1 "../.js/default/bigstringaf/bigstringaf.cma.js" +// Generated by js_of_ocaml +//# 3 "../.js/default/bigstringaf/bigstringaf.cma.js" + +//# 6 "../.js/default/bigstringaf/bigstringaf.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst = " }", + cst_len = ", len: ", + cst_Bigstringaf = "Bigstringaf.", + cst_blit$2 = "blit", + cst_blit_from_bytes$2 = "blit_from_bytes", + cst_blit_from_string$2 = "blit_from_string", + cst_blit_to_bytes$2 = "blit_to_bytes", + cst_memchr$1 = "memchr", + cst_memcmp$2 = "memcmp", + cst_memcmp_string$2 = "memcmp_string", + caml_ba_dim_1 = runtime.caml_ba_dim_1, + caml_ba_uint8_get16 = runtime.caml_ba_uint8_get16, + caml_ba_uint8_get32 = runtime.caml_ba_uint8_get32, + caml_ba_uint8_get64 = runtime.caml_ba_uint8_get64, + caml_ba_uint8_set16 = runtime.caml_ba_uint8_set16, + caml_ba_uint8_set32 = runtime.caml_ba_uint8_set32, + caml_ba_uint8_set64 = runtime.caml_ba_uint8_set64, + caml_bswap16 = runtime.caml_bswap16, + caml_create_bytes = runtime.caml_create_bytes, + caml_int32_bswap = runtime.caml_int32_bswap, + caml_int64_bswap = runtime.caml_int64_bswap, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace, + caml_ml_bytes_length = runtime.caml_ml_bytes_length, + caml_ml_string_length = runtime.caml_ml_string_length; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + function caml_call5(f, a0, a1, a2, a3, a4){ + return (f.l >= 0 ? f.l : f.l = f.length) == 5 + ? f(a0, a1, a2, a3, a4) + : runtime.caml_call_gen(f, [a0, a1, a2, a3, a4]); + } + function caml_call7(f, a0, a1, a2, a3, a4, a5, a6){ + return (f.l >= 0 ? f.l : f.l = f.length) == 7 + ? f(a0, a1, a2, a3, a4, a5, a6) + : runtime.caml_call_gen(f, [a0, a1, a2, a3, a4, a5, a6]); + } + var + global_data = runtime.caml_get_global_data(), + partial = [11, cst_len, [4, 0, 0, 0, [11, cst, 0]]], + partial$0 = [11, cst_len, [4, 0, 0, 0, [11, cst, 0]]], + Stdlib_Sys = global_data.Stdlib__Sys, + Stdlib_Bytes = global_data.Stdlib__Bytes, + Stdlib_Printf = global_data.Stdlib__Printf, + Stdlib = global_data.Stdlib, + Stdlib_Bigarray = global_data.Stdlib__Bigarray; + function create(size){ + return caml_call3 + (Stdlib_Bigarray[19][1], + Stdlib_Bigarray[13], + Stdlib_Bigarray[15], + size); + } + var + empty = create(0), + length = caml_ba_dim_1, + sub = runtime.caml_ba_sub, + _a_ = + [0, + [11, + cst_Bigstringaf, + [2, + 0, + [11, + " invalid range: { buffer_len: ", + [4, + 0, + 0, + 0, + [11, + ", off: ", + [4, 0, 0, 0, [11, cst_len, [4, 0, 0, 0, [11, cst, 0]]]]]]]]], + "Bigstringaf.%s invalid range: { buffer_len: %d, off: %d, len: %d }"], + _b_ = + [0, + [11, + cst_Bigstringaf, + [2, + 0, + [11, + " invalid range: { src_len: ", + [4, + 0, + 0, + 0, + [11, + ", src_off: ", + [4, + 0, + 0, + 0, + [11, + ", dst_len: ", + [4, 0, 0, 0, [11, ", dst_off: ", [4, 0, 0, 0, partial$0]]]]]]]]]], + "Bigstringaf.%s invalid range: { src_len: %d, src_off: %d, dst_len: %d, dst_off: %d, len: %d }"], + _c_ = + [0, + [11, + cst_Bigstringaf, + [2, + 0, + [11, + " invalid range: { buf1_len: ", + [4, + 0, + 0, + 0, + [11, + ", buf1_off: ", + [4, + 0, + 0, + 0, + [11, + ", buf2_len: ", + [4, 0, 0, 0, [11, ", buf2_off: ", [4, 0, 0, 0, partial]]]]]]]]]], + "Bigstringaf.%s invalid range: { buf1_len: %d, buf1_off: %d, buf2_len: %d, buf2_off: %d, len: %d }"], + cst_copy = "copy", + cst_substring = "substring", + cst_of_string = "of_string", + cst_blit = cst_blit$2, + cst_blit$0 = cst_blit$2, + cst_blit$1 = cst_blit$2, + cst_blit_from_string = cst_blit_from_string$2, + cst_blit_from_string$0 = cst_blit_from_string$2, + cst_blit_from_string$1 = cst_blit_from_string$2, + cst_blit_from_bytes = cst_blit_from_bytes$2, + cst_blit_from_bytes$0 = cst_blit_from_bytes$2, + cst_blit_from_bytes$1 = cst_blit_from_bytes$2, + cst_blit_to_bytes = cst_blit_to_bytes$2, + cst_blit_to_bytes$0 = cst_blit_to_bytes$2, + cst_blit_to_bytes$1 = cst_blit_to_bytes$2, + cst_memcmp = cst_memcmp$2, + cst_memcmp$0 = cst_memcmp$2, + cst_memcmp$1 = cst_memcmp$2, + cst_memcmp_string = cst_memcmp_string$2, + cst_memcmp_string$0 = cst_memcmp_string$2, + cst_memcmp_string$1 = cst_memcmp_string$2, + cst_memchr = cst_memchr$1, + cst_memchr$0 = cst_memchr$1; + function invalid_bounds(op, buffer_len, off, len){ + var message = caml_call5(Stdlib_Printf[4], _a_, op, buffer_len, off, len); + throw caml_maybe_attach_backtrace([0, Stdlib[6], message], 1); + } + function invalid_bounds_blit(op, src_len, src_off, dst_len, dst_off, len){ + var + message = + caml_call7 + (Stdlib_Printf[4], _b_, op, src_len, src_off, dst_len, dst_off, len); + throw caml_maybe_attach_backtrace([0, Stdlib[6], message], 1); + } + function invalid_bounds_memcmp + (op, buf1_len, buf1_off, buf2_len, buf2_off, len){ + var + message = + caml_call7 + (Stdlib_Printf[4], + _c_, + op, + buf1_len, + buf1_off, + buf2_len, + buf2_off, + len); + throw caml_maybe_attach_backtrace([0, Stdlib[6], message], 1); + } + function copy(t, off, len){ + var buffer_len = caml_ba_dim_1(t), _ax_ = len < 0 ? 1 : 0; + if(_ax_) + var _ay_ = _ax_; + else + var + _az_ = off < 0 ? 1 : 0, + _ay_ = _az_ || ((buffer_len - off | 0) < len ? 1 : 0); + if(_ay_) invalid_bounds(cst_copy, buffer_len, off, len); + var dst = create(len); + runtime.bigstringaf_blit_to_bigstring(t, off, dst, 0, len); + return dst; + } + function substring(t, off, len){ + var buffer_len = caml_ba_dim_1(t), _au_ = len < 0 ? 1 : 0; + if(_au_) + var _av_ = _au_; + else + var + _aw_ = off < 0 ? 1 : 0, + _av_ = _aw_ || ((buffer_len - off | 0) < len ? 1 : 0); + if(_av_) invalid_bounds(cst_substring, buffer_len, off, len); + var b = caml_create_bytes(len); + runtime.bigstringaf_blit_to_bytes(t, off, b, 0, len); + return caml_call1(Stdlib_Bytes[48], b); + } + function to_string(t){ + var len = caml_ba_dim_1(t), b = caml_create_bytes(len); + runtime.bigstringaf_blit_to_bytes(t, 0, b, 0, len); + return caml_call1(Stdlib_Bytes[48], b); + } + function of_string(off, len, s){ + var buffer_len = caml_ml_string_length(s), _ar_ = len < 0 ? 1 : 0; + if(_ar_) + var _as_ = _ar_; + else + var + _at_ = off < 0 ? 1 : 0, + _as_ = _at_ || ((buffer_len - off | 0) < len ? 1 : 0); + if(_as_) invalid_bounds(cst_of_string, buffer_len, off, len); + var b = create(len); + runtime.bigstringaf_blit_from_bytes(s, off, b, 0, len); + return b; + } + function blit(src, src_off, dst, dst_off, len){ + var src_len = caml_ba_dim_1(src), dst_len = caml_ba_dim_1(dst); + if(len < 0) + invalid_bounds_blit(cst_blit, src_len, src_off, dst_len, dst_off, len); + var + _an_ = src_off < 0 ? 1 : 0, + _ao_ = _an_ || ((src_len - src_off | 0) < len ? 1 : 0); + if(_ao_) + invalid_bounds_blit(cst_blit$0, src_len, src_off, dst_len, dst_off, len); + var + _ap_ = dst_off < 0 ? 1 : 0, + _aq_ = _ap_ || ((dst_len - dst_off | 0) < len ? 1 : 0); + if(_aq_) + invalid_bounds_blit(cst_blit$1, src_len, src_off, dst_len, dst_off, len); + return runtime.bigstringaf_blit_to_bigstring + (src, src_off, dst, dst_off, len); + } + function blit_from_string(src, src_off, dst, dst_off, len){ + var src_len = caml_ml_string_length(src), dst_len = caml_ba_dim_1(dst); + if(len < 0) + invalid_bounds_blit + (cst_blit_from_string, src_len, src_off, dst_len, dst_off, len); + var + _aj_ = src_off < 0 ? 1 : 0, + _ak_ = _aj_ || ((src_len - src_off | 0) < len ? 1 : 0); + if(_ak_) + invalid_bounds_blit + (cst_blit_from_string$0, src_len, src_off, dst_len, dst_off, len); + var + _al_ = dst_off < 0 ? 1 : 0, + _am_ = _al_ || ((dst_len - dst_off | 0) < len ? 1 : 0); + if(_am_) + invalid_bounds_blit + (cst_blit_from_string$1, src_len, src_off, dst_len, dst_off, len); + return runtime.bigstringaf_blit_from_bytes + (src, src_off, dst, dst_off, len); + } + function blit_from_bytes(src, src_off, dst, dst_off, len){ + var src_len = caml_ml_bytes_length(src), dst_len = caml_ba_dim_1(dst); + if(len < 0) + invalid_bounds_blit + (cst_blit_from_bytes, src_len, src_off, dst_len, dst_off, len); + var + _af_ = src_off < 0 ? 1 : 0, + _ag_ = _af_ || ((src_len - src_off | 0) < len ? 1 : 0); + if(_ag_) + invalid_bounds_blit + (cst_blit_from_bytes$0, src_len, src_off, dst_len, dst_off, len); + var + _ah_ = dst_off < 0 ? 1 : 0, + _ai_ = _ah_ || ((dst_len - dst_off | 0) < len ? 1 : 0); + if(_ai_) + invalid_bounds_blit + (cst_blit_from_bytes$1, src_len, src_off, dst_len, dst_off, len); + return runtime.bigstringaf_blit_from_bytes + (src, src_off, dst, dst_off, len); + } + function blit_to_bytes(src, src_off, dst, dst_off, len){ + var src_len = caml_ba_dim_1(src), dst_len = caml_ml_bytes_length(dst); + if(len < 0) + invalid_bounds_blit + (cst_blit_to_bytes, src_len, src_off, dst_len, dst_off, len); + var + _ab_ = src_off < 0 ? 1 : 0, + _ac_ = _ab_ || ((src_len - src_off | 0) < len ? 1 : 0); + if(_ac_) + invalid_bounds_blit + (cst_blit_to_bytes$0, src_len, src_off, dst_len, dst_off, len); + var + _ad_ = dst_off < 0 ? 1 : 0, + _ae_ = _ad_ || ((dst_len - dst_off | 0) < len ? 1 : 0); + if(_ae_) + invalid_bounds_blit + (cst_blit_to_bytes$1, src_len, src_off, dst_len, dst_off, len); + return runtime.bigstringaf_blit_to_bytes(src, src_off, dst, dst_off, len); + } + function memcmp(buf1, buf1_off, buf2, buf2_off, len){ + var buf1_len = caml_ba_dim_1(buf1), buf2_len = caml_ba_dim_1(buf2); + if(len < 0) + invalid_bounds_memcmp + (cst_memcmp, buf1_len, buf1_off, buf2_len, buf2_off, len); + var + _Z_ = buf1_off < 0 ? 1 : 0, + ___ = _Z_ || ((buf1_len - buf1_off | 0) < len ? 1 : 0); + if(___) + invalid_bounds_memcmp + (cst_memcmp$0, buf1_len, buf1_off, buf2_len, buf2_off, len); + var + _$_ = buf2_off < 0 ? 1 : 0, + _aa_ = _$_ || ((buf2_len - buf2_off | 0) < len ? 1 : 0); + if(_aa_) + invalid_bounds_memcmp + (cst_memcmp$1, buf1_len, buf1_off, buf2_len, buf2_off, len); + return runtime.bigstringaf_memcmp_bigstring + (buf1, buf1_off, buf2, buf2_off, len); + } + function memcmp_string(buf1, buf1_off, buf2, buf2_off, len){ + var + buf1_len = caml_ba_dim_1(buf1), + buf2_len = caml_ml_string_length(buf2); + if(len < 0) + invalid_bounds_memcmp + (cst_memcmp_string, buf1_len, buf1_off, buf2_len, buf2_off, len); + var + _V_ = buf1_off < 0 ? 1 : 0, + _W_ = _V_ || ((buf1_len - buf1_off | 0) < len ? 1 : 0); + if(_W_) + invalid_bounds_memcmp + (cst_memcmp_string$0, buf1_len, buf1_off, buf2_len, buf2_off, len); + var + _X_ = buf2_off < 0 ? 1 : 0, + _Y_ = _X_ || ((buf2_len - buf2_off | 0) < len ? 1 : 0); + if(_Y_) + invalid_bounds_memcmp + (cst_memcmp_string$1, buf1_len, buf1_off, buf2_len, buf2_off, len); + return runtime.bigstringaf_memcmp_string + (buf1, buf1_off, buf2, buf2_off, len); + } + function memchr(buf, buf_off, chr, len){ + var buf_len = caml_ba_dim_1(buf); + if(len < 0) invalid_bounds(cst_memchr, buf_len, buf_off, len); + var + _T_ = buf_off < 0 ? 1 : 0, + _U_ = _T_ || ((buf_len - buf_off | 0) < len ? 1 : 0); + if(_U_) invalid_bounds(cst_memchr$0, buf_len, buf_off, len); + return runtime.bigstringaf_memchr(buf, buf_off, chr, len); + } + function caml_bigstring_set_16(bs, off, i){ + return caml_ba_uint8_set16(bs, off, caml_bswap16(i)); + } + function caml_bigstring_set_32(bs, off, i){ + return caml_ba_uint8_set32(bs, off, caml_int32_bswap(i)); + } + function caml_bigstring_set_64(bs, off, i){ + return caml_ba_uint8_set64(bs, off, caml_int64_bswap(i)); + } + function caml_bigstring_get_16(bs, off){ + return caml_bswap16(caml_ba_uint8_get16(bs, off)); + } + function caml_bigstring_get_32(bs, off){ + return caml_int32_bswap(caml_ba_uint8_get32(bs, off)); + } + function caml_bigstring_get_64(bs, off){ + return caml_int64_bswap(caml_ba_uint8_get64(bs, off)); + } + function get_int16_sign_extended(x, off){ + var _R_ = Stdlib_Sys[10] - 16 | 0, _S_ = Stdlib_Sys[10] - 16 | 0; + return caml_bigstring_get_16(x, off) << _S_ >> _R_; + } + if(Stdlib_Sys[11]) + var + set_int16_be = caml_ba_uint8_set16, + set_int16_le = caml_bigstring_set_16; + else + var + set_int16_be = caml_bigstring_set_16, + set_int16_le = caml_ba_uint8_set16; + if(Stdlib_Sys[11]) + var + set_int32_be = caml_ba_uint8_set32, + set_int32_le = caml_bigstring_set_32; + else + var + set_int32_be = caml_bigstring_set_32, + set_int32_le = caml_ba_uint8_set32; + if(Stdlib_Sys[11]) + var + set_int64_be = caml_ba_uint8_set64, + set_int64_le = caml_bigstring_set_64; + else + var + set_int64_be = caml_bigstring_set_64, + set_int64_le = caml_ba_uint8_set64; + if(Stdlib_Sys[11]) + var + get_int16_be = caml_ba_uint8_get16, + get_int16_le = caml_bigstring_get_16; + else + var + get_int16_be = caml_bigstring_get_16, + get_int16_le = caml_ba_uint8_get16; + function get_int16_sign_extended_noswap(x, off){ + var _P_ = Stdlib_Sys[10] - 16 | 0, _Q_ = Stdlib_Sys[10] - 16 | 0; + return caml_ba_uint8_get16(x, off) << _Q_ >> _P_; + } + if(Stdlib_Sys[11]) + var + get_int16_sign_extended_noswap$0 = get_int16_sign_extended_noswap, + get_int16_sign_extended_le = get_int16_sign_extended; + else + var + get_int16_sign_extended_noswap$0 = get_int16_sign_extended, + get_int16_sign_extended_le = get_int16_sign_extended_noswap; + if(Stdlib_Sys[11]) + var + get_int32_be = caml_ba_uint8_get32, + get_int32_le = caml_bigstring_get_32; + else + var + get_int32_be = caml_bigstring_get_32, + get_int32_le = caml_ba_uint8_get32; + if(Stdlib_Sys[11]) + var + get_int64_be = caml_ba_uint8_get64, + get_int64_le = caml_bigstring_get_64; + else + var + get_int64_be = caml_bigstring_get_64, + get_int64_le = caml_ba_uint8_get64; + function caml_bigstring_unsafe_set_16(bs, off, i){ + return caml_ba_uint8_set16(bs, off, caml_bswap16(i)); + } + function caml_bigstring_unsafe_set_32(bs, off, i){ + return caml_ba_uint8_set32(bs, off, caml_int32_bswap(i)); + } + function caml_bigstring_unsafe_set_64(bs, off, i){ + return caml_ba_uint8_set64(bs, off, caml_int64_bswap(i)); + } + function caml_bigstring_unsafe_get_16(bs, off){ + return caml_bswap16(caml_ba_uint8_get16(bs, off)); + } + function caml_bigstring_unsafe_get_32(bs, off){ + return caml_int32_bswap(caml_ba_uint8_get32(bs, off)); + } + function caml_bigstring_unsafe_get_64(bs, off){ + return caml_int64_bswap(caml_ba_uint8_get64(bs, off)); + } + if(Stdlib_Sys[11]) + var + unsafe_set_int16_be = caml_ba_uint8_set16, + unsafe_set_int16_le = caml_bigstring_unsafe_set_16; + else + var + unsafe_set_int16_be = caml_bigstring_unsafe_set_16, + unsafe_set_int16_le = caml_ba_uint8_set16; + if(Stdlib_Sys[11]) + var + unsafe_set_int32_be = caml_ba_uint8_set32, + unsafe_set_int32_le = caml_bigstring_unsafe_set_32; + else + var + unsafe_set_int32_be = caml_bigstring_unsafe_set_32, + unsafe_set_int32_le = caml_ba_uint8_set32; + if(Stdlib_Sys[11]) + var + unsafe_set_int64_be = caml_ba_uint8_set64, + unsafe_set_int64_le = caml_bigstring_unsafe_set_64; + else + var + unsafe_set_int64_be = caml_bigstring_unsafe_set_64, + unsafe_set_int64_le = caml_ba_uint8_set64; + if(Stdlib_Sys[11]) + var + unsafe_get_int16_be = caml_ba_uint8_get16, + unsafe_get_int16_le = caml_bigstring_unsafe_get_16; + else + var + unsafe_get_int16_be = caml_bigstring_unsafe_get_16, + unsafe_get_int16_le = caml_ba_uint8_get16; + function unsafe_get_int16_sign_extended(x, off){ + var _N_ = Stdlib_Sys[10] - 16 | 0, _O_ = Stdlib_Sys[10] - 16 | 0; + return unsafe_get_int16_le(x, off) << _O_ >> _N_; + } + function unsafe_get_int16_sign_extended$0(x, off){ + var _L_ = Stdlib_Sys[10] - 16 | 0, _M_ = Stdlib_Sys[10] - 16 | 0; + return unsafe_get_int16_be(x, off) << _M_ >> _L_; + } + if(Stdlib_Sys[11]) + var + unsafe_get_int32_be = caml_ba_uint8_get32, + unsafe_get_int32_le = caml_bigstring_unsafe_get_32; + else + var + unsafe_get_int32_be = caml_bigstring_unsafe_get_32, + unsafe_get_int32_le = caml_ba_uint8_get32; + if(Stdlib_Sys[11]) + var + unsafe_get_int64_be = caml_ba_uint8_get64, + unsafe_get_int64_le = caml_bigstring_unsafe_get_64; + else + var + unsafe_get_int64_be = caml_bigstring_unsafe_get_64, + unsafe_get_int64_le = caml_ba_uint8_get64; + var + Bigstringaf = + [0, + create, + empty, + of_string, + copy, + sub, + length, + substring, + to_string, + get_int16_le, + get_int16_sign_extended_le, + set_int16_le, + get_int32_le, + set_int32_le, + get_int64_le, + set_int64_le, + get_int16_be, + get_int16_sign_extended_noswap$0, + set_int16_be, + get_int32_be, + set_int32_be, + get_int64_be, + set_int64_be, + blit, + blit_from_string, + blit_from_bytes, + blit_to_bytes, + memcmp, + memcmp_string, + memchr, + unsafe_get_int16_le, + unsafe_get_int16_be, + unsafe_get_int16_sign_extended, + unsafe_get_int16_sign_extended$0, + unsafe_set_int16_le, + unsafe_set_int16_be, + unsafe_get_int32_le, + unsafe_get_int32_be, + unsafe_set_int32_le, + unsafe_set_int32_be, + unsafe_get_int64_le, + unsafe_get_int64_be, + unsafe_set_int64_le, + unsafe_set_int64_be, + function(_K_, _J_, _I_, _H_, _G_){ + return runtime.bigstringaf_blit_to_bigstring(_K_, _J_, _I_, _H_, _G_); + }, + function(_F_, _E_, _D_, _C_, _B_){ + return runtime.bigstringaf_blit_from_bytes(_F_, _E_, _D_, _C_, _B_); + }, + function(_A_, _z_, _y_, _x_, _w_){ + return runtime.bigstringaf_blit_from_bytes(_A_, _z_, _y_, _x_, _w_); + }, + function(_v_, _u_, _t_, _s_, _r_){ + return runtime.bigstringaf_blit_to_bytes(_v_, _u_, _t_, _s_, _r_); + }, + function(_q_, _p_, _o_, _n_, _m_){ + return runtime.bigstringaf_memcmp_bigstring(_q_, _p_, _o_, _n_, _m_); + }, + function(_l_, _k_, _j_, _i_, _h_){ + return runtime.bigstringaf_memcmp_string(_l_, _k_, _j_, _i_, _h_); + }, + function(_g_, _f_, _e_, _d_){ + return runtime.bigstringaf_memchr(_g_, _f_, _e_, _d_); + }]; + runtime.caml_register_global(31, Bigstringaf, "Bigstringaf"); + return; + } + (globalThis)); + + +//# 1 "../.js/default/angstrom/angstrom.cma.js" +// Generated by js_of_ocaml +//# 3 "../.js/default/angstrom/angstrom.cma.js" + +//# 25 "../.js/default/angstrom/angstrom.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + cst = ": ", + cst$0 = " > ", + Stdlib = global_data.Stdlib, + Stdlib_String = global_data.Stdlib__String, + _a_ = [1, "incomplete input"]; + function state_to_option(x){ + switch(x[0]){ + case 0: + return 0; + case 1: + var v = x[2]; return [0, v]; + default: return 0; + } + } + function fail_to_string(marks, err){ + var + _b_ = caml_call2(Stdlib[28], cst, err), + _c_ = caml_call2(Stdlib_String[6], cst$0, marks); + return caml_call2(Stdlib[28], _c_, _b_); + } + function state_to_result(x){ + switch(x[0]){ + case 0: + return _a_; + case 1: + var v = x[2]; return [0, v]; + default: + var err = x[3], marks = x[2]; return [1, fail_to_string(marks, err)]; + } + } + var + Angstrom_Exported_state = + [0, state_to_option, fail_to_string, state_to_result]; + runtime.caml_register_global + (5, Angstrom_Exported_state, "Angstrom__Exported_state"); + return; + } + (globalThis)); + +//# 77 "../.js/default/angstrom/angstrom.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_lib_input_ml = "lib/input.ml", + caml_ba_get_1 = runtime.caml_ba_get_1, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + Bigstringaf = global_data.Bigstringaf, + Assert_failure = global_data.Assert_failure, + _a_ = [0, cst_lib_input_ml, 60, 2], + _b_ = [0, cst_lib_input_ml, 59, 2]; + function create(buffer, off, len, committed_bytes){ + return [0, committed_bytes, committed_bytes, off, len, buffer]; + } + function length(t){return t[2] + t[4] | 0;} + function client_committed_bytes(t){return t[2];} + function parser_committed_bytes(t){return t[1];} + function bytes_for_client_to_commit(t){return t[1] - t[2] | 0;} + function parser_uncommitted_bytes(t){ + var _f_ = bytes_for_client_to_commit(t); + return t[4] - _f_ | 0; + } + function invariant(t){ + var _c_ = length(t), _d_ = parser_uncommitted_bytes(t); + if((t[1] + _d_ | 0) !== _c_) + throw caml_maybe_attach_backtrace([0, Assert_failure, _b_], 1); + var _e_ = bytes_for_client_to_commit(t); + if((t[1] - t[2] | 0) === _e_) return 0; + throw caml_maybe_attach_backtrace([0, Assert_failure, _a_], 1); + } + function offset_in_buffer(t, pos){return (t[3] + pos | 0) - t[2] | 0;} + function apply(t, pos, len, f){ + var off = offset_in_buffer(t, pos); + return caml_call3(f, t[5], off, len); + } + function unsafe_get_char(t, pos){ + var off = offset_in_buffer(t, pos); + return caml_ba_get_1(t[5], off); + } + function unsafe_get_int16_le(t, pos){ + var off = offset_in_buffer(t, pos); + return caml_call2(Bigstringaf[30], t[5], off); + } + function unsafe_get_int32_le(t, pos){ + var off = offset_in_buffer(t, pos); + return caml_call2(Bigstringaf[36], t[5], off); + } + function unsafe_get_int64_le(t, pos){ + var off = offset_in_buffer(t, pos); + return caml_call2(Bigstringaf[40], t[5], off); + } + function unsafe_get_int16_be(t, pos){ + var off = offset_in_buffer(t, pos); + return caml_call2(Bigstringaf[31], t[5], off); + } + function unsafe_get_int32_be(t, pos){ + var off = offset_in_buffer(t, pos); + return caml_call2(Bigstringaf[37], t[5], off); + } + function unsafe_get_int64_be(t, pos){ + var off = offset_in_buffer(t, pos); + return caml_call2(Bigstringaf[41], t[5], off); + } + function count_while(t, pos, f){ + var + buffer = t[5], + off = offset_in_buffer(t, pos), + i = [0, off], + limit = t[3] + t[4] | 0; + for(;;){ + if(i[1] < limit && caml_call1(f, caml_ba_get_1(buffer, i[1]))){i[1]++; continue;} + return i[1] - off | 0; + } + } + function commit(t, pos){t[1] = pos; return 0;} + var + Angstrom_Input = + [0, + create, + length, + client_committed_bytes, + parser_committed_bytes, + parser_uncommitted_bytes, + bytes_for_client_to_commit, + unsafe_get_char, + unsafe_get_int16_le, + unsafe_get_int32_le, + unsafe_get_int64_le, + unsafe_get_int16_be, + unsafe_get_int32_be, + unsafe_get_int64_be, + count_while, + apply, + commit, + invariant]; + runtime.caml_register_global(4, Angstrom_Input, "Angstrom__Input"); + return; + } + (globalThis)); + +//# 197 "../.js/default/angstrom/angstrom.cma.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + function caml_call4(f, a0, a1, a2, a3){ + return (f.l >= 0 ? f.l : f.l = f.length) == 4 + ? f(a0, a1, a2, a3) + : runtime.caml_call_gen(f, [a0, a1, a2, a3]); + } + function caml_call5(f, a0, a1, a2, a3, a4){ + return (f.l >= 0 ? f.l : f.l = f.length) == 5 + ? f(a0, a1, a2, a3, a4) + : runtime.caml_call_gen(f, [a0, a1, a2, a3, a4]); + } + var + global_data = runtime.caml_get_global_data(), + CamlinternalLazy = global_data.CamlinternalLazy, + Angstrom_Input = global_data.Angstrom__Input, + Bigstringaf = global_data.Bigstringaf, + Angstrom_Exported_state = global_data.Angstrom__Exported_state, + State = [0]; + function fail_k(input, pos, param, marks, msg){ + return [3, pos - caml_call1(Angstrom_Input[3], input) | 0, marks, msg]; + } + function succeed_k(input, pos, param, v){ + return [2, pos - caml_call1(Angstrom_Input[3], input) | 0, v]; + } + function to_exported_state(param){ + var param$0 = param; + for(;;) + switch(param$0[0]){ + case 0: + var match = param$0[1], continue$0 = match[2], committed = match[1]; + return [0, + [0, + committed, + function(bs, off, len, more){ + return to_exported_state + (caml_call4(continue$0, bs, off, len, more)); + }]]; + case 1: + var + x = param$0[1], + _c_ = runtime.caml_obj_tag(x), + param$1 = + 250 === _c_ + ? x[1] + : 246 === _c_ ? caml_call1(CamlinternalLazy[2], x) : x; + param$0 = param$1; + break; + case 2: + var x$0 = param$0[2], i = param$0[1]; return [1, i, x$0]; + default: + var s = param$0[3], sl = param$0[2], i$0 = param$0[1]; + return [2, i$0, sl, s]; + } + } + function parse(p){ + var input = caml_call4(Angstrom_Input[1], Bigstringaf[2], 0, 0, 0); + return to_exported_state(caml_call5(p[1], input, 0, 1, fail_k, succeed_k)); + } + function parse_bigstring(p, input){ + var + _a_ = caml_call1(Bigstringaf[6], input), + input$0 = caml_call4(Angstrom_Input[1], input, 0, _a_, 0), + _b_ = + to_exported_state(caml_call5(p[1], input$0, 0, 0, fail_k, succeed_k)); + return caml_call1(Angstrom_Exported_state[3], _b_); + } + function return$0(v){ + return [0, + function(input, pos, more, fail, succ){ + return caml_call4(succ, input, pos, more, v); + }]; + } + function fail(msg){ + return [0, + function(input, pos, more, fail, succ){ + return caml_call5(fail, input, pos, more, 0, msg); + }]; + } + function symbol_bind(p, f){ + return [0, + function(input, pos, more, fail, succ){ + function succ$0(input, pos, more, v){ + return caml_call5 + (caml_call1(f, v)[1], input, pos, more, fail, succ); + } + return caml_call5(p[1], input, pos, more, fail, succ$0); + }]; + } + function symbol_map(p, f){ + return [0, + function(input, pos, more, fail, succ){ + function succ$0(input, pos, more, v){ + return caml_call4(succ, input, pos, more, caml_call1(f, v)); + } + return caml_call5(p[1], input, pos, more, fail, succ$0); + }]; + } + function symbol(f, m){return symbol_map(m, f);} + function symbol$0(f, m){ + return [0, + function(input, pos, more, fail, succ){ + function succ0(input0, pos0, more0, f){ + function succ1(input1, pos1, more1, m){ + return caml_call4(succ, input1, pos1, more1, caml_call1(f, m)); + } + return caml_call5(m[1], input0, pos0, more0, fail, succ1); + } + return caml_call5(f[1], input, pos, more, fail, succ0); + }]; + } + function lift(f, m){return symbol_map(m, f);} + function lift2(f, m1, m2){ + return [0, + function(input, pos, more, fail, succ){ + function succ1(input1, pos1, more1, m1){ + function succ2(input2, pos2, more2, m2){ + return caml_call4 + (succ, input2, pos2, more2, caml_call2(f, m1, m2)); + } + return caml_call5(m2[1], input1, pos1, more1, fail, succ2); + } + return caml_call5(m1[1], input, pos, more, fail, succ1); + }]; + } + function lift3(f, m1, m2, m3){ + return [0, + function(input, pos, more, fail, succ){ + function succ1(input1, pos1, more1, m1){ + function succ2(input2, pos2, more2, m2){ + function succ3(input3, pos3, more3, m3){ + return caml_call4 + (succ, input3, pos3, more3, caml_call3(f, m1, m2, m3)); + } + return caml_call5(m3[1], input2, pos2, more2, fail, succ3); + } + return caml_call5(m2[1], input1, pos1, more1, fail, succ2); + } + return caml_call5(m1[1], input, pos, more, fail, succ1); + }]; + } + function lift4(f, m1, m2, m3, m4){ + return [0, + function(input, pos, more, fail, succ){ + function succ1(input1, pos1, more1, m1){ + function succ2(input2, pos2, more2, m2){ + function succ3(input3, pos3, more3, m3){ + function succ4(input4, pos4, more4, m4){ + return caml_call4 + (succ, input4, pos4, more4, caml_call4(f, m1, m2, m3, m4)); + } + return caml_call5(m4[1], input3, pos3, more3, fail, succ4); + } + return caml_call5(m3[1], input2, pos2, more2, fail, succ3); + } + return caml_call5(m2[1], input1, pos1, more1, fail, succ2); + } + return caml_call5(m1[1], input, pos, more, fail, succ1); + }]; + } + function symbol$1(a, b){ + return [0, + function(input, pos, more, fail, succ){ + function succ$0(input, pos, more, param){ + return caml_call5(b[1], input, pos, more, fail, succ); + } + return caml_call5(a[1], input, pos, more, fail, succ$0); + }]; + } + function symbol$2(a, b){ + return [0, + function(input, pos, more, fail, succ){ + function succ0(input0, pos0, more0, x){ + function succ1(input1, pos1, more1, param){ + return caml_call4(succ, input1, pos1, more1, x); + } + return caml_call5(b[1], input0, pos0, more0, fail, succ1); + } + return caml_call5(a[1], input, pos, more, fail, succ0); + }]; + } + var + Monad = + [0, + return$0, + fail, + symbol_bind, + symbol_map, + symbol, + symbol$0, + lift, + lift2, + lift3, + lift4, + symbol$1, + symbol$2]; + function symbol$3(p, mark){ + return [0, + function(input, pos, more, fail, succ){ + function fail$0(input, pos, more, marks, msg){ + return caml_call5(fail, input, pos, more, [0, mark, marks], msg); + } + return caml_call5(p[1], input, pos, more, fail$0, succ); + }]; + } + function symbol$4(p, q){ + return [0, + function(input, pos, more, fail, succ){ + function fail$0(input, pos$0, more$0, marks, msg){ + return pos < caml_call1(Angstrom_Input[4], input) + ? caml_call5(fail, input, pos$0, more, marks, msg) + : caml_call5(q[1], input, pos, more$0, fail, succ); + } + return caml_call5(p[1], input, pos, more, fail$0, succ); + }]; + } + var + Choice = [0, symbol$3, symbol$4], + return$1 = Monad[1], + fail$0 = Monad[2], + symbol_bind$0 = Monad[3]; + function symbol_map$0(m, f){ + return caml_call2 + (symbol_bind$0, + m, + function(x){return caml_call1(return$1, caml_call1(f, x));}); + } + function symbol$5(f, m){return symbol_map$0(m, f);} + function symbol$6(f, m){ + return caml_call2 + (symbol_bind$0, f, function(f){return symbol_map$0(m, f);}); + } + function lift2$0(f, m1, m2){return symbol$6(symbol_map$0(m1, f), m2);} + function lift3$0(f, m1, m2, m3){ + return symbol$6(symbol$6(symbol_map$0(m1, f), m2), m3); + } + function lift4$0(f, m1, m2, m3, m4){ + return symbol$6(symbol$6(symbol$6(symbol_map$0(m1, f), m2), m3), m4); + } + function symbol$7(a, b){ + return caml_call2(symbol_bind$0, a, function(param){return b;}); + } + function symbol$8(a, b){ + return caml_call2 + (symbol_bind$0, + a, + function(x){return symbol_map$0(b, function(param){return x;});}); + } + var + Monad_use_for_debugging = + [0, + return$1, + fail$0, + symbol_bind$0, + symbol_map$0, + symbol$5, + symbol$6, + symbol_map$0, + lift2$0, + lift3$0, + lift4$0, + symbol$7, + symbol$8], + Angstrom_Parser = + [0, + State, + fail_k, + succeed_k, + to_exported_state, + parse, + parse_bigstring, + Monad, + Choice, + Monad_use_for_debugging]; + runtime.caml_register_global(4, Angstrom_Parser, "Angstrom__Parser"); + return; + } + (globalThis)); + +//# 495 "../.js/default/angstrom/angstrom.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_lib_buffering_ml = "lib/buffering.ml", + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace, + caml_ml_string_length = runtime.caml_ml_string_length; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + function caml_call5(f, a0, a1, a2, a3, a4){ + return (f.l >= 0 ? f.l : f.l = f.length) == 5 + ? f(a0, a1, a2, a3, a4) + : runtime.caml_call_gen(f, [a0, a1, a2, a3, a4]); + } + var + undef = undefined, + global_data = runtime.caml_get_global_data(), + Assert_failure = global_data.Assert_failure, + Bigstringaf = global_data.Bigstringaf, + _a_ = [0, cst_lib_buffering_ml, 8, 2], + _b_ = [0, cst_lib_buffering_ml, 7, 2], + _c_ = [0, cst_lib_buffering_ml, 47, 2], + _d_ = [0, cst_lib_buffering_ml, 46, 2], + _e_ = [0, cst_lib_buffering_ml, 54, 2], + _f_ = [0, cst_lib_buffering_ml, 53, 2], + _g_ = [0, cst_lib_buffering_ml, 64, 2], + _h_ = [0, cst_lib_buffering_ml, 79, 2]; + function of_bigstring(off, len, buf){ + if(0 > off) + throw caml_maybe_attach_backtrace([0, Assert_failure, _b_], 1); + if((len - off | 0) <= caml_call1(Bigstringaf[6], buf)) + return [0, buf, off, len]; + throw caml_maybe_attach_backtrace([0, Assert_failure, _a_], 1); + } + function create(len){ + return of_bigstring(0, 0, caml_call1(Bigstringaf[1], len)); + } + function writable_space(t){ + var _m_ = t[3]; + return caml_call1(Bigstringaf[6], t[1]) - _m_ | 0; + } + function ensure(t, to_copy){ + var + _k_ = t[2] + t[3] | 0, + _l_ = (caml_call1(Bigstringaf[6], t[1]) - _k_ | 0) < to_copy ? 1 : 0; + if(! _l_) return _l_; + if(to_copy <= writable_space(t)){ + caml_call5(Bigstringaf[44], t[1], t[2], t[1], 0, t[3]); + t[2] = 0; + return; + } + var + old_len = caml_call1(Bigstringaf[6], t[1]), + new_len = [0, old_len], + space = writable_space(t); + for(;;){ + if(((space + new_len[1] | 0) - old_len | 0) >= to_copy){ + var new_buf = caml_call1(Bigstringaf[1], new_len[1]); + caml_call5(Bigstringaf[44], t[1], t[2], new_buf, 0, t[3]); + t[1] = new_buf; + t[2] = 0; + return; + } + new_len[1] = (3 * new_len[1] | 0) / 2 | 0; + } + } + function write_pos(t){return t[2] + t[3] | 0;} + function feed_string(t, off, len, str){ + if(0 > off) + throw caml_maybe_attach_backtrace([0, Assert_failure, _d_], 1); + if((len - off | 0) > caml_ml_string_length(str)) + throw caml_maybe_attach_backtrace([0, Assert_failure, _c_], 1); + ensure(t, len); + var _j_ = write_pos(t); + caml_call5(Bigstringaf[45], str, off, t[1], _j_, len); + t[3] = t[3] + len | 0; + return 0; + } + function feed_bigstring(t, off, len, b){ + if(0 > off) + throw caml_maybe_attach_backtrace([0, Assert_failure, _f_], 1); + if((len - off | 0) > caml_call1(Bigstringaf[6], b)) + throw caml_maybe_attach_backtrace([0, Assert_failure, _e_], 1); + ensure(t, len); + var _i_ = write_pos(t); + caml_call5(Bigstringaf[44], b, off, t[1], _i_, len); + t[3] = t[3] + len | 0; + return 0; + } + function feed_input(t, param){ + if(608227697 <= param[1]){ + var b = param[2]; + return feed_bigstring(t, 0, caml_call1(Bigstringaf[6], b), b); + } + var s = param[2]; + return feed_string(t, 0, caml_ml_string_length(s), s); + } + function shift(t, n){ + if(n > t[3]) + throw caml_maybe_attach_backtrace([0, Assert_failure, _g_], 1); + t[2] = t[2] + n | 0; + t[3] = t[3] - n | 0; + return 0; + } + function for_reading(param){ + var buf = param[1], off = param[2], len = param[3]; + return caml_call3(Bigstringaf[5], buf, off, len); + } + function unconsumed(opt, param){ + if(opt) var sth = opt[1], shift = sth; else var shift = 0; + var buf = param[1], off = param[2], len = param[3]; + if(shift <= len) return [0, buf, off + shift | 0, len - shift | 0]; + throw caml_maybe_attach_backtrace([0, Assert_failure, _h_], 1); + } + function of_unconsumed(param){ + var len = param[3], off = param[2], buf = param[1]; + return [0, buf, off, len]; + } + var + Angstrom_Buffering = + [0, + create, + of_bigstring, + feed_string, + feed_bigstring, + feed_input, + shift, + for_reading, + unconsumed, + of_unconsumed]; + runtime.caml_register_global(10, Angstrom_Buffering, "Angstrom__Buffering"); + return; + } + (globalThis)); + +//# 641 "../.js/default/angstrom/angstrom.cma.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_count_while1$1 = "count_while1", + cst_not_enough_input$1 = "not enough input", + cst_satisfy = "satisfy: ", + cst_satisfy_C = "satisfy: %C", + caml_int32_float_of_bits = runtime.caml_int32_float_of_bits, + caml_int64_float_of_bits = runtime.caml_int64_float_of_bits, + caml_ml_string_length = runtime.caml_ml_string_length, + caml_obj_tag = runtime.caml_obj_tag, + caml_update_dummy = runtime.caml_update_dummy; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + function caml_call4(f, a0, a1, a2, a3){ + return (f.l >= 0 ? f.l : f.l = f.length) == 4 + ? f(a0, a1, a2, a3) + : runtime.caml_call_gen(f, [a0, a1, a2, a3]); + } + function caml_call5(f, a0, a1, a2, a3, a4){ + return (f.l >= 0 ? f.l : f.l = f.length) == 5 + ? f(a0, a1, a2, a3, a4) + : runtime.caml_call_gen(f, [a0, a1, a2, a3, a4]); + } + var + global_data = runtime.caml_get_global_data(), + cst = "\r\n", + Stdlib = global_data.Stdlib, + Angstrom_Input = global_data.Angstrom__Input, + Bigstringaf = global_data.Bigstringaf, + Stdlib_Int64 = global_data.Stdlib__Int64, + Stdlib_Int32 = global_data.Stdlib__Int32, + CamlinternalLazy = global_data.CamlinternalLazy, + Stdlib_List = global_data.Stdlib__List, + Stdlib_Char = global_data.Stdlib__Char, + Stdlib_Printf = global_data.Stdlib__Printf, + Angstrom_Buffering = global_data.Angstrom__Buffering, + Angstrom_Parser = global_data.Angstrom__Parser, + Angstrom_Exported_state = global_data.Angstrom__Exported_state, + Stdlib_Sys = global_data.Stdlib__Sys, + parse = Angstrom_Parser[5], + parse_bigstring = Angstrom_Parser[6], + state_to_option = Angstrom_Exported_state[1], + fail_to_string = Angstrom_Exported_state[2], + state_to_result = Angstrom_Exported_state[3], + _a_ = Angstrom_Parser[7], + return$0 = _a_[1], + fail = _a_[2], + symbol_bind = _a_[3], + symbol_map = _a_[4], + symbol = _a_[5], + symbol$0 = _a_[6], + lift = _a_[7], + lift2 = _a_[8], + lift3 = _a_[9], + lift4 = _a_[10], + symbol$1 = _a_[11], + symbol$2 = _a_[12], + include = Angstrom_Parser[8], + symbol$3 = include[1], + symbol$4 = include[2], + cst_parse_invalid_argument_ini = + "parse: invalid argument, initial_buffer_size < 1", + _b_ = [1, "incomplete input"], + cst_prompt_input_shrunk = "prompt: input shrunk!", + cst_not_enough_input = cst_not_enough_input$1, + cst_not_enough_input$0 = cst_not_enough_input$1; + function from_unbuffered_state(f, buffering, param){ + switch(param[0]){ + case 0: + var p = param[1]; return [0, caml_call1(f, p)]; + case 1: + var + v = param[2], + consumed = param[1], + unconsumed = + caml_call2(Angstrom_Buffering[8], [0, consumed], buffering); + return [1, unconsumed, v]; + default: + var + msg = param[3], + marks = param[2], + consumed$0 = param[1], + unconsumed$0 = + caml_call2(Angstrom_Buffering[8], [0, consumed$0], buffering); + return [2, unconsumed$0, marks, msg]; + } + } + function parse$0(opt, p){ + if(opt) + var sth = opt[1], initial_buffer_size = sth; + else + var initial_buffer_size = 4096; + if(initial_buffer_size < 1) + caml_call1(Stdlib[2], cst_parse_invalid_argument_ini); + var buffering = caml_call1(Angstrom_Buffering[1], initial_buffer_size); + function f(p, input){ + caml_call2(Angstrom_Buffering[6], buffering, p[1]); + var + more = + typeof input === "number" + ? 0 + : (caml_call2(Angstrom_Buffering[5], buffering, input), 1), + for_reading = caml_call1(Angstrom_Buffering[7], buffering), + _P_ = caml_call1(Bigstringaf[6], for_reading); + return from_unbuffered_state + (f, buffering, caml_call4(p[2], for_reading, 0, _P_, more)); + } + return from_unbuffered_state(f, buffering, caml_call1(parse, p)); + } + function feed(state, input){ + switch(state[0]){ + case 0: + var k = state[1]; return caml_call1(k, input); + case 1: + var v = state[2], unconsumed = state[1]; + if(typeof input === "number") return state; + var buffering = caml_call1(Angstrom_Buffering[9], unconsumed); + caml_call2(Angstrom_Buffering[5], buffering, input); + return [1, caml_call2(Angstrom_Buffering[8], 0, buffering), v]; + default: + var msg = state[3], marks = state[2], unconsumed$0 = state[1]; + if(typeof input === "number") return state; + var buffering$0 = caml_call1(Angstrom_Buffering[9], unconsumed$0); + caml_call2(Angstrom_Buffering[5], buffering$0, input); + return [2, + caml_call2(Angstrom_Buffering[8], 0, buffering$0), + marks, + msg]; + } + } + function state_to_option$0(param){ + switch(param[0]){ + case 0: + return 0; + case 1: + var v = param[2]; return [0, v]; + default: return 0; + } + } + function state_to_result$0(param){ + switch(param[0]){ + case 0: + return _b_; + case 1: + var v = param[2]; return [0, v]; + default: + var msg = param[3], marks = param[2]; + return [1, caml_call2(fail_to_string, marks, msg)]; + } + } + function state_to_unconsumed(param){ + if(0 === param[0]) return 0; + var unconsumed = param[1]; + return [0, unconsumed]; + } + function prompt(input, pos, fail, succ){ + var + parser_uncommitted_bytes = caml_call1(Angstrom_Input[5], input), + parser_committed_bytes = caml_call1(Angstrom_Input[4], input); + function continue$0(input, off, len, more){ + if(len < parser_uncommitted_bytes) + caml_call1(Stdlib[2], cst_prompt_input_shrunk); + var + input$0 = + caml_call4(Angstrom_Input[1], input, off, len, parser_committed_bytes); + return len === parser_uncommitted_bytes + ? more + ? prompt(input$0, pos, fail, succ) + : caml_call3(fail, input$0, pos, 0) + : caml_call3(succ, input$0, pos, more); + } + return [0, [0, caml_call1(Angstrom_Input[6], input), continue$0]]; + } + var + demand_input = + [0, + function(input, pos, more, fail, succ){ + if(! more) + return caml_call5(fail, input, pos, more, 0, cst_not_enough_input$0); + function succ$0(input, pos, more){ + return caml_call4(succ, input, pos, more, 0); + } + function fail$0(input, pos, more){ + return caml_call5(fail, input, pos, more, 0, cst_not_enough_input); + } + return prompt(input, pos, fail$0, succ$0); + }]; + function ensure_suspended(n, input, pos, more, fail, succ){ + var go = []; + caml_update_dummy + (go, + [0, + function(input, pos, more, fail, succ){ + return (pos + n | 0) <= caml_call1(Angstrom_Input[2], input) + ? caml_call4(succ, input, pos, more, 0) + : caml_call5 + (caml_call2(symbol$1, demand_input, go)[1], + input, + pos, + more, + fail, + succ); + }]); + return caml_call5 + (caml_call2(symbol$1, demand_input, go)[1], + input, + pos, + more, + fail, + succ); + } + function unsafe_apply(len, f){ + return [0, + function(input, pos, more, fail, succ){ + return caml_call4 + (succ, + input, + pos + len | 0, + more, + caml_call4(Angstrom_Input[15], input, pos, len, f)); + }]; + } + function ensure(n, p){ + return [0, + function(input, pos, more, fail, succ){ + if((pos + n | 0) <= caml_call1(Angstrom_Input[2], input)) + return caml_call5(p[1], input, pos, more, fail, succ); + function succ$0(input, pos, more, param){ + return caml_call5(p[1], input, pos, more, fail, succ); + } + return ensure_suspended(n, input, pos, more, fail, succ$0); + }]; + } + var + at_end_of_input = + [0, + function(input, pos, more, param, succ){ + if(pos < caml_call1(Angstrom_Input[2], input)) + return caml_call4(succ, input, pos, more, 0); + if(! more) return caml_call4(succ, input, pos, more, 1); + function succ$0(input, pos, more){ + return caml_call4(succ, input, pos, more, 0); + } + function fail(input, pos, more){ + return caml_call4(succ, input, pos, more, 1); + } + return prompt(input, pos, fail, succ$0); + }], + cst_end_of_input = "end_of_input", + end_of_input = + caml_call2 + (symbol_bind, + at_end_of_input, + function(param){ + return param + ? caml_call1(return$0, 0) + : caml_call1(fail, cst_end_of_input); + }), + cst_advance = "advance"; + function advance(n){ + if(0 > n) return caml_call1(fail, cst_advance); + var + p = + [0, + function(input, pos, more, fail, succ){ + return caml_call4(succ, input, pos + n | 0, more, 0); + }]; + return ensure(n, p); + } + var + pos = + [0, + function(input, pos, more, fail, succ){ + return caml_call4(succ, input, pos, more, pos); + }], + available = + [0, + function(input, pos, more, fail, succ){ + return caml_call4 + (succ, + input, + pos, + more, + caml_call1(Angstrom_Input[2], input) - pos | 0); + }], + commit = + [0, + function(input, pos, more, fail, succ){ + caml_call2(Angstrom_Input[16], input, pos); + return caml_call4(succ, input, pos, more, 0); + }]; + function unsafe_lookahead(p){ + return [0, + function(input, pos, more, fail, succ){ + function succ$0(input, param, more, v){ + return caml_call4(succ, input, pos, more, v); + } + return caml_call5(p[1], input, pos, more, fail, succ$0); + }]; + } + var + peek_char = + [0, + function(input, pos, more, fail, succ){ + if(pos < caml_call1(Angstrom_Input[2], input)) + return caml_call4 + (succ, + input, + pos, + more, + [0, caml_call2(Angstrom_Input[7], input, pos)]); + if(0 === more) return caml_call4(succ, input, pos, more, 0); + function succ$0(input, pos, more){ + return caml_call4 + (succ, + input, + pos, + more, + [0, caml_call2(Angstrom_Input[7], input, pos)]); + } + function fail$0(input, pos, more){ + return caml_call4(succ, input, pos, more, 0); + } + return prompt(input, pos, fail$0, succ$0); + }], + peek_char_fail = []; + caml_update_dummy + (peek_char_fail, + [0, + function(input, pos, more, fail, succ){ + if(pos < caml_call1(Angstrom_Input[2], input)) + return caml_call4 + (succ, + input, + pos, + more, + caml_call2(Angstrom_Input[7], input, pos)); + function succ$0(input, pos, more, param){ + return caml_call5(peek_char_fail[1], input, pos, more, fail, succ); + } + return ensure_suspended(1, input, pos, more, fail, succ$0); + }]); + var + _c_ = [0, [11, cst_satisfy, [1, 0]], cst_satisfy_C], + _d_ = [0, [11, cst_satisfy, [1, 0]], cst_satisfy_C], + _e_ = [0, [11, "char ", [1, 0]], "char %C"], + _f_ = [0, [11, "not char ", [1, 0]], "not char %C"]; + function satisfy(f){ + return [0, + function(input, pos, more, fail, succ){ + if(pos >= caml_call1(Angstrom_Input[2], input)){ + var + succ$0 = + function(input, pos, more, param){ + var c = caml_call2(Angstrom_Input[7], input, pos); + if(caml_call1(f, c)) + return caml_call4(succ, input, pos + 1 | 0, more, c); + var _O_ = caml_call4(fail, input, pos, more, 0); + return caml_call3(Stdlib_Printf[10], _O_, _d_, c); + }; + return ensure_suspended(1, input, pos, more, fail, succ$0); + } + var c = caml_call2(Angstrom_Input[7], input, pos); + if(caml_call1(f, c)) + return caml_call4(succ, input, pos + 1 | 0, more, c); + var _N_ = caml_call4(fail, input, pos, more, 0); + return caml_call3(Stdlib_Printf[10], _N_, _c_, c); + }]; + } + function char$0(c){ + var + p = + [0, + function(input, pos, more, fail, succ){ + return caml_call2(Angstrom_Input[7], input, pos) === c + ? caml_call4(succ, input, pos + 1 | 0, more, c) + : caml_call5 + (fail, + input, + pos, + more, + 0, + caml_call2(Stdlib_Printf[4], _e_, c)); + }]; + return ensure(1, p); + } + function not_char(c){ + var + p = + [0, + function(input, pos, more, fail, succ){ + var c$0 = caml_call2(Angstrom_Input[7], input, pos); + return c !== c$0 + ? caml_call4(succ, input, pos + 1 | 0, more, c$0) + : caml_call5 + (fail, + input, + pos, + more, + 0, + caml_call2(Stdlib_Printf[4], _f_, c)); + }]; + return ensure(1, p); + } + var + p = + [0, + function(input, pos, more, fail, succ){ + return caml_call4 + (succ, + input, + pos + 1 | 0, + more, + caml_call2(Angstrom_Input[7], input, pos)); + }], + any_char = ensure(1, p), + _g_ = [0, [11, "int8 ", [4, 0, 0, 0, 0]], "int8 %d"]; + function int8(i){ + var + p = + [0, + function(input, pos, more, fail, succ){ + var c = caml_call2(Angstrom_Input[7], input, pos); + return c === (i & 255) + ? caml_call4(succ, input, pos + 1 | 0, more, c) + : caml_call5 + (fail, + input, + pos, + more, + 0, + caml_call2(Stdlib_Printf[4], _g_, i)); + }]; + return ensure(1, p); + } + var + p$0 = + [0, + function(input, pos, more, fail, succ){ + var c = caml_call2(Angstrom_Input[7], input, pos); + return caml_call4(succ, input, pos + 1 | 0, more, c); + }], + any_uint8 = ensure(1, p$0), + s = Stdlib_Sys[10] - 8 | 0, + p$1 = + [0, + function(input, pos, more, fail, succ){ + var c = caml_call2(Angstrom_Input[7], input, pos); + return caml_call4(succ, input, pos + 1 | 0, more, c << s >> s); + }], + any_int8 = ensure(1, p$1), + cst_skip = "skip", + cst_count_while1 = cst_count_while1$1, + cst_count_while1$0 = cst_count_while1$1, + _h_ = [1, "string"], + cst_take_n_0 = "take: n < 0", + cst_take_bigstring_n_0 = "take_bigstring: n < 0", + cst_no_more_choices = "no more choices"; + function skip(f){ + var + p = + [0, + function(input, pos, more, fail, succ){ + return caml_call1(f, caml_call2(Angstrom_Input[7], input, pos)) + ? caml_call4(succ, input, pos + 1 | 0, more, 0) + : caml_call5(fail, input, pos, more, 0, cst_skip); + }]; + return ensure(1, p); + } + function count_while(init, f, with_buffer){ + return [0, + function(input, pos, more, fail, succ){ + var + len = caml_call3(Angstrom_Input[14], input, pos + init | 0, f), + input_len = caml_call1(Angstrom_Input[2], input), + init$0 = init + len | 0; + if((pos + init$0 | 0) >= input_len && 0 !== more){ + var + succ$0 = + function(input, pos, more){ + return caml_call5 + (count_while(init$0, f, with_buffer)[1], + input, + pos, + more, + fail, + succ); + }, + fail$0 = + function(input, pos, more){ + return caml_call4 + (succ, + input, + pos + init$0 | 0, + more, + caml_call4 + (Angstrom_Input[15], input, pos, init$0, with_buffer)); + }; + return prompt(input, pos, fail$0, succ$0); + } + return caml_call4 + (succ, + input, + pos + init$0 | 0, + more, + caml_call4 + (Angstrom_Input[15], input, pos, init$0, with_buffer)); + }]; + } + function count_while1(f, with_buffer){ + return [0, + function(input, pos, more, fail, succ){ + var + len = caml_call3(Angstrom_Input[14], input, pos, f), + input_len = caml_call1(Angstrom_Input[2], input); + if(1 <= len){ + if((pos + len | 0) >= input_len && 0 !== more){ + var + succ$0 = + function(input, pos, more){ + return caml_call5 + (count_while(len, f, with_buffer)[1], + input, + pos, + more, + fail, + succ); + }, + fail$0 = + function(input, pos, more){ + return caml_call4 + (succ, + input, + pos + len | 0, + more, + caml_call4(Angstrom_Input[15], input, pos, len, with_buffer)); + }; + return prompt(input, pos, fail$0, succ$0); + } + return caml_call4 + (succ, + input, + pos + len | 0, + more, + caml_call4(Angstrom_Input[15], input, pos, len, with_buffer)); + } + if(pos >= input_len && 0 !== more){ + var + succ$1 = + function(input, pos, more){ + return caml_call5 + (count_while1(f, with_buffer)[1], + input, + pos, + more, + fail, + succ); + }, + fail$1 = + function(input, pos, more){ + return caml_call5 + (fail, input, pos, more, 0, cst_count_while1$0); + }; + return prompt(input, pos, fail$1, succ$1); + } + return caml_call5(fail, input, pos, more, 0, cst_count_while1); + }]; + } + function string(f, s){ + var len = caml_ml_string_length(s); + function f$0(buffer, off, len){ + var i = [0, 0]; + for(;;){ + if(i[1] < len){ + var + _L_ = caml_call1(f, runtime.caml_string_unsafe_get(s, i[1])), + _M_ = caml_call1(f, runtime.caml_ba_get_1(buffer, off + i[1] | 0)); + if(caml_call2(Stdlib_Char[8], _M_, _L_)){i[1]++; continue;} + } + return len === i[1] + ? [0, caml_call3(Bigstringaf[7], buffer, off, len)] + : _h_; + } + } + return ensure + (len, + [0, + function(input, pos, more, fail, succ){ + var + match = caml_call4(Angstrom_Input[15], input, pos, len, f$0); + if(0 === match[0]){ + var x = match[1]; + return caml_call4(succ, input, pos + len | 0, more, x); + } + var e = match[1]; + return caml_call5(fail, input, pos, more, 0, e); + }]); + } + function string$0(s){return string(function(x){return x;}, s);} + function string_ci(s){return string(Stdlib_Char[5], s);} + function skip_while(f){ + return count_while(0, f, function(param, _K_, _J_){return 0;}); + } + function take(n){ + if(0 > n) return caml_call1(fail, cst_take_n_0); + var n$0 = caml_call2(Stdlib[17], n, 0); + return ensure(n$0, unsafe_apply(n$0, Bigstringaf[7])); + } + function take_bigstring(n){ + if(0 > n) return caml_call1(fail, cst_take_bigstring_n_0); + var n$0 = caml_call2(Stdlib[17], n, 0); + return ensure(n$0, unsafe_apply(n$0, Bigstringaf[4])); + } + function take_bigstring_while(f){return count_while(0, f, Bigstringaf[4]);} + function take_bigstring_while1(f){return count_while1(f, Bigstringaf[4]);} + function take_bigstring_till(f){ + return take_bigstring_while(function(c){return 1 - caml_call1(f, c);}); + } + function peek_string(n){return unsafe_lookahead(take(n));} + function take_while(f){return count_while(0, f, Bigstringaf[7]);} + function take_while1(f){return count_while1(f, Bigstringaf[7]);} + function take_till(f){ + return take_while(function(c){return 1 - caml_call1(f, c);}); + } + function choice(opt, ps){ + if(opt) + var sth = opt[1], failure_msg = sth; + else + var failure_msg = cst_no_more_choices; + var _I_ = caml_call1(fail, failure_msg); + return caml_call3(Stdlib_List[26], symbol$4, ps, _I_); + } + function fix_direct(f){ + var p = [], r = []; + caml_update_dummy(p, [246, function(_H_){return caml_call1(f, r);}]); + caml_update_dummy + (r, + [0, + function(buf, pos, more, fail, succ){ + var + _F_ = caml_obj_tag(p), + _G_ = + 250 === _F_ + ? p[1] + : 246 === _F_ ? caml_call1(CamlinternalLazy[2], p) : p; + return caml_call5(_G_[1], buf, pos, more, fail, succ); + }]); + return r; + } + function fix_lazy(max_steps, f){ + var steps = [0, max_steps], p = [], r = []; + caml_update_dummy(p, [246, function(_E_){return caml_call1(f, r);}]); + caml_update_dummy + (r, + [0, + function(buf, pos, more, fail, succ){ + steps[1]--; + if(0 <= steps[1]){ + var + _z_ = caml_obj_tag(p), + _A_ = + 250 === _z_ + ? p[1] + : 246 === _z_ ? caml_call1(CamlinternalLazy[2], p) : p; + return caml_call5(_A_[1], buf, pos, more, fail, succ); + } + steps[1] = max_steps; + return [1, + [246, + function(_B_){ + var + _C_ = caml_obj_tag(p), + _D_ = + 250 === _C_ + ? p[1] + : 246 === _C_ ? caml_call1(CamlinternalLazy[2], p) : p; + return caml_call5(_D_[1], buf, pos, more, fail, succ); + }]]; + }]); + return r; + } + var + _i_ = Stdlib_Sys[5], + cst_LE_int64 = "LE.int64", + cst_LE_int32 = "LE.int32", + cst_LE_int16 = "LE.int16", + cst_BE_int64 = "BE.int64", + cst_BE_int32 = "BE.int32", + cst_BE_int16 = "BE.int16", + cst_consumed_parser_committed = "consumed: parser committed", + cst_count_n_0 = "count: n < 0", + cst_end_of_line = "end_of_line", + fix = + typeof _i_ === "number" + ? _i_ ? fix_direct : fix_direct + : function(f){return fix_lazy(20, f);}; + function option(x, p){ + return caml_call2(symbol$4, p, caml_call1(return$0, x)); + } + function cons(x, xs){return [0, x, xs];} + function list(ps){ + if(! ps) return caml_call1(return$0, 0); + var ps$0 = ps[2], p = ps[1]; + return caml_call3(lift2, cons, p, list(ps$0)); + } + function count(n, p){ + if(0 > n) return caml_call1(fail, cst_count_n_0); + function loop(n){ + return 0 === n + ? caml_call1(return$0, 0) + : caml_call3(lift2, cons, p, loop(n - 1 | 0)); + } + return loop(n); + } + function many(p){ + return fix + (function(m){ + var _y_ = caml_call1(return$0, 0); + return caml_call2(symbol$4, caml_call3(lift2, cons, p, m), _y_); + }); + } + function many1(p){return caml_call3(lift2, cons, p, many(p));} + function many_till(p, t){ + return fix + (function(m){ + var _x_ = caml_call3(lift2, cons, p, m); + return caml_call2 + (symbol$4, + caml_call2(symbol$1, t, caml_call1(return$0, 0)), + _x_); + }); + } + function sep_by1(s, p){ + return fix + (function(m){ + var _w_ = caml_call1(return$0, 0); + return caml_call3 + (lift2, + cons, + p, + caml_call2(symbol$4, caml_call2(symbol$1, s, m), _w_)); + }); + } + function sep_by(s, p){ + var _u_ = caml_call1(return$0, 0), _v_ = caml_call1(return$0, 0); + return caml_call2 + (symbol$4, + caml_call3 + (lift2, + cons, + p, + caml_call2 + (symbol$4, caml_call2(symbol$1, s, sep_by1(s, p)), _v_)), + _u_); + } + function skip_many(p){ + return fix + (function(m){ + var _t_ = caml_call1(return$0, 0); + return caml_call2 + (symbol_bind, + caml_call2 + (symbol$4, + caml_call2(symbol_map, p, function(param){return 1;}), + _t_), + function(param){return param ? m : caml_call1(return$0, 0);}); + }); + } + function skip_many1(p){return caml_call2(symbol$1, p, skip_many(p));} + var + _j_ = caml_call1(return$0, 0), + _k_ = caml_call2(symbol$1, string$0(cst), _j_), + _l_ = caml_call1(return$0, 0), + end_of_line = + caml_call2 + (symbol$3, + caml_call2(symbol$4, caml_call2(symbol$1, char$0(10), _l_), _k_), + cst_end_of_line); + function scan(state, f, with_buffer){ + return [0, + function(input, pos, more, fail, succ){ + var + state$0 = [0, state], + parser = + caml_call2 + (symbol_map, + count_while + (0, + function(c){ + var match = caml_call2(f, state$0[1], c); + if(! match) return 0; + var state = match[1]; + state$0[1] = state; + return 1; + }, + with_buffer), + function(x){return [0, x, state$0[1]];}); + return caml_call5(parser[1], input, pos, more, fail, succ); + }]; + } + function scan$0(state, f){return scan(state, f, Bigstringaf[7]);} + function scan_state(state, f){ + return caml_call2 + (symbol_map, + scan(state, f, function(param, _s_, _r_){return 0;}), + function(param){var state = param[2]; return state;}); + } + function scan_string(state, f){ + return caml_call2 + (symbol_map, scan$0(state, f), function(_q_){return _q_[1];}); + } + function consume_with(p, f){ + return [0, + function(input, pos, more, fail, succ){ + var + parser_committed_bytes = caml_call1(Angstrom_Input[4], input); + function succ$0(input, pos$0, more, param){ + if + (parser_committed_bytes + !== caml_call1(Angstrom_Input[4], input)) + return caml_call5 + (fail, input, pos$0, more, 0, cst_consumed_parser_committed); + var + len = pos$0 - pos | 0, + consumed = caml_call4(Angstrom_Input[15], input, pos, len, f); + return caml_call4(succ, input, pos$0, more, consumed); + } + return caml_call5(p[1], input, pos, more, fail, succ$0); + }]; + } + function consumed(p){return consume_with(p, Bigstringaf[7]);} + function consumed_bigstring(p){return consume_with(p, Bigstringaf[4]);} + function both(a, b){ + return caml_call3(lift2, function(a, b){return [0, a, b];}, a, b); + } + function map(t, f){return caml_call2(symbol_map, t, f);} + function bind(t, f){return caml_call2(symbol_bind, t, f);} + function map2(a, b, f){return caml_call3(lift2, f, a, b);} + function map3(a, b, c, f){return caml_call4(lift3, f, a, b, c);} + function map4(a, b, c, d, f){return caml_call5(lift4, f, a, b, c, d);} + var + Let_syntax = [0, return$0, map, bind, both, map2, map3, map4], + Let_syntax$0 = [0, return$0, symbol_map, symbol_bind, Let_syntax]; + function int16(n){ + var + p = + [0, + function(input, pos, more, fail, succ){ + return caml_call2(Angstrom_Input[11], input, pos) === (n & 65535) + ? caml_call4(succ, input, pos + 2 | 0, more, 0) + : caml_call5(fail, input, pos, more, 0, cst_BE_int16); + }]; + return ensure(2, p); + } + function int32(n){ + var + p = + [0, + function(input, pos, more, fail, succ){ + var _p_ = caml_call2(Angstrom_Input[12], input, pos); + return caml_call2(Stdlib_Int32[17], _p_, n) + ? caml_call4(succ, input, pos + 4 | 0, more, 0) + : caml_call5(fail, input, pos, more, 0, cst_BE_int32); + }]; + return ensure(4, p); + } + function int64(n){ + var + p = + [0, + function(input, pos, more, fail, succ){ + var _o_ = caml_call2(Angstrom_Input[13], input, pos); + return caml_call2(Stdlib_Int64[17], _o_, n) + ? caml_call4(succ, input, pos + 8 | 0, more, 0) + : caml_call5(fail, input, pos, more, 0, cst_BE_int64); + }]; + return ensure(8, p); + } + var + any_uint16 = + ensure + (2, + unsafe_apply + (2, + function(bs, off, param){ + return caml_call2(Bigstringaf[31], bs, off); + })), + any_int16 = + ensure + (2, + unsafe_apply + (2, + function(bs, off, param){ + return caml_call2(Bigstringaf[33], bs, off); + })), + any_int32 = + ensure + (4, + unsafe_apply + (4, + function(bs, off, param){ + return caml_call2(Bigstringaf[37], bs, off); + })), + any_int64 = + ensure + (8, + unsafe_apply + (8, + function(bs, off, param){ + return caml_call2(Bigstringaf[41], bs, off); + })), + any_float = + ensure + (4, + unsafe_apply + (4, + function(bs, off, param){ + return caml_int32_float_of_bits + (caml_call2(Bigstringaf[37], bs, off)); + })), + any_double = + ensure + (8, + unsafe_apply + (8, + function(bs, off, param){ + return caml_int64_float_of_bits + (caml_call2(Bigstringaf[41], bs, off)); + })); + function int16$0(n){ + var + p = + [0, + function(input, pos, more, fail, succ){ + return caml_call2(Angstrom_Input[8], input, pos) === (n & 65535) + ? caml_call4(succ, input, pos + 2 | 0, more, 0) + : caml_call5(fail, input, pos, more, 0, cst_LE_int16); + }]; + return ensure(2, p); + } + function int32$0(n){ + var + p = + [0, + function(input, pos, more, fail, succ){ + var _n_ = caml_call2(Angstrom_Input[9], input, pos); + return caml_call2(Stdlib_Int32[17], _n_, n) + ? caml_call4(succ, input, pos + 4 | 0, more, 0) + : caml_call5(fail, input, pos, more, 0, cst_LE_int32); + }]; + return ensure(4, p); + } + function int64$0(n){ + var + p = + [0, + function(input, pos, more, fail, succ){ + var _m_ = caml_call2(Angstrom_Input[10], input, pos); + return caml_call2(Stdlib_Int64[17], _m_, n) + ? caml_call4(succ, input, pos + 8 | 0, more, 0) + : caml_call5(fail, input, pos, more, 0, cst_LE_int64); + }]; + return ensure(8, p); + } + var + any_uint16$0 = + ensure + (2, + unsafe_apply + (2, + function(bs, off, param){ + return caml_call2(Bigstringaf[30], bs, off); + })), + any_int16$0 = + ensure + (2, + unsafe_apply + (2, + function(bs, off, param){ + return caml_call2(Bigstringaf[32], bs, off); + })), + any_int32$0 = + ensure + (4, + unsafe_apply + (4, + function(bs, off, param){ + return caml_call2(Bigstringaf[36], bs, off); + })), + any_int64$0 = + ensure + (8, + unsafe_apply + (8, + function(bs, off, param){ + return caml_call2(Bigstringaf[40], bs, off); + })), + any_float$0 = + ensure + (4, + unsafe_apply + (4, + function(bs, off, param){ + return caml_int32_float_of_bits + (caml_call2(Bigstringaf[36], bs, off)); + })), + any_double$0 = + ensure + (8, + unsafe_apply + (8, + function(bs, off, param){ + return caml_int64_float_of_bits + (caml_call2(Bigstringaf[40], bs, off)); + })); + function take$0(n, f){ + var n$0 = caml_call2(Stdlib[17], n, 0); + return ensure(n$0, unsafe_apply(n$0, f)); + } + function peek(n, f){return unsafe_lookahead(take$0(n, f));} + function take_while$0(check, f){return count_while(0, check, f);} + function take_while1$0(check, f){return count_while1(check, f);} + function take_till$0(check, f){ + return take_while$0(function(c){return 1 - caml_call1(check, c);}, f); + } + var Consume = [0]; + function parse_bigstring$0(consume, p, bs){ + var p$0 = consume ? caml_call2(symbol$2, p, end_of_input) : p; + return caml_call2(parse_bigstring, p$0, bs); + } + function parse_string(consume, p, s){ + var len = caml_ml_string_length(s), bs = caml_call1(Bigstringaf[1], len); + caml_call5(Bigstringaf[45], s, 0, bs, 0, len); + return parse_bigstring$0(consume, p, bs); + } + var + Angstrom = + [0, + peek_char, + peek_char_fail, + peek_string, + char$0, + not_char, + any_char, + satisfy, + string$0, + string_ci, + skip, + skip_while, + take, + take_while, + take_while1, + take_till, + consumed, + take_bigstring, + take_bigstring_while, + take_bigstring_while1, + take_bigstring_till, + consumed_bigstring, + advance, + end_of_line, + at_end_of_input, + end_of_input, + scan$0, + scan_state, + scan_string, + int8, + any_uint8, + any_int8, + [0, + int16, + int32, + int64, + any_int16, + any_int32, + any_int64, + any_uint16, + any_float, + any_double], + [0, + int16$0, + int32$0, + int64$0, + any_int16$0, + any_int32$0, + any_int64$0, + any_uint16$0, + any_float$0, + any_double$0], + option, + both, + list, + count, + many, + many1, + many_till, + sep_by, + sep_by1, + skip_many, + skip_many1, + fix, + fix_lazy, + symbol$4, + choice, + symbol$3, + commit, + return$0, + fail, + symbol_bind, + bind, + symbol_map, + symbol$0, + symbol, + symbol$1, + symbol$2, + lift, + lift2, + lift3, + lift4, + map, + map2, + map3, + map4, + Let_syntax$0, + symbol_map, + symbol_bind, + both, + [0, take$0, take_while$0, take_while1$0, take_till$0, peek], + Consume, + parse_bigstring$0, + parse_string, + [0, + parse$0, + feed, + state_to_option$0, + state_to_result$0, + state_to_unconsumed], + [0, parse, state_to_option, state_to_result], + pos, + available]; + runtime.caml_register_global(42, Angstrom, "Angstrom"); + return; + } + (globalThis)); + + +//# 1 "../.js/default/zarith/zarith.cma.js" +// Generated by js_of_ocaml +//# 3 "../.js/default/zarith/zarith.cma.js" + + +//# 1 "../.js/default/exenum.internals/exenum_internals.cma.js" +// Generated by js_of_ocaml +//# 3 "../.js/default/exenum.internals/exenum_internals.cma.js" + + +//# 1 "../.js/default/exenum/exenum.cma.js" +// Generated by js_of_ocaml +//# 3 "../.js/default/exenum/exenum.cma.js" + + +//# 1 ".uiml_demo.eobjs/jsoo/dune__exe.cmo.js" +// Generated by js_of_ocaml +//# 3 ".uiml_demo.eobjs/jsoo/dune__exe.cmo.js" + +//# 5 ".uiml_demo.eobjs/jsoo/dune__exe.cmo.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime, Dune_exe = [0]; + runtime.caml_register_global(0, Dune_exe, "Dune__exe"); + return; + } + (globalThis)); + + +//# 1 ".uiml_demo.eobjs/jsoo/dune__exe__Stringconversion.cmo.js" +// Generated by js_of_ocaml +//# 3 ".uiml_demo.eobjs/jsoo/dune__exe__Stringconversion.cmo.js" + +//# 6 ".uiml_demo.eobjs/jsoo/dune__exe__Stringconversion.cmo.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + var + global_data = runtime.caml_get_global_data(), + Stdlib_List = global_data.Stdlib__List, + Stdlib_Bytes = global_data.Stdlib__Bytes; + function camlstring_of_coqstring(s){ + var + r = runtime.caml_create_bytes(caml_call1(Stdlib_List[1], s)), + pos = 0, + param = s; + for(;;){ + if(! param) return caml_call1(Stdlib_Bytes[6], r); + var s$0 = param[2], c = param[1]; + runtime.caml_bytes_set(r, pos, c); + var pos$0 = pos + 1 | 0; + pos = pos$0; + param = s$0; + } + } + function coqstring_of_camlstring(s){ + var + pos$1 = runtime.caml_ml_string_length(s) - 1 | 0, + accu = 0, + pos = pos$1; + for(;;){ + if(0 > pos) return accu; + var + pos$0 = pos - 1 | 0, + accu$0 = [0, runtime.caml_string_get(s, pos), accu]; + accu = accu$0; + pos = pos$0; + } + } + var + Dune_exe_Stringconversion = + [0, camlstring_of_coqstring, coqstring_of_camlstring]; + runtime.caml_register_global + (2, Dune_exe_Stringconversion, "Dune__exe__Stringconversion"); + return; + } + (globalThis)); + + +//# 1 ".uiml_demo.eobjs/jsoo/dune__exe__Modal_expressions_parser.cmo.js" +// Generated by js_of_ocaml +//# 3 ".uiml_demo.eobjs/jsoo/dune__exe__Modal_expressions_parser.cmo.js" + +//# 6 ".uiml_demo.eobjs/jsoo/dune__exe__Modal_expressions_parser.cmo.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + caml_maybe_attach_backtrace = runtime.caml_maybe_attach_backtrace; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + function caml_call3(f, a0, a1, a2){ + return (f.l >= 0 ? f.l : f.l = f.length) == 3 + ? f(a0, a1, a2) + : runtime.caml_call_gen(f, [a0, a1, a2]); + } + var + global_data = runtime.caml_get_global_data(), + Angstrom = global_data.Angstrom, + Dune_exe_Stringconversion = global_data.Dune__exe__Stringconversion, + Stdlib = global_data.Stdlib; + function is_space(param){ + a: + { + if(11 <= param){if(32 === param) break a;} else if(9 <= param) break a; + return 0; + } + return 1; + } + var spaces = caml_call1(Angstrom[11], is_space); + function parens(p){ + var + _aZ_ = caml_call1(Angstrom[4], 41), + _a0_ = caml_call1(Angstrom[4], 40), + _a1_ = caml_call2(Angstrom[58], _a0_, p); + return caml_call2(Angstrom[59], _a1_, _aZ_); + } + function box(p){ + var + _aO_ = caml_call1(Angstrom[4], 161), + _aP_ = caml_call1(Angstrom[4], 150), + _aQ_ = caml_call1(Angstrom[4], 226), + _aR_ = caml_call2(Angstrom[58], _aQ_, _aP_), + _aS_ = caml_call2(Angstrom[58], _aR_, _aO_), + _aT_ = caml_call1(Angstrom[4], 93), + _aU_ = caml_call1(Angstrom[4], 91), + _aV_ = caml_call2(Angstrom[58], _aU_, _aT_), + _aW_ = caml_call2(Angstrom[47], _aV_, _aS_), + _aX_ = caml_call2(Angstrom[58], _aW_, spaces), + _aY_ = caml_call2(Angstrom[58], _aX_, p); + return caml_call2(Angstrom[55], _aY_, function(x){return [4, x];}); + } + function diamond(p){ + var + _aD_ = caml_call1(Angstrom[4], 132), + _aE_ = caml_call1(Angstrom[4], 139), + _aF_ = caml_call1(Angstrom[4], 226), + _aG_ = caml_call2(Angstrom[58], _aF_, _aE_), + _aH_ = caml_call2(Angstrom[58], _aG_, _aD_), + _aI_ = caml_call1(Angstrom[4], 62), + _aJ_ = caml_call1(Angstrom[4], 60), + _aK_ = caml_call2(Angstrom[58], _aJ_, _aI_), + _aL_ = caml_call2(Angstrom[47], _aK_, _aH_), + _aM_ = caml_call2(Angstrom[58], _aL_, spaces), + _aN_ = caml_call2(Angstrom[58], _aM_, p); + return caml_call2 + (Angstrom[55], _aN_, function(x){return [3, [4, [3, x, 0]], 0];}); + } + function neg(p){ + var + _aw_ = caml_call1(Angstrom[4], 172), + _ax_ = caml_call1(Angstrom[4], 194), + _ay_ = caml_call2(Angstrom[58], _ax_, _aw_), + _az_ = caml_call1(Angstrom[4], 126), + _aA_ = caml_call2(Angstrom[47], _az_, _ay_), + _aB_ = caml_call2(Angstrom[58], _aA_, spaces), + _aC_ = caml_call2(Angstrom[58], _aB_, p); + return caml_call2(Angstrom[55], _aC_, function(x){return [3, x, 0];}); + } + var + _a_ = caml_call1(Angstrom[51], function(x, y){return [2, x, y];}), + _b_ = caml_call1(Angstrom[4], 124), + _c_ = caml_call1(Angstrom[4], 168), + _d_ = caml_call1(Angstrom[4], 136), + _e_ = caml_call1(Angstrom[4], 226), + _f_ = caml_call2(Angstrom[58], _e_, _d_), + _g_ = caml_call2(Angstrom[58], _f_, _c_), + _h_ = caml_call2(Angstrom[47], _g_, _b_), + _i_ = caml_call2(Angstrom[58], spaces, _h_), + _j_ = caml_call2(Angstrom[58], _i_, spaces), + disj = caml_call2(Angstrom[58], _j_, _a_), + _k_ = caml_call1(Angstrom[51], function(x, y){return [1, x, y];}), + _l_ = caml_call1(Angstrom[4], 38), + _m_ = caml_call1(Angstrom[4], 167), + _n_ = caml_call1(Angstrom[4], 136), + _o_ = caml_call1(Angstrom[4], 226), + _p_ = caml_call2(Angstrom[58], _o_, _n_), + _q_ = caml_call2(Angstrom[58], _p_, _m_), + _r_ = caml_call2(Angstrom[47], _q_, _l_), + _s_ = caml_call2(Angstrom[58], spaces, _r_), + _t_ = caml_call2(Angstrom[58], _s_, spaces), + conj = caml_call2(Angstrom[58], _t_, _k_); + function modal(p){ + var + _as_ = diamond(p), + _at_ = neg(p), + _au_ = box(p), + _av_ = caml_call2(Angstrom[47], _au_, _at_); + return caml_call2(Angstrom[47], _av_, _as_); + } + var + _u_ = caml_call1(Angstrom[51], function(x, y){return [3, x, y];}), + _v_ = caml_call1(Angstrom[4], 62), + _w_ = caml_call1(Angstrom[4], 45), + _x_ = caml_call2(Angstrom[58], _w_, _v_), + _y_ = caml_call1(Angstrom[4], 146), + _z_ = caml_call1(Angstrom[4], 134), + _A_ = caml_call1(Angstrom[4], 226), + _B_ = caml_call2(Angstrom[58], _A_, _z_), + _C_ = caml_call2(Angstrom[58], _B_, _y_), + _D_ = caml_call2(Angstrom[47], _C_, _x_), + _E_ = caml_call2(Angstrom[58], spaces, _D_), + _F_ = caml_call2(Angstrom[58], _E_, spaces), + impl = caml_call2(Angstrom[58], _F_, _u_), + _G_ = caml_call1(Angstrom[51], 0), + _H_ = caml_call1(Angstrom[4], 70), + _I_ = caml_call1(Angstrom[4], 35), + _J_ = caml_call1(Angstrom[4], 165), + _K_ = caml_call1(Angstrom[4], 138), + _L_ = caml_call1(Angstrom[4], 226), + _M_ = caml_call2(Angstrom[58], _L_, _K_), + _N_ = caml_call2(Angstrom[58], _M_, _J_), + _O_ = caml_call2(Angstrom[47], _N_, _I_), + _P_ = caml_call2(Angstrom[47], _O_, _H_), + _Q_ = caml_call2(Angstrom[58], spaces, _P_), + _R_ = caml_call2(Angstrom[58], _Q_, spaces), + bot = caml_call2(Angstrom[58], _R_, _G_), + _S_ = caml_call1(Angstrom[51], [3, 0, 0]), + _T_ = caml_call1(Angstrom[4], 84), + _U_ = caml_call1(Angstrom[4], 164), + _V_ = caml_call1(Angstrom[4], 138), + _W_ = caml_call1(Angstrom[4], 226), + _X_ = caml_call2(Angstrom[58], _W_, _V_), + _Y_ = caml_call2(Angstrom[58], _X_, _U_), + _Z_ = caml_call2(Angstrom[47], _Y_, _T_), + ___ = caml_call2(Angstrom[58], spaces, _Z_), + _$_ = caml_call2(Angstrom[58], ___, spaces), + top = caml_call2(Angstrom[58], _$_, _S_); + function letter(param){return 25 < param - 97 >>> 0 ? 0 : 1;} + function letter_or_digit(param){ + var _ar_ = param - 48 | 0; + a: + { + if(42 < _ar_ >>> 0){ + if(25 < _ar_ - 49 >>> 0) break a; + } + else if(6 >= _ar_ - 10 >>> 0) break a; + return 1; + } + return 0; + } + var + _aa_ = caml_call1(Angstrom[13], letter_or_digit), + _ab_ = caml_call1(Angstrom[14], letter), + _ac_ = caml_call3(Angstrom[61], Stdlib[28], _ab_, _aa_), + identifier = + caml_call2 + (Angstrom[55], + _ac_, + function(x){return [0, caml_call1(Dune_exe_Stringconversion[2], x)];}); + function chainl1(e, op){ + function go(acc){ + var + _ao_ = caml_call1(Angstrom[51], acc), + _ap_ = + caml_call3 + (Angstrom[61], function(f, x){return caml_call2(f, acc, x);}, op, e), + _aq_ = caml_call2(Angstrom[53], _ap_, go); + return caml_call2(Angstrom[47], _aq_, _ao_); + } + return caml_call2(Angstrom[53], e, function(init){return go(init);}); + } + function chainr1(e, op){ + function go(acc){ + var + _al_ = caml_call1(Angstrom[51], acc), + _am_ = caml_call2(Angstrom[53], e, go), + _an_ = + caml_call3 + (Angstrom[61], + function(f, x){return caml_call2(f, acc, x);}, + op, + _am_); + return caml_call2(Angstrom[47], _an_, _al_); + } + return caml_call2(Angstrom[53], e, go); + } + function chainmod(e, op){ + return caml_call1 + (Angstrom[45], + function(x){ + var _ak_ = caml_call1(op, x); + return caml_call2(Angstrom[47], _ak_, e); + }); + } + var + expr = + caml_call1 + (Angstrom[45], + function(expr){ + var + _ad_ = parens(expr), + _ae_ = caml_call2(Angstrom[47], _ad_, identifier), + _af_ = caml_call2(Angstrom[47], _ae_, bot), + factor = caml_call2(Angstrom[47], _af_, top), + modality = chainmod(factor, modal), + term = chainl1(modality, conj), + _ag_ = chainl1(term, disj), + _ah_ = caml_call2(Angstrom[58], spaces, _ag_), + disjunctions = caml_call2(Angstrom[59], _ah_, spaces), + _ai_ = chainr1(disjunctions, impl), + _aj_ = caml_call2(Angstrom[58], spaces, _ai_); + return caml_call2(Angstrom[59], _aj_, spaces); + }), + ParseError = + [248, + "Dune__exe__Modal_expressions_parser.ParseError", + runtime.caml_fresh_oo_id(0)]; + function eval$0(str){ + var match = caml_call3(Angstrom[75], 1, expr, str); + if(0 !== match[0]) throw caml_maybe_attach_backtrace(ParseError, 1); + var v = match[1]; + return v; + } + var + Dune_exe_Modal_expressions_par = + [0, + is_space, + spaces, + parens, + box, + diamond, + neg, + disj, + conj, + modal, + impl, + bot, + top, + letter, + letter_or_digit, + identifier, + chainl1, + chainr1, + chainmod, + expr, + ParseError, + eval$0]; + runtime.caml_register_global + (5, Dune_exe_Modal_expressions_par, "Dune__exe__Modal_expressions_parser"); + return; + } + (globalThis)); + + +//# 1 ".uiml_demo.eobjs/jsoo/dune__exe__Printer.cmo.js" +// Generated by js_of_ocaml +//# 3 ".uiml_demo.eobjs/jsoo/dune__exe__Printer.cmo.js" + +//# 6 ".uiml_demo.eobjs/jsoo/dune__exe__Printer.cmo.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime, cst$10 = "\xe2\x8b\x84 "; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + global_data = runtime.caml_get_global_data(), + cst = "\xe2\x8a\xa5", + cst$0 = " \xe2\x88\xa7 ", + cst$1 = " \xe2\x88\xa8 ", + cst$2 = "\xe2\x8a\xa4", + cst$5 = cst$10, + cst$4 = "\xc2\xac ", + cst$3 = " \xe2\x86\x92 ", + cst$6 = "\xe2\x96\xa1 ", + cst$9 = cst$10, + cst$7 = ")", + cst$8 = "(", + Dune_exe_Stringconversion = global_data.Dune__exe__Stringconversion, + Stdlib = global_data.Stdlib; + function int_of_nat(param){ + if(! param) return 0; + var n = param[1]; + return 1 + int_of_nat(n) | 0; + } + function string_of_formula(opt){ + if(opt) var sth = opt[1], classical = sth; else var classical = 0; + function string_of_formula(param){ + var param$0 = param; + for(;;){ + if(typeof param$0 === "number") return cst; + a: + switch(param$0[0]){ + case 0: + var v = param$0[1]; + return caml_call1(Dune_exe_Stringconversion[1], v); + case 1: + var + g = param$0[2], + f = param$0[1], + _f_ = bracket(g), + _g_ = caml_call2(Stdlib[28], cst$0, _f_), + _h_ = bracket(f); + return caml_call2(Stdlib[28], _h_, _g_); + case 2: + var + g$0 = param$0[2], + f$0 = param$0[1], + _i_ = bracket(g$0), + _j_ = caml_call2(Stdlib[28], cst$1, _i_), + _k_ = bracket(f$0); + return caml_call2(Stdlib[28], _k_, _j_); + case 3: + var f$1 = param$0[1]; + b: + if(typeof f$1 === "number"){ + if(typeof param$0[2] === "number") return cst$2; + } + else{ + switch(f$1[0]){ + case 3: + if(typeof f$1[2] === "number"){ + if(typeof param$0[2] !== "number") break b; + var f$2 = f$1[1]; + if(classical){param$0 = f$2; break a;} + } + break; + case 4: + var _p_ = f$1[1]; + if(typeof _p_ !== "number" && 3 === _p_[0]){ + if(typeof _p_[2] !== "number") break; + if(typeof param$0[2] !== "number") break b; + var f$3 = _p_[1]; + if(! classical) break; + var _q_ = bracket(f$3); + return caml_call2(Stdlib[28], cst$5, _q_); + } + break; + } + if(typeof param$0[2] === "number"){ + var _o_ = bracket(f$1); + return caml_call2(Stdlib[28], cst$4, _o_); + } + } + var + g$1 = param$0[2], + _l_ = bracket(g$1), + _m_ = caml_call2(Stdlib[28], cst$3, _l_), + _n_ = bracket(f$1); + return caml_call2(Stdlib[28], _n_, _m_); + default: + var f$4 = param$0[1], _r_ = bracket(f$4); + return caml_call2(Stdlib[28], cst$6, _r_); + } + } + } + function bracket(e){ + var e$0 = e; + for(;;){ + a: + if(typeof e$0 !== "number"){ + b: + switch(e$0[0]){ + case 3: + var _c_ = e$0[1]; + if(typeof _c_ !== "number") + switch(_c_[0]){ + case 3: + if(typeof _c_[2] === "number"){ + if(typeof e$0[2] !== "number") break b; + var f = _c_[1]; + if(classical){e$0 = f; continue;} + } + break; + case 4: + var _d_ = _c_[1]; + if(typeof _d_ !== "number" && 3 === _d_[0]){ + if(typeof _d_[2] !== "number") break; + if(typeof e$0[2] !== "number") break b; + var f$0 = _d_[1]; + if(! classical) break; + var _e_ = bracket(f$0); + return caml_call2(Stdlib[28], cst$9, _e_); + } + break; + } + if(typeof e$0[2] === "number") break a; + break; + case 1: + case 2: break; + default: break a; + } + var + _a_ = string_of_formula(e$0), + _b_ = caml_call2(Stdlib[28], _a_, cst$7); + return caml_call2(Stdlib[28], cst$8, _b_); + } + return string_of_formula(e$0); + } + } + return string_of_formula; + } + var Dune_exe_Printer = [0, int_of_nat, string_of_formula]; + runtime.caml_register_global(13, Dune_exe_Printer, "Dune__exe__Printer"); + return; + } + (globalThis)); + + +//# 1 ".uiml_demo.eobjs/jsoo/dune__exe__Uiml_demo.cmo.js" +// Generated by js_of_ocaml +//# 3 ".uiml_demo.eobjs/jsoo/dune__exe__Uiml_demo.cmo.js" + +//# 6 ".uiml_demo.eobjs/jsoo/dune__exe__Uiml_demo.cmo.js" +(function + (globalThis){ + "use strict"; + var + runtime = globalThis.jsoo_runtime, + cst_Error$1 = "Error: ", + caml_js_wrap_meth_callback = runtime.caml_js_wrap_meth_callback, + caml_wrap_exception = runtime.caml_wrap_exception; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + function caml_call2(f, a0, a1){ + return (f.l >= 0 ? f.l : f.l = f.length) == 2 + ? f(a0, a1) + : runtime.caml_call_gen(f, [a0, a1]); + } + var + undef = undefined, + global_data = runtime.caml_get_global_data(), + Dune_exe_Modal_expressions_par = + global_data.Dune__exe__Modal_expressions_parser, + UIML_UIML_extraction = global_data.UIML__UIML_extraction, + Dune_exe_Printer = global_data.Dune__exe__Printer; + global_data.CamlinternalOO; + var + Stdlib = global_data.Stdlib, + Stdlib_Printexc = global_data.Stdlib__Printexc, + Dune_exe_Stringconversion = global_data.Dune__exe__Stringconversion, + Js_of_ocaml_Js = global_data.Js_of_ocaml__Js, + cst_Parse_Error = "Parse Error", + cst_Error = cst_Error$1, + cst_Error$0 = cst_Error$1, + cst_The_provided_formula_conta = + "The provided formula contains modalities"; + function catch_e(f){ + try{var _q_ = caml_call1(f, 0); return _q_;} + catch(e$0){ + var e = caml_wrap_exception(e$0); + if(e === Dune_exe_Modal_expressions_par[20]) return cst_Parse_Error; + if(e[1] === Stdlib[7]){ + var s = e[2]; + return caml_call2(Stdlib[28], cst_Error, s); + } + var _p_ = caml_call1(Stdlib_Printexc[1], e); + return caml_call2(Stdlib[28], cst_Error$0, _p_); + } + } + function fail_on_modality(f){ + function aux(param){ + var param$0 = param; + for(;;){ + if(typeof param$0 !== "number") + switch(param$0[0]){ + case 4: + return caml_call1(Stdlib[2], cst_The_provided_formula_conta); + case 0: break; + default: + var y = param$0[2], x = param$0[1]; aux(x); param$0 = y; continue; + } + return; + } + } + aux(f); + return f; + } + var + v = caml_call1(Dune_exe_Stringconversion[2], "p"), + _a_ = [0, 1], + _b_ = [0, 1]; + function t13(param, s){ + return catch_e + (function(param){ + var _o_ = caml_call1(Dune_exe_Modal_expressions_par[21], s); + return caml_call2(Dune_exe_Printer[2], 0, _o_); + }); + } + function t12(param, s){ + return catch_e + (function(param){ + var + _m_ = caml_call1(Dune_exe_Modal_expressions_par[21], s), + _n_ = caml_call1(caml_call1(UIML_UIML_extraction[4], v), _m_); + return caml_call1(caml_call1(Dune_exe_Printer[2], _a_), _n_); + }); + } + function t11(param, s){ + return catch_e + (function(param){ + var + _k_ = caml_call1(Dune_exe_Modal_expressions_par[21], s), + _l_ = caml_call1(caml_call1(UIML_UIML_extraction[3], v), _k_); + return caml_call1(caml_call1(Dune_exe_Printer[2], _b_), _l_); + }); + } + function t10(param, s){ + return catch_e + (function(param){ + var + _i_ = caml_call1(Dune_exe_Modal_expressions_par[21], s), + _j_ = caml_call1(caml_call1(UIML_UIML_extraction[8], v), _i_); + return caml_call2(Dune_exe_Printer[2], 0, _j_); + }); + } + function t9(param, s){ + return catch_e + (function(param){ + var + _g_ = caml_call1(Dune_exe_Modal_expressions_par[21], s), + _h_ = caml_call1(caml_call1(UIML_UIML_extraction[9], v), _g_); + return caml_call2(Dune_exe_Printer[2], 0, _h_); + }); + } + function t8(param, s){ + return catch_e + (function(param){ + var + _e_ = + fail_on_modality + (caml_call1(Dune_exe_Modal_expressions_par[21], s)), + _f_ = caml_call1(caml_call1(UIML_UIML_extraction[5], v), _e_); + return caml_call2(Dune_exe_Printer[2], 0, _f_); + }); + } + function t7(param, s){ + return catch_e + (function(param){ + var + _c_ = + fail_on_modality + (caml_call1(Dune_exe_Modal_expressions_par[21], s)), + _d_ = caml_call1(caml_call1(UIML_UIML_extraction[6], v), _c_); + return caml_call2(Dune_exe_Printer[2], 0, _d_); + }); + } + caml_call2 + (Js_of_ocaml_Js[50], + "UIML", + {iA: caml_js_wrap_meth_callback(t7), + iE: caml_js_wrap_meth_callback(t8), + islA: caml_js_wrap_meth_callback(t9), + islE: caml_js_wrap_meth_callback(t10), + k: caml_js_wrap_meth_callback(t11), + gl: caml_js_wrap_meth_callback(t12), + parse: caml_js_wrap_meth_callback(t13)}); + var Dune_exe_Uiml_demo = [0]; + runtime.caml_register_global + (26, Dune_exe_Uiml_demo, "Dune__exe__Uiml_demo"); + return; + } + (globalThis)); + + +//# 1 "../.js/default/stdlib/std_exit.cmo.js" +// Generated by js_of_ocaml +//# 3 "../.js/default/stdlib/std_exit.cmo.js" + +//# 6 "../.js/default/stdlib/std_exit.cmo.js" +(function + (globalThis){ + "use strict"; + var runtime = globalThis.jsoo_runtime; + function caml_call1(f, a0){ + return (f.l >= 0 ? f.l : f.l = f.length) == 1 + ? f(a0) + : runtime.caml_call_gen(f, [a0]); + } + var + global_data = runtime.caml_get_global_data(), + Stdlib = global_data.Stdlib; + caml_call1(Stdlib[103], 0); + var Std_exit = [0]; + runtime.caml_register_global(1, Std_exit, "Std_exit"); + return; + } + (globalThis)); + + +//# sourceMappingURL=data:application/json;base64,{"version":3.0,"file":"uiml_demo.bc.js","sourceRoot":"","names":["caml_subarray_to_jsbytes","a","i","len","f","String","null","s","Math","caml_string_of_jsbytes","x","caml_string_of_array","caml_ba_get_1","ba","i0","BigStringReader","bs","this","arr","Array","j","offset","caml_str_repeat","n","r","l","caml_convert_string_to_bytes","jsoo_is_ascii","caml_utf16_of_utf8","b","t","c","c1","c2","v","MlBytes","tag","contents","length","content","caml_utf8_of_utf16","d","caml_string_of_jsstring","unix_error","make_unix_err_args","code","syscall","path","errno","variant","args","caml_named_values","caml_named_value","nm","jsoo_sys_getenv","process","globalThis","undefined","caml_record_backtrace_flag","caml_global_data","caml_exn_with_js_backtrace","exn","force","caml_maybe_attach_backtrace","caml_raise_with_args","caml_is_ml_bytes","caml_is_ml_string","caml_bytes_of_array","Uint8Array","caml_bytes_of_jsbytes","caml_jsbytes_of_string","caml_bytes_of_string","caml_raise_with_arg","arg","caml_raise_with_string","msg","caml_raise_sys_error","caml_raise_no_such_file","name","caml_convert_bytes_to_array","caml_uint8_array_of_bytes","caml_invalid_argument","caml_create_bytes","caml_ml_bytes_length","caml_blit_bytes","s1","i1","s2","i2","MlFile","MlFakeFile","old","buf","pos","clen","new_str","old_data","data","MlFakeFd","file","flags","MlFakeDevice","root","comp","res","Symbol","name_slash","mode","raise_unix","parent","RegExp","seen","m","entry","ok","bytes","MlFakeFd_out","fd","console","src","caml_int64_offset","caml_raise_constant","caml_raise_zero_divide","MlInt64","lo","mi","hi","xhi","h","sign","modulus","divisor","quotient","y","q","MlMutex","MlNat","Int32Array","caml_ml_string_length","caml_string_unsafe_get","caml_uint8_array_of_string","caml_bytes_bound_error","caml_bytes_unsafe_set","caml_bytes_set","MlNodeFd","require","err","buf_offset","read","MlNodeDevice","consts","key","isCharacterDevice","o","js_stats","to_dir","target","link","file_kind","MlObjectTable","NaiveLookup","objs","MlStringReader","caml_int64_create_lo_hi","caml_int64_hi32","caml_int64_lo32","caml_array_bound_error","caml_ba_custom_name","Ml_Bigarray","kind","layout","dims","buffer","ofs","im","re","total","k1","k2","NaN","Ml_Bigarray_c_1_1","UInt8ArrayReader","incr_nat","nat","carry_in","carry","add_nat","nat1","ofs1","len1","nat2","ofs2","len2","caml_ba_get_size","n_dims","size","caml_ba_get_size_per_element","caml_ba_create_unsafe","size_per_element","bigstring_of_array_buffer","ab","ta","bigstring_of_typed_array","bigstring_to_array_buffer","bigstring_to_typed_array","caml_bigstring_blit_string_to_ba","str1","pos1","ba2","pos2","slice","bigstringaf_blit_from_bytes","src_off","dst","dst_off","caml_bigstring_blit_ba_to_ba","ba1","bigstringaf_blit_to_bigstring","caml_bigstring_blit_ba_to_bytes","bytes2","bigstringaf_blit_to_bytes","bigstringaf_memchr","ba_off","chr","caml_int_compare","bigstringaf_memcmp_bigstring","ba1_off","ba2_off","bigstringaf_memcmp_string","str","str_off","blit_nat","caml_MD5Transform","add","xx","ff","gg","hh","ii","w","caml_MD5Final","ctx","in_buf","caml_MD5Init","ArrayBuffer","b32","Uint32Array","b8","caml_MD5Update","input","input_len","input_pos","missing","caml_acosh_float","caml_call_gen","argsLen","g","nargs","extra_args","arguments","caml_alloc_dummy_infix","caml_alloc_stack","hv","hx","hf","caml_argv","main","argv","p","args2","caml_array_append","a1","a2","l1","l2","caml_array_blit","caml_array_concat","caml_array_fill","array","caml_array_get","index","caml_array_of_bytes","caml_array_of_string","caml_array_set","newval","caml_array_sub","caml_asinh_float","caml_atanh_float","caml_atomic_cas","ref","caml_atomic_exchange","caml_atomic_fetch_add","caml_atomic_load","caml_atomic_make_contended","caml_ba_blit","caml_ba_change_layout","new_dims","caml_ba_compare","caml_ba_create_buffer","view","Float32Array","Float64Array","Int8Array","Int16Array","Uint16Array","caml_js_from_array","caml_ba_create","dims_ml","caml_ba_create_from","data1","data2","jstyp","caml_int32_float_of_bits","int32a","float32a","caml_int64_of_bytes","caml_int64_float_of_bits","exp","Infinity","k","caml_failwith","caml_ba_deserialize","reader","sz","num_dims","size_dim","size_dim_hi","size_dim_lo","sixty","int64","caml_ba_dim","caml_ba_dim_1","caml_ba_dim_2","caml_ba_dim_3","caml_ba_fill","caml_ba_kind_of_typed_array","Uint8ClampedArray","caml_ba_from_typed_array","caml_ba_get_2","caml_ba_get_3","caml_ba_get_generic","caml_mul","caml_hash_mix_int","log2_ok","jsoo_floor_log2","caml_int64_create_lo_mi_hi","caml_int64_bits_of_float","isFinite","isNaN","r3","r2","r1","caml_hash_mix_int64","caml_hash_mix_float","v0","caml_ba_hash","num_elts","caml_ba_init","caml_ba_kind","caml_ba_layout","caml_ba_map_file","vfd","shared","caml_ba_map_file_bytecode","argn","caml_ba_num_dims","caml_ba_reshape","vind","new_dim","caml_int32_bits_of_float","caml_int64_to_bytes","caml_ba_serialize","writer","complex","caml_ba_set_1","caml_ba_set_2","caml_ba_set_3","caml_ba_set_generic","caml_ba_slice","num_inds","sub_dims","new_data","caml_ba_sub","changed_dim","mul","caml_ba_to_typed_array","caml_ba_uint8_get16","b1","b2","caml_ba_uint8_get32","b3","b4","caml_ba_uint8_get64","b5","b6","b7","caml_ba_uint8_set16","caml_ba_uint8_set32","caml_ba_uint8_set64","caml_backtrace_status","_unit","caml_bigstring_blit_bytes_to_ba","caml_bigstring_memcmp","caml_blit_string","e","caml_bswap16","caml_jsstring_of_string","caml_build_symbols","symb","caml_bytes_compare","caml_bytes_equal","caml_bytes_unsafe_get","caml_bytes_get","caml_bytes_get16","caml_bytes_get32","caml_bytes_get64","caml_bytes_lessequal","caml_bytes_greaterequal","caml_bytes_lessthan","caml_bytes_greaterthan","caml_bytes_notequal","caml_bytes_of_utf16_jsstring","caml_bytes_set16","i16","caml_bytes_set32","i32","caml_bytes_set64","i64","caml_callback","caml_cbrt_float","caml_ml_channels","caml_ml_channel_get","id","caml_channel_descriptor","chanid","chan","caml_check_bound","caml_classify_float","caml_is_continuation_tag","caml_int32_unmarshal","caml_nativeint_unmarshal","caml_int64_unmarshal","caml_int64_marshal","sizes","caml_int64_compare","caml_int64_hash","caml_custom_ops","caml_compare_val_get_custom","caml_compare_val_number_custom","num","custom","swap","caml_compare_val_tag","Number","caml_string_compare","caml_compare_val","stack","tag_a","tag_b","caml_compare","caml_continuation_use_noexc","cont","caml_continuation_use_and_update_handler_noexc","hval","hexn","heff","caml_convert_raw_backtrace","caml_convert_raw_backtrace_slot","caml_copysign_float","caml_cosh_float","fs_node_supported","make_path_is_absolute","posix","win32","splitDeviceRe","result","device","isUnc","Boolean","sep","path_is_absolute","caml_trailing_slash","caml_current_dir","caml_make_path","comp0","ncomp","caml_get_root","caml_root","jsoo_mount_point","resolve_fs_device","caml_create_file","caml_create_string","caml_custom_event_index","caml_decompress_input","caml_div","caml_domain_dls","caml_domain_dls_get","unit","caml_domain_dls_set","caml_domain_id","caml_ml_mutex_unlock","caml_domain_latest_idx","caml_domain_spawn","mutex","caml_ephe_data_offset","caml_ephe_key_offset","caml_ephe_unset_data","caml_ephe_set_data","caml_ephe_blit_data","caml_ephe_blit_key","caml_ephe_check_data","caml_ephe_check_key","weak","caml_weak_create","caml_ephe_create","caml_ephe_get_data","caml_obj_dup","caml_ephe_get_data_copy","caml_ephe_get_key","caml_ephe_get_key_copy","z","caml_ephe_set_key","Object","caml_ephe_unset_key","count","caml_equal","caml_erf_float","a3","a4","a5","caml_erfc_float","caml_eventlog_pause","caml_eventlog_resume","caml_executable_name","caml_exp2_float","caml_expm1_float","caml_is_special_exception","caml_format_exception","bucket","start","caml_fatal_uncaught_exception","handler","at_exit","caml_fill_bytes","caml_final_register","all_finalizers","caml_final_register_called_without_value","cb","caml_final_release","caml_finish_formatting","rawbuffer","caml_float_compare","caml_float_of_bytes","caml_float_of_string","m3","mantissa","parseInt","exponent","caml_floatarray_blit","caml_floatarray_create","caml_fma_float","SPLIT","MIN_VALUE","EPSILON","C","A","B","multiply","at","ahi","alo","bt","bhi","blo","adjust","scale","xs","ys","zs","xy","u","fs","caml_parse_format","fmt","caml_format_float","toFixed","dp","prec","caml_format_int","caml_oo_last_id","caml_fresh_oo_id","caml_frexp_float","neg","jsoo_create_file","caml_fs_init","tmp","caml_gc_compaction","caml_gc_counters","caml_gc_full_major","caml_gc_get","caml_gc_huge_fallback_count","caml_gc_major","caml_gc_major_slice","work","caml_gc_minor","caml_gc_minor_words","caml_gc_quick_stat","caml_gc_set","_control","caml_gc_stat","caml_get_continuation_callstack","caml_get_current_callstack","caml_get_exception_backtrace","caml_get_exception_raw_backtrace","caml_get_global_data","caml_get_major_bucket","caml_get_major_credit","caml_get_minor_free","caml_method_cache","caml_get_public_method","obj","cacheid","meths","li","caml_gr_arc_aux","cx","cy","ry","rx","rot","xPos","yPos","xPos_prev","yPos_prev","space","delta","caml_gr_state","caml_gr_state_get","caml_gr_blit_image","im2","caml_gr_clear_graph","caml_gr_close_graph","caml_gr_close_subwindow","caml_gr_create_image","caml_gr_current_x","caml_gr_current_y","caml_gr_display_mode","caml_gr_doc_of_state","state","caml_gr_draw_arc","caml_gr_draw_str","dx","caml_gr_draw_char","caml_gr_draw_image","canvas","document","image","caml_gr_draw_rect","caml_gr_draw_string","caml_gr_dump_image","caml_gr_fill_arc","caml_gr_fill_poly","ar","caml_gr_fill_rect","caml_gr_lineto","caml_gr_make_image","caml_gr_moveto","caml_gr_set_window_title","jsname","caml_gr_set_line_width","caml_gr_set_text_size","caml_gr_set_font","caml_gr_set_color","color","convert","number","c_str","caml_gr_resize_window","caml_gr_state_init","caml_gr_state_set","caml_gr_state_create","context","caml_gr_open_graph","info","get","specs","status","win","doc","title","body","caml_gr_open_subwindow","caml_gr_plot","caml_gr_point_color","caml_gr_remember_mode","caml_gr_sigio_handler","caml_gr_sigio_signal","caml_gr_size_x","caml_gr_size_y","caml_gr_synchronize","caml_gr_text_size","txt","caml_gr_wait_event","_evl","caml_gr_window_id","caml_greaterequal","caml_greaterthan","caml_hash_mix_jsbytes","caml_hash_mix_string","caml_hash_mix_bytes_arr","caml_ml_bytes_content","caml_hash_mix_bytes","caml_hash_mix_final","caml_hash","limit","seed","queue","rd","wr","caml_hash_mix_bigstring","num_digits_nat","caml_hash_nat","caml_hexstring_of_float","style","exp_sign","sign_str","cst","x_str","idx","caml_hypot_float","caml_marshal_header_size","caml_refill","str_a","nread","caml_raise_end_of_file","caml_marshal_data_size","readvlq","overflow","n7","header_len","data_len","caml_input_value_from_reader","magic","compressed","uncompressed_data_len","num_objects","_size_32","_size_64","intern_obj_table","obj_counter","intern_rec","header","ops","expected_size","old_pos","caml_string_of_bytes","caml_input_value_from_bytes","caml_input_value","block","caml_input_value_from_string","caml_input_value_to_outside_heap","caml_install_signal_handler","caml_int32_bswap","caml_int64_add","caml_int64_and","caml_int64_bswap","caml_int64_div","caml_int64_is_zero","caml_int64_of_int32","caml_int64_to_int32","caml_int64_is_negative","caml_int64_neg","caml_int64_format","wbase","cvtbl","caml_int64_mod","caml_int64_mul","caml_int64_of_float","caml_int64_ult","caml_parse_sign_and_base","base","caml_parse_digit","caml_int64_of_string","base64","threshold","caml_int64_or","caml_int64_shift_left","caml_int64_shift_right","caml_int64_shift_right_unsigned","caml_int64_sub","caml_int64_to_float","caml_int64_xor","caml_int_of_string","caml_is_js","caml_is_printable","caml_js_call","caml_js_delete","caml_js_equals","caml_js_error_of_exception","caml_js_error_option_of_exception","caml_js_eval_string","eval","caml_js_expr","caml_js_from_bool","caml_js_from_float","caml_js_from_string","caml_js_fun_call","caml_js_function_arity","caml_js_get","caml_js_get_console","caml_js_html_entities","entity","temp","caml_js_regexps","caml_js_html_escape","caml_js_instanceof","caml_js_meth_call","caml_js_new","F","caml_js_object","caml_js_on_ie","ua","caml_js_pure_expr","caml_js_set","caml_js_strict_equals","caml_js_to_array","caml_js_to_bool","caml_js_to_byte_string","caml_js_to_float","caml_js_to_int32","caml_js_to_string","caml_js_typeof","caml_js_var","caml_js_wrap_callback","Function","caml_js_wrap_callback_arguments","caml_js_wrap_callback_strict","arity","caml_js_wrap_callback_unsafe","caml_js_wrap_meth_callback","caml_js_wrap_meth_callback_arguments","caml_js_wrap_meth_callback_strict","caml_js_wrap_meth_callback_unsafe","caml_jsoo_flags_effects","caml_jsoo_flags_use_js_string","caml_lazy_make_forward","caml_obj_tag","caml_lazy_read_result","caml_obj_update_tag","caml_lazy_reset_to_lazy","caml_lazy_update_to_forcing","caml_lazy_update_to_forward","caml_ldexp_float","caml_lessequal","caml_lessthan","caml_lex_array","caml_lex_engine","tbl","start_state","lexbuf","lex_buffer","lex_buffer_len","lex_start_pos","lex_curr_pos","lex_last_pos","lex_last_action","lex_eof_reached","lex_base","lex_backtrk","lex_default","lex_trans","lex_check","backtrk","caml_list_mount_point","prev","caml_list_of_js_array","caml_list_to_js_array","caml_log10_float","caml_log1p_float","caml_log2_float","caml_new_string","caml_lxm_next","shift_l","shift_r","or","xor","rotl","set","M","daba","q0","q1","st","x0","x1","caml_make_float_vect","caml_make_vect","init","caml_marshal_constants","caml_maybe_print_stats","caml_md5_bytes","caml_ml_input_block","avail","caml_md5_chan","toread","caml_md5_string","caml_memprof_discard","caml_memprof_set","caml_memprof_start","rate","stack_size","tracker","caml_memprof_stop","caml_ml_channel_redirect","captured","into","to_restore","new_","caml_ml_channel_restore","caml_ml_channel_size","caml_ml_channel_size_64","caml_sys_fds","caml_sys_close","caml_ml_flush","caml_ml_close_channel","caml_ml_condition_broadcast","caml_ml_condition_new","caml_ml_condition_signal","caml_ml_condition_wait","mutext","caml_ml_debug_info_status","caml_ml_domain_cpu_relax","caml_ml_domain_id","caml_ml_domain_set_name","_name","caml_ml_domain_unique_token_","caml_ml_domain_unique_token","caml_runtime_warnings","caml_ml_enable_runtime_warnings","bool","caml_ml_input","caml_ml_input_bigarray","caml_ml_input_char","caml_ml_input_int","caml_ml_input_scan_line","prev_max","caml_ml_is_buffered","caml_ml_mutex_lock","caml_ml_mutex_new","caml_ml_mutex_try_lock","caml_sys_open_for_node","fd2","caml_sys_open_internal","caml_sys_open","_perms","caml_ml_open_descriptor_in","refill","channel","caml_ml_open_descriptor_out","buffered","caml_ml_out_channels_list","caml_ml_output_ta","caml_ml_output_bytes","caml_ml_output","caml_ml_output_bigarray","caml_ml_output_char","caml_ml_output_int","caml_pos_in","caml_ml_pos_in","caml_ml_pos_in_64","caml_pos_out","caml_ml_pos_out","caml_ml_pos_out_64","caml_ml_runtime_events_pause","caml_ml_runtime_events_resume","caml_ml_runtime_events_start","caml_ml_runtime_warnings_enabled","caml_seek_in","caml_ml_seek_in","caml_ml_seek_in_64","caml_seek_out","caml_ml_seek_out","caml_ml_seek_out_64","caml_ml_set_binary_mode","caml_ml_set_buffered","caml_ml_set_channel_name","caml_ml_set_channel_output","caml_ml_set_channel_refill","caml_mod","caml_modf_float","caml_mount_autoload","caml_lex_run_mem","mem","curr_pos","caml_lex_run_tag","caml_new_lex_engine","lex_mem","lex_base_code","lex_backtrk_code","lex_default_code","lex_trans_code","lex_check_code","lex_code","pc_off","pstate","base_code","caml_nextafter_float","bits","one","caml_notequal","caml_obj_add_offset","caml_obj_block","caml_obj_compare_and_swap","caml_obj_is_block","caml_obj_is_shared","caml_obj_make_forward","caml_obj_raw_field","caml_obj_reachable_words","caml_obj_set_raw_field","caml_obj_set_tag","caml_obj_truncate","caml_obj_with_tag","caml_ojs_new_arr","caml_output_val","Writer","value","no_sharing","closures","memo","existing_offset","extern_rec","sz_32_64","header_pos","type_of_v","caml_output_value_to_string","caml_output_value","caml_output_value_to_buffer","caml_output_value_to_bytes","caml_parser_trace","caml_parse_engine","tables","env","cmd","ERRCODE","loop","testshift","shift","shift_recover","reduce","READ_TOKEN","RAISE_PARSE_ERROR","GROW_STACKS_1","GROW_STACKS_2","COMPUTE_SEMANTIC_ACTION","CALL_ERROR_FUNCTION","env_s_stack","env_v_stack","env_symb_start_stack","env_symb_end_stack","env_stacksize","env_stackbase","env_curr_char","env_lval","env_symb_start","env_symb_end","env_asp","env_rule_len","env_rule_number","env_sp","env_state","env_errflag","tbl_transl_const","tbl_transl_block","tbl_lhs","tbl_len","tbl_defred","tbl_dgoto","tbl_sindex","tbl_rindex","tbl_gindex","tbl_tablesize","tbl_table","tbl_check","tbl_names_const","tbl_names_block","log","token_name","names","print_token","tok","token","n1","n2","state1","sp","errflag","asp","caml_pure_js_expr","caml_raise_not_a_dir","caml_raise_not_found","caml_raw_backtrace_length","caml_raw_backtrace_next_slot","caml_raw_backtrace_slot","caml_read_file_content","caml_recommended_domain_count","caml_record_backtrace","caml_register_channel_for_spacetime","_channel","caml_register_global","name_opt","nid","caml_register_named_value","caml_restore_raw_backtrace","caml_round_float","caml_runtime_events_create_cursor","caml_runtime_events_free_cursor","cursor","caml_runtime_events_read_poll","callbacks","caml_runtime_events_user_register","event_name","event_tag","event_type","caml_runtime_events_user_resolve","caml_runtime_events_user_write","event","event_content","caml_runtime_parameters","caml_runtime_variant","caml_set_oo_id","caml_set_parser_trace","oldflag","caml_set_static_env","caml_signbit_float","caml_sinh_float","caml_spacetime_enabled","caml_spacetime_only_works_for_native_code","caml_str_initialize","caml_string_bound_error","caml_string_concat","caml_string_equal","caml_string_get","caml_string_get16","caml_string_get32","caml_string_get64","caml_string_lessequal","caml_string_greaterequal","caml_string_lessthan","caml_string_greaterthan","caml_string_hash","caml_string_notequal","caml_string_set","caml_string_set16","caml_string_set32","caml_string_set64","caml_string_unsafe_set","caml_sys_argv","caml_sys_chdir","dir","caml_sys_const_backend_type","caml_sys_const_big_endian","caml_sys_const_int_size","caml_sys_const_max_wosize","caml_sys_const_naked_pointers_checked","os_type","caml_sys_const_ostype_cygwin","caml_sys_const_ostype_unix","caml_sys_const_ostype_win32","caml_sys_const_word_size","caml_sys_executable_name","caml_sys_exit","caml_sys_file_exists","caml_sys_get_argv","caml_sys_get_config","caml_sys_getcwd","caml_sys_getenv","caml_sys_is_directory","caml_sys_is_regular_file","caml_sys_isatty","_chan","caml_sys_mkdir","perm","caml_sys_modify_argv","caml_sys_random_seed","now","Date","caml_sys_read_directory","caml_sys_remove","caml_sys_rename","o_root","n_root","caml_sys_rmdir","caml_sys_system_command","child_process","caml_initial_time","caml_sys_time","caml_sys_time_include_children","caml_sys_unsafe_getenv","caml_tanh_float","caml_to_js_string","caml_trampoline","caml_trampoline_return","caml_trunc_float","caml_unix_cleanup","caml_unix_closedir","dir_handle","caml_unix_filedescr_of_fd","caml_unix_findclose","caml_unix_opendir","caml_unix_readdir","caml_unix_findfirst","path_js","first_entry","caml_unix_findnext","caml_unix_getpwuid","caml_unix_gettimeofday","caml_unix_getuid","caml_unix_gmtime","d_num","januaryfirst","doy","caml_unix_has_symlink","caml_unix_inet_addr_of_string","caml_unix_isatty","fileDescriptor","tty","caml_unix_localtime","jan","jul","stdTimezoneOffset","caml_unix_lstat","caml_unix_lstat_64","caml_unix_mkdir","caml_unix_mktime","tm","tm2","caml_unix_readlink","caml_unix_rewinddir","new_dir_handle","caml_unix_rmdir","caml_unix_startup","caml_unix_stat","caml_unix_stat_64","caml_unix_symlink","src_root","dst_root","caml_unix_time","caml_unix_unlink","caml_unmount","caml_update_dummy","caml_weak_set","caml_wrap_exception","caml_xmlhttprequest_create","compare_digits_nat","compare_nat","compare_nat_real","complement_nat","create_nat","decr_nat","borrow","deserialize_nat","div_helper","div_digit_nat","natq","ofsq","natr","ofsr","rem","num_leading_zero_bits_in_digit","shift_left_nat","nbits","wrap","shift_right_nat","set_to_zero_nat","nat_of_array","mult_digit_nat","nat3","ofs3","x2","x3","sub_nat","div_nat","quo","serialize_nat","initialize_nat","is_digit_int","is_digit_odd","is_digit_zero","jsoo_create_file_extern","jsoo_effect_not_supported","land_digit_nat","length_nat","lor_digit_nat","lxor_digit_nat","mult_nat","len3","nth_digit_nat","nth_digit_nat_native","re_match","re_word_letters","opcodes","is_word_letter","in_bitset","re_match_impl","partial","prog","cpool","normtable","numgroups","numregisters","startchars","pc","quit","groups","re_register","backtrack","item","push","accept","prefix_match","op","sarg","uarg","group","Error","re_partial_match","re_replacement_text","repl","orig","cur","end","re_search_backward","re_search_forward","re_string_match","set_digit_nat","digit","set_digit_nat_native","square_nat","caml_setup_uncaught_exception_handler","origin","erase_rel","rest","rest$0","rest$1","rest$2","rest$3","rest$4","rest$5","rest$6","rest$7","ty","rest$8","ty1","rest$9","rest$10","rest$11","rest$12","rest$13","concat_fmtty","fmtty1","fmtty2","ty2","concat_fmt","fmt1","fmt2","pad","pad$0","prec","pad$1","iconv","prec$0","pad$2","iconv$0","prec$1","pad$3","iconv$1","prec$2","pad$4","iconv$2","prec$3","pad$5","fconv","pad$6","str","chr","fmtty","pad$7","fmtty$0","pad$8","rest$14","rest$15","rest$16","fmting_lit","rest$17","fmting_gen","rest$18","rest$19","char_set","width_opt","rest$20","counter","rest$21","rest$22","ign","rest$23","f","arity","make","v","get","r","set","exchange","cur","compare_and_set","seen","fetch_and_add","n","incr","decr","failwith","s","invalid_arg","min","x","y","max","abs","lnot","infinity","neg_infinity","nan","max_float","min_float","epsilon_float","symbol_concat","char_of_int","string_of_bool","b","bool_of_string","bool_of_string_opt","string_of_int","int_of_string_opt","valid_float_lexem","s1","l","i","i$0","string_of_float","float_of_string_opt","symbol","l1","l2","tl","hd","stdin","stdout","stderr","open_out_gen","mode","perm","name","c","open_out","open_out_bin","flush_all","a","output_bytes","oc","output_string","output","ofs","len","output_substring","output_value","chan","close_out","close_out_noerr","open_in_gen","open_in","open_in_bin","input","ic","unsafe_really_input","ofs$0","len$0","len$1","ofs$1","really_input","really_input_string","input_line","build_result","buf","pos$0","accu","beg","accu$0","res","close_in_noerr","print_char","print_string","print_bytes","print_int","print_float","print_endline","print_newline","prerr_char","prerr_string","prerr_bytes","prerr_int","prerr_float","prerr_endline","prerr_newline","read_line","read_int","read_int_opt","read_float","read_float_opt","string_of_format","symbol$0","str2","str1","s2","exit_function","at_exit","f_yet_to_run","old_exit","f_yet_to_run$0","old_exit$0","new_exit","success","do_at_exit","exit","retcode","max_int","min_int","flush","output_char","output_byte","output_binary_int","seek_out","pos_out","out_channel_length","set_binary_mode_out","input_char","input_byte","input_binary_int","input_value","seek_in","pos_in","in_channel_length","close_in","set_binary_mode_in","empty","return$0","cons","next","append","seq1","seq2","map","seq","filter_map","seq$0","filter","concat","flat_map","fold_left","acc","acc$0","acc$1","iter","unfold","u","u$0","some","value","o","default$0","bind","join","fold","none","is_none","is_some","equal","eq","o0","o1","v1","v0","compare","cmp","to_result","to_list","to_seq","left","right","is_left","is_right","find_left","find_right","map_left","e","map_right","v$0","e1","e2","v2","v1$0","v2$0","ok","error","get_ok","get_error","map_error","iter_error","is_ok","is_error","r0","r1","e0","to_option","to_float","to_string","escaped","s$0","lowercase","uppercase","lowercase_ascii","uppercase_ascii","c1","c2","err_no_pred","err_no_succ","lo_bound","hi_bound","succ","pred","is_valid","of_int","is_char","of_char","to_char","unsafe_to_char","hash","length","l$0","nth","n$0","l$1","n$1","nth_opt","rev_append","l1$0","l2$0","l1$1","l2$1","rev","init_aux","rev_init_threshold","init","flatten","mapi","rev_map","iteri","accu$1","fold_right","map2","a2","a1","rev_map2","iter2","fold_left2","fold_right2","for_all","p","exists","for_all2","exists2","mem","memq","assoc","assoc_opt","assq","assq_opt","mem_assoc","mem_assq","remove_assoc","pair","remove_assq","find","find_opt","find_map","result","find_all","filteri","concat_map","xs","fold_left_map","l_accu","x$0","partition","yes","no","partition_map","split","ry","rx","combine","merge","t2","h2","t1","h1","stable_sort","sort","x2","x1","tl$1","x3","x2$0","x1$0","n1","n2","rev_sort","tl$0","sort_uniq","c$0","c$1","c$2","c$3","c$4","c$5","c$6","accu$2","compare_lengths","compare_length_with","aux","tail","of_seq","direct","depth","lognot","copy","of_string","sub","sub_string","extend","dstoff","srcoff","cpylen","fill","blit","ofs1","ofs2","blit_string","sep","seplen","dst","pos","hd$0","cat","is_space","trim","j","apply1","capitalize_ascii","uncapitalize_ascii","starts_with","prefix","len_s","len_pre","ends_with","suffix","len_suf","diff","index_rec","lim","i$1","index","index_rec_opt","index_opt","index_from","index_from_opt","rindex_rec","rindex","rindex_from","rindex_rec_opt","rindex_opt","rindex_from_opt","contains_from","contains","rcontains_from","split_on_char","capitalize","uncapitalize","to_seqi","new_len","new_buf","get_int8","get_uint16_le","get_uint16_be","get_int16_ne","get_int16_le","get_int16_be","get_int32_le","get_int32_be","get_int64_le","get_int64_be","set_int16_le","set_int16_be","set_int32_le","set_int32_be","set_int64_le","set_int64_be","set_uint8","set_uint16_ne","bts","bos","of_bytes","to_bytes","g","to_buffer","buff","flags","data_size","total_size","from_bytes","from_string","is_block","double_field","set_double_field","marshal","obj","unmarshal","custom_tag","info","start_env","of_val","slot","id","extension_constructor","extension_name","extension_id","max_ephe_length","create","raise_if_invalid_offset","msg","get_key","get_key_copy","set_key","unset_key","check_key","blit_key","o2","make_float","make_matrix","sx","sy","la","lb","res$0","list_length","t","of_list","input_array","elt","output_array","elt$0","acc$2","b0","a0","bi","ai","na","nb","maxson","i31","i$6","e$1","i$4","e$0","i$5","j$0","i$2","i$3","father","src1ofs","src1len","src2","src2ofs","src2len","dstofs","src1r","src2r","s2$1","s1$1","i1","i2","d","i2$0","d$0","s2$0","i1$0","d$1","s1$0","isortto","srcofs","sortto","is_finite","is_infinite","is_nan","epsilon","of_string_opt","is_integer","min_max","min_num","max_num","min_max_num","unsafe_fill","check","hlen","src","sofs","dofs","h","mem_ieee","map_to_array","map_from_array","zero","one","minus_one","max_int$0","unsigned_to_int","unsigned_compare","m","unsigned_div","q","unsigned_rem","size","dummy_pos","zero_pos","engine","tbl","state","new_engine","from_function","opt","read_fun","sth","with_positions","aux_buffer","lexbuf","read","newlen","newbuf","from_channel","set_position","position","set_filename","fname","lexeme","sub_lexeme","sub_lexeme_opt","sub_lexeme_char","sub_lexeme_char_opt","lexeme_char","lexeme_start","lexeme_end","lexeme_start_p","lexeme_end_p","new_line","lcp","flush_input","env","grow_stacks","oldsize","newsize","new_s","new_v","new_start","new_end","clear_parser","current_lookahead_fun","yyparse","tables","start","lexer","init_asp","init_sp","init_stackbase","init_state","init_curr_char","init_lval","init_errflag","cmd","arg","arg$0","action","exn$0","exn","curr_char","tok","peek_val","symbol_start_pos","st","en","symbol_end_pos","rhs_start_pos","rhs_end_pos","symbol_start","symbol_end","rhs_start","rhs_end","is_current_lookahead","parse_error","height","hl","h$0","hr","bal","lr","lv","ll","lrr","lrv","lrl","rr","rv","rl","rlr","rlv","rll","add","singleton","add_min_element","add_max_element","rh","lh","min_elt","min_elt_opt","max_elt","max_elt_opt","remove_min_elt","r$0","pres","pres$0","is_empty","remove","union","r2","r2$0","r1$0","inter","split_bis","disjoint","cons_enum","e2$2","e1$2","e2$0","e1$0","e2$1","e1$1","subset","pv","lf","lt","rf","rt","cardinal","elements_aux","elements","find_first","v0$1","v0$0","find_first_opt","find_last","find_last_opt","try_join","v$1","x0","l$3","l$4","x0$0","l$5","x0$1","nl","mid","l$2","x4","add_seq","seq_of_enum","snoc_enum","rev_seq_of_enum","to_rev_seq","to_seq_from","low","ld","lrd","rd","rld","data","d0$1","d0","d0$0","min_binding","min_binding_opt","max_binding","max_binding_opt","remove_min_binding","update","data$0","m$0","add_min_binding","k","add_max_binding","concat_or_join","d1","d2","d2$0","d1$0","d2$1","d1$1","pvd","fvd","m1","m2","bindings_aux","bindings","clear","push","pop","pop_opt","top","top_opt","cell","match","peek","content","peek_opt","take","take_opt","cell$0","q_res","prev","prev$0","transfer","q1","q2","raise_undefined","force_lazy_block","blk","closure","force_val_lazy_block","force","lzv","force_val","from_fun","from_val","is_val","map_val","count","fill_buff","get_data","d11","a$0","a$1","peek_data","junk_data","junk","nget_data","al","npeek","strm","from","of_channel","iapp","icons","ising","lapp","lcons","lsing","slazy","dump","dump_data","contents","reset","resize","more","old_pos","old_len","new_buffer","add_char","add_utf_8_uchar","pos$1","add_utf_16be_uchar","u$1","hi","lo","add_utf_16le_uchar","add_substring","offset","new_position","add_subbytes","add_string","add_bytes","add_buffer","bs","add_channel","to_read$1","already_read","to_read","already_read$0","to_read$0","output_buffer","add_substitute","lim$1","previous","previous$0","start$0","opening","lim$0","stop$0","k$2","closing","stop","k$0","k$1","next_i","ident","i$7","i$8","truncate","add_int8","add_int16_ne","add_int32_ne","add_int64_ne","add_int16_le","add_int16_be","add_int32_le","add_int32_be","add_int64_le","add_int64_be","sub_format","formatting_lit","create_char_set","add_in_char_set","str_ind","mask","freeze_char_set","rev_char_set","char_set$0","is_in_char_set","pad_of_pad_opt","pad_opt","width","param_format_of_ignored_format","fmt","pad_opt$0","pad_opt$1","pad_opt$2","pad_opt$3","pad_opt$4","prec_opt","pad_opt$5","ndec","pad_opt$6","pad_opt$7","pad_opt$8","default_float_precision","buffer_create","init_size","buffer_check_size","overhead","min_len","new_str","buffer_add_char","buffer_add_string","str_len","buffer_contents","char_of_iconv","char_of_fconv","cF","bprint_padty","padty","bprint_ignored_flag","ign_flag","bprint_pad_opt","bprint_padding","padty$0","bprint_precision","bprint_iconv_flag","bprint_altint_fmt","bprint_fconv_flag","string_of_formatting_lit","str$0","bprint_char_literal","bprint_string_literal","bprint_fmtty","fmtty$1","fmtty$2","fmtty$3","fmtty$4","fmtty$5","fmtty$6","fmtty$7","fmtty$8","fmtty$9","sub_fmtty","fmtty$10","sub_fmtty$0","fmtty$11","fmtty$12","fmtty$13","fmtty$14","fmtty$15","int_of_custom_arity","string_of_fmt","fmtiter","fmt$0","ign_flag$0","str$1","set$0","is_alone","after","before","j$1","fmt$1","symm","fmtty_rel_det","de","ed","af","fa","de$0","ed$0","af$0","fa$0","de$1","ed$1","af$1","fa$1","de$2","ed$2","af$2","fa$2","de$3","ed$3","af$3","fa$3","de$4","ed$4","af$4","fa$4","de$5","ed$5","af$5","fa$5","de$6","ed$6","af$6","fa$6","de$7","ed$7","af$7","fa$7","de$8","ed$8","af$8","fa$8","trans","jd","dj","ga","ag","de$9","ed$9","af$9","fa$9","de$10","ed$10","af$10","fa$10","de$11","ed$11","af$11","fa$11","de$12","ed$12","af$12","fa$12","de$13","ed$13","af$13","fa$13","rest1","rest2","rest1$0","rest2$0","rest1$1","rest2$1","rest1$2","rest2$2","rest1$3","rest2$3","rest1$4","rest2$4","rest1$5","rest2$5","rest1$6","rest2$6","rest1$7","ty1$0","rest2$7","ty2$0","rest1$8","ty12","ty11","rest2$8","ty22","ty21","f4","f2","rest1$9","rest2$9","rest1$10","rest2$10","rest1$11","rest2$11","rest1$12","rest2$12","rest1$13","rest2$13","fmtty_of_fmt","fmtty_of_padding_fmtty","ty_rest","prec_ty","fmtty_of_precision_fmtty","ty_rest$0","prec_ty$0","ty_rest$1","prec_ty$1","ty_rest$2","prec_ty$2","ty_rest$3","prec_ty$3","ty$0","formatting_gen","fmtty_of_custom","arity$0","type_padding","w","type_padprec","type_format","type_format_gen","fmtty0","fmtty_rest","fmt_rest","fmtty_rest$0","fmt_rest$0","fmt_rest$1","fmtty_rest$1","fmt$2","fmt_rest$2","fmtty_rest$2","fmt$3","fmt_rest$3","fmtty_rest$3","fmt$4","fmt_rest$4","fmtty_rest$4","fmt$5","fmt_rest$5","fmtty_rest$5","prec$4","fmt$6","fmt_rest$6","prec$5","pad$9","pad$10","fmtty_rest$6","prec$6","fmt$7","fmt_rest$7","prec$7","pad$11","pad$12","fmtty_rest$7","prec$8","fmt$8","fmt_rest$8","pad$13","pad$14","fmtty_rest$8","fmt$9","fmt_rest$9","fmt$10","fmt_rest$10","fmt$11","fmt_rest$11","fmt$12","fmtty_rest$9","fmt_rest$12","fmt$13","fmtty_rest$10","sub_fmtty1","fmt_rest$13","sub_fmtty$1","fmt$14","fmtty_rest$11","fmt_rest$14","fmt$15","fmtty_rest$12","fmt_rest$15","fmt$16","fmt_rest$16","fmtty$16","fmt$17","fmt_rest$17","fmtty3","fmt3","fmt1$0","fmtty2$0","fmt2$0","fmtty3$0","fmt3$0","fmtty_rest$13","fmt_rest$18","fmtty$17","fmt$18","fmtty_rest$14","fmt_rest$19","fmtty$18","fmt$19","fmtty_rest$15","fmt_rest$20","fmtty$19","fmt$20","type_ignored_param_one","sub_fmtty$2","sub_fmtty$3","type_ignored_format_substituti","fmtty$21","fmt$22","sub_fmtty$4","fmtty_rest$16","fmtty$20","fmt$21","sub_fmtty_rest","sub_fmtty_rest$0","sub_fmtty_rest$1","sub_fmtty_rest$2","sub_fmtty_rest$3","sub_fmtty_rest$4","sub_fmtty_rest$5","sub_fmtty_rest$6","sub_fmtty_rest$7","sub_fmtty_rest$8","sub_fmtty_rest$9","sub_fmtty_rest$10","sub_fmtty_rest$11","sub_fmtty_rest$12","sub_fmtty_rest$13","sub_fmtty_rest$14","sub2_fmtty","sub_fmtty_rest$15","sub2_fmtty$0","sub_fmtty_rest$16","sub2_fmtty$1","sub1_fmtty","sub_fmtty_rest$17","sub2_fmtty$2","sub1_fmtty$0","sub_fmtty_rest$18","sub_fmtty_rest$19","sub_fmtty_rest$20","sub_fmtty_rest$21","sub_fmtty_rest$22","sub_fmtty_rest$23","sub_fmtty_rest$24","sub_fmtty_rest$25","sub_fmtty_rest$26","recast","fix_padding","width$0","fix_int_precision","res$1","string_to_caml_string","format_of_fconv","symb","transform_int_alt","digits","put","convert_int","convert_int32","convert_nativeint","convert_int64","convert_float","hex","sign","caml_special_val","string_of_fmtty","make_printf$0","new_acc","make_printf","make_padding","make_int_padding_precision","p$0","p$1","acc$3","acc$4","kacc","make_ignored_param$0","make_custom$0","make_invalid_arg","make_from_fmtty$0","make_ignored_param","make_from_fmtty","make_custom","make_iprintf$0","make_iprintf","x$1","x$2","x$3","x$4","x$5","x$6","x$7","x$8","fn_of_padding_precision","x$9","x$10","x$11","x$12","x$13","x$14","x$15","x$16","koc","rest$24","rest$25","x$17","rest$26","x$18","rest$27","x$19","rest$28","rest$29","fn_of_custom_arity$0","fn_of_custom_arity","output_acc","p$3","p$4","p$5","p$2","bufput_acc","strput_acc","failwith_message","open_box_of_string","invalid_box","parse_spaces","wstart","wend","box_name","nstart","nend","indent","exp_end","box_type","make_padding_fmt_ebb","make_padprec_fmt_ebb","fmt_ebb_of_string","legacy_behavior","flag","legacy_behavior$0","invalid_format_message","invalid_format_without","expected_character","expected","parse","lit_start","end_ind","add_literal","str_ind$1","str_ind$2","parse_flags","str_ind$0","parse_tag","str_ind$3","str_ind_1","parse_integer","str_ind_2","str_ind_3","formatting_lit$0","next_ind","str_ind_4","str_ind_5","str_ind$4","str_ind_1$0","str_ind_2$0","str_ind_3$0","s$1","formatting_lit$1","next_ind$0","pct_ind","minus","plus","space","set_flag","str_ind$5","space$0","hash$0","plus$0","minus$0","zero$0","incompatible_flag","parse_positive","new_ind","parse_after_padding","parse_conversion","parse_literal","parse_after_precision","symb$0","parse_conv","padprec","plus_used","hash_used","space_used","ign_used","pad_used","prec_used","get_plus","get_hash","get_space","get_ign","get_pad","get_prec","get_padprec","get_int_pad","check_no_0","opt_of_pad","width$1","get_pad_opt","get_padprec_opt","fmt_result","sub_end","search_subformat_end","sub_fmt","ignored$2","counter$0","ignored$6","ignored$7","add_range","fail_single_percent","parse_char_set_content","parse_char_set_after_char$0","parse_char_set_after_char","reverse","char_set$1","ignored$9","char_format","fmt_rest$21","fmt_rest$22","fmt_rest$23","ignored$10","fmt_rest$24","fmt_rest$25","sub_end$0","sub_fmt$0","fmt_rest$26","ignored$11","ignored$3","ignored$5","compute_int_conv","ignored$8","space$1","hash$1","plus$2","kind","ignored$4","ignored","ignored$0","ignored$1","plus$1","ign$0","is_open_tag","ind","sub_str","sub_format$0","formatting$0","formatting","sub_end$1","sub_end$2","str_ind$6","str_ind$7","option","subfmt","format_of_string_fmtty","format_of_string_format","kfprintf","kbprintf","ikfprintf","fprintf","bprintf","ifprintf","ibprintf","printf","eprintf","ksprintf","sprintf","assoc3","y2","y1","make_symlist","help_action","add_help","speclist","add1","add2","usage_b","errmsg","doc","spec","key","usage_string","usage","current","parse_and_expand_argv_dynamic_","allow_expand","argv","anonfun","initpos","convert_error","progname","follow$0","keyword","follow$2","no_arg","get_arg","consume_arg","treat_action","no_arg$0","f$0","get_arg$0","consume_arg$0","f$1","r$1","f$2","arg$1","r$2","arg$2","f$3","arg$3","r$3","arg$4","specs","treat_action$0","f$4","arg$5","f$5","f$6","f$7","arg$6","newarg","parse_and_expand_argv_dynamic","parse_argv_dynamic","current$0","parse_argv","msg$0","msg$1","parse_dynamic","parse_expand","second_word","loop","max_arg_len","kwd","replace_leading_tab","align","limit","completed","ksd","cutcol$0","spaces$0","spec$0","cutcol","kwd_len","spaces","read_aux","file","words","stash","word","word$0","read_arg","read_arg0","write_aux","args","write_arg","write_arg0","locfmt","printers","field","other_fields","use_printers","to_string_default","char$0","line","char$1","line$0","file$0","char$2","line$1","file$1","constructor","print","fct","catch$0","raw_backtrace_entries","bt","convert_raw_backtrace","format_backtrace_slot","is_raise","print_raw_backtrace","outchan","raw_backtrace","backtrace","print_backtrace","raw_backtrace_to_string","backtrace_slot_is_raise","param","backtrace_slot_is_inline","backtrace_slot_location","backtrace_slot_defname","backtrace_slots","backtrace_slots_of_raw_entry","entry","raw_backtrace_length","get_backtrace","register_printer","fn","old_printers","new_printers","exn_slot","exn_slot_id","exn_slot_name","errors","default_uncaught_exception_han","status","uncaught_exception_handler","set_uncaught_exception_handler","empty_backtrace","handle_uncaught_exception","debugger_in_use","exn$1","raw_backtrace$0","const$0","flip","negate","protect","finally$0","work","finally_no_exn","work_exn$0","work_exn","work_bt","print_stat","allocated_bytes","ma","pro","mi","create_alarm","delete_alarm","null_tracker","sampling_rate","tracker","callstack_size","string","bytes","substring","subbytes","filename","digest","char_hex","to_hex","from_hex","digit","new_state","assign","st1","st2","full_init","seed","seed$0","make_self_init","bits","curval","newval","newval30","intaux","int$0","bound","full_int","b1","b2","max_int_32","bpos","b3","int32","int64","nativeint","float$0","bool","bits$0","int$1","full_int$0","int32$0","nativeint$0","int64$0","float$1","scale","bool$0","full_init$0","self_init","get_state","set_state","ongoing_traversal","flip_ongoing_traversal","params","randomized_default","randomized","randomize","is_randomized","prng","power_2_above","initial_size","random","copy_bucketlist","key$0","next$0","insert_all_buckets","indexfun","inplace","odata","ndata","nsize","ndata_tail","nidx","match$0","osize","old_trav","filter_map_inplace","b$0","bucket_length","stats","mbl","histo","tbl_data","buck","buck$0","buck$1","to_seq_keys","to_seq_values","key_index","bucket","k1","next1","k2","next2","k3","d3","next3","find_in_bucket","replace","replace_seq","sz","hash_param","seeded_hash","rebuild","get_copy","ar","emptybucket","get_index","create$0","sz$0","sz$1","count_bucket","add_aux","setter","bucket$0","hashes","newsz","newbucket$0","newhashes","hbucket","prev_len","live","j$2","newbucket","oldlen","newt","ob","oi","oh","oi$0","ni","find_or","ifnotfound","find_shadow","iffound","lens","totlen","unknown","pp_enqueue","token","pp_infinity","pp_output_string","pp_output_newline","format_pp_text","text","format_string","break_new_line","real_indent","break_same_line","format_pp_token","size$0","tabs","add_tab","ls","tag_name","marker","breaks","fits","off","box_type$0","off$0","insertion_point","tabs$0","first","head","tab","off$1","insertion_point$0","width$2","box_type$1","tbox","tag_name$0","marker$0","advance_left","pending_count","enqueue_advance","enqueue_string_as","initialize_scan_stack","stack","queue_elem","set_size","left_total","scan_push","elem","pp_open_box_gen","br_ty","pp_close_box","pp_open_stag","pp_close_stag","pp_open_tag","pp_close_tag","pp_set_print_tags","pp_set_mark_tags","pp_get_print_tags","pp_get_mark_tags","pp_set_tags","pp_get_formatter_stag_function","pp_set_formatter_stag_function","pct","pot","mct","mot","pp_rinit","pp_flush_queue","pp_print_as_size","pp_print_as","isize","pp_print_string","pp_print_bytes","pp_print_int","pp_print_float","pp_print_bool","pp_print_char","pp_open_hbox","pp_open_vbox","pp_open_hvbox","pp_open_hovbox","pp_open_box","pp_print_newline","pp_print_flush","pp_force_newline","pp_print_if_newline","pp_print_custom_break","pp_print_break","pp_print_space","pp_print_cut","pp_open_tbox","pp_close_tbox","pp_print_tbreak","pp_print_tab","pp_set_tab","pp_set_max_boxes","pp_get_max_boxes","pp_over_max_boxes","pp_set_ellipsis_text","pp_get_ellipsis_text","pp_limit","pp_set_max_indent","pp_get_max_indent","pp_set_margin","new_max_indent","validate_geometry","margin","max_indent","check_geometry","geometry","pp_get_margin","pp_set_full_geometry","pp_set_geometry","pp_safe_set_geometry","pp_get_geometry","pp_update_geometry","pp_set_formatter_out_functions","pp_get_formatter_out_functions","pp_set_formatter_output_functi","pp_get_formatter_output_functi","display_newline","blank_line","display_blanks","pp_set_formatter_out_channel","default_pp_mark_open_tag","default_pp_mark_close_tag","default_pp_print_open_tag","default_pp_print_close_tag","pp_make_formatter","pp_queue","sys_tok","scan_stack","pp_margin","formatter_of_out_functions","out_funs","make_formatter","ppf","formatter_of_out_channel","formatter_of_buffer","pp_buffer_size","pp_make_buffer","stdbuf","std_formatter","err_formatter","str_formatter","flush_buffer_formatter","flush_str_formatter","make_symbolic_output_buffer","clear_symbolic_output_buffer","sob","get_symbolic_output_buffer","flush_symbolic_output_buffer","items","add_symbolic_output_item","item","formatter_of_symbolic_output_b","open_hbox","open_vbox","open_hvbox","open_hovbox","open_box","close_box","open_tag","close_tag","open_stag","close_stag","print_as","print_bool","print_break","print_cut","print_space","force_newline","print_flush","print_if_newline","open_tbox","close_tbox","print_tbreak","set_tab","print_tab","set_margin","get_margin","set_max_indent","get_max_indent","set_geometry","safe_set_geometry","get_geometry","update_geometry","set_max_boxes","get_max_boxes","over_max_boxes","set_ellipsis_text","get_ellipsis_text","set_formatter_out_channel","set_formatter_out_functions","get_formatter_out_functions","set_formatter_output_functions","get_formatter_output_functions","set_formatter_stag_functions","get_formatter_stag_functions","set_print_tags","get_print_tags","set_mark_tags","get_mark_tags","set_tags","pp_print_list","pp_v","opt$0","pp_sep","opt$1","pp_print_seq","seq$1","seq$2","pp_print_text","pp_print_option","pp_print_result","pp_print_either","compute_tag","tag_acc","output_formatting_lit","bty","p$6","p$7","size$1","p$8","kdprintf","dprintf","kasprintf","asprintf","flush_standard_formatters","pp_set_all_formatter_output_fu","pp_get_all_formatter_output_fu","set_all_formatter_output_funct","get_all_formatter_output_funct","pp_set_formatter_tag_functions","stringify","pp_get_formatter_tag_functions","funs","mark_open_tag","mark_close_tag","print_open_tag","print_close_tag","set_formatter_tag_functions","get_formatter_tag_functions","null_char","next_char","ib","peek_char","checked_peek_char","end_of_input","beginning_of_input","name_of_input","char_count","invalidate_current_char","token_string","token_buffer","ignore_char","store_char","default_token_buffer_size","iname","scan_close_at_end","scan_raise_at_end","from_ic","scan_close_ic","eof","open_in_file","ic$0","memo","memo_from_channel","bad_input","bad_input_escape","bad_token_length","message","bad_hex_float","character_mismatch","ci","check_char","check_this_char","token_char","token_bool","integer_conversion_of_char","token_int_literal","conv","token_float","scan_decimal_digit_star","scan_decimal_digit_plus","scan_digit_plus","basis","digitp","width$3","is_binary_digit","is_octal_digit","is_hexa_digit","scan_sign","scan_optionally_signed_decimal","scan_int_conversion","scan_fractional_part","scan_exponent_part","scan_float","precision","precision$0","check_case_insensitive_string","scan_hex_float","width$4","width$5","width$6","width$10","width$7","width$8","width$9","scan_caml_float_rest","width_precision","frac_width","scan_caml_float","scan_string","stp","hexadecimal_value_of_char","check_next_char","scan_backslash_char","c0","get_digit$0","c1$0","c2$0","get_digit","scan_caml_string","find_stop$0","skip_spaces","find_stop","scan_chars_in_char_set","scan_indic","scan_chars","scanf_bad_input","width_of_pad_opt","stopper_of_formatting_lit","fmting","take_format_readers$0","take_fmtty_format_readers$0","reader","new_k","readers_rest","take_format_readers","take_fmtty_format_readers","make_scanf","readers","scan$0","str_rest","pad_prec_scanf","scan$1","scan$2","scan","scan$3","scan$4","conv$0","scan$5","conv$1","scan$6","conv$2","scan$7","scan$8","fmting_lit$0","stp$0","s$2","str_rest$0","arg_rest","kscanf","ef","exc$0","exc","args$1","args$0","bscanf","ksscanf","sscanf","scanf","bscanf_format","format","sscanf_format","format_from_string","unescaped","kfscanf","fscanf","register","register_exception","o$0","public_method_label","tag","compare$0","compare$1","dummy_table","table_count","dummy_met","initial_object_size","fit_size","new_table","pub_labels","methods","array","new_size","old_size","new_buck","method_count","inst_var_count","new_method","table","get_method_label","label","get_method_labels","names","set_method","element","get_method","arr","narrow","vars","virt_meths","concr_meths","vars$0","virt_meths$0","concr_meths$0","virt_meth_labs","concr_meth_labs","lab","tvars","by_name","by_label","met","hm","widen","saved_vars","saved_hidden_meths","new_variable","to_array","new_methods_variables","meths","vals","meths$0","nmeths","nvals","get_variable","get_variables","add_initializer","create_table","public_methods","tags","init_class","inherits","cla","super$0","nm","make_class","pub_meths","class_init","env_init","make_class_store","init_table","dummy_class","loc","undef","create_object","create_object_opt","obj_0","iter_f","run_initializers","inits","run_initializers_opt","create_object_and_run_initiali","build_path","keys","lookup_tables","root","root_data","tables$0","tables$1","tables_data","new_cache","set_methods","clo","x$20","clo$0","n$38","e$10","n$37","n$36","n$2","n$35","f$20","n$3","f$19","n$34","n$4","f$18","e$9","n$33","n$5","f$17","n$32","f$16","y$0","n$6","f$15","n$31","n$7","f$14","e$8","n$30","n$8","f$13","n$29","n$9","f$12","n$28","f$8","e$2","n$10","f$11","e$7","n$27","f$9","n$11","f$10","n$26","n$12","n$25","n$13","n$24","m$12","n$14","e$3","n$23","e$6","m$11","n$15","m$1","n$22","m$10","m$2","m$9","m$3","n$16","m$8","n$21","m$4","e$4","n$17","m$7","e$5","n$20","m$5","n$18","m$6","n$19","init_mod_block","comps$0","modu","shape","fn$0","comps","init_mod","update_mod_block","cl","update_mod","initial_buffer","buffer","bufpos","reset_buffer","store","newbuffer","get_string","make_lexer","keywords","kwd_table","ident_or_keyword","keyword_or_error","next_token","escape","comment","number","ident2","exponent_part","end_exponent_part","c3","hkey","clean","do_bucket","insert_bucket","container","remove_bucket","hk","new_d","bucket_length_alive","stats_alive","get_data_copy","set_data","unset_data","check_data","blit_data","set_key_data","get_key1","get_key1_copy","set_key1","unset_key1","check_key1","get_key2","get_key2_copy","set_key2","unset_key2","check_key2","blit_key1","blit_key2","blit_key12","get_data$0","get_data_copy$0","set_data$0","unset_data$0","check_data$0","blit_data$0","k2$0","k1$0","equal$0","create$1","get_key$0","get_key_copy$0","set_key$0","unset_key$0","check_key$0","blit_key$0","get_data$1","get_data_copy$1","set_data$1","unset_data$1","check_data$1","blit_data$1","ki","k0","null$0","current_dir_name","parent_dir_name","dir_sep","quotequote","null$1","current_dir_name$0","parent_dir_name$0","dir_sep$0","null$2","current_dir_name$1","parent_dir_name$1","dir_sep$1","generic_basename","is_dir_sep","generic_dirname","is_relative","is_implicit","check_suffix","suff","chop_suffix_opt","len_f","temp_dir_name","quote","quote_command","basename","dirname","is_dir_sep$0","is_relative$0","is_implicit$0","check_suffix$0","chop_suffix_opt$0","temp_dir_name$0","quote$0","loop$0","loop_bs","add_bs","quote_cmd_filename","quote_command$0","drive_and_path","dirname$0","path","drive","dir","basename$0","basename$1","dirname$1","null$3","current_dir_name$2","parent_dir_name$2","dir_sep$2","is_dir_sep$1","is_relative$1","is_implicit$1","check_suffix$1","chop_suffix_opt$1","temp_dir_name$1","quote$1","quote_command$1","basename$2","dirname$2","chop_suffix","extension_len","i0","extension","chop_extension","remove_extension","temp_file_name","temp_dir","rnd","current_temp_dir_name","set_temp_dir_name","get_temp_dir_name","temp_file","open_temp_file","sth$0","perms","sth$1","neg","conj","mul","div","inv","norm2","norm","q$0","polar","sqrt","w$0","exp","log","pow","kind_size_in_bytes","cloop","idx","col","floop","layout","dims","size_in_bytes","size_in_bytes$0","of_value","dim","size_in_bytes$1","slice","init$0","of_array","ba","dim1","dim2","size_in_bytes$2","slice_left","slice_right","init$1","of_array$0","row","create$2","dim3","size_in_bytes$3","slice_left_1","slice_right_1","slice_left_2","slice_right_2","init$2","of_array$1","array0_of_genarray","array1_of_genarray","array2_of_genarray","array3_of_genarray","reshape_0","reshape_1","reshape_2","reshape_3","version","git_version","raise","max","x","y","min","equal","equal$0","max$0","min$0","global","null$0","undefined$0","return$0","map","f","bind","test","iter","case$0","g","get","option","x$0","to_option","return$1","map$0","bind$0","test$0","iter$0","case$1","get$0","option$0","to_option$0","coerce","coerce_opt","true$0","false$0","nfc","nfd","nfkc","nfkd","string_constr","regExp","object_keys","array_constructor","array_get","array_set","array_map","idx","array_mapi","str_array","match_result","date_constr","math","error_constr","exn_with_js_backtrace","name","message","stack","to_string","raise_js_error","e","string_of_error","JSON","decodeURI","s","decodeURIComponent","encodeURI","encodeURIComponent","escape","unescape","isNaN","i","parseInt","s$0","parseFloat","export_js","field","export$0","export_all","key","list_of_nodeList","length","acc","t1","acc$0","i$0","has","t","mask","add","appendChild","removeChild","replaceChild","insertBefore","nodeType","t13","cast","t14","element","text","attr","no_handler","handler","res","full_handler","this$0","invoke_handler","event","eventTarget","make","addEventListenerWithOptions","capture","once","passive","t44","addEventListener","typ","h","capt","removeEventListener","id","preventDefault","createCustomEvent","bubbles","cancelable","detail","x$1","arrayBuffer","int8Array","int16Array","uint16Array","int32Array","uint32Array","float32Array","float64Array","set","a","v","unsafe_get","dataView","of_arrayBuffer","uint8","of_arrayBuffer$0","filter_map","q","v$0","blob_raw","contentType","endings","options","blob_from_string","blob_from_any","l","l$0","a$0","b","filename","name$0","doc_constr","document","blob","string","loadstart","progress","abort","error","load","loadend","fileReader","name$56","name$55","name$54","name$53","name$52","name$51","name$50","name$49","name$48","name$47","name$46","name$45","name$44","name$43","name$42","name$41","name$40","name$39","name$38","name$37","name$36","name$35","name$34","name$33","name$32","name$31","name$30","name$29","name$28","name$27","name$26","name$25","name$24","name$23","name$22","name$21","name$20","name$19","name$18","name$17","name$16","name$15","name$14","name$13","name$12","name$11","name$10","name$9","name$8","name$7","name$6","name$5","name$4","name$3","name$2","name$1","onIE","cancel","click","close","copy","cut","paste","dblclick","mousedown","mouseup","mouseover","mousemove","mouseout","keypress","keydown","keyup","mousewheel","wheel","DOMMouseScroll","touchstart","touchmove","touchend","touchcancel","dragstart","dragend","dragenter","dragover","dragleave","drag","drop","hashchange","change","input","timeupdate","submit","scroll","focus","blur","unload","beforeunload","resize","orientationchange","popstate","select","online","offline","checking","noupdate","downloading","updateready","cached","obsolete","domContentLoaded","animationstart","animationend","animationiteration","animationcancel","transitionrun","transitionstart","transitionend","transitioncancel","canplay","canplaythrough","durationchange","emptied","ended","gotpointercapture","loadeddata","loadedmetadata","lostpointercapture","pause","play","playing","pointerenter","pointercancel","pointerdown","pointerleave","pointermove","pointerout","pointerover","pointerup","ratechange","seeked","seeking","stalled","suspend","volumechange","waiting","d","location_origin","o","window","getElementById","pnode","getElementById_exn","getElementById_opt","getElementById_coerce","createElement","createElementSyntax","unsafeCreateElementEx","type","doc","elt","createHtml","createHead","createLink","createTitle","createMeta","createBase","createStyle","createBody","createForm","createOptgroup","createOption","createSelect","createInput","createTextarea","createButton","createLabel","createFieldset","createLegend","createUl","createOl","createDl","createLi","createDialog","createDiv","createEmbed","createP","createH1","createH2","createH3","createH4","createH5","createH6","createQ","createBlockquote","createPre","createBr","createHr","createIns","createDel","createA","createImg","createObject","createParam","createMap","createArea","createScript","createTable","createCaption","createCol","createColgroup","createThead","createTfoot","createTbody","createTr","createTh","createTd","createSub","createSup","createSpan","createTt","createI","createB","createBig","createSmall","createEm","createStrong","createCite","createDfn","createCode","createSamp","createKbd","createVar","createAbbr","createDd","createDt","createNoscript","createAddress","createFrameset","createFrame","createIframe","createAudio","createVideo","createCanvas","html_element","t54","unsafeCoerce","tag","t55","area","base","blockquote","body","br","button","canvas","caption","col","colgroup","del","div","dl","fieldset","embed","form","frameset","frame","h1","h2","h3","h4","h5","h6","head","hr","html","iframe","img","input$0","ins","label","legend","li","link","meta","object","ol","optgroup","p","pre","script","select$0","style","table","tbody","td","textarea","tfoot","th","thead","title","tr","ul","audio","video","unsafeCoerceEvent","constr","ev","mouseEvent","keyboardEvent","wheelEvent","mouseScrollEvent","popStateEvent","messageEvent","eventRelatedTarget","eventAbsolutePosition","eventAbsolutePosition$0","elementClientPosition","getDocumentScroll","buttonPressed","addMousewheelEventListenerWith","dx","dy","addMousewheelEventListener","try_code","try_key_code_normal","make_unidentified","of_event","value","value$3","value$2","value$1","value$0","char_of_int","empty_string","none","of_event$0","element$0","tagged","t105","opt_tagged","taggedEvent","opt_taggedEvent","stopPropagation","requestAnimationFrame","req","c","callback","now","last","dt","hasPushState","hasPlaceholder","hasRequired","overflow_limit","setTimeout","loop","remain","step","cb","clearTimeout","js_array_of_collection","formData","formData_form","have_content","get_element_content","sth","file","form_elements","i$1","t31","append","form_contents","form_elt","list","empty_form_contents","post_form_contents","contents","get_form_contents","readystatechange","timeout","create","import_scripts","scripts","set_onmessage","js_handler","post_message","webSocket","is_supported","defaultContextAttributes","webglcontextlost","webglcontextrestored","webglcontextcreationerror","getContext","ctx","getContextWithAttributes","regexp","regexp_case_fold","regexp_with_flag","blunt_str_array_get","string_match","search","res_pre","matched_string","r","matched_group","quote_repl","global_replace","s_by","replace_first","t29","list_of_js_array","idx$1","accu","idx$0","accu$0","split","bounded_split","quote","regexp_string","regexp_string_case_fold","interrupt","plus_re","urldecode_js_string_string","t16","urldecode","urlencode","opt","with_plus","path_of_path_string","aux","j","word","encode_arguments","n","decode_arguments_js_string","len","t3","decode_arguments","url_of_js_string","handle","path_str","ssl","url","url_of_string","string_of_url","frag","args","path","port","host","frag$0","args$0","path$0","port$0","host$0","frag$1","args$1","path$1","default_http_port","default_https_port","protocol","path_string","arguments$0","get_fragment","set_fragment","u","as_string","update_file","content","oc","set_channel_flusher","out_channel","f$0","set_channel_filler","in_channel","mount","prefix","unmount","js_of_ocaml_version","empty_resize_observer_options","observe","box","entry_types","empty_mutation_observer_init","child_list","attributes","character_data","subtree","attribute_old_value","character_data_old_value","attribute_filter","remove","find","keys","reviver","unsafe_input","mlInt64_constr","output_reviver","output","string_of_name","name_of_string","rgb_of_name","rgb","hsl","string_of_t","b$0","g$0","r$0","b$1","g$1","r$1","b$2","g$2","r$2","a$1","h$0","hex_of_rgb","blue","green","red","in_range","js_t_of_js_string","t12","js","cn","ml","fail","re_rgb","re_rgb_pct","re_hsl","i_of_s_o","f_of_s","alpha","red$0","green$0","blue$0","alpha$0","red$1","green$1","blue$1","alpha$1","string_of_t$0","f$1","f$2","f$3","f$4","f$5","f$6","f$7","f$8","f$9","f$10","f$11","f$12","js$0","ml$0","re","string_of_t$1","js$1","ml$1","listen","target","stop_listen","createAltGlyph","createAltGlyphDef","createAltGlyphItem","createAnimate","createAnimateColor","createAnimateMotion","createAnimateTransform","createCircle","createClipPath","createCursor","createDefs","createDesc","createEllipse","createFilter","createFont","createFontFace","createFontFaceFormat","createFontFaceName","createFontFaceSrc","createFontFaceUri","createForeignObject","createG","createGlyph","createGlyphRef","createhkern","createImage","createLineElement","createLinearElement","createMask","createMetaData","createMissingGlyph","createMPath","createPath","createPattern","createPolygon","createPolyline","createRadialgradient","createRect","createSet","createStop","createSvg","createSwitch","createSymbol","createTextElement","createTextpath","createTref","createTspan","createUse","createView","createvkern","svg_element","t8","altGlyph","altGlyphDef","altGlyphItem","animate","animateColor","animateMotion","animateTransform","circle","clipPath","cursor","defs","desc","ellipse","filter","font","fontFace","fontFaceFormat","fontFaceName","fontFaceSrc","fontFaceUri","foreignObject","glyph","glyphRef","hkern","image","lineElement","linearElement","metaData","missingGlyph","mPath","pattern","polygon","polyline","radialgradient","rect","stop","svg","switch$0","symbol","textElement","textpath","tref","tspan","use","view","vkern","withCredentials","eventSource","eventSource_options","console","empty_position_options","geolocation","empty_intersection_observer_op","intersectionObserver_unsafe","object_options","options$0","options$1","options$2","intl","collator_constr","dateTimeFormat_constr","numberFormat_constr","pluralRules_constr","decide","decision","decide_rel","relDecision","top","top0","bottom","bottom0","coq_Top","coq_Neg","a","coq_And","b","coq_Or","coq_Diam","eq_dec_form","m","x0","m$0","x0$0","s","s0","f","s1","x1","s2","s3","a0","h$0","i","b6","b5","b4","b3","b2","b1","b0","f$0","b7","b8","b9","b10","b11","b12","b13","b14","h","m1","m0","m3","m2","m0$0","m1$0","unBox_formula","x","unboxed_list","t","top_boxes","fst","snd","y","length","l","app","l1","le_lt_dec","n","n$0","n0","n1","lt_dec","add","p","string_dec","s$0","x$0","form_top","form_eq_dec","v","v0","f1","f0","f3","f2","f1$0","f0$0","f3$0","f2$0","f1$1","f0$1","f3$1","f2$1","f0$2","f1$2","weight","UU03c8","UU03c6_0","UU03c8$0","UU03c6_0$0","UU03c8$1","UU03c6_0$1","UU03c6_0$2","in_dec","l0","remove","eq_dec","tl","list_eq_dec","l$0","l$2","l$1","map","nodup","decA","xs","foldl","a$0","elem_of_list_dec","dec","comparison_eq_dec","symbol","decidable_is_implication","UU03c6","decidable_is_negation","obviously_smaller","UU03c8_0","c","c0","c$0","c0$0","UU03c8_0$0","c$1","c0$1","f$1","c$2","c0$2","f$2","choose_conj","make_conj","UU03c8_2","UU03c8_1","UU03c8_2$0","UU03c8_1$0","UU03c8_2$1","UU03c8_1$1","UU03c6_2","UU03c6_1","choose_disj","make_disj","make_impl","UU03c6$0","UU03c6$1","conjunction","disjunction","in_map_aux","UU0393","UU0393_0","in_map","rm","open_box","coq_XBoxed_list","coq_InT_eq","coq_InT_app_or","l2","i0","i0$0","coq_InT_or_app","i$1","i$0","app0","l3","in_splitT","h0","eq_dec_listsF","eq_dec_seqs","seqs_in_splitT","coq_In_InT_seqs","seq","coq_In_dec","remove_list","t1","h1","dec_prop_var_in","s0$0","dec_is_box","dec_box_in","dec_init_rules","x2","x3","s1$0","s2$0","s2$1","s3$0","x$1","s4","x0$1","x1$0","h0$0","s5","x2$0","x3$0","proj1_sigT2","proj2_sigT2","coq_In_InT_pair","coq_InT_map_iff","iHl","y0","p0","pos_top_imps","top_boxes_nobox_gen_ext","flatten_list","coq_InT_flatten_list_InT_elem","i2","i1","coq_InT_trans_flatten_list","bs","list_of_splits","listInserts","listInsertsR_Seqs","UU0394","listInsertsL_Seqs","remove_nth","tl$0","b$0","nth_split","prems_Imp_R","coq_In_pos_top_imps_split_l","n0$0","coq_ImpR_help01","prem","s0$1","s1$1","x1$2","s3$1","x2$2","s4$1","x3$2","s5$1","x4$2","s6$1","x5$1","x6$1","prems_Imp_R0","l4","l4$0","l4$1","x4$0","l5","x1$1","x2$1","x3$1","s4$0","x4$1","s5$0","x5$0","s6$0","x6$0","x7","x4","s6","x5","x6","coq_ImpR_help1","coq_ImpR_help002","UU0393_1","UU0394_0","UU0394_1","coq_ImpR_help02","h1$0","l2$0","l2$1","tl$4","b0$2","tl$5","tl$6","b0$0","tl$1","b0$1","tl$2","tl$3","n$1","coq_ImpR_help2","finite_ImpR_premises_of_S","prems","prems_Imp_L","z","coq_ImpL_help002","p1","p$0","coq_ImpL_help02","prems_Imp_L0","l1$0","l1$1","coq_ImpL_help2","coq_ImpL_help01","x5$2","s7$1","x6$2","s8$1","x7$2","x8$2","s7$0","x7$1","s8$0","x8$1","x9","i3","i4","b$2","b$1","i5","i6","i7","p2","i8","l4$3","x7$0","i9","x8$0","l4$2","s7","s8","x8","coq_ImpL_help1","finite_ImpL_premises_of_S","prems_Box_R","coq_GLR_help01","coq_GLR_help1","coq_GLR_help02","b_UU0393","coq_GLR_help2","finite_GLR_premises_of_S","subform_boxesF","subform_boxesLF","subform_boxesS","usable_boxes","dec_is_PropVar","dec_KS_init_rules","coq_KR_help01","coq_KR_help1","coq_KR_help02","coq_KR_help2","finite_KR_premises_of_S","e_rule","UU03d5","eA0","UU03b8","e","pe0","UU0394$0","q","UU03b4_UU2082","UU03b4_UU2081","UU03b4_UU2082$0","UU03b4_UU2081$0","UU03b4_2","q$0","UU03b4_UU2082$1","UU03b4_UU2081$1","UU03b4_UU2082$2","UU03b4_UU2081$2","UU03b4_UU2082$3","UU03b4_UU2081$3","UU03b4_1","a_rule_env","a_rule_form","UU03d5_UU2082","UU03d5_UU2081","UU03d5_UU2082$0","UU03d5_UU2081$0","UU03d5_UU2082$1","UU03d5_UU2081$1","UU03b4","coq_EA","pe","coq_E","coq_A","coq_Ef","coq_Af","simp_ors","simp_ands","simp_imp","simp_imps","simp","coq_E_simplified","coq_A_simplified","list_is_nil","flatmap","irred","finite_ImpRules_premises_of_S","prems0","UU0394_1$0","UU0394_0$0","UU0393_1$0","UU0393_0$0","prems0$0","inv_prems","coq_Canopy","is_Prime_dec","critical_Seq_dec","coq_GLR_prems","coq_LexSeq_ind","empty_seq_dec","list_conj","list_disj","list_prop_F","list_prop_LF","restr_list_prop","nodupseq","imap","coq_GUI_tot","iH","coq_KR_prems","coq_LtSeq_ind","j10","coq_MPropF_of_form","form_of_MPropF","gl_UI","k_UI","isl_E","isl_A","isl_simp","isl_simplified_E","isl_simplified_A","exists_dec","coq_Provable_dec","UU0393_2","hind","hAndR","f2$7","f1$10","v$0","hvar","fA","hAndL","s$1","hImpR","f2$6","f1$9","s$2","s0$2","x0$2","fA$0","s$3","s0$3","x0$3","hOrL","s$4","s0$4","x0$4","s1$2","fIp","fp","s$5","s0$5","x0$5","s1$3","x1$3","hImpLVar","s$6","s0$6","x0$6","x1$4","s1$4","fII","s$7","s0$7","x0$7","f2$2","f4","hImpLAnd","s$8","s0$8","x0$8","s1$5","x1$5","s2$2","fII$0","s$9","s0$9","x0$9","f2$3","f1$3","f4$0","hImpLOr","s$10","s0$10","x0$10","s1$6","x1$6","s2$3","hOrR1","f2$5","f1$8","s$14","hOrR2","f2$4","f1$7","s$13","hBoxR","f1$6","s$12","f1$4","UU0393_3","f5","s$11","f1$5","s0$11","create","size","empty","length","sub","invalid_bounds","op","buffer_len","off","len","message","invalid_bounds_blit","src_len","src_off","dst_len","dst_off","invalid_bounds_memcmp","buf1_len","buf1_off","buf2_len","buf2_off","copy","t","dst","substring","b","to_string","of_string","s","blit","src","blit_from_string","blit_from_bytes","blit_to_bytes","memcmp","buf1","buf2","memcmp_string","memchr","buf","buf_off","chr","buf_len","caml_bigstring_set_16","bs","i","caml_bigstring_set_32","caml_bigstring_set_64","caml_bigstring_get_16","caml_bigstring_get_32","caml_bigstring_get_64","get_int16_sign_extended","x","set_int16_be","set_int16_le","set_int32_be","set_int32_le","set_int64_be","set_int64_le","get_int16_be","get_int16_le","get_int16_sign_extended_noswap","get_int16_sign_extended_noswap$0","get_int16_sign_extended_le","get_int32_be","get_int32_le","get_int64_be","get_int64_le","caml_bigstring_unsafe_set_16","caml_bigstring_unsafe_set_32","caml_bigstring_unsafe_set_64","caml_bigstring_unsafe_get_16","caml_bigstring_unsafe_get_32","caml_bigstring_unsafe_get_64","unsafe_set_int16_be","unsafe_set_int16_le","unsafe_set_int32_be","unsafe_set_int32_le","unsafe_set_int64_be","unsafe_set_int64_le","unsafe_get_int16_be","unsafe_get_int16_le","unsafe_get_int16_sign_extended","unsafe_get_int16_sign_extended$0","unsafe_get_int32_be","unsafe_get_int32_le","unsafe_get_int64_be","unsafe_get_int64_le","state_to_option","x","v","fail_to_string","marks","err","state_to_result","create","buffer","off","len","committed_bytes","length","t","client_committed_bytes","parser_committed_bytes","bytes_for_client_to_commit","parser_uncommitted_bytes","invariant","offset_in_buffer","pos","apply","f","unsafe_get_char","unsafe_get_int16_le","unsafe_get_int32_le","unsafe_get_int64_le","unsafe_get_int16_be","unsafe_get_int32_be","unsafe_get_int64_be","count_while","i","limit","commit","fail_k","input","msg","succeed_k","to_exported_state","continue$0","committed","bs","more","x$0","s","sl","i$0","parse","p","parse_bigstring","input$0","return$0","fail","succ","symbol_bind","succ$0","symbol_map","symbol","m","symbol$0","succ0","input0","pos0","more0","succ1","input1","pos1","more1","lift","lift2","m1","m2","succ2","input2","pos2","more2","lift3","m3","succ3","input3","pos3","more3","lift4","m4","succ4","input4","pos4","more4","symbol$1","a","b","symbol$2","symbol$3","mark","fail$0","symbol$4","q","pos$0","more$0","return$1","symbol_bind$0","symbol_map$0","symbol$5","symbol$6","lift2$0","lift3$0","lift4$0","symbol$7","symbol$8","of_bigstring","buf","writable_space","ensure","to_copy","old_len","new_len","space","new_buf","write_pos","feed_string","str","feed_bigstring","feed_input","shift","n","for_reading","unconsumed","opt","sth","of_unconsumed","from_unbuffered_state","buffering","consumed","consumed$0","unconsumed$0","parse$0","initial_buffer_size","feed","state","k","buffering$0","state_to_option$0","state_to_result$0","state_to_unconsumed","prompt","demand_input","ensure_suspended","go","unsafe_apply","at_end_of_input","end_of_input","advance","available","unsafe_lookahead","peek_char","peek_char_fail","satisfy","c","char$0","not_char","c$0","any_char","int8","p$0","any_uint8","p$1","any_int8","skip","init","with_buffer","input_len","init$0","count_while1","succ$1","fail$1","string","f$0","e","string$0","string_ci","skip_while","take","n$0","take_bigstring","take_bigstring_while","take_bigstring_while1","take_bigstring_till","peek_string","take_while","take_while1","take_till","choice","ps","failure_msg","fix_direct","r","fix_lazy","max_steps","steps","fix","option","cons","xs","list","ps$0","count","loop","many","many1","many_till","sep_by1","sep_by","skip_many","skip_many1","end_of_line","scan","state$0","parser","scan$0","scan_state","scan_string","consume_with","consumed_bigstring","both","map","bind","map2","map3","map4","d","int16","int32","int64","any_uint16","any_int16","any_int32","any_int64","any_float","any_double","int16$0","int32$0","int64$0","any_uint16$0","any_int16$0","any_int32$0","any_int64$0","any_float$0","any_double$0","take$0","peek","take_while$0","check","take_while1$0","take_till$0","parse_bigstring$0","consume","parse_string","myfold","l","a","f","myrevmap","myrevmap2","l1","l2","sep","map","sp","acu","x","symbol","symbol$0","b","i","succ","symbol$1","minus","symbol$2","j","symbol$3","symbol$4","quomod","bigmod","sign","big_compare","bigzero","bigone","is_bigone","sob","bos","boi","iob","create","n","v","copy","t","get","index","set","len","newarray","size","fold","akk","iter","find_prime","y","x$0","gcd","x$1","compute_shuffle","card","compute","prime","new_index","get_cardinal","p","shuffle","part","empty_part","uninitialized_part","map_part","part_from_list","values","avalues","union_parts","partlist","index$1","partlist$0","partlist$1","index$0","pre_result","product_parts","parts","part_revvector","part_revvector$0","vector","part_revvector$1","pcard","mod","p_cardinal","cardinal","exen","check_array_index","get_part","array_index","newcell","part$0","get_in_parts","value_index","value_index$0","array_index$0","array_index$1","value_index$1","max","from_single_part","title","a_part","from_list","opt","sth","name","pay","l_exen","is_infinite","new_part","sub","bound","newcardinal","sum_cardinals","acu$0","exens","infmax","max_parts","union","ex","e","prod_cardinals","z","k","find_vectors_aux","last_chance","depth","flag","temp_vect","pos","rev_max","others","current_vup","vup","vlow","racu","current_index","flag$0","find_vectors","rev_max_indexes","last","current_pos","vector_to_part_list","prod_parts","max_revindexes","all_vectors","all_rev_parts","all_prod_parts","product","gen_tester","print","tos","bind","unit","upto","remaining","from","sth$0","verbose_period","bigverbose_period","iterate","count","current","remaining$0","current$0","remaining$1","upper_bound","continue$0","verbose","test_value","tos$0","current$1","get_exen","x","product","union","from_list","single","name","map","get","cardinal","pay","sub","c1_2","c2_2","proj2","a","b","tuple2","ex1","ex2","mex1","mex2","c1_3","c2_3","c3_3","proj3","c","triple","ex3","mex3","tuple4","e1","e2","e3","e4","d","tuple5","e5","e","tuple6","e6","f","char_part","n","usual_char_part","e_unit","e_bool","e_char","e_pchar","e_zero","e_one","big2n","big2np1","e_bigpos","e_bigpos$0","e_bignat","e_bigneg","e_bigint","e_biginterval","e_interval","bmax_int","toint","e_nat","e_pos","e_neg","e_int","e_string_from_echar","enum_chars","enum$0","e_string","e_rstring","charlist","e_list","exen","e_ne_list","e_array","e_option","bigshow","to_string","n1","n2","i","index","show","tester","from","upto","verbose_period","tos","len","camlstring_of_coqstring","s","r","pos","s$0","c","coqstring_of_camlstring","pos$1","accu","pos$0","accu$0","is_space","spaces","parens","p","box","x","diamond","neg","y","disj","conj","modal","impl","bot","top","letter","letter_or_digit","identifier","chainl1","e","op","go","acc","f","init","chainr1","chainmod","expr","factor","modality","term","disjunctions","eval$0","str","v","int_of_nat","n","string_of_formula","opt","sth","classical","v","g","f","bracket","g$0","f$0","f$1","f$2","f$3","g$1","f$4","e","e$0","catch_e","f","e$0","e","s","fail_on_modality","aux","y","x","v"],"sources":["/builtin/+mlBytes.js","/builtin/+bigarray.js","/builtin/+marshal.js","/builtin/+unix.js","/builtin/+stdlib.js","/builtin/+sys.js","/builtin/+backtrace.js","/builtin/+jslib.js","/builtin/+fail.js","/builtin/+fs.js","/builtin/+fs_fake.js","/builtin/+int64.js","/builtin/+sync.js","/builtin/+nat.js","/builtin/+fs_node.js","/builtin/+bigstring.js","/home/coq/.opam/4.13.1+flambda/lib/bigstringaf/runtime.js","/builtin/+compare.js","/builtin/+md5.js","/builtin/+ieee_754.js","/builtin/+obj.js","/builtin/+effect.js","/builtin/+array.js","/builtin/+domain.js","/builtin/+ints.js","/builtin/+hash.js","/builtin/+io.js","/builtin/+runtime_events.js","/builtin/+zstd.js","/builtin/+weak.js","/builtin/+gc.js","/builtin/+format.js","/builtin/+graphics.js","/builtin/+jslib_js_of_ocaml.js","/builtin/+lexing.js","/builtin/+prng.js","/builtin/+parsing.js","/builtin/+str.js","/home/coq/.opam/4.13.1+flambda/lib/ocaml/camlinternalFormatBasics.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/camlinternalAtomic.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/stdlib.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/pervasives.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/seq.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/option.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/either.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/result.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/bool.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/char.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/uchar.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/list.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/int.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/bytes.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/string.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/unit.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/marshal.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/obj.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/array.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/float.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/int32.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/int64.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/nativeint.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/lexing.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/parsing.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/set.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/map.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/stack.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/queue.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/camlinternalLazy.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/lazy.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/stream.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/buffer.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/camlinternalFormat.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/printf.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/arg.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/printexc.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/fun.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/gc.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/digest.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/random.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/hashtbl.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/weak.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/format.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/scanf.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/callback.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/camlinternalOO.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/camlinternalMod.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/genlex.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/ephemeron.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/filename.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/complex.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/bigarray.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml-compiler/runtime/jsoo_runtime__.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml-compiler/runtime/jsoo_runtime.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/js_of_ocaml__.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/import.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/js.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/dom.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/typed_array.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/file.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/dom_html.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/form.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/xmlHttpRequest.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/worker.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/webSockets.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/webGL.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/regexp.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/url.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/sys_js.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/resizeObserver.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/performanceObserver.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/mutationObserver.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/jstable.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/json.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/cSS.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/dom_events.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/dom_svg.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/eventSource.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/firebug.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/geolocation.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/intersectionObserver.ml","/home/coq/.opam/4.13.1+flambda/lib/js_of_ocaml/intl.ml","/workspace_root/extraction/base.ml","/workspace_root/extraction/CML_Syntax.ml","/workspace_root/extraction/Datatypes.ml","/workspace_root/extraction/Compare_dec.ml","/workspace_root/extraction/Nat.ml","/workspace_root/extraction/String.ml","/workspace_root/extraction/Formulas.ml","/workspace_root/extraction/List.ml","/workspace_root/extraction/list0.ml","/workspace_root/extraction/numbers.ml","/workspace_root/extraction/Environments.ml","/workspace_root/extraction/GLS_calcs.ml","/workspace_root/extraction/genT.ml","/workspace_root/extraction/List_lemmasT.ml","/workspace_root/extraction/list_lems.ml","/workspace_root/extraction/remove_list_lems.ml","/workspace_root/extraction/GLS_dec.ml","/workspace_root/extraction/PeanoNat.ml","/workspace_root/extraction/GLS_der_dec.ml","/workspace_root/extraction/GLS_termination_measure.ml","/workspace_root/extraction/KS_dec.ml","/workspace_root/extraction/KS_termination_prelims.ml","/workspace_root/extraction/KS_termination_ImpR.ml","/workspace_root/extraction/KS_termination_ImpL.ml","/workspace_root/extraction/KS_termination_KR.ml","/workspace_root/extraction/PropQuantifiers.ml","/workspace_root/extraction/Simp.ml","/workspace_root/extraction/UIGL_irred_short.ml","/workspace_root/extraction/UIGL_Canopy.ml","/workspace_root/extraction/UIGL_LexSeq.ml","/workspace_root/extraction/UIGL_basics.ml","/workspace_root/extraction/UIGL_nodupseq.ml","/workspace_root/extraction/UIGL_braga.ml","/workspace_root/extraction/UIK_irred_short.ml","/workspace_root/extraction/UIK_Canopy.ml","/workspace_root/extraction/UIK_basics.ml","/workspace_root/extraction/UIK_braga.ml","/workspace_root/extraction/UIML_extraction.ml","/workspace_root/extraction/DecisionProcedure.ml","/home/coq/.opam/4.13.1+flambda/lib/bigstringaf/bigstringaf.ml","/home/coq/.opam/4.13.1+flambda/lib/angstrom/exported_state.ml","/home/coq/.opam/4.13.1+flambda/lib/angstrom/input.ml","/home/coq/.opam/4.13.1+flambda/lib/angstrom/parser.ml","/home/coq/.opam/4.13.1+flambda/lib/angstrom/buffering.ml","/home/coq/.opam/4.13.1+flambda/lib/angstrom/angstrom.ml","/home/coq/.opam/4.13.1+flambda/lib/exenum/internals/convenience.ml","/home/coq/.opam/4.13.1+flambda/lib/exenum/internals/extArray.ml","/home/coq/.opam/4.13.1+flambda/lib/exenum/internals/shuffle.ml","/home/coq/.opam/4.13.1+flambda/lib/exenum/internals/parts.ml","/home/coq/.opam/4.13.1+flambda/lib/exenum/internals/exen.ml","/home/coq/.opam/4.13.1+flambda/lib/exenum/internals/tester.ml","/home/coq/.opam/4.13.1+flambda/lib/exenum/exenum.ml","/workspace_root/bin/stringconversion.ml","/workspace_root/bin/modal_expressions_parser.ml","/workspace_root/bin/printer.ml","/workspace_root/bin/uiml_demo.ml","/home/coq/.opam/4.13.1+flambda/lib/ocaml/std_exit.ml"],"mappings":"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","sourcesContent":["// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010-2014 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n// An OCaml string is an object with three fields:\n// - tag 't'\n// - length 'l'\n// - contents 'c'\n//\n// The contents of the string can be either a JavaScript array or\n// a JavaScript string. The length of this string can be less than the\n// length of the OCaml string. In this case, remaining bytes are\n// assumed to be zeroes. Arrays are mutable but consumes more memory\n// than strings. A common pattern is to start from an empty string and\n// progressively fill it from the start. Partial strings makes it\n// possible to implement this efficiently.\n//\n// When converting to and from UTF-16, we keep track of whether the\n// string is composed only of ASCII characters (in which case, no\n// conversion needs to be performed) or not.\n//\n// The string tag can thus take the following values:\n//   full string     BYTE | UNKNOWN:      0\n//                   BYTE | ASCII:        9\n//                   BYTE | NOT_ASCII:    8\n//   string prefix   PARTIAL:             2\n//   array           ARRAY:               4\n//\n// One can use bit masking to discriminate these different cases:\n//   known_encoding(x) = x&8\n//   is_ascii(x) =       x&1\n//   kind(x) =           x&6\n\n//Provides: caml_str_repeat\nfunction caml_str_repeat(n, s) {\n  if(n == 0) return \"\";\n  if (s.repeat) {return s.repeat(n);} // ECMAscript 6 and Firefox 24+\n  var r = \"\", l = 0;\n  for(;;) {\n    if (n & 1) r += s;\n    n >>= 1;\n    if (n == 0) return r;\n    s += s;\n    l++;\n    if (l == 9) {\n      s.slice(0,1); // flatten the string\n      // then, the flattening of the whole string will be faster,\n      // as it will be composed of larger pieces\n    }\n  }\n}\n\n//Provides: caml_subarray_to_jsbytes\n//Weakdef\n// Pre ECMAScript 5, [apply] would not support array-like object.\n// In such setup, Typed_array would be implemented as polyfill, and [f.apply] would\n// fail here. Mark the primitive as Weakdef, so that people can override it easily.\nfunction caml_subarray_to_jsbytes (a, i, len) {\n  var f = String.fromCharCode;\n  if (i == 0 && len <= 4096 && len == a.length) return f.apply (null, a);\n  var s = \"\";\n  for (; 0 < len; i += 1024,len-=1024)\n    s += f.apply (null, a.slice(i,i + Math.min(len, 1024)));\n  return s;\n}\n\n//Provides: caml_utf8_of_utf16\nfunction caml_utf8_of_utf16(s) {\n  for (var b = \"\", t = b, c, d, i = 0, l = s.length; i < l; i++) {\n    c = s.charCodeAt(i);\n    if (c < 0x80) {\n      for (var j = i + 1; (j < l) && (c = s.charCodeAt(j)) < 0x80; j++);\n      if (j - i > 512) { t.substr(0, 1); b += t; t = \"\"; b += s.slice(i, j) }\n      else t += s.slice(i, j);\n      if (j == l) break;\n      i = j;\n    }\n    if (c < 0x800) {\n      t += String.fromCharCode(0xc0 | (c >> 6));\n      t += String.fromCharCode(0x80 | (c & 0x3f));\n    } else if (c < 0xd800 || c >= 0xdfff) {\n      t += String.fromCharCode(0xe0 | (c >> 12),\n                               0x80 | ((c >> 6) & 0x3f),\n                               0x80 | (c & 0x3f));\n    } else if (c >= 0xdbff || i + 1 == l ||\n               (d = s.charCodeAt(i + 1)) < 0xdc00 || d > 0xdfff) {\n      // Unmatched surrogate pair, replaced by \\ufffd (replacement character)\n      t += \"\\xef\\xbf\\xbd\";\n    } else {\n      i++;\n      c = (c << 10) + d - 0x35fdc00;\n      t += String.fromCharCode(0xf0 | (c >> 18),\n                               0x80 | ((c >> 12) & 0x3f),\n                               0x80 | ((c >> 6) & 0x3f),\n                               0x80 | (c & 0x3f));\n    }\n    if (t.length > 1024) {t.substr(0, 1); b += t; t = \"\";}\n  }\n  return b+t;\n}\n\n//Provides: caml_utf16_of_utf8\nfunction caml_utf16_of_utf8(s) {\n  for (var b = \"\", t = \"\", c, c1, c2, v, i = 0, l = s.length; i < l; i++) {\n    c1 = s.charCodeAt(i);\n    if (c1 < 0x80) {\n      for (var j = i + 1; (j < l) && (c1 = s.charCodeAt(j)) < 0x80; j++);\n      if (j - i > 512) { t.substr(0, 1); b += t; t = \"\"; b += s.slice(i, j) }\n      else t += s.slice(i, j);\n      if (j == l) break;\n      i = j;\n    }\n    v = 1;\n    if ((++i < l) && (((c2 = s.charCodeAt(i)) & -64) == 128)) {\n      c = c2 + (c1 << 6);\n      if (c1 < 0xe0) {\n        v = c - 0x3080;\n        if (v < 0x80) v = 1;\n      } else {\n        v = 2;\n        if ((++i < l) && (((c2 = s.charCodeAt(i)) & -64) == 128)) {\n          c = c2 + (c << 6);\n          if (c1 < 0xf0) {\n            v = c - 0xe2080;\n            if ((v < 0x800) || ((v >= 0xd7ff) && (v < 0xe000))) v = 2;\n          } else {\n            v = 3;\n            if ((++i < l) && (((c2 = s.charCodeAt(i)) & -64) == 128) &&\n                (c1 < 0xf5)) {\n              v = c2 - 0x3c82080 + (c << 6);\n              if (v < 0x10000 || v > 0x10ffff) v = 3;\n            }\n          }\n        }\n      }\n    }\n    if (v < 4) { // Invalid sequence\n      i -= v;\n      t += \"\\ufffd\";\n    } else if (v > 0xffff)\n      t += String.fromCharCode(0xd7c0 + (v >> 10), 0xdc00 + (v & 0x3FF))\n    else\n      t += String.fromCharCode(v);\n    if (t.length > 1024) {t.substr(0, 1); b += t; t = \"\";}\n  }\n  return b+t;\n}\n\n//Provides: jsoo_is_ascii\nfunction jsoo_is_ascii (s) {\n  // The regular expression gets better at around this point for all browsers\n  if (s.length < 24) {\n    // Spidermonkey gets much slower when s.length >= 24 (on 64 bit archs)\n    for (var i = 0; i < s.length; i++) if (s.charCodeAt(i) > 127) return false;\n    return true;\n  } else\n    return !/[^\\x00-\\x7f]/.test(s);\n}\n\n//Provides: caml_bytes_unsafe_get mutable\nfunction caml_bytes_unsafe_get (s, i) {\n  switch (s.t & 6) {\n  default: /* PARTIAL */\n    if (i >= s.c.length) return 0;\n  case 0: /* BYTES */\n    return s.c.charCodeAt(i);\n  case 4: /* ARRAY */\n    return s.c[i]\n  }\n}\n\n//Provides: caml_bytes_unsafe_set\n//Requires: caml_convert_bytes_to_array\nfunction caml_bytes_unsafe_set (s, i, c) {\n  // The OCaml compiler uses Char.unsafe_chr on integers larger than 255!\n  c &= 0xff;\n  if (s.t != 4 /* ARRAY */) {\n    if (i == s.c.length) {\n      s.c += String.fromCharCode (c);\n      if (i + 1 == s.l) s.t = 0; /*BYTES | UNKOWN*/\n      return 0;\n    }\n    caml_convert_bytes_to_array (s);\n  }\n  s.c[i] = c;\n  return 0;\n}\n\n//Provides: caml_string_bound_error\n//Requires: caml_invalid_argument\nfunction caml_string_bound_error () {\n  caml_invalid_argument (\"index out of bounds\");\n}\n\n//Provides: caml_bytes_bound_error\n//Requires: caml_invalid_argument\nfunction caml_bytes_bound_error () {\n  caml_invalid_argument (\"index out of bounds\");\n}\n\n//Provides: caml_string_get\n//Requires: caml_string_bound_error, caml_string_unsafe_get\n//Requires: caml_ml_string_length\nfunction caml_string_get (s, i) {\n  if (i >>> 0 >= caml_ml_string_length(s)) caml_string_bound_error();\n  return caml_string_unsafe_get (s, i);\n}\n\n//Provides: caml_string_get16\n//Requires: caml_string_unsafe_get, caml_string_bound_error\n//Requires: caml_ml_string_length\nfunction caml_string_get16(s,i) {\n  if (i >>> 0 >= caml_ml_string_length(s) - 1) caml_string_bound_error();\n  var b1 = caml_string_unsafe_get (s, i),\n      b2 = caml_string_unsafe_get (s, i + 1);\n  return (b2 << 8 | b1);\n}\n\n//Provides: caml_bytes_get16\n//Requires: caml_bytes_unsafe_get, caml_bytes_bound_error\nfunction caml_bytes_get16(s,i) {\n  if (i >>> 0 >= s.l - 1) caml_bytes_bound_error();\n  var b1 = caml_bytes_unsafe_get (s, i),\n      b2 = caml_bytes_unsafe_get (s, i + 1);\n  return (b2 << 8 | b1);\n}\n\n//Provides: caml_string_get32\n//Requires: caml_string_unsafe_get, caml_string_bound_error\n//Requires: caml_ml_string_length\nfunction caml_string_get32(s,i) {\n  if (i >>> 0 >= caml_ml_string_length(s) - 3) caml_string_bound_error();\n  var b1 = caml_string_unsafe_get (s, i),\n      b2 = caml_string_unsafe_get (s, i + 1),\n      b3 = caml_string_unsafe_get (s, i + 2),\n      b4 = caml_string_unsafe_get (s, i + 3);\n  return (b4 << 24 | b3 << 16 | b2 << 8 | b1);\n}\n\n//Provides: caml_bytes_get32\n//Requires: caml_bytes_unsafe_get, caml_bytes_bound_error\nfunction caml_bytes_get32(s,i) {\n  if (i >>> 0 >= s.l - 3) caml_bytes_bound_error();\n  var b1 = caml_bytes_unsafe_get (s, i),\n      b2 = caml_bytes_unsafe_get (s, i + 1),\n      b3 = caml_bytes_unsafe_get (s, i + 2),\n      b4 = caml_bytes_unsafe_get (s, i + 3);\n  return (b4 << 24 | b3 << 16 | b2 << 8 | b1);\n}\n\n//Provides: caml_string_get64\n//Requires: caml_string_unsafe_get, caml_string_bound_error\n//Requires: caml_int64_of_bytes\n//Requires: caml_ml_string_length\nfunction caml_string_get64(s,i) {\n  if (i >>> 0 >= caml_ml_string_length(s) - 7) caml_string_bound_error();\n  var a = new Array(8);\n  for(var j = 0; j < 8; j++){\n    a[7 - j] = caml_string_unsafe_get (s, i + j);\n  }\n  return caml_int64_of_bytes(a);\n}\n\n//Provides: caml_bytes_get64\n//Requires: caml_bytes_unsafe_get, caml_bytes_bound_error\n//Requires: caml_int64_of_bytes\nfunction caml_bytes_get64(s,i) {\n  if (i >>> 0 >= s.l - 7) caml_bytes_bound_error();\n  var a = new Array(8);\n  for(var j = 0; j < 8; j++){\n    a[7 - j] = caml_bytes_unsafe_get (s, i + j);\n  }\n  return caml_int64_of_bytes(a);\n}\n\n//Provides: caml_bytes_get\n//Requires: caml_bytes_bound_error, caml_bytes_unsafe_get\nfunction caml_bytes_get (s, i) {\n  if (i >>> 0 >= s.l) caml_bytes_bound_error();\n  return caml_bytes_unsafe_get (s, i);\n}\n\n//Provides: caml_string_set\n//Requires: caml_failwith\n//If: js-string\nfunction caml_string_set (s, i, c) {\n  caml_failwith(\"caml_string_set\");\n}\n\n//Provides: caml_string_set\n//Requires: caml_string_unsafe_set, caml_string_bound_error\n//If: !js-string\nfunction caml_string_set (s, i, c) {\n  if (i >>> 0 >= s.l) caml_string_bound_error();\n  return caml_string_unsafe_set (s, i, c);\n}\n\n//Provides: caml_bytes_set16\n//Requires: caml_bytes_bound_error, caml_bytes_unsafe_set\nfunction caml_bytes_set16(s,i,i16){\n  if (i >>> 0 >= s.l - 1) caml_bytes_bound_error();\n  var b2 = 0xFF & i16 >> 8,\n      b1 = 0xFF & i16;\n  caml_bytes_unsafe_set (s, i + 0, b1);\n  caml_bytes_unsafe_set (s, i + 1, b2);\n  return 0\n}\n\n//Provides: caml_string_set16\n//Requires: caml_failwith\n//If: js-string\nfunction caml_string_set16(s,i,i16){\n  caml_failwith(\"caml_string_set16\");\n}\n\n//Provides: caml_string_set16\n//Requires: caml_bytes_set16\n//If: !js-string\nfunction caml_string_set16(s,i,i16){\n  return caml_bytes_set16(s,i,i16);\n}\n\n//Provides: caml_bytes_set32\n//Requires: caml_bytes_bound_error, caml_bytes_unsafe_set\nfunction caml_bytes_set32(s,i,i32){\n  if (i >>> 0 >= s.l - 3) caml_bytes_bound_error();\n  var b4 = 0xFF & i32 >> 24,\n      b3 = 0xFF & i32 >> 16,\n      b2 = 0xFF & i32 >> 8,\n      b1 = 0xFF & i32;\n  caml_bytes_unsafe_set (s, i + 0, b1);\n  caml_bytes_unsafe_set (s, i + 1, b2);\n  caml_bytes_unsafe_set (s, i + 2, b3);\n  caml_bytes_unsafe_set (s, i + 3, b4);\n  return 0\n}\n\n//Provides: caml_string_set32\n//Requires: caml_failwith\n//If: js-string\nfunction caml_string_set32(s,i,i32){\n  caml_failwith(\"caml_string_set32\");\n}\n\n//Provides: caml_string_set32\n//Requires: caml_bytes_set32\n//If: !js-string\nfunction caml_string_set32(s,i,i32){\n  return caml_bytes_set32(s,i,i32);\n}\n\n//Provides: caml_bytes_set64\n//Requires: caml_bytes_bound_error, caml_bytes_unsafe_set\n//Requires: caml_int64_to_bytes\nfunction caml_bytes_set64(s,i,i64){\n  if (i >>> 0 >= s.l - 7) caml_bytes_bound_error();\n  var a = caml_int64_to_bytes(i64);\n  for(var j = 0; j < 8; j++) {\n    caml_bytes_unsafe_set (s, i + 7 - j, a[j]);\n  }\n  return 0\n}\n\n//Provides: caml_string_set64\n//Requires: caml_failwith\n//If: js-string\nfunction caml_string_set64(s,i,i64){\n  caml_failwith(\"caml_string_set64\");\n}\n\n//Provides: caml_string_set64\n//Requires: caml_bytes_set64\n//If: !js-string\nfunction caml_string_set64(s,i,i64){\n  return caml_bytes_set64(s,i,i64);\n}\n\n//Provides: caml_bytes_set\n//Requires: caml_bytes_bound_error, caml_bytes_unsafe_set\nfunction caml_bytes_set (s, i, c) {\n  if (i >>> 0 >= s.l) caml_bytes_bound_error();\n  return caml_bytes_unsafe_set (s, i, c);\n}\n\n//Provides: caml_bytes_of_utf16_jsstring\n//Requires: jsoo_is_ascii, caml_utf8_of_utf16, MlBytes\nfunction caml_bytes_of_utf16_jsstring (s) {\n  var tag = 9 /* BYTES | ASCII */;\n  if (!jsoo_is_ascii(s))\n    tag = 8 /* BYTES | NOT_ASCII */, s = caml_utf8_of_utf16(s);\n  return new MlBytes(tag, s, s.length);\n}\n\n\n//Provides: MlBytes\n//Requires: caml_convert_string_to_bytes, jsoo_is_ascii, caml_utf16_of_utf8\nfunction MlBytes (tag, contents, length) {\n  this.t=tag; this.c=contents; this.l=length;\n}\nMlBytes.prototype.toString = function(){\n  switch (this.t) {\n  case 9: /*BYTES | ASCII*/\n    return this.c;\n  default:\n    caml_convert_string_to_bytes(this);\n  case 0: /*BYTES | UNKOWN*/\n    if (jsoo_is_ascii(this.c)) {\n      this.t = 9; /*BYTES | ASCII*/\n      return this.c;\n    }\n    this.t = 8; /*BYTES | NOT_ASCII*/\n  case 8: /*BYTES | NOT_ASCII*/\n    return this.c;\n  }\n};\nMlBytes.prototype.toUtf16 = function (){\n  var r = this.toString();\n  if(this.t == 9) return r\n  return caml_utf16_of_utf8(r);\n}\nMlBytes.prototype.slice = function (){\n  var content = this.t == 4 ? this.c.slice() : this.c;\n  return new MlBytes(this.t,content,this.l);\n}\n\n//Provides: caml_convert_string_to_bytes\n//Requires: caml_str_repeat, caml_subarray_to_jsbytes\nfunction caml_convert_string_to_bytes (s) {\n  /* Assumes not BYTES */\n  if (s.t == 2 /* PARTIAL */)\n    s.c += caml_str_repeat(s.l - s.c.length, '\\0')\n  else\n    s.c = caml_subarray_to_jsbytes (s.c, 0, s.c.length);\n  s.t = 0; /*BYTES | UNKOWN*/\n}\n\n//Provides: caml_convert_bytes_to_array\nfunction caml_convert_bytes_to_array (s) {\n  /* Assumes not ARRAY */\n  var a = new Uint8Array(s.l);\n  var b = s.c, l = b.length, i = 0;\n  for (; i < l; i++) a[i] = b.charCodeAt(i);\n  for (l = s.l; i < l; i++) a[i] = 0;\n  s.c = a;\n  s.t = 4; /* ARRAY */\n  return a;\n}\n\n//Provides: caml_uint8_array_of_bytes mutable\n//Requires: caml_convert_bytes_to_array\nfunction caml_uint8_array_of_bytes (s) {\n  if (s.t != 4 /* ARRAY */) caml_convert_bytes_to_array(s);\n  return s.c;\n}\n\n//Provides: caml_uint8_array_of_string mutable\n//Requires: caml_convert_bytes_to_array\n//Requires: caml_ml_string_length, caml_string_unsafe_get\nfunction caml_uint8_array_of_string (s) {\n  var l = caml_ml_string_length(s);\n  var a = new Uint8Array(l);\n  var i = 0;\n  for (; i < l; i++) a[i] = caml_string_unsafe_get(s,i);\n  return a;\n}\n\n//Provides: caml_create_string const\n//Requires: MlBytes, caml_invalid_argument\n//If: !js-string\nfunction caml_create_string(len) {\n  if(len < 0) caml_invalid_argument(\"String.create\");\n  return new MlBytes(len?2:9,\"\",len);\n}\n\n//Provides: caml_create_string const\n//Requires: caml_invalid_argument\n//If: js-string\nfunction caml_create_string(len) {\n  caml_invalid_argument(\"String.create\");\n}\n\n//Provides: caml_create_bytes const\n//Requires: MlBytes,caml_invalid_argument\nfunction caml_create_bytes(len) {\n  if (len < 0) caml_invalid_argument(\"Bytes.create\");\n  return new MlBytes(len?2:9,\"\",len);\n}\n\n//Provides: caml_string_of_array\n//Requires: caml_subarray_to_jsbytes, caml_string_of_jsbytes\nfunction caml_string_of_array (a) {\n  return caml_string_of_jsbytes(caml_subarray_to_jsbytes(a,0,a.length));\n}\n\n//Provides: caml_bytes_of_array\n//Requires: MlBytes\nfunction caml_bytes_of_array (a) {\n  if(! (a instanceof Uint8Array)) {\n    a = new Uint8Array(a);\n  }\n  return new MlBytes(4,a,a.length);\n}\n\n//Provides: caml_bytes_compare mutable\n//Requires: caml_convert_string_to_bytes\nfunction caml_bytes_compare(s1, s2) {\n  (s1.t & 6) && caml_convert_string_to_bytes(s1);\n  (s2.t & 6) && caml_convert_string_to_bytes(s2);\n  return (s1.c < s2.c)?-1:(s1.c > s2.c)?1:0;\n}\n\n\n//Provides: caml_bytes_equal mutable (const, const)\n//Requires: caml_convert_string_to_bytes\nfunction caml_bytes_equal(s1, s2) {\n  if(s1 === s2) return 1;\n  (s1.t & 6) && caml_convert_string_to_bytes(s1);\n  (s2.t & 6) && caml_convert_string_to_bytes(s2);\n  return (s1.c == s2.c)?1:0;\n}\n\n//Provides: caml_string_notequal mutable (const, const)\n//Requires: caml_string_equal\nfunction caml_string_notequal(s1, s2) { return 1-caml_string_equal(s1, s2); }\n\n//Provides: caml_bytes_notequal mutable (const, const)\n//Requires: caml_bytes_equal\nfunction caml_bytes_notequal(s1, s2) { return 1-caml_bytes_equal(s1, s2); }\n\n//Provides: caml_bytes_lessequal mutable\n//Requires: caml_convert_string_to_bytes\nfunction caml_bytes_lessequal(s1, s2) {\n  (s1.t & 6) && caml_convert_string_to_bytes(s1);\n  (s2.t & 6) && caml_convert_string_to_bytes(s2);\n  return (s1.c <= s2.c)?1:0;\n}\n\n//Provides: caml_bytes_lessthan mutable\n//Requires: caml_convert_string_to_bytes\nfunction caml_bytes_lessthan(s1, s2) {\n  (s1.t & 6) && caml_convert_string_to_bytes(s1);\n  (s2.t & 6) && caml_convert_string_to_bytes(s2);\n  return (s1.c < s2.c)?1:0;\n}\n\n//Provides: caml_string_greaterequal\n//Requires: caml_string_lessequal\nfunction caml_string_greaterequal(s1, s2) {\n  return caml_string_lessequal(s2,s1);\n}\n//Provides: caml_bytes_greaterequal\n//Requires: caml_bytes_lessequal\nfunction caml_bytes_greaterequal(s1, s2) {\n  return caml_bytes_lessequal(s2,s1);\n}\n\n//Provides: caml_string_greaterthan\n//Requires: caml_string_lessthan\nfunction caml_string_greaterthan(s1, s2) {\n  return caml_string_lessthan(s2, s1);\n}\n\n//Provides: caml_bytes_greaterthan\n//Requires: caml_bytes_lessthan\nfunction caml_bytes_greaterthan(s1, s2) {\n  return caml_bytes_lessthan(s2, s1);\n}\n\n//Provides: caml_fill_bytes\n//Requires: caml_str_repeat, caml_convert_bytes_to_array\n//Alias: caml_fill_string\nfunction caml_fill_bytes(s, i, l, c) {\n  if (l > 0) {\n    if (i == 0 && (l >= s.l || (s.t == 2 /* PARTIAL */ && l >= s.c.length))) {\n      if (c == 0) {\n        s.c = \"\";\n        s.t = 2; /* PARTIAL */\n      } else {\n        s.c = caml_str_repeat (l, String.fromCharCode(c));\n        s.t = (l == s.l)?0 /* BYTES | UNKOWN */ :2; /* PARTIAL */\n      }\n    } else {\n      if (s.t != 4 /* ARRAY */) caml_convert_bytes_to_array(s);\n      for (l += i; i < l; i++) s.c[i] = c;\n    }\n  }\n  return 0;\n}\n\n//Provides: caml_blit_bytes\n//Requires: caml_subarray_to_jsbytes, caml_convert_bytes_to_array\nfunction caml_blit_bytes(s1, i1, s2, i2, len) {\n  if (len == 0) return 0;\n  if ((i2 == 0) &&\n      (len >= s2.l || (s2.t == 2 /* PARTIAL */ && len >= s2.c.length))) {\n    s2.c = (s1.t == 4 /* ARRAY */)?\n      caml_subarray_to_jsbytes(s1.c, i1, len):\n      (i1 == 0 && s1.c.length == len)?s1.c:s1.c.substr(i1, len);\n    s2.t = (s2.c.length == s2.l)?0 /* BYTES | UNKOWN */ :2; /* PARTIAL */\n  } else if (s2.t == 2 /* PARTIAL */ && i2 == s2.c.length) {\n    s2.c += (s1.t == 4 /* ARRAY */)?\n      caml_subarray_to_jsbytes(s1.c, i1, len):\n      (i1 == 0 && s1.c.length == len)?s1.c:s1.c.substr(i1, len);\n    s2.t = (s2.c.length == s2.l)?0 /* BYTES | UNKOWN */ :2; /* PARTIAL */\n  } else {\n    if (s2.t != 4 /* ARRAY */) caml_convert_bytes_to_array(s2);\n    var c1 = s1.c, c2 = s2.c;\n    if (s1.t == 4 /* ARRAY */) {\n      if (i2 <= i1) {\n        for (var i = 0; i < len; i++) c2 [i2 + i] = c1 [i1 + i];\n      } else {\n        for (var i = len - 1; i >= 0; i--) c2 [i2 + i] = c1 [i1 + i];\n      }\n    } else {\n      var l = Math.min (len, c1.length - i1);\n      for (var i = 0; i < l; i++) c2 [i2 + i] = c1.charCodeAt(i1 + i);\n      for (; i < len; i++) c2 [i2 + i] = 0;\n    }\n  }\n  return 0;\n}\n\n//Provides: caml_blit_string\n//Requires: caml_blit_bytes, caml_bytes_of_string\nfunction caml_blit_string(a,b,c,d,e) {\n  caml_blit_bytes(caml_bytes_of_string(a),b,c,d,e);\n  return 0\n}\n\n//Provides: caml_ml_bytes_length const\nfunction caml_ml_bytes_length(s) { return s.l }\n\n//Provides: caml_string_concat\n//If: js-string\nfunction caml_string_concat(a,b) { return a + b }\n\n//Provides: caml_string_concat\n//Requires: caml_convert_string_to_bytes, MlBytes\n//If: !js-string\nfunction caml_string_concat(s1,s2){\n  (s1.t & 6) && caml_convert_string_to_bytes(s1);\n  (s2.t & 6) && caml_convert_string_to_bytes(s2);\n  return new MlBytes(s1.t,s1.c+s2.c,s1.l+s2.l)\n}\n\n\n//Provides: caml_string_unsafe_get const\n//If: js-string\nfunction caml_string_unsafe_get (s, i) {\n  return s.charCodeAt(i);\n}\n\n//Provides: caml_string_unsafe_set\n//Requires: caml_failwith\n//If: js-string\nfunction caml_string_unsafe_set (s, i, c) {\n  caml_failwith(\"caml_string_unsafe_set\");\n}\n\n//Provides: caml_ml_string_length const\n//If: js-string\nfunction caml_ml_string_length(s) {\n  return s.length\n}\n\n//Provides: caml_string_compare const\n//If: js-string\nfunction caml_string_compare(s1, s2) {\n  return (s1 < s2)?-1:(s1 > s2)?1:0;\n}\n\n//Provides: caml_string_equal const\n//If: js-string\nfunction caml_string_equal(s1, s2) {\n  if(s1 === s2) return 1;\n  return 0;\n}\n\n//Provides: caml_string_lessequal const\n//If: js-string\nfunction caml_string_lessequal(s1, s2) {\n  return (s1 <= s2)?1:0;\n}\n\n//Provides: caml_string_lessthan const\n//If: js-string\nfunction caml_string_lessthan(s1, s2) {\n  return (s1 < s2)?1:0;\n}\n\n//Provides: caml_string_of_bytes\n//Requires: caml_convert_string_to_bytes, caml_string_of_jsbytes\n//If: js-string\nfunction caml_string_of_bytes(s) {\n  (s.t & 6) && caml_convert_string_to_bytes(s);\n  return caml_string_of_jsbytes(s.c);\n}\n\n//Provides: caml_bytes_of_string const\n//Requires: caml_bytes_of_jsbytes, caml_jsbytes_of_string\n//If: js-string\nfunction caml_bytes_of_string(s) {\n  return caml_bytes_of_jsbytes(caml_jsbytes_of_string(s));\n}\n\n//Provides: caml_string_of_jsbytes const\n//If: js-string\nfunction caml_string_of_jsbytes(x) { return x }\n\n//Provides: caml_jsbytes_of_string const\n//If: js-string\nfunction caml_jsbytes_of_string(x) { return x }\n\n//Provides: caml_jsstring_of_string const\n//Requires: jsoo_is_ascii, caml_utf16_of_utf8\n//If: js-string\nfunction caml_jsstring_of_string(s) {\n  if(jsoo_is_ascii(s))\n    return s;\n  return caml_utf16_of_utf8(s); }\n\n//Provides: caml_string_of_jsstring const\n//Requires: jsoo_is_ascii, caml_utf8_of_utf16, caml_string_of_jsbytes\n//If: js-string\nfunction caml_string_of_jsstring (s) {\n  if (jsoo_is_ascii(s))\n    return caml_string_of_jsbytes(s)\n  else return caml_string_of_jsbytes(caml_utf8_of_utf16(s));\n}\n\n//Provides: caml_bytes_of_jsbytes const\n//Requires: MlBytes\nfunction caml_bytes_of_jsbytes(s) { return new MlBytes(0,s,s.length); }\n\n\n// The section below should be used when use-js-string=false\n\n//Provides: caml_string_unsafe_get const\n//Requires: caml_bytes_unsafe_get\n//If: !js-string\nfunction caml_string_unsafe_get (s, i) {\n  return caml_bytes_unsafe_get(s,i);\n}\n\n//Provides: caml_string_unsafe_set\n//Requires: caml_bytes_unsafe_set\n//If: !js-string\nfunction caml_string_unsafe_set (s, i, c) {\n  return caml_bytes_unsafe_set(s,i,c);\n}\n\n//Provides: caml_ml_string_length const\n//Requires: caml_ml_bytes_length\n//If: !js-string\nfunction caml_ml_string_length(s) {\n  return caml_ml_bytes_length(s)\n}\n\n//Provides: caml_string_compare\n//Requires: caml_bytes_compare\n//If: !js-string\nfunction caml_string_compare(s1, s2) {\n  return caml_bytes_compare(s1,s2)\n}\n\n//Provides: caml_string_equal\n//Requires: caml_bytes_equal\n//If: !js-string\nfunction caml_string_equal(s1, s2) {\n  return caml_bytes_equal(s1,s2)\n}\n\n//Provides: caml_string_lessequal\n//Requires: caml_bytes_lessequal\n//If: !js-string\nfunction caml_string_lessequal(s1, s2) {\n  return caml_bytes_lessequal(s1,s2)\n}\n\n//Provides: caml_string_lessthan\n//Requires: caml_bytes_lessthan\n//If: !js-string\nfunction caml_string_lessthan(s1, s2) {\n  return caml_bytes_lessthan(s1,s2)\n}\n\n//Provides: caml_string_of_bytes\n//If: !js-string\nfunction caml_string_of_bytes(s) { return s }\n\n//Provides: caml_bytes_of_string const\n//If: !js-string\nfunction caml_bytes_of_string(s) { return s }\n\n//Provides: caml_string_of_jsbytes const\n//Requires: caml_bytes_of_jsbytes\n//If: !js-string\nfunction caml_string_of_jsbytes(s) { return caml_bytes_of_jsbytes(s); }\n\n//Provides: caml_jsbytes_of_string const\n//Requires: caml_convert_string_to_bytes\n//If: !js-string\nfunction caml_jsbytes_of_string(s) {\n  (s.t & 6) && caml_convert_string_to_bytes(s);\n  return s.c }\n\n//Provides: caml_jsstring_of_string mutable (const)\n//If: !js-string\nfunction caml_jsstring_of_string(s){\n  return s.toUtf16()\n}\n\n//Provides: caml_string_of_jsstring\n//Requires: caml_bytes_of_utf16_jsstring\n//If: !js-string\nfunction caml_string_of_jsstring (s) {\n  return caml_bytes_of_utf16_jsstring(s);\n}\n\n//Provides: caml_is_ml_bytes\n//Requires: MlBytes\nfunction caml_is_ml_bytes(s) {\n  return (s instanceof MlBytes);\n}\n\n//Provides: caml_ml_bytes_content\n//Requires: MlBytes, caml_convert_string_to_bytes\nfunction caml_ml_bytes_content(s) {\n  switch (s.t & 6) {\n  default: /* PARTIAL */\n    caml_convert_string_to_bytes(s);\n  case 0: /* BYTES */\n    return s.c;\n  case 4:\n    return s.c\n  }\n}\n\n//Provides: caml_is_ml_string\n//Requires: jsoo_is_ascii\n//If: js-string\nfunction caml_is_ml_string(s) {\n  return (typeof s === \"string\" && !/[^\\x00-\\xff]/.test(s));\n}\n\n//Provides: caml_is_ml_string\n//Requires: caml_is_ml_bytes\n//If: !js-string\nfunction caml_is_ml_string(s) {\n  return caml_is_ml_bytes(s);\n}\n\n// The functions below are deprecated\n\n//Provides: caml_js_to_byte_string const\n//Requires: caml_string_of_jsbytes\nfunction caml_js_to_byte_string(s) { return caml_string_of_jsbytes(s) }\n\n//Provides: caml_new_string\n//Requires: caml_string_of_jsbytes\nfunction caml_new_string (s) { return caml_string_of_jsbytes(s) }\n\n//Provides: caml_js_from_string mutable (const)\n//Requires: caml_jsstring_of_string\nfunction caml_js_from_string(s) {\n  return caml_jsstring_of_string(s)\n}\n\n//Provides: caml_to_js_string mutable (const)\n//Requires: caml_jsstring_of_string\nfunction caml_to_js_string(s) {\n  return caml_jsstring_of_string(s)\n}\n\n//Provides: caml_js_to_string const\n//Requires: caml_string_of_jsstring\nfunction caml_js_to_string (s) {\n  return caml_string_of_jsstring(s);\n}\n\n\n//Provides: caml_array_of_string\n//Requires: caml_uint8_array_of_string\nfunction caml_array_of_string(x) { return caml_uint8_array_of_string(x) }\n\n//Provides: caml_array_of_bytes\n//Requires: caml_uint8_array_of_bytes\nfunction caml_array_of_bytes(x) { return caml_uint8_array_of_bytes(x) }\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Jérôme Vouillon, Hugo Heuzard, Andy Ray\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n//\n// Bigarray.\n//\n// - all bigarray types including Int64 and Complex.\n// - fortran + c layouts\n// - sub/slice/reshape\n// - retain fast path for 1d array access\n\n//Provides: caml_ba_init const\nfunction caml_ba_init() {\n  return 0;\n}\n\n//Provides: caml_ba_get_size\n//Requires: caml_invalid_argument\nfunction caml_ba_get_size(dims) {\n  var n_dims = dims.length;\n  var size = 1;\n  for (var i = 0; i < n_dims; i++) {\n    if (dims[i] < 0)\n      caml_invalid_argument(\"Bigarray.create: negative dimension\");\n    size = size * dims[i];\n  }\n  return size;\n}\n\n//Provides: caml_ba_get_size_per_element\nfunction caml_ba_get_size_per_element(kind){\n  switch(kind){\n  case 7: case 10: case 11: return 2;\n  default: return 1;\n  }\n}\n\n//Provides: caml_ba_create_buffer\n//Requires: caml_ba_get_size_per_element\n//Requires: caml_invalid_argument\nfunction caml_ba_create_buffer(kind, size){\n  var view;\n  switch(kind){\n  case 0:  view = Float32Array; break;\n  case 1:  view = Float64Array; break;\n  case 2:  view = Int8Array; break;\n  case 3:  view = Uint8Array; break;\n  case 4:  view = Int16Array; break;\n  case 5:  view = Uint16Array; break;\n  case 6:  view = Int32Array; break;\n  case 7:  view = Int32Array; break;\n  case 8:  view = Int32Array; break;\n  case 9:  view = Int32Array; break;\n  case 10: view = Float32Array; break;\n  case 11: view = Float64Array; break;\n  case 12: view = Uint8Array; break;\n  }\n  if (!view) caml_invalid_argument(\"Bigarray.create: unsupported kind\");\n  var data = new view(size * caml_ba_get_size_per_element(kind));\n  return data;\n}\n\n//Provides: caml_ba_custom_name\n//Version: < 4.11\nvar caml_ba_custom_name = \"_bigarray\"\n\n//Provides: caml_ba_custom_name\n//Version: >= 4.11\nvar caml_ba_custom_name = \"_bigarr02\"\n\n//Provides: Ml_Bigarray\n//Requires: caml_array_bound_error, caml_invalid_argument, caml_ba_custom_name\n//Requires: caml_int64_create_lo_hi, caml_int64_hi32, caml_int64_lo32\nfunction Ml_Bigarray (kind, layout, dims, buffer) {\n\n  this.kind   = kind ;\n  this.layout = layout;\n  this.dims   = dims;\n  this.data = buffer;\n}\n\nMl_Bigarray.prototype.caml_custom = caml_ba_custom_name;\n\nMl_Bigarray.prototype.offset = function (arg) {\n  var ofs = 0;\n  if(typeof arg === \"number\") arg = [arg];\n  if (! (arg instanceof Array)) caml_invalid_argument(\"bigarray.js: invalid offset\");\n  if (this.dims.length != arg.length)\n    caml_invalid_argument(\"Bigarray.get/set: bad number of dimensions\");\n  if(this.layout == 0 /* c_layout */) {\n    for (var i = 0; i < this.dims.length; i++) {\n      if (arg[i] < 0 || arg[i] >= this.dims[i])\n        caml_array_bound_error();\n      ofs = (ofs * this.dims[i]) + arg[i];\n    }\n  } else {\n    for (var i = this.dims.length - 1; i >= 0; i--) {\n      if (arg[i] < 1 || arg[i] > this.dims[i]){\n        caml_array_bound_error();\n      }\n      ofs = (ofs * this.dims[i]) + (arg[i] - 1);\n    }\n  }\n  return ofs;\n}\n\nMl_Bigarray.prototype.get = function (ofs) {\n  switch(this.kind){\n  case 7:\n    // Int64\n    var l = this.data[ofs * 2 + 0];\n    var h = this.data[ofs * 2 + 1];\n    return caml_int64_create_lo_hi(l,h);\n  case 10: case 11:\n    // Complex32, Complex64\n    var r = this.data[ofs * 2 + 0];\n    var i = this.data[ofs * 2 + 1];\n    return [254, r, i];\n  default:\n    return this.data[ofs]\n  }\n}\n\nMl_Bigarray.prototype.set = function (ofs,v) {\n  switch(this.kind){\n  case 7:\n    // Int64\n    this.data[ofs * 2 + 0] = caml_int64_lo32(v);\n    this.data[ofs * 2 + 1] = caml_int64_hi32(v);\n    break;\n  case 10: case 11:\n    // Complex32, Complex64\n    this.data[ofs * 2 + 0] = v[1];\n    this.data[ofs * 2 + 1] = v[2];\n    break;\n  default:\n    this.data[ofs] = v;\n    break;\n  }\n  return 0\n}\n\n\nMl_Bigarray.prototype.fill = function (v) {\n  switch(this.kind){\n  case 7:\n    // Int64\n    var a = caml_int64_lo32(v);\n    var b = caml_int64_hi32(v);\n    if(a == b){\n      this.data.fill(a);\n    }\n    else {\n      for(var i = 0; i<this.data.length; i++){\n        this.data[i] = (i%2 == 0) ? a : b;\n      }\n    }\n    break;\n  case 10: case 11:\n    // Complex32, Complex64\n    var im = v[1];\n    var re = v[2];\n    if(im == re){\n      this.data.fill(im);\n    }\n    else {\n      for(var i = 0; i<this.data.length; i++){\n        this.data[i] = (i%2 == 0) ? im : re;\n      }\n    }\n    break;\n  default:\n    this.data.fill(v);\n    break;\n  }\n}\n\n\nMl_Bigarray.prototype.compare = function (b, total) {\n  if (this.layout != b.layout || this.kind != b.kind) {\n    var k1 = this.kind | (this.layout << 8);\n    var k2 =    b.kind | (b.layout << 8);\n    return k2 - k1;\n  }\n  if (this.dims.length != b.dims.length) {\n    return b.dims.length - this.dims.length;\n  }\n  for (var i = 0; i < this.dims.length; i++)\n    if (this.dims[i] != b.dims[i])\n      return (this.dims[i] < b.dims[i]) ? -1 : 1;\n  switch (this.kind) {\n  case 0:\n  case 1:\n  case 10:\n  case 11:\n    // Floats\n    var x, y;\n    for (var i = 0; i < this.data.length; i++) {\n      x = this.data[i];\n      y = b.data[i];\n      if (x < y)\n        return -1;\n      if (x > y)\n        return 1;\n      if (x != y) {\n        if (!total) return NaN;\n        if (x == x) return 1;\n        if (y == y) return -1;\n      }\n    }\n    break;\n  case 7:\n    // Int64\n    for (var i = 0; i < this.data.length; i+=2) {\n      // Check highest bits first\n      if (this.data[i+1] < b.data[i+1])\n        return -1;\n      if (this.data[i+1] > b.data[i+1])\n        return 1;\n      if ((this.data[i] >>> 0) < (b.data[i] >>> 0))\n        return -1;\n      if ((this.data[i] >>> 0) > (b.data[i] >>> 0))\n        return 1;\n    }\n    break;\n  case 2:\n  case 3:\n  case 4:\n  case 5:\n  case 6:\n  case 8:\n  case 9:\n  case 12:\n    for (var i = 0; i < this.data.length; i++) {\n      if (this.data[i] < b.data[i])\n        return -1;\n      if (this.data[i] > b.data[i])\n        return 1;\n    }\n    break;\n  }\n  return 0;\n}\n\n//Provides: Ml_Bigarray_c_1_1\n//Requires: Ml_Bigarray, caml_array_bound_error, caml_invalid_argument\nfunction Ml_Bigarray_c_1_1(kind, layout, dims, buffer) {\n  this.kind   = kind ;\n  this.layout = layout;\n  this.dims   = dims;\n  this.data   = buffer;\n}\n\nMl_Bigarray_c_1_1.prototype = new Ml_Bigarray()\nMl_Bigarray_c_1_1.prototype.offset = function (arg) {\n  if(typeof arg !== \"number\"){\n    if((arg instanceof Array) && arg.length == 1)\n      arg = arg[0];\n    else caml_invalid_argument(\"Ml_Bigarray_c_1_1.offset\");\n  }\n  if (arg < 0 || arg >= this.dims[0])\n    caml_array_bound_error();\n  return arg;\n}\n\nMl_Bigarray_c_1_1.prototype.get = function (ofs) {\n  return this.data[ofs];\n}\n\nMl_Bigarray_c_1_1.prototype.set = function (ofs,v) {\n  this.data[ofs] = v;\n  return 0\n}\n\nMl_Bigarray_c_1_1.prototype.fill = function (v) {\n  this.data.fill(v);\n  return 0\n}\n\n//Provides: caml_ba_compare\nfunction caml_ba_compare(a,b,total){\n  return a.compare(b,total)\n}\n\n//Provides: caml_ba_create_unsafe\n//Requires: Ml_Bigarray, Ml_Bigarray_c_1_1, caml_ba_get_size, caml_ba_get_size_per_element\n//Requires: caml_invalid_argument\nfunction caml_ba_create_unsafe(kind, layout, dims, data){\n  var size_per_element = caml_ba_get_size_per_element(kind);\n  if(caml_ba_get_size(dims) * size_per_element != data.length) {\n    caml_invalid_argument(\"length doesn't match dims\");\n  }\n  if(layout == 0 && // c_layout\n     dims.length == 1 && // Array1\n     size_per_element == 1) // 1-to-1 mapping\n    return new Ml_Bigarray_c_1_1(kind, layout, dims, data);\n  return new Ml_Bigarray(kind, layout, dims, data);\n\n}\n\n\n//Provides: caml_ba_create\n//Requires: caml_js_from_array\n//Requires: caml_ba_get_size, caml_ba_create_unsafe\n//Requires: caml_ba_create_buffer\nfunction caml_ba_create(kind, layout, dims_ml) {\n  var dims = caml_js_from_array(dims_ml);\n  var data = caml_ba_create_buffer(kind, caml_ba_get_size(dims));\n  return caml_ba_create_unsafe(kind, layout, dims, data);\n}\n\n//Provides: caml_ba_change_layout\n//Requires: caml_ba_create_unsafe\nfunction caml_ba_change_layout(ba, layout) {\n  if(ba.layout == layout) return ba;\n  var new_dims = []\n  for(var i = 0; i < ba.dims.length; i++) new_dims[i] = ba.dims[ba.dims.length - i - 1];\n  return caml_ba_create_unsafe(ba.kind, layout, new_dims, ba.data);\n}\n\n//Provides: caml_ba_kind\nfunction caml_ba_kind(ba) {\n  return ba.kind;\n}\n\n//Provides: caml_ba_layout\nfunction caml_ba_layout(ba) {\n  return ba.layout;\n}\n\n//Provides: caml_ba_num_dims\nfunction caml_ba_num_dims(ba) {\n  return ba.dims.length;\n}\n\n//Provides: caml_ba_dim\n//Requires: caml_invalid_argument\nfunction caml_ba_dim(ba, i) {\n  if (i < 0 || i >= ba.dims.length)\n    caml_invalid_argument(\"Bigarray.dim\");\n  return ba.dims[i];\n}\n\n//Provides: caml_ba_dim_1\n//Requires: caml_ba_dim\nfunction caml_ba_dim_1(ba) {\n  return caml_ba_dim(ba, 0);\n}\n\n//Provides: caml_ba_dim_2\n//Requires: caml_ba_dim\nfunction caml_ba_dim_2(ba) {\n  return caml_ba_dim(ba, 1);\n}\n\n//Provides: caml_ba_dim_3\n//Requires: caml_ba_dim\nfunction caml_ba_dim_3(ba) {\n  return caml_ba_dim(ba, 2);\n}\n\n//Provides: caml_ba_get_generic\n//Requires: caml_js_from_array\nfunction caml_ba_get_generic(ba, i) {\n  var ofs = ba.offset(caml_js_from_array(i));\n  return ba.get(ofs);\n}\n\n//Provides: caml_ba_uint8_get16\n//Requires: caml_array_bound_error\nfunction caml_ba_uint8_get16(ba, i0) {\n  var ofs = ba.offset(i0);\n  if(ofs + 1 >= ba.data.length) caml_array_bound_error();\n  var b1 = ba.get(ofs);\n  var b2 = ba.get(ofs + 1);\n  return (b1 | (b2 << 8));\n}\n\n//Provides: caml_ba_uint8_get32\n//Requires: caml_array_bound_error\nfunction caml_ba_uint8_get32(ba, i0) {\n  var ofs = ba.offset(i0);\n  if(ofs + 3 >= ba.data.length) caml_array_bound_error();\n  var b1 = ba.get(ofs+0);\n  var b2 = ba.get(ofs+1);\n  var b3 = ba.get(ofs+2);\n  var b4 = ba.get(ofs+3);\n  return ( (b1 << 0)  |\n           (b2 << 8)  |\n           (b3 << 16) |\n           (b4 << 24) );\n}\n\n//Provides: caml_ba_uint8_get64\n//Requires: caml_array_bound_error, caml_int64_of_bytes\nfunction caml_ba_uint8_get64(ba, i0) {\n  var ofs = ba.offset(i0);\n  if(ofs + 7 >= ba.data.length) caml_array_bound_error();\n  var b1 = ba.get(ofs+0);\n  var b2 = ba.get(ofs+1);\n  var b3 = ba.get(ofs+2);\n  var b4 = ba.get(ofs+3);\n  var b5 = ba.get(ofs+4);\n  var b6 = ba.get(ofs+5);\n  var b7 = ba.get(ofs+6);\n  var b8 = ba.get(ofs+7);\n  return caml_int64_of_bytes([b8,b7,b6,b5,b4,b3,b2,b1]);\n}\n\n//Provides: caml_ba_get_1\nfunction caml_ba_get_1(ba, i0) {\n  return ba.get(ba.offset(i0));\n}\n\n//Provides: caml_ba_get_2\nfunction caml_ba_get_2(ba, i0, i1) {\n  return ba.get(ba.offset([i0,i1]));\n}\n\n//Provides: caml_ba_get_3\nfunction caml_ba_get_3(ba, i0, i1, i2) {\n  return ba.get(ba.offset([i0,i1,i2]));\n}\n\n//Provides: caml_ba_set_generic\n//Requires: caml_js_from_array\nfunction caml_ba_set_generic(ba, i, v) {\n  ba.set(ba.offset(caml_js_from_array(i)), v);\n  return 0\n}\n\n//Provides: caml_ba_uint8_set16\n//Requires: caml_array_bound_error\nfunction caml_ba_uint8_set16(ba, i0, v) {\n  var ofs = ba.offset(i0);\n  if(ofs + 1 >= ba.data.length) caml_array_bound_error();\n  ba.set(ofs+0,  v        & 0xff);\n  ba.set(ofs+1, (v >>> 8) & 0xff);\n  return 0;\n}\n\n//Provides: caml_ba_uint8_set32\n//Requires: caml_array_bound_error\nfunction caml_ba_uint8_set32(ba, i0, v) {\n  var ofs = ba.offset(i0);\n  if(ofs + 3 >= ba.data.length) caml_array_bound_error();\n  ba.set(ofs+0,  v         & 0xff);\n  ba.set(ofs+1, (v >>> 8)  & 0xff);\n  ba.set(ofs+2, (v >>> 16) & 0xff);\n  ba.set(ofs+3, (v >>> 24) & 0xff);\n  return 0;\n}\n\n//Provides: caml_ba_uint8_set64\n//Requires: caml_array_bound_error, caml_int64_to_bytes\nfunction caml_ba_uint8_set64(ba, i0, v) {\n  var ofs = ba.offset(i0);\n  if(ofs + 7 >= ba.data.length) caml_array_bound_error();\n  var v = caml_int64_to_bytes(v);\n  for(var i = 0; i < 8; i++) ba.set(ofs+i, v[7-i])\n  return 0;\n}\n\n//Provides: caml_ba_set_1\nfunction caml_ba_set_1(ba, i0, v) {\n  ba.set(ba.offset(i0), v);\n  return 0\n}\n\n//Provides: caml_ba_set_2\nfunction caml_ba_set_2(ba, i0, i1, v) {\n  ba.set(ba.offset([i0,i1]), v);\n  return 0;\n}\n\n//Provides: caml_ba_set_3\nfunction caml_ba_set_3(ba, i0, i1, i2, v) {\n  ba.set(ba.offset([i0,i1,i2]), v);\n  return 0;\n}\n\n//Provides: caml_ba_fill\nfunction caml_ba_fill(ba, v) {\n  ba.fill(v);\n  return 0;\n}\n\n//Provides: caml_ba_blit\n//Requires: caml_invalid_argument\nfunction caml_ba_blit(src, dst) {\n  if (dst.dims.length != src.dims.length)\n    caml_invalid_argument(\"Bigarray.blit: dimension mismatch\");\n  for (var i = 0; i < dst.dims.length; i++)\n    if (dst.dims[i] != src.dims[i])\n      caml_invalid_argument(\"Bigarray.blit: dimension mismatch\");\n  dst.data.set(src.data);\n  return 0;\n}\n\n//Provides: caml_ba_sub\n//Requires: caml_invalid_argument, caml_ba_create_unsafe, caml_ba_get_size\n//Requires: caml_ba_get_size_per_element\nfunction caml_ba_sub(ba, ofs, len) {\n  var changed_dim;\n  var mul = 1;\n  if (ba.layout == 0) {\n    for (var i = 1; i < ba.dims.length; i++)\n      mul = mul * ba.dims[i];\n    changed_dim = 0;\n  } else {\n    for (var i = 0; i < (ba.dims.length - 1); i++)\n      mul = mul * ba.dims[i];\n    changed_dim = ba.dims.length - 1;\n    ofs = ofs - 1;\n  }\n  if (ofs < 0 || len < 0 || (ofs + len) > ba.dims[changed_dim]){\n    caml_invalid_argument(\"Bigarray.sub: bad sub-array\");\n  }\n  var new_dims = [];\n  for (var i = 0; i < ba.dims.length; i++)\n    new_dims[i] = ba.dims[i];\n  new_dims[changed_dim] = len;\n  mul *= caml_ba_get_size_per_element(ba.kind);\n  var new_data = ba.data.subarray(ofs * mul, (ofs + len) * mul);\n  return caml_ba_create_unsafe(ba.kind, ba.layout, new_dims, new_data);\n}\n\n//Provides: caml_ba_slice\n//Requires: caml_js_from_array, caml_ba_create_unsafe, caml_invalid_argument, caml_ba_get_size\n//Requires: caml_ba_get_size_per_element\nfunction caml_ba_slice(ba, vind) {\n  vind = caml_js_from_array(vind);\n  var num_inds = vind.length;\n  var index = [];\n  var sub_dims = [];\n  var ofs;\n\n  if (num_inds > ba.dims.length)\n    caml_invalid_argument(\"Bigarray.slice: too many indices\");\n\n  // Compute offset and check bounds\n  if (ba.layout == 0) {\n    for (var i = 0; i < num_inds; i++)\n      index[i] = vind[i];\n    for (; i < ba.dims.length; i++)\n      index[i] = 0;\n    sub_dims = ba.dims.slice(num_inds);\n  } else {\n    for (var i = 0; i < num_inds; i++)\n      index[ba.dims.length - num_inds + i] = vind[i];\n    for (var i = 0; i < ba.dims.length - num_inds; i++)\n      index[i] = 1;\n    sub_dims = ba.dims.slice(0, ba.dims.length - num_inds);\n  }\n  ofs = ba.offset(index);\n  var size = caml_ba_get_size(sub_dims);\n  var size_per_element = caml_ba_get_size_per_element(ba.kind);\n  var new_data = ba.data.subarray(ofs * size_per_element, (ofs + size) * size_per_element);\n  return caml_ba_create_unsafe(ba.kind, ba.layout, sub_dims, new_data);\n}\n\n//Provides: caml_ba_reshape\n//Requires: caml_js_from_array, caml_invalid_argument, caml_ba_create_unsafe, caml_ba_get_size\nfunction caml_ba_reshape(ba, vind) {\n  vind = caml_js_from_array(vind);\n  var new_dim = [];\n  var num_dims = vind.length;\n\n  if (num_dims < 0 || num_dims > 16){\n    caml_invalid_argument(\"Bigarray.reshape: bad number of dimensions\");\n  }\n  var num_elts = 1;\n  for (var i = 0; i < num_dims; i++) {\n    new_dim[i] = vind[i];\n    if (new_dim[i] < 0)\n      caml_invalid_argument(\"Bigarray.reshape: negative dimension\");\n    num_elts = num_elts * new_dim[i];\n  }\n\n  var size = caml_ba_get_size(ba.dims);\n  // Check that sizes agree\n  if (num_elts != size)\n    caml_invalid_argument(\"Bigarray.reshape: size mismatch\");\n  return caml_ba_create_unsafe(ba.kind, ba.layout, new_dim, ba.data);\n}\n\n//Provides: caml_ba_serialize\n//Requires: caml_int64_bits_of_float, caml_int64_to_bytes\n//Requires: caml_int32_bits_of_float\nfunction caml_ba_serialize(writer, ba, sz) {\n  writer.write(32, ba.dims.length);\n  writer.write(32, (ba.kind | (ba.layout << 8)));\n  if(ba.caml_custom == \"_bigarr02\")\n    for(var i = 0; i < ba.dims.length; i++) {\n      if(ba.dims[i] < 0xffff)\n        writer.write(16, ba.dims[i]);\n      else {\n        writer.write(16, 0xffff);\n        writer.write(32, 0);\n        writer.write(32, ba.dims[i]);\n      }\n    }\n  else\n    for(var i = 0; i < ba.dims.length; i++) writer.write(32,ba.dims[i])\n  switch(ba.kind){\n  case 2:  //Int8Array\n  case 3:  //Uint8Array\n  case 12: //Uint8Array\n    for(var i = 0; i < ba.data.length; i++){\n      writer.write(8, ba.data[i]);\n    }\n    break;\n  case 4:  // Int16Array\n  case 5:  // Uint16Array\n    for(var i = 0; i < ba.data.length; i++){\n      writer.write(16, ba.data[i]);\n    }\n    break;\n  case 6:  // Int32Array (int32)\n    for(var i = 0; i < ba.data.length; i++){\n      writer.write(32, ba.data[i]);\n    }\n    break;\n  case 8:  // Int32Array (int)\n  case 9:  // Int32Array (nativeint)\n    writer.write(8,0);\n    for(var i = 0; i < ba.data.length; i++){\n      writer.write(32, ba.data[i]);\n    }\n    break;\n  case 7:  // Int32Array (int64)\n    for(var i = 0; i < ba.data.length / 2; i++){\n      var b = caml_int64_to_bytes(ba.get(i));\n      for (var j = 0; j < 8; j++) writer.write (8, b[j]);\n    }\n    break;\n  case 1:  // Float64Array\n    for(var i = 0; i < ba.data.length; i++){\n      var b = caml_int64_to_bytes(caml_int64_bits_of_float(ba.get(i)));\n      for (var j = 0; j < 8; j++) writer.write (8, b[j]);\n    }\n    break;\n  case 0:  // Float32Array\n    for(var i = 0; i < ba.data.length; i++){\n      var b = caml_int32_bits_of_float(ba.get(i));\n      writer.write(32, b);\n    }\n    break;\n  case 10: // Float32Array (complex32)\n    for(var i = 0; i < ba.data.length / 2; i++){\n      var j = ba.get(i);\n      writer.write(32, caml_int32_bits_of_float(j[1]));\n      writer.write(32, caml_int32_bits_of_float(j[2]));\n    }\n    break;\n  case 11: // Float64Array (complex64)\n    for(var i = 0; i < ba.data.length / 2; i++){\n      var complex = ba.get(i);\n      var b = caml_int64_to_bytes(caml_int64_bits_of_float(complex[1]));\n      for (var j = 0; j < 8; j++) writer.write (8, b[j]);\n      var b = caml_int64_to_bytes(caml_int64_bits_of_float(complex[2]));\n      for (var j = 0; j < 8; j++) writer.write (8, b[j]);\n    }\n    break;\n  }\n  sz[0] = (4 + ba.dims.length) * 4;\n  sz[1] = (4 + ba.dims.length) * 8;\n}\n\n//Provides: caml_ba_deserialize\n//Requires: caml_ba_create_unsafe, caml_failwith\n//Requires: caml_ba_get_size\n//Requires: caml_int64_of_bytes, caml_int64_float_of_bits\n//Requires: caml_int32_float_of_bits\n//Requires: caml_ba_create_buffer\nfunction caml_ba_deserialize(reader, sz, name){\n  var num_dims = reader.read32s();\n  if (num_dims < 0 || num_dims > 16)\n    caml_failwith(\"input_value: wrong number of bigarray dimensions\");\n  var tag = reader.read32s();\n  var kind = tag & 0xff\n  var layout = (tag >> 8) & 1;\n  var dims = []\n  if(name == \"_bigarr02\")\n    for (var i = 0; i < num_dims; i++) {\n      var size_dim = reader.read16u();\n      if(size_dim == 0xffff){\n        var size_dim_hi = reader.read32u();\n        var size_dim_lo = reader.read32u();\n        if(size_dim_hi != 0)\n          caml_failwith(\"input_value: bigarray dimension overflow in 32bit\");\n        size_dim = size_dim_lo;\n      }\n      dims.push(size_dim);\n    }\n  else\n    for (var i = 0; i < num_dims; i++) dims.push(reader.read32u());\n  var size = caml_ba_get_size(dims);\n  var data = caml_ba_create_buffer(kind, size);\n  var ba = caml_ba_create_unsafe(kind, layout, dims, data);\n  switch(kind){\n  case 2:  //Int8Array\n    for(var i = 0; i < size; i++){\n      data[i] = reader.read8s();\n    }\n    break;\n  case 3:  //Uint8Array\n  case 12: //Uint8Array\n    for(var i = 0; i < size; i++){\n      data[i] = reader.read8u();\n    }\n    break;\n  case 4:  // Int16Array\n    for(var i = 0; i < size; i++){\n      data[i] = reader.read16s();\n    }\n    break;\n  case 5:  // Uint16Array\n    for(var i = 0; i < size; i++){\n      data[i] = reader.read16u();\n    }\n    break;\n  case 6:  // Int32Array (int32)\n    for(var i = 0; i < size; i++){\n      data[i] = reader.read32s();\n    }\n    break;\n  case 8:  // Int32Array (int)\n  case 9:  // Int32Array (nativeint)\n    var sixty = reader.read8u();\n    if(sixty) caml_failwith(\"input_value: cannot read bigarray with 64-bit OCaml ints\");\n    for(var i = 0; i < size; i++){\n      data[i] = reader.read32s();\n    }\n    break;\n  case 7: // (int64)\n    var t = new Array(8);;\n    for(var i = 0; i < size; i++){\n      for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n      var int64 = caml_int64_of_bytes(t);\n      ba.set(i,int64);\n    }\n    break;\n  case 1:  // Float64Array\n    var t = new Array(8);;\n    for(var i = 0; i < size; i++){\n      for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n      var f = caml_int64_float_of_bits(caml_int64_of_bytes(t));\n      ba.set(i,f);\n    }\n    break;\n  case 0:  // Float32Array\n    for(var i = 0; i < size; i++){\n      var f = caml_int32_float_of_bits(reader.read32s());\n      ba.set(i,f);\n    }\n    break;\n  case 10: // Float32Array (complex32)\n    for(var i = 0; i < size; i++){\n      var re = caml_int32_float_of_bits(reader.read32s());\n      var im = caml_int32_float_of_bits(reader.read32s());\n      ba.set(i,[254,re,im]);\n    }\n    break;\n  case 11: // Float64Array (complex64)\n    var t = new Array(8);;\n    for(var i = 0; i < size; i++){\n      for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n      var re = caml_int64_float_of_bits(caml_int64_of_bytes(t));\n      for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n      var im = caml_int64_float_of_bits(caml_int64_of_bytes(t));\n      ba.set(i,[254,re,im]);\n    }\n    break\n  }\n  sz[0] = (4 + num_dims) * 4;\n  return caml_ba_create_unsafe(kind, layout, dims, data);\n}\n\n//Deprecated\n//Provides: caml_ba_create_from\n//Requires: caml_ba_create_unsafe, caml_invalid_argument, caml_ba_get_size_per_element\nfunction caml_ba_create_from(data1, data2, jstyp, kind, layout, dims){\n  if(data2 || caml_ba_get_size_per_element(kind) == 2){\n    caml_invalid_argument(\"caml_ba_create_from: use return caml_ba_create_unsafe\");\n  }\n  return caml_ba_create_unsafe(kind, layout, dims, data1);\n}\n\n//Provides: caml_ba_hash const\n//Requires: caml_ba_get_size, caml_hash_mix_int, caml_hash_mix_float\nfunction caml_ba_hash(ba){\n  var num_elts = caml_ba_get_size(ba.dims);\n  var h = 0;\n  switch(ba.kind){\n  case 2:  //Int8Array\n  case 3:  //Uint8Array\n  case 12: //Uint8Array\n    if(num_elts > 256) num_elts = 256;\n    var w = 0, i =0;\n    for(i = 0; i + 4 <= ba.data.length; i+=4){\n      w = ba.data[i+0] | (ba.data[i+1] << 8) | (ba.data[i+2] << 16) | (ba.data[i+3] << 24);\n      h = caml_hash_mix_int(h,w);\n    }\n    w = 0;\n    switch (num_elts & 3) {\n    case 3: w  = ba.data[i+2] << 16;    /* fallthrough */\n    case 2: w |= ba.data[i+1] << 8;     /* fallthrough */\n    case 1: w |= ba.data[i+0];\n      h = caml_hash_mix_int(h, w);\n    }\n    break;\n  case 4:  // Int16Array\n  case 5:  // Uint16Array\n    if(num_elts > 128) num_elts = 128;\n    var w = 0, i =0;\n    for(i = 0; i + 2 <= ba.data.length; i+=2){\n      w = ba.data[i+0] | (ba.data[i+1] << 16);\n      h = caml_hash_mix_int(h,w);\n    }\n    if ((num_elts & 1) != 0)\n      h = caml_hash_mix_int(h, ba.data[i]);\n    break;\n  case 6:  // Int32Array (int32)\n    if (num_elts > 64) num_elts = 64;\n    for (var i = 0; i < num_elts; i++) h = caml_hash_mix_int(h, ba.data[i]);\n    break;\n  case 8:  // Int32Array (int)\n  case 9:  // Int32Array (nativeint)\n    if (num_elts > 64) num_elts = 64;\n    for (var i = 0; i < num_elts; i++) h = caml_hash_mix_int(h, ba.data[i]);\n    break;\n  case 7:  // Int32Array (int64)\n    if (num_elts > 32) num_elts = 32;\n    num_elts *= 2\n    for (var i = 0; i < num_elts; i++) {\n      h = caml_hash_mix_int(h, ba.data[i]);\n    }\n    break;\n  case 10: // Float32Array (complex32)\n    num_elts *=2; /* fallthrough */\n  case 0:  // Float32Array\n    if (num_elts > 64) num_elts = 64;\n    for (var i = 0; i < num_elts; i++) h = caml_hash_mix_float(h, ba.data[i]);\n    break;\n  case 11: // Float64Array (complex64)\n    num_elts *=2; /* fallthrough */\n  case 1:  // Float64Array\n    if (num_elts > 32) num_elts = 32;\n    for (var i = 0; i < num_elts; i++) h = caml_hash_mix_float(h, ba.data[i]);\n    break;\n  }\n  return h;\n}\n\n//Provides: caml_ba_to_typed_array mutable\nfunction caml_ba_to_typed_array(ba){\n  return ba.data;\n}\n\n//Provides: caml_ba_kind_of_typed_array mutable\n//Requires: caml_invalid_argument\nfunction caml_ba_kind_of_typed_array(ta){\n  var kind;\n  if      (ta instanceof Float32Array) kind = 0;\n  else if (ta instanceof Float64Array) kind = 1;\n  else if (ta instanceof Int8Array) kind = 2;\n  else if (ta instanceof Uint8Array) kind = 3;\n  else if (ta instanceof Uint8ClampedArray) kind = 3;\n  else if (ta instanceof Int16Array) kind = 4;\n  else if (ta instanceof Uint16Array) kind = 5;\n  else if (ta instanceof Int32Array) kind = 6;\n  else if (ta instanceof Uint32Array) kind = 6;\n  else caml_invalid_argument(\"caml_ba_kind_of_typed_array: unsupported kind\");\n  return kind;\n}\n\n//Provides: caml_ba_from_typed_array mutable\n//Requires: caml_ba_kind_of_typed_array\n//Requires: caml_ba_create_unsafe\nfunction caml_ba_from_typed_array(ta){\n  var kind = caml_ba_kind_of_typed_array(ta);\n  var ta =\n      /* Needed to avoid unsigned setters overflowing\n         the range of OCaml [int32] values. */\n      ta instanceof Uint32Array ?\n      new Int32Array(ta.buffer ,ta.byteOffset, ta.length) : ta;\n  return caml_ba_create_unsafe(kind, 0, [ta.length], ta);\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_marshal_constants\nvar caml_marshal_constants = {\n  PREFIX_SMALL_BLOCK:         0x80,\n  PREFIX_SMALL_INT:           0x40,\n  PREFIX_SMALL_STRING:        0x20,\n  CODE_INT8:                  0x00,\n  CODE_INT16:                 0x01,\n  CODE_INT32:                 0x02,\n  CODE_INT64:                 0x03,\n  CODE_SHARED8:               0x04,\n  CODE_SHARED16:              0x05,\n  CODE_SHARED32:              0x06,\n  CODE_BLOCK32:               0x08,\n  CODE_BLOCK64:               0x13,\n  CODE_STRING8:               0x09,\n  CODE_STRING32:              0x0A,\n  CODE_DOUBLE_BIG:            0x0B,\n  CODE_DOUBLE_LITTLE:         0x0C,\n  CODE_DOUBLE_ARRAY8_BIG:     0x0D,\n  CODE_DOUBLE_ARRAY8_LITTLE:  0x0E,\n  CODE_DOUBLE_ARRAY32_BIG:    0x0F,\n  CODE_DOUBLE_ARRAY32_LITTLE: 0x07,\n  CODE_CODEPOINTER:           0x10,\n  CODE_INFIXPOINTER:          0x11,\n  CODE_CUSTOM:                0x12,\n  CODE_CUSTOM_LEN:            0x18,\n  CODE_CUSTOM_FIXED:          0x19\n}\n\n\n//Provides: UInt8ArrayReader\n//Requires: caml_string_of_array, caml_jsbytes_of_string\nfunction UInt8ArrayReader (s, i) { this.s = s; this.i = i; }\nUInt8ArrayReader.prototype = {\n  read8u:function () { return this.s[this.i++]; },\n  read8s:function () { return this.s[this.i++] << 24 >> 24; },\n  read16u:function () {\n    var s = this.s, i = this.i;\n    this.i = i + 2;\n    return (s[i] << 8) | s[i + 1]\n  },\n  read16s:function () {\n    var s = this.s, i = this.i;\n    this.i = i + 2;\n    return (s[i] << 24 >> 16) | s[i + 1];\n  },\n  read32u:function () {\n    var s = this.s, i = this.i;\n    this.i = i + 4;\n    return ((s[i] << 24) | (s[i+1] << 16) |\n            (s[i+2] << 8) | s[i+3]) >>> 0;\n  },\n  read32s:function () {\n    var s = this.s, i = this.i;\n    this.i = i + 4;\n    return (s[i] << 24) | (s[i+1] << 16) |\n      (s[i+2] << 8) | s[i+3];\n  },\n  readstr:function (len) {\n    var i = this.i;\n    this.i = i + len;\n    return caml_string_of_array(this.s.subarray(i, i + len));\n  },\n  readuint8array:function (len) {\n    var i = this.i;\n    this.i = i + len;\n    return this.s.subarray(i, i + len);\n  }\n}\n\n\n//Provides: MlStringReader\n//Requires: caml_string_of_jsbytes, caml_jsbytes_of_string\nfunction MlStringReader (s, i) { this.s = caml_jsbytes_of_string(s); this.i = i; }\nMlStringReader.prototype = {\n  read8u:function () { return this.s.charCodeAt(this.i++); },\n  read8s:function () { return this.s.charCodeAt(this.i++) << 24 >> 24; },\n  read16u:function () {\n    var s = this.s, i = this.i;\n    this.i = i + 2;\n    return (s.charCodeAt(i) << 8) | s.charCodeAt(i + 1)\n  },\n  read16s:function () {\n    var s = this.s, i = this.i;\n    this.i = i + 2;\n    return (s.charCodeAt(i) << 24 >> 16) | s.charCodeAt(i + 1);\n  },\n  read32u:function () {\n    var s = this.s, i = this.i;\n    this.i = i + 4;\n    return ((s.charCodeAt(i) << 24) | (s.charCodeAt(i+1) << 16) |\n            (s.charCodeAt(i+2) << 8) | s.charCodeAt(i+3)) >>> 0;\n  },\n  read32s:function () {\n    var s = this.s, i = this.i;\n    this.i = i + 4;\n    return (s.charCodeAt(i) << 24) | (s.charCodeAt(i+1) << 16) |\n      (s.charCodeAt(i+2) << 8) | s.charCodeAt(i+3);\n  },\n  readstr:function (len) {\n    var i = this.i;\n    this.i = i + len;\n    return caml_string_of_jsbytes(this.s.substring(i, i + len));\n  },\n  readuint8array:function (len) {\n    var b = new Uint8Array(len);\n    var s = this.s;\n    var i = this.i;\n    for(var j = 0; j < len; j++) {\n      b[j] = s.charCodeAt(i + j);\n    }\n    this.i = i + len;\n    return b;\n  }\n}\n\n//Provides: BigStringReader\n//Requires: caml_string_of_array, caml_ba_get_1\nfunction BigStringReader (bs, i) { this.s = bs; this.i = i; }\nBigStringReader.prototype = {\n  read8u:function () { return caml_ba_get_1(this.s,this.i++); },\n  read8s:function () { return caml_ba_get_1(this.s,this.i++) << 24 >> 24; },\n  read16u:function () {\n    var s = this.s, i = this.i;\n    this.i = i + 2;\n    return (caml_ba_get_1(s,i) << 8) | caml_ba_get_1(s,i + 1)\n  },\n  read16s:function () {\n    var s = this.s, i = this.i;\n    this.i = i + 2;\n    return (caml_ba_get_1(s,i) << 24 >> 16) | caml_ba_get_1(s,i + 1);\n  },\n  read32u:function () {\n    var s = this.s, i = this.i;\n    this.i = i + 4;\n    return ((caml_ba_get_1(s,i)   << 24) | (caml_ba_get_1(s,i+1) << 16) |\n            (caml_ba_get_1(s,i+2) << 8)  | caml_ba_get_1(s,i+3)         ) >>> 0;\n  },\n  read32s:function () {\n    var s = this.s, i = this.i;\n    this.i = i + 4;\n    return (caml_ba_get_1(s,i)   << 24) | (caml_ba_get_1(s,i+1) << 16) |\n      (caml_ba_get_1(s,i+2) << 8)  | caml_ba_get_1(s,i+3);\n  },\n  readstr:function (len) {\n    var i = this.i;\n    var arr = new Array(len)\n    for(var j = 0; j < len; j++){\n      arr[j] = caml_ba_get_1(this.s, i+j);\n    }\n    this.i = i + len;\n    return caml_string_of_array(arr);\n  },\n  readuint8array:function (len) {\n    var i = this.i;\n    var offset = this.offset(i);\n    this.i = i + len;\n    return this.s.data.subarray(offset, offset + len);\n  }\n}\n\n\n\n//Provides: caml_float_of_bytes\n//Requires: caml_int64_float_of_bits, caml_int64_of_bytes\nfunction caml_float_of_bytes (a) {\n  return caml_int64_float_of_bits (caml_int64_of_bytes (a));\n}\n\n//Provides: caml_input_value_from_string mutable\n//Requires: MlStringReader, caml_input_value_from_reader\nfunction caml_input_value_from_string(s,ofs) {\n  var reader = new MlStringReader (s, typeof ofs==\"number\"?ofs:ofs[0]);\n  return caml_input_value_from_reader(reader, ofs)\n}\n\n//Provides: caml_input_value_from_bytes mutable\n//Requires: MlStringReader, caml_input_value_from_reader, caml_string_of_bytes\nfunction caml_input_value_from_bytes(s,ofs) {\n  var reader = new MlStringReader (caml_string_of_bytes(s), typeof ofs==\"number\"?ofs:ofs[0]);\n  return caml_input_value_from_reader(reader, ofs)\n}\n\n//Provides: caml_int64_unmarshal\n//Requires: caml_int64_of_bytes\nfunction caml_int64_unmarshal(reader, size){\n  var t = new Array(8);;\n  for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n  size[0] = 8;\n  return caml_int64_of_bytes (t);\n}\n\n//Provides: caml_int64_marshal\n//Requires: caml_int64_to_bytes\nfunction caml_int64_marshal(writer, v, sizes) {\n  var b = caml_int64_to_bytes (v);\n  for (var i = 0; i < 8; i++) writer.write (8, b[i]);\n  sizes[0] = 8; sizes[1] = 8;\n}\n\n//Provides: caml_int32_unmarshal\nfunction caml_int32_unmarshal(reader, size){\n  size[0] = 4;\n  return reader.read32s ();\n}\n\n//Provides: caml_nativeint_unmarshal\n//Requires: caml_failwith\nfunction caml_nativeint_unmarshal(reader, size){\n  switch (reader.read8u ()) {\n  case 1:\n    size[0] = 4;\n    return reader.read32s ();\n  case 2:\n    caml_failwith(\"input_value: native integer value too large\");\n  default: caml_failwith(\"input_value: ill-formed native integer\");\n  }\n}\n\n//Provides: caml_custom_ops\n//Requires: caml_int64_unmarshal, caml_int64_marshal, caml_int64_compare, caml_int64_hash\n//Requires: caml_int32_unmarshal, caml_nativeint_unmarshal\n//Requires: caml_ba_serialize, caml_ba_deserialize, caml_ba_compare, caml_ba_hash\nvar caml_custom_ops =\n    {\"_j\": {\n      deserialize : caml_int64_unmarshal,\n      serialize  : caml_int64_marshal,\n      fixed_length : 8,\n      compare : caml_int64_compare,\n      hash : caml_int64_hash\n    },\n     \"_i\": {\n       deserialize : caml_int32_unmarshal,\n       fixed_length : 4,\n     },\n     \"_n\": {\n       deserialize : caml_nativeint_unmarshal,\n       fixed_length : 4,\n     },\n     \"_bigarray\":{\n       deserialize : (function (reader, sz) {return caml_ba_deserialize (reader,sz,\"_bigarray\")}),\n       serialize : caml_ba_serialize,\n       compare : caml_ba_compare,\n       hash: caml_ba_hash,\n     },\n     \"_bigarr02\":{\n       deserialize : (function (reader, sz) {return caml_ba_deserialize (reader,sz,\"_bigarr02\")}),\n       serialize : caml_ba_serialize,\n       compare : caml_ba_compare,\n       hash: caml_ba_hash,\n     }\n    }\n\n//Provides: caml_input_value_from_reader mutable\n//Requires: caml_failwith\n//Requires: caml_float_of_bytes, caml_custom_ops\n//Requires: UInt8ArrayReader\n//Requires: caml_decompress_input\nfunction caml_input_value_from_reader(reader, ofs) {\n  function readvlq(overflow) {\n    var c = reader.read8u();\n    var n = c & 0x7F;\n    while ((c & 0x80) != 0) {\n      c = reader.read8u();\n      var n7 = n << 7;\n      if (n != n7 >> 7) overflow[0] = true;\n      n = n7 | (c & 0x7F);\n    }\n    return n;\n  }\n  var magic = reader.read32u ()\n  switch(magic){\n  case 0x8495A6BE: /* Intext_magic_number_small */\n    var header_len = 20;\n    var compressed = 0;\n    var data_len = reader.read32u ();\n    var uncompressed_data_len = data_len;\n    var num_objects = reader.read32u ();\n    var _size_32 = reader.read32u ();\n    var _size_64 = reader.read32u ();\n    break\n  case 0x8495A6BD: /* Intext_magic_number_compressed */\n    var header_len = reader.read8u() & 0x3F;\n    var compressed = 1;\n    var overflow = [false];\n    var data_len = readvlq(overflow);\n    var uncompressed_data_len = readvlq(overflow);\n    var num_objects = readvlq(overflow);\n    var _size_32 = readvlq (overflow);\n    var _size_64 = readvlq (overflow);\n    if(overflow[0]){\n        caml_failwith(\"caml_input_value_from_reader: object too large to be read back on this platform\");\n    }\n    break\n  case 0x8495A6BF: /* Intext_magic_number_big */\n    caml_failwith(\"caml_input_value_from_reader: object too large to be read back on a 32-bit platform\");\n    break\n  default:\n    caml_failwith(\"caml_input_value_from_reader: bad object\");\n    break;\n  }\n  var stack = [];\n  var intern_obj_table = (num_objects > 0)?[]:null;\n  var obj_counter = 0;\n  function intern_rec (reader) {\n    var code = reader.read8u ();\n    if (code >= 0x40 /*cst.PREFIX_SMALL_INT*/) {\n      if (code >= 0x80 /*cst.PREFIX_SMALL_BLOCK*/) {\n        var tag = code & 0xF;\n        var size = (code >> 4) & 0x7;\n        var v = [tag];\n        if (size == 0) return v;\n        if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n        stack.push(v, size);\n        return v;\n      } else\n        return (code & 0x3F);\n    } else {\n      if (code >= 0x20/*cst.PREFIX_SMALL_STRING */) {\n        var len = code & 0x1F;\n        var v = reader.readstr (len);\n        if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n        return v;\n      } else {\n        switch(code) {\n        case 0x00: //cst.CODE_INT8:\n          return reader.read8s ();\n        case 0x01: //cst.CODE_INT16:\n          return reader.read16s ();\n        case 0x02: //cst.CODE_INT32:\n          return reader.read32s ();\n        case 0x03: //cst.CODE_INT64:\n          caml_failwith(\"input_value: integer too large\");\n          break;\n        case 0x04: //cst.CODE_SHARED8:\n          var offset = reader.read8u ();\n          if(compressed == 0) offset = obj_counter - offset;\n          return intern_obj_table[offset];\n        case 0x05: //cst.CODE_SHARED16:\n          var offset = reader.read16u ();\n          if(compressed == 0) offset = obj_counter - offset;\n          return intern_obj_table[offset];\n        case 0x06: //cst.CODE_SHARED32:\n          var offset = reader.read32u ();\n          if(compressed == 0) offset = obj_counter - offset;\n          return intern_obj_table[offset];\n        case 0x08: //cst.CODE_BLOCK32:\n          var header = reader.read32u ();\n          var tag = header & 0xFF;\n          var size = header >> 10;\n          var v = [tag];\n          if (size == 0) return v;\n          if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n          stack.push(v, size);\n          return v;\n        case 0x13: //cst.CODE_BLOCK64:\n          caml_failwith (\"input_value: data block too large\");\n          break;\n        case 0x09: //cst.CODE_STRING8:\n          var len = reader.read8u();\n          var v = reader.readstr (len);\n          if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n          return v;\n        case 0x0A: //cst.CODE_STRING32:\n          var len = reader.read32u();\n          var v = reader.readstr (len);\n          if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n          return v;\n        case 0x0C: //cst.CODE_DOUBLE_LITTLE:\n          var t = new Array(8);;\n          for (var i = 0;i < 8;i++) t[7 - i] = reader.read8u ();\n          var v = caml_float_of_bytes (t);\n          if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n          return v;\n        case 0x0B: //cst.CODE_DOUBLE_BIG:\n          var t = new Array(8);;\n          for (var i = 0;i < 8;i++) t[i] = reader.read8u ();\n          var v = caml_float_of_bytes (t);\n          if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n          return v;\n        case 0x0E: //cst.CODE_DOUBLE_ARRAY8_LITTLE:\n          var len = reader.read8u();\n          var v = new Array(len+1);\n          v[0] = 254;\n          var t = new Array(8);;\n          if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n          for (var i = 1;i <= len;i++) {\n            for (var j = 0;j < 8;j++) t[7 - j] = reader.read8u();\n            v[i] = caml_float_of_bytes (t);\n          }\n          return v;\n        case 0x0D: //cst.CODE_DOUBLE_ARRAY8_BIG:\n          var len = reader.read8u();\n          var v = new Array(len+1);\n          v[0] = 254;\n          var t = new Array(8);;\n          if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n          for (var i = 1;i <= len;i++) {\n            for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n            v [i] = caml_float_of_bytes (t);\n          }\n          return v;\n        case 0x07: //cst.CODE_DOUBLE_ARRAY32_LITTLE:\n          var len = reader.read32u();\n          var v = new Array(len+1);\n          v[0] = 254;\n          if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n          var t = new Array(8);;\n          for (var i = 1;i <= len;i++) {\n            for (var j = 0;j < 8;j++) t[7 - j] = reader.read8u();\n            v[i] = caml_float_of_bytes (t);\n          }\n          return v;\n        case 0x0F: //cst.CODE_DOUBLE_ARRAY32_BIG:\n          var len = reader.read32u();\n          var v = new Array(len+1);\n          v[0] = 254;\n          var t = new Array(8);;\n          for (var i = 1;i <= len;i++) {\n            for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n            v [i] = caml_float_of_bytes (t);\n          }\n          return v;\n        case 0x10: //cst.CODE_CODEPOINTER:\n        case 0x11: //cst.CODE_INFIXPOINTER:\n          caml_failwith (\"input_value: code pointer\");\n          break;\n        case 0x12: //cst.CODE_CUSTOM:\n        case 0x18: //cst.CODE_CUSTOM_LEN:\n        case 0x19: //cst.CODE_CUSTOM_FIXED:\n          var c, s = \"\";\n          while ((c = reader.read8u ()) != 0) s += String.fromCharCode (c);\n          var ops = caml_custom_ops[s];\n          var expected_size;\n          if(!ops)\n            caml_failwith(\"input_value: unknown custom block identifier\");\n          switch(code){\n          case 0x12: // cst.CODE_CUSTOM (deprecated)\n            break;\n          case 0x19: // cst.CODE_CUSTOM_FIXED\n            if(!ops.fixed_length)\n              caml_failwith(\"input_value: expected a fixed-size custom block\");\n            expected_size = ops.fixed_length;\n            break;\n          case 0x18: // cst.CODE_CUSTOM_LEN\n            expected_size = reader.read32u ();\n            // Skip size64\n            reader.read32s(); reader.read32s();\n            break;\n          }\n          var old_pos = reader.i;\n          var size = [0];\n          var v = ops.deserialize(reader, size);\n          if(expected_size != undefined){\n            if(expected_size != size[0])\n              caml_failwith(\"input_value: incorrect length of serialized custom block\");\n          }\n          if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n          return v;\n        default:\n          caml_failwith (\"input_value: ill-formed message\");\n        }\n      }\n    }\n  }\n  if(compressed) {\n    if(caml_decompress_input) {\n      var data = reader.readuint8array(data_len);\n      var res = new Uint8Array(uncompressed_data_len);\n      var res = caml_decompress_input(data, res);\n      var reader = new UInt8ArrayReader(res, 0);\n    } else {\n      caml_failwith(\"input_value: compressed object, cannot decompress\");\n    }\n  }\n  var res = intern_rec (reader);\n  while (stack.length > 0) {\n    var size = stack.pop();\n    var v = stack.pop();\n    var d = v.length;\n    if (d < size) stack.push(v, size);\n    v[d] = intern_rec (reader);\n  }\n  if (typeof ofs!=\"number\") ofs[0] = reader.i;\n  return res;\n}\n\n//Provides: caml_marshal_header_size\n//Version: < 5.1.0\nvar caml_marshal_header_size = 20\n\n//Provides: caml_marshal_header_size\n//Version: >= 5.1.0\nvar caml_marshal_header_size = 16\n\n\n\n//Provides: caml_marshal_data_size mutable\n//Requires: caml_failwith, caml_bytes_unsafe_get\n//Requires: caml_uint8_array_of_bytes\n//Requires: UInt8ArrayReader\n//Requires: caml_marshal_header_size\nfunction caml_marshal_data_size (s, ofs) {\n  var r = new UInt8ArrayReader(caml_uint8_array_of_bytes(s), ofs);\n  function readvlq(overflow) {\n    var c = r.read8u();\n    var n = c & 0x7F;\n    while ((c & 0x80) != 0) {\n      c = r.read8u();\n      var n7 = n << 7;\n      if (n != n7 >> 7) overflow[0] = true;\n      n = n7 | (c & 0x7F);\n    }\n    return n;\n  }\n\n  switch(r.read32u()){\n  case 0x8495A6BE: /* Intext_magic_number_small */\n    var header_len = 20;\n    var data_len = r.read32u();\n    break;\n  case 0x8495A6BD: /* Intext_magic_number_compressed */\n    var header_len = r.read8u() & 0x3F;\n    var overflow = [false];\n    var data_len = readvlq(overflow);\n    if(overflow[0]){\n      caml_failwith(\"Marshal.data_size: object too large to be read back on this platform\");\n    }\n    break\n  case 0x8495A6BF: /* Intext_magic_number_big */\n  default:\n    caml_failwith(\"Marshal.data_size: bad object\");\n    break\n  }\n  return header_len - caml_marshal_header_size + data_len;\n}\n\n//Provides: MlObjectTable\nvar MlObjectTable;\nif (typeof globalThis.Map === 'undefined') {\n  MlObjectTable = function() {\n    /* polyfill (using linear search) */\n    function NaiveLookup(objs) { this.objs = objs; }\n    NaiveLookup.prototype.get = function(v) {\n      for (var i = 0; i < this.objs.length; i++) {\n        if (this.objs[i] === v) return i;\n      }\n    };\n    NaiveLookup.prototype.set = function() {\n      // Do nothing here. [MlObjectTable.store] will push to [this.objs] directly.\n    };\n\n    return function MlObjectTable() {\n      this.objs = []; this.lookup = new NaiveLookup(this.objs);\n    };\n  }();\n}\nelse {\n  MlObjectTable = function MlObjectTable() {\n    this.objs = []; this.lookup = new globalThis.Map();\n  };\n}\n\nMlObjectTable.prototype.store = function(v) {\n  this.lookup.set(v, this.objs.length);\n  this.objs.push(v);\n}\n\nMlObjectTable.prototype.recall = function(v) {\n  var i = this.lookup.get(v);\n  return (i === undefined)\n    ? undefined : this.objs.length - i;   /* index is relative */\n}\n\n//Provides: caml_output_val\n//Requires: caml_int64_to_bytes, caml_failwith\n//Requires: caml_int64_bits_of_float\n//Requires: caml_is_ml_bytes, caml_ml_bytes_length, caml_bytes_unsafe_get\n//Requires: caml_is_ml_string, caml_ml_string_length, caml_string_unsafe_get\n//Requires: MlObjectTable, caml_list_to_js_array, caml_custom_ops\n//Requires: caml_invalid_argument,caml_string_of_jsbytes, caml_is_continuation_tag\nvar caml_output_val = function (){\n  function Writer () { this.chunk = []; }\n  Writer.prototype = {\n    chunk_idx:20, block_len:0, obj_counter:0, size_32:0, size_64:0,\n    write:function (size, value) {\n      for (var i = size - 8;i >= 0;i -= 8)\n        this.chunk[this.chunk_idx++] = (value >> i) & 0xFF;\n    },\n    write_at:function (pos, size, value) {\n      var pos = pos;\n      for (var i = size - 8;i >= 0;i -= 8)\n        this.chunk[pos++] = (value >> i) & 0xFF;\n    },\n    write_code:function (size, code, value) {\n      this.chunk[this.chunk_idx++] = code;\n      for (var i = size - 8;i >= 0;i -= 8)\n        this.chunk[this.chunk_idx++] = (value >> i) & 0xFF;\n    },\n    write_shared:function (offset) {\n      if (offset < (1 << 8)) this.write_code(8, 0x04 /*cst.CODE_SHARED8*/, offset);\n      else if (offset < (1 << 16)) this.write_code(16, 0x05 /*cst.CODE_SHARED16*/, offset);\n      else this.write_code(32, 0x06 /*cst.CODE_SHARED32*/, offset);\n    },\n    pos:function () { return this.chunk_idx },\n    finalize:function () {\n      this.block_len = this.chunk_idx - 20;\n      this.chunk_idx = 0;\n      this.write (32, 0x8495A6BE);\n      this.write (32, this.block_len);\n      this.write (32, this.obj_counter);\n      this.write (32, this.size_32);\n      this.write (32, this.size_64);\n      return this.chunk;\n    }\n  }\n  return function (v, flags) {\n    flags = caml_list_to_js_array(flags);\n\n    var no_sharing = (flags.indexOf(0 /*Marshal.No_sharing*/) !== -1),\n        closures =  (flags.indexOf(1 /*Marshal.Closures*/) !== -1);\n    /* Marshal.Compat_32 is redundant since integers are 32-bit anyway */\n\n    if (closures)\n      console.warn(\"in caml_output_val: flag Marshal.Closures is not supported.\");\n\n    var writer = new Writer ();\n    var stack = [];\n    var intern_obj_table = no_sharing ? null : new MlObjectTable();\n\n    function memo(v) {\n      if (no_sharing) return false;\n      var existing_offset = intern_obj_table.recall(v);\n      if (existing_offset) { writer.write_shared(existing_offset); return true; }\n      else { intern_obj_table.store(v); return false; }\n    }\n\n    function extern_rec (v) {\n      if (v.caml_custom) {\n        if (memo(v)) return;\n        var name = v.caml_custom;\n        var ops = caml_custom_ops[name];\n        var sz_32_64 = [0,0];\n        if(!ops.serialize)\n          caml_invalid_argument(\"output_value: abstract value (Custom)\");\n        if(ops.fixed_length == undefined){\n          writer.write (8, 0x18 /*cst.CODE_CUSTOM_LEN*/);\n          for (var i = 0; i < name.length; i++)\n            writer.write (8, name.charCodeAt(i));\n          writer.write(8, 0);\n          var header_pos = writer.pos ();\n          for(var i = 0; i < 12; i++) {\n            writer.write(8, 0);\n          }\n          ops.serialize(writer, v, sz_32_64);\n          writer.write_at(header_pos, 32, sz_32_64[0]);\n          writer.write_at(header_pos + 4, 32, 0); // zero\n          writer.write_at(header_pos + 8, 32, sz_32_64[1]);\n        } else {\n          writer.write (8, 0x19 /*cst.CODE_CUSTOM_FIXED*/);\n          for (var i = 0; i < name.length; i++)\n            writer.write (8, name.charCodeAt(i));\n          writer.write(8, 0);\n          var old_pos = writer.pos();\n          ops.serialize(writer, v, sz_32_64);\n          if (ops.fixed_length != writer.pos() - old_pos)\n            caml_failwith(\"output_value: incorrect fixed sizes specified by \" + name);\n        }\n        writer.size_32 += 2 + ((sz_32_64[0] + 3) >> 2);\n        writer.size_64 += 2 + ((sz_32_64[1] + 7) >> 3);\n      }\n      else if (v instanceof Array && v[0] === (v[0]|0)) {\n        if (v[0] == 251) {\n          caml_failwith(\"output_value: abstract value (Abstract)\");\n        }\n        if (caml_is_continuation_tag(v[0]))\n          caml_invalid_argument(\"output_value: continuation value\");\n        if (v.length > 1 && memo(v)) return;\n        if (v[0] < 16 && v.length - 1 < 8)\n          writer.write (8, 0x80 /*cst.PREFIX_SMALL_BLOCK*/ + v[0] + ((v.length - 1)<<4));\n        else\n          writer.write_code(32, 0x08 /*cst.CODE_BLOCK32*/, ((v.length-1) << 10) | v[0]);\n        writer.size_32 += v.length;\n        writer.size_64 += v.length;\n        if (v.length > 1) stack.push (v, 1);\n      } else if (caml_is_ml_bytes(v)) {\n        if(!(caml_is_ml_bytes(caml_string_of_jsbytes(\"\")))) {\n          caml_failwith(\"output_value: [Bytes.t] cannot safely be marshaled with [--enable use-js-string]\");\n        }\n        if (memo(v)) return;\n        var len = caml_ml_bytes_length(v);\n        if (len < 0x20)\n          writer.write (8, 0x20 /*cst.PREFIX_SMALL_STRING*/ + len);\n        else if (len < 0x100)\n          writer.write_code (8, 0x09/*cst.CODE_STRING8*/, len);\n        else\n          writer.write_code (32, 0x0A /*cst.CODE_STRING32*/, len);\n        for (var i = 0;i < len;i++)\n          writer.write (8, caml_bytes_unsafe_get(v,i));\n        writer.size_32 += 1 + (((len + 4) / 4)|0);\n        writer.size_64 += 1 + (((len + 8) / 8)|0);\n      } else if (caml_is_ml_string(v)) {\n        if (memo(v)) return;\n        var len = caml_ml_string_length(v);\n        if (len < 0x20)\n          writer.write (8, 0x20 /*cst.PREFIX_SMALL_STRING*/ + len);\n        else if (len < 0x100)\n          writer.write_code (8, 0x09/*cst.CODE_STRING8*/, len);\n        else\n          writer.write_code (32, 0x0A /*cst.CODE_STRING32*/, len);\n        for (var i = 0;i < len;i++)\n          writer.write (8, caml_string_unsafe_get(v,i));\n        writer.size_32 += 1 + (((len + 4) / 4)|0);\n        writer.size_64 += 1 + (((len + 8) / 8)|0);\n      } else {\n        if (v != (v|0)){\n          var type_of_v = typeof v;\n          if(type_of_v != \"number\")\n            caml_failwith(\"output_value: abstract value (\"+type_of_v+\")\");\n          // If a float happens to be an integer it is serialized as an integer\n          // (Js_of_ocaml cannot tell whether the type of an integer number is\n          // float or integer.) This can result in unexpected crashes when\n          // unmarshalling using the standard runtime.\n          if (memo(v)) return;\n          var t = caml_int64_to_bytes(caml_int64_bits_of_float(v));\n          writer.write (8, 0x0C /*cst.CODE_DOUBLE_LITTLE*/);\n          for(var i = 0; i<8; i++){writer.write(8,t[7 - i])}\n          writer.size_32 += 3\n          writer.size_64 += 2\n        }\n        else if (v >= 0 && v < 0x40) {\n          writer.write (8, 0X40 /*cst.PREFIX_SMALL_INT*/ + v);\n        } else {\n          if (v >= -(1 << 7) && v < (1 << 7))\n            writer.write_code(8, 0x00 /*cst.CODE_INT8*/, v);\n          else if (v >= -(1 << 15) && v < (1 << 15))\n            writer.write_code(16, 0x01 /*cst.CODE_INT16*/, v);\n          else\n            writer.write_code(32, 0x02 /*cst.CODE_INT32*/, v);\n        }\n      }\n    }\n    extern_rec (v);\n    while (stack.length > 0) {\n      var i = stack.pop ();\n      var v = stack.pop ();\n      if (i + 1 < v.length) stack.push (v, i + 1);\n      extern_rec (v[i]);\n    }\n    if (intern_obj_table) writer.obj_counter = intern_obj_table.objs.length;\n    writer.finalize();\n    return writer.chunk;\n  }\n} ();\n\n//Provides: caml_output_value_to_string mutable\n//Requires: caml_output_val, caml_string_of_array\nfunction caml_output_value_to_string (v, flags) {\n  return caml_string_of_array (caml_output_val (v, flags));\n}\n\n//Provides: caml_output_value_to_bytes mutable\n//Requires: caml_output_val, caml_bytes_of_array\nfunction caml_output_value_to_bytes (v, flags) {\n  return caml_bytes_of_array (caml_output_val (v, flags));\n}\n\n//Provides: caml_output_value_to_buffer\n//Requires: caml_output_val, caml_failwith, caml_blit_bytes\nfunction caml_output_value_to_buffer (s, ofs, len, v, flags) {\n  var t = caml_output_val (v, flags);\n  if (t.length > len) caml_failwith (\"Marshal.to_buffer: buffer overflow\");\n  caml_blit_bytes(t, 0, s, ofs, t.length);\n  return 0;\n}\n","//Provides: caml_unix_gettimeofday\n//Alias: unix_gettimeofday\nfunction caml_unix_gettimeofday () {\n  return (new Date()).getTime() / 1000;\n}\n\n//Provides: caml_unix_time\n//Requires: caml_unix_gettimeofday\n//Alias: unix_time\nfunction caml_unix_time () {\n  return Math.floor(caml_unix_gettimeofday ());\n}\n\n//Provides: caml_unix_gmtime\n//Alias: unix_gmtime\nfunction caml_unix_gmtime (t) {\n  var d = new Date (t * 1000);\n  var d_num = d.getTime();\n  var januaryfirst = (new Date(Date.UTC(d.getUTCFullYear(), 0, 1))).getTime();\n  var doy = Math.floor((d_num - januaryfirst) / 86400000);\n  return BLOCK(0, d.getUTCSeconds(), d.getUTCMinutes(), d.getUTCHours(),\n               d.getUTCDate(), d.getUTCMonth(), d.getUTCFullYear() - 1900,\n               d.getUTCDay(), doy,\n               false | 0 /* for UTC daylight savings time is false */)\n}\n\n//Provides: caml_unix_localtime\n//Alias: unix_localtime\nfunction caml_unix_localtime (t) {\n  var d = new Date (t * 1000);\n  var d_num = d.getTime();\n  var januaryfirst = (new Date(d.getFullYear(), 0, 1)).getTime();\n  var doy = Math.floor((d_num - januaryfirst) / 86400000);\n  var jan = new Date(d.getFullYear(), 0, 1);\n  var jul = new Date(d.getFullYear(), 6, 1);\n  var stdTimezoneOffset = Math.max(jan.getTimezoneOffset(), jul.getTimezoneOffset());\n  return BLOCK(0, d.getSeconds(), d.getMinutes(), d.getHours(),\n               d.getDate(), d.getMonth(), d.getFullYear() - 1900,\n               d.getDay(), doy,\n               (d.getTimezoneOffset() < stdTimezoneOffset) | 0 /* daylight savings time  field. */)\n}\n\n//Provides: caml_unix_mktime\n//Requires: caml_unix_localtime\n//Alias: unix_mktime\nfunction caml_unix_mktime(tm){\n  var d = (new Date(tm[6]+1900,tm[5],tm[4],tm[3],tm[2],tm[1])).getTime();\n  var t = Math.floor(d / 1000);\n  var tm2 = caml_unix_localtime(t);\n  return BLOCK(0,t,tm2);\n}\n//Provides: caml_unix_startup const\n//Alias: win_startup\nfunction caml_unix_startup() {}\n\n//Provides: caml_unix_cleanup const\n//Alias: win_cleanup\nfunction caml_unix_cleanup() {}\n\n//Provides: caml_unix_filedescr_of_fd const\n//Alias: win_handle_fd\nfunction caml_unix_filedescr_of_fd(x) {return x;}\n\n//Provides: caml_unix_isatty\n//Requires: fs_node_supported\n//Alias: unix_isatty\nfunction caml_unix_isatty(fileDescriptor) {\n  if(fs_node_supported()) {\n    var tty = require('tty');\n    return tty.isatty(fileDescriptor)?1:0;\n  } else {\n    return 0;\n  }\n}\n\n\n//Provides: caml_unix_isatty\n//Alias: unix_isatty\n//If: browser\nfunction caml_unix_isatty(fileDescriptor) {\n  return 0;\n}\n\n//Provides: make_unix_err_args\n//Requires: caml_string_of_jsstring\nvar unix_error = [\n  /* ===Unix.error===\n   *\n   * This array is in order of the variant in OCaml\n   */\n  \"E2BIG\", \"EACCES\", \"EAGAIN\", \"EBADF\", \"EBUSY\", \"ECHILD\", \"EDEADLK\", \"EDOM\",\n  \"EEXIST\", \"EFAULT\", \"EFBIG\", \"EINTR\", \"EINVAL\", \"EIO\", \"EISDIR\", \"EMFILE\",\n  \"EMLINK\", \"ENAMETOOLONG\", \"ENFILE\", \"ENODEV\", \"ENOENT\", \"ENOEXEC\", \"ENOLCK\",\n  \"ENOMEM\", \"ENOSPC\", \"ENOSYS\", \"ENOTDIR\", \"ENOTEMPTY\", \"ENOTTY\", \"ENXIO\",\n  \"EPERM\", \"EPIPE\", \"ERANGE\", \"EROFS\", \"ESPIPE\", \"ESRCH\", \"EXDEV\", \"EWOULDBLOCK\",\n  \"EINPROGRESS\", \"EALREADY\", \"ENOTSOCK\", \"EDESTADDRREQ\", \"EMSGSIZE\",\n  \"EPROTOTYPE\", \"ENOPROTOOPT\", \"EPROTONOSUPPORT\", \"ESOCKTNOSUPPORT\",\n  \"EOPNOTSUPP\", \"EPFNOSUPPORT\", \"EAFNOSUPPORT\", \"EADDRINUSE\", \"EADDRNOTAVAIL\",\n  \"ENETDOWN\", \"ENETUNREACH\", \"ENETRESET\", \"ECONNABORTED\", \"ECONNRESET\", \"ENOBUFS\",\n  \"EISCONN\", \"ENOTCONN\", \"ESHUTDOWN\", \"ETOOMANYREFS\", \"ETIMEDOUT\", \"ECONNREFUSED\",\n  \"EHOSTDOWN\", \"EHOSTUNREACH\", \"ELOOP\", \"EOVERFLOW\"\n];\nfunction make_unix_err_args(code, syscall, path, errno) {\n  var variant = unix_error.indexOf(code);\n  if (variant < 0) {\n    // Default if undefined\n    if (errno == null) {\n      errno = -9999\n    }\n    // If none of the above variants, fallback to EUNKNOWNERR(int)\n    variant = BLOCK(0, errno);\n  }\n  var args = [\n    variant,\n    caml_string_of_jsstring(syscall || \"\"),\n    caml_string_of_jsstring(path || \"\")\n  ];\n  return args;\n}\n\n//Provides: caml_unix_stat\n//Requires: resolve_fs_device, caml_failwith\n//Alias: unix_stat\nfunction caml_unix_stat(name) {\n  var root = resolve_fs_device(name);\n  if (!root.device.stat) {\n    caml_failwith(\"caml_unix_stat: not implemented\");\n  }\n  return root.device.stat(root.rest, /* raise Unix_error */ true);\n}\n\n//Provides: caml_unix_stat_64\n//Requires: caml_unix_stat, caml_int64_of_int32\n//Alias: unix_stat_64\nfunction caml_unix_stat_64(name) {\n  var r = caml_unix_stat(name);\n  r[9] = caml_int64_of_int32(r[9]);\n  return r;\n}\n\n//Provides: caml_unix_lstat\n//Requires: resolve_fs_device, caml_failwith\n//Alias: unix_lstat\nfunction caml_unix_lstat(name) {\n  var root = resolve_fs_device(name);\n  if (!root.device.lstat) {\n    caml_failwith(\"caml_unix_lstat: not implemented\");\n  }\n  return root.device.lstat(root.rest, /* raise Unix_error */ true);\n}\n\n//Provides: caml_unix_lstat_64\n//Requires: caml_unix_lstat, caml_int64_of_int32\n//Alias: unix_lstat_64\nfunction caml_unix_lstat_64(name) {\n  var r = caml_unix_lstat(name);\n  r[9] = caml_int64_of_int32(r[9]);\n  return r;\n}\n\n//Provides: caml_unix_mkdir\n//Requires: resolve_fs_device, caml_failwith\n//Alias: unix_mkdir\nfunction caml_unix_mkdir(name, perm) {\n  var root = resolve_fs_device(name);\n  if (!root.device.mkdir) {\n    caml_failwith(\"caml_unix_mkdir: not implemented\");\n  }\n  return root.device.mkdir(root.rest, perm, /* raise Unix_error */ true);\n}\n\n//Provides: caml_unix_rmdir\n//Requires: resolve_fs_device, caml_failwith\n//Alias: unix_rmdir\nfunction caml_unix_rmdir(name) {\n  var root = resolve_fs_device(name);\n  if (!root.device.rmdir) {\n    caml_failwith(\"caml_unix_rmdir: not implemented\");\n  }\n  return root.device.rmdir(root.rest, /* raise Unix_error */ true);\n}\n\n//Provides: caml_unix_symlink\n//Requires: resolve_fs_device, caml_failwith\n//Alias: unix_symlink\nfunction caml_unix_symlink(to_dir, src, dst) {\n  var src_root = resolve_fs_device(src);\n  var dst_root = resolve_fs_device(dst);\n  if(src_root.device != dst_root.device)\n    caml_failwith(\"caml_unix_symlink: cannot symlink between two filesystems\");\n  if (!src_root.device.symlink) {\n    caml_failwith(\"caml_unix_symlink: not implemented\");\n  }\n  return src_root.device.symlink(to_dir, src_root.rest, dst_root.rest, /* raise Unix_error */ true);\n}\n\n//Provides: caml_unix_readlink\n//Requires: resolve_fs_device, caml_failwith\n//Alias: unix_readlink\nfunction caml_unix_readlink(name) {\n  var root = resolve_fs_device(name);\n  if (!root.device.readlink) {\n    caml_failwith(\"caml_unix_readlink: not implemented\");\n  }\n  return root.device.readlink(root.rest, /* raise Unix_error */ true);\n}\n\n//Provides: caml_unix_unlink\n//Requires: resolve_fs_device, caml_failwith\n//Alias: unix_unlink\nfunction caml_unix_unlink(name) {\n  var root = resolve_fs_device(name);\n  if (!root.device.unlink) {\n    caml_failwith(\"caml_unix_unlink: not implemented\");\n  }\n  return root.device.unlink(root.rest, /* raise Unix_error */ true);\n}\n\n//Provides: caml_unix_getuid\n//Requires: caml_raise_not_found\n//Alias: unix_getuid\nfunction caml_unix_getuid(unit) {\n  if(globalThis.process && globalThis.process.getuid){\n    return globalThis.process.getuid();\n  }\n  caml_raise_not_found();\n}\n\n//Provides: caml_unix_getpwuid\n//Requires: caml_raise_not_found\n//Alias: unix_getpwuid\nfunction caml_unix_getpwuid(unit) {\n  caml_raise_not_found();\n}\n\n//Provides: caml_unix_has_symlink\n//Requires: fs_node_supported\n//Alias: unix_has_symlink\nfunction caml_unix_has_symlink(unit) {\n  return fs_node_supported()?1:0\n}\n\n//Provides: caml_unix_opendir\n//Requires: resolve_fs_device, caml_failwith\n//Alias: unix_opendir\nfunction caml_unix_opendir(path) {\n  var root = resolve_fs_device(path);\n  if (!root.device.opendir) {\n    caml_failwith(\"caml_unix_opendir: not implemented\");\n  }\n  var dir_handle = root.device.opendir(root.rest, /* raise Unix_error */ true);\n  return { pointer : dir_handle, path: path }\n}\n\n//Provides: caml_unix_readdir\n//Requires: caml_raise_end_of_file\n//Requires: caml_string_of_jsstring\n//Requires: make_unix_err_args, caml_raise_with_args, caml_named_value\n//Alias: unix_readdir\nfunction caml_unix_readdir(dir_handle) {\n  var entry;\n  try {\n      entry = dir_handle.pointer.readSync();\n  } catch (e) {\n      var unix_error = caml_named_value('Unix.Unix_error');\n      caml_raise_with_args(unix_error, make_unix_err_args(\"EBADF\", \"readdir\", dir_handle.path));\n  }\n  if (entry === null) {\n      caml_raise_end_of_file();\n  } else {\n      return caml_string_of_jsstring(entry.name);\n  }\n}\n\n//Provides: caml_unix_closedir\n//Requires: make_unix_err_args, caml_raise_with_args, caml_named_value\n//Alias: unix_closedir\nfunction caml_unix_closedir(dir_handle) {\n  try {\n      dir_handle.pointer.closeSync();\n  } catch (e) {\n      var unix_error = caml_named_value('Unix.Unix_error');\n      caml_raise_with_args(unix_error, make_unix_err_args(\"EBADF\", \"closedir\", dir_handle.path));\n  }\n}\n\n//Provides: caml_unix_rewinddir\n//Requires: caml_unix_closedir, caml_unix_opendir\n//Alias: unix_rewinddir\nfunction caml_unix_rewinddir(dir_handle) {\n  caml_unix_closedir(dir_handle);\n  var new_dir_handle = caml_unix_opendir(dir_handle.path);\n  dir_handle.pointer = new_dir_handle.pointer;\n  return 0;\n}\n\n//Provides: caml_unix_findfirst\n//Requires: caml_jsstring_of_string, caml_string_of_jsstring\n//Requires: caml_unix_opendir, caml_unix_readdir\n//Alias: win_findfirst\nfunction caml_unix_findfirst(path) {\n  // The Windows code adds this glob to the path, so we need to remove it\n  var path_js = caml_jsstring_of_string(path);\n  path_js = path_js.replace(/(^|[\\\\\\/])\\*\\.\\*$/, \"\");\n  path = caml_string_of_jsstring(path_js);\n  // *.* is now stripped\n  var dir_handle = caml_unix_opendir(path);\n  var first_entry = caml_unix_readdir(dir_handle);\n  // The Windows bindings type dir_handle as an `int` but it's not in JS\n  return [0, first_entry, dir_handle];\n}\n\n//Provides: caml_unix_findnext\n//Requires: caml_unix_readdir\n//Alias: win_findnext\nfunction caml_unix_findnext(dir_handle) {\n  return caml_unix_readdir(dir_handle);\n}\n\n//Provides: caml_unix_findclose\n//Requires: caml_unix_closedir\n//Alias: win_findclose\nfunction caml_unix_findclose(dir_handle) {\n  return caml_unix_closedir(dir_handle);\n}\n\n\n//Provides: caml_unix_inet_addr_of_string const\n//Alias: unix_inet_addr_of_string\nfunction caml_unix_inet_addr_of_string () {return 0;}\n\n\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_call_gen (const, shallow)\n//If: !effects\n//Weakdef\nfunction caml_call_gen(f, args) {\n  var n = (f.l >= 0)?f.l:(f.l = f.length);\n  var argsLen = args.length;\n  var d = n - argsLen;\n  if (d == 0)\n    return f.apply(null, args);\n  else if (d < 0) {\n    var g = f.apply(null,args.slice(0,n));\n    if(typeof g !== \"function\") return g;\n    return caml_call_gen(g,args.slice(n));\n  }\n  else {\n    switch (d) {\n    case 1: {\n      var g = function (x){\n        var nargs = new Array(argsLen + 1);\n        for(var i = 0; i < argsLen; i++ ) nargs[i] = args[i];\n        nargs[argsLen] = x;\n        return f.apply(null, nargs)\n      };\n      break;\n    }\n    case 2: {\n      var g = function (x, y){\n        var nargs = new Array(argsLen + 2);\n        for(var i = 0; i < argsLen; i++ ) nargs[i] = args[i];\n        nargs[argsLen] = x;\n        nargs[argsLen + 1] = y;\n        return f.apply(null, nargs)\n      };\n      break;\n    }\n    default: {\n      var g = function (){\n        var extra_args = (arguments.length == 0)?1:arguments.length;\n        var nargs = new Array(args.length+extra_args);\n        for(var i = 0; i < args.length; i++ ) nargs[i] = args[i];\n        for(var i = 0; i < arguments.length; i++ ) nargs[args.length+i] = arguments[i];\n        return caml_call_gen(f, nargs)\n      };\n    }}\n    g.l = d;\n    return g;\n  }\n}\n\n//Provides: caml_call_gen (const, shallow)\n//If: effects\n//Weakdef\nfunction caml_call_gen(f, args) {\n  var n = (f.l >= 0)?f.l:(f.l = f.length);\n  var argsLen = args.length;\n  var d = n - argsLen;\n  if (d == 0) {\n    return f.apply(null, args);\n  } else if (d < 0) {\n    var rest = args.slice(n - 1);\n    var k = args [argsLen - 1];\n    args = args.slice(0, n);\n    args[n - 1] = function (g) {\n      if (typeof g !== \"function\") return k(g);\n      var args = rest.slice();\n      args[args.length - 1] = k;\n      return caml_call_gen(g, args); };\n    return f.apply(null, args);\n  } else {\n    argsLen--;\n    var k = args [argsLen];\n    switch (d) {\n    case 1: {\n      var g = function (x, y){\n        var nargs = new Array(argsLen + 2);\n        for(var i = 0; i < argsLen; i++ ) nargs[i] = args[i];\n        nargs[argsLen] = x;\n        nargs[argsLen + 1] = y;\n        return f.apply(null, nargs)\n      };\n      break;\n    }\n    case 2: {\n      var g = function (x, y, z){\n        var nargs = new Array(argsLen + 3);\n        for(var i = 0; i < argsLen; i++ ) nargs[i] = args[i];\n        nargs[argsLen] = x;\n        nargs[argsLen + 1] = y;\n        nargs[argsLen + 2] = z;\n        return f.apply(null, nargs)\n      };\n      break;\n    }\n    default: {\n      var g = function (){\n        var extra_args = (arguments.length == 0)?1:arguments.length;\n        var nargs = new Array(argsLen + extra_args);\n        for(var i = 0; i < argsLen; i++ ) nargs[i] = args[i];\n        for(var i = 0; i < arguments.length; i++ )\n          nargs[argsLen + i] = arguments[i];\n        return caml_call_gen(f, nargs)\n      };\n    }}\n    g.l = d + 1;\n    return k(g);\n  }\n}\n\n//Provides: caml_named_values\nvar caml_named_values = {};\n\n//Provides: caml_register_named_value (const,mutable)\n//Requires: caml_named_values, caml_jsbytes_of_string\nfunction caml_register_named_value(nm,v) {\n  caml_named_values[caml_jsbytes_of_string(nm)] = v;\n  return 0;\n}\n\n//Provides: caml_named_value\n//Requires: caml_named_values\nfunction caml_named_value(nm) {\n  return caml_named_values[nm]\n}\n\n//Provides: caml_global_data\nvar caml_global_data = [0];\n\n//Provides: caml_build_symbols\n//Requires: caml_jsstring_of_string\nfunction caml_build_symbols(symb) {\n  var r = {};\n  if(symb) {\n    for(var i = 1; i < symb.length; i++){\n      r[caml_jsstring_of_string(symb[i][1])] = symb[i][2]\n    }\n  }\n  return r;\n}\n\n//Provides: caml_register_global (const, shallow, const)\n//Requires: caml_global_data, caml_callback, caml_build_symbols\n//Requires: caml_failwith\nfunction caml_register_global (n, v, name_opt) {\n  if (name_opt) {\n    var name = name_opt;\n    if(globalThis.toplevelReloc) {\n      n = caml_callback(globalThis.toplevelReloc, [name]);\n    }\n    else if (caml_global_data.symbols) {\n      if(!caml_global_data.symidx) {\n        caml_global_data.symidx = caml_build_symbols(caml_global_data.symbols)\n      }\n      var nid = caml_global_data.symidx[name]\n      if(nid >= 0)\n        n = nid\n      else {\n        caml_failwith(\"caml_register_global: cannot locate \" + name);\n      }\n    }\n  }\n  caml_global_data[n + 1] = v;\n  if(name_opt) caml_global_data[name_opt] = v;\n}\n\n//Provides: caml_get_global_data mutable\n//Requires: caml_global_data\nfunction caml_get_global_data () { return caml_global_data; }\n\n//Provides: caml_is_printable const (const)\nfunction caml_is_printable(c) { return +(c > 31 && c < 127); }\n\n//Provides: caml_maybe_print_stats\nfunction caml_maybe_print_stats(unit) { return 0 }\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Sys\n\n//Provides: caml_raise_sys_error (const)\n//Requires: caml_raise_with_string, caml_global_data\nfunction caml_raise_sys_error (msg) {\n  caml_raise_with_string(caml_global_data.Sys_error, msg);\n}\n\n//Provides: caml_sys_exit\n//Requires: caml_invalid_argument\nfunction caml_sys_exit (code) {\n  if(globalThis.quit) globalThis.quit(code);\n  //nodejs\n  if(globalThis.process && globalThis.process.exit)\n    globalThis.process.exit(code);\n  caml_invalid_argument(\"Function 'exit' not implemented\");\n}\n\n//Provides: caml_is_special_exception\nfunction caml_is_special_exception(exn){\n  switch(exn[2]) {\n  case -8: // Match_failure\n  case -11: // Assert_failure\n  case -12: // Undefined_recursive_module\n    return 1;\n  default:\n    return 0;\n  }\n}\n\n//Provides: caml_format_exception\n//Requires: MlBytes, caml_is_special_exception\nfunction caml_format_exception(exn){\n  var r = \"\";\n  if(exn[0] == 0) {\n    r += exn[1][1];\n    if(exn.length == 3 && exn[2][0] == 0 && caml_is_special_exception(exn[1])) {\n\n      var bucket = exn[2];\n      var start = 1;\n    } else {\n      var start = 2\n      var bucket = exn;\n    }\n    r += \"(\";\n    for(var i = start; i < bucket.length; i ++){\n      if(i > start) r+=\", \";\n      var v = bucket[i]\n      if(typeof v == \"number\")\n        r+= v.toString();\n      else if(v instanceof MlBytes){\n        r+= '\"' + v.toString() + '\"';\n      }\n      else if(typeof v == \"string\"){\n        r+= '\"' + v.toString() + '\"';\n      }\n      else r += \"_\";\n    }\n    r += \")\"\n  } else if (exn[0] == 248){\n    r += exn[1]\n  }\n  return r\n}\n\n//Provides: caml_fatal_uncaught_exception\n//Requires: caml_named_value, caml_format_exception, caml_callback\nfunction caml_fatal_uncaught_exception(err){\n  if(err instanceof Array && (err[0] == 0 || err[0] == 248)) {\n    var handler = caml_named_value(\"Printexc.handle_uncaught_exception\");\n    if(handler) caml_callback(handler, [err,false]);\n    else {\n      var msg = caml_format_exception(err);\n      var at_exit = caml_named_value(\"Pervasives.do_at_exit\");\n      if(at_exit) caml_callback(at_exit, [0]);\n      console.error(\"Fatal error: exception \" + msg);\n      if(err.js_error) throw err.js_error;\n    }\n  }\n  else {\n    throw err\n  }\n}\n\n//Provides: caml_set_static_env\nfunction caml_set_static_env(k,v){\n  if(!globalThis.jsoo_static_env)\n    globalThis.jsoo_static_env = {}\n  globalThis.jsoo_static_env[k] = v;\n  return 0;\n}\n\n//Provides: jsoo_sys_getenv (const)\nfunction jsoo_sys_getenv(n) {\n  var process = globalThis.process;\n  //nodejs env\n  if(process\n     && process.env\n     && process.env[n] != undefined)\n    return process.env[n];\n  if(globalThis.jsoo_static_env\n     && globalThis.jsoo_static_env[n])\n    return globalThis.jsoo_static_env[n]\n}\n\n//Provides: caml_sys_getenv (const)\n//Requires: caml_raise_not_found\n//Requires: caml_string_of_jsstring\n//Requires: caml_jsstring_of_string\n//Requires: jsoo_sys_getenv\nfunction caml_sys_getenv (name) {\n  var r = jsoo_sys_getenv(caml_jsstring_of_string(name));\n  if(r === undefined)\n    caml_raise_not_found ();\n  return caml_string_of_jsstring(r)\n}\n\n//Provides: caml_sys_unsafe_getenv\n//Requires: caml_sys_getenv\nfunction caml_sys_unsafe_getenv(name){\n  return caml_sys_getenv (name);\n}\n\n//Provides: caml_argv\n//Requires: caml_string_of_jsstring\nvar caml_argv = ((function () {\n  var process = globalThis.process;\n  var main = \"a.out\";\n  var args = []\n\n  if(process\n     && process.argv\n     && process.argv.length > 1) {\n    var argv = process.argv\n    //nodejs\n    main = argv[1];\n    args = argv.slice(2);\n  }\n\n  var p = caml_string_of_jsstring(main);\n  var args2 = [0, p];\n  for(var i = 0; i < args.length; i++)\n    args2.push(caml_string_of_jsstring(args[i]));\n  return args2;\n})())\n\n//Provides: caml_executable_name\n//Requires: caml_argv\nvar caml_executable_name = caml_argv[1]\n\n//Provides: caml_sys_get_argv\n//Requires: caml_argv\nfunction caml_sys_get_argv (a) {\n  return [0, caml_argv[1], caml_argv];\n}\n\n//Provides: caml_sys_argv\n//Requires: caml_argv\nfunction caml_sys_argv (a) {\n  return caml_argv;\n}\n\n//Provides: caml_sys_modify_argv\n//Requires: caml_argv\nfunction caml_sys_modify_argv(arg){\n  caml_argv = arg;\n  return 0;\n}\n\n//Provides: caml_sys_executable_name const\n//Requires: caml_executable_name\nfunction caml_sys_executable_name(a){\n  return caml_executable_name\n}\n\n//Provides: caml_sys_system_command\n//Requires: caml_jsstring_of_string\nfunction caml_sys_system_command(cmd){\n  var cmd = caml_jsstring_of_string(cmd);\n  if (typeof require != \"undefined\"){\n    var child_process = require('child_process');\n    if(child_process && child_process.execSync)\n      try {\n        child_process.execSync(cmd,{stdio: 'inherit'});\n        return 0\n      } catch (e) {\n        return 1\n      }\n  }\n  else return 127;\n}\n\n//Provides: caml_sys_system_command\n//Requires: caml_jsstring_of_string\n//If: browser\nfunction caml_sys_system_command(cmd){\n  return 127;\n}\n\n//Provides: caml_sys_time mutable\nvar caml_initial_time = (new Date()).getTime() * 0.001;\nfunction caml_sys_time () {\n  var now = (new Date()).getTime();\n  return now * 0.001 - caml_initial_time;\n}\n\n//Provides: caml_sys_time_include_children\n//Requires: caml_sys_time\nfunction caml_sys_time_include_children(b) {\n  return caml_sys_time();\n}\n\n//Provides: caml_sys_random_seed mutable\n//The function needs to return an array since OCaml 4.0...\nfunction caml_sys_random_seed () {\n  if (globalThis.crypto) {\n     if (globalThis.crypto.getRandomValues) {\n       var a = globalThis.crypto.getRandomValues(new Int32Array(4));\n       return [0, a[0], a[1], a[2], a[3]];\n     } else if (globalThis.crypto.randomBytes) {\n       var a = new Int32Array(globalThis.crypto.randomBytes(16).buffer);\n       return [0, a[0], a[1], a[2], a[3]];\n     }\n  }\n  var now = (new Date()).getTime();\n  var x = now^0xffffffff*Math.random();\n  return [0,x];\n}\n\n//Provides: caml_sys_const_big_endian const\nfunction caml_sys_const_big_endian () { return 0; }\n\n//Provides: caml_sys_const_word_size const\nfunction caml_sys_const_word_size () { return 32; }\n\n//Provides: caml_sys_const_int_size const\nfunction caml_sys_const_int_size () { return 32; }\n\n//Provides: caml_sys_const_max_wosize const\n// max_int / 4 so that the following does not overflow\n//let max_string_length = word_size / 8 * max_array_length - 1;;\nfunction caml_sys_const_max_wosize () { return (0x7FFFFFFF/4) | 0;}\n\n//Provides: caml_sys_const_ostype_unix const\n//Requires: os_type\nfunction caml_sys_const_ostype_unix () { return os_type == \"Unix\" ? 1 : 0; }\n//Provides: caml_sys_const_ostype_win32 const\n//Requires: os_type\nfunction caml_sys_const_ostype_win32 () { return os_type == \"Win32\" ? 1 : 0; }\n//Provides: caml_sys_const_ostype_cygwin const\n//Requires: os_type\nfunction caml_sys_const_ostype_cygwin () { return os_type == \"Cygwin\" ? 1 : 0; }\n\n//Provides: caml_sys_const_backend_type const\n//Requires: caml_string_of_jsbytes\nfunction caml_sys_const_backend_type () {\n  return [0, caml_string_of_jsbytes(\"js_of_ocaml\")];\n}\n\n//Provides: os_type\nvar os_type = (globalThis.process &&\n               globalThis.process.platform &&\n               globalThis.process.platform == \"win32\") ? \"Cygwin\" : \"Unix\";\n\n\n//Provides: caml_sys_get_config const\n//Requires: caml_string_of_jsbytes, os_type\nfunction caml_sys_get_config () {\n  return [0, caml_string_of_jsbytes(os_type), 32, 0];\n}\n\n//Provides: caml_sys_isatty\nfunction caml_sys_isatty(_chan) {\n  return 0;\n}\n\n//Provides: caml_runtime_variant\n//Requires: caml_string_of_jsbytes\nfunction caml_runtime_variant(_unit) {\n  return caml_string_of_jsbytes(\"\");\n}\n//Provides: caml_runtime_parameters\n//Requires: caml_string_of_jsbytes\nfunction caml_runtime_parameters(_unit) {\n  return caml_string_of_jsbytes(\"\");\n}\n\n//Provides: caml_install_signal_handler const\nfunction caml_install_signal_handler(){return 0}\n\n//Provides: caml_runtime_warnings\nvar caml_runtime_warnings = 0;\n\n//Provides: caml_ml_enable_runtime_warnings\n//Requires: caml_runtime_warnings\nfunction caml_ml_enable_runtime_warnings (bool) {\n  caml_runtime_warnings = bool;\n  return 0;\n}\n\n//Provides: caml_ml_runtime_warnings_enabled\n//Requires: caml_runtime_warnings\nfunction caml_ml_runtime_warnings_enabled (_unit) {\n  return caml_runtime_warnings;\n}\n\n\n//Provides: caml_spacetime_enabled const (const)\nfunction caml_spacetime_enabled(_unit) {\n  return 0;\n}\n\n//Provides: caml_sys_const_naked_pointers_checked const (const)\nfunction caml_sys_const_naked_pointers_checked(_unit) {\n  return 0;\n}\n\n//Provides: caml_register_channel_for_spacetime const (const)\nfunction caml_register_channel_for_spacetime(_channel) {\n  return 0;\n}\n\n//Provides: caml_spacetime_only_works_for_native_code\n//Requires: caml_failwith\nfunction caml_spacetime_only_works_for_native_code() {\n  caml_failwith(\"Spacetime profiling only works for native code\");\n}\n\n//Provides: caml_xdg_defaults\n//Version: >= 5.2\nfunction caml_xdg_defaults(_unit) {\n  return 0; // empty list\n}\n\n//Provides: caml_sys_is_regular_file\n//Requires: resolve_fs_device\nfunction caml_sys_is_regular_file(name) {\n  var root = resolve_fs_device(name);\n  return root.device.isFile(root.rest);\n}\n//Always\n//Requires: caml_fatal_uncaught_exception\nfunction caml_setup_uncaught_exception_handler() {\n  var process = globalThis.process;\n  if(process && process.on) {\n    process.on('uncaughtException', function (err, origin) {\n      caml_fatal_uncaught_exception(err);\n      process.exit (2);\n    })\n  }\n  else if(globalThis.addEventListener){\n    globalThis.addEventListener('error', function(event){\n      if(event.error){\n        caml_fatal_uncaught_exception(event.error);\n      }\n    });\n  }\n}\ncaml_setup_uncaught_exception_handler();\n\n\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n\n//Provides: caml_record_backtrace_flag\n//Requires: jsoo_sys_getenv\nvar caml_record_backtrace_flag = FLAG(\"with-js-error\");\n\n(function () {\n  var r = jsoo_sys_getenv(\"OCAMLRUNPARAM\")\n  if(r !== undefined){\n    var l = r.split(\",\");\n    for(var i = 0; i < l.length; i++){\n      if(l[i] == \"b\") { caml_record_backtrace_flag = 1; break }\n      else if (l[i].startsWith(\"b=\")) {\n        caml_record_backtrace_flag = +(l[i].slice(2))}\n      else continue;\n    }\n  }\n}) ()\n\n\n//Provides: caml_ml_debug_info_status const\nfunction caml_ml_debug_info_status () { return 0; }\n//Provides: caml_backtrace_status\n//Requires: caml_record_backtrace_flag\nfunction caml_backtrace_status (_unit) { return caml_record_backtrace_flag ? 1 : 0; }\n//Provides: caml_get_exception_backtrace const\nfunction caml_get_exception_backtrace () { return 0; }\n//Provides: caml_get_exception_raw_backtrace const\nfunction caml_get_exception_raw_backtrace () { return [0]; }\n//Provides: caml_record_backtrace\n//Requires: caml_record_backtrace_flag\nfunction caml_record_backtrace (b) { caml_record_backtrace_flag = b; return 0; }\n//Provides: caml_convert_raw_backtrace const\nfunction caml_convert_raw_backtrace () { return [0]; }\n//Provides: caml_raw_backtrace_length\nfunction caml_raw_backtrace_length() { return 0; }\n//Provides: caml_raw_backtrace_next_slot\nfunction caml_raw_backtrace_next_slot() { return 0 }\n//Provides: caml_raw_backtrace_slot\n//Requires: caml_invalid_argument\nfunction caml_raw_backtrace_slot () {\n  caml_invalid_argument(\"Printexc.get_raw_backtrace_slot: index out of bounds\");\n}\n//Provides: caml_restore_raw_backtrace\nfunction caml_restore_raw_backtrace(exn, bt) { return 0 }\n//Provides: caml_get_current_callstack const\nfunction caml_get_current_callstack () { return [0]; }\n\n//Provides: caml_convert_raw_backtrace_slot\n//Requires: caml_failwith\nfunction caml_convert_raw_backtrace_slot(){\n  caml_failwith(\"caml_convert_raw_backtrace_slot\");\n}\n","// Js_of_ocaml library\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Jslib\n\n//Provides: caml_js_pure_expr const\n//Requires: caml_callback\nfunction caml_js_pure_expr (f) { return caml_callback(f, [0]); }\n\n//Provides: caml_js_set (mutable, const, mutable)\nfunction caml_js_set(o,f,v) { o[f]=v;return 0}\n//Provides: caml_js_get (mutable, const)\nfunction caml_js_get(o,f) { return o[f]; }\n//Provides: caml_js_delete (mutable, const)\nfunction caml_js_delete(o,f) { delete o[f]; return 0}\n\n//Provides: caml_js_instanceof (const, const)\nfunction caml_js_instanceof(o,c) { return (o instanceof c) ? 1 : 0; }\n\n//Provides: caml_js_typeof (const)\nfunction caml_js_typeof(o) { return typeof o; }\n\n//Provides:caml_trampoline\nfunction caml_trampoline(res) {\n  var c = 1;\n  while(res && res.joo_tramp){\n    res = res.joo_tramp.apply(null, res.joo_args);\n    c++;\n  }\n  return res;\n}\n\n//Provides:caml_trampoline_return\nfunction caml_trampoline_return(f,args) {\n  return {joo_tramp:f,joo_args:args};\n}\n\n//Provides:caml_stack_depth\n//If: effects\nvar caml_stack_depth = 0;\n\n//Provides:caml_stack_check_depth\n//If: effects\n//Requires:caml_stack_depth\nfunction caml_stack_check_depth() {\n    return --caml_stack_depth > 0;\n}\n\n//Provides: caml_callback\n//If: !effects\n//Requires:caml_call_gen\nvar caml_callback = caml_call_gen;\n\n//Provides: caml_callback\n//If: effects\n//Requires:caml_stack_depth, caml_call_gen, caml_exn_stack, caml_fiber_stack, caml_wrap_exception, caml_resume_stack, caml_fresh_oo_id, caml_named_value, caml_raise_with_arg, caml_string_of_jsbytes\n//Requires: caml_raise_constant\nfunction caml_callback(f,args) {\n  function uncaught_effect_handler(eff,k,ms) {\n    // Resumes the continuation k by raising exception Unhandled.\n    caml_resume_stack(k[1],ms);\n    var exn = caml_named_value(\"Effect.Unhandled\");\n    if(exn) caml_raise_with_arg(exn, eff);\n    else {\n      exn = [248,caml_string_of_jsbytes(\"Effect.Unhandled\"), caml_fresh_oo_id(0)];\n      caml_raise_constant(exn);\n    }\n  }\n  var saved_stack_depth = caml_stack_depth;\n  var saved_exn_stack = caml_exn_stack;\n  var saved_fiber_stack = caml_fiber_stack;\n  try {\n    caml_exn_stack = 0;\n    caml_fiber_stack =\n      {h:[0, 0, 0, uncaught_effect_handler], r:{k:0, x:0, e:0}};\n    var res = {joo_tramp: f,\n               joo_args: args.concat(function (x){return x;})};\n    do {\n      caml_stack_depth = 40;\n      try {\n        res = caml_call_gen(res.joo_tramp, res.joo_args);\n      } catch (e) {\n        /* Handle exception coming from JavaScript or from the runtime. */\n        if (!caml_exn_stack) throw e;\n        var handler = caml_exn_stack[1];\n        caml_exn_stack = caml_exn_stack[2];\n        res = {joo_tramp: handler,\n               joo_args: [caml_wrap_exception(e)]};\n      }\n    } while(res && res.joo_args)\n  } finally {\n    caml_stack_depth = saved_stack_depth;\n    caml_exn_stack = saved_exn_stack;\n    caml_fiber_stack = saved_fiber_stack;\n  }\n  return res;\n}\n\n//Provides: caml_is_js\nfunction caml_is_js() {\n  return 1;\n}\n\n//Provides: caml_jsoo_flags_use_js_string\nfunction caml_jsoo_flags_use_js_string(unit){\n  return FLAG(\"use-js-string\")\n}\n\n//Provides: caml_jsoo_flags_effects\nfunction caml_jsoo_flags_effects(unit){\n  return FLAG(\"effects\")\n}\n\n//Provides: caml_wrap_exception const (mutable)\n//Requires: caml_global_data,caml_string_of_jsstring,caml_named_value\nfunction caml_wrap_exception(e) {\n  if (FLAG(\"excwrap\")) {\n    if(e instanceof Array) return e;\n    var exn;\n    //Stack_overflow: chrome, safari\n    if(globalThis.RangeError\n       && e instanceof globalThis.RangeError\n       && e.message\n       && e.message.match(/maximum call stack/i))\n      exn = caml_global_data.Stack_overflow;\n    //Stack_overflow: firefox\n    else if(globalThis.InternalError\n       && e instanceof globalThis.InternalError\n       && e.message\n       && e.message.match(/too much recursion/i))\n      exn = caml_global_data.Stack_overflow;\n    //Wrap Error in Js.Error exception\n    else if(e instanceof globalThis.Error && caml_named_value(\"jsError\"))\n      exn = [0,caml_named_value(\"jsError\"),e];\n    else\n      //fallback: wrapped in Failure\n      exn = [0,caml_global_data.Failure,caml_string_of_jsstring (String(e))];\n    // We already have an error at hand, let's use it.\n    if (e instanceof globalThis.Error)\n      exn.js_error = e;\n    return exn;\n  } else\n    return e;\n}\n\n//Provides: caml_maybe_attach_backtrace\n//Requires: caml_exn_with_js_backtrace\n//Requires: caml_record_backtrace_flag\nfunction caml_maybe_attach_backtrace(exn, force) {\n  if(caml_record_backtrace_flag)\n    return caml_exn_with_js_backtrace(exn, force);\n  else return exn\n}\n\n// Experimental\n//Provides: caml_exn_with_js_backtrace\n//Requires: caml_global_data\nfunction caml_exn_with_js_backtrace(exn, force) {\n  //never reraise for constant exn\n  if(!exn.js_error || force || exn[0] == 248) exn.js_error = new globalThis.Error(\"Js exception containing backtrace\");\n  return exn;\n}\n\n\n//Provides: caml_js_error_option_of_exception\nfunction caml_js_error_option_of_exception(exn) {\n  if(exn.js_error) { return [0, exn.js_error]; }\n  return 0;\n}\n\n\n\n//Provides: caml_js_from_bool const (const)\nfunction caml_js_from_bool(x) { return !!x; }\n//Provides: caml_js_to_bool const (const)\nfunction caml_js_to_bool(x) { return +x; }\n//Provides: caml_js_from_float const (const)\n//Alias: caml_js_from_int32\n//Alias: caml_js_from_nativeint\nfunction caml_js_from_float(x) { return x; }\n//Provides: caml_js_to_float const (const)\nfunction caml_js_to_float(x) { return x; }\n//Provides: caml_js_to_int32 const (const)\n//Alias: caml_js_to_nativeint\nfunction caml_js_to_int32(x) { return x|0; }\n\n//Provides: caml_js_from_array mutable (shallow)\nfunction caml_js_from_array(a) {\n  return a.slice(1);\n}\n//Provides: caml_js_to_array mutable (shallow)\nfunction caml_js_to_array(a) {\n  var len = a.length;\n  var b = new Array(len+1);\n  b[0] = 0;\n  for(var i=0;i<len;i++) b[i+1] = a[i];\n  return b;\n}\n\n//Provides: caml_list_of_js_array const (mutable)\nfunction caml_list_of_js_array(a){\n  var l = 0;\n  for(var i=a.length - 1; i>=0; i--){\n    var e = a[i];\n    l = [0,e,l];\n  }\n  return l\n}\n\n//Provides: caml_list_to_js_array const (mutable)\nfunction caml_list_to_js_array(l){\n  var a = [];\n  for(; l !== 0; l = l[2]) {\n    a.push(l[1]);\n  }\n  return a;\n}\n\n//Provides: caml_js_var mutable\n//Requires: caml_jsstring_of_string\nfunction caml_js_var(x) {\n  var x = caml_jsstring_of_string(x);\n  //Checks that x has the form ident[.ident]*\n  if(!x.match(/^[a-zA-Z_$][a-zA-Z_$0-9]*(\\.[a-zA-Z_$][a-zA-Z_$0-9]*)*$/)){\n    console.error(\"caml_js_var: \\\"\" + x + \"\\\" is not a valid JavaScript variable. continuing ..\");\n    //console.error(\"Js.Unsafe.eval_string\")\n  }\n  return eval(x);\n}\n//Provides: caml_js_call (const, mutable, shallow)\n//Requires: caml_js_from_array\nfunction caml_js_call(f, o, args) { return f.apply(o, caml_js_from_array(args)); }\n//Provides: caml_js_fun_call (const, shallow)\n//Requires: caml_js_from_array\nfunction caml_js_fun_call(f, a) {\n  switch (a.length) {\n  case 1: return f();\n  case 2: return f (a[1]);\n  case 3: return f (a[1],a[2]);\n  case 4: return f (a[1],a[2],a[3]);\n  case 5: return f (a[1],a[2],a[3],a[4]);\n  case 6: return f (a[1],a[2],a[3],a[4],a[5]);\n  case 7: return f (a[1],a[2],a[3],a[4],a[5],a[6]);\n  case 8: return f (a[1],a[2],a[3],a[4],a[5],a[6],a[7]);\n  }\n  return f.apply(null, caml_js_from_array(a));\n}\n//Provides: caml_js_meth_call (mutable, const, shallow)\n//Requires: caml_jsstring_of_string\n//Requires: caml_js_from_array\nfunction caml_js_meth_call(o, f, args) {\n  return o[caml_jsstring_of_string(f)].apply(o, caml_js_from_array(args));\n}\n//Provides: caml_js_new (const, shallow)\n//Requires: caml_js_from_array\nfunction caml_js_new(c, a) {\n  switch (a.length) {\n  case 1: return new c;\n  case 2: return new c (a[1]);\n  case 3: return new c (a[1],a[2]);\n  case 4: return new c (a[1],a[2],a[3]);\n  case 5: return new c (a[1],a[2],a[3],a[4]);\n  case 6: return new c (a[1],a[2],a[3],a[4],a[5]);\n  case 7: return new c (a[1],a[2],a[3],a[4],a[5],a[6]);\n  case 8: return new c (a[1],a[2],a[3],a[4],a[5],a[6],a[7]);\n  }\n  function F() { return c.apply(this, caml_js_from_array(a)); }\n  F.prototype = c.prototype;\n  return new F;\n}\n//Provides: caml_ojs_new_arr (const, shallow)\n//Requires: caml_js_from_array\nfunction caml_ojs_new_arr(c, a) {\n  switch (a.length) {\n  case 0: return new c;\n  case 1: return new c (a[0]);\n  case 2: return new c (a[0],a[1]);\n  case 3: return new c (a[0],a[1],a[2]);\n  case 4: return new c (a[0],a[1],a[2],a[3]);\n  case 5: return new c (a[0],a[1],a[2],a[3],a[4]);\n  case 6: return new c (a[0],a[1],a[2],a[3],a[4],a[5]);\n  case 7: return new c (a[0],a[1],a[2],a[3],a[4],a[5],a[6]);\n  }\n  function F() { return c.apply(this, a); }\n  F.prototype = c.prototype;\n  return new F;\n}\n//Provides: caml_js_wrap_callback const (const)\n//Requires: caml_callback\nfunction caml_js_wrap_callback(f) {\n  return function () {\n    var len = arguments.length;\n    if(len > 0){\n      var args = new Array(len);\n      for (var i = 0; i < len; i++) args[i] = arguments[i];\n    } else {\n      args = [undefined];\n    }\n    var res = caml_callback(f, args);\n    return (res instanceof Function)?caml_js_wrap_callback(res):res;\n  }\n}\n\n//Provides: caml_js_wrap_callback_arguments\n//Requires: caml_callback\nfunction caml_js_wrap_callback_arguments(f) {\n  return function() {\n    var len = arguments.length;\n    var args = new Array(len);\n    for (var i = 0; i < len; i++) args[i] = arguments[i];\n    return caml_callback(f, [args]);\n  }\n}\n//Provides: caml_js_wrap_callback_strict const\n//Requires: caml_callback\nfunction caml_js_wrap_callback_strict(arity, f) {\n  return function () {\n    var n = arguments.length;\n    var args = new Array(arity);\n    var len = Math.min(arguments.length, arity)\n    for (var i = 0; i < len; i++) args[i] = arguments[i];\n    return caml_callback(f, args);\n  };\n}\n//Provides: caml_js_wrap_callback_unsafe const (const)\n//Requires: caml_callback, caml_js_function_arity\nfunction caml_js_wrap_callback_unsafe(f) {\n  return function () {\n    var len = caml_js_function_arity(f);\n    var args = new Array(len);\n    for (var i = 0; i < len; i++) args[i] = arguments[i];\n    return caml_callback(f, args); }\n}\n//Provides: caml_js_wrap_meth_callback const (const)\n//Requires: caml_callback, caml_js_wrap_callback\nfunction caml_js_wrap_meth_callback(f) {\n  return function () {\n    var len = arguments.length;\n    var args = new Array(len + 1);\n    args[0] = this;\n    for (var i = 0; i < len; i++) args[i+1] = arguments[i];\n    var res = caml_callback(f,args);\n    return (res instanceof Function)?caml_js_wrap_callback(res):res;\n  }\n}\n//Provides: caml_js_wrap_meth_callback_arguments const (const)\n//Requires: caml_callback\nfunction caml_js_wrap_meth_callback_arguments(f) {\n  return function () {\n    var len = arguments.length;\n    var args = new Array(len);\n    for (var i = 0; i < len; i++) args[i] = arguments[i];\n    return caml_callback(f,[this,args]);\n  }\n}\n//Provides: caml_js_wrap_meth_callback_strict const\n//Requires: caml_callback\nfunction caml_js_wrap_meth_callback_strict(arity, f) {\n  return function () {\n    var args = new Array(arity + 1);\n    var len = Math.min(arguments.length, arity)\n    args[0] = this;\n    for (var i = 0; i < len; i++) args[i+1] = arguments[i];\n    return caml_callback(f, args);\n  };\n}\n//Provides: caml_js_wrap_meth_callback_unsafe const (const)\n//Requires: caml_callback, caml_js_function_arity\nfunction caml_js_wrap_meth_callback_unsafe(f) {\n  return function () {\n    var len = caml_js_function_arity(f) - 1;\n    var args = new Array(len + 1);\n    args[0] = this;\n    for (var i = 0; i < len; i++) args[i+1] = arguments[i];\n    return caml_callback(f, args); }\n}\n\n//Provides: caml_js_function_arity\n//If: !effects\nfunction caml_js_function_arity(f) {\n  return (f.l >= 0)?f.l:(f.l = f.length)\n}\n\n//Provides: caml_js_function_arity\n//If: effects\nfunction caml_js_function_arity(f) {\n  // Functions have an additional continuation parameter. This should\n  // not be visible when calling them from JavaScript\n  return ((f.l >= 0)?f.l:(f.l = f.length)) - 1\n}\n\n//Provides: caml_js_equals mutable (const, const)\nfunction caml_js_equals (x, y) { return +(x == y); }\n\n//Provides: caml_js_strict_equals mutable (const, const)\nfunction caml_js_strict_equals (x, y) { return +(x === y); }\n\n//Provides: caml_js_eval_string (const)\n//Requires: caml_jsstring_of_string\nfunction caml_js_eval_string (s) {return eval(caml_jsstring_of_string(s));}\n\n//Provides: caml_js_expr (const)\n//Requires: caml_jsstring_of_string\nfunction caml_js_expr(s) {\n  console.error(\"caml_js_expr: fallback to runtime evaluation\\n\");\n  return eval(caml_jsstring_of_string(s));}\n\n//Provides: caml_pure_js_expr const (const)\n//Requires: caml_jsstring_of_string\nfunction caml_pure_js_expr (s){\n  console.error(\"caml_pure_js_expr: fallback to runtime evaluation\\n\");\n  return eval(caml_jsstring_of_string(s));}\n\n//Provides: caml_js_object (object_literal)\n//Requires: caml_jsstring_of_string\nfunction caml_js_object (a) {\n  var o = {};\n  for (var i = 1; i < a.length; i++) {\n    var p = a[i];\n    o[caml_jsstring_of_string(p[1])] = p[2];\n  }\n  return o;\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Raise exception\n\n//Provides: caml_raise_constant (const)\nfunction caml_raise_constant (tag) { throw tag; }\n\n//Provides: caml_raise_with_arg (const, mutable)\n//Requires: caml_maybe_attach_backtrace\nfunction caml_raise_with_arg (tag, arg) { throw caml_maybe_attach_backtrace([0, tag, arg]); }\n\n//Provides: caml_raise_with_args (const, mutable)\n//Requires: caml_maybe_attach_backtrace\nfunction caml_raise_with_args (tag, args) { throw caml_maybe_attach_backtrace([0, tag].concat(args)); }\n\n//Provides: caml_raise_with_string (const, const)\n//Requires: caml_raise_with_arg, caml_string_of_jsbytes\nfunction caml_raise_with_string (tag, msg) {\n  caml_raise_with_arg (tag, caml_string_of_jsbytes(msg));\n}\n\n//Provides: caml_failwith (const)\n//Requires: caml_raise_with_string, caml_global_data, caml_string_of_jsbytes\nfunction caml_failwith (msg) {\n  if(!caml_global_data.Failure)\n    caml_global_data.Failure=[248,caml_string_of_jsbytes(\"Failure\"),-3];\n  caml_raise_with_string(caml_global_data.Failure, msg);\n}\n\n\n//Provides: caml_invalid_argument (const)\n//Requires: caml_raise_with_string, caml_global_data\nfunction caml_invalid_argument (msg) {\n  caml_raise_with_string(caml_global_data.Invalid_argument, msg);\n}\n\n//Provides: caml_raise_end_of_file\n//Requires: caml_raise_constant, caml_global_data\nfunction caml_raise_end_of_file () {\n  caml_raise_constant(caml_global_data.End_of_file);\n}\n\n//Provides: caml_raise_zero_divide\n//Requires: caml_raise_constant, caml_global_data\nfunction caml_raise_zero_divide () {\n  caml_raise_constant(caml_global_data.Division_by_zero);\n}\n\n//Provides: caml_raise_not_found\n//Requires: caml_raise_constant, caml_global_data\nfunction caml_raise_not_found () {\n  caml_raise_constant(caml_global_data.Not_found); }\n\n\n//Provides: caml_array_bound_error\n//Requires: caml_invalid_argument\nfunction caml_array_bound_error () {\n  caml_invalid_argument(\"index out of bounds\");\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Jérôme Vouillon, Hugo Heuzard\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Dummy filesystem\n\n//Provides: caml_trailing_slash\nfunction caml_trailing_slash(name){\n  return (name.slice(-1) !== \"/\") ? (name + \"/\") : name;\n}\n\n//Provides: caml_current_dir\n//Requires: caml_trailing_slash, fs_node_supported\nif(fs_node_supported () && globalThis.process && globalThis.process.cwd)\n  var caml_current_dir = globalThis.process.cwd().replace(/\\\\/g,'/');\nelse\n  var caml_current_dir =  \"/static\";\ncaml_current_dir = caml_trailing_slash(caml_current_dir);\n\n//Provides: caml_get_root\n//Requires: path_is_absolute\nfunction caml_get_root(path){\n  var x = path_is_absolute(path);\n  if (!x) return;\n  return x[0] + \"/\"}\n\n//Provides: caml_root\n//Requires: caml_get_root, caml_current_dir, caml_failwith\nvar caml_root = caml_get_root(caml_current_dir) || caml_failwith(\"unable to compute caml_root\");\n\n\n//Provides: MlFile\nfunction MlFile(){  }\n\n//Provides: path_is_absolute\n//Requires: fs_node_supported\nfunction make_path_is_absolute() {\n  function posix(path) {\n    if (path.charAt(0) === '/') return [\"\", path.substring(1)];\n    return;\n  }\n\n  function win32(path) {\n    // https://github.com/nodejs/node/blob/b3fcc245fb25539909ef1d5eaa01dbf92e168633/lib/path.js#L56\n    var splitDeviceRe = /^([a-zA-Z]:|[\\\\/]{2}[^\\\\/]+[\\\\/]+[^\\\\/]+)?([\\\\/])?([\\s\\S]*?)$/;\n    var result = splitDeviceRe.exec(path);\n    var device = result[1] || '';\n    var isUnc = Boolean(device && device.charAt(1) !== ':');\n\n    // UNC paths are always absolute\n    if (Boolean(result[2] || isUnc)) {\n      var root = (result[1] || '');\n      var sep = (result[2] || '');\n      return [root, path.substring(root.length + sep.length)]\n    }\n    return;\n  }\n  if(fs_node_supported () && globalThis.process && globalThis.process.platform) {\n    return globalThis.process.platform === 'win32' ? win32 : posix;\n  }\n  else return posix\n}\nvar path_is_absolute = make_path_is_absolute();\n\n//Provides: caml_make_path\n//Requires: caml_current_dir\n//Requires: caml_jsstring_of_string, path_is_absolute\nfunction caml_make_path (name) {\n  name=caml_jsstring_of_string(name);\n  if( !path_is_absolute(name) )\n    name = caml_current_dir + name;\n  var comp0 = path_is_absolute(name);\n  var comp = comp0[1].split(\"/\");\n  var ncomp = []\n  for(var i = 0; i<comp.length; i++){\n    switch(comp[i]){\n    case \"..\": if(ncomp.length>1) ncomp.pop(); break;\n    case \".\": break;\n    case \"\": break;\n    default: ncomp.push(comp[i]);break\n    }\n  }\n  ncomp.unshift(comp0[0]);\n  ncomp.orig = name;\n  return ncomp;\n}\n\n//Provides:jsoo_mount_point\n//Requires: MlFakeDevice, MlNodeDevice, caml_root, fs_node_supported\nvar jsoo_mount_point = []\nif (fs_node_supported()) {\n  jsoo_mount_point.push({path:caml_root,device:new MlNodeDevice(caml_root)});\n} else {\n  jsoo_mount_point.push({path:caml_root,device:new MlFakeDevice(caml_root)});\n}\njsoo_mount_point.push({path:\"/static/\", device:new MlFakeDevice(\"/static/\")});\n\n//Provides:caml_list_mount_point\n//Requires: jsoo_mount_point, caml_string_of_jsbytes\nfunction caml_list_mount_point(){\n  var prev = 0\n  for(var i = 0; i < jsoo_mount_point.length; i++){\n    var old = prev;\n    prev = [0, caml_string_of_jsbytes(jsoo_mount_point[i].path), old]\n  }\n  return prev;\n}\n\n//Provides: resolve_fs_device\n//Requires: caml_make_path, jsoo_mount_point, caml_raise_sys_error, caml_get_root, MlNodeDevice, caml_trailing_slash, fs_node_supported\nfunction resolve_fs_device(name){\n  var path = caml_make_path(name);\n  var name = path.join(\"/\");\n  var name_slash = caml_trailing_slash(name);\n  var res;\n  for(var i = 0; i < jsoo_mount_point.length; i++) {\n    var m = jsoo_mount_point[i];\n    if(name_slash.search(m.path) == 0\n       && (!res || res.path.length < m.path.length))\n      res = {path:m.path,device:m.device,rest:name.substring(m.path.length,name.length)};\n  }\n  if( !res && fs_node_supported()) {\n    var root = caml_get_root(name);\n    if (root && root.match(/^[a-zA-Z]:\\/$/)){\n      var m = {path:root,device:new MlNodeDevice(root)};\n      jsoo_mount_point.push(m);\n      res = {path:m.path,device:m.device,rest:name.substring(m.path.length,name.length)};\n    }\n  }\n  if( res ) return res;\n  caml_raise_sys_error(\"no device found for \" + name_slash);\n}\n\n//Provides: caml_mount_autoload\n//Requires: MlFakeDevice, caml_make_path, jsoo_mount_point, caml_trailing_slash\nfunction caml_mount_autoload(name,f){\n  var path = caml_make_path(name);\n  var name = caml_trailing_slash(path.join(\"/\"));\n  jsoo_mount_point.push({path:name,device:new MlFakeDevice(name,f)})\n  return 0;\n}\n\n//Provides: caml_unmount\n//Requires: jsoo_mount_point, caml_make_path, caml_trailing_slash\nfunction caml_unmount(name){\n  var path = caml_make_path(name);\n  var name = caml_trailing_slash(path.join(\"/\"));\n  var idx = -1;\n  for(var i = 0; i < jsoo_mount_point.length; i++)\n    if(jsoo_mount_point[i].path == name) idx = i;\n  if(idx > -1) jsoo_mount_point.splice(idx,1);\n  return 0\n}\n\n//Provides: caml_sys_getcwd\n//Requires: caml_current_dir, caml_string_of_jsbytes\nfunction caml_sys_getcwd() {\n  return caml_string_of_jsbytes(caml_current_dir);\n}\n\n//Provides: caml_sys_chdir\n//Requires: caml_current_dir, caml_raise_no_such_file, resolve_fs_device, caml_trailing_slash, caml_jsbytes_of_string\nfunction caml_sys_chdir(dir) {\n  var root = resolve_fs_device(dir);\n  if(root.device.exists(root.rest)) {\n    if(root.rest) caml_current_dir = caml_trailing_slash(root.path + root.rest);\n    else caml_current_dir = root.path;\n    return 0;\n  }\n  else {\n    caml_raise_no_such_file(caml_jsbytes_of_string(dir));\n  }\n}\n\n//Provides: caml_raise_no_such_file\n//Requires: caml_raise_sys_error\nfunction caml_raise_no_such_file(name){\n  caml_raise_sys_error (name + \": No such file or directory\");\n}\n\n//Provides: caml_raise_not_a_dir\n//Requires: caml_raise_sys_error\nfunction caml_raise_not_a_dir(name){\n  caml_raise_sys_error (name + \": Not a directory\");\n}\n\n//Provides: caml_sys_file_exists\n//Requires: resolve_fs_device\nfunction caml_sys_file_exists (name) {\n  var root = resolve_fs_device(name);\n  return root.device.exists(root.rest);\n}\n\n//Provides: caml_sys_read_directory\n//Requires: caml_string_of_jsbytes\n//Requires: caml_raise_not_a_dir, resolve_fs_device\nfunction caml_sys_read_directory(name){\n  var root = resolve_fs_device(name);\n  var a = root.device.readdir(root.rest);\n  var l = new Array(a.length + 1);\n  l[0] = 0;\n  for(var i=0;i<a.length;i++)\n    l[i+1] = caml_string_of_jsbytes(a[i]);\n  return l;\n}\n\n//Provides: caml_sys_remove\n//Requires: caml_raise_no_such_file, resolve_fs_device, caml_jsbytes_of_string\nfunction caml_sys_remove(name){\n  var root = resolve_fs_device(name);\n  var ok = root.device.unlink(root.rest);\n  if(ok == 0) caml_raise_no_such_file(caml_jsbytes_of_string(name));\n  return 0;\n}\n\n//Provides: caml_sys_is_directory\n//Requires: resolve_fs_device\nfunction caml_sys_is_directory(name){\n  var root = resolve_fs_device(name);\n  var a = root.device.is_dir(root.rest);\n  return a?1:0;\n}\n\n//Provides: caml_sys_rename\n//Requires: caml_failwith, resolve_fs_device\nfunction caml_sys_rename(o,n){\n  var o_root = resolve_fs_device(o);\n  var n_root = resolve_fs_device(n);\n  if(o_root.device != n_root.device)\n    caml_failwith(\"caml_sys_rename: cannot move file between two filesystem\");\n  if(!o_root.device.rename)\n    caml_failwith(\"caml_sys_rename: no implemented\");\n  o_root.device.rename(o_root.rest, n_root.rest);\n}\n\n//Provides: caml_sys_mkdir\n//Requires: resolve_fs_device, caml_raise_sys_error\nfunction caml_sys_mkdir(name, perm){\n  var root = resolve_fs_device(name);\n  root.device.mkdir(root.rest,perm);\n  return 0;\n}\n\n//Provides: caml_sys_rmdir\n//Requires: resolve_fs_device, caml_raise_sys_error, caml_raise_not_a_dir\nfunction caml_sys_rmdir(name){\n  var root = resolve_fs_device(name);\n  root.device.rmdir(root.rest);\n  return 0;\n}\n\n//Provides: caml_ba_map_file\n//Requires: caml_failwith\nfunction caml_ba_map_file(vfd, kind, layout, shared, dims, pos) {\n  // var data = caml_sys_fds[vfd];\n  caml_failwith(\"caml_ba_map_file not implemented\");\n}\n\n//Provides: caml_ba_map_file_bytecode\n//Requires: caml_ba_map_file\nfunction caml_ba_map_file_bytecode(argv,argn){\n  return caml_ba_map_file(argv[0],argv[1],argv[2],argv[3],argv[4],argv[5]);\n}\n\n//Provides: jsoo_create_file_extern\nfunction jsoo_create_file_extern(name,content){\n  if(globalThis.jsoo_create_file)\n    globalThis.jsoo_create_file(name,content);\n  else {\n    if(!globalThis.caml_fs_tmp) globalThis.caml_fs_tmp = [];\n    globalThis.caml_fs_tmp.push({name:name,content:content});\n  }\n  return 0;\n}\n\n//Provides: caml_fs_init\n//Requires: jsoo_create_file\nfunction caml_fs_init (){\n  var tmp=globalThis.caml_fs_tmp\n  if(tmp){\n    for(var i = 0; i < tmp.length; i++){\n      jsoo_create_file(tmp[i].name,tmp[i].content);\n    }\n  }\n  globalThis.jsoo_create_file = jsoo_create_file;\n  globalThis.caml_fs_tmp = [];\n  return 0;\n}\n\n//Provides: caml_create_file\n//Requires: caml_failwith, resolve_fs_device\nfunction caml_create_file(name,content) {\n  var root = resolve_fs_device(name);\n  if(! root.device.register) caml_failwith(\"cannot register file\");\n  root.device.register(root.rest,content);\n  return 0;\n}\n\n\n//Provides: jsoo_create_file\n//Requires: caml_create_file, caml_string_of_jsbytes\nfunction jsoo_create_file(name,content) {\n  var name = caml_string_of_jsbytes(name);\n  var content = caml_string_of_jsbytes(content);\n  return caml_create_file(name, content);\n}\n\n\n//Provides: caml_read_file_content\n//Requires: resolve_fs_device, caml_raise_no_such_file, caml_string_of_array\n//Requires: caml_string_of_jsbytes, caml_jsbytes_of_string\nfunction caml_read_file_content (name) {\n  var name = (typeof name == \"string\")?caml_string_of_jsbytes(name):name;\n  var root = resolve_fs_device(name);\n  if(root.device.exists(root.rest)) {\n    var file = root.device.open(root.rest,{rdonly:1});\n    var len  = file.length();\n    var buf = new Uint8Array(len);\n    file.read(0,buf,0,len);\n    return caml_string_of_array(buf)\n  }\n  caml_raise_no_such_file(caml_jsbytes_of_string(name));\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Jérôme Vouillon, Hugo Heuzard\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: MlFakeDevice\n//Requires: MlFakeFile, MlFakeFd, caml_create_bytes\n//Requires: caml_raise_sys_error, caml_raise_no_such_file\n//Requires: caml_string_of_jsbytes, caml_string_of_jsstring\n//Requires: caml_bytes_of_array, caml_bytes_of_string, caml_bytes_of_jsbytes\n//Requires: caml_is_ml_bytes, caml_is_ml_string\n//Requires: caml_named_value, caml_raise_with_args, caml_named_values\n//Requires: make_unix_err_args\nfunction MlFakeDevice (root, f) {\n  this.content={};\n  this.root = root;\n  this.lookupFun = f;\n}\nMlFakeDevice.prototype.nm = function(name) {\n  return (this.root + name);\n}\nMlFakeDevice.prototype.create_dir_if_needed = function(name) {\n  var comp = name.split(\"/\");\n  var res = \"\";\n  for(var i = 0; i < comp.length - 1; i++){\n    res += comp[i] + \"/\";\n    if(this.content[res]) continue;\n    this.content[res] = Symbol(\"directory\");\n  }\n}\nMlFakeDevice.prototype.slash = function(name){\n  return /\\/$/.test(name)?name:(name + \"/\");\n}\nMlFakeDevice.prototype.lookup = function(name) {\n  if(!this.content[name] && this.lookupFun) {\n    var res = this.lookupFun(caml_string_of_jsbytes(this.root), caml_string_of_jsbytes(name));\n    if(res !== 0) {\n      this.create_dir_if_needed(name);\n      this.content[name]=new MlFakeFile(caml_bytes_of_string(res[1]));\n    }\n  }\n}\nMlFakeDevice.prototype.exists = function(name) {\n  // The root of the device exists\n  if(name == \"\") return 1;\n  // Check if a directory exists\n  var name_slash = this.slash(name);\n  if(this.content[name_slash]) return 1;\n  // Check if a file exists\n  this.lookup(name);\n  return this.content[name]?1:0;\n}\nMlFakeDevice.prototype.isFile = function(name) {\n  if(this.exists(name) && !this.is_dir(name)) {\n    return 1\n  }\n  else {\n    return 0\n  }\n}\nMlFakeDevice.prototype.mkdir = function(name,mode, raise_unix) {\n  var unix_error = raise_unix && caml_named_value('Unix.Unix_error');\n  if(this.exists(name)) {\n    if (unix_error) {\n      caml_raise_with_args(unix_error, make_unix_err_args(\"EEXIST\", \"mkdir\", this.nm(name)));\n    }\n    else {\n      caml_raise_sys_error(name + \": File exists\");\n    }\n  }\n  var parent = /^(.*)\\/[^/]+/.exec(name);\n  parent = (parent && parent[1]) || '';\n  if(!this.exists(parent)){\n    if (unix_error) {\n      caml_raise_with_args(unix_error, make_unix_err_args(\"ENOENT\", \"mkdir\", this.nm(parent)));\n    }\n    else {\n      caml_raise_sys_error(parent + \": No such file or directory\");\n    }\n  }\n  if(!this.is_dir(parent)){\n    if (unix_error) {\n      caml_raise_with_args(unix_error, make_unix_err_args(\"ENOTDIR\", \"mkdir\", this.nm(parent)));\n    }\n    else {\n      caml_raise_sys_error(parent + \": Not a directory\");\n    }\n  }\n  this.create_dir_if_needed(this.slash(name));\n}\nMlFakeDevice.prototype.rmdir = function(name, raise_unix) {\n  var unix_error = raise_unix && caml_named_value('Unix.Unix_error');\n  var name_slash = (name == \"\")?\"\":(this.slash(name));\n  var r = new RegExp(\"^\" + name_slash + \"([^/]+)\");\n  if(!this.exists(name)) {\n    if (unix_error) {\n      caml_raise_with_args(unix_error, make_unix_err_args(\"ENOENT\", \"rmdir\", this.nm(name)));\n    }\n    else {\n      caml_raise_sys_error(name + \": No such file or directory\");\n    }\n  }\n  if(!this.is_dir(name)) {\n    if (unix_error) {\n      caml_raise_with_args(unix_error, make_unix_err_args(\"ENOTDIR\", \"rmdir\", this.nm(name)));\n    }\n    else {\n      caml_raise_sys_error(name + \": Not a directory\");\n    }\n  }\n  for(var n in this.content) {\n    if(n.match(r)) {\n      if (unix_error) {\n        caml_raise_with_args(unix_error, make_unix_err_args(\"ENOTEMPTY\", \"rmdir\", this.nm(name)));\n      } else {\n        caml_raise_sys_error(this.nm(name) + \": Directory not empty\");\n      }\n    }\n  }\n  delete this.content[name_slash];\n}\nMlFakeDevice.prototype.readdir = function(name) {\n  var name_slash = (name == \"\")?\"\":(this.slash(name));\n  if(!this.exists(name)) {\n    caml_raise_sys_error(name + \": No such file or directory\");\n  }\n  if(!this.is_dir(name)) {\n    caml_raise_sys_error(name + \": Not a directory\");\n  }\n  var r = new RegExp(\"^\" + name_slash + \"([^/]+)\");\n  var seen = {}\n  var a = [];\n  for(var n in this.content) {\n    var m = n.match(r);\n    if(m && !seen[m[1]]) {seen[m[1]] = true; a.push(m[1])}\n  }\n  return a;\n}\nMlFakeDevice.prototype.opendir = function(name, raise_unix) {\n  var unix_error = raise_unix && caml_named_value('Unix.Unix_error');\n\n  var a = this.readdir(name);\n  var c = false;\n  var i = 0;\n  return { readSync : (function () {\n    if (c) {\n      if (unix_error) {\n        caml_raise_with_args(unix_error, make_unix_err_args(\"EBADF\", \"closedir\", this.nm(name)));\n      }\n      else {\n        caml_raise_sys_error(name + \": closedir failed\");\n      }\n    }\n    if(i == a.length) return null;\n    var entry = a[i];\n    i++;\n    return { name: entry }\n  })\n    , closeSync: (function () {\n      if (c) {\n        if (unix_error) {\n          caml_raise_with_args(unix_error, make_unix_err_args(\"EBADF\", \"closedir\", this.nm(name)));\n        }\n        else {\n          caml_raise_sys_error(name + \": closedir failed\");\n        }\n      }\n      c = true;\n      a = [];\n    })\n  }\n}\nMlFakeDevice.prototype.is_dir = function(name) {\n  if(name == \"\")  return true;\n  var name_slash = this.slash(name);\n  return this.content[name_slash]?1:0;\n}\nMlFakeDevice.prototype.unlink = function(name) {\n  var ok = this.content[name]?true:false;\n  delete this.content[name];\n  return ok;\n}\nMlFakeDevice.prototype.open = function(name, f) {\n  var file;\n  if(f.rdonly && f.wronly)\n    caml_raise_sys_error(this.nm(name) + \" : flags Open_rdonly and Open_wronly are not compatible\");\n  if(f.text && f.binary)\n    caml_raise_sys_error(this.nm(name) + \" : flags Open_text and Open_binary are not compatible\");\n  this.lookup(name);\n  if (this.content[name]) {\n    if (this.is_dir(name)) caml_raise_sys_error(this.nm(name) + \" : is a directory\");\n    if (f.create && f.excl) caml_raise_sys_error(this.nm(name) + \" : file already exists\");\n    file = this.content[name];\n    if(f.truncate) file.truncate();\n  } else if (f.create) {\n    this.create_dir_if_needed(name);\n    this.content[name] = new MlFakeFile(caml_create_bytes(0));\n    file = this.content[name];\n  } else {\n    caml_raise_no_such_file (this.nm(name));\n  }\n  return new MlFakeFd(this.nm(name), file, f);\n}\n\nMlFakeDevice.prototype.open = function(name, f) {\n  var file;\n  if(f.rdonly && f.wronly)\n    caml_raise_sys_error(this.nm(name) + \" : flags Open_rdonly and Open_wronly are not compatible\");\n  if(f.text && f.binary)\n    caml_raise_sys_error(this.nm(name) + \" : flags Open_text and Open_binary are not compatible\");\n  this.lookup(name);\n  if (this.content[name]) {\n    if (this.is_dir(name)) caml_raise_sys_error(this.nm(name) + \" : is a directory\");\n    if (f.create && f.excl) caml_raise_sys_error(this.nm(name) + \" : file already exists\");\n    file = this.content[name];\n    if(f.truncate) file.truncate();\n  } else if (f.create) {\n    this.create_dir_if_needed(name);\n    this.content[name] = new MlFakeFile(caml_create_bytes(0));\n    file = this.content[name];\n  } else {\n    caml_raise_no_such_file (this.nm(name));\n  }\n  return new MlFakeFd(this.nm(name), file, f);\n}\n\nMlFakeDevice.prototype.register= function (name,content){\n  var file;\n  if(this.content[name]) caml_raise_sys_error(this.nm(name) + \" : file already exists\");\n  if(caml_is_ml_bytes(content))\n    file = new MlFakeFile(content);\n  if(caml_is_ml_string(content))\n    file = new MlFakeFile(caml_bytes_of_string(content));\n  else if(content instanceof Array)\n    file = new MlFakeFile(caml_bytes_of_array(content));\n  else if(typeof content === \"string\")\n    file = new MlFakeFile(caml_bytes_of_jsbytes(content));\n  else if(content.toString) {\n    var bytes = caml_bytes_of_string(caml_string_of_jsstring(content.toString()));\n    file = new MlFakeFile(bytes);\n  }\n  if(file){\n    this.create_dir_if_needed(name);\n    this.content[name] = file;\n  }\n  else caml_raise_sys_error(this.nm(name) + \" : registering file with invalid content type\");\n}\n\nMlFakeDevice.prototype.constructor = MlFakeDevice\n\n//Provides: MlFakeFile\n//Requires: MlFile\n//Requires: caml_create_bytes, caml_ml_bytes_length, caml_blit_bytes\n//Requires: caml_uint8_array_of_bytes, caml_bytes_of_array\nfunction MlFakeFile(content){\n  this.data = content;\n}\nMlFakeFile.prototype = new MlFile ();\nMlFakeFile.prototype.constructor = MlFakeFile\nMlFakeFile.prototype.truncate = function(len){\n  var old = this.data;\n  this.data = caml_create_bytes(len|0);\n  caml_blit_bytes(old, 0, this.data, 0, len);\n}\nMlFakeFile.prototype.length = function () {\n  return caml_ml_bytes_length(this.data);\n}\nMlFakeFile.prototype.write = function(offset,buf,pos,len){\n  var clen = this.length();\n  if(offset + len >= clen) {\n    var new_str = caml_create_bytes(offset + len);\n    var old_data = this.data;\n    this.data = new_str;\n    caml_blit_bytes(old_data, 0, this.data, 0, clen);\n  }\n  caml_blit_bytes(caml_bytes_of_array(buf), pos, this.data, offset, len);\n  return 0\n}\nMlFakeFile.prototype.read = function(offset,buf,pos,len){\n  var clen = this.length();\n  if(offset + len >= clen) {\n    len = clen - offset;\n  }\n  if(len) {\n    var data = caml_create_bytes(len|0);\n    caml_blit_bytes(this.data, offset, data, 0, len);\n    buf.set(caml_uint8_array_of_bytes(data), pos);\n  }\n  return len\n}\n\n\n//Provides: MlFakeFd_out\n//Requires: MlFakeFile, caml_create_bytes, caml_blit_bytes, caml_bytes_of_array\n//Requires: caml_raise_sys_error\nfunction MlFakeFd_out(fd,flags) {\n  MlFakeFile.call(this, caml_create_bytes(0));\n  this.log = (function (s) { return 0 });\n  if(fd == 1 && typeof console.log == \"function\")\n    this.log = console.log;\n  else if(fd == 2 && typeof console.error == \"function\")\n    this.log = console.error;\n  else if(typeof console.log == \"function\")\n    this.log = console.log\n  this.flags = flags;\n}\nMlFakeFd_out.prototype.length = function() { return 0 }\nMlFakeFd_out.prototype.write = function (offset,buf,pos,len) {\n  if(this.log) {\n    if(len > 0\n       && pos >= 0\n       && pos+len <= buf.length\n       && buf[pos+len-1] == 10)\n      len --;\n    // Do not output the last \\n if present\n    // as console logging display a newline at the end\n    var src = caml_create_bytes(len);\n    caml_blit_bytes(caml_bytes_of_array(buf), pos, src, 0, len);\n    this.log(src.toUtf16());\n    return 0;\n  }\n  caml_raise_sys_error(this.fd  + \": file descriptor already closed\");\n}\nMlFakeFd_out.prototype.read = function (offset, buf, pos, len) {\n  caml_raise_sys_error(this.fd  + \": file descriptor is write only\");\n}\nMlFakeFd_out.prototype.close = function () {\n  this.log = undefined;\n}\n\n\n//Provides: MlFakeFd\n//Requires: MlFakeFile\n//Requires: caml_raise_sys_error\nfunction MlFakeFd(name, file,flags) {\n  this.file = file;\n  this.name = name;\n  this.flags = flags;\n}\n\nMlFakeFd.prototype.err_closed = function () {\n  caml_raise_sys_error(this.name  + \": file descriptor already closed\");\n}\nMlFakeFd.prototype.length = function() {\n  if(this.file) return this.file.length ()\n  this.err_closed();\n}\nMlFakeFd.prototype.write = function (offset,buf,pos,len) {\n  if(this.file) return this.file.write(offset,buf,pos,len)\n  this.err_closed();\n}\nMlFakeFd.prototype.read = function (offset, buf, pos, len) {\n  if(this.file) return this.file.read(offset, buf, pos, len)\n  this.err_closed();\n}\nMlFakeFd.prototype.close = function () {\n  this.file = undefined;\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_int64_offset\nvar caml_int64_offset = Math.pow(2, -24);\n\n//Provides: MlInt64\n//Requires: caml_int64_offset, caml_raise_zero_divide\nfunction MlInt64 (lo,mi,hi) {\n  this.lo = lo & 0xffffff;\n  this.mi = mi & 0xffffff;\n  this.hi = hi & 0xffff;\n}\nMlInt64.prototype.caml_custom = \"_j\"\nMlInt64.prototype.copy = function () {\n  return new MlInt64(this.lo,this.mi,this.hi);\n}\n\nMlInt64.prototype.ucompare = function (x) {\n  if (this.hi > x.hi) return 1;\n  if (this.hi < x.hi) return -1;\n  if (this.mi > x.mi) return 1;\n  if (this.mi < x.mi) return -1;\n  if (this.lo > x.lo) return 1;\n  if (this.lo < x.lo) return -1;\n  return 0;\n}\nMlInt64.prototype.compare = function (x) {\n  var hi = this.hi << 16;\n  var xhi = x.hi << 16;\n  if (hi > xhi) return 1;\n  if (hi < xhi) return -1;\n  if (this.mi > x.mi) return 1;\n  if (this.mi < x.mi) return -1;\n  if (this.lo > x.lo) return 1;\n  if (this.lo < x.lo) return -1;\n  return 0;\n}\nMlInt64.prototype.neg = function () {\n  var lo = - this.lo;\n  var mi = - this.mi + (lo >> 24);\n  var hi = - this.hi + (mi >> 24);\n  return new MlInt64(lo, mi, hi);\n}\nMlInt64.prototype.add = function (x) {\n  var lo = this.lo + x.lo;\n  var mi = this.mi + x.mi + (lo >> 24);\n  var hi = this.hi + x.hi + (mi >> 24);\n  return new MlInt64(lo, mi, hi);\n}\nMlInt64.prototype.sub = function (x) {\n  var lo = this.lo - x.lo;\n  var mi = this.mi - x.mi + (lo >> 24);\n  var hi = this.hi - x.hi + (mi >> 24);\n  return new MlInt64(lo, mi, hi);\n}\nMlInt64.prototype.mul = function (x) {\n  var lo = this.lo * x.lo;\n  var mi = ((lo * caml_int64_offset) | 0) + this.mi * x.lo + this.lo * x.mi;\n  var hi = ((mi * caml_int64_offset) | 0) + this.hi * x.lo + this.mi * x.mi + this.lo * x.hi;\n  return new MlInt64(lo, mi, hi);\n}\nMlInt64.prototype.isZero = function () {\n  return (this.lo|this.mi|this.hi) == 0;\n}\nMlInt64.prototype.isNeg = function () {\n  return (this.hi << 16) < 0;\n}\nMlInt64.prototype.and = function (x) {\n  return new MlInt64(this.lo & x.lo, this.mi & x.mi, this.hi & x.hi);\n}\nMlInt64.prototype.or = function (x) {\n  return new MlInt64(this.lo|x.lo, this.mi|x.mi, this.hi|x.hi);\n}\nMlInt64.prototype.xor = function (x) {\n  return new MlInt64(this.lo^x.lo, this.mi^x.mi, this.hi^x.hi);\n}\nMlInt64.prototype.shift_left = function (s) {\n  s = s & 63;\n  if (s == 0) return this;\n  if (s < 24) {\n    return new MlInt64 (this.lo << s,\n                        (this.mi << s) | (this.lo >> (24 - s)),\n                        (this.hi << s) | (this.mi >> (24 - s)));\n  }\n  if (s < 48)\n    return new MlInt64 (0,\n                        this.lo << (s - 24),\n                        (this.mi << (s - 24)) | (this.lo >> (48 - s)));\n  return new MlInt64(0, 0, this.lo << (s - 48))\n}\nMlInt64.prototype.shift_right_unsigned = function (s) {\n  s = s & 63;\n  if (s == 0) return this;\n  if (s < 24)\n    return new MlInt64 (\n      (this.lo >> s) | (this.mi << (24 - s)),\n      (this.mi >> s) | (this.hi << (24 - s)),\n      (this.hi >> s));\n  if (s < 48)\n    return new MlInt64 (\n      (this.mi >> (s - 24)) | (this.hi << (48 - s)),\n      (this.hi >> (s - 24)),\n      0);\n  return new MlInt64 (this.hi >> (s - 48), 0, 0);\n}\nMlInt64.prototype.shift_right = function (s) {\n  s = s & 63;\n  if (s == 0) return this;\n  var h = (this.hi << 16) >> 16;\n  if (s < 24)\n    return new MlInt64 (\n      (this.lo >> s) | (this.mi << (24 - s)),\n      (this.mi >> s) | (h << (24 - s)),\n      ((this.hi << 16) >> s) >>> 16);\n  var sign = (this.hi << 16) >> 31;\n  if (s < 48)\n    return new MlInt64 (\n      (this.mi >> (s - 24)) | (this.hi << (48 - s)),\n      (this.hi << 16) >> (s - 24) >> 16,\n      sign & 0xffff);\n  return new MlInt64 ((this.hi << 16) >> (s - 32), sign, sign);\n}\nMlInt64.prototype.lsl1 = function () {\n  this.hi = (this.hi << 1) | (this.mi >> 23);\n  this.mi = ((this.mi << 1) | (this.lo >> 23)) & 0xffffff;\n  this.lo = (this.lo << 1) & 0xffffff;\n}\nMlInt64.prototype.lsr1 = function () {\n  this.lo = ((this.lo >>> 1) | (this.mi << 23)) & 0xffffff;\n  this.mi = ((this.mi >>> 1) | (this.hi << 23)) & 0xffffff;\n  this.hi = this.hi >>> 1;\n}\nMlInt64.prototype.udivmod = function (x) {\n  var offset = 0;\n  var modulus = this.copy();\n  var divisor = x.copy();\n  var quotient = new MlInt64(0,0,0);\n  while (modulus.ucompare(divisor) > 0) {\n    offset++;\n    divisor.lsl1();\n  }\n  while (offset >= 0) {\n    offset --;\n    quotient.lsl1();\n    if (modulus.ucompare(divisor) >= 0) {\n      quotient.lo ++;\n      modulus = modulus.sub(divisor);\n    }\n    divisor.lsr1();\n  }\n  return { quotient : quotient, modulus : modulus };\n}\nMlInt64.prototype.div = function (y)\n{\n  var x = this;\n  if (y.isZero()) caml_raise_zero_divide ();\n  var sign = x.hi ^ y.hi;\n  if (x.hi & 0x8000) x = x.neg();\n  if (y.hi & 0x8000) y = y.neg();\n  var q = x.udivmod(y).quotient;\n  if (sign & 0x8000) q = q.neg();\n  return q;\n}\nMlInt64.prototype.mod = function (y)\n{\n  var x = this;\n  if (y.isZero()) caml_raise_zero_divide ();\n  var sign = x.hi;\n  if (x.hi & 0x8000) x = x.neg();\n  if (y.hi & 0x8000) y = y.neg();\n  var r = x.udivmod(y).modulus;\n  if (sign & 0x8000) r = r.neg();\n  return r;\n}\nMlInt64.prototype.toInt = function () {\n  return this.lo | (this.mi << 24);\n}\nMlInt64.prototype.toFloat = function () {\n  return ((this.hi << 16) * Math.pow(2, 32) + this.mi * Math.pow(2, 24)) + this.lo;\n}\nMlInt64.prototype.toArray = function () {\n  return [this.hi >> 8,\n          this.hi & 0xff,\n          this.mi >> 16,\n          (this.mi >> 8) & 0xff,\n          this.mi & 0xff,\n          this.lo >> 16,\n          (this.lo >> 8) & 0xff,\n          this.lo & 0xff];\n}\nMlInt64.prototype.lo32 = function () {\n  return this.lo | ((this.mi & 0xff) << 24);\n}\nMlInt64.prototype.hi32 = function () {\n  return ((this.mi >>> 8) & 0xffff) | (this.hi << 16);\n}\n\n//Provides: caml_int64_ult const\nfunction caml_int64_ult(x,y) { return x.ucompare(y) < 0; }\n\n//Provides: caml_int64_compare const\nfunction caml_int64_compare(x,y, total) { return x.compare(y) }\n\n//Provides: caml_int64_neg const\nfunction caml_int64_neg (x) { return x.neg() }\n\n//Provides: caml_int64_add const\nfunction caml_int64_add (x, y) { return x.add(y) }\n\n//Provides: caml_int64_sub const\nfunction caml_int64_sub (x, y) { return x.sub(y) }\n\n//Provides: caml_int64_mul const\n//Requires: caml_int64_offset\nfunction caml_int64_mul(x,y) { return x.mul(y) }\n\n//Provides: caml_int64_is_zero const\nfunction caml_int64_is_zero(x) { return +x.isZero(); }\n\n//Provides: caml_int64_is_negative const\nfunction caml_int64_is_negative(x) { return +x.isNeg(); }\n\n//Provides: caml_int64_and const\nfunction caml_int64_and (x, y) { return x.and(y); }\n\n//Provides: caml_int64_or const\nfunction caml_int64_or (x, y) { return x.or(y); }\n\n//Provides: caml_int64_xor const\nfunction caml_int64_xor (x, y) { return x.xor(y) }\n\n//Provides: caml_int64_shift_left const\nfunction caml_int64_shift_left (x, s) { return x.shift_left(s) }\n\n//Provides: caml_int64_shift_right_unsigned const\nfunction caml_int64_shift_right_unsigned (x, s) { return x.shift_right_unsigned(s) }\n\n//Provides: caml_int64_shift_right const\nfunction caml_int64_shift_right (x, s) { return x.shift_right(s) }\n\n//Provides: caml_int64_div const\nfunction caml_int64_div (x, y) { return x.div(y) }\n\n//Provides: caml_int64_mod const\nfunction caml_int64_mod (x, y) { return x.mod(y) }\n\n//Provides: caml_int64_of_int32 const\n//Requires: MlInt64\nfunction caml_int64_of_int32 (x) {\n  return new MlInt64(x & 0xffffff, (x >> 24) & 0xffffff, (x >> 31) & 0xffff)\n}\n\n//Provides: caml_int64_to_int32 const\nfunction caml_int64_to_int32 (x) { return x.toInt() }\n\n//Provides: caml_int64_to_float const\nfunction caml_int64_to_float (x) { return x.toFloat () }\n\n//Provides: caml_int64_of_float const\n//Requires: caml_int64_offset, MlInt64\nfunction caml_int64_of_float (x) {\n  if (x < 0) x = Math.ceil(x);\n  return new MlInt64(\n    x & 0xffffff,\n    Math.floor(x * caml_int64_offset) & 0xffffff,\n    Math.floor(x * caml_int64_offset * caml_int64_offset) & 0xffff);\n}\n\n//Provides: caml_int64_format const\n//Requires: caml_parse_format, caml_finish_formatting\n//Requires: caml_int64_is_negative, caml_int64_neg\n//Requires: caml_int64_of_int32, caml_int64_to_int32\n//Requires: caml_int64_is_zero, caml_str_repeat\nfunction caml_int64_format (fmt, x) {\n  var f = caml_parse_format(fmt);\n  if (f.signedconv && caml_int64_is_negative(x)) {\n    f.sign = -1; x = caml_int64_neg(x);\n  }\n  var buffer = \"\";\n  var wbase = caml_int64_of_int32(f.base);\n  var cvtbl = \"0123456789abcdef\";\n  do {\n    var p = x.udivmod(wbase);\n    x = p.quotient;\n    buffer = cvtbl.charAt(caml_int64_to_int32(p.modulus)) + buffer;\n  } while (! caml_int64_is_zero(x));\n  if (f.prec >= 0) {\n    f.filler = ' ';\n    var n = f.prec - buffer.length;\n    if (n > 0) buffer = caml_str_repeat (n, '0') + buffer;\n  }\n  return caml_finish_formatting(f, buffer);\n}\n\n//Provides: caml_int64_of_string\n//Requires: caml_parse_sign_and_base, caml_failwith, caml_parse_digit\n//Requires: caml_int64_of_int32, caml_int64_ult\n//Requires: caml_int64_add, caml_int64_mul, caml_int64_neg\n//Requires: caml_ml_string_length,caml_string_unsafe_get, MlInt64\nfunction caml_int64_of_string(s) {\n  var r = caml_parse_sign_and_base (s);\n  var i = r[0], sign = r[1], base = r[2];\n  var base64 = caml_int64_of_int32(base);\n  var threshold =\n      new MlInt64(0xffffff, 0xfffffff, 0xffff).udivmod(base64).quotient;\n  var c = caml_string_unsafe_get(s, i);\n  var d = caml_parse_digit(c);\n  if (d < 0 || d >= base) caml_failwith(\"int_of_string\");\n  var res = caml_int64_of_int32(d);\n  for (;;) {\n    i++;\n    c = caml_string_unsafe_get(s, i);\n    if (c == 95) continue;\n    d = caml_parse_digit(c);\n    if (d < 0 || d >= base) break;\n    /* Detect overflow in multiplication base * res */\n    if (caml_int64_ult(threshold, res)) caml_failwith(\"int_of_string\");\n    d = caml_int64_of_int32(d);\n    res = caml_int64_add(caml_int64_mul(base64, res), d);\n    /* Detect overflow in addition (base * res) + d */\n    if (caml_int64_ult(res, d)) caml_failwith(\"int_of_string\");\n  }\n  if (i != caml_ml_string_length(s)) caml_failwith(\"int_of_string\");\n  if (base == 10 && caml_int64_ult(new MlInt64(0, 0, 0x8000), res))\n    caml_failwith(\"int_of_string\");\n  if (sign < 0) res = caml_int64_neg(res);\n  return res;\n}\n\n//Provides: caml_int64_create_lo_mi_hi const\n//Requires: MlInt64\nfunction caml_int64_create_lo_mi_hi(lo, mi, hi){\n  return new MlInt64(lo, mi, hi)\n}\n//Provides: caml_int64_create_lo_hi const\n//Requires: MlInt64\nfunction caml_int64_create_lo_hi(lo, hi){\n  return new MlInt64 (\n    lo & 0xffffff,\n    ((lo >>> 24) & 0xff) | ((hi & 0xffff) << 8),\n    (hi >>> 16) & 0xffff);\n}\n//Provides: caml_int64_lo32 const\nfunction caml_int64_lo32(v){ return v.lo32() }\n\n//Provides: caml_int64_hi32 const\nfunction caml_int64_hi32(v){ return v.hi32() }\n\n//Provides: caml_int64_of_bytes const\n//Requires: MlInt64\nfunction caml_int64_of_bytes(a) {\n  return new MlInt64(a[7] << 0 | (a[6] << 8) | (a[5] << 16),\n                     a[4] << 0 | (a[3] << 8) | (a[2] << 16),\n                     a[1] << 0 | (a[0] << 8));\n}\n//Provides: caml_int64_to_bytes const\nfunction caml_int64_to_bytes(x) { return x.toArray() }\n\n//Provides: caml_int64_hash const\nfunction caml_int64_hash(v){\n  return (v.lo32()) ^ (v.hi32())\n}\n","\n//Provides: MlMutex\nfunction MlMutex() {\n  this.locked = false\n}\n\n//Provides: caml_ml_mutex_new\n//Requires: MlMutex\nfunction caml_ml_mutex_new(unit) {\n  return new MlMutex();\n}\n\n//Provides: caml_ml_mutex_lock\n//Requires: caml_failwith\nfunction caml_ml_mutex_lock(t) {\n  if(t.locked)\n    caml_failwith(\"Mutex.lock: mutex already locked. Cannot wait.\");\n  else t.locked = true;\n  return 0;\n}\n\n//Provides: caml_ml_mutex_try_lock\nfunction caml_ml_mutex_try_lock(t) {\n  if(!t.locked) {\n    t.locked = true;\n    return 1;\n  }\n  return 0;\n}\n\n//Provides: caml_ml_mutex_unlock\nfunction caml_ml_mutex_unlock(t) {\n  t.locked = false;\n  return 0;\n}\n","//Provides: initialize_nat\n//Requires: caml_custom_ops\n//Requires: serialize_nat, deserialize_nat, caml_hash_nat\nfunction initialize_nat() {\n  caml_custom_ops[\"_nat\"] =\n    { deserialize : deserialize_nat,\n      serialize : serialize_nat,\n      hash : caml_hash_nat\n    }\n}\n\n//Provides: MlNat\nfunction MlNat(x){\n  this.data = new Int32Array(x);\n  // For num < 1.5\n  // length_nat isn't external, so we have to make the Obj.size\n  // work out right.\n  // We add +2 to the array length:\n  // - +1 for the tag\n  // - +1 for the custom_ops slot\n  this.length = this.data.length + 2\n}\n\nMlNat.prototype.caml_custom = \"_nat\";\n\n//Provides: caml_hash_nat\n//Requires: caml_hash_mix_int, num_digits_nat\nfunction caml_hash_nat(x) {\n  var len = num_digits_nat(x, 0, x.data.length);\n  var h = 0;\n  for (var i = 0; i < len; i++) {\n    h = caml_hash_mix_int(h, x.data[i]);\n  }\n  return h;\n}\n\n//Provides: length_nat\nfunction length_nat(x) {\n  return x.data.length;\n}\n\n//Provides: nat_of_array\n//Requires: MlNat\nfunction nat_of_array(l){\n  return new MlNat(l);\n}\n\n//Provides: create_nat\n//Requires: MlNat\nfunction create_nat(size) {\n  var arr = new MlNat(size);\n  for(var i = 0; i < size; i++) {\n    arr.data[i] = -1;\n  }\n  return arr;\n}\n\n//Provides: set_to_zero_nat\nfunction set_to_zero_nat(nat, ofs, len) {\n  for(var i = 0; i < len; i++) {\n    nat.data[ofs+i] = 0;\n  }\n  return 0;\n}\n\n//Provides: blit_nat\nfunction blit_nat(nat1, ofs1, nat2, ofs2, len) {\n  for(var i = 0; i < len; i++) {\n    nat1.data[ofs1+i] = nat2.data[ofs2+i];\n  }\n  return 0;\n}\n\n//Provides: set_digit_nat\nfunction set_digit_nat(nat, ofs, digit) {\n  nat.data[ofs] = digit;\n  return 0;\n}\n\n//Provides: nth_digit_nat\nfunction nth_digit_nat(nat, ofs) {\n  return nat.data[ofs];\n}\n\n//Provides: set_digit_nat_native\nfunction set_digit_nat_native(nat, ofs, digit) {\n  nat.data[ofs] = digit;\n  return 0;\n}\n\n//Provides: nth_digit_nat_native\nfunction nth_digit_nat_native(nat, ofs) {\n  return nat.data[ofs];\n}\n\n//Provides: num_digits_nat\nfunction num_digits_nat(nat, ofs, len) {\n  for(var i = len - 1; i >= 0; i--) {\n    if(nat.data[ofs+i] != 0) return i+1;\n  }\n  return 1; // 0 counts as 1 digit\n}\n\n//Provides: num_leading_zero_bits_in_digit\nfunction num_leading_zero_bits_in_digit(nat, ofs) {\n  var a = nat.data[ofs];\n  var b = 0;\n  if(a & 0xFFFF0000) { b +=16; a >>>=16; }\n  if(a & 0xFF00)     { b += 8; a >>>= 8; }\n  if(a & 0xF0)       { b += 4; a >>>= 4; }\n  if(a & 12)         { b += 2; a >>>= 2; }\n  if(a & 2)          { b += 1; a >>>= 1; }\n  if(a & 1)          { b += 1; }\n  return 32 - b;\n}\n\n//Provides: is_digit_int\nfunction is_digit_int(nat, ofs) {\n  if (nat.data[ofs] >= 0) return 1\n  return 0;\n}\n\n//Provides: is_digit_zero\nfunction is_digit_zero(nat, ofs) {\n  if(nat.data[ofs] == 0) return 1;\n  return 0;\n}\n\n//Provides: is_digit_odd\nfunction is_digit_odd(nat, ofs) {\n  if(nat.data[ofs] & 1) return 1;\n  return 0;\n}\n\n//Provides: incr_nat\nfunction incr_nat(nat, ofs, len, carry_in) {\n  var carry = carry_in;\n  for(var i = 0; i < len; i++) {\n    var x = (nat.data[ofs+i] >>> 0) + carry;\n    nat.data[ofs+i] = (x | 0);\n    if(x == (x >>> 0)) {\n      carry = 0;\n      break;\n    } else {\n      carry = 1;\n    }\n  }\n  return carry;\n}\n\n// len1 >= len2\n//Provides: add_nat\n//Requires: incr_nat\nfunction add_nat(nat1, ofs1, len1, nat2, ofs2, len2, carry_in) {\n  var carry = carry_in;\n  for(var i = 0; i < len2; i++) {\n    var x = (nat1.data[ofs1+i] >>> 0) + (nat2.data[ofs2+i] >>> 0) + carry;\n    nat1.data[ofs1+i] = x\n    if(x == (x >>> 0)) {\n      carry = 0;\n    } else {\n      carry = 1;\n    }\n  }\n  return incr_nat(nat1, ofs1+len2, len1-len2, carry);\n}\n\n//Provides: complement_nat\nfunction complement_nat(nat, ofs, len) {\n  for(var i = 0; i < len; i++) {\n    nat.data[ofs+i] = (-1 >>> 0) - (nat.data[ofs+i] >>> 0);\n  }\n}\n\n// ocaml flips carry_in\n//Provides: decr_nat\nfunction decr_nat(nat, ofs, len, carry_in) {\n  var borrow = (carry_in == 1) ? 0 : 1;\n  for(var i = 0; i < len; i++) {\n    var x = (nat.data[ofs+i] >>>0) - borrow;\n    nat.data[ofs+i] = x;\n    if (x >= 0) {\n      borrow = 0;\n      break;\n    } else {\n      borrow = 1;\n    }\n  }\n  return (borrow == 1) ? 0 : 1;\n}\n\n// ocaml flips carry_in\n// len1 >= len2\n//Provides: sub_nat\n//Requires: decr_nat\nfunction sub_nat(nat1, ofs1, len1, nat2, ofs2, len2, carry_in) {\n  var borrow = (carry_in == 1) ? 0 : 1;\n  for(var i = 0; i < len2; i++) {\n    var x = (nat1.data[ofs1+i] >>> 0) - (nat2.data[ofs2+i] >>> 0) - borrow;\n    nat1.data[ofs1+i] = x;\n    if (x >= 0) {\n      borrow = 0;\n    } else {\n      borrow = 1;\n    }\n  }\n  return decr_nat(nat1, ofs1+len2, len1-len2, (borrow==1)?0:1);\n}\n\n// nat1 += nat2 * nat3[ofs3]\n// len1 >= len2\n//Provides: mult_digit_nat\n//Requires: add_nat, nat_of_array\nfunction mult_digit_nat(nat1, ofs1, len1, nat2, ofs2, len2, nat3, ofs3) {\n  var carry = 0;\n  var a = (nat3.data[ofs3] >>> 0);\n  for(var i = 0; i < len2; i++) {\n    var x1 = (nat1.data[ofs1+i] >>> 0) + (nat2.data[ofs2+i] >>> 0) * (a & 0x0000FFFF) + carry;\n    var x2 = (nat2.data[ofs2+i] >>> 0) * (a >>> 16);\n    carry = Math.floor(x2/65536);\n    var x3 = x1 + (x2 % 65536) * 65536;\n    nat1.data[ofs1+i] = x3;\n    carry += Math.floor(x3/4294967296);\n  }\n\n  if(len2 < len1 && carry) {\n    return add_nat(nat1, ofs1+len2, len1-len2, nat_of_array([carry]), 0, 1, 0);\n  } else {\n    return carry;\n  }\n}\n\n// nat1 += nat2 * nat3\n// len1 >= len2 + len3.\n//Provides: mult_nat\n//Requires: mult_digit_nat\nfunction mult_nat(nat1, ofs1, len1, nat2, ofs2, len2, nat3, ofs3, len3) {\n  var carry = 0;\n  for(var i = 0; i < len3; i++) {\n    carry += mult_digit_nat(nat1, ofs1+i, len1-i, nat2, ofs2, len2, nat3, ofs3+i);\n  }\n  return carry;\n}\n\n// nat1 = 2 * nat1 + nat2 * nat2\n// len1 >= 2 * len2\n//Provides: square_nat\n//Requires: mult_nat, add_nat\nfunction square_nat(nat1, ofs1, len1, nat2, ofs2, len2) {\n  var carry = 0;\n  carry += add_nat(nat1, ofs1, len1, nat1, ofs1, len1, 0);\n  carry += mult_nat(nat1, ofs1, len1, nat2, ofs2, len2, nat2, ofs2, len2);\n  return carry;\n}\n\n\n// 0 <= shift < 32\n//Provides: shift_left_nat\nfunction shift_left_nat(nat1, ofs1, len1, nat2, ofs2, nbits) {\n  if(nbits == 0) {\n    nat2.data[ofs2] = 0;\n    return 0;\n  }\n  var wrap = 0;\n  for(var i = 0; i < len1; i++) {\n    var a = (nat1.data[ofs1+i] >>> 0);\n    nat1.data[ofs1+i] = (a << nbits) | wrap;\n    wrap = a >>> (32 - nbits);\n  }\n  nat2.data[ofs2] = wrap;\n  return 0;\n}\n\n// Assuming c > a, returns [quotient, remainder] of (a<<32 + b)/c\n//Provides: div_helper\nfunction div_helper(a, b, c) {\n  var x = a * 65536 + (b>>>16);\n  var y = Math.floor(x/c) * 65536;\n  var z = (x % c) * 65536;\n  var w = z + (b & 0x0000FFFF);\n  return [y + Math.floor(w/c), w % c];\n}\n\n// nat1[ofs1+len] < nat2[ofs2]\n//Provides: div_digit_nat\n//Requires: div_helper\nfunction div_digit_nat(natq, ofsq, natr, ofsr, nat1, ofs1, len, nat2, ofs2) {\n  var rem = (nat1.data[ofs1+len-1] >>>0);\n  // natq[ofsq+len-1] is guaranteed to be zero (due to the MSD requirement),\n  // and should not be written to.\n  for(var i = len-2; i >= 0; i--) {\n    var x = div_helper(rem, (nat1.data[ofs1+i] >>> 0), (nat2.data[ofs2] >>> 0));\n    natq.data[ofsq+i] = x[0];\n    rem = x[1];\n  }\n  natr.data[ofsr] = rem;\n  return 0;\n}\n\n// nat1[nat2:] := nat1 / nat2\n// nat1[:nat2] := nat1 % nat2\n// len1 > len2, nat2[ofs2+len2-1] > nat1[ofs1+len1-1]\n//Provides: div_nat\n//Requires: div_digit_nat, div_helper, num_leading_zero_bits_in_digit, shift_left_nat, shift_right_nat, create_nat, set_to_zero_nat, mult_digit_nat, sub_nat, compare_nat, nat_of_array\nfunction div_nat(nat1, ofs1, len1, nat2, ofs2, len2) {\n  if(len2 == 1) {\n    div_digit_nat(nat1, ofs1+1, nat1, ofs1, nat1, ofs1, len1, nat2, ofs2);\n    return 0;\n  }\n\n  var s = num_leading_zero_bits_in_digit(nat2, ofs2+len2-1);\n  shift_left_nat(nat2, ofs2, len2, nat_of_array([0]), 0, s);\n  shift_left_nat(nat1, ofs1, len1, nat_of_array([0]), 0, s);\n\n  var d = (nat2.data[ofs2+len2-1] >>> 0) + 1;\n  var a = create_nat(len2+1);\n  for (var i = len1 - 1; i >= len2; i--) {\n    // Decent lower bound on quo\n    var quo = d == 4294967296 ? (nat1.data[ofs1+i] >>> 0) : div_helper((nat1.data[ofs1+i] >>> 0), (nat1.data[ofs1+i-1] >>>0), d)[0];\n    set_to_zero_nat(a, 0, len2+1);\n    mult_digit_nat(a, 0, len2+1, nat2, ofs2, len2, nat_of_array([quo]), 0);\n    sub_nat(nat1, ofs1+i-len2, len2+1, a, 0, len2+1, 1);\n\n    while (nat1.data[ofs1+i] != 0 || compare_nat(nat1, ofs1+i-len2, len2, nat2, ofs2, len2) >= 0) {\n      quo = quo + 1;\n      sub_nat(nat1, ofs1+i-len2, len2+1, nat2, ofs2, len2, 1);\n    }\n\n    nat1.data[ofs1+i] = quo;\n  }\n\n  shift_right_nat(nat1, ofs1, len2, nat_of_array([0]), 0, s); // shift remainder\n  shift_right_nat(nat2, ofs2, len2, nat_of_array([0]), 0, s); // restore\n  return 0;\n}\n\n\n// 0 <= shift < 32\n//Provides: shift_right_nat\nfunction shift_right_nat(nat1, ofs1, len1, nat2, ofs2, nbits) {\n  if(nbits == 0) {\n    nat2.data[ofs2] = 0;\n    return 0;\n  }\n  var wrap = 0;\n  for(var i = len1-1; i >= 0; i--) {\n    var a = nat1.data[ofs1+i] >>> 0;\n    nat1.data[ofs1+i] = (a >>> nbits) | wrap;\n    wrap = a << (32 - nbits);\n  }\n  nat2.data[ofs2] = wrap;\n  return 0;\n}\n\n//Provides: compare_digits_nat\nfunction compare_digits_nat(nat1, ofs1, nat2, ofs2) {\n  if(nat1.data[ofs1] > nat2.data[ofs2]) return 1;\n  if(nat1.data[ofs1] < nat2.data[ofs2]) return -1;\n  return 0;\n}\n\n//Provides: compare_nat\n//Requires: num_digits_nat\nfunction compare_nat(nat1, ofs1, len1, nat2, ofs2, len2) {\n  var a = num_digits_nat(nat1, ofs1, len1);\n  var b = num_digits_nat(nat2, ofs2, len2);\n  if(a > b) return 1;\n  if(a < b) return -1;\n  for(var i = len1 - 1; i >= 0; i--) {\n    if ((nat1.data[ofs1+i] >>> 0) > (nat2.data[ofs2+i] >>> 0)) return 1;\n    if ((nat1.data[ofs1+i] >>> 0) < (nat2.data[ofs2+i] >>> 0)) return -1;\n  }\n  return 0;\n}\n\n//Provides: compare_nat_real\n//Requires: compare_nat\nfunction compare_nat_real(nat1,nat2){\n  return compare_nat(nat1,0,nat1.data.length,nat2,0,nat2.data.length);\n}\n\n//Provides: land_digit_nat\nfunction land_digit_nat(nat1, ofs1, nat2, ofs2) {\n  nat1.data[ofs1] &= nat2.data[ofs2];\n  return 0;\n}\n\n//Provides: lor_digit_nat\nfunction lor_digit_nat(nat1, ofs1, nat2, ofs2) {\n  nat1.data[ofs1] |= nat2.data[ofs2];\n  return 0;\n}\n\n//Provides: lxor_digit_nat\nfunction lxor_digit_nat(nat1, ofs1, nat2, ofs2) {\n  nat1.data[ofs1] ^= nat2.data[ofs2];\n  return 0;\n}\n\n\n//Provides: serialize_nat\nfunction serialize_nat(writer, nat, sz){\n  var len = nat.data.length;\n  writer.write(32, len);\n  for(var i = 0; i < len; i++){\n    writer.write(32, nat.data[i]);\n  }\n  sz[0] = len * 4;\n  sz[1] = len * 8;\n}\n\n//Provides: deserialize_nat\n//Requires: MlNat\nfunction deserialize_nat(reader, sz){\n  var len = reader.read32s();\n  var nat = new MlNat(len);\n  for(var i = 0; i < len; i++){\n    nat.data[i] = reader.read32s();\n  }\n  sz[0] = len * 4;\n  return nat;\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Jérôme Vouillon, Hugo Heuzard\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: fs_node_supported\nfunction fs_node_supported () {\n  return (\n    typeof globalThis.process !== 'undefined'\n      && typeof globalThis.process.versions !== 'undefined'\n      && typeof globalThis.process.versions.node !== 'undefined')\n}\n//Provides: fs_node_supported\n//If: browser\nfunction fs_node_supported () {\n  return false\n}\n\n\n//Provides: MlNodeDevice\n//Requires: MlNodeFd, caml_raise_sys_error, caml_raise_with_args\n//Requires: make_unix_err_args, caml_named_value, caml_string_of_jsstring\nfunction MlNodeDevice(root) {\n  this.fs = require('fs');\n  this.root = root;\n}\nMlNodeDevice.prototype.nm = function(name) {\n  return (this.root + name);\n}\nMlNodeDevice.prototype.exists = function(name) {\n  try {\n    return this.fs.existsSync(this.nm(name))?1:0;\n  } catch (err) {\n    return 0;\n  }\n}\nMlNodeDevice.prototype.isFile = function(name) {\n  try {\n    return this.fs.statSync(this.nm(name)).isFile()?1:0;\n  } catch (err) {\n    caml_raise_sys_error(err.toString());\n  }\n}\nMlNodeDevice.prototype.mkdir = function(name, mode, raise_unix) {\n  try {\n    this.fs.mkdirSync(this.nm(name),{mode:mode});\n    return 0\n  } catch (err) {\n    this.raise_nodejs_error(err, raise_unix);\n  }\n}\nMlNodeDevice.prototype.rmdir = function(name, raise_unix) {\n  try {\n    this.fs.rmdirSync(this.nm(name));\n    return 0\n  } catch (err) {\n    this.raise_nodejs_error(err, raise_unix);\n  }\n}\nMlNodeDevice.prototype.readdir = function(name, raise_unix) {\n  try {\n    return this.fs.readdirSync(this.nm(name));\n  } catch (err) {\n    this.raise_nodejs_error(err, raise_unix);\n  }\n}\nMlNodeDevice.prototype.is_dir = function(name) {\n  try {\n    return this.fs.statSync(this.nm(name)).isDirectory()?1:0;\n  } catch (err) {\n    caml_raise_sys_error(err.toString());\n  }\n}\nMlNodeDevice.prototype.unlink = function(name, raise_unix) {\n  try {\n    var b = this.fs.existsSync(this.nm(name))?1:0;\n    this.fs.unlinkSync(this.nm(name));\n    return b;\n  } catch (err) {\n    this.raise_nodejs_error(err, raise_unix);\n  }\n}\nMlNodeDevice.prototype.open = function(name, f, raise_unix) {\n  var consts = require('constants');\n  var res = 0;\n  for(var key in f){\n    switch(key){\n    case \"rdonly\"  : res |= consts.O_RDONLY; break;\n    case \"wronly\"  : res |= consts.O_WRONLY; break;\n    case \"append\"  :\n      res |= consts.O_WRONLY | consts.O_APPEND;\n      break;\n    case \"create\"   : res |= consts.O_CREAT;    break;\n    case \"truncate\" : res |= consts.O_TRUNC;    break;\n    case \"excl\"     : res |= consts.O_EXCL;     break;\n    case \"binary\"   : res |= consts.O_BINARY;   break;\n    case \"text\"     : res |= consts.O_TEXT;     break;\n    case \"nonblock\" : res |= consts.O_NONBLOCK; break;\n    }\n  }\n  try {\n    var fd = this.fs.openSync(this.nm(name), res);\n    var isCharacterDevice = this.fs.lstatSync(this.nm(name)).isCharacterDevice();\n    f.isCharacterDevice = isCharacterDevice;\n    return new MlNodeFd(fd, f);\n  } catch (err) {\n    this.raise_nodejs_error(err, raise_unix);\n  }\n}\n\nMlNodeDevice.prototype.rename = function(o, n, raise_unix) {\n  try {\n    this.fs.renameSync(this.nm(o), this.nm(n));\n  } catch (err) {\n    this.raise_nodejs_error(err, raise_unix);\n  }\n}\nMlNodeDevice.prototype.stat = function(name, raise_unix) {\n  try {\n    var js_stats = this.fs.statSync(this.nm(name));\n    return this.stats_from_js(js_stats);\n  } catch (err) {\n    this.raise_nodejs_error(err, raise_unix);\n  }\n}\nMlNodeDevice.prototype.lstat = function(name, raise_unix) {\n  try {\n    var js_stats = this.fs.lstatSync(this.nm(name));\n    return this.stats_from_js(js_stats);\n  } catch (err) {\n    this.raise_nodejs_error(err, raise_unix);\n  }\n}\nMlNodeDevice.prototype.symlink = function(to_dir, target, path, raise_unix) {\n  try {\n    this.fs.symlinkSync(this.nm(target), this.nm(path), to_dir ? 'dir' : 'file');\n    return 0;\n  } catch (err) {\n    this.raise_nodejs_error(err, raise_unix);\n  }\n}\nMlNodeDevice.prototype.readlink = function(name, raise_unix) {\n  try {\n    var link = this.fs.readlinkSync(this.nm(name), 'utf8');\n    return caml_string_of_jsstring(link);\n  } catch (err) {\n    this.raise_nodejs_error(err, raise_unix);\n  }\n}\nMlNodeDevice.prototype.opendir = function(name, raise_unix) {\n  try {\n    return this.fs.opendirSync(this.nm(name));\n  } catch (err) {\n    this.raise_nodejs_error(err, raise_unix);\n  }\n}\nMlNodeDevice.prototype.raise_nodejs_error = function(err, raise_unix) {\n  var unix_error = caml_named_value(\"Unix.Unix_error\");\n  if (raise_unix && unix_error) {\n    var args = make_unix_err_args(err.code, err.syscall, err.path, err.errno);\n    caml_raise_with_args(unix_error, args);\n  } else {\n    caml_raise_sys_error(err.toString());\n  }\n}\nMlNodeDevice.prototype.stats_from_js = function(js_stats) {\n  /* ===Unix.file_kind===\n   * type file_kind =\n   *     S_REG                       (** Regular file *)\n   *   | S_DIR                       (** Directory *)\n   *   | S_CHR                       (** Character device *)\n   *   | S_BLK                       (** Block device *)\n   *   | S_LNK                       (** Symbolic link *)\n   *   | S_FIFO                      (** Named pipe *)\n   *   | S_SOCK                      (** Socket *)\n   */\n  var file_kind;\n  if (js_stats.isFile()) {\n    file_kind = 0;\n  } else if (js_stats.isDirectory()) {\n    file_kind = 1;\n  } else if (js_stats.isCharacterDevice()) {\n    file_kind = 2;\n  } else if (js_stats.isBlockDevice()) {\n    file_kind = 3;\n  } else if (js_stats.isSymbolicLink()) {\n    file_kind = 4;\n  } else if (js_stats.isFIFO()) {\n    file_kind = 5;\n  } else if (js_stats.isSocket()) {\n    file_kind = 6;\n  }\n  /* ===Unix.stats===\n   * type stats =\n   *  { st_dev : int;               (** Device number *)\n   *    st_ino : int;               (** Inode number *)\n   *    st_kind : file_kind;        (** Kind of the file *)\n   *    st_perm : file_perm;        (** Access rights *)\n   *    st_nlink : int;             (** Number of links *)\n   *    st_uid : int;               (** User id of the owner *)\n   *    st_gid : int;               (** Group ID of the file's group *)\n   *    st_rdev : int;              (** Device ID (if special file) *)\n   *    st_size : int;              (** Size in bytes *)\n   *    st_atime : float;           (** Last access time *)\n   *    st_mtime : float;           (** Last modification time *)\n   *    st_ctime : float;           (** Last status change time *)\n   *  }\n   */\n  return BLOCK(\n    0,\n    js_stats.dev,\n    js_stats.ino,\n    file_kind,\n    js_stats.mode,\n    js_stats.nlink,\n    js_stats.uid,\n    js_stats.gid,\n    js_stats.rdev,\n    js_stats.size,\n    js_stats.atimeMs,\n    js_stats.mtimeMs,\n    js_stats.ctimeMs\n  );\n}\n\nMlNodeDevice.prototype.constructor = MlNodeDevice\n\n//Provides: MlNodeDevice\n//If: browser\nfunction MlNodeDevice() {\n}\n\n//Provides: MlNodeFd\n//Requires: MlFile, caml_uint8_array_of_string, caml_uint8_array_of_bytes, caml_bytes_set, caml_raise_sys_error\nfunction MlNodeFd(fd, flags){\n  this.fs = require('fs');\n  this.fd = fd;\n  this.flags = flags;\n}\nMlNodeFd.prototype = new MlFile ();\nMlNodeFd.prototype.constructor = MlNodeFd;\n\nMlNodeFd.prototype.truncate = function(len){\n  try {\n    this.fs.ftruncateSync(this.fd,len|0);\n  } catch (err) {\n    caml_raise_sys_error(err.toString());\n  }\n}\nMlNodeFd.prototype.length = function () {\n  try {\n    return this.fs.fstatSync(this.fd).size;\n  } catch (err) {\n    caml_raise_sys_error(err.toString());\n  }\n}\nMlNodeFd.prototype.write = function(offset,buf,buf_offset,len){\n  try {\n    if(this.flags.isCharacterDevice)\n      this.fs.writeSync(this.fd, buf, buf_offset, len);\n    else\n      this.fs.writeSync(this.fd, buf, buf_offset, len, offset);\n  } catch (err) {\n    caml_raise_sys_error(err.toString());\n  }\n  return 0;\n}\nMlNodeFd.prototype.read = function(offset,a,buf_offset,len){\n  try {\n    if(this.flags.isCharacterDevice)\n      var read = this.fs.readSync(this.fd, a, buf_offset, len);\n    else\n      var read = this.fs.readSync(this.fd, a, buf_offset, len, offset);\n    return read;\n  } catch (err) {\n    caml_raise_sys_error(err.toString());\n  }\n}\nMlNodeFd.prototype.close = function(){\n  try {\n    this.fs.closeSync(this.fd);\n    return 0\n  } catch (err) {\n    caml_raise_sys_error(err.toString());\n  }\n}\n\n\n//Provides: MlNodeFd\n//If: browser\nfunction MlNodeFd(){\n}\n\n\n//Provides: caml_sys_open_for_node\n//Requires: MlNodeFd\nfunction caml_sys_open_for_node(fd, flags){\n  if(flags.name) {\n    try {\n      var fs = require(\"fs\");\n      var fd2 = fs.openSync(flags.name, \"rs\");\n      return new MlNodeFd(fd2, flags);\n    } catch(e) {  }\n  }\n  return new MlNodeFd(fd, flags);\n}\n\n//Provides: caml_sys_open_for_node\n//If: browser\nfunction caml_sys_open_for_node(fd, flags){\n  return null;\n}\n","///////// BIGSTRING\n\n//Provides: caml_hash_mix_bigstring\n//Requires: caml_hash_mix_bytes_arr\nfunction caml_hash_mix_bigstring(h, bs) {\n  return caml_hash_mix_bytes_arr(h,bs.data);\n}\n\n//Provides: bigstring_to_array_buffer mutable\nfunction bigstring_to_array_buffer(bs) {\n  return bs.data.buffer\n}\n\n//Provides: bigstring_to_typed_array mutable\nfunction bigstring_to_typed_array(bs) {\n  return bs.data\n}\n\n//Provides: bigstring_of_array_buffer mutable\n//Requires: caml_ba_create_unsafe\nfunction bigstring_of_array_buffer(ab) {\n  var ta = new Uint8Array(ab);\n  return caml_ba_create_unsafe(12, 0, [ta.length], ta);\n}\n\n//Provides: bigstring_of_typed_array mutable\n//Requires: caml_ba_create_unsafe\nfunction bigstring_of_typed_array(ba) {\n  var ta = new Uint8Array(ba.buffer, ba.byteOffset, ba.length * ba.BYTES_PER_ELEMENT);\n  return caml_ba_create_unsafe(12, 0, [ta.length], ta);\n}\n\n//Provides: caml_bigstring_memcmp\n//Requires: caml_ba_get_1\nfunction caml_bigstring_memcmp(s1, pos1, s2, pos2, len){\n  for (var i = 0; i < len; i++) {\n    var a = caml_ba_get_1(s1,pos1 + i);\n    var b = caml_ba_get_1(s2,pos2 + i);\n    if (a < b) return -1;\n    if (a > b) return 1;\n  }\n  return 0;\n}\n\n//Provides: caml_bigstring_blit_ba_to_ba\n//Requires: caml_invalid_argument, caml_array_bound_error\nfunction caml_bigstring_blit_ba_to_ba(ba1, pos1, ba2, pos2, len){\n  if(12 != ba1.kind)\n    caml_invalid_argument(\"caml_bigstring_blit_ba_to_ba: kind mismatch\");\n  if(12 != ba2.kind)\n    caml_invalid_argument(\"caml_bigstring_blit_ba_to_ba: kind mismatch\");\n  if(len == 0) return 0;\n  var ofs1 = ba1.offset(pos1);\n  var ofs2 = ba2.offset(pos2);\n  if(ofs1 + len > ba1.data.length){\n    caml_array_bound_error();\n  }\n  if(ofs2 + len > ba2.data.length){\n    caml_array_bound_error();\n  }\n  var slice = ba1.data.subarray(ofs1,ofs1+len);\n  ba2.data.set(slice,pos2);\n  return 0\n}\n\n//Provides: caml_bigstring_blit_string_to_ba\n//Requires: caml_invalid_argument, caml_array_bound_error, caml_uint8_array_of_string\n//Requires: caml_ml_string_length\nfunction caml_bigstring_blit_string_to_ba(str1, pos1, ba2, pos2, len){\n  if(12 != ba2.kind)\n    caml_invalid_argument(\"caml_bigstring_blit_string_to_ba: kind mismatch\");\n  if(len == 0) return 0;\n  var ofs2 = ba2.offset(pos2);\n  if(pos1 + len > caml_ml_string_length(str1)) {\n    caml_array_bound_error();\n  }\n  if(ofs2 + len > ba2.data.length) {\n    caml_array_bound_error();\n  }\n  var slice = caml_uint8_array_of_string(str1).slice(pos1,pos1 + len);\n  ba2.data.set(slice,ofs2);\n  return 0\n}\n\n//Provides: caml_bigstring_blit_bytes_to_ba\n//Requires: caml_invalid_argument, caml_array_bound_error, caml_uint8_array_of_bytes\n//Requires: caml_ml_bytes_length\nfunction caml_bigstring_blit_bytes_to_ba(str1, pos1, ba2, pos2, len){\n  if(12 != ba2.kind)\n    caml_invalid_argument(\"caml_bigstring_blit_string_to_ba: kind mismatch\");\n  if(len == 0) return 0;\n  var ofs2 = ba2.offset(pos2);\n  if(pos1 + len > caml_ml_bytes_length(str1)) {\n    caml_array_bound_error();\n  }\n  if(ofs2 + len > ba2.data.length) {\n    caml_array_bound_error();\n  }\n  var slice = caml_uint8_array_of_bytes(str1).slice(pos1,pos1 + len);\n  ba2.data.set(slice,ofs2);\n  return 0\n}\n\n//Provides: caml_bigstring_blit_ba_to_bytes\n//Requires: caml_invalid_argument, caml_array_bound_error\n//Requires: caml_blit_bytes, caml_bytes_of_array\n//Requires: caml_ml_bytes_length\nfunction caml_bigstring_blit_ba_to_bytes(ba1, pos1, bytes2, pos2, len){\n  if(12 != ba1.kind)\n    caml_invalid_argument(\"caml_bigstring_blit_string_to_ba: kind mismatch\");\n  if(len == 0) return 0;\n  var ofs1 = ba1.offset(pos1);\n  if(ofs1 + len > ba1.data.length){\n    caml_array_bound_error();\n  }\n  if(pos2 + len > caml_ml_bytes_length(bytes2)){\n    caml_array_bound_error();\n  }\n  var slice = ba1.data.slice(ofs1, ofs1+len);\n  caml_blit_bytes(caml_bytes_of_array(slice), 0, bytes2, pos2, len);\n  return 0\n}\n","/*----------------------------------------------------------------------------\n    Copyright (c) 2017 Inhabited Type LLC.\n\n    All rights reserved.\n\n    Redistribution and use in source and binary forms, with or without\n    modification, are permitted provided that the following conditions\n    are met:\n\n    1. Redistributions of source code must retain the above copyright\n       notice, this list of conditions and the following disclaimer.\n\n    2. Redistributions in binary form must reproduce the above copyright\n       notice, this list of conditions and the following disclaimer in the\n       documentation and/or other materials provided with the distribution.\n\n    3. Neither the name of the author nor the names of his contributors\n       may be used to endorse or promote products derived from this software\n       without specific prior written permission.\n\n    THIS SOFTWARE IS PROVIDED BY THE CONTRIBUTORS ``AS IS'' AND ANY EXPRESS\n    OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n    WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n    DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR\n    ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n    DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\n    OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\n    HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,\n    STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN\n    ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE\n    POSSIBILITY OF SUCH DAMAGE.\n  ----------------------------------------------------------------------------*/\n\n//Provides: bigstringaf_blit_to_bytes\n//Requires: caml_bigstring_blit_ba_to_bytes\nfunction bigstringaf_blit_to_bytes(src, src_off, dst, dst_off, len) {\n  return caml_bigstring_blit_ba_to_bytes(src,src_off,dst,dst_off,len);\n}\n\n//Provides: bigstringaf_blit_to_bigstring\n//Requires: caml_bigstring_blit_ba_to_ba\nfunction bigstringaf_blit_to_bigstring(src, src_off, dst, dst_off, len) {\n  return caml_bigstring_blit_ba_to_ba(src, src_off, dst, dst_off, len);\n}\n\n//Provides: bigstringaf_blit_from_bytes\n//Requires: caml_bigstring_blit_string_to_ba\nfunction bigstringaf_blit_from_bytes(src, src_off, dst, dst_off, len) {\n  return caml_bigstring_blit_string_to_ba(src, src_off, dst, dst_off, len);\n}\n\n//Provides: bigstringaf_memcmp_bigstring\n//Requires: caml_ba_get_1, caml_int_compare\nfunction bigstringaf_memcmp_bigstring(ba1, ba1_off, ba2, ba2_off, len) {\n  for (var i = 0; i < len; i++) {\n    var c = caml_int_compare(caml_ba_get_1(ba1, ba1_off + i), caml_ba_get_1(ba2, ba2_off + i));\n    if (c != 0) return c\n  }\n  return 0;\n}\n\n//Provides: bigstringaf_memcmp_string\n//Requires: caml_ba_get_1, caml_int_compare, caml_string_unsafe_get\nfunction bigstringaf_memcmp_string(ba, ba_off, str, str_off, len) {\n  for (var i = 0; i < len; i++) {\n    var c = caml_int_compare(caml_ba_get_1(ba, ba_off + i), caml_string_unsafe_get(str, str_off + i));\n    if (c != 0) return c\n  }\n  return 0;\n}\n\n//Provides: bigstringaf_memchr\n//Requires: caml_ba_get_1\nfunction bigstringaf_memchr(ba, ba_off, chr, len) {\n  for (var i = 0; i < len; i++) {\n    if (caml_ba_get_1(ba, ba_off + i) == chr) {\n      return (ba_off + i);\n    }\n  }\n  return -1;\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_compare_val_tag\n//Requires: caml_is_ml_string, caml_is_ml_bytes\nfunction caml_compare_val_tag(a){\n  if (typeof a === \"number\") return 1000; // int_tag (we use it for all numbers)\n  else if (caml_is_ml_bytes(a)) return 252; // string_tag\n  else if (caml_is_ml_string(a)) return 1252; // ocaml string (if different from bytes)\n  else if (a instanceof Array && a[0] === (a[0]>>>0) && a[0] <= 255) {\n    // Look like an ocaml block\n    var tag = a[0] | 0;\n    // ignore double_array_tag because we cannot accurately set\n    // this tag when we create an array of float.\n    return (tag == 254)?0:tag\n  }\n  else if (a instanceof String) return 12520; // javascript string, like string_tag (252)\n  else if (typeof a == \"string\") return 12520; // javascript string, like string_tag (252)\n  else if (a instanceof Number) return 1000; // int_tag (we use it for all numbers)\n  else if (a && a.caml_custom) return 1255; // like custom_tag (255)\n  else if (a && a.compare) return 1256; // like custom_tag (255)\n  else if (typeof a == \"function\") return 1247; // like closure_tag (247)\n  else if (typeof a == \"symbol\") return 1251;\n  return 1001; //out_of_heap_tag\n}\n\n//Provides: caml_compare_val_get_custom\n//Requires: caml_custom_ops\nfunction caml_compare_val_get_custom(a){\n  return caml_custom_ops[a.caml_custom] && caml_custom_ops[a.caml_custom].compare;\n}\n\n//Provides: caml_compare_val_number_custom\n//Requires: caml_compare_val_get_custom\nfunction caml_compare_val_number_custom(num, custom, swap, total) {\n  var comp = caml_compare_val_get_custom(custom);\n  if(comp) {\n    var x = (swap > 0)?comp(custom,num,total):comp(num,custom,total);\n    if(total && x != x) return swap; // total && nan\n    if(+x != +x) return +x; // nan\n    if((x | 0) != 0) return (x | 0); // !nan\n  }\n  return swap\n}\n\n//Provides: caml_compare_val (const, const, const)\n//Requires: caml_int_compare, caml_string_compare, caml_bytes_compare\n//Requires: caml_invalid_argument, caml_compare_val_get_custom, caml_compare_val_tag\n//Requires: caml_compare_val_number_custom\n//Requires: caml_jsbytes_of_string\n//Requires: caml_is_continuation_tag\nfunction caml_compare_val (a, b, total) {\n  var stack = [];\n  for(;;) {\n    if (!(total && a === b)) {\n      var tag_a = caml_compare_val_tag(a);\n      // forward_tag ?\n      if(tag_a == 250) { a = a[1]; continue }\n\n      var tag_b = caml_compare_val_tag(b);\n      // forward_tag ?\n      if(tag_b == 250) { b = b[1]; continue }\n\n      // tags are different\n      if(tag_a !== tag_b) {\n        if(tag_a == 1000) {\n          if(tag_b == 1255) { //immediate can compare against custom\n            return caml_compare_val_number_custom(a, b, -1, total);\n          }\n          return -1\n        }\n        if(tag_b == 1000) {\n          if(tag_a == 1255) { //immediate can compare against custom\n            return caml_compare_val_number_custom(b, a, 1, total);\n          }\n          return 1\n        }\n        return (tag_a < tag_b)?-1:1;\n      }\n      switch(tag_a){\n        // 246: Lazy_tag handled bellow\n      case 247: // Closure_tag\n        // Cannot happen\n        caml_invalid_argument(\"compare: functional value\");\n        break\n      case 248: // Object\n        var x = caml_int_compare(a[2], b[2]);\n        if (x != 0) return (x | 0);\n        break;\n      case 249: // Infix\n        // Cannot happen\n        caml_invalid_argument(\"compare: functional value\");\n        break\n      case 250: // Forward tag\n        // Cannot happen, handled above\n        caml_invalid_argument(\"equal: got Forward_tag, should not happen\");\n        break;\n      case 251: //Abstract\n        caml_invalid_argument(\"equal: abstract value\");\n        break;\n      case 252: // OCaml bytes\n        if (a !== b) {\n          var x = caml_bytes_compare(a, b);\n          if (x != 0) return (x | 0);\n        };\n        break;\n      case 253: // Double_tag\n        // Cannot happen\n        caml_invalid_argument(\"equal: got Double_tag, should not happen\");\n        break;\n      case 254: // Double_array_tag\n        // Cannot happen, handled above\n        caml_invalid_argument(\"equal: got Double_array_tag, should not happen\");\n        break\n      case 255: // Custom_tag\n        caml_invalid_argument(\"equal: got Custom_tag, should not happen\");\n        break;\n      case 1247: // Function\n        caml_invalid_argument(\"compare: functional value\");\n        break;\n      case 1255: // Custom\n        var comp = caml_compare_val_get_custom(a);\n        if(comp != caml_compare_val_get_custom(b)){\n          return (a.caml_custom<b.caml_custom)?-1:1;\n        }\n        if(!comp)\n          caml_invalid_argument(\"compare: abstract value\");\n        var x = comp(a,b,total);\n        if(x != x){ // Protect against invalid UNORDERED\n          return total?-1:x;\n        }\n        if(x !== (x|0)){ // Protect against invalid return value\n          return -1\n        }\n        if (x != 0) return (x | 0);\n        break;\n      case 1256: // compare function\n        var x = a.compare(b,total);\n        if(x != x) { // Protect against invalid UNORDERED\n          return total?-1:x;\n        }\n        if(x !== (x|0)){ // Protect against invalid return value\n          return -1\n        }\n        if (x != 0) return (x | 0);\n        break;\n      case 1000: // Number\n        a = +a;\n        b = +b;\n        if (a < b) return -1;\n        if (a > b) return 1;\n        if (a != b) {\n          if (!total) return NaN;\n          if (a == a) return 1;\n          if (b == b) return -1;\n        }\n        break;\n      case 1001: // The rest\n        // Here we can be in the following cases:\n        // 1. JavaScript primitive types\n        // 2. JavaScript object that can be coerced to primitive types\n        // 3. JavaScript object than cannot be coerced to primitive types\n        //\n        // (3) will raise a [TypeError]\n        // (2) will coerce to primitive types using [valueOf] or [toString]\n        // (2) and (3), after eventual coercion\n        // - if a and b are strings, apply lexicographic comparison\n        // - if a or b are not strings, convert a and b to number\n        //   and apply standard comparison\n        //\n        // Exception: `!=` will not coerce/convert if both a and b are objects\n        if (a < b) return -1;\n        if (a > b) return 1;\n        if (a != b) {\n          if (!total) return NaN;\n          if (a == a) return 1;\n          if (b == b) return -1;\n        }\n        break;\n      case 1251: // JavaScript Symbol, no ordering.\n        if(a !== b) {\n          if (!total) return NaN;\n          return 1;\n        }\n        break;\n      case 1252: // ocaml strings\n        var a = caml_jsbytes_of_string(a);\n        var b = caml_jsbytes_of_string(b);\n        if(a !== b) {\n          if(a < b) return -1;\n          if(a > b) return 1;\n        }\n        break;\n      case 12520: // javascript strings\n        var a = a.toString();\n        var b = b.toString();\n        if(a !== b) {\n          if(a < b) return -1;\n          if(a > b) return 1;\n        }\n        break;\n      case 246: // Lazy_tag\n      case 254: // Double_array\n      default: // Block with other tag\n        if(caml_is_continuation_tag(tag_a)) {\n          caml_invalid_argument(\"compare: continuation value\");\n          break;\n        }\n        if (a.length != b.length) return (a.length < b.length)?-1:1;\n        if (a.length > 1) stack.push(a, b, 1);\n        break;\n      }\n    }\n    if (stack.length == 0) return 0;\n    var i = stack.pop();\n    b = stack.pop();\n    a = stack.pop();\n    if (i + 1 < a.length) stack.push(a, b, i + 1);\n    a = a[i];\n    b = b[i];\n  }\n}\n//Provides: caml_compare (const, const)\n//Requires: caml_compare_val\nfunction caml_compare (a, b) { return caml_compare_val (a, b, true); }\n//Provides: caml_int_compare mutable (const, const)\nfunction caml_int_compare (a, b) {\n  if (a < b) return (-1); if (a == b) return 0; return 1;\n}\n//Provides: caml_equal mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_equal (x, y) { return +(caml_compare_val(x,y,false) == 0); }\n//Provides: caml_notequal mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_notequal (x, y) { return +(caml_compare_val(x,y,false) != 0); }\n//Provides: caml_greaterequal mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_greaterequal (x, y) { return +(caml_compare_val(x,y,false) >= 0); }\n//Provides: caml_greaterthan mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_greaterthan (x, y) { return +(caml_compare_val(x,y,false) > 0); }\n//Provides: caml_lessequal mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_lessequal (x, y) { return +(caml_compare_val(x,y,false) <= 0); }\n//Provides: caml_lessthan mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_lessthan (x, y) { return +(caml_compare_val(x,y,false) < 0); }\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_md5_chan\n//Requires: caml_string_of_array\n//Requires: caml_raise_end_of_file, caml_ml_input_block\n//Requires: caml_MD5Init, caml_MD5Update, caml_MD5Final\nfunction caml_md5_chan(chanid,toread){\n  var ctx = caml_MD5Init();\n  var buffer = new Uint8Array(4096);\n  if(toread < 0){\n    while(true){\n      var read = caml_ml_input_block(chanid,buffer,0,buffer.length);\n      if(read == 0) break;\n      caml_MD5Update(ctx,buffer.subarray(0, read), read);\n    }\n  } else {\n    while(toread > 0) {\n      var read = caml_ml_input_block(chanid,buffer,0, (toread > buffer.length ? buffer.length : toread));\n      if(read == 0) caml_raise_end_of_file();\n      caml_MD5Update(ctx,buffer.subarray(0, read), read);\n      toread -= read\n    }\n  }\n  return caml_string_of_array(caml_MD5Final(ctx));\n}\n\n//Provides: caml_md5_string\n//Requires: caml_bytes_of_string, caml_md5_bytes\nfunction caml_md5_string(s, ofs, len) {\n  return caml_md5_bytes(caml_bytes_of_string(s),ofs,len);\n}\n\n//Provides: caml_MD5Transform\nvar caml_MD5Transform = (function () {\n  function add (x, y) { return (x + y) | 0; }\n  function xx(q,a,b,x,s,t) {\n    a = add(add(a, q), add(x, t));\n    return add((a << s) | (a >>> (32 - s)), b);\n  }\n  function ff(a,b,c,d,x,s,t) {\n    return xx((b & c) | ((~b) & d), a, b, x, s, t);\n  }\n  function gg(a,b,c,d,x,s,t) {\n    return xx((b & d) | (c & (~d)), a, b, x, s, t);\n  }\n  function hh(a,b,c,d,x,s,t) { return xx(b ^ c ^ d, a, b, x, s, t); }\n  function ii(a,b,c,d,x,s,t) { return xx(c ^ (b | (~d)), a, b, x, s, t); }\n\n  return function (w, buffer) {\n    var a = w[0], b = w[1], c = w[2], d = w[3];\n\n    a = ff(a, b, c, d, buffer[ 0], 7, 0xD76AA478);\n    d = ff(d, a, b, c, buffer[ 1], 12, 0xE8C7B756);\n    c = ff(c, d, a, b, buffer[ 2], 17, 0x242070DB);\n    b = ff(b, c, d, a, buffer[ 3], 22, 0xC1BDCEEE);\n    a = ff(a, b, c, d, buffer[ 4], 7, 0xF57C0FAF);\n    d = ff(d, a, b, c, buffer[ 5], 12, 0x4787C62A);\n    c = ff(c, d, a, b, buffer[ 6], 17, 0xA8304613);\n    b = ff(b, c, d, a, buffer[ 7], 22, 0xFD469501);\n    a = ff(a, b, c, d, buffer[ 8], 7, 0x698098D8);\n    d = ff(d, a, b, c, buffer[ 9], 12, 0x8B44F7AF);\n    c = ff(c, d, a, b, buffer[10], 17, 0xFFFF5BB1);\n    b = ff(b, c, d, a, buffer[11], 22, 0x895CD7BE);\n    a = ff(a, b, c, d, buffer[12], 7, 0x6B901122);\n    d = ff(d, a, b, c, buffer[13], 12, 0xFD987193);\n    c = ff(c, d, a, b, buffer[14], 17, 0xA679438E);\n    b = ff(b, c, d, a, buffer[15], 22, 0x49B40821);\n\n    a = gg(a, b, c, d, buffer[ 1], 5, 0xF61E2562);\n    d = gg(d, a, b, c, buffer[ 6], 9, 0xC040B340);\n    c = gg(c, d, a, b, buffer[11], 14, 0x265E5A51);\n    b = gg(b, c, d, a, buffer[ 0], 20, 0xE9B6C7AA);\n    a = gg(a, b, c, d, buffer[ 5], 5, 0xD62F105D);\n    d = gg(d, a, b, c, buffer[10], 9, 0x02441453);\n    c = gg(c, d, a, b, buffer[15], 14, 0xD8A1E681);\n    b = gg(b, c, d, a, buffer[ 4], 20, 0xE7D3FBC8);\n    a = gg(a, b, c, d, buffer[ 9], 5, 0x21E1CDE6);\n    d = gg(d, a, b, c, buffer[14], 9, 0xC33707D6);\n    c = gg(c, d, a, b, buffer[ 3], 14, 0xF4D50D87);\n    b = gg(b, c, d, a, buffer[ 8], 20, 0x455A14ED);\n    a = gg(a, b, c, d, buffer[13], 5, 0xA9E3E905);\n    d = gg(d, a, b, c, buffer[ 2], 9, 0xFCEFA3F8);\n    c = gg(c, d, a, b, buffer[ 7], 14, 0x676F02D9);\n    b = gg(b, c, d, a, buffer[12], 20, 0x8D2A4C8A);\n\n    a = hh(a, b, c, d, buffer[ 5], 4, 0xFFFA3942);\n    d = hh(d, a, b, c, buffer[ 8], 11, 0x8771F681);\n    c = hh(c, d, a, b, buffer[11], 16, 0x6D9D6122);\n    b = hh(b, c, d, a, buffer[14], 23, 0xFDE5380C);\n    a = hh(a, b, c, d, buffer[ 1], 4, 0xA4BEEA44);\n    d = hh(d, a, b, c, buffer[ 4], 11, 0x4BDECFA9);\n    c = hh(c, d, a, b, buffer[ 7], 16, 0xF6BB4B60);\n    b = hh(b, c, d, a, buffer[10], 23, 0xBEBFBC70);\n    a = hh(a, b, c, d, buffer[13], 4, 0x289B7EC6);\n    d = hh(d, a, b, c, buffer[ 0], 11, 0xEAA127FA);\n    c = hh(c, d, a, b, buffer[ 3], 16, 0xD4EF3085);\n    b = hh(b, c, d, a, buffer[ 6], 23, 0x04881D05);\n    a = hh(a, b, c, d, buffer[ 9], 4, 0xD9D4D039);\n    d = hh(d, a, b, c, buffer[12], 11, 0xE6DB99E5);\n    c = hh(c, d, a, b, buffer[15], 16, 0x1FA27CF8);\n    b = hh(b, c, d, a, buffer[ 2], 23, 0xC4AC5665);\n\n    a = ii(a, b, c, d, buffer[ 0], 6, 0xF4292244);\n    d = ii(d, a, b, c, buffer[ 7], 10, 0x432AFF97);\n    c = ii(c, d, a, b, buffer[14], 15, 0xAB9423A7);\n    b = ii(b, c, d, a, buffer[ 5], 21, 0xFC93A039);\n    a = ii(a, b, c, d, buffer[12], 6, 0x655B59C3);\n    d = ii(d, a, b, c, buffer[ 3], 10, 0x8F0CCC92);\n    c = ii(c, d, a, b, buffer[10], 15, 0xFFEFF47D);\n    b = ii(b, c, d, a, buffer[ 1], 21, 0x85845DD1);\n    a = ii(a, b, c, d, buffer[ 8], 6, 0x6FA87E4F);\n    d = ii(d, a, b, c, buffer[15], 10, 0xFE2CE6E0);\n    c = ii(c, d, a, b, buffer[ 6], 15, 0xA3014314);\n    b = ii(b, c, d, a, buffer[13], 21, 0x4E0811A1);\n    a = ii(a, b, c, d, buffer[ 4], 6, 0xF7537E82);\n    d = ii(d, a, b, c, buffer[11], 10, 0xBD3AF235);\n    c = ii(c, d, a, b, buffer[ 2], 15, 0x2AD7D2BB);\n    b = ii(b, c, d, a, buffer[ 9], 21, 0xEB86D391);\n\n    w[0] = add(a, w[0]);\n    w[1] = add(b, w[1]);\n    w[2] = add(c, w[2]);\n    w[3] = add(d, w[3]);\n  }})()\n\n//Provides: caml_MD5Init\nfunction caml_MD5Init() {\n  var buffer = new ArrayBuffer(64);\n  var b32 = new Uint32Array(buffer);\n  var b8 = new Uint8Array(buffer);\n  return {len:0,\n          w:new Uint32Array([0x67452301, 0xEFCDAB89, 0x98BADCFE, 0x10325476]),\n          b32:b32,\n          b8:b8}\n}\n\n//Provides: caml_MD5Update\n//Requires: caml_MD5Transform\nfunction caml_MD5Update(ctx, input, input_len){\n  var in_buf = ctx.len & 0x3f;\n  var input_pos = 0;\n  ctx.len += input_len;\n  if(in_buf){\n    var missing = 64 - in_buf;\n    if(input_len < missing) {\n      ctx.b8.set(input.subarray(0,input_len),in_buf);\n      return\n    }\n    ctx.b8.set(input.subarray(0,missing),in_buf);\n    caml_MD5Transform(ctx.w, ctx.b32);\n    input_len -= missing;\n    input_pos += missing;\n  }\n  while(input_len >= 64){\n    ctx.b8.set(input.subarray(input_pos,input_pos + 64), 0);\n    caml_MD5Transform(ctx.w, ctx.b32);\n    input_len -= 64;\n    input_pos += 64;\n  }\n  if(input_len)\n    ctx.b8.set(input.subarray(input_pos,input_pos + input_len), 0);\n}\n\n//Provides: caml_MD5Final\n//Requires: caml_MD5Transform\nfunction caml_MD5Final(ctx){\n  var in_buf = ctx.len & 0x3f;\n  ctx.b8[in_buf] = 0x80;\n  in_buf ++;\n  if(in_buf > 56) {\n    for(var j = in_buf; j < 64; j++){\n      ctx.b8[j] = 0;\n    }\n    caml_MD5Transform(ctx.w, ctx.b32);\n    for(var j = 0; j < 56; j++){\n      ctx.b8[j] = 0;\n    }\n  } else {\n    for(var j = in_buf; j < 56; j++){\n      ctx.b8[j] = 0;\n    }\n  }\n  ctx.b32[14] = ctx.len << 3;\n  ctx.b32[15] = (ctx.len >> 29) & 0x1FFFFFFF;\n  caml_MD5Transform(ctx.w, ctx.b32);\n  var t = new Uint8Array(16);\n  for (var i = 0; i < 4; i++)\n    for (var j = 0; j < 4; j++)\n      t[i * 4 + j] = (ctx.w[i] >> (8 * j)) & 0xFF;\n  return t;\n}\n\n\n//Provides: caml_md5_bytes\n//Requires: caml_uint8_array_of_bytes, caml_string_of_array\n//Requires: caml_MD5Init, caml_MD5Update, caml_MD5Final\nfunction caml_md5_bytes(s, ofs, len) {\n  var ctx = caml_MD5Init();\n  var a = caml_uint8_array_of_bytes(s);\n  caml_MD5Update(ctx,a.subarray(ofs, ofs + len), len);\n  return caml_string_of_array(caml_MD5Final(ctx));\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: jsoo_floor_log2\nvar log2_ok = Math.log2 && Math.log2(1.1235582092889474E+307) == 1020\nfunction jsoo_floor_log2(x) {\n  if(log2_ok) return Math.floor(Math.log2(x))\n  var i = 0;\n  if (x == 0) return -Infinity;\n  if(x>=1) {while (x>=2) {x/=2; i++} }\n  else {while (x < 1) {x*=2; i--} };\n  return i;\n}\n\n//Provides: caml_int64_bits_of_float const\n//Requires: jsoo_floor_log2, caml_int64_create_lo_mi_hi\nfunction caml_int64_bits_of_float (x) {\n  if (!isFinite(x)) {\n    if (isNaN(x))\n      return caml_int64_create_lo_mi_hi(1, 0, 0x7ff0);\n    if (x > 0)\n      return caml_int64_create_lo_mi_hi(0, 0, 0x7ff0)\n    else\n      return caml_int64_create_lo_mi_hi(0, 0, 0xfff0)\n  }\n  var sign = (x==0 && 1/x == -Infinity)?0x8000:(x>=0)?0:0x8000;\n  if (sign) x = -x;\n  // Int64.bits_of_float 1.1235582092889474E+307 = 0x7fb0000000000000L\n  // using Math.LOG2E*Math.log(x) in place of Math.log2 result in precision lost\n  var exp = jsoo_floor_log2(x) + 1023;\n  if (exp <= 0) {\n    exp = 0;\n    x /= Math.pow(2,-1026);\n  } else {\n    x /= Math.pow(2,exp-1027);\n    if (x < 16) {\n      x *= 2; exp -=1; }\n    if (exp == 0) {\n      x /= 2; }\n  }\n  var k = Math.pow(2,24);\n  var r3 = x|0;\n  x = (x - r3) * k;\n  var r2 = x|0;\n  x = (x - r2) * k;\n  var r1 = x|0;\n  r3 = (r3 &0xf) | sign | exp << 4;\n  return caml_int64_create_lo_mi_hi(r1, r2, r3);\n}\n\n//Provides: caml_int32_bits_of_float const\n//Requires: jsoo_floor_log2\nfunction caml_int32_bits_of_float (x) {\n  var float32a = new Float32Array(1);\n  float32a[0] = x;\n  var int32a = new Int32Array(float32a.buffer);\n  return int32a[0] | 0;\n}\n\n//FP literals can be written using the hexadecimal\n//notation 0x<mantissa in hex>p<exponent> from ISO C99.\n//https://github.com/dankogai/js-hexfloat/blob/master/hexfloat.js\n//Provides: caml_hexstring_of_float const\n//Requires: caml_string_of_jsstring, caml_str_repeat\nfunction caml_hexstring_of_float (x, prec, style) {\n  if (!isFinite(x)) {\n    if (isNaN(x)) return caml_string_of_jsstring(\"nan\");\n    return caml_string_of_jsstring ((x > 0)?\"infinity\":\"-infinity\");\n  }\n  var sign = (x==0 && 1/x == -Infinity)?1:(x>=0)?0:1;\n  if(sign) x = -x;\n  var exp = 0;\n  if (x == 0) { }\n  else if (x < 1) {\n    while (x < 1 && exp > -1022)  { x *= 2; exp-- }\n  } else {\n    while (x >= 2) { x /= 2; exp++ }\n  }\n  var exp_sign = exp < 0 ? '' : '+';\n  var sign_str = '';\n  if (sign) sign_str = '-'\n  else {\n    switch(style){\n    case 43 /* '+' */: sign_str = '+'; break;\n    case 32 /* ' ' */: sign_str = ' '; break;\n    default: break;\n    }\n  }\n  if (prec >= 0 && prec < 13) {\n    /* If a precision is given, and is small, round mantissa accordingly */\n    var cst = Math.pow(2,prec * 4);\n    x = Math.round(x * cst) / cst;\n  }\n  var x_str = x.toString(16);\n  if(prec >= 0){\n    var idx = x_str.indexOf('.');\n    if(idx<0) {\n      x_str += '.' + caml_str_repeat(prec, '0');\n    }\n    else {\n      var size = idx+1+prec;\n      if(x_str.length < size)\n        x_str += caml_str_repeat(size - x_str.length, '0');\n      else\n        x_str = x_str.substr(0,size);\n    }\n  }\n  return caml_string_of_jsstring (sign_str + '0x' + x_str + 'p' + exp_sign + exp.toString(10));\n}\n\n//Provides: caml_int64_float_of_bits const\nfunction caml_int64_float_of_bits (x) {\n  var lo = x.lo;\n  var mi = x.mi;\n  var hi = x.hi;\n  var exp = (hi & 0x7fff) >> 4;\n  if (exp == 2047) {\n    if ((lo|mi|(hi&0xf)) == 0)\n      return (hi & 0x8000)?(-Infinity):Infinity;\n    else\n      return NaN;\n  }\n  var k = Math.pow(2,-24);\n  var res = (lo*k+mi)*k+(hi&0xf);\n  if (exp > 0) {\n    res += 16;\n    res *= Math.pow(2,exp-1027);\n  } else\n    res *= Math.pow(2,-1026);\n  if (hi & 0x8000) res = - res;\n  return res;\n}\n\n//Provides: caml_nextafter_float const\n//Requires: caml_int64_float_of_bits, caml_int64_bits_of_float, caml_int64_add, caml_int64_sub,caml_int64_of_int32\nfunction caml_nextafter_float (x,y) {\n  if(isNaN(x) || isNaN(y)) return NaN;\n  if(x==y) return y;\n  if(x==0){\n    if(y < 0)\n      return -Math.pow(2, -1074)\n    else\n      return Math.pow(2, -1074)\n  }\n  var bits = caml_int64_bits_of_float(x);\n  var one = caml_int64_of_int32(1);\n  if ((x<y) == (x>0))\n    bits = caml_int64_add(bits, one)\n  else\n    bits = caml_int64_sub(bits, one)\n  return caml_int64_float_of_bits(bits);\n}\n\n//Provides: caml_trunc_float\nfunction caml_trunc_float(x){\n  return Math.trunc(x);\n}\n\n//Provides: caml_int32_float_of_bits const\nfunction caml_int32_float_of_bits (x) {\n  var int32a = new Int32Array(1);\n  int32a[0] = x;\n  var float32a = new Float32Array(int32a.buffer);\n  return float32a[0];\n}\n\n//Provides: caml_classify_float const\nfunction caml_classify_float (x) {\n  if (isFinite (x)) {\n    if (Math.abs(x) >= 2.2250738585072014e-308) return 0;\n    if (x != 0) return 1;\n    return 2;\n  }\n  return isNaN(x)?4:3;\n}\n//Provides: caml_modf_float const\nfunction caml_modf_float (x) {\n  if (isFinite (x)) {\n    var neg = (1/x) < 0;\n    x = Math.abs(x);\n    var i = Math.floor (x);\n    var f = x - i;\n    if (neg) { i = -i; f = -f; }\n    return [0, f, i];\n  }\n  if (isNaN (x)) return [0, NaN, NaN];\n  return [0, 1/x, x];\n}\n//Provides: caml_ldexp_float const\nfunction caml_ldexp_float (x,exp) {\n  exp |= 0;\n  if (exp > 1023) {\n    exp -= 1023;\n    x *= Math.pow(2, 1023);\n    if (exp > 1023) {  // in case x is subnormal\n      exp -= 1023;\n      x *= Math.pow(2, 1023);\n    }\n  }\n  if (exp < -1023) {\n    exp += 1023;\n    x *= Math.pow(2, -1023);\n  }\n  x *= Math.pow(2, exp);\n  return x;\n}\n//Provides: caml_frexp_float const\n//Requires: jsoo_floor_log2\nfunction caml_frexp_float (x) {\n  if ((x == 0) || !isFinite(x)) return [0, x, 0];\n  var neg = x < 0;\n  if (neg) x = - x;\n  var exp = Math.max(-1023, jsoo_floor_log2(x) + 1);\n  x *= Math.pow(2,-exp);\n  while (x < 0.5) {\n    x *= 2;\n    exp--;\n  }\n  while (x >= 1) {\n    x *= 0.5;\n    exp++;\n  }\n  if (neg) x = - x;\n  return [0, x, exp];\n}\n\n//Provides: caml_float_compare const\nfunction caml_float_compare (x, y) {\n  if (x === y) return 0;\n  if (x < y) return -1;\n  if (x > y) return 1;\n  if (x === x) return 1;\n  if (y === y) return -1;\n  return 0;\n}\n\n//Provides: caml_copysign_float const\nfunction caml_copysign_float (x, y) {\n  if (y == 0) y = 1 / y;\n  x = Math.abs(x);\n  return (y < 0)?(-x):x;\n}\n\n//Provides: caml_signbit_float const\nfunction caml_signbit_float(x) {\n  if (x == 0) x = 1 / x;\n  return (x < 0)?1:0;\n}\n\n//Provides: caml_expm1_float const\nfunction caml_expm1_float (x) { return Math.expm1(x); }\n//Provides: caml_exp2_float const\nfunction caml_exp2_float(x) { return Math.pow(2, x); }\n//Provides: caml_log1p_float const\nfunction caml_log1p_float(x) { return Math.log1p(x); }\n//Provides: caml_log2_float const\nfunction caml_log2_float(x) { return Math.log2(x); }\n//Provides: caml_hypot_float const\nfunction caml_hypot_float (x, y) { return Math.hypot(x, y); }\n//Provides: caml_log10_float const\nfunction caml_log10_float (x) { return Math.log10(x); }\n//Provides: caml_cosh_float const\nfunction caml_cosh_float (x) { return Math.cosh(x); }\n//Provides: caml_acosh_float const\nfunction caml_acosh_float (x) { return Math.acosh(x); }\n//Provides: caml_sinh_float const\nfunction caml_sinh_float (x) { return Math.sinh(x); }\n//Provides: caml_asinh_float const\nfunction caml_asinh_float (x) { return Math.asinh(x); }\n//Provides: caml_tanh_float const\nfunction caml_tanh_float (x) { return Math.tanh(x); }\n//Provides: caml_atanh_float const\nfunction caml_atanh_float (x) { return Math.atanh(x); }\n//Provides: caml_round_float const\nfunction caml_round_float (x) {\n  if (x >= 0) {\n    var y = Math.floor(x);\n    return (x - y >= 0.5)?(y + 1):y\n  } else {\n    var y = Math.ceil(x);\n    return (y - x >= 0.5)?(y - 1):y\n  }\n}\n//Provides: caml_cbrt_float const\nfunction caml_cbrt_float (x) { return Math.cbrt(x); }\n\n//Provides: caml_erf_float const\nfunction caml_erf_float(x) {\n  var a1 = 0.254829592;\n  var a2 = -0.284496736;\n  var a3 = 1.421413741;\n  var a4 = -1.453152027;\n  var a5 = 1.061405429;\n  var p = 0.3275911;\n\n  var sign = 1;\n  if (x < 0) {\n    sign = -1;\n  }\n  x = Math.abs(x);\n  var t = 1.0 / (1.0 + p * x);\n  var y = 1.0 - ((((a5 * t + a4) * t + a3) * t + a2) * t + a1) * t * Math.exp(-x * x);\n\n  return sign * y;\n}\n\n//Provides: caml_erfc_float const\n//Requires: caml_erf_float\nfunction caml_erfc_float(x) {\n  return 1 - caml_erf_float(x);\n}\n\n\n//Provides: caml_fma_float const\nfunction caml_fma_float(x, y, z) {\n  var SPLIT = Math.pow(2, 27) + 1;\n  var MIN_VALUE = Math.pow(2, -1022);\n  var EPSILON = Math.pow(2, -52);\n  var C = 416;\n  var A = Math.pow(2, +C);\n  var B = Math.pow(2, -C);\n\n  function multiply (a, b) {\n    var at = SPLIT * a;\n    var ahi = at - (at - a);\n    var alo = a - ahi;\n    var bt = SPLIT * b;\n    var bhi = bt - (bt - b);\n    var blo = b - bhi;\n    var p = a * b;\n    var e = ((ahi * bhi - p) + ahi * blo + alo * bhi) + alo * blo;\n    return {\n      p: p,\n      e: e\n    };\n  };\n\n  function add (a, b) {\n    var s = a + b;\n    var v = s - a;\n    var e = (a - (s - v)) + (b - v);\n    return {\n      s: s,\n      e: e\n    };\n  };\n\n  function adjust (x, y) {\n    return x !== 0 && y !== 0 && SPLIT * x - (SPLIT * x - x) === x ? x * (1 + (x < 0 ? -1 : +1) * (y < 0 ? -1 : +1) * EPSILON) : x;\n  };\n\n  if (x === 0 || x !== x || x === +1 / 0 || x === -1 / 0 ||\n      y === 0 || y !== y || y === +1 / 0 || y === -1 / 0) {\n    return x * y + z;\n  }\n  if (z === 0) {\n    return x * y;\n  }\n  if (z !== z || z === +1 / 0 || z === -1 / 0) {\n    return z;\n  }\n\n  var scale = 1;\n  while (Math.abs(x) > A) {\n    scale *= A;\n    x *= B;\n  }\n  while (Math.abs(y) > A) {\n    scale *= A;\n    y *= B;\n  }\n  if (scale === 1 / 0) {\n    return x * y * scale;\n  }\n  while (Math.abs(x) < B) {\n    scale *= B;\n    x *= A;\n  }\n  while (Math.abs(y) < B) {\n    scale *= B;\n    y *= A;\n  }\n  if (scale === 0) {\n    return z;\n  }\n\n  var xs = x;\n  var ys = y;\n  var zs = z / scale;\n\n  if (Math.abs(zs) > Math.abs(xs * ys) * 4 / EPSILON) {\n    return z;\n  }\n  if (Math.abs(zs) < Math.abs(xs * ys) * EPSILON / 4 * EPSILON / 4) {\n    zs = (z < 0 ? -1 : +1) * MIN_VALUE;\n  }\n\n  var xy = multiply(xs, ys);\n  var s = add(xy.p, zs);\n  var u = add(xy.e, s.e);\n  var i = add(s.s, u.s);\n\n  var f = i.s + adjust(i.e, u.e);\n  if (f === 0) {\n    return f;\n  }\n\n  var fs = f * scale;\n  if (Math.abs(fs) > MIN_VALUE) {\n    return fs;\n  }\n\n  // It is possible that there was extra rounding for a denormalized value.\n  return fs + adjust(f - fs / scale, i.e) * scale;\n}\n\n//Provides: caml_format_float const\n//Requires: caml_parse_format, caml_finish_formatting\nfunction caml_format_float (fmt, x) {\n  function toFixed(x,dp) {\n    if (Math.abs(x) < 1.0) {\n      return x.toFixed(dp);\n    } else {\n      var e = parseInt(x.toString().split('+')[1]);\n      if (e > 20) {\n        e -= 20;\n        x /= Math.pow(10,e);\n        x += (new Array(e+1)).join('0');\n        if(dp > 0) {\n          x = x + '.' + (new Array(dp+1)).join('0');\n        }\n        return x;\n      }\n      else return x.toFixed(dp)\n    }\n  }\n  var s, f = caml_parse_format(fmt);\n  var prec = (f.prec < 0)?6:f.prec;\n  if (x < 0 || (x == 0 && 1/x == -Infinity)) { f.sign = -1; x = -x; }\n  if (isNaN(x)) { s = \"nan\"; f.filler = ' '; }\n  else if (!isFinite(x)) { s = \"inf\"; f.filler = ' '; }\n  else\n    switch (f.conv) {\n    case 'e':\n      var s = x.toExponential(prec);\n      // exponent should be at least two digits\n      var i = s.length;\n      if (s.charAt(i - 3) == 'e')\n        s = s.slice (0, i - 1) + '0' + s.slice (i - 1);\n      break;\n    case 'f':\n      s = toFixed(x, prec); break;\n    case 'g':\n      prec = prec?prec:1;\n      s = x.toExponential(prec - 1);\n      var j = s.indexOf('e');\n      var exp = +s.slice(j + 1);\n      if (exp < -4 || x >= 1e21 || x.toFixed(0).length > prec) {\n        // remove trailing zeroes\n        var i = j - 1; while (s.charAt(i) == '0') i--;\n        if (s.charAt(i) == '.') i--;\n        s = s.slice(0, i + 1) + s.slice(j);\n        i = s.length;\n        if (s.charAt(i - 3) == 'e')\n          s = s.slice (0, i - 1) + '0' + s.slice (i - 1);\n        break;\n      } else {\n        var p = prec;\n        if (exp < 0) { p -= exp + 1; s = x.toFixed(p); }\n        else while (s = x.toFixed(p), s.length > prec + 1) p--;\n        if (p) {\n          // remove trailing zeroes\n          var i = s.length - 1; while (s.charAt(i) == '0') i--;\n          if (s.charAt(i) == '.') i--;\n          s = s.slice(0, i + 1);\n        }\n      }\n      break;\n    }\n  return caml_finish_formatting(f, s);\n}\n\n//Provides: caml_float_of_string (const)\n//Requires: caml_failwith, caml_jsbytes_of_string\nfunction caml_float_of_string(s) {\n  var res;\n  s = caml_jsbytes_of_string(s)\n  res = +s;\n  if ((s.length > 0) && (res === res)) return res;\n  s = s.replace(/_/g,\"\");\n  res = +s;\n  if (((s.length > 0) && (res === res)) || /^[+-]?nan$/i.test(s)) return res;\n  var m = /^ *([+-]?)0x([0-9a-f]+)\\.?([0-9a-f]*)(p([+-]?[0-9]+))?/i.exec(s);\n  //          1        2             3           5\n  if(m){\n    var m3 = m[3].replace(/0+$/,'');\n    var mantissa = parseInt(m[1] + m[2] + m3, 16);\n    var exponent = (m[5]|0) - 4*m3.length;\n    res = mantissa * Math.pow(2, exponent);\n    return res;\n  }\n  if(/^\\+?inf(inity)?$/i.test(s)) return Infinity;\n  if(/^-inf(inity)?$/i.test(s)) return -Infinity;\n  caml_failwith(\"float_of_string\");\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_update_dummy\nfunction caml_update_dummy (x, y) {\n  if( y.fun ) { x.fun = y.fun; return 0; }\n  if( typeof y===\"function\" ) { x.fun = y; return 0; }\n  var i = y.length; while (i--) x[i] = y[i]; return 0;\n}\n\n//Provides: caml_alloc_dummy_infix\n//Requires: caml_call_gen\nfunction caml_alloc_dummy_infix () {\n  return function f (x) { return caml_call_gen(f.fun, [x]) }\n}\n\n//Provides: caml_obj_is_block const (const)\nfunction caml_obj_is_block (x) { return +(x instanceof Array); }\n\n\n//Provides: caml_obj_tag\n//Requires: caml_is_ml_bytes, caml_is_ml_string\nfunction caml_obj_tag (x) {\n  if ((x instanceof Array) && x[0] == (x[0] >>> 0))\n    return x[0]\n  else if (caml_is_ml_bytes(x))\n    return 252\n  else if (caml_is_ml_string(x))\n    return 252\n  else if ((x instanceof Function) || typeof x == \"function\")\n    return 247\n  else if (x && x.caml_custom)\n    return 255\n  else\n    return 1000\n}\n\n//Provides: caml_obj_set_tag (mutable, const)\nfunction caml_obj_set_tag (x, tag) { x[0] = tag; return 0; }\n//Provides: caml_obj_block const (const,const)\nfunction caml_obj_block (tag, size) {\n  var o = new Array(size+1);\n  o[0]=tag;\n  for (var i = 1; i <= size; i++) o[i] = 0;\n  return o;\n}\n\n//Provides: caml_obj_with_tag\nfunction caml_obj_with_tag(tag,x) {\n  var l = x.length;\n  var a = new Array(l);\n  a[0] = tag;\n  for(var i = 1; i < l; i++ ) a[i] = x[i];\n  return a;\n}\n\n//Provides: caml_obj_dup mutable (mutable)\nfunction caml_obj_dup (x) {\n  var l = x.length;\n  var a = new Array(l);\n  for(var i = 0; i < l; i++ ) a[i] = x[i];\n  return a;\n}\n\n//Provides: caml_obj_truncate (mutable, const)\n//Requires: caml_invalid_argument\nfunction caml_obj_truncate (x, s) {\n  if (s<=0 || s + 1 > x.length)\n    caml_invalid_argument (\"Obj.truncate\");\n  if (x.length != s + 1) x.length = s + 1;\n  return 0;\n}\n\n//Provides: caml_obj_make_forward\nfunction caml_obj_make_forward (b,v) {\n  b[0]=250;\n  b[1]=v;\n  return 0\n}\n\n//Provides: caml_obj_compare_and_swap\nfunction caml_obj_compare_and_swap(x,i,old,n){\n  if(x[i+1] == old) {\n    x[i+1] = n;\n    return 1;\n  }\n  return 0\n}\n\n//Provides: caml_obj_is_shared\nfunction caml_obj_is_shared(x){\n  return 1\n}\n\n//Provides: caml_lazy_make_forward const (mutable)\nfunction caml_lazy_make_forward (v) { return [250, v]; }\n\n///////////// CamlinternalOO\n//Provides: caml_get_public_method const\nvar caml_method_cache = [];\nfunction caml_get_public_method (obj, tag, cacheid) {\n  var meths = obj[1];\n  var ofs = caml_method_cache[cacheid];\n  if (ofs === undefined) {\n    // Make sure the array is not sparse\n    for (var i = caml_method_cache.length; i < cacheid; i++)\n      caml_method_cache[i] = 0;\n  } else if (meths[ofs] === tag) {\n    return meths[ofs - 1];\n  }\n  var li = 3, hi = meths[1] * 2 + 1, mi;\n  while (li < hi) {\n    mi = ((li+hi) >> 1) | 1;\n    if (tag < meths[mi+1]) hi = mi-2;\n    else li = mi;\n  }\n  caml_method_cache[cacheid] = li + 1;\n  /* return 0 if tag is not there */\n  return (tag == meths[li+1] ? meths[li] : 0);\n}\n\n//Provides: caml_oo_last_id\nvar caml_oo_last_id = 0;\n\n//Provides: caml_set_oo_id\n//Requires: caml_oo_last_id\nfunction caml_set_oo_id (b) {\n  b[2]=caml_oo_last_id++;\n  return b;\n}\n\n//Provides: caml_fresh_oo_id const\n//Requires: caml_oo_last_id\nfunction caml_fresh_oo_id() {\n  return caml_oo_last_id++;\n}\n\n//Provides: caml_obj_raw_field\nfunction caml_obj_raw_field(o,i) { return o[i+1] }\n\n//Provides: caml_obj_set_raw_field\nfunction caml_obj_set_raw_field(o,i,v) { return o[i+1] = v }\n\n//Provides: caml_obj_reachable_words\nfunction caml_obj_reachable_words(o) { return 0; }\n\n//Provides: caml_obj_add_offset\n//Requires: caml_failwith\nfunction caml_obj_add_offset(v,offset) {\n  caml_failwith(\"Obj.add_offset is not supported\");\n}\n\n//Provides: caml_obj_update_tag\nfunction caml_obj_update_tag(b,o,n) {\n    if(b[0]==o) { b[0] = n; return 1 }\n    return 0\n}\n\n//Provides: caml_lazy_update_to_forcing\n//Requires: caml_obj_update_tag\nfunction caml_lazy_update_to_forcing(o) {\n  if ((o instanceof Array) && o[0] == (o[0] >>> 0) &&\n      caml_obj_update_tag(o, 246, 244)) {\n    return 0;\n  } else {\n    return 1;\n  }\n}\n\n//Provides: caml_lazy_update_to_forward\n//Requires: caml_obj_update_tag\n  function caml_lazy_update_to_forward(o) {\n  caml_obj_update_tag(o,244,250);\n  return 0; // unit\n}\n\n\n//Provides: caml_lazy_reset_to_lazy\n//Requires: caml_obj_update_tag\nfunction caml_lazy_reset_to_lazy(o) {\n  caml_obj_update_tag(o,244,246);\n  return 0;\n}\n\n//Provides: caml_lazy_read_result\n//Requires: caml_obj_tag\nfunction caml_lazy_read_result(o) {\n  return (caml_obj_tag(o) == 250)?o[1]:o;\n}\n\n\n//Provides: caml_is_continuation_tag\n//Version: < 5\nfunction caml_is_continuation_tag(t) {\n  return 0;\n}\n\n//Provides: caml_is_continuation_tag\n//Version: >= 5\nfunction caml_is_continuation_tag(t) {\n  return (t == 245) ? 1 : 0;\n}\n","/*\nTo deal with effects, the execution context is intuitively composed of\na stack of fibers. Each fiber has a current low-level continuation\n(one-argument JavaScript function), a stack of exception handlers and\na triple of handlers, which are invoked when the fiber terminates\n(either with a value or an exception) or when an effect is performed.\nThe low-level continuation of the topmost fiber (which is currently\nexecuting) is passed from function to function as an additional\nargument. Its stack of exception handlers is stored in\n[caml_exn_stack]. Exception handlers are pushed into this stack when\nentering a [try ... with ...] and popped on exit. Then, handlers and\nthe remaining fibers are stored in [caml_fiber_stack]. To install an\neffect handler, we push a new fiber into the execution context.\n\nWe have basically the following type for reified continuations (type\n[continuation] in module [Effect] of the standard library):\n\n  type ('a, 'b) continuation = ('a, 'b) stack ref\n\n  and (_, _) stack =\n      Cons : ('b -> unit) *             (* low-level continuation *)\n             (exn -> unit) list *       (* exception handlers *)\n             ('b, 'c) handler *\n             ('a, 'b) stack\n             -> ('a, 'c) stack\n    | Empty : ('a, 'a) stack\n\n  and ('a,'b) handler =   (* As in module Effect from the standard library *)\n    { retc: 'a -> 'b;\n      exnc: exn -> 'b;\n      effc: 'c.'c Effect.t -> (('c,'b) continuation -> 'b) option }\n\nContinuations are one-shot. A continuation [ref Empty] has already\nbeen resumed.\n\nA continuation is basically composed of a list of fibers, which each\nhas its low-level continuation, its stack of exception handlers and a\ntriple of handlers to deal with when the fiber terminates or an\neffect is performed. When resuming a continuation, the innermost fiber\nis resumed first.\n\nThe handlers are CPS-transformed functions: they actually take an\nadditional parameter which is the current low-level continuation.\n*/\n\n//Provides: caml_exn_stack\n//If: effects\n// This is an OCaml list of exception handlers\nvar caml_exn_stack = 0;\n\n//Provides: caml_push_trap\n//Requires: caml_exn_stack\n//If: effects\nfunction caml_push_trap(handler) {\n  caml_exn_stack=[0,handler,caml_exn_stack];\n}\n\n//Provides: caml_pop_trap\n//Requires: caml_exn_stack\n//If: effects\nfunction caml_pop_trap() {\n  if (!caml_exn_stack) return function(x){throw x;}\n  var h = caml_exn_stack[1];\n  caml_exn_stack=caml_exn_stack[2];\n  return h\n}\n\n//Provides: caml_fiber_stack\n//If: effects\n// This has the shape {h, r:{k, x, e}} where h is a triple of handlers\n// (see effect.js) and k, x and e are the saved continuation,\n// exception stack and fiber stack of the parent fiber.\nvar caml_fiber_stack;\n\n//Provides:caml_resume_stack\n//Requires: caml_named_value, caml_raise_constant, caml_exn_stack, caml_fiber_stack\n//If: effects\nfunction caml_resume_stack(stack, k) {\n  if (!stack) caml_raise_constant\n                 (caml_named_value(\"Effect.Continuation_already_resumed\"));\n  // Update the execution context with the stack of fibers in [stack] in\n  // order to resume the continuation\n  do {\n    caml_fiber_stack =\n      {h:stack[3], r:{k:k, x:caml_exn_stack, e:caml_fiber_stack}};\n    k = stack[1];\n    caml_exn_stack = stack[2];\n    stack = stack[4];\n  } while (stack)\n  return k;\n}\n\n//Provides: caml_pop_fiber\n//Requires: caml_exn_stack, caml_fiber_stack\n//If: effects\nfunction caml_pop_fiber() {\n  // Move to the parent fiber, returning the parent's low-level continuation\n  var rem = caml_fiber_stack.r;\n  caml_exn_stack = rem.x;\n  caml_fiber_stack = rem.e;\n  return rem.k;\n}\n\n//Provides: caml_perform_effect\n//Requires: caml_pop_fiber, caml_stack_check_depth, caml_trampoline_return, caml_exn_stack, caml_fiber_stack\n//If: effects\nfunction caml_perform_effect(eff, cont, k0) {\n  // Allocate a continuation if we don't already have one\n  if (!cont) cont = [245 /*continuation*/, 0];\n  // Get current effect handler\n  var handler = caml_fiber_stack.h[3];\n  // Cons the current fiber onto the continuation:\n  //   cont := Cons (k, exn_stack, handlers, !cont)\n  cont[1] = [0,k0,caml_exn_stack,caml_fiber_stack.h,cont[1]];\n  // Move to parent fiber and execute the effect handler there\n  // The handler is defined in Stdlib.Effect, so we know that the arity matches\n  var k1 = caml_pop_fiber();\n  return caml_stack_check_depth()?handler(eff,cont,k1,k1)\n         :caml_trampoline_return(handler,[eff,cont,k1,k1]);\n}\n\n//Provides: caml_alloc_stack\n//Requires: caml_pop_fiber, caml_fiber_stack, caml_call_gen, caml_stack_check_depth, caml_trampoline_return\n//If: effects\nfunction caml_alloc_stack(hv, hx, hf) {\n  function call(i, x) {\n    var f=caml_fiber_stack.h[i];\n    var args = [x, caml_pop_fiber()];\n    return caml_stack_check_depth()?caml_call_gen(f,args)\n           :caml_trampoline_return(f,args);\n  }\n  function hval(x) {\n    // Call [hv] in the parent fiber\n    return call(1, x);\n  }\n  function hexn(e) {\n    // Call [hx] in the parent fiber\n    return call(2, e);\n  }\n  return [0, hval, [0, hexn, 0], [0, hv, hx, hf], 0];\n}\n\n//Provides: caml_alloc_stack\n//If: !effects\nfunction caml_alloc_stack(hv, hx, hf) {\n  return 0;\n}\n\n//Provides: caml_continuation_use_noexc\nfunction caml_continuation_use_noexc(cont) {\n  var stack=cont[1];\n  cont[1]=0;\n  return stack;\n}\n\n//Provides: caml_continuation_use_and_update_handler_noexc\n//Requires: caml_continuation_use_noexc\nfunction caml_continuation_use_and_update_handler_noexc(cont, hval, hexn, heff) {\n  var stack = caml_continuation_use_noexc(cont);\n  stack[3] = [0, hval, hexn, heff];\n  return stack;\n}\n\n//Provides: caml_get_continuation_callstack\nfunction caml_get_continuation_callstack () { return [0]; }\n\n//Provides: caml_ml_condition_new\nfunction caml_ml_condition_new(unit){\n    return {condition:1};\n}\n\n//Provides: caml_ml_condition_wait\nfunction caml_ml_condition_wait(t,mutext){\n    return 0;\n}\n\n//Provides: caml_ml_condition_broadcast\nfunction caml_ml_condition_broadcast(t){\n    return 0;\n}\n\n//Provides: caml_ml_condition_signal\nfunction caml_ml_condition_signal(t){\n    return 0;\n}\n\n//Provides: jsoo_effect_not_supported\n//Requires: caml_failwith\n//!If: effects\nfunction jsoo_effect_not_supported(){\n  caml_failwith(\"Effect handlers are not supported\");\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Array\n\n//Provides: caml_array_sub mutable\nfunction caml_array_sub (a, i, len) {\n  var a2 = new Array(len+1);\n  a2[0]=0;\n  for(var i2 = 1, i1= i+1; i2 <= len; i2++,i1++ ){\n    a2[i2]=a[i1];\n  }\n  return a2;\n}\n\n//Provides: caml_array_append mutable\nfunction caml_array_append(a1, a2) {\n  var l1 = a1.length, l2 = a2.length;\n  var l = l1+l2-1\n  var a = new Array(l);\n  a[0] = 0;\n  var i = 1,j = 1;\n  for(;i<l1;i++) a[i]=a1[i];\n  for(;i<l;i++,j++) a[i]=a2[j];\n  return a;\n}\n\n//Provides: caml_array_concat mutable\nfunction caml_array_concat(l) {\n  var a = [0];\n  while (l !== 0) {\n    var b = l[1];\n    for (var i = 1; i < b.length; i++) a.push(b[i]);\n    l = l[2];\n  }\n  return a;\n}\n\n//Provides: caml_array_blit\nfunction caml_array_blit(a1, i1, a2, i2, len) {\n  if (i2 <= i1) {\n    for (var j = 1; j <= len; j++) a2[i2 + j] = a1[i1 + j];\n  } else {\n    for (var j = len; j >= 1; j--) a2[i2 + j] = a1[i1 + j];\n  };\n  return 0;\n}\n\n//Provides: caml_floatarray_blit\nfunction caml_floatarray_blit(a1, i1, a2, i2, len) {\n  if (i2 <= i1) {\n    for (var j = 1; j <= len; j++) a2[i2 + j] = a1[i1 + j];\n  } else {\n    for (var j = len; j >= 1; j--) a2[i2 + j] = a1[i1 + j];\n  };\n  return 0;\n}\n\n///////////// Pervasive\n//Provides: caml_array_set (mutable, const, mutable)\n//Requires: caml_array_bound_error\nfunction caml_array_set (array, index, newval) {\n  if ((index < 0) || (index >= array.length - 1)) caml_array_bound_error();\n  array[index+1]=newval; return 0;\n}\n\n//Provides: caml_array_get mutable (mutable, const)\n//Requires: caml_array_bound_error\nfunction caml_array_get (array, index) {\n  if ((index < 0) || (index >= array.length - 1)) caml_array_bound_error();\n  return array[index+1];\n}\n\n//Provides: caml_array_fill\nfunction caml_array_fill(array, ofs, len, v){\n  for(var i = 0; i < len; i++){\n    array[ofs+i+1] = v;\n  }\n  return 0;\n}\n\n//Provides: caml_check_bound (mutable, const)\n//Requires: caml_array_bound_error\nfunction caml_check_bound (array, index) {\n  if (index >>> 0 >= array.length - 1) caml_array_bound_error();\n  return array;\n}\n\n//Provides: caml_make_vect const (const, mutable)\n//Requires: caml_array_bound_error\nfunction caml_make_vect (len, init) {\n  if (len < 0) caml_array_bound_error();\n  var len = len + 1 | 0;\n  var b = new Array(len);\n  b[0]=0;\n  for (var i = 1; i < len; i++) b[i] = init;\n  return b;\n}\n\n//Provides: caml_make_float_vect const (const)\n//Requires: caml_array_bound_error\nfunction caml_make_float_vect(len){\n  if (len < 0) caml_array_bound_error();\n  var len = len + 1 | 0;\n  var b = new Array(len);\n  b[0]=254;\n  for (var i = 1; i < len; i++) b[i] = 0;\n  return b\n}\n//Provides: caml_floatarray_create const (const)\n//Requires: caml_array_bound_error\nfunction caml_floatarray_create(len){\n  if (len < 0) caml_array_bound_error();\n  var len = len + 1 | 0;\n  var b = new Array(len);\n  b[0]=254;\n  for (var i = 1; i < len; i++) b[i] = 0;\n  return b\n}\n","//Provides: caml_domain_dls\nvar caml_domain_dls = [0];\n\n//Provides: caml_domain_dls_set\n//Requires: caml_domain_dls\nfunction caml_domain_dls_set(a) {\n  caml_domain_dls = a;\n}\n\n//Provides: caml_domain_dls_compare_and_set\n//Requires: caml_domain_dls\n//Version: >= 5.2\nfunction caml_domain_dls_compare_and_set(old,n) {\n  if(caml_domain_dls !== old) return 0\n  caml_domain_dls = n;\n  return 1;\n}\n\n//Provides: caml_domain_dls_get\n//Requires: caml_domain_dls\nfunction caml_domain_dls_get(unit) {\n  return caml_domain_dls;\n}\n\n\n//Provides: caml_atomic_load\nfunction caml_atomic_load(ref){\n  return ref[1];\n}\n\n//Provides: caml_atomic_cas\nfunction caml_atomic_cas(ref,o,n) {\n  if(ref[1] === o){\n    ref[1] = n;\n    return 1;\n  }\n  return 0;\n}\n\n//Provides: caml_atomic_fetch_add\nfunction caml_atomic_fetch_add(ref, i) {\n  var old = ref[1];\n  ref[1] += i;\n  return old;\n}\n\n//Provides: caml_atomic_exchange\nfunction caml_atomic_exchange(ref, v) {\n  var r = ref[1];\n  ref[1] = v;\n  return r;\n}\n\n//Provides: caml_atomic_make_contended\nfunction caml_atomic_make_contended(a) {\n  return [0, a]\n}\n\n//Provides: caml_ml_domain_unique_token\n//Version: < 5.2\nvar caml_ml_domain_unique_token_ = [0]\nfunction caml_ml_domain_unique_token(unit) {\n  return caml_ml_domain_unique_token_\n}\n\n\n//Provides: caml_ml_domain_set_name\nfunction caml_ml_domain_set_name(_name) {\n  return 0;\n}\n\n//Provides: caml_recommended_domain_count\nfunction caml_recommended_domain_count(unit) { return 1 }\n\n\n//Provides: caml_domain_id\nvar caml_domain_id = 0;\n\n//Provides: caml_domain_spawn\n//Requires: caml_ml_mutex_unlock\n//Requires: caml_domain_id\n//Requires: caml_callback\n//Version: >= 5.2\nvar caml_domain_latest_idx = 1\nfunction caml_domain_spawn(f,term_sync){\n    var id = caml_domain_latest_idx++;\n    var old = caml_domain_id;\n    caml_domain_id = id;\n    var res = caml_callback(f,[0]);\n    caml_domain_id = old;\n    caml_ml_mutex_unlock(term_sync[2]);\n    //TODO: fix exn case\n    term_sync[1] = [0, [0, res]];\n    return id;\n}\n\n//Provides: caml_domain_spawn\n//Requires: caml_ml_mutex_unlock\n//Requires: caml_domain_id\n//Requires: caml_callback\n//Version: < 5.2\nvar caml_domain_latest_idx = 1\nfunction caml_domain_spawn(f,mutex){\n    var id = caml_domain_latest_idx++;\n    var old = caml_domain_id;\n    caml_domain_id = id;\n    var res = caml_callback(f,[0]);\n    caml_domain_id = old;\n    caml_ml_mutex_unlock(mutex);\n    return id;\n}\n\n\n//Provides: caml_ml_domain_id\n//Requires: caml_domain_id\nfunction caml_ml_domain_id(unit){\n    return caml_domain_id;\n}\n\n\n//Provides: caml_ml_domain_cpu_relax\nfunction caml_ml_domain_cpu_relax(unit){\n    return 0;\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_format_int const (const, const)\n//Requires: caml_parse_format, caml_finish_formatting, caml_str_repeat\n//Requires: caml_string_of_jsbytes, caml_jsbytes_of_string\nfunction caml_format_int(fmt, i) {\n  if (caml_jsbytes_of_string(fmt) == \"%d\") return caml_string_of_jsbytes(\"\"+i);\n  var f = caml_parse_format(fmt);\n  if (i < 0) { if (f.signedconv) { f.sign = -1; i = -i; } else i >>>= 0; }\n  var s = i.toString(f.base);\n  if (f.prec >= 0) {\n    f.filler = ' ';\n    var n = f.prec - s.length;\n    if (n > 0) s = caml_str_repeat (n, '0') + s;\n  }\n  return caml_finish_formatting(f, s);\n}\n\n//Provides: caml_parse_sign_and_base\n//Requires: caml_string_unsafe_get, caml_ml_string_length\nfunction caml_parse_sign_and_base (s) {\n  var i = 0, len = caml_ml_string_length(s), base = 10, sign = 1;\n  if (len > 0) {\n    switch (caml_string_unsafe_get(s,i)) {\n    case 45: i++; sign = -1; break;\n    case 43: i++; sign = 1; break;\n    }\n  }\n  if (i + 1 < len && caml_string_unsafe_get(s, i) == 48)\n    switch (caml_string_unsafe_get(s, i + 1)) {\n    case 120: case 88: base = 16; i += 2; break;\n    case 111: case 79: base =  8; i += 2; break;\n    case  98: case 66: base =  2; i += 2; break;\n    case 117: case 85: i += 2; break;\n    }\n  return [i, sign, base];\n}\n\n//Provides: caml_parse_digit\nfunction caml_parse_digit(c) {\n  if (c >= 48 && c <= 57)  return c - 48;\n  if (c >= 65 && c <= 90)  return c - 55;\n  if (c >= 97 && c <= 122) return c - 87;\n  return -1;\n}\n\n//Provides: caml_int_of_string (const)\n//Requires: caml_ml_string_length, caml_string_unsafe_get\n//Requires: caml_parse_sign_and_base, caml_parse_digit, caml_failwith\nfunction caml_int_of_string (s) {\n  var r = caml_parse_sign_and_base (s);\n  var i = r[0], sign = r[1], base = r[2];\n  var len = caml_ml_string_length(s);\n  var threshold = -1 >>> 0;\n  var c = (i < len)?caml_string_unsafe_get(s, i):0;\n  var d = caml_parse_digit(c);\n  if (d < 0 || d >= base) caml_failwith(\"int_of_string\");\n  var res = d;\n  for (i++;i<len;i++) {\n    c = caml_string_unsafe_get(s, i);\n    if (c == 95) continue;\n    d = caml_parse_digit(c);\n    if (d < 0 || d >= base) break;\n    res = base * res + d;\n    if (res > threshold) caml_failwith(\"int_of_string\");\n  }\n  if (i != len) caml_failwith(\"int_of_string\");\n  // For base different from 10, we expect an unsigned representation,\n  // hence any value of 'res' (less than 'threshold') is acceptable.\n  // But we have to convert the result back to a signed integer.\n  res = sign * res;\n  if ((base == 10) && ((res | 0) != res))\n    /* Signed representation expected, allow -2^(nbits-1) to 2^(nbits-1) - 1 */\n    caml_failwith(\"int_of_string\");\n  return res | 0;\n}\n\n//Provides: caml_mul const\nfunction caml_mul(a,b){\n  return Math.imul(a,b);\n}\n\n//Provides: caml_div\n//Requires: caml_raise_zero_divide\nfunction caml_div(x,y) {\n  if (y == 0) caml_raise_zero_divide ();\n  return (x/y)|0;\n}\n\n//Provides: caml_mod\n//Requires: caml_raise_zero_divide\nfunction caml_mod(x,y) {\n  if (y == 0) caml_raise_zero_divide ();\n  return x%y;\n}\n\n//Provides: caml_bswap16\nfunction caml_bswap16(x) {\n  return ((((x & 0x00FF) << 8) |\n           ((x & 0xFF00) >> 8)));\n}\n//Provides: caml_int32_bswap\nfunction caml_int32_bswap(x) {\n  return (((x & 0x000000FF) << 24) |\n          ((x & 0x0000FF00) << 8) |\n          ((x & 0x00FF0000) >>> 8) |\n          ((x & 0xFF000000) >>> 24));\n}\n//Provides: caml_int64_bswap\n//Requires: caml_int64_to_bytes, caml_int64_of_bytes\nfunction caml_int64_bswap(x) {\n  var y = caml_int64_to_bytes(x);\n  return caml_int64_of_bytes([y[7], y[6], y[5], y[4], y[3], y[2], y[1], y[0]]);\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Hashtbl\n\n\n//Provides: caml_hash_univ_param mutable\n//Requires: caml_is_ml_string, caml_is_ml_bytes\n//Requires: caml_ml_bytes_content\n//Requires: caml_int64_to_bytes, caml_int64_bits_of_float, caml_custom_ops\n//Requires: caml_ml_bytes_length, caml_jsbytes_of_string\n//Version: < 4.12\nfunction caml_hash_univ_param (count, limit, obj) {\n  var hash_accu = 0;\n  function hash_aux (obj) {\n    limit --;\n    if (count < 0 || limit < 0) return;\n    if (obj instanceof Array && obj[0] === (obj[0]|0)) {\n      switch (obj[0]) {\n      case 248:\n        // Object\n        count --;\n        hash_accu = (hash_accu * 65599 + obj[2]) | 0;\n        break;\n      case 250:\n        // Forward\n        limit++; hash_aux(obj); break;\n      default:\n        count --;\n        hash_accu = (hash_accu * 19 + obj[0]) | 0;\n        for (var i = obj.length - 1; i > 0; i--) hash_aux (obj[i]);\n      }\n    } else if (caml_is_ml_bytes(obj)) {\n      count --;\n      var content = caml_ml_bytes_content(obj);\n      if(typeof content === \"string\") {\n        for (var b = content, l = b.length, i = 0; i < l; i++)\n          hash_accu = (hash_accu * 19 + b.charCodeAt(i)) | 0;\n      } else { /* ARRAY */\n        for (var a = content, l = a.length, i = 0; i < l; i++)\n          hash_accu = (hash_accu * 19 + a[i]) | 0;\n      }\n    } else if (caml_is_ml_string(obj)) {\n      var jsbytes = caml_jsbytes_of_string(obj);\n      for (var b = jsbytes, l = jsbytes.length, i = 0; i < l; i++)\n        hash_accu = (hash_accu * 19 + b.charCodeAt(i)) | 0;\n    } else if (typeof obj === \"string\") {\n      for (var b = obj, l = obj.length, i = 0; i < l; i++)\n        hash_accu = (hash_accu * 19 + b.charCodeAt(i)) | 0;\n    } else if (obj === (obj|0)) {\n      // Integer\n      count --;\n      hash_accu = (hash_accu * 65599 + obj) | 0;\n    } else if (obj === +obj) {\n      // Float\n      count--;\n      var p = caml_int64_to_bytes (caml_int64_bits_of_float (obj));\n      for (var i = 7; i >= 0; i--) hash_accu = (hash_accu * 19 + p[i]) | 0;\n    } else if(obj && obj.caml_custom) {\n      if(caml_custom_ops[obj.caml_custom] && caml_custom_ops[obj.caml_custom].hash) {\n        var h = caml_custom_ops[obj.caml_custom].hash(obj) | 0;\n        hash_accu = (hash_accu * 65599 + h) | 0;\n      }\n    }\n  }\n  hash_aux (obj);\n  return hash_accu & 0x3FFFFFFF;\n}\n\n//function ROTL32(x,n) { return ((x << n) | (x >>> (32-n))); }\n//Provides: caml_hash_mix_int\n//Requires: caml_mul\nfunction caml_hash_mix_int(h,d) {\n  d = caml_mul(d, 0xcc9e2d51|0);\n  d = ((d << 15) | (d >>> (32-15))); // ROTL32(d, 15);\n  d = caml_mul(d, 0x1b873593);\n  h ^= d;\n  h = ((h << 13) | (h >>> (32-13)));   //ROTL32(h, 13);\n  return (((h + (h << 2))|0) + (0xe6546b64|0))|0;\n}\n\n//Provides: caml_hash_mix_final\n//Requires: caml_mul\nfunction caml_hash_mix_final(h) {\n  h ^= h >>> 16;\n  h = caml_mul (h, 0x85ebca6b|0);\n  h ^= h >>> 13;\n  h = caml_mul (h, 0xc2b2ae35|0);\n  h ^= h >>> 16;\n  return h;\n}\n\n//Provides: caml_hash_mix_float\n//Requires: caml_int64_bits_of_float, caml_hash_mix_int64\nfunction caml_hash_mix_float (h, v0) {\n  return caml_hash_mix_int64(h, caml_int64_bits_of_float (v0));\n}\n//Provides: caml_hash_mix_int64\n//Requires: caml_hash_mix_int\n//Requires: caml_int64_lo32, caml_int64_hi32\nfunction caml_hash_mix_int64 (h, v) {\n  h = caml_hash_mix_int(h, caml_int64_lo32(v));\n  h = caml_hash_mix_int(h, caml_int64_hi32(v));\n  return h;\n}\n\n//Provides: caml_hash_mix_jsbytes\n//Requires: caml_hash_mix_int\nfunction caml_hash_mix_jsbytes(h, s) {\n  var len = s.length, i, w;\n  for (i = 0; i + 4 <= len; i += 4) {\n    w = s.charCodeAt(i)\n      | (s.charCodeAt(i+1) << 8)\n      | (s.charCodeAt(i+2) << 16)\n      | (s.charCodeAt(i+3) << 24);\n    h = caml_hash_mix_int(h, w);\n  }\n  w = 0;\n  switch (len & 3) {\n  case 3: w  = s.charCodeAt(i+2) << 16;\n  case 2: w |= s.charCodeAt(i+1) << 8;\n  case 1:\n    w |= s.charCodeAt(i);\n    h = caml_hash_mix_int(h, w);\n  default:\n  }\n  h ^= len;\n  return h;\n}\n\n//Provides: caml_hash_mix_bytes_arr\n//Requires: caml_hash_mix_int\nfunction caml_hash_mix_bytes_arr(h, s) {\n  var len = s.length, i, w;\n  for (i = 0; i + 4 <= len; i += 4) {\n    w = s[i]\n      | (s[i+1] << 8)\n      | (s[i+2] << 16)\n      | (s[i+3] << 24);\n    h = caml_hash_mix_int(h, w);\n  }\n  w = 0;\n  switch (len & 3) {\n  case 3: w  = s[i+2] << 16;\n  case 2: w |= s[i+1] << 8;\n  case 1: w |= s[i];\n    h = caml_hash_mix_int(h, w);\n  default:\n  }\n  h ^= len;\n  return h;\n}\n\n//Provides: caml_hash_mix_bytes\n//Requires: caml_ml_bytes_content\n//Requires: caml_hash_mix_jsbytes\n//Requires: caml_hash_mix_bytes_arr\nfunction caml_hash_mix_bytes(h, v) {\n  var content = caml_ml_bytes_content(v);\n  if(typeof content === \"string\")\n    return caml_hash_mix_jsbytes(h, content)\n  else /* ARRAY */\n    return caml_hash_mix_bytes_arr(h, content);\n}\n\n//Provides: caml_hash_mix_string\n//Requires: caml_hash_mix_jsbytes, caml_jsbytes_of_string\nfunction caml_hash_mix_string(h, v) {\n  return caml_hash_mix_jsbytes(h, caml_jsbytes_of_string(v));\n}\n\n\n//Provides: caml_hash mutable\n//Requires: caml_is_ml_string, caml_is_ml_bytes\n//Requires: caml_hash_mix_int, caml_hash_mix_final\n//Requires: caml_hash_mix_float, caml_hash_mix_string, caml_hash_mix_bytes, caml_custom_ops\n//Requires: caml_hash_mix_jsbytes\n//Requires: caml_is_continuation_tag\nfunction caml_hash (count, limit, seed, obj) {\n  var queue, rd, wr, sz, num, h, v, i, len;\n  sz = limit;\n  if (sz < 0 || sz > 256) sz = 256;\n  num = count;\n  h = seed;\n  queue = [obj]; rd = 0; wr = 1;\n  while (rd < wr && num > 0) {\n    v = queue[rd++];\n    if (v && v.caml_custom){\n      if(caml_custom_ops[v.caml_custom] && caml_custom_ops[v.caml_custom].hash) {\n        var hh = caml_custom_ops[v.caml_custom].hash(v);\n        h = caml_hash_mix_int (h, hh);\n        num --;\n      }\n    }\n    else if (v instanceof Array && v[0] === (v[0]|0)) {\n      switch (v[0]) {\n      case 248:\n        // Object\n        h = caml_hash_mix_int(h, v[2]);\n        num--;\n        break;\n      case 250:\n        // Forward\n        queue[--rd] = v[1];\n        break;\n      default:\n        if(caml_is_continuation_tag(v[0])) {\n          /* All continuations hash to the same value,\n             since we have no idea how to distinguish them. */\n          break;\n        }\n        var tag = ((v.length - 1) << 10) | v[0];\n        h = caml_hash_mix_int(h, tag);\n        for (i = 1, len = v.length; i < len; i++) {\n          if (wr >= sz) break;\n          queue[wr++] = v[i];\n        }\n        break;\n      }\n    } else if (caml_is_ml_bytes(v)) {\n      h = caml_hash_mix_bytes(h,v)\n      num--;\n    } else if (caml_is_ml_string(v)) {\n      h = caml_hash_mix_string(h,v)\n      num--;\n    } else if (typeof v === \"string\") {\n      h = caml_hash_mix_jsbytes(h,v)\n      num--;\n    } else if (v === (v|0)) {\n      // Integer\n      h = caml_hash_mix_int(h, v+v+1);\n      num--;\n    } else if (typeof v === \"number\") {\n      // Float\n      h = caml_hash_mix_float(h,v);\n      num--;\n    }\n  }\n  h = caml_hash_mix_final(h);\n  return h & 0x3FFFFFFF;\n}\n\n//Provides: caml_string_hash\n//Requires: caml_hash_mix_final, caml_hash_mix_string\nfunction caml_string_hash(h, v){\n  var h = caml_hash_mix_string(h,v);\n  var h = caml_hash_mix_final(h);\n  return h & 0x3FFFFFFF;\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Jérôme Vouillon, Hugo Heuzard\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Io\n\n//Provides: caml_sys_fds\nvar caml_sys_fds = new Array(3);\n\n//Provides: caml_sys_close\n//Requires: caml_sys_fds\nfunction caml_sys_close(fd) {\n  var file = caml_sys_fds[fd];\n  if(file) file.close();\n  delete caml_sys_fds[fd];\n  return 0;\n}\n\n\n//Provides: caml_sys_open\n//Requires: caml_raise_sys_error\n//Requires: MlFakeFd_out\n//Requires: resolve_fs_device\n//Requires: caml_jsbytes_of_string\n//Requires: fs_node_supported\n//Requires: caml_sys_fds\n//Requires: caml_sys_open_for_node\nfunction caml_sys_open_internal(file,idx) {\n  if(idx == undefined){\n    idx = caml_sys_fds.length;\n  }\n  caml_sys_fds[idx] = file;\n  return idx | 0;\n}\nfunction caml_sys_open (name, flags, _perms) {\n  var f = {};\n  while(flags){\n    switch(flags[1]){\n    case 0: f.rdonly = 1;break;\n    case 1: f.wronly = 1;break;\n    case 2: f.append = 1;break;\n    case 3: f.create = 1;break;\n    case 4: f.truncate = 1;break;\n    case 5: f.excl = 1; break;\n    case 6: f.binary = 1;break;\n    case 7: f.text = 1;break;\n    case 8: f.nonblock = 1;break;\n    }\n    flags=flags[2];\n  }\n  if(f.rdonly && f.wronly)\n    caml_raise_sys_error(caml_jsbytes_of_string(name) + \" : flags Open_rdonly and Open_wronly are not compatible\");\n  if(f.text && f.binary)\n    caml_raise_sys_error(caml_jsbytes_of_string(name) + \" : flags Open_text and Open_binary are not compatible\");\n  var root = resolve_fs_device(name);\n  var file = root.device.open(root.rest,f);\n  return caml_sys_open_internal (file, undefined);\n}\n(function () {\n  function file(fd, flags) {\n    if(fs_node_supported()) {\n      return caml_sys_open_for_node(fd, flags);\n    }\n    else\n      return new MlFakeFd_out(fd, flags)\n  }\n  caml_sys_open_internal(file(0,{rdonly:1,altname:\"/dev/stdin\",isCharacterDevice:true}), 0);\n  caml_sys_open_internal(file(1,{buffered:2,wronly:1,isCharacterDevice:true}), 1);\n  caml_sys_open_internal(file(2,{buffered:2,wronly:1,isCharacterDevice:true}), 2);\n})()\n\n\n// ocaml Channels\n\n//Provides: caml_ml_set_channel_name\n//Requires: caml_ml_channel_get\nfunction caml_ml_set_channel_name(chanid, name) {\n  var chan = caml_ml_channel_get(chanid);\n  chan.name = name;\n  return 0;\n}\n\n//Provides: caml_ml_channels\nvar caml_ml_channels = new Array();\n\n//Provides: caml_ml_channel_redirect\n//Requires: caml_ml_channel_get, caml_ml_channels\nfunction caml_ml_channel_redirect (captured, into){\n  var to_restore = caml_ml_channel_get(captured);\n  var new_ = caml_ml_channel_get(into);\n  caml_ml_channels[captured] = new_; // XXX\n  return to_restore;\n}\n\n//Provides: caml_ml_channel_restore\n//Requires: caml_ml_channels\nfunction caml_ml_channel_restore (captured, to_restore){\n  caml_ml_channels[captured] = to_restore; // XXX\n  return 0;\n}\n\n//Provides: caml_ml_channel_get\n//Requires: caml_ml_channels\nfunction caml_ml_channel_get(id) {\n  return caml_ml_channels[id]; // XXX\n}\n\n//Provides: caml_ml_out_channels_list\n//Requires: caml_ml_channels\nfunction caml_ml_out_channels_list () {\n  var l = 0;\n  for(var c = 0; c < caml_ml_channels.length; c++){\n    if(caml_ml_channels[c] && caml_ml_channels[c].opened && caml_ml_channels[c].out)\n      l=[0,caml_ml_channels[c].fd,l];\n  }\n  return l;\n}\n\n\n//Provides: caml_ml_open_descriptor_out\n//Requires: caml_ml_channels, caml_sys_fds\n//Requires: caml_raise_sys_error\n//Requires: caml_sys_open\nfunction caml_ml_open_descriptor_out (fd) {\n  var file = caml_sys_fds[fd];\n  if(file.flags.rdonly) caml_raise_sys_error(\"fd \"+ fd + \" is readonly\");\n  var buffered = (file.flags.buffered !== undefined) ? file.flags.buffered : 1;\n  var channel = {\n    file:file,\n    offset:file.flags.append?file.length():0,\n    fd:fd,\n    opened:true,\n    out:true,\n    buffer_curr:0,\n    buffer:new Uint8Array(65536),\n    buffered:buffered\n  };\n  caml_ml_channels[channel.fd]=channel;\n  return channel.fd;\n}\n\n//Provides: caml_ml_open_descriptor_in\n//Requires: caml_ml_channels, caml_sys_fds\n//Requires: caml_raise_sys_error\n//Requires: caml_sys_open\nfunction caml_ml_open_descriptor_in (fd)  {\n  var file = caml_sys_fds[fd];\n  if(file.flags.wronly) caml_raise_sys_error(\"fd \"+ fd + \" is writeonly\");\n  var refill = null;\n  var channel = {\n    file:file,\n    offset:file.flags.append?file.length():0,\n    fd:fd,\n    opened:true,\n    out: false,\n    buffer_curr:0,\n    buffer_max:0,\n    buffer:new Uint8Array(65536),\n    refill:refill\n  };\n  caml_ml_channels[channel.fd]=channel;\n  return channel.fd;\n}\n\n\n//Provides: caml_ml_open_descriptor_in_with_flags\n//Requires: caml_ml_open_descriptor_in\n//Version: >= 5.1\nfunction caml_ml_open_descriptor_in_with_flags(fd, flags){\n  return caml_ml_open_descriptor_in(fd);\n}\n\n//Provides: caml_ml_open_descriptor_out_with_flags\n//Requires: caml_ml_open_descriptor_out\n//Version: >= 5.1\nfunction caml_ml_open_descriptor_out_with_flags(fd, flags){\n  return caml_ml_open_descriptor_out(fd);\n}\n\n//Provides: caml_channel_descriptor\n//Requires: caml_ml_channel_get\n//Alias: win_filedescr_of_channel\nfunction caml_channel_descriptor(chanid){\n  var chan = caml_ml_channel_get(chanid);\n  return chan.fd;\n}\n\n//Provides: caml_ml_set_binary_mode\n//Requires: caml_ml_channel_get\nfunction caml_ml_set_binary_mode(chanid,mode){\n  var chan = caml_ml_channel_get(chanid);\n  chan.file.flags.text = !mode\n  chan.file.flags.binary = mode\n  return 0;\n}\n\n//Provides: caml_ml_is_binary_mode\n//Requires: caml_ml_channel_get\n//Version: >= 5.2\nfunction caml_ml_is_binary_mode(chanid) {\n  var chan = caml_ml_channel_get(chanid);\n  return chan.file.flags.binary\n}\n\n//Input from in_channel\n\n//Provides: caml_ml_close_channel\n//Requires: caml_ml_flush, caml_ml_channel_get\n//Requires: caml_sys_close\nfunction caml_ml_close_channel (chanid) {\n  var chan = caml_ml_channel_get(chanid);\n  if(chan.opened) {\n    chan.opened = false;\n    caml_sys_close(chan.fd);\n    chan.fd = -1;\n    chan.buffer = new Uint8Array(0);\n    chan.buffer_curr = 0;\n    chan.buffer_max = 0;\n  }\n  return 0;\n}\n\n//Provides: caml_ml_channel_size\n//Requires: caml_ml_channel_get\nfunction caml_ml_channel_size(chanid) {\n  var chan = caml_ml_channel_get(chanid);\n  return chan.file.length();\n}\n\n//Provides: caml_ml_channel_size_64\n//Requires: caml_int64_of_float,caml_ml_channel_get\nfunction caml_ml_channel_size_64(chanid) {\n  var chan = caml_ml_channel_get(chanid);\n  return caml_int64_of_float(chan.file.length ());\n}\n\n//Provides: caml_ml_set_channel_output\n//Requires: caml_ml_channel_get\nfunction caml_ml_set_channel_output(chanid,f) {\n  var chan = caml_ml_channel_get(chanid);\n  chan.output = (function (s) {f(s)});\n  return 0;\n}\n\n//Provides: caml_ml_set_channel_refill\n//Requires: caml_ml_channel_get\nfunction caml_ml_set_channel_refill(chanid,f) {\n  caml_ml_channel_get(chanid).refill = f;\n  return 0;\n}\n\n//Provides: caml_refill\n//Requires: caml_ml_string_length, caml_uint8_array_of_string\nfunction caml_refill (chan) {\n  if(chan.refill != null){\n    var str = chan.refill();\n    var str_a = caml_uint8_array_of_string(str);\n    if (str_a.length == 0) {\n      chan.refill = null\n    }\n    else {\n      if(chan.buffer.length < chan.buffer_max + str_a.length){\n        var b = new Uint8Array(chan.buffer_max + str_a.length);\n        b.set(chan.buffer);\n        chan.buffer = b;\n      }\n      chan.buffer.set(str_a,chan.buffer_max);\n      chan.offset += str_a.length;\n      chan.buffer_max += str_a.length;\n    }\n  } else {\n    var nread = chan.file.read(chan.offset, chan.buffer, chan.buffer_max, chan.buffer.length - chan.buffer_max);\n    chan.offset += nread;\n    chan.buffer_max += nread;\n  }\n}\n\n//Provides: caml_ml_input\n//Requires: caml_ml_input_block\n//Requires: caml_uint8_array_of_bytes\nfunction caml_ml_input (chanid, b, i, l) {\n  var ba = caml_uint8_array_of_bytes(b);\n  return caml_ml_input_block(chanid, ba, i, l)\n}\n\n//Provides: caml_ml_input_bigarray\n//Requires: caml_ml_input_block\n//Requires: caml_ba_to_typed_array\nfunction caml_ml_input_bigarray (chanid, b, i, l) {\n  var ba = caml_ba_to_typed_array(b);\n  return caml_ml_input_block(chanid, ba, i, l)\n}\n\n//Provides: caml_ml_input_block\n//Requires: caml_refill, caml_ml_channel_get\nfunction caml_ml_input_block (chanid, ba, i, l) {\n  var chan = caml_ml_channel_get(chanid);\n  var n = l;\n  var avail = chan.buffer_max - chan.buffer_curr;\n  if(l <= avail) {\n    ba.set(chan.buffer.subarray(chan.buffer_curr,chan.buffer_curr + l), i);\n    chan.buffer_curr += l;\n  }\n  else if(avail > 0) {\n    ba.set(chan.buffer.subarray(chan.buffer_curr,chan.buffer_curr + avail), i);\n    chan.buffer_curr += avail;\n    n = avail;\n  } else {\n    chan.buffer_curr = 0;\n    chan.buffer_max = 0;\n    caml_refill(chan);\n    var avail = chan.buffer_max - chan.buffer_curr;\n    if(n > avail) n = avail;\n    ba.set(chan.buffer.subarray(chan.buffer_curr,chan.buffer_curr + n), i);\n    chan.buffer_curr += n;\n  }\n  return n | 0;\n}\n\n//Provides: caml_input_value\n//Requires: caml_marshal_data_size, caml_input_value_from_bytes, caml_create_bytes, caml_ml_channel_get, caml_bytes_of_array\n//Requires: caml_refill, caml_failwith, caml_raise_end_of_file\n//Requires: caml_marshal_header_size\nfunction caml_input_value (chanid) {\n  var chan = caml_ml_channel_get(chanid);\n  var header = new Uint8Array(caml_marshal_header_size);\n  function block(buffer, offset, n) {\n    var r = 0;\n    while(r < n){\n      if(chan.buffer_curr >= chan.buffer_max){\n        chan.buffer_curr = 0;\n        chan.buffer_max = 0;\n        caml_refill(chan);\n      }\n      if (chan.buffer_curr >= chan.buffer_max)\n        break;\n      buffer[offset+r] = chan.buffer[chan.buffer_curr];\n      chan.buffer_curr++;\n      r++;\n    }\n    return r;\n  }\n  var r = block(header, 0, caml_marshal_header_size);\n  if(r == 0)\n    caml_raise_end_of_file();\n  else if (r < caml_marshal_header_size)\n    caml_failwith(\"input_value: truncated object\");\n  var len = caml_marshal_data_size (caml_bytes_of_array(header), 0);\n  var buf = new Uint8Array(len + caml_marshal_header_size);\n  buf.set(header,0);\n  var r = block(buf, caml_marshal_header_size, len)\n  if(r < len)\n    caml_failwith(\"input_value: truncated object \" + r + \"  \" + len);\n  var offset = [0];\n  var res = caml_input_value_from_bytes(caml_bytes_of_array(buf), offset);\n  chan.offset = chan.offset + offset[0];\n  return res;\n}\n\n//Provides: caml_input_value_to_outside_heap\n//Requires: caml_input_value\nfunction caml_input_value_to_outside_heap(c) {\n  return caml_input_value(c);\n}\n\n//Provides: caml_ml_input_char\n//Requires: caml_raise_end_of_file, caml_array_bound_error\n//Requires: caml_ml_channel_get, caml_refill\nfunction caml_ml_input_char (chanid) {\n  var chan = caml_ml_channel_get(chanid);\n  if(chan.buffer_curr >= chan.buffer_max){\n    chan.buffer_curr = 0;\n    chan.buffer_max = 0;\n    caml_refill(chan);\n  }\n  if (chan.buffer_curr >= chan.buffer_max)\n    caml_raise_end_of_file();\n  var res = chan.buffer[chan.buffer_curr];\n  chan.buffer_curr++;\n  return res;\n}\n\n//Provides: caml_ml_input_int\n//Requires: caml_raise_end_of_file\n//Requires: caml_ml_input_char, caml_ml_channel_get\nfunction caml_ml_input_int (chanid) {\n  var chan = caml_ml_channel_get(chanid);\n  var res = 0;\n  for(var i = 0; i < 4; i++){\n    res = (res << 8) + caml_ml_input_char(chanid) | 0;\n  }\n  return res | 0;\n}\n\n//Provides: caml_seek_in\n//Requires: caml_raise_sys_error, caml_ml_channel_get\nfunction caml_seek_in(chanid, pos) {\n  var chan = caml_ml_channel_get(chanid);\n  if (chan.refill != null) caml_raise_sys_error(\"Illegal seek\");\n  if(pos >= chan.offset - chan.buffer_max\n     && pos <= chan.offset\n     && chan.file.flags.binary) {\n    chan.buffer_curr = chan.buffer_max - (chan.offset - pos);\n  } else {\n    chan.offset = pos;\n    chan.buffer_curr = 0;\n    chan.buffer_max = 0;\n  }\n  return 0;\n}\n\n//Provides: caml_ml_seek_in\n//Requires: caml_seek_in\nfunction caml_ml_seek_in(chanid,pos){\n  return caml_seek_in(chanid,pos);\n}\n\n//Provides: caml_ml_seek_in_64\n//Requires: caml_int64_to_float, caml_seek_in\nfunction caml_ml_seek_in_64(chanid,pos){\n  var pos = caml_int64_to_float(pos);\n  return caml_seek_in(chanid, pos);\n}\n\n//Provides: caml_pos_in\n//Requires: caml_ml_channel_get\nfunction caml_pos_in(chanid) {\n  var chan = caml_ml_channel_get(chanid);\n  return chan.offset - (chan.buffer_max - chan.buffer_curr) | 0;\n}\n\n//Provides: caml_ml_pos_in\n//Requires: caml_pos_in\nfunction caml_ml_pos_in(chanid) {\n  return caml_pos_in(chanid);\n}\n\n//Provides: caml_ml_pos_in_64\n//Requires: caml_int64_of_float, caml_pos_in\nfunction caml_ml_pos_in_64(chanid) {\n  return caml_int64_of_float(caml_pos_in(chanid));\n}\n\n//Provides: caml_ml_input_scan_line\n//Requires: caml_array_bound_error\n//Requires: caml_ml_channel_get, caml_refill\nfunction caml_ml_input_scan_line(chanid){\n  var chan = caml_ml_channel_get(chanid);\n  var p = chan.buffer_curr;\n  do {\n    if(p >= chan.buffer_max) {\n      if(chan.buffer_curr > 0) {\n        chan.buffer.set(chan.buffer.subarray(chan.buffer_curr),0);\n        p -= chan.buffer_curr;\n        chan.buffer_max -= chan.buffer_curr;\n        chan.buffer_curr = 0;\n      }\n      if(chan.buffer_max >= chan.buffer.length) {\n        return -(chan.buffer_max) | 0;\n      }\n      var prev_max = chan.buffer_max;\n      caml_refill (chan);\n      if(prev_max == chan.buffer_max) {\n        return -(chan.buffer_max) | 0;\n      }\n    }\n  } while (chan.buffer[p++] != 10);\n  return (p - chan.buffer_curr) | 0;\n}\n\n//Provides: caml_ml_flush\n//Requires: caml_raise_sys_error, caml_ml_channel_get\n//Requires: caml_subarray_to_jsbytes\nfunction caml_ml_flush (chanid) {\n  var chan = caml_ml_channel_get(chanid);\n  if(! chan.opened) caml_raise_sys_error(\"Cannot flush a closed channel\");\n  if(!chan.buffer || chan.buffer_curr == 0) return 0;\n  if(chan.output) {\n    chan.output(caml_subarray_to_jsbytes(chan.buffer, 0, chan.buffer_curr));\n  } else {\n    chan.file.write(chan.offset, chan.buffer, 0, chan.buffer_curr);\n  }\n  chan.offset += chan.buffer_curr;\n  chan.buffer_curr = 0;\n  return 0;\n}\n\n//output to out_channel\n\n//Provides: caml_ml_output_ta\n//Requires: caml_ml_flush,caml_ml_bytes_length\n//Requires: caml_raise_sys_error, caml_ml_channel_get\nfunction caml_ml_output_ta(chanid,buffer,offset,len) {\n  var chan = caml_ml_channel_get(chanid);\n  if(! chan.opened) caml_raise_sys_error(\"Cannot output to a closed channel\");\n  buffer = buffer.subarray(offset, offset + len);\n  if(chan.buffer_curr + buffer.length > chan.buffer.length) {\n    var b = new Uint8Array(chan.buffer_curr + buffer.length);\n    b.set(chan.buffer);\n    chan.buffer = b\n  }\n  switch(chan.buffered){\n  case 0: // Unbuffered\n    chan.buffer.set(buffer, chan.buffer_curr);\n    chan.buffer_curr += buffer.length;\n    caml_ml_flush (chanid);\n    break\n  case 1: // Buffered (the default)\n    chan.buffer.set(buffer, chan.buffer_curr);\n    chan.buffer_curr += buffer.length;\n    if(chan.buffer_curr >= chan.buffer.length)\n      caml_ml_flush (chanid);\n    break;\n  case 2: // Buffered (only for stdout and stderr)\n    var id = buffer.lastIndexOf(10)\n    if(id < 0) {\n      chan.buffer.set(buffer, chan.buffer_curr);\n      chan.buffer_curr += buffer.length;\n      if(chan.buffer_curr >= chan.buffer.length)\n        caml_ml_flush (chanid);\n    }\n    else {\n      chan.buffer.set(buffer.subarray(0, id + 1), chan.buffer_curr);\n      chan.buffer_curr += id + 1;\n      caml_ml_flush (chanid);\n      chan.buffer.set(buffer.subarray(id + 1), chan.buffer_curr);\n      chan.buffer_curr += buffer.length - id - 1;\n    }\n    break;\n  }\n  return 0;\n}\n\n//Provides: caml_ml_output_bytes\n//Requires: caml_uint8_array_of_bytes, caml_ml_output_ta\nfunction caml_ml_output_bytes(chanid,buffer,offset,len) {\n  var buffer = caml_uint8_array_of_bytes(buffer);\n  return caml_ml_output_ta(chanid,buffer,offset,len);\n}\n\n\n//Provides: caml_ml_output_bigarray\n//Requires: caml_ba_to_typed_array, caml_ml_output_ta\nfunction caml_ml_output_bigarray(chanid,buffer,offset,len) {\n  var buffer = caml_ba_to_typed_array(buffer);\n  return caml_ml_output_ta(chanid,buffer,offset,len);\n}\n\n\n\n//Provides: caml_ml_output\n//Requires: caml_ml_output_bytes, caml_bytes_of_string\nfunction caml_ml_output(chanid,buffer,offset,len){\n  return caml_ml_output_bytes(chanid,caml_bytes_of_string(buffer),offset,len);\n}\n\n//Provides: caml_ml_output_char\n//Requires: caml_ml_output\n//Requires: caml_string_of_jsbytes\nfunction caml_ml_output_char (chanid,c) {\n  var s = caml_string_of_jsbytes(String.fromCharCode(c));\n  caml_ml_output(chanid,s,0,1);\n  return 0;\n}\n\n//Provides: caml_output_value\n//Requires: caml_output_value_to_string, caml_ml_output,caml_ml_string_length\nfunction caml_output_value (chanid,v,flags) {\n  var s = caml_output_value_to_string(v, flags);\n  caml_ml_output(chanid,s,0,caml_ml_string_length(s));\n  return 0;\n}\n\n\n//Provides: caml_seek_out\n//Requires: caml_ml_channel_get, caml_ml_flush\nfunction caml_seek_out(chanid, pos){\n  caml_ml_flush(chanid);\n  var chan = caml_ml_channel_get(chanid);\n  chan.offset = pos;\n  return 0;\n}\n\n//Provides: caml_ml_seek_out\n//Requires: caml_seek_out\nfunction caml_ml_seek_out(chanid,pos){\n  return caml_seek_out(chanid, pos);\n}\n//Provides: caml_ml_seek_out_64\n//Requires: caml_int64_to_float, caml_seek_out\nfunction caml_ml_seek_out_64(chanid,pos){\n  var pos = caml_int64_to_float(pos);\n  return caml_seek_out(chanid, pos);\n}\n\n//Provides: caml_pos_out\n//Requires: caml_ml_channel_get, caml_ml_flush\nfunction caml_pos_out(chanid) {\n  var chan = caml_ml_channel_get(chanid);\n  return chan.offset + chan.buffer_curr\n}\n\n//Provides: caml_ml_pos_out\n//Requires: caml_pos_out\nfunction caml_ml_pos_out(chanid) {\n  return caml_pos_out(chanid);\n}\n\n//Provides: caml_ml_pos_out_64\n//Requires: caml_int64_of_float, caml_pos_out\nfunction caml_ml_pos_out_64(chanid) {\n  return caml_int64_of_float (caml_pos_out(chanid));\n}\n\n//Provides: caml_ml_output_int\n//Requires: caml_ml_output\n//Requires: caml_string_of_array\nfunction caml_ml_output_int (chanid,i) {\n  var arr = [(i>>24) & 0xFF,(i>>16) & 0xFF,(i>>8) & 0xFF,i & 0xFF ];\n  var s = caml_string_of_array(arr);\n  caml_ml_output(chanid,s,0,4);\n  return 0\n}\n\n//Provides: caml_ml_is_buffered\n//Requires: caml_ml_channel_get\nfunction caml_ml_is_buffered(chanid) {\n  return caml_ml_channel_get(chanid).buffered ? 1 : 0\n}\n\n//Provides: caml_ml_set_buffered\n//Requires: caml_ml_channel_get, caml_ml_flush\nfunction caml_ml_set_buffered(chanid,v) {\n  caml_ml_channel_get(chanid).buffered = v;\n  if(!v) caml_ml_flush(chanid);\n  return 0\n}\n","\n//Provides: caml_custom_event_index\nvar caml_custom_event_index = 0;\n\n//Provides: caml_runtime_events_user_register\n//Requires: caml_custom_event_index\nfunction caml_runtime_events_user_register(event_name, event_tag, event_type) {\n  caml_custom_event_index += 1;\n  return [0, caml_custom_event_index, event_name, event_type, event_tag];\n}\n\n//Provides: caml_runtime_events_user_write\nfunction caml_runtime_events_user_write(event, event_content) {\n  return 0;\n}\n\n//Provides: caml_runtime_events_user_resolve\nfunction caml_runtime_events_user_resolve() {\n  return 0;\n}\n\n//Provides: caml_ml_runtime_events_start\n//Alias: caml_runtime_events_start\nfunction caml_ml_runtime_events_start() {\n  return 0;\n}\n\n//Provides: caml_ml_runtime_events_pause\n//Alias: caml_runtime_events_pause\nfunction caml_ml_runtime_events_pause() {\n  return 0;\n}\n\n//Provides: caml_ml_runtime_events_are_active\n//Version: >= 5.2\nfunction caml_ml_runtime_events_are_active() {\n  return 0;\n}\n\n//Provides: caml_ml_runtime_events_resume\n//Alias: caml_runtime_events_resume\nfunction caml_ml_runtime_events_resume() {\n  return 0;\n}\n\n//Provides: caml_runtime_events_create_cursor\nfunction caml_runtime_events_create_cursor(target) {\n  return {};\n}\n\n//Provides: caml_runtime_events_free_cursor\nfunction caml_runtime_events_free_cursor(cursor) {\n  return 0;\n}\n\n//Provides: caml_runtime_events_read_poll\nfunction caml_runtime_events_read_poll(cursor, callbacks, num) {\n  return 0;\n}\n","\n//Provides: zstd_decompress\n//Version: >= 5.1\nvar zstd_decompress = (function () {\n\"use strict\";\n// aliases for shorter compressed code (most minifers don't do this)\nvar ab = ArrayBuffer, u8 = Uint8Array, u16 = Uint16Array, i16 = Int16Array, u32 = Uint32Array, i32 = Int32Array;\nvar slc = function (v, s, e) {\n    if (u8.prototype.slice)\n        return u8.prototype.slice.call(v, s, e);\n    if (s == null || s < 0)\n        s = 0;\n    if (e == null || e > v.length)\n        e = v.length;\n    var n = new u8(e - s);\n    n.set(v.subarray(s, e));\n    return n;\n};\nvar fill = function (v, n, s, e) {\n    if (u8.prototype.fill)\n        return u8.prototype.fill.call(v, n, s, e);\n    if (s == null || s < 0)\n        s = 0;\n    if (e == null || e > v.length)\n        e = v.length;\n    for (; s < e; ++s)\n        v[s] = n;\n    return v;\n};\nvar cpw = function (v, t, s, e) {\n    if (u8.prototype.copyWithin)\n        return u8.prototype.copyWithin.call(v, t, s, e);\n    if (s == null || s < 0)\n        s = 0;\n    if (e == null || e > v.length)\n        e = v.length;\n    while (s < e) {\n        v[t++] = v[s++];\n    }\n};\n/**\n * Codes for errors generated within this library\n */\n// error codes\nvar ec = [\n    'invalid zstd data',\n    'window size too large (>2046MB)',\n    'invalid block type',\n    'FSE accuracy too high',\n    'match distance too far back',\n    'unexpected EOF'\n];\n;\nvar err = function (ind, msg, nt) {\n    var e = new Error(msg || ec[ind]);\n    e.code = ind;\n    if (!nt)\n        throw e;\n    return e;\n};\nvar rb = function (d, b, n) {\n    var i = 0, o = 0;\n    for (; i < n; ++i)\n        o |= d[b++] << (i << 3);\n    return o;\n};\nvar b4 = function (d, b) { return (d[b] | (d[b + 1] << 8) | (d[b + 2] << 16) | (d[b + 3] << 24)) >>> 0; };\n// read Zstandard frame header\nvar rzfh = function (dat, w) {\n    var n3 = dat[0] | (dat[1] << 8) | (dat[2] << 16);\n    if (n3 == 0x2FB528 && dat[3] == 253) {\n        // Zstandard\n        var flg = dat[4];\n        //    single segment       checksum             dict flag     frame content flag\n        var ss = (flg >> 5) & 1, cc = (flg >> 2) & 1, df = flg & 3, fcf = flg >> 6;\n        if (flg & 8)\n            err(0);\n        // byte\n        var bt = 6 - ss;\n        // dict bytes\n        var db = df == 3 ? 4 : df;\n        // dictionary id\n        var di = rb(dat, bt, db);\n        bt += db;\n        // frame size bytes\n        var fsb = fcf ? (1 << fcf) : ss;\n        // frame source size\n        var fss = rb(dat, bt, fsb) + ((fcf == 1) && 256);\n        // window size\n        var ws = fss;\n        if (!ss) {\n            // window descriptor\n            var wb = 1 << (10 + (dat[5] >> 3));\n            ws = wb + (wb >> 3) * (dat[5] & 7);\n        }\n        if (ws > 2145386496)\n            err(1);\n        var buf = new u8((w == 1 ? (fss || ws) : w ? 0 : ws) + 12);\n        buf[0] = 1, buf[4] = 4, buf[8] = 8;\n        return {\n            b: bt + fsb,\n            y: 0,\n            l: 0,\n            d: di,\n            w: (w && w != 1) ? w : buf.subarray(12),\n            e: ws,\n            o: new i32(buf.buffer, 0, 3),\n            u: fss,\n            c: cc,\n            m: Math.min(131072, ws)\n        };\n    }\n    else if (((n3 >> 4) | (dat[3] << 20)) == 0x184D2A5) {\n        // skippable\n        return b4(dat, 4) + 8;\n    }\n    err(0);\n};\n// most significant bit for nonzero\nvar msb = function (val) {\n    var bits = 0;\n    for (; (1 << bits) <= val; ++bits)\n        ;\n    return bits - 1;\n};\n// read finite state entropy\nvar rfse = function (dat, bt, mal) {\n    // table pos\n    var tpos = (bt << 3) + 4;\n    // accuracy log\n    var al = (dat[bt] & 15) + 5;\n    if (al > mal)\n        err(3);\n    // size\n    var sz = 1 << al;\n    // probabilities symbols  repeat   index   high threshold\n    var probs = sz, sym = -1, re = -1, i = -1, ht = sz;\n    // optimization: single allocation is much faster\n    var buf = new ab(512 + (sz << 2));\n    var freq = new i16(buf, 0, 256);\n    // same view as freq\n    var dstate = new u16(buf, 0, 256);\n    var nstate = new u16(buf, 512, sz);\n    var bb1 = 512 + (sz << 1);\n    var syms = new u8(buf, bb1, sz);\n    var nbits = new u8(buf, bb1 + sz);\n    while (sym < 255 && probs > 0) {\n        var bits = msb(probs + 1);\n        var cbt = tpos >> 3;\n        // mask\n        var msk = (1 << (bits + 1)) - 1;\n        var val = ((dat[cbt] | (dat[cbt + 1] << 8) | (dat[cbt + 2] << 16)) >> (tpos & 7)) & msk;\n        // mask (1 fewer bit)\n        var msk1fb = (1 << bits) - 1;\n        // max small value\n        var msv = msk - probs - 1;\n        // small value\n        var sval = val & msk1fb;\n        if (sval < msv)\n            tpos += bits, val = sval;\n        else {\n            tpos += bits + 1;\n            if (val > msk1fb)\n                val -= msv;\n        }\n        freq[++sym] = --val;\n        if (val == -1) {\n            probs += val;\n            syms[--ht] = sym;\n        }\n        else\n            probs -= val;\n        if (!val) {\n            do {\n                // repeat byte\n                var rbt = tpos >> 3;\n                re = ((dat[rbt] | (dat[rbt + 1] << 8)) >> (tpos & 7)) & 3;\n                tpos += 2;\n                sym += re;\n            } while (re == 3);\n        }\n    }\n    if (sym > 255 || probs)\n        err(0);\n    var sympos = 0;\n    // sym step (coprime with sz - formula from zstd source)\n    var sstep = (sz >> 1) + (sz >> 3) + 3;\n    // sym mask\n    var smask = sz - 1;\n    for (var s = 0; s <= sym; ++s) {\n        var sf = freq[s];\n        if (sf < 1) {\n            dstate[s] = -sf;\n            continue;\n        }\n        // This is split into two loops in zstd to avoid branching, but as JS is higher-level that is unnecessary\n        for (i = 0; i < sf; ++i) {\n            syms[sympos] = s;\n            do {\n                sympos = (sympos + sstep) & smask;\n            } while (sympos >= ht);\n        }\n    }\n    // After spreading symbols, should be zero again\n    if (sympos)\n        err(0);\n    for (i = 0; i < sz; ++i) {\n        // next state\n        var ns = dstate[syms[i]]++;\n        // num bits\n        var nb = nbits[i] = al - msb(ns);\n        nstate[i] = (ns << nb) - sz;\n    }\n    return [(tpos + 7) >> 3, {\n            b: al,\n            s: syms,\n            n: nbits,\n            t: nstate\n        }];\n};\n// read huffman\nvar rhu = function (dat, bt) {\n    //  index  weight count\n    var i = 0, wc = -1;\n    //    buffer             header byte\n    var buf = new u8(292), hb = dat[bt];\n    // huffman weights\n    var hw = buf.subarray(0, 256);\n    // rank count\n    var rc = buf.subarray(256, 268);\n    // rank index\n    var ri = new u16(buf.buffer, 268);\n    // NOTE: at this point bt is 1 less than expected\n    if (hb < 128) {\n        // end byte, fse decode table\n        var _a = rfse(dat, bt + 1, 6), ebt = _a[0], fdt = _a[1];\n        bt += hb;\n        var epos = ebt << 3;\n        // last byte\n        var lb = dat[bt];\n        if (!lb)\n            err(0);\n        //  state1   state2   state1 bits   state2 bits\n        var st1 = 0, st2 = 0, btr1 = fdt.b, btr2 = btr1;\n        // fse pos\n        // pre-increment to account for original deficit of 1\n        var fpos = (++bt << 3) - 8 + msb(lb);\n        for (;;) {\n            fpos -= btr1;\n            if (fpos < epos)\n                break;\n            var cbt = fpos >> 3;\n            st1 += ((dat[cbt] | (dat[cbt + 1] << 8)) >> (fpos & 7)) & ((1 << btr1) - 1);\n            hw[++wc] = fdt.s[st1];\n            fpos -= btr2;\n            if (fpos < epos)\n                break;\n            cbt = fpos >> 3;\n            st2 += ((dat[cbt] | (dat[cbt + 1] << 8)) >> (fpos & 7)) & ((1 << btr2) - 1);\n            hw[++wc] = fdt.s[st2];\n            btr1 = fdt.n[st1];\n            st1 = fdt.t[st1];\n            btr2 = fdt.n[st2];\n            st2 = fdt.t[st2];\n        }\n        if (++wc > 255)\n            err(0);\n    }\n    else {\n        wc = hb - 127;\n        for (; i < wc; i += 2) {\n            var byte = dat[++bt];\n            hw[i] = byte >> 4;\n            hw[i + 1] = byte & 15;\n        }\n        ++bt;\n    }\n    // weight exponential sum\n    var wes = 0;\n    for (i = 0; i < wc; ++i) {\n        var wt = hw[i];\n        // bits must be at most 11, same as weight\n        if (wt > 11)\n            err(0);\n        wes += wt && (1 << (wt - 1));\n    }\n    // max bits\n    var mb = msb(wes) + 1;\n    // table size\n    var ts = 1 << mb;\n    // remaining sum\n    var rem = ts - wes;\n    // must be power of 2\n    if (rem & (rem - 1))\n        err(0);\n    hw[wc++] = msb(rem) + 1;\n    for (i = 0; i < wc; ++i) {\n        var wt = hw[i];\n        ++rc[hw[i] = wt && (mb + 1 - wt)];\n    }\n    // huf buf\n    var hbuf = new u8(ts << 1);\n    //    symbols                      num bits\n    var syms = hbuf.subarray(0, ts), nb = hbuf.subarray(ts);\n    ri[mb] = 0;\n    for (i = mb; i > 0; --i) {\n        var pv = ri[i];\n        fill(nb, i, pv, ri[i - 1] = pv + rc[i] * (1 << (mb - i)));\n    }\n    if (ri[0] != ts)\n        err(0);\n    for (i = 0; i < wc; ++i) {\n        var bits = hw[i];\n        if (bits) {\n            var code = ri[bits];\n            fill(syms, i, code, ri[bits] = code + (1 << (mb - bits)));\n        }\n    }\n    return [bt, {\n            n: nb,\n            b: mb,\n            s: syms\n        }];\n};\n// Tables generated using this:\n// https://gist.github.com/101arrowz/a979452d4355992cbf8f257cbffc9edd\n// default literal length table\nvar dllt = /*#__PURE__*/ rfse(/*#__PURE__*/ new u8([\n    81, 16, 99, 140, 49, 198, 24, 99, 12, 33, 196, 24, 99, 102, 102, 134, 70, 146, 4\n]), 0, 6)[1];\n// default match length table\nvar dmlt = /*#__PURE__*/ rfse(/*#__PURE__*/ new u8([\n    33, 20, 196, 24, 99, 140, 33, 132, 16, 66, 8, 33, 132, 16, 66, 8, 33, 68, 68, 68, 68, 68, 68, 68, 68, 36, 9\n]), 0, 6)[1];\n// default offset code table\nvar doct = /*#__PURE__ */ rfse(/*#__PURE__*/ new u8([\n    32, 132, 16, 66, 102, 70, 68, 68, 68, 68, 36, 73, 2\n]), 0, 5)[1];\n// bits to baseline\nvar b2bl = function (b, s) {\n    var len = b.length, bl = new i32(len);\n    for (var i = 0; i < len; ++i) {\n        bl[i] = s;\n        s += 1 << b[i];\n    }\n    return bl;\n};\n// literal length bits\nvar llb = /*#__PURE__ */ new u8(( /*#__PURE__ */new i32([\n    0, 0, 0, 0, 16843009, 50528770, 134678020, 202050057, 269422093\n])).buffer, 0, 36);\n// literal length baseline\nvar llbl = /*#__PURE__ */ b2bl(llb, 0);\n// match length bits\nvar mlb = /*#__PURE__ */ new u8(( /*#__PURE__ */new i32([\n    0, 0, 0, 0, 0, 0, 0, 0, 16843009, 50528770, 117769220, 185207048, 252579084, 16\n])).buffer, 0, 53);\n// match length baseline\nvar mlbl = /*#__PURE__ */ b2bl(mlb, 3);\n// decode huffman stream\nvar dhu = function (dat, out, hu) {\n    var len = dat.length, ss = out.length, lb = dat[len - 1], msk = (1 << hu.b) - 1, eb = -hu.b;\n    if (!lb)\n        err(0);\n    var st = 0, btr = hu.b, pos = (len << 3) - 8 + msb(lb) - btr, i = -1;\n    for (; pos > eb && i < ss;) {\n        var cbt = pos >> 3;\n        var val = (dat[cbt] | (dat[cbt + 1] << 8) | (dat[cbt + 2] << 16)) >> (pos & 7);\n        st = ((st << btr) | val) & msk;\n        out[++i] = hu.s[st];\n        pos -= (btr = hu.n[st]);\n    }\n    if (pos != eb || i + 1 != ss)\n        err(0);\n};\n// decode huffman stream 4x\n// TODO: use workers to parallelize\nvar dhu4 = function (dat, out, hu) {\n    var bt = 6;\n    var ss = out.length, sz1 = (ss + 3) >> 2, sz2 = sz1 << 1, sz3 = sz1 + sz2;\n    dhu(dat.subarray(bt, bt += dat[0] | (dat[1] << 8)), out.subarray(0, sz1), hu);\n    dhu(dat.subarray(bt, bt += dat[2] | (dat[3] << 8)), out.subarray(sz1, sz2), hu);\n    dhu(dat.subarray(bt, bt += dat[4] | (dat[5] << 8)), out.subarray(sz2, sz3), hu);\n    dhu(dat.subarray(bt), out.subarray(sz3), hu);\n};\n// read Zstandard block\nvar rzb = function (dat, st, out) {\n    var _a;\n    var bt = st.b;\n    //    byte 0        block type\n    var b0 = dat[bt], btype = (b0 >> 1) & 3;\n    st.l = b0 & 1;\n    var sz = (b0 >> 3) | (dat[bt + 1] << 5) | (dat[bt + 2] << 13);\n    // end byte for block\n    var ebt = (bt += 3) + sz;\n    if (btype == 1) {\n        if (bt >= dat.length)\n            return;\n        st.b = bt + 1;\n        if (out) {\n            fill(out, dat[bt], st.y, st.y += sz);\n            return out;\n        }\n        return fill(new u8(sz), dat[bt]);\n    }\n    if (ebt > dat.length)\n        return;\n    if (btype == 0) {\n        st.b = ebt;\n        if (out) {\n            out.set(dat.subarray(bt, ebt), st.y);\n            st.y += sz;\n            return out;\n        }\n        return slc(dat, bt, ebt);\n    }\n    if (btype == 2) {\n        //    byte 3        lit btype     size format\n        var b3 = dat[bt], lbt = b3 & 3, sf = (b3 >> 2) & 3;\n        // lit src size  lit cmp sz 4 streams\n        var lss = b3 >> 4, lcs = 0, s4 = 0;\n        if (lbt < 2) {\n            if (sf & 1)\n                lss |= (dat[++bt] << 4) | ((sf & 2) && (dat[++bt] << 12));\n            else\n                lss = b3 >> 3;\n        }\n        else {\n            s4 = sf;\n            if (sf < 2)\n                lss |= ((dat[++bt] & 63) << 4), lcs = (dat[bt] >> 6) | (dat[++bt] << 2);\n            else if (sf == 2)\n                lss |= (dat[++bt] << 4) | ((dat[++bt] & 3) << 12), lcs = (dat[bt] >> 2) | (dat[++bt] << 6);\n            else\n                lss |= (dat[++bt] << 4) | ((dat[++bt] & 63) << 12), lcs = (dat[bt] >> 6) | (dat[++bt] << 2) | (dat[++bt] << 10);\n        }\n        ++bt;\n        // add literals to end - can never overlap with backreferences because unused literals always appended\n        var buf = out ? out.subarray(st.y, st.y + st.m) : new u8(st.m);\n        // starting point for literals\n        var spl = buf.length - lss;\n        if (lbt == 0)\n            buf.set(dat.subarray(bt, bt += lss), spl);\n        else if (lbt == 1)\n            fill(buf, dat[bt++], spl);\n        else {\n            // huffman table\n            var hu = st.h;\n            if (lbt == 2) {\n                var hud = rhu(dat, bt);\n                // subtract description length\n                lcs += bt - (bt = hud[0]);\n                st.h = hu = hud[1];\n            }\n            else if (!hu)\n                err(0);\n            (s4 ? dhu4 : dhu)(dat.subarray(bt, bt += lcs), buf.subarray(spl), hu);\n        }\n        // num sequences\n        var ns = dat[bt++];\n        if (ns) {\n            if (ns == 255)\n                ns = (dat[bt++] | (dat[bt++] << 8)) + 0x7F00;\n            else if (ns > 127)\n                ns = ((ns - 128) << 8) | dat[bt++];\n            // symbol compression modes\n            var scm = dat[bt++];\n            if (scm & 3)\n                err(0);\n            var dts = [dmlt, doct, dllt];\n            for (var i = 2; i > -1; --i) {\n                var md = (scm >> ((i << 1) + 2)) & 3;\n                if (md == 1) {\n                    // rle buf\n                    var rbuf = new u8([0, 0, dat[bt++]]);\n                    dts[i] = {\n                        s: rbuf.subarray(2, 3),\n                        n: rbuf.subarray(0, 1),\n                        t: new u16(rbuf.buffer, 0, 1),\n                        b: 0\n                    };\n                }\n                else if (md == 2) {\n                    // accuracy log 8 for offsets, 9 for others\n                    _a = rfse(dat, bt, 9 - (i & 1)), bt = _a[0], dts[i] = _a[1];\n                }\n                else if (md == 3) {\n                    if (!st.t)\n                        err(0);\n                    dts[i] = st.t[i];\n                }\n            }\n            var _b = st.t = dts, mlt = _b[0], oct = _b[1], llt = _b[2];\n            var lb = dat[ebt - 1];\n            if (!lb)\n                err(0);\n            var spos = (ebt << 3) - 8 + msb(lb) - llt.b, cbt = spos >> 3, oubt = 0;\n            var lst = ((dat[cbt] | (dat[cbt + 1] << 8)) >> (spos & 7)) & ((1 << llt.b) - 1);\n            cbt = (spos -= oct.b) >> 3;\n            var ost = ((dat[cbt] | (dat[cbt + 1] << 8)) >> (spos & 7)) & ((1 << oct.b) - 1);\n            cbt = (spos -= mlt.b) >> 3;\n            var mst = ((dat[cbt] | (dat[cbt + 1] << 8)) >> (spos & 7)) & ((1 << mlt.b) - 1);\n            for (++ns; --ns;) {\n                var llc = llt.s[lst];\n                var lbtr = llt.n[lst];\n                var mlc = mlt.s[mst];\n                var mbtr = mlt.n[mst];\n                var ofc = oct.s[ost];\n                var obtr = oct.n[ost];\n                cbt = (spos -= ofc) >> 3;\n                var ofp = 1 << ofc;\n                var off = ofp + (((dat[cbt] | (dat[cbt + 1] << 8) | (dat[cbt + 2] << 16) | (dat[cbt + 3] << 24)) >>> (spos & 7)) & (ofp - 1));\n                cbt = (spos -= mlb[mlc]) >> 3;\n                var ml = mlbl[mlc] + (((dat[cbt] | (dat[cbt + 1] << 8) | (dat[cbt + 2] << 16)) >> (spos & 7)) & ((1 << mlb[mlc]) - 1));\n                cbt = (spos -= llb[llc]) >> 3;\n                var ll = llbl[llc] + (((dat[cbt] | (dat[cbt + 1] << 8) | (dat[cbt + 2] << 16)) >> (spos & 7)) & ((1 << llb[llc]) - 1));\n                cbt = (spos -= lbtr) >> 3;\n                lst = llt.t[lst] + (((dat[cbt] | (dat[cbt + 1] << 8)) >> (spos & 7)) & ((1 << lbtr) - 1));\n                cbt = (spos -= mbtr) >> 3;\n                mst = mlt.t[mst] + (((dat[cbt] | (dat[cbt + 1] << 8)) >> (spos & 7)) & ((1 << mbtr) - 1));\n                cbt = (spos -= obtr) >> 3;\n                ost = oct.t[ost] + (((dat[cbt] | (dat[cbt + 1] << 8)) >> (spos & 7)) & ((1 << obtr) - 1));\n                if (off > 3) {\n                    st.o[2] = st.o[1];\n                    st.o[1] = st.o[0];\n                    st.o[0] = off -= 3;\n                }\n                else {\n                    var idx = off - (ll != 0);\n                    if (idx) {\n                        off = idx == 3 ? st.o[0] - 1 : st.o[idx];\n                        if (idx > 1)\n                            st.o[2] = st.o[1];\n                        st.o[1] = st.o[0];\n                        st.o[0] = off;\n                    }\n                    else\n                        off = st.o[0];\n                }\n                for (var i = 0; i < ll; ++i) {\n                    buf[oubt + i] = buf[spl + i];\n                }\n                oubt += ll, spl += ll;\n                var stin = oubt - off;\n                if (stin < 0) {\n                    var len = -stin;\n                    var bs = st.e + stin;\n                    if (len > ml)\n                        len = ml;\n                    for (var i = 0; i < len; ++i) {\n                        buf[oubt + i] = st.w[bs + i];\n                    }\n                    oubt += len, ml -= len, stin = 0;\n                }\n                for (var i = 0; i < ml; ++i) {\n                    buf[oubt + i] = buf[stin + i];\n                }\n                oubt += ml;\n            }\n            if (oubt != spl) {\n                while (spl < buf.length) {\n                    buf[oubt++] = buf[spl++];\n                }\n            }\n            else\n                oubt = buf.length;\n            if (out)\n                st.y += oubt;\n            else\n                buf = slc(buf, 0, oubt);\n        }\n        else {\n            if (out) {\n                st.y += lss;\n                if (spl) {\n                    for (var i = 0; i < lss; ++i) {\n                        buf[i] = buf[spl + i];\n                    }\n                }\n            }\n            else if (spl)\n                buf = slc(buf, spl);\n        }\n        st.b = ebt;\n        return buf;\n    }\n    err(2);\n};\n// concat\nvar cct = function (bufs, ol) {\n    if (bufs.length == 1)\n        return bufs[0];\n    var buf = new u8(ol);\n    for (var i = 0, b = 0; i < bufs.length; ++i) {\n        var chk = bufs[i];\n        buf.set(chk, b);\n        b += chk.length;\n    }\n    return buf;\n};\n/**\n * Decompresses Zstandard data\n * @param dat The input data\n * @param buf The output buffer. If unspecified, the function will allocate\n *            exactly enough memory to fit the decompressed data. If your\n *            data has multiple frames and you know the output size, specifying\n *            it will yield better performance.\n * @returns The decompressed data\n */\nreturn function decompress(dat, buf) {\n    var bt = 0, bufs = [], nb = +!buf, ol = 0;\n    for (; dat.length;) {\n        var st = rzfh(dat, nb || buf);\n        if (typeof st == 'object') {\n            if (nb) {\n                buf = null;\n                if (st.w.length == st.u) {\n                    bufs.push(buf = st.w);\n                    ol += st.u;\n                }\n            }\n            else {\n                bufs.push(buf);\n                st.e = 0;\n            }\n            for (; !st.l;) {\n                var blk = rzb(dat, st, buf);\n                if (!blk)\n                    err(5);\n                if (buf)\n                    st.e = st.y;\n                else {\n                    bufs.push(blk);\n                    ol += blk.length;\n                    cpw(st.w, 0, blk.length);\n                    st.w.set(blk, st.w.length - blk.length);\n                }\n            }\n            bt = st.b + (st.c * 4);\n        }\n        else\n            bt = st;\n        dat = dat.subarray(bt);\n    }\n    return cct(bufs, ol);\n}\n}) ()\n\n\n//Provides: caml_decompress_input\n//Version: < 5.1.0\nvar caml_decompress_input = null\n\n//Provides: caml_decompress_input\n//Version: >= 5.1.0\n//Version: < 5.1.1\n//Requires: zstd_decompress\nvar caml_decompress_input = zstd_decompress;\n\n//Provides: caml_decompress_input\n//Version: >= 5.1.1\n//Version: < 5.2.0\nvar caml_decompress_input = null\n\n//Provides: caml_decompress_input\n//Version: >= 5.2\n//Requires: zstd_decompress\nvar caml_decompress_input = zstd_decompress;\n\n//Provides: caml_zstd_initialize\n//Requires: caml_decompress_input\n//Requires: zstd_decompress\n//Version: >= 5.1.1\nfunction caml_zstd_initialize(unit) {\n  caml_decompress_input = zstd_decompress;\n  return 1\n}\n\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n// Weak API\n\n//Provides: caml_ephe_key_offset\nvar caml_ephe_key_offset = 3\n\n//Provides: caml_ephe_data_offset\nvar caml_ephe_data_offset = 2\n\n//Provides: caml_ephe_set_key\n//Requires: caml_invalid_argument, caml_ephe_key_offset\nfunction caml_ephe_set_key(x, i, v) {\n  if(i < 0 || caml_ephe_key_offset + i >= x.length)\n    caml_invalid_argument (\"Weak.set\");\n  if (v instanceof Object && globalThis.WeakRef) {\n    if(x[1].register) x[1].register(v, undefined, v);\n    x[caml_ephe_key_offset + i] = new globalThis.WeakRef(v);\n  }\n  else x[caml_ephe_key_offset + i] = v;\n  return 0\n}\n\n//Provides: caml_ephe_unset_key\n//Requires: caml_invalid_argument, caml_ephe_key_offset\nfunction caml_ephe_unset_key(x, i) {\n  if(i < 0 || caml_ephe_key_offset + i >= x.length)\n    caml_invalid_argument (\"Weak.set\");\n  if(globalThis.WeakRef && x[caml_ephe_key_offset + i] instanceof globalThis.WeakRef && x[1].unregister) {\n    var old = x[caml_ephe_key_offset + i].deref();\n    if(old !== undefined) {\n      var count = 0\n      for(var j = caml_ephe_key_offset; j < x.length; j++){\n        var key = x[j];\n        if(key instanceof globalThis.WeakRef){\n          key = key.deref()\n          if(key === old) count++;\n        }\n      }\n      if(count == 1) x[1].unregister(old);\n    }\n  }\n  x[caml_ephe_key_offset + i] = undefined;\n  return 0\n}\n\n\n//Provides: caml_ephe_create\n//Requires: caml_weak_create, caml_ephe_data_offset\nfunction caml_ephe_create (n) {\n  var x = caml_weak_create(n);\n  return x;\n}\n\n//Provides: caml_weak_create\n//Requires: caml_ephe_key_offset, caml_invalid_argument,caml_ephe_data_offset\nfunction caml_weak_create (n) {\n  if (n < 0) caml_invalid_argument (\"Weak.create\");\n  var x = [251,\"caml_ephe_list_head\"];\n  x.length = caml_ephe_key_offset + n;\n  return x;\n}\n\n//Provides: caml_weak_set\n//Requires: caml_invalid_argument\n//Requires: caml_ephe_set_key, caml_ephe_unset_key\nfunction caml_weak_set(x, i, v) {\n  if(v == 0) caml_ephe_unset_key(x,i)\n  else caml_ephe_set_key(x,i,v[1])\n  return 0;\n}\n//Provides: caml_ephe_get_key\n//Requires: caml_ephe_key_offset, caml_invalid_argument\n//Alias: caml_weak_get\nfunction caml_ephe_get_key(x, i) {\n  if(i < 0 || caml_ephe_key_offset + i >= x.length)\n    caml_invalid_argument (\"Weak.get_key\");\n  var weak = x[caml_ephe_key_offset + i ];\n  if(globalThis.WeakRef && weak instanceof globalThis.WeakRef) weak = weak.deref();\n  return (weak===undefined)?0:[0, weak];\n}\n//Provides: caml_ephe_get_key_copy\n//Requires: caml_ephe_get_key,caml_ephe_key_offset\n//Requires: caml_obj_dup, caml_invalid_argument\n//Alias: caml_weak_get_copy\nfunction caml_ephe_get_key_copy(x, i) {\n  if(i < 0 || caml_ephe_key_offset + i >= x.length)\n    caml_invalid_argument (\"Weak.get_copy\");\n  var y = caml_ephe_get_key(x, i);\n  if (y === 0) return y;\n  var z = y[1];\n  if (z instanceof Array) return [0, caml_obj_dup(z)];\n  return y;\n}\n\n//Provides: caml_ephe_check_key mutable\n//Requires: caml_ephe_key_offset\n//Alias: caml_weak_check\nfunction caml_ephe_check_key(x, i) {\n  var weak = x[caml_ephe_key_offset + i];\n  if(globalThis.WeakRef && weak instanceof globalThis.WeakRef) weak = weak.deref();\n  if(weak===undefined)\n    return 0;\n  else\n    return 1;\n}\n\n//Provides: caml_ephe_blit_key\n//Requires: caml_array_blit\n//Requires: caml_ephe_key_offset\n//Alias: caml_weak_blit\nfunction caml_ephe_blit_key(a1, i1, a2, i2, len) {\n  // minus one because caml_array_blit works on ocaml array\n  caml_array_blit(a1, caml_ephe_key_offset + i1 - 1,\n                  a2, caml_ephe_key_offset + i2 - 1,\n                  len);\n  return 0;\n}\n\n//Provides: caml_ephe_blit_data\n//Requires: caml_ephe_data_offset, caml_ephe_set_data, caml_ephe_unset_data\nfunction caml_ephe_blit_data(src, dst){\n  var n = src[caml_ephe_data_offset];\n  if(n === undefined) caml_ephe_unset_data(dst);\n  else caml_ephe_set_data(dst, n);\n  return 0;\n}\n\n//Provides: caml_ephe_get_data\n//Requires: caml_ephe_data_offset\nfunction caml_ephe_get_data(x){\n  if(x[caml_ephe_data_offset] === undefined)\n    return 0;\n  else\n    return [0, x[caml_ephe_data_offset]];\n}\n\n//Provides: caml_ephe_get_data_copy\n//Requires: caml_ephe_data_offset\n//Requires: caml_obj_dup\nfunction caml_ephe_get_data_copy(x){\n  if(x[caml_ephe_data_offset] === undefined)\n    return 0;\n  else\n    return [0, caml_obj_dup(x[caml_ephe_data_offset])];\n}\n\n//Provides: caml_ephe_set_data\n//Requires: caml_ephe_data_offset, caml_ephe_key_offset, caml_ephe_unset_data\nfunction caml_ephe_set_data(x, data){\n  if(globalThis.FinalizationRegistry && globalThis.WeakRef) {\n    if(! (x[1] instanceof globalThis.FinalizationRegistry)) {\n      x[1] = new globalThis.FinalizationRegistry(function () { caml_ephe_unset_data(x) });\n      //register all keys\n      for(var j = caml_ephe_key_offset; j < x.length; j++){\n        var key = x[j];\n        if(key instanceof globalThis.WeakRef) {\n          key = key.deref();\n          if(key) x[1].register(key, undefined, key);\n        }\n      }\n    }\n  }\n  x[caml_ephe_data_offset] = data;\n  return 0;\n}\n\n//Provides: caml_ephe_unset_data\n//Requires: caml_ephe_data_offset, caml_ephe_key_offset\nfunction caml_ephe_unset_data(x){\n  if(globalThis.FinalizationRegistry && globalThis.WeakRef) {\n    if(x[1] instanceof globalThis.FinalizationRegistry){\n      //unregister all keys\n      for(var j = caml_ephe_key_offset; j < x.length; j++){\n        var key = x[j];\n        if(key instanceof globalThis.WeakRef) {\n          key = key.deref();\n          if(key) x[1].unregister(key);\n        }\n      }\n    }\n  }\n  x[caml_ephe_data_offset] = undefined;\n  return 0;\n}\n\n//Provides: caml_ephe_check_data\n//Requires: caml_ephe_data_offset\nfunction caml_ephe_check_data(x){\n  if(x[caml_ephe_data_offset] === undefined)\n    return 0;\n  else\n    return 1;\n}\n","\n\n//Provides: caml_gc_minor\nfunction caml_gc_minor(unit){\n  //available with [node --expose-gc]\n  if(typeof globalThis.gc == 'function') globalThis.gc(true);\n  return 0\n}\n//Provides: caml_gc_major\nfunction caml_gc_major(unit){\n  //available with [node --expose-gc]\n  if(typeof globalThis.gc == 'function') globalThis.gc();\n  return 0\n}\n//Provides: caml_gc_full_major\nfunction caml_gc_full_major(unit){\n  //available with [node --expose-gc]\n  if(typeof globalThis.gc == 'function') globalThis.gc();\n  return 0\n}\n//Provides: caml_gc_compaction\nfunction caml_gc_compaction(){ return 0}\n//Provides: caml_gc_counters\nfunction caml_gc_counters() { return [254,0,0,0] }\n//Provides: caml_gc_quick_stat\n//Version: >= 4.12\nfunction caml_gc_quick_stat(){\n  return [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]\n}\n\n//Provides: caml_gc_quick_stat\n//Version: < 4.12\nfunction caml_gc_quick_stat(){\n  return [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]\n}\n//Provides: caml_gc_stat\n//Requires: caml_gc_quick_stat\nfunction caml_gc_stat() {\n  return caml_gc_quick_stat();\n}\n\n//Provides: caml_gc_set\nfunction caml_gc_set(_control) {\n  return 0;\n}\n\n//Provides: caml_gc_get\nfunction caml_gc_get(){\n  return [0,0,0,0,0,0,0,0,0,0,0,0]\n}\n\n//Provides: caml_memprof_set\nfunction caml_memprof_set(_control) {\n  return 0;\n}\n\n//Provides: caml_final_register const\nfunction caml_final_register () { return 0; }\n\n//Provides: caml_final_register_called_without_value\nvar all_finalizers = new globalThis.Set()\nfunction caml_final_register_called_without_value (cb, a) {\n  if(globalThis.FinalizationRegistry && a instanceof Object) {\n    var x = new globalThis.FinalizationRegistry(function (x){all_finalizers.delete(x); cb(0); return;});\n    x.register(a,x);\n    all_finalizers.add(x);\n  }\n  return 0;\n}\n\n//Provides: caml_final_release const\nfunction caml_final_release () { return 0; }\n\n//Provides: caml_memprof_start\nfunction caml_memprof_start(rate,stack_size,tracker){\n  return 0;\n}\n\n//Provides: caml_memprof_stop\nfunction caml_memprof_stop(unit) {\n  return 0;\n}\n\n//Provides: caml_memprof_discard\nfunction caml_memprof_discard(t) { return 0 }\n\n//Provides: caml_eventlog_resume\nfunction caml_eventlog_resume(unit) { return 0; }\n\n//Provides: caml_eventlog_pause\nfunction caml_eventlog_pause(unit) { return 0; }\n\n//Provides: caml_gc_huge_fallback_count\nfunction caml_gc_huge_fallback_count(unit) { return 0; }\n\n//Provides: caml_gc_major_slice\nfunction caml_gc_major_slice(work) { return 0; }\n\n//Provides: caml_gc_minor_words\nfunction caml_gc_minor_words(unit) { return 0; }\n\n//Provides: caml_get_minor_free\nfunction caml_get_minor_free(unit) { return 0; }\n\n//Provides: caml_get_major_bucket\nfunction caml_get_major_bucket(n) { return 0; }\n\n//Provides: caml_get_major_credit\nfunction caml_get_major_credit(n) { return 0; }\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Format\n\n//Provides: caml_parse_format\n//Requires: caml_jsbytes_of_string, caml_invalid_argument\nfunction caml_parse_format (fmt) {\n  fmt = caml_jsbytes_of_string(fmt);\n  var len = fmt.length;\n  if (len > 31) caml_invalid_argument(\"format_int: format too long\");\n  var f =\n      { justify:'+', signstyle:'-', filler:' ', alternate:false,\n        base:0, signedconv:false, width:0, uppercase:false,\n        sign:1, prec:-1, conv:'f' };\n  for (var i = 0; i < len; i++) {\n    var c = fmt.charAt(i);\n    switch (c) {\n    case '-':\n      f.justify = '-'; break;\n    case '+': case ' ':\n      f.signstyle = c; break;\n    case '0':\n      f.filler = '0'; break;\n    case '#':\n      f.alternate = true; break;\n    case '1': case '2': case '3': case '4': case '5':\n    case '6': case '7': case '8': case '9':\n      f.width = 0;\n      while (c=fmt.charCodeAt(i) - 48, c >= 0 && c <= 9) {\n        f.width = f.width * 10 + c; i++\n      }\n      i--;\n      break;\n    case '.':\n      f.prec = 0;\n      i++;\n      while (c=fmt.charCodeAt(i) - 48, c >= 0 && c <= 9) {\n        f.prec = f.prec * 10 + c; i++\n      }\n      i--;\n    case 'd': case 'i':\n      f.signedconv = true; /* fallthrough */\n    case 'u':\n      f.base = 10; break;\n    case 'x':\n      f.base = 16; break;\n    case 'X':\n      f.base = 16; f.uppercase = true; break;\n    case 'o':\n      f.base = 8; break;\n    case 'e': case 'f': case 'g':\n      f.signedconv = true; f.conv = c; break;\n    case 'E': case 'F': case 'G':\n      f.signedconv = true; f.uppercase = true;\n      f.conv = c.toLowerCase (); break;\n    }\n  }\n  return f;\n}\n\n//Provides: caml_finish_formatting\n//Requires: caml_string_of_jsbytes\nfunction caml_finish_formatting(f, rawbuffer) {\n  if (f.uppercase) rawbuffer = rawbuffer.toUpperCase();\n  var len = rawbuffer.length;\n  /* Adjust len to reflect additional chars (sign, etc) */\n  if (f.signedconv && (f.sign < 0 || f.signstyle != '-')) len++;\n  if (f.alternate) {\n    if (f.base == 8) len += 1;\n    if (f.base == 16) len += 2;\n  }\n  /* Do the formatting */\n  var buffer = \"\";\n  if (f.justify == '+' && f.filler == ' ')\n    for (var i = len; i < f.width; i++) buffer += ' ';\n  if (f.signedconv) {\n    if (f.sign < 0) buffer += '-';\n    else if (f.signstyle != '-') buffer += f.signstyle;\n  }\n  if (f.alternate && f.base == 8) buffer += '0';\n  if (f.alternate && f.base == 16) buffer += f.uppercase?\"0X\":\"0x\";\n  if (f.justify == '+' && f.filler == '0')\n    for (var i = len; i < f.width; i++) buffer += '0';\n  buffer += rawbuffer;\n  if (f.justify == '-')\n    for (var i = len; i < f.width; i++) buffer += ' ';\n  return caml_string_of_jsbytes(buffer);\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Hugo Heuzard\n\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_gr_state\nvar caml_gr_state;\n\n//Provides: caml_gr_state_get\n//Requires: caml_gr_state\n//Requires: caml_named_value, caml_string_of_jsbytes\n//Requires: caml_maybe_attach_backtrace\nfunction caml_gr_state_get() {\n  if(caml_gr_state) {\n    return caml_gr_state;\n  }\n  throw caml_maybe_attach_backtrace([0,caml_named_value(\"Graphics.Graphic_failure\"), caml_string_of_jsbytes(\"Not initialized\")]);\n}\n//Provides: caml_gr_state_set\n//Requires: caml_gr_state,caml_gr_state_init\nfunction caml_gr_state_set(ctx) {\n  caml_gr_state=ctx;\n  caml_gr_state_init()\n  return 0;\n}\n\n//Provides: caml_gr_open_graph\n//Requires: caml_gr_state_create\n//Requires: caml_gr_state_set\n//Requires: caml_failwith\n//Requires: caml_jsstring_of_string\nfunction caml_gr_open_graph(info){\n  var info = caml_jsstring_of_string(info);\n  function get(name){\n    var res = info.match(\"(^|,) *\"+name+\" *= *([a-zA-Z0-9_]+) *(,|$)\");\n    if(res) return res[2];\n  }\n  var specs = [];\n  if(!(info==\"\")) specs.push(info);\n  var target = get(\"target\");\n  if(!target) target=\"\";\n  var status = get(\"status\");\n  if(!status) specs.push(\"status=1\")\n\n  var w = get(\"width\");\n  w = w?parseInt(w):200;\n  specs.push(\"width=\"+w);\n\n  var h = get(\"height\");\n  h = h?parseInt(h):200;\n  specs.push(\"height=\"+h);\n\n  var win = globalThis.open(\"about:blank\",target,specs.join(\",\"));\n  if(!win) {caml_failwith(\"Graphics.open_graph: cannot open the window\")}\n  var doc = win.document;\n  var canvas = doc.createElement(\"canvas\");\n  canvas.width = w;\n  canvas.height = h;\n  var ctx = caml_gr_state_create(canvas,w,h);\n  ctx.set_title = function (title) {\n    doc.title = title;\n  };\n  caml_gr_state_set(ctx);\n  var body = doc.body;\n  body.style.margin = \"0px\";\n  body.appendChild(canvas);\n  return 0;\n}\n\n//Provides: caml_gr_state_init\n//Requires: caml_gr_state\n//Requires: caml_gr_set_color,caml_gr_moveto,caml_gr_resize_window\n//Requires: caml_gr_set_line_width,caml_gr_set_text_size,caml_gr_set_font\n//Requires: caml_gr_set_window_title\nfunction caml_gr_state_init(){\n  caml_gr_moveto(caml_gr_state.x,caml_gr_state.y);\n  caml_gr_resize_window(caml_gr_state.width,caml_gr_state.height);\n  caml_gr_set_line_width(caml_gr_state.line_width);\n  caml_gr_set_text_size(caml_gr_state.text_size);\n  caml_gr_set_font(caml_gr_state.font);\n  caml_gr_set_color(caml_gr_state.color);\n  caml_gr_set_window_title(caml_gr_state.title);\n  //caml_gr_resize_window might reset some canvas' properties\n  caml_gr_state.context.textBaseline = 'bottom';\n}\n\n//Provides: caml_gr_state_create\n//Requires: caml_string_of_jsbytes\nfunction caml_gr_state_create(canvas,w,h){\n  var context = canvas.getContext(\"2d\");\n  return {\n    context: context,\n    canvas : canvas,\n    x : 0,\n    y : 0,\n    width : w,\n    height : h,\n    line_width : 1,\n    font : caml_string_of_jsbytes(\"fixed\"),\n    text_size : 26,\n    color : 0x000000,\n    title : caml_string_of_jsbytes(\"\")\n  };\n}\n\n//Provides: caml_gr_doc_of_state\nfunction caml_gr_doc_of_state(state) {\n  if(state.canvas.ownerDocument)\n    return state.canvas.ownerDocument;\n}\n\n//Provides: caml_gr_close_graph\n//Requires: caml_gr_state_get\nfunction caml_gr_close_graph(){\n  var s = caml_gr_state_get();\n  s.canvas.width = 0;\n  s.canvas.height = 0;\n  return 0;\n}\n\n//Provides: caml_gr_set_window_title\n//Requires: caml_gr_state_get\n//Requires: caml_jsstring_of_string\nfunction caml_gr_set_window_title(name){\n  var s = caml_gr_state_get();\n  s.title = name;\n  var jsname = caml_jsstring_of_string(name);\n  if(s.set_title) s.set_title(jsname);\n  return 0;\n}\n\n//Provides: caml_gr_resize_window\n//Requires: caml_gr_state_get\nfunction caml_gr_resize_window(w,h){\n  var s = caml_gr_state_get()\n  s.width = w;\n  s.height = h;\n  s.canvas.width = w;\n  s.canvas.height = h;\n  return 0;\n}\n\n//Provides: caml_gr_clear_graph\n//Requires: caml_gr_state_get\nfunction caml_gr_clear_graph(){\n  var s = caml_gr_state_get();\n  s.canvas.width = s.width;\n  s.canvas.height = s.height;\n  //  s.context.strokeRect (0., 0., s.width, s.height);\n  return 0;\n}\n\n//Provides: caml_gr_size_x\n//Requires: caml_gr_state_get\nfunction caml_gr_size_x(){\n  var s = caml_gr_state_get();\n  return s.width;\n}\n//Provides: caml_gr_size_y\n//Requires: caml_gr_state_get\nfunction caml_gr_size_y(){\n  var s = caml_gr_state_get();\n  return s.height;\n}\n\n\n//Provides: caml_gr_set_color\n//Requires: caml_gr_state_get\nfunction caml_gr_set_color(color){\n  var s = caml_gr_state_get();\n  function convert(number) {\n    var str = '' + number.toString(16);\n    while (str.length < 2) str = '0' + str;\n    return str;\n  }\n  var\n  r = (color >> 16) & 0xff,\n  g = (color >> 8)  & 0xff,\n  b = (color >> 0)  & 0xff;\n  s.color=color;\n  var c_str = '#' + convert(r) + convert(g) + convert(b);\n  s.context.fillStyle =   c_str;\n  s.context.strokeStyle = c_str;\n  return 0;\n}\n//Provides: caml_gr_plot\n//Requires: caml_gr_state_get\nfunction caml_gr_plot(x,y){\n  var s = caml_gr_state_get();\n  var im=s.context.createImageData(1,1);\n  var d = im.data;\n  var color = s.color;\n  d[0] = (color >> 16) & 0xff; //r\n  d[1] = (color >> 8)  & 0xff, //g\n  d[2] = (color >> 0)  & 0xff; //b\n  d[3] = 0xFF; //a\n  s.x=x;\n  s.y=y;\n  s.context.putImageData(im,x,s.height - y);\n  return 0;\n}\n\n//Provides: caml_gr_point_color\n//Requires: caml_gr_state_get\nfunction caml_gr_point_color(x,y){\n  var s = caml_gr_state_get();\n  var im=s.context.getImageData(x,s.height - y,1,1);\n  var d = im.data;\n  return (d[0] << 16) + (d[1] << 8) + d[2];\n}\n//Provides: caml_gr_moveto\n//Requires: caml_gr_state_get\nfunction caml_gr_moveto(x,y){\n  var s = caml_gr_state_get();\n  s.x=x;\n  s.y=y;\n  return 0;\n}\n\n//Provides: caml_gr_current_x\n//Requires: caml_gr_state_get\nfunction caml_gr_current_x(){\n  var s = caml_gr_state_get();\n  return s.x\n}\n//Provides: caml_gr_current_y\n//Requires: caml_gr_state_get\nfunction caml_gr_current_y(){\n  var s = caml_gr_state_get();\n  return s.y\n}\n//Provides: caml_gr_lineto\n//Requires: caml_gr_state_get\nfunction caml_gr_lineto(x,y){\n  var s = caml_gr_state_get();\n  s.context.beginPath();\n  s.context.moveTo(s.x,s.height - s.y);\n  s.context.lineTo(x,s.height - y);\n  s.context.stroke();\n  s.x=x;\n  s.y=y;\n  return 0;\n}\n//Provides: caml_gr_draw_rect\n//Requires: caml_gr_state_get\nfunction caml_gr_draw_rect(x,y,w,h){\n  var s = caml_gr_state_get();\n  s.context.strokeRect(x,s.height - y,w,-h);\n  return 0;\n}\n\n//Provides: caml_gr_arc_aux\nfunction caml_gr_arc_aux(ctx,cx,cy,ry,rx,a1,a2){\n  while(a1>a2) a2+=360;\n  a1 /= 180;\n  a2 /= 180;\n  var rot = 0,xPos,yPos,xPos_prev,yPos_prev;\n  var space = 2;\n  var num = (((a2 - a1) * Math.PI * ((rx+ry)/2)) / space) | 0;\n  var delta = (a2 - a1) * Math.PI / num;\n  var i = a1 * Math.PI;\n  for (var j=0;j<=num;j++){\n    xPos = cx - (rx * Math.sin(i)) * Math.sin(rot * Math.PI) + (ry * Math.cos(i)) * Math.cos(rot * Math.PI);\n    xPos = xPos.toFixed(2);\n    yPos = cy + (ry * Math.cos(i)) * Math.sin(rot * Math.PI) + (rx * Math.sin(i)) * Math.cos(rot * Math.PI);\n    yPos = yPos.toFixed(2);\n    if (j==0) {\n      ctx.moveTo(xPos, yPos);\n    } else if (xPos_prev!=xPos || yPos_prev!=yPos){\n      ctx.lineTo(xPos, yPos);\n    }\n    xPos_prev=xPos;\n    yPos_prev=yPos;\n    i-= delta;//ccw\n  }\n  return 0;\n}\n\n\n//Provides: caml_gr_draw_arc\n//Requires: caml_gr_state_get, caml_gr_arc_aux\nfunction caml_gr_draw_arc(x,y,rx,ry,a1,a2){\n  var s = caml_gr_state_get();\n  s.context.beginPath();\n  caml_gr_arc_aux(s.context,x,s.height - y,rx,ry,a1,a2);\n  s.context.stroke();\n  return 0;\n}\n\n//Provides: caml_gr_set_line_width\n//Requires: caml_gr_state_get\nfunction caml_gr_set_line_width(w){\n  var s = caml_gr_state_get();\n  s.line_width = w;\n  s.context.lineWidth = w\n  return 0;\n}\n\n//Provides: caml_gr_fill_rect\n//Requires: caml_gr_state_get\nfunction caml_gr_fill_rect(x,y,w,h){\n  var s = caml_gr_state_get();\n  s.context.fillRect(x,s.height - y,w,-h);\n  return 0;\n}\n//Provides: caml_gr_fill_poly\n//Requires: caml_gr_state_get\nfunction caml_gr_fill_poly(ar){\n  var s = caml_gr_state_get();\n  s.context.beginPath();\n  s.context.moveTo(ar[1][1],s.height - ar[1][2]);\n  for(var i = 2; i < ar.length; i++)\n    s.context.lineTo(ar[i][1],s.height - ar[i][2]);\n  s.context.lineTo(ar[1][1],s.height - ar[1][2]);\n  s.context.fill();\n  return 0;\n}\n\n//Provides: caml_gr_fill_arc\n//Requires: caml_gr_state_get, caml_gr_arc_aux\nfunction caml_gr_fill_arc(x,y,rx,ry,a1,a2){\n  var s = caml_gr_state_get();\n  s.context.beginPath();\n  caml_gr_arc_aux(s.context,x,s.height - y,rx,ry,a1,a2);\n  s.context.fill();\n  return 0;\n}\n\n//Provides: caml_gr_draw_str\n//Requires: caml_gr_state_get\nfunction caml_gr_draw_str(str){\n  var s = caml_gr_state_get();\n  var m = s.context.measureText(str);\n  var dx = m.width;\n  s.context.fillText(str,s.x,s.height - s.y);\n  s.x += dx | 0;\n  return 0;\n}\n\n//Provides: caml_gr_draw_char\n//Requires: caml_gr_draw_str\nfunction caml_gr_draw_char(c){\n  caml_gr_draw_str(String.fromCharCode(c));\n  return 0;\n}\n\n//Provides: caml_gr_draw_string\n//Requires: caml_gr_draw_str\n//Requires: caml_jsstring_of_string\nfunction caml_gr_draw_string(str){\n  caml_gr_draw_str(caml_jsstring_of_string(str));\n  return 0;\n}\n\n//Provides: caml_gr_set_font\n//Requires: caml_gr_state_get\n//Requires: caml_jsstring_of_string\nfunction caml_gr_set_font(f){\n  var s = caml_gr_state_get();\n  s.font = f;\n  s.context.font = s.text_size + \"px \" + caml_jsstring_of_string(s.font);\n  return 0;\n}\n\n//Provides: caml_gr_set_text_size\n//Requires: caml_gr_state_get\n//Requires: caml_jsstring_of_string\nfunction caml_gr_set_text_size(size){\n  var s = caml_gr_state_get();\n  s.text_size = size;\n  s.context.font = s.text_size + \"px \" + caml_jsstring_of_string(s.font);\n  return 0;\n}\n\n//Provides: caml_gr_text_size\n//Requires: caml_gr_state_get\n//Requires: caml_jsstring_of_string\nfunction caml_gr_text_size(txt){\n  var s = caml_gr_state_get();\n  var w = s.context.measureText(caml_jsstring_of_string(txt)).width;\n  return [0,w,s.text_size];\n}\n\n\n//Provides: caml_gr_make_image\n//Requires: caml_gr_state_get\nfunction caml_gr_make_image(arr){\n  var s = caml_gr_state_get();\n  var h = arr.length - 1 ;\n  var w = arr[1].length - 1;\n  var im = s.context.createImageData(w,h);\n  for(var i=0;i<h;i++){\n    for(var j=0;j<w;j++){\n      var c = arr[i+1][j+1];\n      var o = i*(w*4) + (j * 4);\n      if(c == -1) {\n        im.data[o + 0] = 0;\n        im.data[o + 1] = 0;\n        im.data[o + 2] = 0;\n        im.data[o + 3] = 0;\n      } else {\n        im.data[o + 0] = c >> 16 & 0xff;\n        im.data[o + 1] = c >>  8 & 0xff;\n        im.data[o + 2] = c >>  0 & 0Xff;\n        im.data[o + 3] = 0xff;\n      }\n    }\n  }\n  return im\n}\n//Provides: caml_gr_dump_image\n//Requires: caml_gr_state_get\nfunction caml_gr_dump_image(im){\n  var data = [0]\n  for(var i=0; i<im.height;i++){\n    data[i+1] = [0]\n    for(var j=0; j<im.width;j++){\n      var o = i*(im.width*4) + (j * 4),\n          r = im.data[o+0],\n          g = im.data[o+1],\n          b = im.data[o+2];\n      data[i+1][j+1] = (r << 16) + (g << 8) + b\n    }\n  }\n  return data\n}\n//Provides: caml_gr_draw_image\n//Requires: caml_gr_state_get\nfunction caml_gr_draw_image(im,x,y){\n  var s = caml_gr_state_get();\n  if(!im.image) {\n    var canvas = document.createElement(\"canvas\");\n    canvas.width = s.width;\n    canvas.height = s.height;\n    canvas.getContext(\"2d\").putImageData(im,0,0);\n    var image = new globalThis.Image();\n    image.onload = function () {\n      s.context.drawImage(image,x,s.height - im.height - y);\n      im.image = image;\n    }\n    image.src = canvas.toDataURL(\"image/png\");\n  } else {\n    s.context.drawImage(im.image,x,s.height - im.height - y);\n  }\n  return 0;\n}\n//Provides: caml_gr_create_image\n//Requires: caml_gr_state_get\nfunction caml_gr_create_image(x,y){\n  var s = caml_gr_state_get();\n  return s.context.createImageData(x,y);\n}\n//Provides: caml_gr_blit_image\n//Requires: caml_gr_state_get\nfunction caml_gr_blit_image(im,x,y){\n  var s = caml_gr_state_get();\n  var im2 = s.context.getImageData(x,s.height - im.height - y,im.width,im.height);\n  for (var i = 0; i < im2.data.length; i+=4){\n    im.data[i] = im2.data[i];\n    im.data[i+1] = im2.data[i+1];\n    im.data[i+2] = im2.data[i+2];\n    im.data[i+3] = im2.data[i+3];\n  }\n  return 0;\n}\n//Provides: caml_gr_sigio_handler\nfunction caml_gr_sigio_handler(){return 0}\n//Provides: caml_gr_sigio_signal\nfunction caml_gr_sigio_signal(){return 0}\n//Provides: caml_gr_wait_event\n//Requires: caml_failwith\nfunction caml_gr_wait_event(_evl){\n  caml_failwith(\"caml_gr_wait_event not Implemented: use Graphics_js instead\");\n}\n\n//Provides: caml_gr_synchronize\n//Requires: caml_failwith\nfunction caml_gr_synchronize () {\n  caml_failwith(\"caml_gr_synchronize not Implemented\");\n}\n//Provides: caml_gr_remember_mode\n//Requires: caml_failwith\nfunction caml_gr_remember_mode () {\n  caml_failwith(\"caml_gr_remember_mode not Implemented\");\n}\n//Provides: caml_gr_display_mode\n//Requires: caml_failwith\nfunction caml_gr_display_mode() {\n  caml_failwith(\"caml_gr_display_mode not Implemented\");\n}\n\n//Provides: caml_gr_window_id\n//Requires: caml_failwith\nfunction caml_gr_window_id(a) {\n  caml_failwith(\"caml_gr_window_id not Implemented\");\n}\n\n//Provides: caml_gr_open_subwindow\n//Requires: caml_failwith\nfunction caml_gr_open_subwindow(a,b,c,d) {\n  caml_failwith(\"caml_gr_open_subwindow not Implemented\");\n}\n\n//Provides: caml_gr_close_subwindow\n//Requires: caml_failwith\nfunction caml_gr_close_subwindow(a) {\n  caml_failwith(\"caml_gr_close_subwindow not Implemented\");\n}\n","// Js_of_ocaml library\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Jslib: code specific to Js_of_ocaml\n\n//Provides: caml_js_on_ie const\nfunction caml_js_on_ie () {\n  var ua =\n      (globalThis.navigator&&globalThis.navigator.userAgent)\n      ?globalThis.navigator.userAgent:\"\";\n  return ua.indexOf(\"MSIE\") != -1 && ua.indexOf(\"Opera\") != 0;\n}\n\n//Provides: caml_js_html_escape const (const)\nvar caml_js_regexps = { amp:/&/g, lt:/</g, quot:/\\\"/g, all:/[&<\\\"]/ };\nfunction caml_js_html_escape (s) {\n  if (!caml_js_regexps.all.test(s)) return s;\n  return s.replace(caml_js_regexps.amp, \"&amp;\")\n    .replace(caml_js_regexps.lt, \"&lt;\")\n    .replace(caml_js_regexps.quot, \"&quot;\");\n}\n\n//Provides: caml_js_html_entities\n//Requires: caml_failwith\nfunction caml_js_html_entities(s) {\n  var entity = /^&#?[0-9a-zA-Z]+;$/\n  if(s.match(entity))\n  {\n    var str, temp = document.createElement('p');\n    temp.innerHTML= s;\n    str= temp.textContent || temp.innerText;\n    temp=null;\n    return str;\n  }\n  else {\n    caml_failwith(\"Invalid entity \" + s);\n  }\n}\n\n//Provides: caml_js_get_console const\nfunction caml_js_get_console () {\n  var c = console;\n  var m = [\"log\", \"debug\", \"info\", \"warn\", \"error\", \"assert\", \"dir\", \"dirxml\",\n           \"trace\", \"group\", \"groupCollapsed\", \"groupEnd\", \"time\", \"timeEnd\"];\n  function f () {}\n  for (var i = 0; i < m.length; i++) if (!c[m[i]]) c[m[i]]=f;\n  return c;\n}\n\n//Provides: caml_xmlhttprequest_create\n//Requires: caml_failwith\n//Weakdef\nfunction caml_xmlhttprequest_create(unit){\n  if(typeof globalThis.XMLHttpRequest !== 'undefined') {\n    try { return new globalThis.XMLHttpRequest } catch (e) { };\n  }\n  if(typeof globalThis.activeXObject !== 'undefined') {\n    try { return new globalThis.activeXObject(\"Msxml2.XMLHTTP\") } catch(e){ };\n    try { return new globalThis.activeXObject(\"Msxml3.XMLHTTP\") } catch(e){ };\n    try { return new globalThis.activeXObject(\"Microsoft.XMLHTTP\") } catch(e){ };\n  }\n  caml_failwith(\"Cannot create a XMLHttpRequest\");\n}\n\n//Provides: caml_js_error_of_exception\nfunction caml_js_error_of_exception(exn) {\n  if(exn.js_error) { return exn.js_error; }\n  return null;\n}\n","/***********************************************************************/\n/*                                                                     */\n/*                           Objective Caml                            */\n/*                                                                     */\n/*            Xavier Leroy, projet Cristal, INRIA Rocquencourt         */\n/*                                                                     */\n/*  Copyright 1996 Institut National de Recherche en Informatique et   */\n/*  en Automatique.  All rights reserved.  This file is distributed    */\n/*  under the terms of the GNU Lesser General Public License, with     */\n/*  the special exception on linking described in file ../LICENSE.     */\n/*                                                                     */\n/***********************************************************************/\n\n/* $Id: lexing.c 6045 2004-01-01 16:42:43Z doligez $ */\n\n/* The table-driven automaton for lexers generated by camllex. */\n\n//Provides: caml_lex_array\n//Requires: caml_jsbytes_of_string\nfunction caml_lex_array(s) {\n  s = caml_jsbytes_of_string(s);\n  var l = s.length / 2;\n  var a = new Array(l);\n  for (var i = 0; i < l; i++)\n    a[i] = (s.charCodeAt(2 * i) | (s.charCodeAt(2 * i + 1) << 8)) << 16 >> 16;\n  return a;\n}\n\n//Provides: caml_lex_engine\n//Requires: caml_failwith, caml_lex_array, caml_uint8_array_of_bytes\nfunction caml_lex_engine(tbl, start_state, lexbuf) {\n  var lex_buffer = 2;\n  var lex_buffer_len = 3;\n  var lex_start_pos = 5;\n  var lex_curr_pos = 6;\n  var lex_last_pos = 7;\n  var lex_last_action = 8;\n  var lex_eof_reached = 9;\n  var lex_base = 1;\n  var lex_backtrk = 2;\n  var lex_default = 3;\n  var lex_trans = 4;\n  var lex_check = 5;\n\n  if (!tbl.lex_default) {\n    tbl.lex_base =    caml_lex_array (tbl[lex_base]);\n    tbl.lex_backtrk = caml_lex_array (tbl[lex_backtrk]);\n    tbl.lex_check =   caml_lex_array (tbl[lex_check]);\n    tbl.lex_trans =   caml_lex_array (tbl[lex_trans]);\n    tbl.lex_default = caml_lex_array (tbl[lex_default]);\n  }\n\n  var c, state = start_state;\n\n  var buffer = caml_uint8_array_of_bytes(lexbuf[lex_buffer]);\n\n  if (state >= 0) {\n    /* First entry */\n    lexbuf[lex_last_pos] = lexbuf[lex_start_pos] = lexbuf[lex_curr_pos];\n    lexbuf[lex_last_action] = -1;\n  } else {\n    /* Reentry after refill */\n    state = -state - 1;\n  }\n  for(;;) {\n    /* Lookup base address or action number for current state */\n    var base = tbl.lex_base[state];\n    if (base < 0) return -base-1;\n    /* See if it's a backtrack point */\n    var backtrk = tbl.lex_backtrk[state];\n    if (backtrk >= 0) {\n      lexbuf[lex_last_pos] = lexbuf[lex_curr_pos];\n      lexbuf[lex_last_action] = backtrk;\n    }\n    /* See if we need a refill */\n    if (lexbuf[lex_curr_pos] >= lexbuf[lex_buffer_len]){\n      if (lexbuf[lex_eof_reached] == 0)\n        return -state - 1;\n      else\n        c = 256;\n    }else{\n      /* Read next input char */\n      c = buffer[lexbuf[lex_curr_pos]];\n      lexbuf[lex_curr_pos] ++;\n    }\n    /* Determine next state */\n    if (tbl.lex_check[base + c] == state)\n      state = tbl.lex_trans[base + c];\n    else\n      state = tbl.lex_default[state];\n    /* If no transition on this char, return to last backtrack point */\n    if (state < 0) {\n      lexbuf[lex_curr_pos] = lexbuf[lex_last_pos];\n      if (lexbuf[lex_last_action] == -1)\n        caml_failwith(\"lexing: empty token\");\n      else\n        return lexbuf[lex_last_action];\n    }else{\n      /* Erase the EOF condition only if the EOF pseudo-character was\n         consumed by the automaton (i.e. there was no backtrack above)\n      */\n      if (c == 256) lexbuf[lex_eof_reached] = 0;\n    }\n  }\n}\n\n/***********************************************/\n/* New lexer engine, with memory of positions  */\n/***********************************************/\n\n//Provides: caml_new_lex_engine\n//Requires: caml_failwith, caml_lex_array\n//Requires: caml_jsbytes_of_string, caml_uint8_array_of_bytes\nfunction caml_lex_run_mem(s, i, mem, curr_pos) {\n  for (;;) {\n    var dst = s.charCodeAt(i); i++;\n    if (dst == 0xff) return;\n    var src = s.charCodeAt(i); i++;\n    if (src == 0xff)\n      mem [dst + 1] = curr_pos;\n    else\n      mem [dst + 1] = mem [src + 1];\n  }\n}\n\nfunction caml_lex_run_tag(s, i, mem) {\n  for (;;) {\n    var dst = s.charCodeAt(i); i++;\n    if (dst == 0xff) return ;\n    var src = s.charCodeAt(i); i++;\n    if (src == 0xff)\n      mem [dst + 1] = -1;\n    else\n      mem [dst + 1] = mem [src + 1];\n  }\n}\n\nfunction caml_new_lex_engine(tbl, start_state, lexbuf) {\n  var lex_buffer = 2;\n  var lex_buffer_len = 3;\n  var lex_start_pos = 5;\n  var lex_curr_pos = 6;\n  var lex_last_pos = 7;\n  var lex_last_action = 8;\n  var lex_eof_reached = 9;\n  var lex_mem = 10;\n  var lex_base = 1;\n  var lex_backtrk = 2;\n  var lex_default = 3;\n  var lex_trans = 4;\n  var lex_check = 5;\n  var lex_base_code = 6;\n  var lex_backtrk_code = 7;\n  var lex_default_code = 8;\n  var lex_trans_code = 9;\n  var lex_check_code = 10;\n  var lex_code = 11;\n\n  if (!tbl.lex_default) {\n    tbl.lex_base =    caml_lex_array (tbl[lex_base]);\n    tbl.lex_backtrk = caml_lex_array (tbl[lex_backtrk]);\n    tbl.lex_check =   caml_lex_array (tbl[lex_check]);\n    tbl.lex_trans =   caml_lex_array (tbl[lex_trans]);\n    tbl.lex_default = caml_lex_array (tbl[lex_default]);\n  }\n  if (!tbl.lex_default_code) {\n    tbl.lex_base_code =    caml_lex_array (tbl[lex_base_code]);\n    tbl.lex_backtrk_code = caml_lex_array (tbl[lex_backtrk_code]);\n    tbl.lex_check_code =   caml_lex_array (tbl[lex_check_code]);\n    tbl.lex_trans_code =   caml_lex_array (tbl[lex_trans_code]);\n    tbl.lex_default_code = caml_lex_array (tbl[lex_default_code]);\n  }\n  if (tbl.lex_code == null) tbl.lex_code = caml_jsbytes_of_string(tbl[lex_code]);\n\n  var c, state = start_state;\n\n  var buffer = caml_uint8_array_of_bytes(lexbuf[lex_buffer]);\n\n  if (state >= 0) {\n    /* First entry */\n    lexbuf[lex_last_pos] = lexbuf[lex_start_pos] = lexbuf[lex_curr_pos];\n    lexbuf[lex_last_action] = -1;\n  } else {\n    /* Reentry after refill */\n    state = -state - 1;\n  }\n  for(;;) {\n    /* Lookup base address or action number for current state */\n    var base = tbl.lex_base[state];\n    if (base < 0) {\n      var pc_off = tbl.lex_base_code[state];\n      caml_lex_run_tag(tbl.lex_code, pc_off, lexbuf[lex_mem]);\n      return -base-1;\n    }\n    /* See if it's a backtrack point */\n    var backtrk = tbl.lex_backtrk[state];\n    if (backtrk >= 0) {\n      var pc_off = tbl.lex_backtrk_code[state];\n      caml_lex_run_tag(tbl.lex_code, pc_off, lexbuf[lex_mem]);\n      lexbuf[lex_last_pos] = lexbuf[lex_curr_pos];\n      lexbuf[lex_last_action] = backtrk;\n    }\n    /* See if we need a refill */\n    if (lexbuf[lex_curr_pos] >= lexbuf[lex_buffer_len]){\n      if (lexbuf[lex_eof_reached] == 0)\n        return -state - 1;\n      else\n        c = 256;\n    }else{\n      /* Read next input char */\n      c = buffer[lexbuf[lex_curr_pos]];\n      lexbuf[lex_curr_pos] ++;\n    }\n    /* Determine next state */\n    var pstate = state ;\n    if (tbl.lex_check[base + c] == state)\n      state = tbl.lex_trans[base + c];\n    else\n      state = tbl.lex_default[state];\n    /* If no transition on this char, return to last backtrack point */\n    if (state < 0) {\n      lexbuf[lex_curr_pos] = lexbuf[lex_last_pos];\n      if (lexbuf[lex_last_action] == -1)\n        caml_failwith(\"lexing: empty token\");\n      else\n        return lexbuf[lex_last_action];\n    }else{\n      /* If some transition, get and perform memory moves */\n      var base_code = tbl.lex_base_code[pstate], pc_off;\n      if (tbl.lex_check_code[base_code + c] == pstate)\n        pc_off = tbl.lex_trans_code[base_code + c];\n      else\n        pc_off = tbl.lex_default_code[pstate];\n      if (pc_off > 0)\n        caml_lex_run_mem\n      (tbl.lex_code, pc_off, lexbuf[lex_mem], lexbuf[lex_curr_pos]);\n      /* Erase the EOF condition only if the EOF pseudo-character was\n         consumed by the automaton (i.e. there was no backtrack above)\n      */\n      if (c == 256) lexbuf[lex_eof_reached] = 0;\n    }\n  }\n}\n","\n//Provides: caml_lxm_next\n//Requires: caml_int64_shift_left\n//Requires: caml_int64_shift_right_unsigned\n//Requires: caml_int64_or\n//Requires: caml_int64_xor\n//Requires: caml_int64_add\n//Requires: caml_int64_mul\n//Requires: caml_ba_get_1\n//Requires: caml_ba_set_1\n//Requires: caml_int64_of_string\n//Requires: caml_new_string\nfunction caml_lxm_next(v) {\n  function shift_l(x, k){\n    return caml_int64_shift_left(x,k);\n  }\n  function shift_r(x, k){\n    return caml_int64_shift_right_unsigned(x,k);\n  }\n  function or(a, b){\n    return caml_int64_or(a,b);\n  }\n  function xor(a, b){\n    return caml_int64_xor(a,b);\n  }\n  function add(a, b){\n    return caml_int64_add(a,b);\n  }\n  function mul(a, b){\n    return caml_int64_mul(a,b);\n  }\n  function rotl(x, k) {\n    return or(shift_l(x,k),shift_r (x, 64 - k));\n  }\n  function get(a, i) {\n    return caml_ba_get_1(a, i);\n  }\n  function set(a, i, x) {\n    return caml_ba_set_1(a, i, x);\n  }\n  var M = caml_int64_of_string(caml_new_string(\"0xd1342543de82ef95\"));\n  var daba = caml_int64_of_string(caml_new_string(\"0xdaba0b6eb09322e3\"));\n  var z, q0, q1;\n  var st = v;\n  var a = get(st,0);\n  var s = get(st,1);\n  var x0 = get(st,2);\n  var x1 = get(st,3);\n  /* Combining operation */\n  z = add(s, x0);\n  /* Mixing function */\n  z = mul(xor(z,shift_r(z,32)), daba);\n  z = mul(xor(z,shift_r(z,32)), daba);\n  z = xor(z,shift_r(z,32));\n  /* LCG update */\n  set(st, 1, add (mul(s,M), a));\n  /* XBG update */\n  var q0 = x0\n  var q1 = x1\n  q1 = xor(q1,q0);\n  q0 = rotl(q0, 24);\n  q0 = xor(xor(q0, q1), (shift_l(q1,16)));\n  q1 = rotl(q1, 37);\n  set(st, 2, q0);\n  set(st, 3, q1);\n  /* Return result */\n  return z;\n}\n","/***********************************************************************/\n/*                                                                     */\n/*                           Objective Caml                            */\n/*                                                                     */\n/*            Xavier Leroy, projet Cristal, INRIA Rocquencourt         */\n/*                                                                     */\n/*  Copyright 1996 Institut National de Recherche en Informatique et   */\n/*  en Automatique.  All rights reserved.  This file is distributed    */\n/*  under the terms of the GNU Lesser General Public License, with     */\n/*  the special exception on linking described in file ../LICENSE.     */\n/*                                                                     */\n/***********************************************************************/\n\n/* $Id: parsing.c 8983 2008-08-06 09:38:25Z xleroy $ */\n\n/* The PDA automaton for parsers generated by camlyacc */\n\n/* The pushdown automata */\n\n//Provides: caml_parser_trace\nvar caml_parser_trace = 0;\n\n//Provides: caml_parse_engine\n//Requires: caml_lex_array, caml_parser_trace,caml_jsstring_of_string\n//Requires: caml_ml_output, caml_ml_string_length, caml_string_of_jsbytes\n//Requires: caml_jsbytes_of_string, MlBytes\nfunction caml_parse_engine(tables, env, cmd, arg)\n{\n  var ERRCODE = 256;\n\n  //var START = 0;\n  //var TOKEN_READ = 1;\n  //var STACKS_GROWN_1 = 2;\n  //var STACKS_GROWN_2 = 3;\n  //var SEMANTIC_ACTION_COMPUTED = 4;\n  //var ERROR_DETECTED = 5;\n  var loop = 6;\n  var testshift = 7;\n  var shift = 8;\n  var shift_recover = 9;\n  var reduce = 10;\n\n  var READ_TOKEN = 0;\n  var RAISE_PARSE_ERROR = 1;\n  var GROW_STACKS_1 = 2;\n  var GROW_STACKS_2 = 3;\n  var COMPUTE_SEMANTIC_ACTION = 4;\n  var CALL_ERROR_FUNCTION = 5;\n\n  var env_s_stack = 1;\n  var env_v_stack = 2;\n  var env_symb_start_stack = 3;\n  var env_symb_end_stack = 4;\n  var env_stacksize = 5;\n  var env_stackbase = 6;\n  var env_curr_char = 7;\n  var env_lval = 8;\n  var env_symb_start = 9;\n  var env_symb_end = 10;\n  var env_asp = 11;\n  var env_rule_len = 12;\n  var env_rule_number = 13;\n  var env_sp = 14;\n  var env_state = 15;\n  var env_errflag = 16;\n\n  // var _tbl_actions = 1;\n  var tbl_transl_const = 2;\n  var tbl_transl_block = 3;\n  var tbl_lhs = 4;\n  var tbl_len = 5;\n  var tbl_defred = 6;\n  var tbl_dgoto = 7;\n  var tbl_sindex = 8;\n  var tbl_rindex = 9;\n  var tbl_gindex = 10;\n  var tbl_tablesize = 11;\n  var tbl_table = 12;\n  var tbl_check = 13;\n  // var _tbl_error_function = 14;\n  var tbl_names_const = 15;\n  var tbl_names_block = 16;\n\n\n  function log(x) {\n    var s = caml_string_of_jsbytes(x + \"\\n\");\n    caml_ml_output(2, s, 0, caml_ml_string_length(s));\n  }\n\n  function token_name(names, number)\n  {\n    var str = caml_jsstring_of_string(names);\n    if (str[0] == '\\x00')\n      return \"<unknown token>\";\n    return str.split('\\x00')[number];\n  }\n\n  function print_token(state, tok)\n  {\n    var token, kind;\n    if (tok instanceof Array) {\n      token = token_name(tables[tbl_names_block], tok[0]);\n      if (typeof tok[1] == \"number\")\n        kind = \"\" + tok[1];\n      else if (typeof tok[1] == \"string\")\n        kind = tok[1]\n      else if (tok[1] instanceof MlBytes)\n        kind = caml_jsbytes_of_string(tok[1])\n      else\n        kind = \"_\"\n      log(\"State \" + state + \": read token \" + token + \"(\" + kind + \")\");\n    } else {\n      token = token_name(tables[tbl_names_const], tok);\n      log(\"State \" + state + \": read token \" + token);\n    }\n  }\n\n  if (!tables.dgoto) {\n    tables.defred = caml_lex_array (tables[tbl_defred]);\n    tables.sindex = caml_lex_array (tables[tbl_sindex]);\n    tables.check  = caml_lex_array (tables[tbl_check]);\n    tables.rindex = caml_lex_array (tables[tbl_rindex]);\n    tables.table  = caml_lex_array (tables[tbl_table]);\n    tables.len    = caml_lex_array (tables[tbl_len]);\n    tables.lhs    = caml_lex_array (tables[tbl_lhs]);\n    tables.gindex = caml_lex_array (tables[tbl_gindex]);\n    tables.dgoto  = caml_lex_array (tables[tbl_dgoto]);\n  }\n\n  var res = 0, n, n1, n2, state1;\n\n  // RESTORE\n  var sp = env[env_sp];\n  var state = env[env_state];\n  var errflag = env[env_errflag];\n\n  exit:for (;;) {\n    next:switch(cmd) {\n    case 0://START:\n      state = 0;\n      errflag = 0;\n      // Fall through\n\n    case 6://loop:\n      n = tables.defred[state];\n      if (n != 0) { cmd = reduce; break; }\n      if (env[env_curr_char] >= 0) { cmd = testshift; break; }\n      res = READ_TOKEN;\n      break exit;\n      /* The ML code calls the lexer and updates */\n      /* symb_start and symb_end */\n    case 1://TOKEN_READ:\n      if (arg instanceof Array) {\n        env[env_curr_char] = tables[tbl_transl_block][arg[0] + 1];\n        env[env_lval] = arg[1];\n      } else {\n        env[env_curr_char] = tables[tbl_transl_const][arg + 1];\n        env[env_lval] = 0;\n      }\n      if (caml_parser_trace) print_token (state, arg);\n      // Fall through\n\n    case 7://testshift:\n      n1 = tables.sindex[state];\n      n2 = n1 + env[env_curr_char];\n      if (n1 != 0 && n2 >= 0 && n2 <= tables[tbl_tablesize] &&\n          tables.check[n2] == env[env_curr_char]) {\n        cmd = shift; break;\n      }\n      n1 = tables.rindex[state];\n      n2 = n1 + env[env_curr_char];\n      if (n1 != 0 && n2 >= 0 && n2 <= tables[tbl_tablesize] &&\n          tables.check[n2] == env[env_curr_char]) {\n        n = tables.table[n2];\n        cmd = reduce; break;\n      }\n      if (errflag <= 0) {\n        res = CALL_ERROR_FUNCTION;\n        break exit;\n      }\n      // Fall through\n      /* The ML code calls the error function */\n    case 5://ERROR_DETECTED:\n      if (errflag < 3) {\n        errflag = 3;\n        for (;;) {\n          state1 = env[env_s_stack][sp + 1];\n          n1 = tables.sindex[state1];\n          n2 = n1 + ERRCODE;\n          if (n1 != 0 && n2 >= 0 && n2 <= tables[tbl_tablesize] &&\n              tables.check[n2] == ERRCODE) {\n            if (caml_parser_trace)\n              log(\"Recovering in state \" + state1);\n            cmd = shift_recover; break next;\n          } else {\n            if (caml_parser_trace)\n              log(\"Discarding state \" + state1);\n            if (sp <= env[env_stackbase]) {\n              if (caml_parser_trace)\n                log(\"No more states to discard\");\n              return RAISE_PARSE_ERROR;\n            }\n            /* The ML code raises Parse_error */\n            sp--;\n          }\n        }\n      } else {\n        if (env[env_curr_char] == 0)\n          return RAISE_PARSE_ERROR; /* The ML code raises Parse_error */\n        if (caml_parser_trace)\n          log(\"Discarding last token read\");\n        env[env_curr_char] = -1;\n        cmd = loop; break;\n      }\n      // Fall through\n    case 8://shift:\n      env[env_curr_char] = -1;\n      if (errflag > 0) errflag--;\n      // Fall through\n    case 9://shift_recover:\n      if (caml_parser_trace)\n        log(\"State \" + state + \": shift to state \" + tables.table[n2]);\n      state = tables.table[n2];\n      sp++;\n      if (sp >= env[env_stacksize]) {\n        res = GROW_STACKS_1;\n        break exit;\n      }\n      // Fall through\n      /* The ML code resizes the stacks */\n    case 2://STACKS_GROWN_1:\n      env[env_s_stack][sp + 1] = state;\n      env[env_v_stack][sp + 1] = env[env_lval];\n      env[env_symb_start_stack][sp + 1] = env[env_symb_start];\n      env[env_symb_end_stack][sp + 1] = env[env_symb_end];\n      cmd = loop;\n      break;\n\n    case 10://reduce:\n      if (caml_parser_trace)\n        log(\"State \" + state + \": reduce by rule \" + n);\n      var m = tables.len[n];\n      env[env_asp] = sp;\n      env[env_rule_number] = n;\n      env[env_rule_len] = m;\n      sp = sp - m + 1;\n      m = tables.lhs[n];\n      state1 = env[env_s_stack][sp];\n      n1 = tables.gindex[m];\n      n2 = n1 + state1;\n      if (n1 != 0 && n2 >= 0 && n2 <= tables[tbl_tablesize] &&\n          tables.check[n2] == state1)\n        state = tables.table[n2];\n      else\n        state = tables.dgoto[m];\n      if (sp >= env[env_stacksize]) {\n        res = GROW_STACKS_2;\n        break exit;\n      }\n      // Fall through\n      /* The ML code resizes the stacks */\n    case 3://STACKS_GROWN_2:\n      res = COMPUTE_SEMANTIC_ACTION;\n      break exit;\n      /* The ML code calls the semantic action */\n    case 4://SEMANTIC_ACTION_COMPUTED:\n      env[env_s_stack][sp + 1] = state;\n      env[env_v_stack][sp + 1] = arg;\n      var asp = env[env_asp];\n      env[env_symb_end_stack][sp + 1] = env[env_symb_end_stack][asp + 1];\n      if (sp > asp) {\n        /* This is an epsilon production. Take symb_start equal to symb_end. */\n        env[env_symb_start_stack][sp + 1] = env[env_symb_end_stack][asp + 1];\n      }\n      cmd = loop; break;\n      /* Should not happen */\n    default:\n      return RAISE_PARSE_ERROR;\n    }\n  }\n  // SAVE\n  env[env_sp] = sp;\n  env[env_state] = state;\n  env[env_errflag] = errflag;\n  return res;\n}\n\n//Provides: caml_set_parser_trace\n//Requires: caml_parser_trace\nfunction caml_set_parser_trace(bool) {\n  var oldflag = caml_parser_trace;\n  caml_parser_trace = bool;\n  return oldflag;\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2020 - Hugo Heuzard\n// Copyright (C) 2020 - Shachar Itzhaky\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n// Based on https://github.com/ocaml/ocaml/blob/4.07/otherlibs/str/strstubs.c\n// Copied from https://github.com/jscoq/jscoq/blob/v8.11/coq-js/js_stub/str.js\n\n//Provides: re_match\n//Requires: caml_jsbytes_of_string, caml_js_from_array, caml_uint8_array_of_string\n//Requires: caml_string_get\n\nvar re_match = function(){\n  var re_word_letters = [\n    0x00, 0x00, 0x00, 0x00,       /* 0x00-0x1F: none */\n    0x00, 0x00, 0xFF, 0x03,       /* 0x20-0x3F: digits 0-9 */\n    0xFE, 0xFF, 0xFF, 0x87,       /* 0x40-0x5F: A to Z, _ */\n    0xFE, 0xFF, 0xFF, 0x07,       /* 0x60-0x7F: a to z */\n    0x00, 0x00, 0x00, 0x00,       /* 0x80-0x9F: none */\n    0x00, 0x00, 0x00, 0x00,       /* 0xA0-0xBF: none */\n    0xFF, 0xFF, 0x7F, 0xFF,       /* 0xC0-0xDF: Latin-1 accented uppercase */\n    0xFF, 0xFF, 0x7F, 0xFF        /* 0xE0-0xFF: Latin-1 accented lowercase */\n  ];\n\n  var opcodes = {\n    CHAR: 0, CHARNORM: 1, STRING: 2, STRINGNORM: 3, CHARCLASS: 4,\n    BOL: 5, EOL: 6, WORDBOUNDARY: 7,\n    BEGGROUP: 8, ENDGROUP: 9, REFGROUP: 10,\n    ACCEPT: 11,\n    SIMPLEOPT: 12, SIMPLESTAR: 13, SIMPLEPLUS: 14,\n    GOTO: 15, PUSHBACK: 16, SETMARK: 17,\n    CHECKPROGRESS: 18\n  };\n\n  function is_word_letter(c) {\n    return (re_word_letters[  (c >> 3)] >> (c & 7)) & 1;\n  }\n\n  function in_bitset(s,i) {\n    return (caml_string_get(s,(i >> 3)) >> (i & 7)) & 1;\n  }\n\n  function re_match_impl(re, s, pos, partial) {\n\n    var prog          = caml_js_from_array(re[1]),\n        cpool         = caml_js_from_array(re[2]),\n        normtable     = caml_jsbytes_of_string(re[3]),\n        numgroups     = re[4] | 0,\n        numregisters  = re[5] | 0,\n        startchars    = re[6] | 0;\n\n    var s = caml_uint8_array_of_string(s);\n\n    var pc = 0,\n        quit = false,\n        stack = [],\n        groups = new Array(numgroups),\n        re_register = new Array(numregisters);\n\n    for(var i = 0; i < groups.length; i++){\n      groups[i] = {start: -1, end:-1}\n    }\n    groups[0].start = pos;\n\n    var backtrack = function () {\n      while (stack.length) {\n        var item = stack.pop();\n        if (item.undo) {\n          item.undo.obj[item.undo.prop] = item.undo.value;\n        }\n        else if(item.pos) {\n          pc = item.pos.pc;\n          pos = item.pos.txt;\n          return;\n        }\n      }\n      quit = true;\n    };\n\n    var push = function(item) { stack.push(item); };\n\n    var accept = function () {\n      groups[0].end = pos;\n      var result = new Array(1 + groups.length*2);\n      result[0] = 0; // tag\n      for(var i = 0; i < groups.length; i++){\n        var g = groups[i];\n        if(g.start < 0 || g.end < 0) {\n          g.start = g.end = -1;\n        }\n        result[2*i + 1 ] = g.start;\n        result[2*i + 1 + 1 ] = g.end;\n      };\n      return result\n    };\n\n    var prefix_match = function () {\n      if(partial) return accept ();\n      else backtrack ();\n    }\n\n    /* Main DFA interpreter loop */\n    while (!quit) {\n      var op = prog[pc] & 0xff,\n          sarg = prog[pc] >> 8,\n          uarg = sarg & 0xff,\n          c = s[pos],\n          group;\n\n      pc++;\n\n      switch (op) {\n      case opcodes.CHAR:\n        if(pos === s.length) {prefix_match (); break};\n        if (c === uarg) pos++;\n        else backtrack();\n        break;\n      case opcodes.CHARNORM:\n        if(pos === s.length) {prefix_match (); break};\n        if (normtable.charCodeAt(c) === uarg) pos++;\n        else backtrack();\n        break;\n      case opcodes.STRING:\n        for (var arg = caml_jsbytes_of_string(cpool[uarg]), i = 0; i < arg.length; i++) {\n          if(pos === s.length) {prefix_match (); break};\n          if (c === arg.charCodeAt(i))\n            c = s[++pos];\n          else { backtrack(); break; }\n        }\n        break;\n      case opcodes.STRINGNORM:\n        for (var arg = caml_jsbytes_of_string(cpool[uarg]), i = 0; i < arg.length; i++) {\n          if(pos === s.length) {prefix_match (); break};\n          if (normtable.charCodeAt(c) === arg.charCodeAt(i))\n            c = s[++pos];\n          else { backtrack(); break; }\n        }\n        break;\n      case opcodes.CHARCLASS:\n        if(pos === s.length) {prefix_match (); break};\n        if (in_bitset(cpool[uarg], c)) pos++;\n        else backtrack();\n        break;\n      case opcodes.BOL:\n        if(pos > 0 && s[pos - 1] != 10 /* \\n */) {backtrack()}\n        break;\n      case opcodes.EOL:\n        if(pos < s.length && s[pos] != 10 /* \\n */) {backtrack()}\n        break;\n      case opcodes.WORDBOUNDARY:\n        if(pos == 0) {\n          if(pos === s.length) {prefix_match (); break};\n          if(is_word_letter(s[0])) break;\n          backtrack();\n        }\n        else if (pos === s.length) {\n          if(is_word_letter(s[pos - 1])) break;\n          backtrack ();\n        }\n        else {\n          if(is_word_letter(s[pos - 1]) != is_word_letter(s[pos])) break;\n          backtrack ();\n        }\n        break;\n      case opcodes.BEGGROUP:\n        group = groups[uarg];\n        push({undo: {obj:group,\n                     prop:'start',\n                     value: group.start}});\n        group.start = pos;\n        break;\n      case opcodes.ENDGROUP:\n        group = groups[uarg];\n        push({undo: {obj: group,\n                     prop:'end',\n                     value: group.end}});\n        group.end = pos;\n        break;\n      case opcodes.REFGROUP:\n        group = groups[uarg];\n        if(group.start < 0 || group.end < 0) {backtrack (); break}\n        for (var i = group.start; i < group.end; i++){\n          if(pos === s.length) {prefix_match (); break};\n          if(s[i] != s[pos]) {backtrack (); break}\n          pos++;\n        }\n        break;\n      case opcodes.SIMPLEOPT:\n        if (in_bitset(cpool[uarg], c)) pos++;\n        break;\n      case opcodes.SIMPLESTAR:\n        while (in_bitset(cpool[uarg], c))\n          c = s[++pos];\n        break;\n      case opcodes.SIMPLEPLUS:\n        if(pos === s.length) {prefix_match (); break};\n        if (in_bitset(cpool[uarg], c)) {\n          do {\n            c = s[++pos];\n          } while (in_bitset(cpool[uarg], c));\n        }\n        else backtrack();\n        break;\n      case opcodes.ACCEPT:\n        return accept();\n      case opcodes.GOTO:\n        pc = pc + sarg;\n        break;\n      case opcodes.PUSHBACK:\n        push({pos: {pc: pc + sarg, txt: pos}});\n        break;\n      case opcodes.SETMARK:\n        push({undo: {obj:re_register,\n                     prop: uarg,\n                     value: re_register[uarg]}});\n        re_register[uarg] = pos;\n        break;\n      case opcodes.CHECKPROGRESS:\n        if (re_register[uarg] === pos) backtrack();\n        break;\n      default: throw new Error(\"Invalid bytecode\");\n      }\n    }\n    return 0;\n  }\n\n  return re_match_impl;\n}();\n\n\n//Provides: re_search_forward\n//Requires: re_match, caml_ml_string_length, caml_invalid_argument\nfunction re_search_forward(re, s, pos) {\n  if(pos < 0 || pos > caml_ml_string_length(s))\n    caml_invalid_argument(\"Str.search_forward\")\n  while (pos <= caml_ml_string_length(s)) {\n    var res = re_match(re, s, pos, 0);\n    if (res) return res;\n    pos++;\n  }\n\n  return [0];  /* [||] : int array */\n}\n\n//Provides: re_search_backward\n//Requires: re_match, caml_ml_string_length, caml_invalid_argument\nfunction re_search_backward(re, s, pos) {\n  if(pos < 0 || pos > caml_ml_string_length(s))\n    caml_invalid_argument(\"Str.search_backward\")\n  while (pos >= 0) {\n    var res = re_match(re, s, pos, 0);\n    if (res) return res;\n    pos--;\n  }\n\n  return [0];  /* [||] : int array */\n}\n\n\n//Provides: re_string_match\n//Requires: re_match, caml_ml_string_length, caml_invalid_argument\nfunction re_string_match(re,s,pos){\n  if(pos < 0 || pos > caml_ml_string_length(s))\n    caml_invalid_argument(\"Str.string_match\")\n  var res = re_match(re, s, pos, 0);\n  if (res) return res;\n  else return [0];\n}\n\n//Provides: re_partial_match\n//Requires: re_match, caml_ml_string_length, caml_invalid_argument\nfunction re_partial_match(re,s,pos){\n  if(pos < 0 || pos > caml_ml_string_length(s))\n    caml_invalid_argument(\"Str.partial_match\")\n  var res = re_match(re, s, pos, 1);\n  if (res) return res;\n  else return [0];\n}\n\n//Provides: re_replacement_text\n//Requires: caml_jsbytes_of_string, caml_string_of_jsbytes\n//Requires: caml_array_get\n//Requires: caml_failwith\n// external re_replacement_text: string -> int array -> string -> string\nfunction re_replacement_text(repl,groups,orig) {\n  var repl = caml_jsbytes_of_string(repl);\n  var len = repl.length;\n  var orig = caml_jsbytes_of_string(orig);\n  var res = \"\"; //result\n  var n = 0; // current position\n  var cur; //current char\n  var start, end, c;\n  while(n < len){\n    cur = repl.charAt(n++);\n    if(cur != '\\\\'){\n      res += cur;\n    }\n    else {\n      if(n == len) caml_failwith(\"Str.replace: illegal backslash sequence\");\n      cur = repl.charAt(n++);\n      switch(cur){\n      case '\\\\':\n        res += cur;\n        break;\n      case '0': case '1': case '2': case '3': case '4':\n      case '5': case '6': case '7': case '8': case '9':\n        c = +cur;\n        if (c*2 >= groups.length - 1 )\n          caml_failwith(\"Str.replace: reference to unmatched group\" );\n        start = caml_array_get(groups,c*2);\n        end = caml_array_get(groups, c*2 +1);\n        if (start == -1)\n          caml_failwith(\"Str.replace: reference to unmatched group\");\n        res+=orig.slice(start,end);\n        break;\n      default:\n        res += ('\\\\'  + cur);\n      }\n    }\n  }\n  return caml_string_of_jsbytes(res); }\n\n\n//Provides: caml_str_initialize\nfunction caml_str_initialize(unit) {\n  return 0;\n}\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*                          Benoit Vaugon, ENSTA                          *)\n(*                                                                        *)\n(*   Copyright 2014 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Padding position. *)\ntype padty =\n  | Left   (* Text is left justified ('-' option).               *)\n  | Right  (* Text is right justified (no '-' option).           *)\n  | Zeros  (* Text is right justified by zeros (see '0' option). *)\n\n(***)\n\n(* Integer conversion. *)\ntype int_conv =\n  | Int_d | Int_pd | Int_sd        (*  %d | %+d | % d  *)\n  | Int_i | Int_pi | Int_si        (*  %i | %+i | % i  *)\n  | Int_x | Int_Cx                 (*  %x | %#x        *)\n  | Int_X | Int_CX                 (*  %X | %#X        *)\n  | Int_o | Int_Co                 (*  %o | %#o        *)\n  | Int_u                          (*  %u              *)\n  | Int_Cd | Int_Ci | Int_Cu       (*  %#d | %#i | %#u *)\n\n(* Float conversion. *)\ntype float_flag_conv =\n  | Float_flag_                    (* %[feEgGFhH] *)\n  | Float_flag_p                   (* %+[feEgGFhH] *)\n  | Float_flag_s                   (* % [feEgGFhH] *)\ntype float_kind_conv =\n  | Float_f                        (*  %f | %+f | % f  *)\n  | Float_e                        (*  %e | %+e | % e  *)\n  | Float_E                        (*  %E | %+E | % E  *)\n  | Float_g                        (*  %g | %+g | % g  *)\n  | Float_G                        (*  %G | %+G | % G  *)\n  | Float_F                        (*  %F | %+F | % F  *)\n  | Float_h                        (*  %h | %+h | % h  *)\n  | Float_H                        (*  %H | %+H | % H  *)\n  | Float_CF                       (*  %#F| %+#F| % #F *)\ntype float_conv = float_flag_conv * float_kind_conv\n\n(***)\n\n(* Char sets (see %[...]) are bitmaps implemented as 32-char strings. *)\ntype char_set = string\n\n(***)\n\n(* Counter used in Scanf. *)\ntype counter =\n  | Line_counter     (*  %l      *)\n  | Char_counter     (*  %n      *)\n  | Token_counter    (*  %N, %L  *)\n\n(***)\n\n(* Padding of strings and numbers. *)\ntype ('a, 'b) padding =\n  (* No padding (ex: \"%d\") *)\n  | No_padding  : ('a, 'a) padding\n  (* Literal padding (ex: \"%8d\") *)\n  | Lit_padding : padty * int -> ('a, 'a) padding\n  (* Padding as extra argument (ex: \"%*d\") *)\n  | Arg_padding : padty -> (int -> 'a, 'a) padding\n\n(* Some formats, such as %_d,\n   only accept an optional number as padding option (no extra argument) *)\ntype pad_option = int option\n\n(* Precision of floats and '0'-padding of integers. *)\ntype ('a, 'b) precision =\n  (* No precision (ex: \"%f\") *)\n  | No_precision : ('a, 'a) precision\n  (* Literal precision (ex: \"%.3f\") *)\n  | Lit_precision : int -> ('a, 'a) precision\n  (* Precision as extra argument (ex: \"%.*f\") *)\n  | Arg_precision : (int -> 'a, 'a) precision\n\n(* Some formats, such as %_f,\n   only accept an optional number as precision option (no extra argument) *)\ntype prec_option = int option\n\n(* see the Custom format combinator *)\ntype ('a, 'b, 'c) custom_arity =\n  | Custom_zero : ('a, string, 'a) custom_arity\n  | Custom_succ : ('a, 'b, 'c) custom_arity ->\n    ('a, 'x -> 'b, 'x -> 'c) custom_arity\n\n(***)\n\n(*        Relational format types\n\nIn the first format+gadts implementation, the type for %(..%) in the\nfmt GADT was as follows:\n\n| Format_subst :                                           (* %(...%) *)\n    pad_option * ('d1, 'q1, 'd2, 'q2) reader_nb_unifier *\n    ('x, 'b, 'c, 'd1, 'q1, 'u) fmtty *\n    ('u, 'b, 'c, 'q1, 'e1, 'f) fmt ->\n      (('x, 'b, 'c, 'd2, 'q2, 'u) format6 -> 'x, 'b, 'c, 'd1, 'e1, 'f) fmt\n\nNotice that the 'u parameter in 'f position in the format argument\n(('x, .., 'u) format6 -> ..) is equal to the 'u parameter in 'a\nposition in the format tail (('u, .., 'f) fmt). This means that the\ntype of the expected format parameter depends of where the %(...%)\nare in the format string:\n\n  # Printf.printf \"%(%)\"\n  - : (unit, out_channel, unit, '_a, '_a, unit)\n      CamlinternalFormatBasics.format6 -> unit\n  = <fun>\n  # Printf.printf \"%(%)%d\"\n  - : (int -> unit, out_channel, unit, '_a, '_a, int -> unit)\n      CamlinternalFormatBasics.format6 -> int -> unit\n  = <fun>\n\nOn the contrary, the legacy typer gives a clever type that does not\ndepend on the position of %(..%) in the format string. For example,\n%(%) will have the polymorphic type ('a, 'b, 'c, 'd, 'd, 'a): it can\nbe concatenated to any format type, and only enforces the constraint\nthat its 'a and 'f parameters are equal (no format arguments) and 'd\nand 'e are equal (no reader argument).\n\nThe weakening of this parameter type in the GADT version broke user\ncode (in fact it essentially made %(...%) unusable except at the last\nposition of a format). In particular, the following would not work\nanymore:\n\n  fun sep ->\n    Format.printf \"foo%(%)bar%(%)baz\" sep sep\n\nAs the type-checker would require two *incompatible* types for the %(%)\nin different positions.\n\nThe solution to regain a general type for %(..%) is to generalize this\ntechnique, not only on the 'd, 'e parameters, but on all six\nparameters of a format: we introduce a \"relational\" type\n  ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n   'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\nwhose values are proofs that ('a1, .., 'f1) and ('a2, .., 'f2) morally\ncorrespond to the same format type: 'a1 is obtained from 'f1,'b1,'c1\nin the exact same way that 'a2 is obtained from 'f2,'b2,'c2, etc.\n\nFor example, the relation between two format types beginning with a Char\nparameter is as follows:\n\n| Char_ty :                                                 (* %c  *)\n    ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n     'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n    (char -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n     char -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n\nIn the general case, the term structure of fmtty_rel is (almost[1])\nisomorphic to the fmtty of the previous implementation: every\nconstructor is re-read with a binary, relational type, instead of the\nprevious unary typing. fmtty can then be re-defined as the diagonal of\nfmtty_rel:\n\n  type ('a, 'b, 'c, 'd, 'e, 'f) fmtty =\n       ('a, 'b, 'c, 'd, 'e, 'f,\n        'a, 'b, 'c, 'd, 'e, 'f) fmtty_rel\n\nOnce we have this fmtty_rel type in place, we can give the more\ngeneral type to %(...%):\n\n| Format_subst :                                           (* %(...%) *)\n    pad_option *\n    ('g, 'h, 'i, 'j, 'k, 'l,\n     'g2, 'b, 'c, 'j2, 'd, 'a) fmtty_rel *\n    ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n    (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g2, 'b, 'c, 'j2, 'e, 'f) fmt\n\nWe accept any format (('g, 'h, 'i, 'j, 'k, 'l) format6) (this is\ncompletely unrelated to the type of the current format), but also\nrequire a proof that this format is in relation to another format that\nis concatenable to the format tail. When executing a %(...%) format\n(in camlinternalFormat.ml:make_printf or scanf.ml:make_scanf), we\ntranstype the format along this relation using the 'recast' function\nto transpose between related format types.\n\n  val recast :\n     ('a1, 'b1, 'c1, 'd1, 'e1, 'f1) fmt\n  -> ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n      'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n  -> ('a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmt\n\nNOTE [1]: the typing of Format_subst_ty requires not one format type, but\ntwo, one to establish the link between the format argument and the\nfirst six parameters, and the other for the link between the format\nargument and the last six parameters.\n\n| Format_subst_ty :                                         (* %(...%) *)\n    ('g, 'h, 'i, 'j, 'k, 'l,\n     'g1, 'b1, 'c1, 'j1, 'd1, 'a1) fmtty_rel *\n    ('g, 'h, 'i, 'j, 'k, 'l,\n     'g2, 'b2, 'c2, 'j2, 'd2, 'a2) fmtty_rel *\n    ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n     'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n    (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g1, 'b1, 'c1, 'j1, 'e1, 'f1,\n     ('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g2, 'b2, 'c2, 'j2, 'e2, 'f2) fmtty_rel\n\nWhen we generate a format AST, we generate exactly the same witness\nfor both relations, and the witness-conversion functions in\ncamlinternalFormat do rely on this invariant. For example, the\nfunction that proves that the relation is transitive\n\n  val trans :\n     ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n      'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n  -> ('a2, 'b2, 'c2, 'd2, 'e2, 'f2,\n      'a3, 'b3, 'c3, 'd3, 'e3, 'f3) fmtty_rel\n  -> ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n      'a3, 'b3, 'c3, 'd3, 'e3, 'f3) fmtty_rel\n\ndoes assume that the two inputs have exactly the same term structure\n(and is only every used for argument witnesses of the\nFormat_subst_ty constructor).\n*)\n\n(* Type of a block used by the Format pretty-printer. *)\ntype block_type =\n  | Pp_hbox   (* Horizontal block no line breaking *)\n  | Pp_vbox   (* Vertical block each break leads to a new line *)\n  | Pp_hvbox  (* Horizontal-vertical block: same as vbox, except if this block\n                 is small enough to fit on a single line *)\n  | Pp_hovbox (* Horizontal or Vertical block: breaks lead to new line\n                 only when necessary to print the content of the block *)\n  | Pp_box    (* Horizontal or Indent block: breaks lead to new line\n                 only when necessary to print the content of the block, or\n                 when it leads to a new indentation of the current line *)\n  | Pp_fits   (* Internal usage: when a block fits on a single line *)\n\n(* Formatting element used by the Format pretty-printer. *)\ntype formatting_lit =\n  | Close_box                                           (* @]   *)\n  | Close_tag                                           (* @}   *)\n  | Break of string * int * int          (* @, | @  | @; | @;<> *)\n  | FFlush                                              (* @?   *)\n  | Force_newline                                       (* @\\n  *)\n  | Flush_newline                                       (* @.   *)\n  | Magic_size of string * int                          (* @<n> *)\n  | Escaped_at                                          (* @@   *)\n  | Escaped_percent                                     (* @%%  *)\n  | Scan_indic of char                                  (* @X   *)\n\n(* Formatting element used by the Format pretty-printer. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) formatting_gen =\n  | Open_tag : ('a, 'b, 'c, 'd, 'e, 'f) format6 ->      (* @{   *)\n    ('a, 'b, 'c, 'd, 'e, 'f) formatting_gen\n  | Open_box : ('a, 'b, 'c, 'd, 'e, 'f) format6 ->      (* @[   *)\n    ('a, 'b, 'c, 'd, 'e, 'f) formatting_gen\n\n(***)\n\n(* List of format type elements. *)\n(* In particular used to represent %(...%) and %{...%} contents. *)\nand ('a, 'b, 'c, 'd, 'e, 'f) fmtty =\n     ('a, 'b, 'c, 'd, 'e, 'f,\n      'a, 'b, 'c, 'd, 'e, 'f) fmtty_rel\nand ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n     'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel =\n  | Char_ty :                                                 (* %c  *)\n      ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n      (char -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       char -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n  | String_ty :                                               (* %s  *)\n      ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n      (string -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       string -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n  | Int_ty :                                                  (* %d  *)\n      ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n      (int -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       int -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n  | Int32_ty :                                                (* %ld *)\n      ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n      (int32 -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       int32 -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n  | Nativeint_ty :                                            (* %nd *)\n      ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n      (nativeint -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       nativeint -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n  | Int64_ty :                                                (* %Ld *)\n      ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n      (int64 -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       int64 -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n  | Float_ty :                                                (* %f  *)\n      ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n      (float -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       float -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n  | Bool_ty :                                                 (* %B  *)\n      ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n      (bool -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       bool -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n\n  | Format_arg_ty :                                           (* %{...%} *)\n      ('g, 'h, 'i, 'j, 'k, 'l) fmtty *\n      ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n      (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       ('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2)\n           fmtty_rel\n  | Format_subst_ty :                                         (* %(...%) *)\n      ('g, 'h, 'i, 'j, 'k, 'l,\n       'g1, 'b1, 'c1, 'j1, 'd1, 'a1) fmtty_rel *\n      ('g, 'h, 'i, 'j, 'k, 'l,\n       'g2, 'b2, 'c2, 'j2, 'd2, 'a2) fmtty_rel *\n      ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n      (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g1, 'b1, 'c1, 'j1, 'e1, 'f1,\n       ('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g2, 'b2, 'c2, 'j2, 'e2, 'f2)\n           fmtty_rel\n\n  (* Printf and Format specific constructors. *)\n  | Alpha_ty :                                                (* %a  *)\n      ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n      (('b1 -> 'x -> 'c1) -> 'x -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       ('b2 -> 'x -> 'c2) -> 'x -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n  | Theta_ty :                                                (* %t  *)\n      ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n      (('b1 -> 'c1) -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       ('b2 -> 'c2) -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n  | Any_ty :                                    (* Used for custom formats *)\n      ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n      ('x -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'x -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n\n  (* Scanf specific constructor. *)\n  | Reader_ty :                                               (* %r  *)\n      ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n      ('x -> 'a1, 'b1, 'c1, ('b1 -> 'x) -> 'd1, 'e1, 'f1,\n       'x -> 'a2, 'b2, 'c2, ('b2 -> 'x) -> 'd2, 'e2, 'f2) fmtty_rel\n  | Ignored_reader_ty :                                       (* %_r  *)\n      ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n      ('a1, 'b1, 'c1, ('b1 -> 'x) -> 'd1, 'e1, 'f1,\n       'a2, 'b2, 'c2, ('b2 -> 'x) -> 'd2, 'e2, 'f2) fmtty_rel\n\n  | End_of_fmtty :\n      ('f1, 'b1, 'c1, 'd1, 'd1, 'f1,\n       'f2, 'b2, 'c2, 'd2, 'd2, 'f2) fmtty_rel\n\n(***)\n\n(* List of format elements. *)\nand ('a, 'b, 'c, 'd, 'e, 'f) fmt =\n  | Char :                                                   (* %c *)\n      ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        (char -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n  | Caml_char :                                              (* %C *)\n      ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        (char -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n  | String :                                                 (* %s *)\n      ('x, string -> 'a) padding * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        ('x, 'b, 'c, 'd, 'e, 'f) fmt\n  | Caml_string :                                            (* %S *)\n      ('x, string -> 'a) padding * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        ('x, 'b, 'c, 'd, 'e, 'f) fmt\n  | Int :                                                    (* %[dixXuo] *)\n      int_conv * ('x, 'y) padding * ('y, int -> 'a) precision *\n      ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        ('x, 'b, 'c, 'd, 'e, 'f) fmt\n  | Int32 :                                                  (* %l[dixXuo] *)\n      int_conv * ('x, 'y) padding * ('y, int32 -> 'a) precision *\n      ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        ('x, 'b, 'c, 'd, 'e, 'f) fmt\n  | Nativeint :                                              (* %n[dixXuo] *)\n      int_conv * ('x, 'y) padding * ('y, nativeint -> 'a) precision *\n      ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        ('x, 'b, 'c, 'd, 'e, 'f) fmt\n  | Int64 :                                                  (* %L[dixXuo] *)\n      int_conv * ('x, 'y) padding * ('y, int64 -> 'a) precision *\n      ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        ('x, 'b, 'c, 'd, 'e, 'f) fmt\n  | Float :                                                  (* %[feEgGFhH] *)\n      float_conv * ('x, 'y) padding * ('y, float -> 'a) precision *\n      ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        ('x, 'b, 'c, 'd, 'e, 'f) fmt\n  | Bool :                                                   (* %[bB] *)\n      ('x, bool -> 'a) padding * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        ('x, 'b, 'c, 'd, 'e, 'f) fmt\n  | Flush :                                                  (* %! *)\n      ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        ('a, 'b, 'c, 'd, 'e, 'f) fmt\n\n  | String_literal :                                         (* abc *)\n      string * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        ('a, 'b, 'c, 'd, 'e, 'f) fmt\n  | Char_literal :                                           (* x *)\n      char * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        ('a, 'b, 'c, 'd, 'e, 'f) fmt\n\n  | Format_arg :                                             (* %{...%} *)\n      pad_option * ('g, 'h, 'i, 'j, 'k, 'l) fmtty *\n      ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n  | Format_subst :                                           (* %(...%) *)\n      pad_option *\n      ('g, 'h, 'i, 'j, 'k, 'l,\n       'g2, 'b, 'c, 'j2, 'd, 'a) fmtty_rel *\n      ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n      (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g2, 'b, 'c, 'j2, 'e, 'f) fmt\n\n  (* Printf and Format specific constructor. *)\n  | Alpha :                                                  (* %a *)\n      ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        (('b -> 'x -> 'c) -> 'x -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n  | Theta :                                                  (* %t *)\n      ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        (('b -> 'c) -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n\n  (* Format specific constructor: *)\n  | Formatting_lit :                                         (* @_ *)\n      formatting_lit * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        ('a, 'b, 'c, 'd, 'e, 'f) fmt\n  | Formatting_gen :                                             (* @_ *)\n      ('a1, 'b, 'c, 'd1, 'e1, 'f1) formatting_gen *\n      ('f1, 'b, 'c, 'e1, 'e2, 'f2) fmt -> ('a1, 'b, 'c, 'd1, 'e2, 'f2) fmt\n\n  (* Scanf specific constructors: *)\n  | Reader :                                                 (* %r *)\n      ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        ('x -> 'a, 'b, 'c, ('b -> 'x) -> 'd, 'e, 'f) fmt\n  | Scan_char_set :                                          (* %[...] *)\n      pad_option * char_set * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        (string -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n  | Scan_get_counter :                                       (* %[nlNL] *)\n      counter * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n        (int -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n  | Scan_next_char :                                         (* %0c *)\n      ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n      (char -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n  | Ignored_param :                                          (* %_ *)\n      ('a, 'b, 'c, 'd, 'y, 'x) ignored * ('x, 'b, 'c, 'y, 'e, 'f) fmt ->\n        ('a, 'b, 'c, 'd, 'e, 'f) fmt\n\n  (* Custom printing format (PR#6452, GPR#140)\n\n     We include a type Custom of \"custom converters\", where an\n     arbitrary function can be used to convert one or more\n     arguments. There is no syntax for custom converters, it is only\n     intended for custom processors that wish to rely on the\n     stdlib-defined format GADTs.\n\n     For instance a pre-processor could choose to interpret strings\n     prefixed with [\"!\"] as format strings where [%{{ ... }}] is\n     a special form to pass a to_string function, so that one could\n     write:\n\n     {[\n       type t = { x : int; y : int }\n\n       let string_of_t t = Printf.sprintf \"{ x = %d; y = %d }\" t.x t.y\n\n       Printf.printf !\"t = %{{string_of_t}}\" { x = 42; y = 42 }\n     ]}\n  *)\n  | Custom :\n      ('a, 'x, 'y) custom_arity * (unit -> 'x) * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n      ('y, 'b, 'c, 'd, 'e, 'f) fmt\n\n  (* end of a format specification *)\n  | End_of_format :\n        ('f, 'b, 'c, 'e, 'e, 'f) fmt\n\n(***)\n\n(* Type for ignored parameters (see \"%_\"). *)\nand ('a, 'b, 'c, 'd, 'e, 'f) ignored =\n  | Ignored_char :                                           (* %_c *)\n      ('a, 'b, 'c, 'd, 'd, 'a) ignored\n  | Ignored_caml_char :                                      (* %_C *)\n      ('a, 'b, 'c, 'd, 'd, 'a) ignored\n  | Ignored_string :                                         (* %_s *)\n      pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n  | Ignored_caml_string :                                    (* %_S *)\n      pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n  | Ignored_int :                                            (* %_d *)\n      int_conv * pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n  | Ignored_int32 :                                          (* %_ld *)\n      int_conv * pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n  | Ignored_nativeint :                                      (* %_nd *)\n      int_conv * pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n  | Ignored_int64 :                                          (* %_Ld *)\n      int_conv * pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n  | Ignored_float :                                          (* %_f *)\n      pad_option * prec_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n  | Ignored_bool :                                           (* %_B *)\n      pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n  | Ignored_format_arg :                                     (* %_{...%} *)\n      pad_option * ('g, 'h, 'i, 'j, 'k, 'l) fmtty ->\n        ('a, 'b, 'c, 'd, 'd, 'a) ignored\n  | Ignored_format_subst :                                   (* %_(...%) *)\n      pad_option * ('a, 'b, 'c, 'd, 'e, 'f) fmtty ->\n        ('a, 'b, 'c, 'd, 'e, 'f) ignored\n  | Ignored_reader :                                         (* %_r *)\n      ('a, 'b, 'c, ('b -> 'x) -> 'd, 'd, 'a) ignored\n  | Ignored_scan_char_set :                                  (* %_[...] *)\n      pad_option * char_set -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n  | Ignored_scan_get_counter :                               (* %_[nlNL] *)\n      counter -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n  | Ignored_scan_next_char :                                 (* %_0c *)\n      ('a, 'b, 'c, 'd, 'd, 'a) ignored\n\nand ('a, 'b, 'c, 'd, 'e, 'f) format6 =\n  Format of ('a, 'b, 'c, 'd, 'e, 'f) fmt * string\n\nlet rec erase_rel : type a b c d e f g h i j k l .\n  (a, b, c, d, e, f,\n   g, h, i, j, k, l) fmtty_rel -> (a, b, c, d, e, f) fmtty\n= function\n  | Char_ty rest ->\n    Char_ty (erase_rel rest)\n  | String_ty rest ->\n    String_ty (erase_rel rest)\n  | Int_ty rest ->\n    Int_ty (erase_rel rest)\n  | Int32_ty rest ->\n    Int32_ty (erase_rel rest)\n  | Int64_ty rest ->\n    Int64_ty (erase_rel rest)\n  | Nativeint_ty rest ->\n    Nativeint_ty (erase_rel rest)\n  | Float_ty rest ->\n    Float_ty (erase_rel rest)\n  | Bool_ty rest ->\n    Bool_ty (erase_rel rest)\n  | Format_arg_ty (ty, rest) ->\n    Format_arg_ty (ty, erase_rel rest)\n  | Format_subst_ty (ty1, _ty2, rest) ->\n    Format_subst_ty (ty1, ty1, erase_rel rest)\n  | Alpha_ty rest ->\n    Alpha_ty (erase_rel rest)\n  | Theta_ty rest ->\n    Theta_ty (erase_rel rest)\n  | Any_ty rest ->\n    Any_ty (erase_rel rest)\n  | Reader_ty rest ->\n    Reader_ty (erase_rel rest)\n  | Ignored_reader_ty rest ->\n    Ignored_reader_ty (erase_rel rest)\n  | End_of_fmtty -> End_of_fmtty\n\n(******************************************************************************)\n                         (* Format type concatenation *)\n\n(* Concatenate two format types. *)\n(* Used by:\n   * reader_nb_unifier_of_fmtty to count readers in an fmtty,\n   * Scanf.take_fmtty_format_readers to extract readers inside %(...%),\n   * CamlinternalFormat.fmtty_of_ignored_format to extract format type. *)\n\n(*\nlet rec concat_fmtty : type a b c d e f g h .\n    (a, b, c, d, e, f) fmtty ->\n    (f, b, c, e, g, h) fmtty ->\n    (a, b, c, d, g, h) fmtty =\n*)\nlet rec concat_fmtty :\n  type a1 b1 c1 d1 e1 f1\n       a2 b2 c2 d2 e2 f2\n       g1 j1 g2 j2\n  .\n    (g1, b1, c1, j1, d1, a1,\n     g2, b2, c2, j2, d2, a2) fmtty_rel ->\n    (a1, b1, c1, d1, e1, f1,\n     a2, b2, c2, d2, e2, f2) fmtty_rel ->\n    (g1, b1, c1, j1, e1, f1,\n     g2, b2, c2, j2, e2, f2) fmtty_rel =\nfun fmtty1 fmtty2 -> match fmtty1 with\n  | Char_ty rest ->\n    Char_ty (concat_fmtty rest fmtty2)\n  | String_ty rest ->\n    String_ty (concat_fmtty rest fmtty2)\n  | Int_ty rest ->\n    Int_ty (concat_fmtty rest fmtty2)\n  | Int32_ty rest ->\n    Int32_ty (concat_fmtty rest fmtty2)\n  | Nativeint_ty rest ->\n    Nativeint_ty (concat_fmtty rest fmtty2)\n  | Int64_ty rest ->\n    Int64_ty (concat_fmtty rest fmtty2)\n  | Float_ty rest ->\n    Float_ty (concat_fmtty rest fmtty2)\n  | Bool_ty rest ->\n    Bool_ty (concat_fmtty rest fmtty2)\n  | Alpha_ty rest ->\n    Alpha_ty (concat_fmtty rest fmtty2)\n  | Theta_ty rest ->\n    Theta_ty (concat_fmtty rest fmtty2)\n  | Any_ty rest ->\n    Any_ty (concat_fmtty rest fmtty2)\n  | Reader_ty rest ->\n    Reader_ty (concat_fmtty rest fmtty2)\n  | Ignored_reader_ty rest ->\n    Ignored_reader_ty (concat_fmtty rest fmtty2)\n  | Format_arg_ty (ty, rest) ->\n    Format_arg_ty (ty, concat_fmtty rest fmtty2)\n  | Format_subst_ty (ty1, ty2, rest) ->\n    Format_subst_ty (ty1, ty2, concat_fmtty rest fmtty2)\n  | End_of_fmtty -> fmtty2\n\n(******************************************************************************)\n                           (* Format concatenation *)\n\n(* Concatenate two formats. *)\nlet rec concat_fmt : type a b c d e f g h .\n    (a, b, c, d, e, f) fmt ->\n    (f, b, c, e, g, h) fmt ->\n    (a, b, c, d, g, h) fmt =\nfun fmt1 fmt2 -> match fmt1 with\n  | String (pad, rest) ->\n    String (pad, concat_fmt rest fmt2)\n  | Caml_string (pad, rest) ->\n    Caml_string (pad, concat_fmt rest fmt2)\n\n  | Int (iconv, pad, prec, rest) ->\n    Int (iconv, pad, prec, concat_fmt rest fmt2)\n  | Int32 (iconv, pad, prec, rest) ->\n    Int32 (iconv, pad, prec, concat_fmt rest fmt2)\n  | Nativeint (iconv, pad, prec, rest) ->\n    Nativeint (iconv, pad, prec, concat_fmt rest fmt2)\n  | Int64 (iconv, pad, prec, rest) ->\n    Int64 (iconv, pad, prec, concat_fmt rest fmt2)\n  | Float (fconv, pad, prec, rest) ->\n    Float (fconv, pad, prec, concat_fmt rest fmt2)\n\n  | Char (rest) ->\n    Char (concat_fmt rest fmt2)\n  | Caml_char rest ->\n    Caml_char (concat_fmt rest fmt2)\n  | Bool (pad, rest) ->\n    Bool (pad, concat_fmt rest fmt2)\n  | Alpha rest ->\n    Alpha (concat_fmt rest fmt2)\n  | Theta rest ->\n    Theta (concat_fmt rest fmt2)\n  | Custom (arity, f, rest) ->\n    Custom (arity, f, concat_fmt rest fmt2)\n  | Reader rest ->\n    Reader (concat_fmt rest fmt2)\n  | Flush rest ->\n    Flush (concat_fmt rest fmt2)\n\n  | String_literal (str, rest) ->\n    String_literal (str, concat_fmt rest fmt2)\n  | Char_literal (chr, rest) ->\n    Char_literal   (chr, concat_fmt rest fmt2)\n\n  | Format_arg (pad, fmtty, rest) ->\n    Format_arg   (pad, fmtty, concat_fmt rest fmt2)\n  | Format_subst (pad, fmtty, rest) ->\n    Format_subst (pad, fmtty, concat_fmt rest fmt2)\n\n  | Scan_char_set (width_opt, char_set, rest) ->\n    Scan_char_set (width_opt, char_set, concat_fmt rest fmt2)\n  | Scan_get_counter (counter, rest) ->\n    Scan_get_counter (counter, concat_fmt rest fmt2)\n  | Scan_next_char (rest) ->\n    Scan_next_char (concat_fmt rest fmt2)\n  | Ignored_param (ign, rest) ->\n    Ignored_param (ign, concat_fmt rest fmt2)\n\n  | Formatting_lit (fmting_lit, rest) ->\n    Formatting_lit (fmting_lit, concat_fmt rest fmt2)\n  | Formatting_gen (fmting_gen, rest) ->\n    Formatting_gen (fmting_gen, concat_fmt rest fmt2)\n\n  | End_of_format ->\n    fmt2\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Gabriel Scherer, projet Partout, INRIA Paris-Saclay        *)\n(*                                                                        *)\n(*   Copyright 2020 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* CamlinternalAtomic is a dependency of Stdlib, so it is compiled with\n   -nopervasives. *)\nexternal ( == ) : 'a -> 'a -> bool = \"%eq\"\nexternal ( + ) : int -> int -> int = \"%addint\"\nexternal ignore : 'a -> unit = \"%ignore\"\n\n(* We are not reusing ('a ref) directly to make it easier to reason\n   about atomicity if we wish to: even in a sequential implementation,\n   signals and other asynchronous callbacks might break atomicity. *)\ntype 'a t = {mutable v: 'a}\n\nlet make v = {v}\nlet get r = r.v\nlet set r v = r.v <- v\n\n(* The following functions are set to never be inlined: Flambda is\n   allowed to move surrounding code inside the critical section,\n   including allocations. *)\n\nlet[@inline never] exchange r v =\n  (* BEGIN ATOMIC *)\n  let cur = r.v in\n  r.v <- v;\n  (* END ATOMIC *)\n  cur\n\nlet[@inline never] compare_and_set r seen v =\n  (* BEGIN ATOMIC *)\n  let cur = r.v in\n  if cur == seen then (\n    r.v <- v;\n    (* END ATOMIC *)\n    true\n  ) else\n    false\n\nlet[@inline never] fetch_and_add r n =\n  (* BEGIN ATOMIC *)\n  let cur = r.v in\n  r.v <- (cur + n);\n  (* END ATOMIC *)\n  cur\n\nlet incr r = ignore (fetch_and_add r 1)\nlet decr r = ignore (fetch_and_add r (-1))\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Exceptions *)\n\nexternal register_named_value : string -> 'a -> unit\n                              = \"caml_register_named_value\"\n\nlet () =\n  (* for runtime/fail_nat.c *)\n  register_named_value \"Pervasives.array_bound_error\"\n    (Invalid_argument \"index out of bounds\")\n\nexternal raise : exn -> 'a = \"%raise\"\nexternal raise_notrace : exn -> 'a = \"%raise_notrace\"\n\nlet failwith s = raise(Failure s)\nlet invalid_arg s = raise(Invalid_argument s)\n\nexception Exit\nexception Match_failure = Match_failure\nexception Assert_failure = Assert_failure\nexception Invalid_argument = Invalid_argument\nexception Failure = Failure\nexception Not_found = Not_found\nexception Out_of_memory = Out_of_memory\nexception Stack_overflow = Stack_overflow\nexception Sys_error = Sys_error\nexception End_of_file = End_of_file\nexception Division_by_zero = Division_by_zero\nexception Sys_blocked_io = Sys_blocked_io\nexception Undefined_recursive_module = Undefined_recursive_module\n\n(* Composition operators *)\n\nexternal ( |> ) : 'a -> ('a -> 'b) -> 'b = \"%revapply\"\nexternal ( @@ ) : ('a -> 'b) -> 'a -> 'b = \"%apply\"\n\n(* Debugging *)\n\nexternal __LOC__ : string = \"%loc_LOC\"\nexternal __FILE__ : string = \"%loc_FILE\"\nexternal __LINE__ : int = \"%loc_LINE\"\nexternal __MODULE__ : string = \"%loc_MODULE\"\nexternal __POS__ : string * int * int * int = \"%loc_POS\"\nexternal __FUNCTION__ : string = \"%loc_FUNCTION\"\n\nexternal __LOC_OF__ : 'a -> string * 'a = \"%loc_LOC\"\nexternal __LINE_OF__ : 'a -> int * 'a = \"%loc_LINE\"\nexternal __POS_OF__ : 'a -> (string * int * int * int) * 'a = \"%loc_POS\"\n\n(* Comparisons *)\n\nexternal ( = ) : 'a -> 'a -> bool = \"%equal\"\nexternal ( <> ) : 'a -> 'a -> bool = \"%notequal\"\nexternal ( < ) : 'a -> 'a -> bool = \"%lessthan\"\nexternal ( > ) : 'a -> 'a -> bool = \"%greaterthan\"\nexternal ( <= ) : 'a -> 'a -> bool = \"%lessequal\"\nexternal ( >= ) : 'a -> 'a -> bool = \"%greaterequal\"\nexternal compare : 'a -> 'a -> int = \"%compare\"\n\nlet min x y = if x <= y then x else y\nlet max x y = if x >= y then x else y\n\nexternal ( == ) : 'a -> 'a -> bool = \"%eq\"\nexternal ( != ) : 'a -> 'a -> bool = \"%noteq\"\n\n(* Boolean operations *)\n\nexternal not : bool -> bool = \"%boolnot\"\nexternal ( & ) : bool -> bool -> bool = \"%sequand\"\nexternal ( && ) : bool -> bool -> bool = \"%sequand\"\nexternal ( or ) : bool -> bool -> bool = \"%sequor\"\nexternal ( || ) : bool -> bool -> bool = \"%sequor\"\n\n(* Integer operations *)\n\nexternal ( ~- ) : int -> int = \"%negint\"\nexternal ( ~+ ) : int -> int = \"%identity\"\nexternal succ : int -> int = \"%succint\"\nexternal pred : int -> int = \"%predint\"\nexternal ( + ) : int -> int -> int = \"%addint\"\nexternal ( - ) : int -> int -> int = \"%subint\"\nexternal ( * ) : int -> int -> int = \"%mulint\"\nexternal ( / ) : int -> int -> int = \"%divint\"\nexternal ( mod ) : int -> int -> int = \"%modint\"\n\nlet abs x = if x >= 0 then x else -x\n\nexternal ( land ) : int -> int -> int = \"%andint\"\nexternal ( lor ) : int -> int -> int = \"%orint\"\nexternal ( lxor ) : int -> int -> int = \"%xorint\"\n\nlet lnot x = x lxor (-1)\n\nexternal ( lsl ) : int -> int -> int = \"%lslint\"\nexternal ( lsr ) : int -> int -> int = \"%lsrint\"\nexternal ( asr ) : int -> int -> int = \"%asrint\"\n\nlet max_int = (-1) lsr 1\nlet min_int = max_int + 1\n\n(* Floating-point operations *)\n\nexternal ( ~-. ) : float -> float = \"%negfloat\"\nexternal ( ~+. ) : float -> float = \"%identity\"\nexternal ( +. ) : float -> float -> float = \"%addfloat\"\nexternal ( -. ) : float -> float -> float = \"%subfloat\"\nexternal ( *. ) : float -> float -> float = \"%mulfloat\"\nexternal ( /. ) : float -> float -> float = \"%divfloat\"\nexternal ( ** ) : float -> float -> float = \"caml_power_float\" \"pow\"\n  [@@unboxed] [@@noalloc]\nexternal exp : float -> float = \"caml_exp_float\" \"exp\" [@@unboxed] [@@noalloc]\nexternal expm1 : float -> float = \"caml_expm1_float\" \"caml_expm1\"\n  [@@unboxed] [@@noalloc]\nexternal acos : float -> float = \"caml_acos_float\" \"acos\"\n  [@@unboxed] [@@noalloc]\nexternal asin : float -> float = \"caml_asin_float\" \"asin\"\n  [@@unboxed] [@@noalloc]\nexternal atan : float -> float = \"caml_atan_float\" \"atan\"\n  [@@unboxed] [@@noalloc]\nexternal atan2 : float -> float -> float = \"caml_atan2_float\" \"atan2\"\n  [@@unboxed] [@@noalloc]\nexternal hypot : float -> float -> float\n               = \"caml_hypot_float\" \"caml_hypot\" [@@unboxed] [@@noalloc]\nexternal cos : float -> float = \"caml_cos_float\" \"cos\" [@@unboxed] [@@noalloc]\nexternal cosh : float -> float = \"caml_cosh_float\" \"cosh\"\n  [@@unboxed] [@@noalloc]\nexternal acosh : float -> float = \"caml_acosh_float\" \"caml_acosh\"\n  [@@unboxed] [@@noalloc]\nexternal log : float -> float = \"caml_log_float\" \"log\" [@@unboxed] [@@noalloc]\nexternal log10 : float -> float = \"caml_log10_float\" \"log10\"\n  [@@unboxed] [@@noalloc]\nexternal log1p : float -> float = \"caml_log1p_float\" \"caml_log1p\"\n  [@@unboxed] [@@noalloc]\nexternal sin : float -> float = \"caml_sin_float\" \"sin\" [@@unboxed] [@@noalloc]\nexternal sinh : float -> float = \"caml_sinh_float\" \"sinh\"\n  [@@unboxed] [@@noalloc]\nexternal asinh : float -> float = \"caml_asinh_float\" \"caml_asinh\"\n  [@@unboxed] [@@noalloc]\nexternal sqrt : float -> float = \"caml_sqrt_float\" \"sqrt\"\n  [@@unboxed] [@@noalloc]\nexternal tan : float -> float = \"caml_tan_float\" \"tan\" [@@unboxed] [@@noalloc]\nexternal tanh : float -> float = \"caml_tanh_float\" \"tanh\"\n  [@@unboxed] [@@noalloc]\nexternal atanh : float -> float = \"caml_atanh_float\" \"caml_atanh\"\n  [@@unboxed] [@@noalloc]\nexternal ceil : float -> float = \"caml_ceil_float\" \"ceil\"\n  [@@unboxed] [@@noalloc]\nexternal floor : float -> float = \"caml_floor_float\" \"floor\"\n  [@@unboxed] [@@noalloc]\nexternal abs_float : float -> float = \"%absfloat\"\nexternal copysign : float -> float -> float\n                  = \"caml_copysign_float\" \"caml_copysign\"\n                  [@@unboxed] [@@noalloc]\nexternal mod_float : float -> float -> float = \"caml_fmod_float\" \"fmod\"\n  [@@unboxed] [@@noalloc]\nexternal frexp : float -> float * int = \"caml_frexp_float\"\nexternal ldexp : (float [@unboxed]) -> (int [@untagged]) -> (float [@unboxed]) =\n  \"caml_ldexp_float\" \"caml_ldexp_float_unboxed\" [@@noalloc]\nexternal modf : float -> float * float = \"caml_modf_float\"\nexternal float : int -> float = \"%floatofint\"\nexternal float_of_int : int -> float = \"%floatofint\"\nexternal truncate : float -> int = \"%intoffloat\"\nexternal int_of_float : float -> int = \"%intoffloat\"\nexternal float_of_bits : int64 -> float\n  = \"caml_int64_float_of_bits\" \"caml_int64_float_of_bits_unboxed\"\n  [@@unboxed] [@@noalloc]\nlet infinity =\n  float_of_bits 0x7F_F0_00_00_00_00_00_00L\nlet neg_infinity =\n  float_of_bits 0xFF_F0_00_00_00_00_00_00L\nlet nan =\n  float_of_bits 0x7F_F0_00_00_00_00_00_01L\nlet max_float =\n  float_of_bits 0x7F_EF_FF_FF_FF_FF_FF_FFL\nlet min_float =\n  float_of_bits 0x00_10_00_00_00_00_00_00L\nlet epsilon_float =\n  float_of_bits 0x3C_B0_00_00_00_00_00_00L\n\ntype fpclass =\n    FP_normal\n  | FP_subnormal\n  | FP_zero\n  | FP_infinite\n  | FP_nan\nexternal classify_float : (float [@unboxed]) -> fpclass =\n  \"caml_classify_float\" \"caml_classify_float_unboxed\" [@@noalloc]\n\n(* String and byte sequence operations -- more in modules String and Bytes *)\n\nexternal string_length : string -> int = \"%string_length\"\nexternal bytes_length : bytes -> int = \"%bytes_length\"\nexternal bytes_create : int -> bytes = \"caml_create_bytes\"\nexternal string_blit : string -> int -> bytes -> int -> int -> unit\n                     = \"caml_blit_string\" [@@noalloc]\nexternal bytes_blit : bytes -> int -> bytes -> int -> int -> unit\n                        = \"caml_blit_bytes\" [@@noalloc]\nexternal bytes_unsafe_to_string : bytes -> string = \"%bytes_to_string\"\n\nlet ( ^ ) s1 s2 =\n  let l1 = string_length s1 and l2 = string_length s2 in\n  let s = bytes_create (l1 + l2) in\n  string_blit s1 0 s 0 l1;\n  string_blit s2 0 s l1 l2;\n  bytes_unsafe_to_string s\n\n(* Character operations -- more in module Char *)\n\nexternal int_of_char : char -> int = \"%identity\"\nexternal unsafe_char_of_int : int -> char = \"%identity\"\nlet char_of_int n =\n  if n < 0 || n > 255 then invalid_arg \"char_of_int\" else unsafe_char_of_int n\n\n(* Unit operations *)\n\nexternal ignore : 'a -> unit = \"%ignore\"\n\n(* Pair operations *)\n\nexternal fst : 'a * 'b -> 'a = \"%field0\"\nexternal snd : 'a * 'b -> 'b = \"%field1\"\n\n(* References *)\n\ntype 'a ref = { mutable contents : 'a }\nexternal ref : 'a -> 'a ref = \"%makemutable\"\nexternal ( ! ) : 'a ref -> 'a = \"%field0\"\nexternal ( := ) : 'a ref -> 'a -> unit = \"%setfield0\"\nexternal incr : int ref -> unit = \"%incr\"\nexternal decr : int ref -> unit = \"%decr\"\n\n(* Result type *)\n\ntype ('a,'b) result = Ok of 'a | Error of 'b\n\n(* String conversion functions *)\n\nexternal format_int : string -> int -> string = \"caml_format_int\"\nexternal format_float : string -> float -> string = \"caml_format_float\"\n\nlet string_of_bool b =\n  if b then \"true\" else \"false\"\nlet bool_of_string = function\n  | \"true\" -> true\n  | \"false\" -> false\n  | _ -> invalid_arg \"bool_of_string\"\n\nlet bool_of_string_opt = function\n  | \"true\" -> Some true\n  | \"false\" -> Some false\n  | _ -> None\n\nlet string_of_int n =\n  format_int \"%d\" n\n\nexternal int_of_string : string -> int = \"caml_int_of_string\"\n\nlet int_of_string_opt s =\n  (* TODO: provide this directly as a non-raising primitive. *)\n  try Some (int_of_string s)\n  with Failure _ -> None\n\nexternal string_get : string -> int -> char = \"%string_safe_get\"\n\nlet valid_float_lexem s =\n  let l = string_length s in\n  let rec loop i =\n    if i >= l then s ^ \".\" else\n    match string_get s i with\n    | '0' .. '9' | '-' -> loop (i + 1)\n    | _ -> s\n  in\n  loop 0\n\nlet string_of_float f = valid_float_lexem (format_float \"%.12g\" f)\n\nexternal float_of_string : string -> float = \"caml_float_of_string\"\n\nlet float_of_string_opt s =\n  (* TODO: provide this directly as a non-raising primitive. *)\n  try Some (float_of_string s)\n  with Failure _ -> None\n\n(* List operations -- more in module List *)\n\nlet rec ( @ ) l1 l2 =\n  match l1 with\n    [] -> l2\n  | hd :: tl -> hd :: (tl @ l2)\n\n(* I/O operations *)\n\ntype in_channel\ntype out_channel\n\nexternal open_descriptor_out : int -> out_channel\n                             = \"caml_ml_open_descriptor_out\"\nexternal open_descriptor_in : int -> in_channel = \"caml_ml_open_descriptor_in\"\n\nlet stdin = open_descriptor_in 0\nlet stdout = open_descriptor_out 1\nlet stderr = open_descriptor_out 2\n\n(* General output functions *)\n\ntype open_flag =\n    Open_rdonly | Open_wronly | Open_append\n  | Open_creat | Open_trunc | Open_excl\n  | Open_binary | Open_text | Open_nonblock\n\nexternal open_desc : string -> open_flag list -> int -> int = \"caml_sys_open\"\n\nexternal set_out_channel_name: out_channel -> string -> unit =\n  \"caml_ml_set_channel_name\"\n\nlet open_out_gen mode perm name =\n  let c = open_descriptor_out(open_desc name mode perm) in\n  set_out_channel_name c name;\n  c\n\nlet open_out name =\n  open_out_gen [Open_wronly; Open_creat; Open_trunc; Open_text] 0o666 name\n\nlet open_out_bin name =\n  open_out_gen [Open_wronly; Open_creat; Open_trunc; Open_binary] 0o666 name\n\nexternal flush : out_channel -> unit = \"caml_ml_flush\"\n\nexternal out_channels_list : unit -> out_channel list\n                           = \"caml_ml_out_channels_list\"\n\nlet flush_all () =\n  let rec iter = function\n      [] -> ()\n    | a::l ->\n        begin try\n            flush a\n        with Sys_error _ ->\n          () (* ignore channels closed during a preceding flush. *)\n        end;\n        iter l\n  in iter (out_channels_list ())\n\nexternal unsafe_output : out_channel -> bytes -> int -> int -> unit\n                       = \"caml_ml_output_bytes\"\nexternal unsafe_output_string : out_channel -> string -> int -> int -> unit\n                              = \"caml_ml_output\"\n\nexternal output_char : out_channel -> char -> unit = \"caml_ml_output_char\"\n\nlet output_bytes oc s =\n  unsafe_output oc s 0 (bytes_length s)\n\nlet output_string oc s =\n  unsafe_output_string oc s 0 (string_length s)\n\nlet output oc s ofs len =\n  if ofs < 0 || len < 0 || ofs > bytes_length s - len\n  then invalid_arg \"output\"\n  else unsafe_output oc s ofs len\n\nlet output_substring oc s ofs len =\n  if ofs < 0 || len < 0 || ofs > string_length s - len\n  then invalid_arg \"output_substring\"\n  else unsafe_output_string oc s ofs len\n\nexternal output_byte : out_channel -> int -> unit = \"caml_ml_output_char\"\nexternal output_binary_int : out_channel -> int -> unit = \"caml_ml_output_int\"\n\nexternal marshal_to_channel : out_channel -> 'a -> unit list -> unit\n     = \"caml_output_value\"\nlet output_value chan v = marshal_to_channel chan v []\n\nexternal seek_out : out_channel -> int -> unit = \"caml_ml_seek_out\"\nexternal pos_out : out_channel -> int = \"caml_ml_pos_out\"\nexternal out_channel_length : out_channel -> int = \"caml_ml_channel_size\"\nexternal close_out_channel : out_channel -> unit = \"caml_ml_close_channel\"\nlet close_out oc = flush oc; close_out_channel oc\nlet close_out_noerr oc =\n  (try flush oc with _ -> ());\n  (try close_out_channel oc with _ -> ())\nexternal set_binary_mode_out : out_channel -> bool -> unit\n                             = \"caml_ml_set_binary_mode\"\n\n(* General input functions *)\n\nexternal set_in_channel_name: in_channel -> string -> unit =\n  \"caml_ml_set_channel_name\"\n\nlet open_in_gen mode perm name =\n  let c = open_descriptor_in(open_desc name mode perm) in\n  set_in_channel_name c name;\n  c\n\nlet open_in name =\n  open_in_gen [Open_rdonly; Open_text] 0 name\n\nlet open_in_bin name =\n  open_in_gen [Open_rdonly; Open_binary] 0 name\n\nexternal input_char : in_channel -> char = \"caml_ml_input_char\"\n\nexternal unsafe_input : in_channel -> bytes -> int -> int -> int\n                      = \"caml_ml_input\"\n\nlet input ic s ofs len =\n  if ofs < 0 || len < 0 || ofs > bytes_length s - len\n  then invalid_arg \"input\"\n  else unsafe_input ic s ofs len\n\nlet rec unsafe_really_input ic s ofs len =\n  if len <= 0 then () else begin\n    let r = unsafe_input ic s ofs len in\n    if r = 0\n    then raise End_of_file\n    else unsafe_really_input ic s (ofs + r) (len - r)\n  end\n\nlet really_input ic s ofs len =\n  if ofs < 0 || len < 0 || ofs > bytes_length s - len\n  then invalid_arg \"really_input\"\n  else unsafe_really_input ic s ofs len\n\nlet really_input_string ic len =\n  let s = bytes_create len in\n  really_input ic s 0 len;\n  bytes_unsafe_to_string s\n\nexternal input_scan_line : in_channel -> int = \"caml_ml_input_scan_line\"\n\nlet input_line chan =\n  let rec build_result buf pos = function\n    [] -> buf\n  | hd :: tl ->\n      let len = bytes_length hd in\n      bytes_blit hd 0 buf (pos - len) len;\n      build_result buf (pos - len) tl in\n  let rec scan accu len =\n    let n = input_scan_line chan in\n    if n = 0 then begin                   (* n = 0: we are at EOF *)\n      match accu with\n        [] -> raise End_of_file\n      | _  -> build_result (bytes_create len) len accu\n    end else if n > 0 then begin          (* n > 0: newline found in buffer *)\n      let res = bytes_create (n - 1) in\n      ignore (unsafe_input chan res 0 (n - 1));\n      ignore (input_char chan);           (* skip the newline *)\n      match accu with\n        [] -> res\n      |  _ -> let len = len + n - 1 in\n              build_result (bytes_create len) len (res :: accu)\n    end else begin                        (* n < 0: newline not found *)\n      let beg = bytes_create (-n) in\n      ignore(unsafe_input chan beg 0 (-n));\n      scan (beg :: accu) (len - n)\n    end\n  in bytes_unsafe_to_string (scan [] 0)\n\nexternal input_byte : in_channel -> int = \"caml_ml_input_char\"\nexternal input_binary_int : in_channel -> int = \"caml_ml_input_int\"\nexternal input_value : in_channel -> 'a = \"caml_input_value\"\nexternal seek_in : in_channel -> int -> unit = \"caml_ml_seek_in\"\nexternal pos_in : in_channel -> int = \"caml_ml_pos_in\"\nexternal in_channel_length : in_channel -> int = \"caml_ml_channel_size\"\nexternal close_in : in_channel -> unit = \"caml_ml_close_channel\"\nlet close_in_noerr ic = (try close_in ic with _ -> ())\nexternal set_binary_mode_in : in_channel -> bool -> unit\n                            = \"caml_ml_set_binary_mode\"\n\n(* Output functions on standard output *)\n\nlet print_char c = output_char stdout c\nlet print_string s = output_string stdout s\nlet print_bytes s = output_bytes stdout s\nlet print_int i = output_string stdout (string_of_int i)\nlet print_float f = output_string stdout (string_of_float f)\nlet print_endline s =\n  output_string stdout s; output_char stdout '\\n'; flush stdout\nlet print_newline () = output_char stdout '\\n'; flush stdout\n\n(* Output functions on standard error *)\n\nlet prerr_char c = output_char stderr c\nlet prerr_string s = output_string stderr s\nlet prerr_bytes s = output_bytes stderr s\nlet prerr_int i = output_string stderr (string_of_int i)\nlet prerr_float f = output_string stderr (string_of_float f)\nlet prerr_endline s =\n  output_string stderr s; output_char stderr '\\n'; flush stderr\nlet prerr_newline () = output_char stderr '\\n'; flush stderr\n\n(* Input functions on standard input *)\n\nlet read_line () = flush stdout; input_line stdin\nlet read_int () = int_of_string(read_line())\nlet read_int_opt () = int_of_string_opt(read_line())\nlet read_float () = float_of_string(read_line())\nlet read_float_opt () = float_of_string_opt(read_line())\n\n(* Operations on large files *)\n\nmodule LargeFile =\n  struct\n    external seek_out : out_channel -> int64 -> unit = \"caml_ml_seek_out_64\"\n    external pos_out : out_channel -> int64 = \"caml_ml_pos_out_64\"\n    external out_channel_length : out_channel -> int64\n                                = \"caml_ml_channel_size_64\"\n    external seek_in : in_channel -> int64 -> unit = \"caml_ml_seek_in_64\"\n    external pos_in : in_channel -> int64 = \"caml_ml_pos_in_64\"\n    external in_channel_length : in_channel -> int64 = \"caml_ml_channel_size_64\"\n  end\n\n(* Formats *)\n\ntype ('a, 'b, 'c, 'd, 'e, 'f) format6\n   = ('a, 'b, 'c, 'd, 'e, 'f) CamlinternalFormatBasics.format6\n   = Format of ('a, 'b, 'c, 'd, 'e, 'f) CamlinternalFormatBasics.fmt\n               * string\n\ntype ('a, 'b, 'c, 'd) format4 = ('a, 'b, 'c, 'c, 'c, 'd) format6\n\ntype ('a, 'b, 'c) format = ('a, 'b, 'c, 'c) format4\n\nlet string_of_format (Format (_fmt, str)) = str\n\nexternal format_of_string :\n ('a, 'b, 'c, 'd, 'e, 'f) format6 ->\n ('a, 'b, 'c, 'd, 'e, 'f) format6 = \"%identity\"\n\nlet ( ^^ ) (Format (fmt1, str1)) (Format (fmt2, str2)) =\n  Format (CamlinternalFormatBasics.concat_fmt fmt1 fmt2,\n          str1 ^ \"%,\" ^ str2)\n\n(* Miscellaneous *)\n\nexternal sys_exit : int -> 'a = \"caml_sys_exit\"\n\nlet exit_function = CamlinternalAtomic.make flush_all\n\nlet rec at_exit f =\n  let module Atomic = CamlinternalAtomic in\n  (* MPR#7253, MPR#7796: make sure \"f\" is executed only once *)\n  let f_yet_to_run = Atomic.make true in\n  let old_exit = Atomic.get exit_function in\n  let new_exit () =\n    if Atomic.compare_and_set f_yet_to_run true false then f () ;\n    old_exit ()\n  in\n  let success = Atomic.compare_and_set exit_function old_exit new_exit in\n  if not success then at_exit f\n\nlet do_at_exit () = (CamlinternalAtomic.get exit_function) ()\n\nlet exit retcode =\n  do_at_exit ();\n  sys_exit retcode\n\nlet _ = register_named_value \"Pervasives.do_at_exit\" do_at_exit\n\nexternal major : unit -> unit = \"caml_gc_major\"\nexternal naked_pointers_checked : unit -> bool\n  = \"caml_sys_const_naked_pointers_checked\"\nlet () = if naked_pointers_checked () then at_exit major\n\n(*MODULE_ALIASES*)\nmodule Arg          = Arg\nmodule Array        = Array\nmodule ArrayLabels  = ArrayLabels\nmodule Atomic       = Atomic\nmodule Bigarray     = Bigarray\nmodule Bool         = Bool\nmodule Buffer       = Buffer\nmodule Bytes        = Bytes\nmodule BytesLabels  = BytesLabels\nmodule Callback     = Callback\nmodule Char         = Char\nmodule Complex      = Complex\nmodule Digest       = Digest\nmodule Either       = Either\nmodule Ephemeron    = Ephemeron\nmodule Filename     = Filename\nmodule Float        = Float\nmodule Format       = Format\nmodule Fun          = Fun\nmodule Gc           = Gc\nmodule Genlex       = Genlex\nmodule Hashtbl      = Hashtbl\nmodule Int          = Int\nmodule Int32        = Int32\nmodule Int64        = Int64\nmodule Lazy         = Lazy\nmodule Lexing       = Lexing\nmodule List         = List\nmodule ListLabels   = ListLabels\nmodule Map          = Map\nmodule Marshal      = Marshal\nmodule MoreLabels   = MoreLabels\nmodule Nativeint    = Nativeint\nmodule Obj          = Obj\nmodule Oo           = Oo\nmodule Option       = Option\nmodule Parsing      = Parsing\nmodule Pervasives   = Pervasives\nmodule Printexc     = Printexc\nmodule Printf       = Printf\nmodule Queue        = Queue\nmodule Random       = Random\nmodule Result       = Result\nmodule Scanf        = Scanf\nmodule Seq          = Seq\nmodule Set          = Set\nmodule Stack        = Stack\nmodule StdLabels    = StdLabels\nmodule Stream       = Stream\nmodule String       = String\nmodule StringLabels = StringLabels\nmodule Sys          = Sys\nmodule Uchar        = Uchar\nmodule Unit         = Unit\nmodule Weak         = Weak\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*                   Jeremie Dimino, Jane Street Europe                   *)\n(*                                                                        *)\n(*   Copyright 2017 Jane Street Group LLC                                 *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(** @deprecated Use {!Stdlib} *)\n\nexternal raise : exn -> 'a = \"%raise\"\nexternal raise_notrace : exn -> 'a = \"%raise_notrace\"\nlet invalid_arg = invalid_arg\nlet failwith = failwith\nexception Exit\nexternal ( = ) : 'a -> 'a -> bool = \"%equal\"\nexternal ( <> ) : 'a -> 'a -> bool = \"%notequal\"\nexternal ( < ) : 'a -> 'a -> bool = \"%lessthan\"\nexternal ( > ) : 'a -> 'a -> bool = \"%greaterthan\"\nexternal ( <= ) : 'a -> 'a -> bool = \"%lessequal\"\nexternal ( >= ) : 'a -> 'a -> bool = \"%greaterequal\"\nexternal compare : 'a -> 'a -> int = \"%compare\"\nlet min = min\nlet max = max\nexternal ( == ) : 'a -> 'a -> bool = \"%eq\"\nexternal ( != ) : 'a -> 'a -> bool = \"%noteq\"\nexternal not : bool -> bool = \"%boolnot\"\nexternal ( && ) : bool -> bool -> bool = \"%sequand\"\nexternal ( & ) : bool -> bool -> bool = \"%sequand\"\n  [@@ocaml.deprecated \"Use (&&) instead.\"]\nexternal ( || ) : bool -> bool -> bool = \"%sequor\"\nexternal ( or ) : bool -> bool -> bool = \"%sequor\"\n  [@@ocaml.deprecated \"Use (||) instead.\"]\nexternal __LOC__ : string = \"%loc_LOC\"\nexternal __FILE__ : string = \"%loc_FILE\"\nexternal __LINE__ : int = \"%loc_LINE\"\nexternal __MODULE__ : string = \"%loc_MODULE\"\nexternal __POS__ : string * int * int * int = \"%loc_POS\"\nexternal __LOC_OF__ : 'a -> string * 'a = \"%loc_LOC\"\nexternal __LINE_OF__ : 'a -> int * 'a = \"%loc_LINE\"\nexternal __POS_OF__ : 'a -> (string * int * int * int) * 'a = \"%loc_POS\"\nexternal ( |> ) : 'a -> ('a -> 'b) -> 'b = \"%revapply\"\nexternal ( @@ ) : ('a -> 'b) -> 'a -> 'b = \"%apply\"\nexternal ( ~- ) : int -> int = \"%negint\"\nexternal ( ~+ ) : int -> int = \"%identity\"\nexternal succ : int -> int = \"%succint\"\nexternal pred : int -> int = \"%predint\"\nexternal ( + ) : int -> int -> int = \"%addint\"\nexternal ( - ) : int -> int -> int = \"%subint\"\nexternal ( * ) : int -> int -> int = \"%mulint\"\nexternal ( / ) : int -> int -> int = \"%divint\"\nexternal ( mod ) : int -> int -> int = \"%modint\"\nlet abs = abs\nlet max_int = max_int\nlet min_int = min_int\nexternal ( land ) : int -> int -> int = \"%andint\"\nexternal ( lor ) : int -> int -> int = \"%orint\"\nexternal ( lxor ) : int -> int -> int = \"%xorint\"\nlet lnot = lnot\nexternal ( lsl ) : int -> int -> int = \"%lslint\"\nexternal ( lsr ) : int -> int -> int = \"%lsrint\"\nexternal ( asr ) : int -> int -> int = \"%asrint\"\nexternal ( ~-. ) : float -> float = \"%negfloat\"\nexternal ( ~+. ) : float -> float = \"%identity\"\nexternal ( +. ) : float -> float -> float = \"%addfloat\"\nexternal ( -. ) : float -> float -> float = \"%subfloat\"\nexternal ( *. ) : float -> float -> float = \"%mulfloat\"\nexternal ( /. ) : float -> float -> float = \"%divfloat\"\nexternal ( ** ) : float -> float -> float = \"caml_power_float\" \"pow\"\n  [@@unboxed] [@@noalloc]\nexternal sqrt : float -> float = \"caml_sqrt_float\" \"sqrt\"\n  [@@unboxed] [@@noalloc]\nexternal exp : float -> float = \"caml_exp_float\" \"exp\" [@@unboxed] [@@noalloc]\nexternal log : float -> float = \"caml_log_float\" \"log\" [@@unboxed] [@@noalloc]\nexternal log10 : float -> float = \"caml_log10_float\" \"log10\"\n  [@@unboxed] [@@noalloc]\nexternal expm1 : float -> float = \"caml_expm1_float\" \"caml_expm1\"\n  [@@unboxed] [@@noalloc]\nexternal log1p : float -> float = \"caml_log1p_float\" \"caml_log1p\"\n  [@@unboxed] [@@noalloc]\nexternal cos : float -> float = \"caml_cos_float\" \"cos\" [@@unboxed] [@@noalloc]\nexternal sin : float -> float = \"caml_sin_float\" \"sin\" [@@unboxed] [@@noalloc]\nexternal tan : float -> float = \"caml_tan_float\" \"tan\" [@@unboxed] [@@noalloc]\nexternal acos : float -> float = \"caml_acos_float\" \"acos\"\n  [@@unboxed] [@@noalloc]\nexternal asin : float -> float = \"caml_asin_float\" \"asin\"\n  [@@unboxed] [@@noalloc]\nexternal atan : float -> float = \"caml_atan_float\" \"atan\"\n  [@@unboxed] [@@noalloc]\nexternal atan2 : float -> float -> float = \"caml_atan2_float\" \"atan2\"\n  [@@unboxed] [@@noalloc]\nexternal hypot : float -> float -> float = \"caml_hypot_float\" \"caml_hypot\"\n  [@@unboxed] [@@noalloc]\nexternal cosh : float -> float = \"caml_cosh_float\" \"cosh\"\n  [@@unboxed] [@@noalloc]\nexternal sinh : float -> float = \"caml_sinh_float\" \"sinh\"\n  [@@unboxed] [@@noalloc]\nexternal tanh : float -> float = \"caml_tanh_float\" \"tanh\"\n  [@@unboxed] [@@noalloc]\nexternal ceil : float -> float = \"caml_ceil_float\" \"ceil\"\n  [@@unboxed] [@@noalloc]\nexternal floor : float -> float = \"caml_floor_float\" \"floor\"\n  [@@unboxed] [@@noalloc]\nexternal abs_float : float -> float = \"%absfloat\"\nexternal copysign : float -> float -> float\n                  = \"caml_copysign_float\" \"caml_copysign\"\n                  [@@unboxed] [@@noalloc]\nexternal mod_float : float -> float -> float = \"caml_fmod_float\" \"fmod\"\n  [@@unboxed] [@@noalloc]\nexternal frexp : float -> float * int = \"caml_frexp_float\"\nexternal ldexp : (float [@unboxed]) -> (int [@untagged]) -> (float [@unboxed]) =\n  \"caml_ldexp_float\" \"caml_ldexp_float_unboxed\" [@@noalloc]\nexternal modf : float -> float * float = \"caml_modf_float\"\nexternal float : int -> float = \"%floatofint\"\nexternal float_of_int : int -> float = \"%floatofint\"\nexternal truncate : float -> int = \"%intoffloat\"\nexternal int_of_float : float -> int = \"%intoffloat\"\nlet infinity = infinity\nlet neg_infinity = neg_infinity\nlet nan = nan\nlet max_float = max_float\nlet min_float = min_float\nlet epsilon_float = epsilon_float\ntype nonrec fpclass = fpclass =\n    FP_normal\n  | FP_subnormal\n  | FP_zero\n  | FP_infinite\n  | FP_nan\nexternal classify_float : (float [@unboxed]) -> fpclass =\n  \"caml_classify_float\" \"caml_classify_float_unboxed\" [@@noalloc]\nlet ( ^ ) = ( ^ )\nexternal int_of_char : char -> int = \"%identity\"\nlet char_of_int = char_of_int\nexternal ignore : 'a -> unit = \"%ignore\"\nlet string_of_bool = string_of_bool\nlet bool_of_string = bool_of_string\nlet bool_of_string_opt = bool_of_string_opt\nlet string_of_int = string_of_int\nexternal int_of_string : string -> int = \"caml_int_of_string\"\nlet int_of_string_opt = int_of_string_opt\nlet string_of_float = string_of_float\nexternal float_of_string : string -> float = \"caml_float_of_string\"\nlet float_of_string_opt = float_of_string_opt\nexternal fst : 'a * 'b -> 'a = \"%field0\"\nexternal snd : 'a * 'b -> 'b = \"%field1\"\nlet ( @ )  = ( @ )\ntype nonrec in_channel = in_channel\ntype nonrec out_channel = out_channel\nlet stdin = stdin\nlet stdout = stdout\nlet stderr = stderr\nlet print_char = print_char\nlet print_string = print_string\nlet print_bytes = print_bytes\nlet print_int = print_int\nlet print_float = print_float\nlet print_endline = print_endline\nlet print_newline = print_newline\nlet prerr_char = prerr_char\nlet prerr_string = prerr_string\nlet prerr_bytes = prerr_bytes\nlet prerr_int = prerr_int\nlet prerr_float = prerr_float\nlet prerr_endline = prerr_endline\nlet prerr_newline = prerr_newline\nlet read_line = read_line\nlet read_int = read_int\nlet read_int_opt = read_int_opt\nlet read_float = read_float\nlet read_float_opt = read_float_opt\ntype nonrec open_flag = open_flag =\n    Open_rdonly\n  | Open_wronly\n  | Open_append\n  | Open_creat\n  | Open_trunc\n  | Open_excl\n  | Open_binary\n  | Open_text\n  | Open_nonblock\nlet open_out = open_out\nlet open_out_bin = open_out_bin\nlet open_out_gen = open_out_gen\nlet flush = flush\nlet flush_all = flush_all\nlet output_char = output_char\nlet output_string = output_string\nlet output_bytes = output_bytes\nlet output = output\nlet output_substring = output_substring\nlet output_byte = output_byte\nlet output_binary_int = output_binary_int\nlet output_value = output_value\nlet seek_out = seek_out\nlet pos_out = pos_out\nlet out_channel_length = out_channel_length\nlet close_out = close_out\nlet close_out_noerr = close_out_noerr\nlet set_binary_mode_out = set_binary_mode_out\nlet open_in = open_in\nlet open_in_bin = open_in_bin\nlet open_in_gen = open_in_gen\nlet input_char = input_char\nlet input_line = input_line\nlet input = input\nlet really_input = really_input\nlet really_input_string = really_input_string\nlet input_byte = input_byte\nlet input_binary_int = input_binary_int\nlet input_value = input_value\nlet seek_in = seek_in\nlet pos_in = pos_in\nlet in_channel_length = in_channel_length\nlet close_in = close_in\nlet close_in_noerr = close_in_noerr\nlet set_binary_mode_in = set_binary_mode_in\nmodule LargeFile = LargeFile\ntype nonrec 'a ref = 'a ref = { mutable contents : 'a }\nexternal ref : 'a -> 'a ref = \"%makemutable\"\nexternal ( ! ) : 'a ref -> 'a = \"%field0\"\nexternal ( := ) : 'a ref -> 'a -> unit = \"%setfield0\"\nexternal incr : int ref -> unit = \"%incr\"\nexternal decr : int ref -> unit = \"%decr\"\ntype nonrec ('a,'b) result = ('a,'b) result = Ok of 'a | Error of 'b\ntype ('a, 'b, 'c, 'd, 'e, 'f) format6 =\n  ('a, 'b, 'c, 'd, 'e, 'f) CamlinternalFormatBasics.format6\ntype ('a, 'b, 'c, 'd) format4 = ('a, 'b, 'c, 'c, 'c, 'd) format6\ntype ('a, 'b, 'c) format = ('a, 'b, 'c, 'c) format4\nlet string_of_format = string_of_format\nexternal format_of_string :\n  ('a, 'b, 'c, 'd, 'e, 'f) format6 ->\n  ('a, 'b, 'c, 'd, 'e, 'f) format6 = \"%identity\"\nlet ( ^^ ) = ( ^^ )\nlet exit = exit\nlet at_exit = at_exit\nlet valid_float_lexem = valid_float_lexem\nlet do_at_exit = do_at_exit\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*                 Simon Cruanes                                          *)\n(*                                                                        *)\n(*   Copyright 2017 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Module [Seq]: functional iterators *)\n\ntype +'a node =\n  | Nil\n  | Cons of 'a * 'a t\n\nand 'a t = unit -> 'a node\n\nlet empty () = Nil\n\nlet return x () = Cons (x, empty)\n\nlet cons x next () = Cons (x, next)\n\nlet rec append seq1 seq2 () =\n  match seq1() with\n  | Nil -> seq2()\n  | Cons (x, next) -> Cons (x, append next seq2)\n\nlet rec map f seq () = match seq() with\n  | Nil -> Nil\n  | Cons (x, next) -> Cons (f x, map f next)\n\nlet rec filter_map f seq () = match seq() with\n  | Nil -> Nil\n  | Cons (x, next) ->\n      match f x with\n        | None -> filter_map f next ()\n        | Some y -> Cons (y, filter_map f next)\n\nlet rec filter f seq () = match seq() with\n  | Nil -> Nil\n  | Cons (x, next) ->\n      if f x\n      then Cons (x, filter f next)\n      else filter f next ()\n\nlet rec concat seq () = match seq () with\n  | Nil -> Nil\n  | Cons (x, next) ->\n     append x (concat next) ()\n\nlet rec flat_map f seq () = match seq () with\n  | Nil -> Nil\n  | Cons (x, next) ->\n    append (f x) (flat_map f next) ()\n\nlet concat_map = flat_map\n\nlet fold_left f acc seq =\n  let rec aux f acc seq = match seq () with\n    | Nil -> acc\n    | Cons (x, next) ->\n        let acc = f acc x in\n        aux f acc next\n  in\n  aux f acc seq\n\nlet iter f seq =\n  let rec aux seq = match seq () with\n    | Nil -> ()\n    | Cons (x, next) ->\n        f x;\n        aux next\n  in\n  aux seq\n\nlet rec unfold f u () =\n  match f u with\n  | None -> Nil\n  | Some (x, u') -> Cons (x, unfold f u')\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*                         The OCaml programmers                          *)\n(*                                                                        *)\n(*   Copyright 2018 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\ntype 'a t = 'a option = None | Some of 'a\n\nlet none = None\nlet some v = Some v\nlet value o ~default = match o with Some v -> v | None -> default\nlet get = function Some v -> v | None -> invalid_arg \"option is None\"\nlet bind o f = match o with None -> None | Some v -> f v\nlet join = function Some o -> o | None -> None\nlet map f o = match o with None -> None | Some v -> Some (f v)\nlet fold ~none ~some = function Some v -> some v | None -> none\nlet iter f = function Some v -> f v | None -> ()\nlet is_none = function None -> true | Some _ -> false\nlet is_some = function None -> false | Some _ -> true\n\nlet equal eq o0 o1 = match o0, o1 with\n| Some v0, Some v1 -> eq v0 v1\n| None, None -> true\n| _ -> false\n\nlet compare cmp o0 o1 = match o0, o1 with\n| Some v0, Some v1 -> cmp v0 v1\n| None, None -> 0\n| None, Some _ -> -1\n| Some _, None -> 1\n\nlet to_result ~none = function None -> Error none | Some v -> Ok v\nlet to_list = function None -> [] | Some v -> [v]\nlet to_seq = function None -> Seq.empty | Some v -> Seq.return v\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*         Gabriel Scherer, projet Parsifal, INRIA Saclay                 *)\n(*                                                                        *)\n(*   Copyright 2019 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\ntype ('a, 'b) t = Left of 'a | Right of 'b\n\nlet left v = Left v\nlet right v = Right v\n\nlet is_left = function\n| Left _ -> true\n| Right _ -> false\n\nlet is_right = function\n| Left _ -> false\n| Right _ -> true\n\nlet find_left = function\n| Left v -> Some v\n| Right _ -> None\n\nlet find_right = function\n| Left _ -> None\n| Right v -> Some v\n\nlet map_left f = function\n| Left v -> Left (f v)\n| Right _ as e -> e\n\nlet map_right f = function\n| Left _ as e -> e\n| Right v -> Right (f v)\n\nlet map ~left ~right = function\n| Left v -> Left (left v)\n| Right v -> Right (right v)\n\nlet fold ~left ~right = function\n| Left v -> left v\n| Right v -> right v\n\nlet iter = fold\n\nlet for_all = fold\n\nlet equal ~left ~right e1 e2 = match e1, e2 with\n| Left v1, Left v2 -> left v1 v2\n| Right v1, Right v2 -> right v1 v2\n| Left _, Right _ | Right _, Left _ -> false\n\nlet compare ~left ~right e1 e2 = match e1, e2 with\n| Left v1, Left v2 -> left v1 v2\n| Right v1, Right v2 -> right v1 v2\n| Left _, Right _ -> (-1)\n| Right _, Left _ -> 1\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*                         The OCaml programmers                          *)\n(*                                                                        *)\n(*   Copyright 2018 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\ntype ('a, 'e) t = ('a, 'e) result = Ok of 'a | Error of 'e\n\nlet ok v = Ok v\nlet error e = Error e\nlet value r ~default = match r with Ok v -> v | Error _ -> default\nlet get_ok = function Ok v -> v | Error _ -> invalid_arg \"result is Error _\"\nlet get_error = function Error e -> e | Ok _ -> invalid_arg \"result is Ok _\"\nlet bind r f = match r with Ok v -> f v | Error _ as e -> e\nlet join = function Ok r -> r | Error _ as e -> e\nlet map f = function Ok v -> Ok (f v) | Error _ as e -> e\nlet map_error f = function Error e -> Error (f e) | Ok _ as v -> v\nlet fold ~ok ~error = function Ok v -> ok v | Error e -> error e\nlet iter f = function Ok v -> f v | Error _ -> ()\nlet iter_error f = function Error e -> f e | Ok _ -> ()\nlet is_ok = function Ok _ -> true | Error _ -> false\nlet is_error = function Error _ -> true | Ok _ -> false\n\nlet equal ~ok ~error r0 r1 = match r0, r1 with\n| Ok v0, Ok v1 -> ok v0 v1\n| Error e0, Error e1 -> error e0 e1\n| _, _ -> false\n\nlet compare ~ok ~error r0 r1 = match r0, r1 with\n| Ok v0, Ok v1 -> ok v0 v1\n| Error e0, Error e1 -> error e0 e1\n| Ok _, Error _ -> -1\n| Error _, Ok _ -> 1\n\nlet to_option = function Ok v -> Some v | Error _ -> None\nlet to_list = function Ok v -> [v] | Error _ -> []\nlet to_seq = function Ok v -> Seq.return v | Error _ -> Seq.empty\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*                         The OCaml programmers                          *)\n(*                                                                        *)\n(*   Copyright 2018 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\ntype t = bool = false | true\n\nexternal not : bool -> bool = \"%boolnot\"\nexternal ( && ) : bool -> bool -> bool = \"%sequand\"\nexternal ( || ) : bool -> bool -> bool = \"%sequor\"\nlet equal : bool -> bool -> bool = ( = )\nlet compare : bool -> bool -> int = Stdlib.compare\nexternal to_int : bool -> int = \"%identity\"\nlet to_float = function false -> 0. | true -> 1.\n\n(*\nlet of_string = function\n| \"false\" -> Some false\n| \"true\" -> Some true\n| _ -> None\n*)\n\nlet to_string = function false -> \"false\" | true -> \"true\"\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Character operations *)\n\nexternal code: char -> int = \"%identity\"\nexternal unsafe_chr: int -> char = \"%identity\"\n\nlet chr n =\n  if n < 0 || n > 255 then invalid_arg \"Char.chr\" else unsafe_chr n\n\nexternal bytes_create: int -> bytes = \"caml_create_bytes\"\nexternal bytes_unsafe_set : bytes -> int -> char -> unit\n                           = \"%bytes_unsafe_set\"\nexternal unsafe_to_string : bytes -> string = \"%bytes_to_string\"\n\nlet escaped = function\n  | '\\'' -> \"\\\\'\"\n  | '\\\\' -> \"\\\\\\\\\"\n  | '\\n' -> \"\\\\n\"\n  | '\\t' -> \"\\\\t\"\n  | '\\r' -> \"\\\\r\"\n  | '\\b' -> \"\\\\b\"\n  | ' ' .. '~' as c ->\n      let s = bytes_create 1 in\n      bytes_unsafe_set s 0 c;\n      unsafe_to_string s\n  | c ->\n      let n = code c in\n      let s = bytes_create 4 in\n      bytes_unsafe_set s 0 '\\\\';\n      bytes_unsafe_set s 1 (unsafe_chr (48 + n / 100));\n      bytes_unsafe_set s 2 (unsafe_chr (48 + (n / 10) mod 10));\n      bytes_unsafe_set s 3 (unsafe_chr (48 + n mod 10));\n      unsafe_to_string s\n\nlet lowercase = function\n  | 'A' .. 'Z'\n  | '\\192' .. '\\214'\n  | '\\216' .. '\\222' as c ->\n    unsafe_chr(code c + 32)\n  | c -> c\n\nlet uppercase = function\n  | 'a' .. 'z'\n  | '\\224' .. '\\246'\n  | '\\248' .. '\\254' as c ->\n    unsafe_chr(code c - 32)\n  | c -> c\n\nlet lowercase_ascii = function\n  | 'A' .. 'Z' as c -> unsafe_chr(code c + 32)\n  | c -> c\n\nlet uppercase_ascii = function\n  | 'a' .. 'z' as c -> unsafe_chr(code c - 32)\n  | c -> c\n\ntype t = char\n\nlet compare c1 c2 = code c1 - code c2\nlet equal (c1: t) (c2: t) = compare c1 c2 = 0\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*                           Daniel C. Buenzli                            *)\n(*                                                                        *)\n(*   Copyright 2014 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\nexternal format_int : string -> int -> string = \"caml_format_int\"\n\nlet err_no_pred = \"U+0000 has no predecessor\"\nlet err_no_succ = \"U+10FFFF has no successor\"\nlet err_not_sv i = format_int \"%X\" i ^ \" is not an Unicode scalar value\"\nlet err_not_latin1 u = \"U+\" ^ format_int \"%04X\" u ^ \" is not a latin1 character\"\n\ntype t = int\n\nlet min = 0x0000\nlet max = 0x10FFFF\nlet lo_bound = 0xD7FF\nlet hi_bound = 0xE000\n\nlet bom = 0xFEFF\nlet rep = 0xFFFD\n\nlet succ u =\n  if u = lo_bound then hi_bound else\n  if u = max then invalid_arg err_no_succ else\n  u + 1\n\nlet pred u =\n  if u = hi_bound then lo_bound else\n  if u = min then invalid_arg err_no_pred else\n  u - 1\n\nlet is_valid i = (min <= i && i <= lo_bound) || (hi_bound <= i && i <= max)\nlet of_int i = if is_valid i then i else invalid_arg (err_not_sv i)\nexternal unsafe_of_int : int -> t = \"%identity\"\nexternal to_int : t -> int = \"%identity\"\n\nlet is_char u = u < 256\nlet of_char c = Char.code c\nlet to_char u =\n  if u > 255 then invalid_arg (err_not_latin1 u) else\n  Char.unsafe_chr u\n\nlet unsafe_to_char = Char.unsafe_chr\n\nlet equal : int -> int -> bool = ( = )\nlet compare : int -> int -> int = Stdlib.compare\nlet hash = to_int\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* An alias for the type of lists. *)\ntype 'a t = 'a list = [] | (::) of 'a * 'a list\n\n(* List operations *)\n\nlet rec length_aux len = function\n    [] -> len\n  | _::l -> length_aux (len + 1) l\n\nlet length l = length_aux 0 l\n\nlet cons a l = a::l\n\nlet hd = function\n    [] -> failwith \"hd\"\n  | a::_ -> a\n\nlet tl = function\n    [] -> failwith \"tl\"\n  | _::l -> l\n\nlet nth l n =\n  if n < 0 then invalid_arg \"List.nth\" else\n  let rec nth_aux l n =\n    match l with\n    | [] -> failwith \"nth\"\n    | a::l -> if n = 0 then a else nth_aux l (n-1)\n  in nth_aux l n\n\nlet nth_opt l n =\n  if n < 0 then invalid_arg \"List.nth\" else\n  let rec nth_aux l n =\n    match l with\n    | [] -> None\n    | a::l -> if n = 0 then Some a else nth_aux l (n-1)\n  in nth_aux l n\n\nlet append = (@)\n\nlet rec rev_append l1 l2 =\n  match l1 with\n    [] -> l2\n  | a :: l -> rev_append l (a :: l2)\n\nlet rev l = rev_append l []\n\nlet rec init_tailrec_aux acc i n f =\n  if i >= n then acc\n  else init_tailrec_aux (f i :: acc) (i+1) n f\n\nlet rec init_aux i n f =\n  if i >= n then []\n  else\n    let r = f i in\n    r :: init_aux (i+1) n f\n\nlet rev_init_threshold =\n  match Sys.backend_type with\n  | Sys.Native | Sys.Bytecode -> 10_000\n  (* We don't know the size of the stack, better be safe and assume it's\n     small. *)\n  | Sys.Other _ -> 50\n\nlet init len f =\n  if len < 0 then invalid_arg \"List.init\" else\n  if len > rev_init_threshold then rev (init_tailrec_aux [] 0 len f)\n  else init_aux 0 len f\n\nlet rec flatten = function\n    [] -> []\n  | l::r -> l @ flatten r\n\nlet concat = flatten\n\nlet rec map f = function\n    [] -> []\n  | a::l -> let r = f a in r :: map f l\n\nlet rec mapi i f = function\n    [] -> []\n  | a::l -> let r = f i a in r :: mapi (i + 1) f l\n\nlet mapi f l = mapi 0 f l\n\nlet rev_map f l =\n  let rec rmap_f accu = function\n    | [] -> accu\n    | a::l -> rmap_f (f a :: accu) l\n  in\n  rmap_f [] l\n\n\nlet rec iter f = function\n    [] -> ()\n  | a::l -> f a; iter f l\n\nlet rec iteri i f = function\n    [] -> ()\n  | a::l -> f i a; iteri (i + 1) f l\n\nlet iteri f l = iteri 0 f l\n\nlet rec fold_left f accu l =\n  match l with\n    [] -> accu\n  | a::l -> fold_left f (f accu a) l\n\nlet rec fold_right f l accu =\n  match l with\n    [] -> accu\n  | a::l -> f a (fold_right f l accu)\n\nlet rec map2 f l1 l2 =\n  match (l1, l2) with\n    ([], []) -> []\n  | (a1::l1, a2::l2) -> let r = f a1 a2 in r :: map2 f l1 l2\n  | (_, _) -> invalid_arg \"List.map2\"\n\nlet rev_map2 f l1 l2 =\n  let rec rmap2_f accu l1 l2 =\n    match (l1, l2) with\n    | ([], []) -> accu\n    | (a1::l1, a2::l2) -> rmap2_f (f a1 a2 :: accu) l1 l2\n    | (_, _) -> invalid_arg \"List.rev_map2\"\n  in\n  rmap2_f [] l1 l2\n\n\nlet rec iter2 f l1 l2 =\n  match (l1, l2) with\n    ([], []) -> ()\n  | (a1::l1, a2::l2) -> f a1 a2; iter2 f l1 l2\n  | (_, _) -> invalid_arg \"List.iter2\"\n\nlet rec fold_left2 f accu l1 l2 =\n  match (l1, l2) with\n    ([], []) -> accu\n  | (a1::l1, a2::l2) -> fold_left2 f (f accu a1 a2) l1 l2\n  | (_, _) -> invalid_arg \"List.fold_left2\"\n\nlet rec fold_right2 f l1 l2 accu =\n  match (l1, l2) with\n    ([], []) -> accu\n  | (a1::l1, a2::l2) -> f a1 a2 (fold_right2 f l1 l2 accu)\n  | (_, _) -> invalid_arg \"List.fold_right2\"\n\nlet rec for_all p = function\n    [] -> true\n  | a::l -> p a && for_all p l\n\nlet rec exists p = function\n    [] -> false\n  | a::l -> p a || exists p l\n\nlet rec for_all2 p l1 l2 =\n  match (l1, l2) with\n    ([], []) -> true\n  | (a1::l1, a2::l2) -> p a1 a2 && for_all2 p l1 l2\n  | (_, _) -> invalid_arg \"List.for_all2\"\n\nlet rec exists2 p l1 l2 =\n  match (l1, l2) with\n    ([], []) -> false\n  | (a1::l1, a2::l2) -> p a1 a2 || exists2 p l1 l2\n  | (_, _) -> invalid_arg \"List.exists2\"\n\nlet rec mem x = function\n    [] -> false\n  | a::l -> compare a x = 0 || mem x l\n\nlet rec memq x = function\n    [] -> false\n  | a::l -> a == x || memq x l\n\nlet rec assoc x = function\n    [] -> raise Not_found\n  | (a,b)::l -> if compare a x = 0 then b else assoc x l\n\nlet rec assoc_opt x = function\n    [] -> None\n  | (a,b)::l -> if compare a x = 0 then Some b else assoc_opt x l\n\nlet rec assq x = function\n    [] -> raise Not_found\n  | (a,b)::l -> if a == x then b else assq x l\n\nlet rec assq_opt x = function\n    [] -> None\n  | (a,b)::l -> if a == x then Some b else assq_opt x l\n\nlet rec mem_assoc x = function\n  | [] -> false\n  | (a, _) :: l -> compare a x = 0 || mem_assoc x l\n\nlet rec mem_assq x = function\n  | [] -> false\n  | (a, _) :: l -> a == x || mem_assq x l\n\nlet rec remove_assoc x = function\n  | [] -> []\n  | (a, _ as pair) :: l ->\n      if compare a x = 0 then l else pair :: remove_assoc x l\n\nlet rec remove_assq x = function\n  | [] -> []\n  | (a, _ as pair) :: l -> if a == x then l else pair :: remove_assq x l\n\nlet rec find p = function\n  | [] -> raise Not_found\n  | x :: l -> if p x then x else find p l\n\nlet rec find_opt p = function\n  | [] -> None\n  | x :: l -> if p x then Some x else find_opt p l\n\nlet rec find_map f = function\n  | [] -> None\n  | x :: l ->\n     begin match f x with\n       | Some _ as result -> result\n       | None -> find_map f l\n     end\n\nlet find_all p =\n  let rec find accu = function\n  | [] -> rev accu\n  | x :: l -> if p x then find (x :: accu) l else find accu l in\n  find []\n\nlet filter = find_all\n\nlet filteri p l =\n  let rec aux i acc = function\n  | [] -> rev acc\n  | x::l -> aux (i + 1) (if p i x then x::acc else acc) l\n  in\n  aux 0 [] l\n\nlet filter_map f =\n  let rec aux accu = function\n    | [] -> rev accu\n    | x :: l ->\n        match f x with\n        | None -> aux accu l\n        | Some v -> aux (v :: accu) l\n  in\n  aux []\n\nlet concat_map f l =\n  let rec aux f acc = function\n    | [] -> rev acc\n    | x :: l ->\n       let xs = f x in\n       aux f (rev_append xs acc) l\n  in aux f [] l\n\nlet fold_left_map f accu l =\n  let rec aux accu l_accu = function\n    | [] -> accu, rev l_accu\n    | x :: l ->\n        let accu, x = f accu x in\n        aux accu (x :: l_accu) l in\n  aux accu [] l\n\nlet partition p l =\n  let rec part yes no = function\n  | [] -> (rev yes, rev no)\n  | x :: l -> if p x then part (x :: yes) no l else part yes (x :: no) l in\n  part [] [] l\n\nlet partition_map p l =\n  let rec part left right = function\n  | [] -> (rev left, rev right)\n  | x :: l ->\n     begin match p x with\n       | Either.Left v -> part (v :: left) right l\n       | Either.Right v -> part left (v :: right) l\n     end\n  in\n  part [] [] l\n\nlet rec split = function\n    [] -> ([], [])\n  | (x,y)::l ->\n      let (rx, ry) = split l in (x::rx, y::ry)\n\nlet rec combine l1 l2 =\n  match (l1, l2) with\n    ([], []) -> []\n  | (a1::l1, a2::l2) -> (a1, a2) :: combine l1 l2\n  | (_, _) -> invalid_arg \"List.combine\"\n\n(** sorting *)\n\nlet rec merge cmp l1 l2 =\n  match l1, l2 with\n  | [], l2 -> l2\n  | l1, [] -> l1\n  | h1 :: t1, h2 :: t2 ->\n      if cmp h1 h2 <= 0\n      then h1 :: merge cmp t1 l2\n      else h2 :: merge cmp l1 t2\n\n\nlet stable_sort cmp l =\n  let rec rev_merge l1 l2 accu =\n    match l1, l2 with\n    | [], l2 -> rev_append l2 accu\n    | l1, [] -> rev_append l1 accu\n    | h1::t1, h2::t2 ->\n        if cmp h1 h2 <= 0\n        then rev_merge t1 l2 (h1::accu)\n        else rev_merge l1 t2 (h2::accu)\n  in\n  let rec rev_merge_rev l1 l2 accu =\n    match l1, l2 with\n    | [], l2 -> rev_append l2 accu\n    | l1, [] -> rev_append l1 accu\n    | h1::t1, h2::t2 ->\n        if cmp h1 h2 > 0\n        then rev_merge_rev t1 l2 (h1::accu)\n        else rev_merge_rev l1 t2 (h2::accu)\n  in\n  let rec sort n l =\n    match n, l with\n    | 2, x1 :: x2 :: tl ->\n        let s = if cmp x1 x2 <= 0 then [x1; x2] else [x2; x1] in\n        (s, tl)\n    | 3, x1 :: x2 :: x3 :: tl ->\n        let s =\n          if cmp x1 x2 <= 0 then\n            if cmp x2 x3 <= 0 then [x1; x2; x3]\n            else if cmp x1 x3 <= 0 then [x1; x3; x2]\n            else [x3; x1; x2]\n          else if cmp x1 x3 <= 0 then [x2; x1; x3]\n          else if cmp x2 x3 <= 0 then [x2; x3; x1]\n          else [x3; x2; x1]\n        in\n        (s, tl)\n    | n, l ->\n        let n1 = n asr 1 in\n        let n2 = n - n1 in\n        let s1, l2 = rev_sort n1 l in\n        let s2, tl = rev_sort n2 l2 in\n        (rev_merge_rev s1 s2 [], tl)\n  and rev_sort n l =\n    match n, l with\n    | 2, x1 :: x2 :: tl ->\n        let s = if cmp x1 x2 > 0 then [x1; x2] else [x2; x1] in\n        (s, tl)\n    | 3, x1 :: x2 :: x3 :: tl ->\n        let s =\n          if cmp x1 x2 > 0 then\n            if cmp x2 x3 > 0 then [x1; x2; x3]\n            else if cmp x1 x3 > 0 then [x1; x3; x2]\n            else [x3; x1; x2]\n          else if cmp x1 x3 > 0 then [x2; x1; x3]\n          else if cmp x2 x3 > 0 then [x2; x3; x1]\n          else [x3; x2; x1]\n        in\n        (s, tl)\n    | n, l ->\n        let n1 = n asr 1 in\n        let n2 = n - n1 in\n        let s1, l2 = sort n1 l in\n        let s2, tl = sort n2 l2 in\n        (rev_merge s1 s2 [], tl)\n  in\n  let len = length l in\n  if len < 2 then l else fst (sort len l)\n\n\nlet sort = stable_sort\nlet fast_sort = stable_sort\n\n(* Note: on a list of length between about 100000 (depending on the minor\n   heap size and the type of the list) and Sys.max_array_size, it is\n   actually faster to use the following, but it might also use more memory\n   because the argument list cannot be deallocated incrementally.\n\n   Also, there seems to be a bug in this code or in the\n   implementation of obj_truncate.\n\nexternal obj_truncate : 'a array -> int -> unit = \"caml_obj_truncate\"\n\nlet array_to_list_in_place a =\n  let l = Array.length a in\n  let rec loop accu n p =\n    if p <= 0 then accu else begin\n      if p = n then begin\n        obj_truncate a p;\n        loop (a.(p-1) :: accu) (n-1000) (p-1)\n      end else begin\n        loop (a.(p-1) :: accu) n (p-1)\n      end\n    end\n  in\n  loop [] (l-1000) l\n\n\nlet stable_sort cmp l =\n  let a = Array.of_list l in\n  Array.stable_sort cmp a;\n  array_to_list_in_place a\n\n*)\n\n\n(** sorting + removing duplicates *)\n\nlet sort_uniq cmp l =\n  let rec rev_merge l1 l2 accu =\n    match l1, l2 with\n    | [], l2 -> rev_append l2 accu\n    | l1, [] -> rev_append l1 accu\n    | h1::t1, h2::t2 ->\n        let c = cmp h1 h2 in\n        if c = 0 then rev_merge t1 t2 (h1::accu)\n        else if c < 0\n        then rev_merge t1 l2 (h1::accu)\n        else rev_merge l1 t2 (h2::accu)\n  in\n  let rec rev_merge_rev l1 l2 accu =\n    match l1, l2 with\n    | [], l2 -> rev_append l2 accu\n    | l1, [] -> rev_append l1 accu\n    | h1::t1, h2::t2 ->\n        let c = cmp h1 h2 in\n        if c = 0 then rev_merge_rev t1 t2 (h1::accu)\n        else if c > 0\n        then rev_merge_rev t1 l2 (h1::accu)\n        else rev_merge_rev l1 t2 (h2::accu)\n  in\n  let rec sort n l =\n    match n, l with\n    | 2, x1 :: x2 :: tl ->\n        let s =\n          let c = cmp x1 x2 in\n          if c = 0 then [x1] else if c < 0 then [x1; x2] else [x2; x1]\n        in\n        (s, tl)\n    | 3, x1 :: x2 :: x3 :: tl ->\n        let s =\n          let c = cmp x1 x2 in\n          if c = 0 then\n            let c = cmp x2 x3 in\n            if c = 0 then [x2] else if c < 0 then [x2; x3] else [x3; x2]\n          else if c < 0 then\n            let c = cmp x2 x3 in\n            if c = 0 then [x1; x2]\n            else if c < 0 then [x1; x2; x3]\n            else\n              let c = cmp x1 x3 in\n              if c = 0 then [x1; x2]\n              else if c < 0 then [x1; x3; x2]\n              else [x3; x1; x2]\n          else\n            let c = cmp x1 x3 in\n            if c = 0 then [x2; x1]\n            else if c < 0 then [x2; x1; x3]\n            else\n              let c = cmp x2 x3 in\n              if c = 0 then [x2; x1]\n              else if c < 0 then [x2; x3; x1]\n              else [x3; x2; x1]\n        in\n        (s, tl)\n    | n, l ->\n        let n1 = n asr 1 in\n        let n2 = n - n1 in\n        let s1, l2 = rev_sort n1 l in\n        let s2, tl = rev_sort n2 l2 in\n        (rev_merge_rev s1 s2 [], tl)\n  and rev_sort n l =\n    match n, l with\n    | 2, x1 :: x2 :: tl ->\n        let s =\n          let c = cmp x1 x2 in\n          if c = 0 then [x1] else if c > 0 then [x1; x2] else [x2; x1]\n        in\n        (s, tl)\n    | 3, x1 :: x2 :: x3 :: tl ->\n        let s =\n          let c = cmp x1 x2 in\n          if c = 0 then\n            let c = cmp x2 x3 in\n            if c = 0 then [x2] else if c > 0 then [x2; x3] else [x3; x2]\n          else if c > 0 then\n            let c = cmp x2 x3 in\n            if c = 0 then [x1; x2]\n            else if c > 0 then [x1; x2; x3]\n            else\n              let c = cmp x1 x3 in\n              if c = 0 then [x1; x2]\n              else if c > 0 then [x1; x3; x2]\n              else [x3; x1; x2]\n          else\n            let c = cmp x1 x3 in\n            if c = 0 then [x2; x1]\n            else if c > 0 then [x2; x1; x3]\n            else\n              let c = cmp x2 x3 in\n              if c = 0 then [x2; x1]\n              else if c > 0 then [x2; x3; x1]\n              else [x3; x2; x1]\n        in\n        (s, tl)\n    | n, l ->\n        let n1 = n asr 1 in\n        let n2 = n - n1 in\n        let s1, l2 = sort n1 l in\n        let s2, tl = sort n2 l2 in\n        (rev_merge s1 s2 [], tl)\n  in\n  let len = length l in\n  if len < 2 then l else fst (sort len l)\n\n\nlet rec compare_lengths l1 l2 =\n  match l1, l2 with\n  | [], [] -> 0\n  | [], _ -> -1\n  | _, [] -> 1\n  | _ :: l1, _ :: l2 -> compare_lengths l1 l2\n;;\n\nlet rec compare_length_with l n =\n  match l with\n  | [] ->\n    if n = 0 then 0 else\n      if n > 0 then -1 else 1\n  | _ :: l ->\n    if n <= 0 then 1 else\n      compare_length_with l (n-1)\n;;\n\n(** {1 Comparison} *)\n\n(* Note: we are *not* shortcutting the list by using\n   [List.compare_lengths] first; this may be slower on long lists\n   immediately start with distinct elements. It is also incorrect for\n   [compare] below, and it is better (principle of least surprise) to\n   use the same approach for both functions. *)\nlet rec equal eq l1 l2 =\n  match l1, l2 with\n  | [], [] -> true\n  | [], _::_ | _::_, [] -> false\n  | a1::l1, a2::l2 -> eq a1 a2 && equal eq l1 l2\n\nlet rec compare cmp l1 l2 =\n  match l1, l2 with\n  | [], [] -> 0\n  | [], _::_ -> -1\n  | _::_, [] -> 1\n  | a1::l1, a2::l2 ->\n    let c = cmp a1 a2 in\n    if c <> 0 then c\n    else compare cmp l1 l2\n\n(** {1 Iterators} *)\n\nlet to_seq l =\n  let rec aux l () = match l with\n    | [] -> Seq.Nil\n    | x :: tail -> Seq.Cons (x, aux tail)\n  in\n  aux l\n\nlet of_seq seq =\n  let rec direct depth seq : _ list =\n    if depth=0\n    then\n      Seq.fold_left (fun acc x -> x::acc) [] seq\n      |> rev (* tailrec *)\n    else match seq() with\n      | Seq.Nil -> []\n      | Seq.Cons (x, next) -> x :: direct (depth-1) next\n  in\n  direct 500 seq\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*                         The OCaml programmers                          *)\n(*                                                                        *)\n(*   Copyright 2018 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\ntype t = int\n\nlet zero = 0\nlet one = 1\nlet minus_one = -1\nexternal neg : int -> int = \"%negint\"\nexternal add : int -> int -> int = \"%addint\"\nexternal sub : int -> int -> int = \"%subint\"\nexternal mul : int -> int -> int = \"%mulint\"\nexternal div : int -> int -> int = \"%divint\"\nexternal rem : int -> int -> int = \"%modint\"\nexternal succ : int -> int = \"%succint\"\nexternal pred : int -> int = \"%predint\"\nlet abs x = if x >= 0 then x else -x\nlet max_int = (-1) lsr 1\nlet min_int = max_int + 1\nexternal logand : int -> int -> int = \"%andint\"\nexternal logor : int -> int -> int = \"%orint\"\nexternal logxor : int -> int -> int = \"%xorint\"\nlet lognot x = logxor x (-1)\nexternal shift_left : int -> int -> int = \"%lslint\"\nexternal shift_right : int -> int -> int = \"%asrint\"\nexternal shift_right_logical : int -> int -> int = \"%lsrint\"\nlet equal : int -> int -> bool = ( = )\nlet compare : int -> int -> int = Stdlib.compare\nlet min x y : t = if x <= y then x else y\nlet max x y : t = if x >= y then x else y\nexternal to_float : int -> float = \"%floatofint\"\nexternal of_float : float -> int = \"%intoffloat\"\n\n(*\nexternal int_of_string : string -> int = \"caml_int_of_string\"\nlet of_string s = try Some (int_of_string s) with Failure _ -> None\n*)\n\nexternal format_int : string -> int -> string = \"caml_format_int\"\nlet to_string x = format_int \"%d\" x\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Byte sequence operations *)\n\n(* WARNING: Some functions in this file are duplicated in string.ml for\n   efficiency reasons. When you modify the one in this file you need to\n   modify its duplicate in string.ml.\n   These functions have a \"duplicated\" comment above their definition.\n*)\n\nexternal length : bytes -> int = \"%bytes_length\"\nexternal string_length : string -> int = \"%string_length\"\nexternal get : bytes -> int -> char = \"%bytes_safe_get\"\nexternal set : bytes -> int -> char -> unit = \"%bytes_safe_set\"\nexternal create : int -> bytes = \"caml_create_bytes\"\nexternal unsafe_get : bytes -> int -> char = \"%bytes_unsafe_get\"\nexternal unsafe_set : bytes -> int -> char -> unit = \"%bytes_unsafe_set\"\nexternal unsafe_fill : bytes -> int -> int -> char -> unit\n                     = \"caml_fill_bytes\" [@@noalloc]\nexternal unsafe_to_string : bytes -> string = \"%bytes_to_string\"\nexternal unsafe_of_string : string -> bytes = \"%bytes_of_string\"\n\nexternal unsafe_blit : bytes -> int -> bytes -> int -> int -> unit\n                     = \"caml_blit_bytes\" [@@noalloc]\nexternal unsafe_blit_string : string -> int -> bytes -> int -> int -> unit\n                     = \"caml_blit_string\" [@@noalloc]\n\nlet make n c =\n  let s = create n in\n  unsafe_fill s 0 n c;\n  s\n\nlet init n f =\n  let s = create n in\n  for i = 0 to n - 1 do\n    unsafe_set s i (f i)\n  done;\n  s\n\nlet empty = create 0\n\nlet copy s =\n  let len = length s in\n  let r = create len in\n  unsafe_blit s 0 r 0 len;\n  r\n\nlet to_string b = unsafe_to_string (copy b)\nlet of_string s = copy (unsafe_of_string s)\n\nlet sub s ofs len =\n  if ofs < 0 || len < 0 || ofs > length s - len\n  then invalid_arg \"String.sub / Bytes.sub\"\n  else begin\n    let r = create len in\n    unsafe_blit s ofs r 0 len;\n    r\n  end\n\nlet sub_string b ofs len = unsafe_to_string (sub b ofs len)\n\n(* addition with an overflow check *)\nlet (++) a b =\n  let c = a + b in\n  match a < 0, b < 0, c < 0 with\n  | true , true , false\n  | false, false, true  -> invalid_arg \"Bytes.extend\" (* overflow *)\n  | _ -> c\n\nlet extend s left right =\n  let len = length s ++ left ++ right in\n  let r = create len in\n  let (srcoff, dstoff) = if left < 0 then -left, 0 else 0, left in\n  let cpylen = Int.min (length s - srcoff) (len - dstoff) in\n  if cpylen > 0 then unsafe_blit s srcoff r dstoff cpylen;\n  r\n\nlet fill s ofs len c =\n  if ofs < 0 || len < 0 || ofs > length s - len\n  then invalid_arg \"String.fill / Bytes.fill\"\n  else unsafe_fill s ofs len c\n\nlet blit s1 ofs1 s2 ofs2 len =\n  if len < 0 || ofs1 < 0 || ofs1 > length s1 - len\n             || ofs2 < 0 || ofs2 > length s2 - len\n  then invalid_arg \"Bytes.blit\"\n  else unsafe_blit s1 ofs1 s2 ofs2 len\n\nlet blit_string s1 ofs1 s2 ofs2 len =\n  if len < 0 || ofs1 < 0 || ofs1 > string_length s1 - len\n             || ofs2 < 0 || ofs2 > length s2 - len\n  then invalid_arg \"String.blit / Bytes.blit_string\"\n  else unsafe_blit_string s1 ofs1 s2 ofs2 len\n\n(* duplicated in string.ml *)\nlet iter f a =\n  for i = 0 to length a - 1 do f(unsafe_get a i) done\n\n(* duplicated in string.ml *)\nlet iteri f a =\n  for i = 0 to length a - 1 do f i (unsafe_get a i) done\n\nlet ensure_ge (x:int) y = if x >= y then x else invalid_arg \"Bytes.concat\"\n\nlet rec sum_lengths acc seplen = function\n  | [] -> acc\n  | hd :: [] -> length hd + acc\n  | hd :: tl -> sum_lengths (ensure_ge (length hd + seplen + acc) acc) seplen tl\n\nlet rec unsafe_blits dst pos sep seplen = function\n    [] -> dst\n  | hd :: [] ->\n    unsafe_blit hd 0 dst pos (length hd); dst\n  | hd :: tl ->\n    unsafe_blit hd 0 dst pos (length hd);\n    unsafe_blit sep 0 dst (pos + length hd) seplen;\n    unsafe_blits dst (pos + length hd + seplen) sep seplen tl\n\nlet concat sep = function\n    [] -> empty\n  | l -> let seplen = length sep in\n          unsafe_blits\n            (create (sum_lengths 0 seplen l))\n            0 sep seplen l\n\nlet cat s1 s2 =\n  let l1 = length s1 in\n  let l2 = length s2 in\n  let r = create (l1 + l2) in\n  unsafe_blit s1 0 r 0 l1;\n  unsafe_blit s2 0 r l1 l2;\n  r\n\n\nexternal char_code: char -> int = \"%identity\"\nexternal char_chr: int -> char = \"%identity\"\n\nlet is_space = function\n  | ' ' | '\\012' | '\\n' | '\\r' | '\\t' -> true\n  | _ -> false\n\nlet trim s =\n  let len = length s in\n  let i = ref 0 in\n  while !i < len && is_space (unsafe_get s !i) do\n    incr i\n  done;\n  let j = ref (len - 1) in\n  while !j >= !i && is_space (unsafe_get s !j) do\n    decr j\n  done;\n  if !j >= !i then\n    sub s !i (!j - !i + 1)\n  else\n    empty\n\nlet escaped s =\n  let n = ref 0 in\n  for i = 0 to length s - 1 do\n    n := !n +\n      (match unsafe_get s i with\n       | '\\\"' | '\\\\' | '\\n' | '\\t' | '\\r' | '\\b' -> 2\n       | ' ' .. '~' -> 1\n       | _ -> 4)\n  done;\n  if !n = length s then copy s else begin\n    let s' = create !n in\n    n := 0;\n    for i = 0 to length s - 1 do\n      begin match unsafe_get s i with\n      | ('\\\"' | '\\\\') as c ->\n          unsafe_set s' !n '\\\\'; incr n; unsafe_set s' !n c\n      | '\\n' ->\n          unsafe_set s' !n '\\\\'; incr n; unsafe_set s' !n 'n'\n      | '\\t' ->\n          unsafe_set s' !n '\\\\'; incr n; unsafe_set s' !n 't'\n      | '\\r' ->\n          unsafe_set s' !n '\\\\'; incr n; unsafe_set s' !n 'r'\n      | '\\b' ->\n          unsafe_set s' !n '\\\\'; incr n; unsafe_set s' !n 'b'\n      | (' ' .. '~') as c -> unsafe_set s' !n c\n      | c ->\n          let a = char_code c in\n          unsafe_set s' !n '\\\\';\n          incr n;\n          unsafe_set s' !n (char_chr (48 + a / 100));\n          incr n;\n          unsafe_set s' !n (char_chr (48 + (a / 10) mod 10));\n          incr n;\n          unsafe_set s' !n (char_chr (48 + a mod 10));\n      end;\n      incr n\n    done;\n    s'\n  end\n\nlet map f s =\n  let l = length s in\n  if l = 0 then s else begin\n    let r = create l in\n    for i = 0 to l - 1 do unsafe_set r i (f (unsafe_get s i)) done;\n    r\n  end\n\nlet mapi f s =\n  let l = length s in\n  if l = 0 then s else begin\n    let r = create l in\n    for i = 0 to l - 1 do unsafe_set r i (f i (unsafe_get s i)) done;\n    r\n  end\n\nlet fold_left f x a =\n  let r = ref x in\n  for i = 0 to length a - 1 do\n    r := f !r (unsafe_get a i)\n  done;\n  !r\n\nlet fold_right f a x =\n  let r = ref x in\n  for i = length a - 1 downto 0 do\n    r := f (unsafe_get a i) !r\n  done;\n  !r\n\nlet exists p s =\n  let n = length s in\n  let rec loop i =\n    if i = n then false\n    else if p (unsafe_get s i) then true\n    else loop (succ i) in\n  loop 0\n\nlet for_all p s =\n  let n = length s in\n  let rec loop i =\n    if i = n then true\n    else if p (unsafe_get s i) then loop (succ i)\n    else false in\n  loop 0\n\nlet uppercase_ascii s = map Char.uppercase_ascii s\nlet lowercase_ascii s = map Char.lowercase_ascii s\n\nlet apply1 f s =\n  if length s = 0 then s else begin\n    let r = copy s in\n    unsafe_set r 0 (f(unsafe_get s 0));\n    r\n  end\n\nlet capitalize_ascii s = apply1 Char.uppercase_ascii s\nlet uncapitalize_ascii s = apply1 Char.lowercase_ascii s\n\n(* duplicated in string.ml *)\nlet starts_with ~prefix s =\n  let len_s = length s\n  and len_pre = length prefix in\n  let rec aux i =\n    if i = len_pre then true\n    else if unsafe_get s i <> unsafe_get prefix i then false\n    else aux (i + 1)\n  in len_s >= len_pre && aux 0\n\n(* duplicated in string.ml *)\nlet ends_with ~suffix s =\n  let len_s = length s\n  and len_suf = length suffix in\n  let diff = len_s - len_suf in\n  let rec aux i =\n    if i = len_suf then true\n    else if unsafe_get s (diff + i) <> unsafe_get suffix i then false\n    else aux (i + 1)\n  in diff >= 0 && aux 0\n\n(* duplicated in string.ml *)\nlet rec index_rec s lim i c =\n  if i >= lim then raise Not_found else\n  if unsafe_get s i = c then i else index_rec s lim (i + 1) c\n\n(* duplicated in string.ml *)\nlet index s c = index_rec s (length s) 0 c\n\n(* duplicated in string.ml *)\nlet rec index_rec_opt s lim i c =\n  if i >= lim then None else\n  if unsafe_get s i = c then Some i else index_rec_opt s lim (i + 1) c\n\n(* duplicated in string.ml *)\nlet index_opt s c = index_rec_opt s (length s) 0 c\n\n(* duplicated in string.ml *)\nlet index_from s i c =\n  let l = length s in\n  if i < 0 || i > l then invalid_arg \"String.index_from / Bytes.index_from\" else\n  index_rec s l i c\n\n(* duplicated in string.ml *)\nlet index_from_opt s i c =\n  let l = length s in\n  if i < 0 || i > l then\n    invalid_arg \"String.index_from_opt / Bytes.index_from_opt\"\n  else\n    index_rec_opt s l i c\n\n(* duplicated in string.ml *)\nlet rec rindex_rec s i c =\n  if i < 0 then raise Not_found else\n  if unsafe_get s i = c then i else rindex_rec s (i - 1) c\n\n(* duplicated in string.ml *)\nlet rindex s c = rindex_rec s (length s - 1) c\n\n(* duplicated in string.ml *)\nlet rindex_from s i c =\n  if i < -1 || i >= length s then\n    invalid_arg \"String.rindex_from / Bytes.rindex_from\"\n  else\n    rindex_rec s i c\n\n(* duplicated in string.ml *)\nlet rec rindex_rec_opt s i c =\n  if i < 0 then None else\n  if unsafe_get s i = c then Some i else rindex_rec_opt s (i - 1) c\n\n(* duplicated in string.ml *)\nlet rindex_opt s c = rindex_rec_opt s (length s - 1) c\n\n(* duplicated in string.ml *)\nlet rindex_from_opt s i c =\n  if i < -1 || i >= length s then\n    invalid_arg \"String.rindex_from_opt / Bytes.rindex_from_opt\"\n  else\n    rindex_rec_opt s i c\n\n\n(* duplicated in string.ml *)\nlet contains_from s i c =\n  let l = length s in\n  if i < 0 || i > l then\n    invalid_arg \"String.contains_from / Bytes.contains_from\"\n  else\n    try ignore (index_rec s l i c); true with Not_found -> false\n\n\n(* duplicated in string.ml *)\nlet contains s c = contains_from s 0 c\n\n(* duplicated in string.ml *)\nlet rcontains_from s i c =\n  if i < 0 || i >= length s then\n    invalid_arg \"String.rcontains_from / Bytes.rcontains_from\"\n  else\n    try ignore (rindex_rec s i c); true with Not_found -> false\n\n\ntype t = bytes\n\nlet compare (x: t) (y: t) = Stdlib.compare x y\nexternal equal : t -> t -> bool = \"caml_bytes_equal\" [@@noalloc]\n\n(* duplicated in string.ml *)\nlet split_on_char sep s =\n  let r = ref [] in\n  let j = ref (length s) in\n  for i = length s - 1 downto 0 do\n    if unsafe_get s i = sep then begin\n      r := sub s (i + 1) (!j - i - 1) :: !r;\n      j := i\n    end\n  done;\n  sub s 0 !j :: !r\n\n(* Deprecated functions implemented via other deprecated functions *)\n[@@@ocaml.warning \"-3\"]\nlet uppercase s = map Char.uppercase s\nlet lowercase s = map Char.lowercase s\n\nlet capitalize s = apply1 Char.uppercase s\nlet uncapitalize s = apply1 Char.lowercase s\n\n(** {1 Iterators} *)\n\nlet to_seq s =\n  let rec aux i () =\n    if i = length s then Seq.Nil\n    else\n      let x = get s i in\n      Seq.Cons (x, aux (i+1))\n  in\n  aux 0\n\nlet to_seqi s =\n  let rec aux i () =\n    if i = length s then Seq.Nil\n    else\n      let x = get s i in\n      Seq.Cons ((i,x), aux (i+1))\n  in\n  aux 0\n\nlet of_seq i =\n  let n = ref 0 in\n  let buf = ref (make 256 '\\000') in\n  let resize () =\n    (* resize *)\n    let new_len = Int.min (2 * length !buf) Sys.max_string_length in\n    if length !buf = new_len then failwith \"Bytes.of_seq: cannot grow bytes\";\n    let new_buf = make new_len '\\000' in\n    blit !buf 0 new_buf 0 !n;\n    buf := new_buf\n  in\n  Seq.iter\n    (fun c ->\n       if !n = length !buf then resize();\n       set !buf !n c;\n       incr n)\n    i;\n  sub !buf 0 !n\n\n(** {6 Binary encoding/decoding of integers} *)\n\n(* The get_ functions are all duplicated in string.ml *)\n\nexternal get_uint8 : bytes -> int -> int = \"%bytes_safe_get\"\nexternal get_uint16_ne : bytes -> int -> int = \"%caml_bytes_get16\"\nexternal get_int32_ne : bytes -> int -> int32 = \"%caml_bytes_get32\"\nexternal get_int64_ne : bytes -> int -> int64 = \"%caml_bytes_get64\"\nexternal set_int8 : bytes -> int -> int -> unit = \"%bytes_safe_set\"\nexternal set_int16_ne : bytes -> int -> int -> unit = \"%caml_bytes_set16\"\nexternal set_int32_ne : bytes -> int -> int32 -> unit = \"%caml_bytes_set32\"\nexternal set_int64_ne : bytes -> int -> int64 -> unit = \"%caml_bytes_set64\"\nexternal swap16 : int -> int = \"%bswap16\"\nexternal swap32 : int32 -> int32 = \"%bswap_int32\"\nexternal swap64 : int64 -> int64 = \"%bswap_int64\"\n\nlet get_int8 b i =\n  ((get_uint8 b i) lsl (Sys.int_size - 8)) asr (Sys.int_size - 8)\n\nlet get_uint16_le b i =\n  if Sys.big_endian then swap16 (get_uint16_ne b i)\n  else get_uint16_ne b i\n\nlet get_uint16_be b i =\n  if not Sys.big_endian then swap16 (get_uint16_ne b i)\n  else get_uint16_ne b i\n\nlet get_int16_ne b i =\n  ((get_uint16_ne b i) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet get_int16_le b i =\n  ((get_uint16_le b i) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet get_int16_be b i =\n  ((get_uint16_be b i) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet get_int32_le b i =\n  if Sys.big_endian then swap32 (get_int32_ne b i)\n  else get_int32_ne b i\n\nlet get_int32_be b i =\n  if not Sys.big_endian then swap32 (get_int32_ne b i)\n  else get_int32_ne b i\n\nlet get_int64_le b i =\n  if Sys.big_endian then swap64 (get_int64_ne b i)\n  else get_int64_ne b i\n\nlet get_int64_be b i =\n  if not Sys.big_endian then swap64 (get_int64_ne b i)\n  else get_int64_ne b i\n\nlet set_int16_le b i x =\n  if Sys.big_endian then set_int16_ne b i (swap16 x)\n  else set_int16_ne b i x\n\nlet set_int16_be b i x =\n  if not Sys.big_endian then set_int16_ne b i (swap16 x)\n  else set_int16_ne b i x\n\nlet set_int32_le b i x =\n  if Sys.big_endian then set_int32_ne b i (swap32 x)\n  else set_int32_ne b i x\n\nlet set_int32_be b i x =\n  if not Sys.big_endian then set_int32_ne b i (swap32 x)\n  else set_int32_ne b i x\n\nlet set_int64_le b i x =\n  if Sys.big_endian then set_int64_ne b i (swap64 x)\n  else set_int64_ne b i x\n\nlet set_int64_be b i x =\n  if not Sys.big_endian then set_int64_ne b i (swap64 x)\n  else set_int64_ne b i x\n\nlet set_uint8 = set_int8\nlet set_uint16_ne = set_int16_ne\nlet set_uint16_be = set_int16_be\nlet set_uint16_le = set_int16_le\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*           Damien Doligez, projet Gallium, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 2014 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* String operations, based on byte sequence operations *)\n\n(* WARNING: Some functions in this file are duplicated in bytes.ml for\n   efficiency reasons. When you modify the one in this file you need to\n   modify its duplicate in bytes.ml.\n   These functions have a \"duplicated\" comment above their definition.\n*)\n\nexternal length : string -> int = \"%string_length\"\nexternal get : string -> int -> char = \"%string_safe_get\"\nexternal set : bytes -> int -> char -> unit = \"%string_safe_set\"\nexternal create : int -> bytes = \"caml_create_string\"\nexternal unsafe_get : string -> int -> char = \"%string_unsafe_get\"\nexternal unsafe_set : bytes -> int -> char -> unit = \"%string_unsafe_set\"\nexternal unsafe_blit : string -> int ->  bytes -> int -> int -> unit\n                     = \"caml_blit_string\" [@@noalloc]\nexternal unsafe_fill : bytes -> int -> int -> char -> unit\n                     = \"caml_fill_string\" [@@noalloc]\n\nmodule B = Bytes\n\nlet bts = B.unsafe_to_string\nlet bos = B.unsafe_of_string\n\nlet make n c =\n  B.make n c |> bts\nlet init n f =\n  B.init n f |> bts\nlet empty = \"\"\nlet copy s =\n  B.copy (bos s) |> bts\nlet of_bytes = B.to_string\nlet to_bytes = B.of_string\nlet sub s ofs len =\n  B.sub (bos s) ofs len |> bts\nlet fill =\n  B.fill\nlet blit =\n  B.blit_string\n\nlet ensure_ge (x:int) y = if x >= y then x else invalid_arg \"String.concat\"\n\nlet rec sum_lengths acc seplen = function\n  | [] -> acc\n  | hd :: [] -> length hd + acc\n  | hd :: tl -> sum_lengths (ensure_ge (length hd + seplen + acc) acc) seplen tl\n\nlet rec unsafe_blits dst pos sep seplen = function\n    [] -> dst\n  | hd :: [] ->\n    unsafe_blit hd 0 dst pos (length hd); dst\n  | hd :: tl ->\n    unsafe_blit hd 0 dst pos (length hd);\n    unsafe_blit sep 0 dst (pos + length hd) seplen;\n    unsafe_blits dst (pos + length hd + seplen) sep seplen tl\n\nlet concat sep = function\n    [] -> \"\"\n  | l -> let seplen = length sep in bts @@\n          unsafe_blits\n            (B.create (sum_lengths 0 seplen l))\n            0 sep seplen l\n\nlet cat = ( ^ )\n\n(* duplicated in bytes.ml *)\nlet iter f s =\n  for i = 0 to length s - 1 do f (unsafe_get s i) done\n\n(* duplicated in bytes.ml *)\nlet iteri f s =\n  for i = 0 to length s - 1 do f i (unsafe_get s i) done\n\nlet map f s =\n  B.map f (bos s) |> bts\nlet mapi f s =\n  B.mapi f (bos s) |> bts\nlet fold_right f x a =\n  B.fold_right f (bos x) a\nlet fold_left f a x =\n  B.fold_left f a (bos x)\nlet exists f s =\n  B.exists f (bos s)\nlet for_all f s =\n  B.for_all f (bos s)\n\n(* Beware: we cannot use B.trim or B.escape because they always make a\n   copy, but String.mli spells out some cases where we are not allowed\n   to make a copy. *)\n\nlet is_space = function\n  | ' ' | '\\012' | '\\n' | '\\r' | '\\t' -> true\n  | _ -> false\n\nlet trim s =\n  if s = \"\" then s\n  else if is_space (unsafe_get s 0) || is_space (unsafe_get s (length s - 1))\n    then bts (B.trim (bos s))\n  else s\n\nlet escaped s =\n  let rec escape_if_needed s n i =\n    if i >= n then s else\n      match unsafe_get s i with\n      | '\\\"' | '\\\\' | '\\000'..'\\031' | '\\127'.. '\\255' ->\n          bts (B.escaped (bos s))\n      | _ -> escape_if_needed s n (i+1)\n  in\n  escape_if_needed s (length s) 0\n\n(* duplicated in bytes.ml *)\nlet rec index_rec s lim i c =\n  if i >= lim then raise Not_found else\n  if unsafe_get s i = c then i else index_rec s lim (i + 1) c\n\n(* duplicated in bytes.ml *)\nlet index s c = index_rec s (length s) 0 c\n\n(* duplicated in bytes.ml *)\nlet rec index_rec_opt s lim i c =\n  if i >= lim then None else\n  if unsafe_get s i = c then Some i else index_rec_opt s lim (i + 1) c\n\n(* duplicated in bytes.ml *)\nlet index_opt s c = index_rec_opt s (length s) 0 c\n\n(* duplicated in bytes.ml *)\nlet index_from s i c =\n  let l = length s in\n  if i < 0 || i > l then invalid_arg \"String.index_from / Bytes.index_from\" else\n    index_rec s l i c\n\n(* duplicated in bytes.ml *)\nlet index_from_opt s i c =\n  let l = length s in\n  if i < 0 || i > l then\n    invalid_arg \"String.index_from_opt / Bytes.index_from_opt\"\n  else\n    index_rec_opt s l i c\n\n(* duplicated in bytes.ml *)\nlet rec rindex_rec s i c =\n  if i < 0 then raise Not_found else\n  if unsafe_get s i = c then i else rindex_rec s (i - 1) c\n\n(* duplicated in bytes.ml *)\nlet rindex s c = rindex_rec s (length s - 1) c\n\n(* duplicated in bytes.ml *)\nlet rindex_from s i c =\n  if i < -1 || i >= length s then\n    invalid_arg \"String.rindex_from / Bytes.rindex_from\"\n  else\n    rindex_rec s i c\n\n(* duplicated in bytes.ml *)\nlet rec rindex_rec_opt s i c =\n  if i < 0 then None else\n  if unsafe_get s i = c then Some i else rindex_rec_opt s (i - 1) c\n\n(* duplicated in bytes.ml *)\nlet rindex_opt s c = rindex_rec_opt s (length s - 1) c\n\n(* duplicated in bytes.ml *)\nlet rindex_from_opt s i c =\n  if i < -1 || i >= length s then\n    invalid_arg \"String.rindex_from_opt / Bytes.rindex_from_opt\"\n  else\n    rindex_rec_opt s i c\n\n(* duplicated in bytes.ml *)\nlet contains_from s i c =\n  let l = length s in\n  if i < 0 || i > l then\n    invalid_arg \"String.contains_from / Bytes.contains_from\"\n  else\n    try ignore (index_rec s l i c); true with Not_found -> false\n\n(* duplicated in bytes.ml *)\nlet contains s c = contains_from s 0 c\n\n(* duplicated in bytes.ml *)\nlet rcontains_from s i c =\n  if i < 0 || i >= length s then\n    invalid_arg \"String.rcontains_from / Bytes.rcontains_from\"\n  else\n    try ignore (rindex_rec s i c); true with Not_found -> false\n\nlet uppercase_ascii s =\n  B.uppercase_ascii (bos s) |> bts\nlet lowercase_ascii s =\n  B.lowercase_ascii (bos s) |> bts\nlet capitalize_ascii s =\n  B.capitalize_ascii (bos s) |> bts\nlet uncapitalize_ascii s =\n  B.uncapitalize_ascii (bos s) |> bts\n\n(* duplicated in bytes.ml *)\nlet starts_with ~prefix s =\n  let len_s = length s\n  and len_pre = length prefix in\n  let rec aux i =\n    if i = len_pre then true\n    else if unsafe_get s i <> unsafe_get prefix i then false\n    else aux (i + 1)\n  in len_s >= len_pre && aux 0\n\n(* duplicated in bytes.ml *)\nlet ends_with ~suffix s =\n  let len_s = length s\n  and len_suf = length suffix in\n  let diff = len_s - len_suf in\n  let rec aux i =\n    if i = len_suf then true\n    else if unsafe_get s (diff + i) <> unsafe_get suffix i then false\n    else aux (i + 1)\n  in diff >= 0 && aux 0\n\n(* duplicated in bytes.ml *)\nlet split_on_char sep s =\n  let r = ref [] in\n  let j = ref (length s) in\n  for i = length s - 1 downto 0 do\n    if unsafe_get s i = sep then begin\n      r := sub s (i + 1) (!j - i - 1) :: !r;\n      j := i\n    end\n  done;\n  sub s 0 !j :: !r\n\n(* Deprecated functions implemented via other deprecated functions *)\n[@@@ocaml.warning \"-3\"]\nlet uppercase s =\n  B.uppercase (bos s) |> bts\nlet lowercase s =\n  B.lowercase (bos s) |> bts\nlet capitalize s =\n  B.capitalize (bos s) |> bts\nlet uncapitalize s =\n  B.uncapitalize (bos s) |> bts\n\ntype t = string\n\nlet compare (x: t) (y: t) = Stdlib.compare x y\nexternal equal : string -> string -> bool = \"caml_string_equal\" [@@noalloc]\n\n(** {1 Iterators} *)\n\nlet to_seq s = bos s |> B.to_seq\n\nlet to_seqi s = bos s |> B.to_seqi\n\nlet of_seq g = B.of_seq g |> bts\n\n(** {6 Binary encoding/decoding of integers} *)\n\nexternal get_uint8 : string -> int -> int = \"%string_safe_get\"\nexternal get_uint16_ne : string -> int -> int = \"%caml_string_get16\"\nexternal get_int32_ne : string -> int -> int32 = \"%caml_string_get32\"\nexternal get_int64_ne : string -> int -> int64 = \"%caml_string_get64\"\n\nlet get_int8 s i = B.get_int8 (bos s) i\nlet get_uint16_le s i = B.get_uint16_le (bos s) i\nlet get_uint16_be s i = B.get_uint16_be (bos s) i\nlet get_int16_ne s i = B.get_int16_ne (bos s) i\nlet get_int16_le s i = B.get_int16_le (bos s) i\nlet get_int16_be s i = B.get_int16_be (bos s) i\nlet get_int32_le s i = B.get_int32_le (bos s) i\nlet get_int32_be s i = B.get_int32_be (bos s) i\nlet get_int64_le s i = B.get_int64_le (bos s) i\nlet get_int64_be s i = B.get_int64_be (bos s) i\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*                         The OCaml programmers                          *)\n(*                                                                        *)\n(*   Copyright 2018 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\ntype t = unit = ()\n\nlet equal () () = true\nlet compare () () = 0\nlet to_string () = \"()\"\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1997 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\ntype extern_flags =\n    No_sharing\n  | Closures\n  | Compat_32\n(* note: this type definition is used in 'runtime/debugger.c' *)\n\nexternal to_channel: out_channel -> 'a -> extern_flags list -> unit\n    = \"caml_output_value\"\nexternal to_bytes: 'a -> extern_flags list -> bytes\n    = \"caml_output_value_to_bytes\"\nexternal to_string: 'a -> extern_flags list -> string\n    = \"caml_output_value_to_string\"\nexternal to_buffer_unsafe:\n      bytes -> int -> int -> 'a -> extern_flags list -> int\n    = \"caml_output_value_to_buffer\"\n\nlet to_buffer buff ofs len v flags =\n  if ofs < 0 || len < 0 || ofs > Bytes.length buff - len\n  then invalid_arg \"Marshal.to_buffer: substring out of bounds\"\n  else to_buffer_unsafe buff ofs len v flags\n\n(* The functions below use byte sequences as input, never using any\n   mutation. It makes sense to use non-mutated [bytes] rather than\n   [string], because we really work with sequences of bytes, not\n   a text representation.\n*)\n\nexternal from_channel: in_channel -> 'a = \"caml_input_value\"\nexternal from_bytes_unsafe: bytes -> int -> 'a = \"caml_input_value_from_bytes\"\nexternal data_size_unsafe: bytes -> int -> int = \"caml_marshal_data_size\"\n\nlet header_size = 20\nlet data_size buff ofs =\n  if ofs < 0 || ofs > Bytes.length buff - header_size\n  then invalid_arg \"Marshal.data_size\"\n  else data_size_unsafe buff ofs\nlet total_size buff ofs = header_size + data_size buff ofs\n\nlet from_bytes buff ofs =\n  if ofs < 0 || ofs > Bytes.length buff - header_size\n  then invalid_arg \"Marshal.from_bytes\"\n  else begin\n    let len = data_size_unsafe buff ofs in\n    if ofs > Bytes.length buff - (header_size + len)\n    then invalid_arg \"Marshal.from_bytes\"\n    else from_bytes_unsafe buff ofs\n  end\n\nlet from_string buff ofs =\n  (* Bytes.unsafe_of_string is safe here, as the produced byte\n     sequence is never mutated *)\n  from_bytes (Bytes.unsafe_of_string buff) ofs\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Operations on internal representations of values *)\n\ntype t\n\ntype raw_data = nativeint\n\nexternal repr : 'a -> t = \"%identity\"\nexternal obj : t -> 'a = \"%identity\"\nexternal magic : 'a -> 'b = \"%identity\"\nexternal is_int : t -> bool = \"%obj_is_int\"\nlet [@inline always] is_block a = not (is_int a)\nexternal tag : t -> int = \"caml_obj_tag\" [@@noalloc]\nexternal set_tag : t -> int -> unit = \"caml_obj_set_tag\"\nexternal size : t -> int = \"%obj_size\"\nexternal reachable_words : t -> int = \"caml_obj_reachable_words\"\nexternal field : t -> int -> t = \"%obj_field\"\nexternal set_field : t -> int -> t -> unit = \"%obj_set_field\"\nexternal floatarray_get : floatarray -> int -> float = \"caml_floatarray_get\"\nexternal floatarray_set :\n    floatarray -> int -> float -> unit = \"caml_floatarray_set\"\nlet [@inline always] double_field x i = floatarray_get (obj x : floatarray) i\nlet [@inline always] set_double_field x i v =\n  floatarray_set (obj x : floatarray) i v\nexternal raw_field : t -> int -> raw_data = \"caml_obj_raw_field\"\nexternal set_raw_field : t -> int -> raw_data -> unit\n                                          = \"caml_obj_set_raw_field\"\n\nexternal new_block : int -> int -> t = \"caml_obj_block\"\nexternal dup : t -> t = \"caml_obj_dup\"\nexternal truncate : t -> int -> unit = \"caml_obj_truncate\"\nexternal add_offset : t -> Int32.t -> t = \"caml_obj_add_offset\"\nexternal with_tag : int -> t -> t = \"caml_obj_with_tag\"\n\nlet marshal (obj : t) =\n  Marshal.to_bytes obj []\nlet unmarshal str pos =\n  (Marshal.from_bytes str pos, pos + Marshal.total_size str pos)\n\nlet first_non_constant_constructor_tag = 0\nlet last_non_constant_constructor_tag = 245\n\nlet lazy_tag = 246\nlet closure_tag = 247\nlet object_tag = 248\nlet infix_tag = 249\nlet forward_tag = 250\n\nlet no_scan_tag = 251\n\nlet abstract_tag = 251\nlet string_tag = 252\nlet double_tag = 253\nlet double_array_tag = 254\nlet custom_tag = 255\nlet final_tag = custom_tag\n\n\nlet int_tag = 1000\nlet out_of_heap_tag = 1001\nlet unaligned_tag = 1002\n\nmodule Closure = struct\n  type info = {\n    arity: int;\n    start_env: int;\n  }\n\n  let info_of_raw (info : nativeint) =\n    let open Nativeint in\n    let arity =\n      (* signed: negative for tupled functions *)\n      if Sys.word_size = 64 then\n        to_int (shift_right info 56)\n      else\n        to_int (shift_right info 24)\n    in\n    let start_env =\n      (* start_env is unsigned, but we know it can always fit an OCaml\n         integer so we use [to_int] instead of [unsigned_to_int]. *)\n      to_int (shift_right_logical (shift_left info 8) 9) in\n    { arity; start_env }\n\n  (* note: we expect a closure, not an infix pointer *)\n  let info (obj : t) =\n    assert (tag obj = closure_tag);\n    info_of_raw (raw_field obj 1)\nend\n\nmodule Extension_constructor =\nstruct\n  type t = extension_constructor\n  let of_val x =\n    let x = repr x in\n    let slot =\n      if (is_block x) && (tag x) <> object_tag && (size x) >= 1 then field x 0\n      else x\n    in\n    let name =\n      if (is_block slot) && (tag slot) = object_tag then field slot 0\n      else invalid_arg \"Obj.extension_constructor\"\n    in\n      if (tag name) = string_tag then (obj slot : t)\n      else invalid_arg \"Obj.extension_constructor\"\n\n  let [@inline always] name (slot : t) =\n    (obj (field (repr slot) 0) : string)\n\n  let [@inline always] id (slot : t) =\n    (obj (field (repr slot) 1) : int)\nend\n\nlet extension_constructor = Extension_constructor.of_val\nlet extension_name = Extension_constructor.name\nlet extension_id = Extension_constructor.id\n\nmodule Ephemeron = struct\n  type obj_t = t\n\n  type t (** ephemeron *)\n\n   (** To change in sync with weak.h *)\n  let additional_values = 2\n  let max_ephe_length = Sys.max_array_length - additional_values\n\n  external create : int -> t = \"caml_ephe_create\";;\n  let create l =\n    if not (0 <= l && l <= max_ephe_length) then\n      invalid_arg \"Obj.Ephemeron.create\";\n    create l\n\n  let length x = size(repr x) - additional_values\n\n  let raise_if_invalid_offset e o msg =\n    if not (0 <= o && o < length e) then\n      invalid_arg msg\n\n  external get_key: t -> int -> obj_t option = \"caml_ephe_get_key\"\n  let get_key e o =\n    raise_if_invalid_offset e o \"Obj.Ephemeron.get_key\";\n    get_key e o\n\n  external get_key_copy: t -> int -> obj_t option = \"caml_ephe_get_key_copy\"\n  let get_key_copy e o =\n    raise_if_invalid_offset e o \"Obj.Ephemeron.get_key_copy\";\n    get_key_copy e o\n\n  external set_key: t -> int -> obj_t -> unit = \"caml_ephe_set_key\"\n  let set_key e o x =\n    raise_if_invalid_offset e o \"Obj.Ephemeron.set_key\";\n    set_key e o x\n\n  external unset_key: t -> int -> unit = \"caml_ephe_unset_key\"\n  let unset_key e o =\n    raise_if_invalid_offset e o \"Obj.Ephemeron.unset_key\";\n    unset_key e o\n\n  external check_key: t -> int -> bool = \"caml_ephe_check_key\"\n  let check_key e o =\n    raise_if_invalid_offset e o \"Obj.Ephemeron.check_key\";\n    check_key e o\n\n  external blit_key : t -> int -> t -> int -> int -> unit\n    = \"caml_ephe_blit_key\"\n\n  let blit_key e1 o1 e2 o2 l =\n    if l < 0 || o1 < 0 || o1 > length e1 - l\n       || o2 < 0 || o2 > length e2 - l\n    then invalid_arg \"Obj.Ephemeron.blit_key\"\n    else if l <> 0 then blit_key e1 o1 e2 o2 l\n\n  external get_data: t -> obj_t option = \"caml_ephe_get_data\"\n  external get_data_copy: t -> obj_t option = \"caml_ephe_get_data_copy\"\n  external set_data: t -> obj_t -> unit = \"caml_ephe_set_data\"\n  external unset_data: t -> unit = \"caml_ephe_unset_data\"\n  external check_data: t -> bool = \"caml_ephe_check_data\"\n  external blit_data : t -> t -> unit = \"caml_ephe_blit_data\"\n\nend\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* An alias for the type of arrays. *)\ntype 'a t = 'a array\n\n(* Array operations *)\n\nexternal length : 'a array -> int = \"%array_length\"\nexternal get: 'a array -> int -> 'a = \"%array_safe_get\"\nexternal set: 'a array -> int -> 'a -> unit = \"%array_safe_set\"\nexternal unsafe_get: 'a array -> int -> 'a = \"%array_unsafe_get\"\nexternal unsafe_set: 'a array -> int -> 'a -> unit = \"%array_unsafe_set\"\nexternal make: int -> 'a -> 'a array = \"caml_make_vect\"\nexternal create: int -> 'a -> 'a array = \"caml_make_vect\"\nexternal unsafe_sub : 'a array -> int -> int -> 'a array = \"caml_array_sub\"\nexternal append_prim : 'a array -> 'a array -> 'a array = \"caml_array_append\"\nexternal concat : 'a array list -> 'a array = \"caml_array_concat\"\nexternal unsafe_blit :\n  'a array -> int -> 'a array -> int -> int -> unit = \"caml_array_blit\"\nexternal unsafe_fill :\n  'a array -> int -> int -> 'a -> unit = \"caml_array_fill\"\nexternal create_float: int -> float array = \"caml_make_float_vect\"\nlet make_float = create_float\n\nmodule Floatarray = struct\n  external create : int -> floatarray = \"caml_floatarray_create\"\n  external length : floatarray -> int = \"%floatarray_length\"\n  external get : floatarray -> int -> float = \"%floatarray_safe_get\"\n  external set : floatarray -> int -> float -> unit = \"%floatarray_safe_set\"\n  external unsafe_get : floatarray -> int -> float = \"%floatarray_unsafe_get\"\n  external unsafe_set : floatarray -> int -> float -> unit\n      = \"%floatarray_unsafe_set\"\nend\n\nlet init l f =\n  if l = 0 then [||] else\n  if l < 0 then invalid_arg \"Array.init\"\n  (* See #6575. We could also check for maximum array size, but this depends\n     on whether we create a float array or a regular one... *)\n  else\n   let res = create l (f 0) in\n   for i = 1 to pred l do\n     unsafe_set res i (f i)\n   done;\n   res\n\nlet make_matrix sx sy init =\n  let res = create sx [||] in\n  for x = 0 to pred sx do\n    unsafe_set res x (create sy init)\n  done;\n  res\n\nlet create_matrix = make_matrix\n\nlet copy a =\n  let l = length a in if l = 0 then [||] else unsafe_sub a 0 l\n\nlet append a1 a2 =\n  let l1 = length a1 in\n  if l1 = 0 then copy a2\n  else if length a2 = 0 then unsafe_sub a1 0 l1\n  else append_prim a1 a2\n\nlet sub a ofs len =\n  if ofs < 0 || len < 0 || ofs > length a - len\n  then invalid_arg \"Array.sub\"\n  else unsafe_sub a ofs len\n\nlet fill a ofs len v =\n  if ofs < 0 || len < 0 || ofs > length a - len\n  then invalid_arg \"Array.fill\"\n  else unsafe_fill a ofs len v\n\nlet blit a1 ofs1 a2 ofs2 len =\n  if len < 0 || ofs1 < 0 || ofs1 > length a1 - len\n             || ofs2 < 0 || ofs2 > length a2 - len\n  then invalid_arg \"Array.blit\"\n  else unsafe_blit a1 ofs1 a2 ofs2 len\n\nlet iter f a =\n  for i = 0 to length a - 1 do f(unsafe_get a i) done\n\nlet iter2 f a b =\n  if length a <> length b then\n    invalid_arg \"Array.iter2: arrays must have the same length\"\n  else\n    for i = 0 to length a - 1 do f (unsafe_get a i) (unsafe_get b i) done\n\nlet map f a =\n  let l = length a in\n  if l = 0 then [||] else begin\n    let r = create l (f(unsafe_get a 0)) in\n    for i = 1 to l - 1 do\n      unsafe_set r i (f(unsafe_get a i))\n    done;\n    r\n  end\n\nlet map2 f a b =\n  let la = length a in\n  let lb = length b in\n  if la <> lb then\n    invalid_arg \"Array.map2: arrays must have the same length\"\n  else begin\n    if la = 0 then [||] else begin\n      let r = create la (f (unsafe_get a 0) (unsafe_get b 0)) in\n      for i = 1 to la - 1 do\n        unsafe_set r i (f (unsafe_get a i) (unsafe_get b i))\n      done;\n      r\n    end\n  end\n\nlet iteri f a =\n  for i = 0 to length a - 1 do f i (unsafe_get a i) done\n\nlet mapi f a =\n  let l = length a in\n  if l = 0 then [||] else begin\n    let r = create l (f 0 (unsafe_get a 0)) in\n    for i = 1 to l - 1 do\n      unsafe_set r i (f i (unsafe_get a i))\n    done;\n    r\n  end\n\nlet to_list a =\n  let rec tolist i res =\n    if i < 0 then res else tolist (i - 1) (unsafe_get a i :: res) in\n  tolist (length a - 1) []\n\n(* Cannot use List.length here because the List module depends on Array. *)\nlet rec list_length accu = function\n  | [] -> accu\n  | _::t -> list_length (succ accu) t\n\nlet of_list = function\n    [] -> [||]\n  | hd::tl as l ->\n      let a = create (list_length 0 l) hd in\n      let rec fill i = function\n          [] -> a\n        | hd::tl -> unsafe_set a i hd; fill (i+1) tl in\n      fill 1 tl\n\nlet fold_left f x a =\n  let r = ref x in\n  for i = 0 to length a - 1 do\n    r := f !r (unsafe_get a i)\n  done;\n  !r\n\nlet fold_left_map f acc input_array =\n  let len = length input_array in\n  if len = 0 then (acc, [||]) else begin\n    let acc, elt = f acc (unsafe_get input_array 0) in\n    let output_array = create len elt in\n    let acc = ref acc in\n    for i = 1 to len - 1 do\n      let acc', elt = f !acc (unsafe_get input_array i) in\n      acc := acc';\n      unsafe_set output_array i elt;\n    done;\n    !acc, output_array\n  end\n\nlet fold_right f a x =\n  let r = ref x in\n  for i = length a - 1 downto 0 do\n    r := f (unsafe_get a i) !r\n  done;\n  !r\n\nlet exists p a =\n  let n = length a in\n  let rec loop i =\n    if i = n then false\n    else if p (unsafe_get a i) then true\n    else loop (succ i) in\n  loop 0\n\nlet for_all p a =\n  let n = length a in\n  let rec loop i =\n    if i = n then true\n    else if p (unsafe_get a i) then loop (succ i)\n    else false in\n  loop 0\n\nlet for_all2 p l1 l2 =\n  let n1 = length l1\n  and n2 = length l2 in\n  if n1 <> n2 then invalid_arg \"Array.for_all2\"\n  else let rec loop i =\n    if i = n1 then true\n    else if p (unsafe_get l1 i) (unsafe_get l2 i) then loop (succ i)\n    else false in\n  loop 0\n\nlet exists2 p l1 l2 =\n  let n1 = length l1\n  and n2 = length l2 in\n  if n1 <> n2 then invalid_arg \"Array.exists2\"\n  else let rec loop i =\n    if i = n1 then false\n    else if p (unsafe_get l1 i) (unsafe_get l2 i) then true\n    else loop (succ i) in\n  loop 0\n\nlet mem x a =\n  let n = length a in\n  let rec loop i =\n    if i = n then false\n    else if compare (unsafe_get a i) x = 0 then true\n    else loop (succ i) in\n  loop 0\n\nlet memq x a =\n  let n = length a in\n  let rec loop i =\n    if i = n then false\n    else if x == (unsafe_get a i) then true\n    else loop (succ i) in\n  loop 0\n\nlet find_opt p a =\n  let n = length a in\n  let rec loop i =\n    if i = n then None\n    else\n      let x = unsafe_get a i in\n      if p x then Some x\n      else loop (succ i)\n  in\n  loop 0\n\nlet find_map f a =\n  let n = length a in\n  let rec loop i =\n    if i = n then None\n    else\n      match f (unsafe_get a i) with\n      | None -> loop (succ i)\n      | Some _ as r -> r\n  in\n  loop 0\n\nlet split x =\n  if x = [||] then [||], [||]\n  else begin\n    let a0, b0 = unsafe_get x 0 in\n    let n = length x in\n    let a = create n a0 in\n    let b = create n b0 in\n    for i = 1 to n - 1 do\n      let ai, bi = unsafe_get x i in\n      unsafe_set a i ai;\n      unsafe_set b i bi\n    done;\n    a, b\n  end\n\nlet combine a b =\n  let na = length a in\n  let nb = length b in\n  if na <> nb then invalid_arg \"Array.combine\";\n  if na = 0 then [||]\n  else begin\n    let x = create na (unsafe_get a 0, unsafe_get b 0) in\n    for i = 1 to na - 1 do\n      unsafe_set x i (unsafe_get a i, unsafe_get b i)\n    done;\n    x\n  end\n\nexception Bottom of int\nlet sort cmp a =\n  let maxson l i =\n    let i31 = i+i+i+1 in\n    let x = ref i31 in\n    if i31+2 < l then begin\n      if cmp (get a i31) (get a (i31+1)) < 0 then x := i31+1;\n      if cmp (get a !x) (get a (i31+2)) < 0 then x := i31+2;\n      !x\n    end else\n      if i31+1 < l && cmp (get a i31) (get a (i31+1)) < 0\n      then i31+1\n      else if i31 < l then i31 else raise (Bottom i)\n  in\n  let rec trickledown l i e =\n    let j = maxson l i in\n    if cmp (get a j) e > 0 then begin\n      set a i (get a j);\n      trickledown l j e;\n    end else begin\n      set a i e;\n    end;\n  in\n  let trickle l i e = try trickledown l i e with Bottom i -> set a i e in\n  let rec bubbledown l i =\n    let j = maxson l i in\n    set a i (get a j);\n    bubbledown l j\n  in\n  let bubble l i = try bubbledown l i with Bottom i -> i in\n  let rec trickleup i e =\n    let father = (i - 1) / 3 in\n    assert (i <> father);\n    if cmp (get a father) e < 0 then begin\n      set a i (get a father);\n      if father > 0 then trickleup father e else set a 0 e;\n    end else begin\n      set a i e;\n    end;\n  in\n  let l = length a in\n  for i = (l + 1) / 3 - 1 downto 0 do trickle l i (get a i); done;\n  for i = l - 1 downto 2 do\n    let e = (get a i) in\n    set a i (get a 0);\n    trickleup (bubble i 0) e;\n  done;\n  if l > 1 then (let e = (get a 1) in set a 1 (get a 0); set a 0 e)\n\n\nlet cutoff = 5\nlet stable_sort cmp a =\n  let merge src1ofs src1len src2 src2ofs src2len dst dstofs =\n    let src1r = src1ofs + src1len and src2r = src2ofs + src2len in\n    let rec loop i1 s1 i2 s2 d =\n      if cmp s1 s2 <= 0 then begin\n        set dst d s1;\n        let i1 = i1 + 1 in\n        if i1 < src1r then\n          loop i1 (get a i1) i2 s2 (d + 1)\n        else\n          blit src2 i2 dst (d + 1) (src2r - i2)\n      end else begin\n        set dst d s2;\n        let i2 = i2 + 1 in\n        if i2 < src2r then\n          loop i1 s1 i2 (get src2 i2) (d + 1)\n        else\n          blit a i1 dst (d + 1) (src1r - i1)\n      end\n    in loop src1ofs (get a src1ofs) src2ofs (get src2 src2ofs) dstofs;\n  in\n  let isortto srcofs dst dstofs len =\n    for i = 0 to len - 1 do\n      let e = (get a (srcofs + i)) in\n      let j = ref (dstofs + i - 1) in\n      while (!j >= dstofs && cmp (get dst !j) e > 0) do\n        set dst (!j + 1) (get dst !j);\n        decr j;\n      done;\n      set dst (!j + 1) e;\n    done;\n  in\n  let rec sortto srcofs dst dstofs len =\n    if len <= cutoff then isortto srcofs dst dstofs len else begin\n      let l1 = len / 2 in\n      let l2 = len - l1 in\n      sortto (srcofs + l1) dst (dstofs + l1) l2;\n      sortto srcofs a (srcofs + l2) l1;\n      merge (srcofs + l2) l1 dst (dstofs + l1) l2 dst dstofs;\n    end;\n  in\n  let l = length a in\n  if l <= cutoff then isortto 0 a 0 l else begin\n    let l1 = l / 2 in\n    let l2 = l - l1 in\n    let t = make l2 (get a 0) in\n    sortto l1 t 0 l2;\n    sortto 0 a l2 l1;\n    merge l2 l1 t 0 l2 a 0;\n  end\n\n\nlet fast_sort = stable_sort\n\n(** {1 Iterators} *)\n\nlet to_seq a =\n  let rec aux i () =\n    if i < length a\n    then\n      let x = unsafe_get a i in\n      Seq.Cons (x, aux (i+1))\n    else Seq.Nil\n  in\n  aux 0\n\nlet to_seqi a =\n  let rec aux i () =\n    if i < length a\n    then\n      let x = unsafe_get a i in\n      Seq.Cons ((i,x), aux (i+1))\n    else Seq.Nil\n  in\n  aux 0\n\nlet of_rev_list = function\n    [] -> [||]\n  | hd::tl as l ->\n      let len = list_length 0 l in\n      let a = create len hd in\n      let rec fill i = function\n          [] -> a\n        | hd::tl -> unsafe_set a i hd; fill (i-1) tl\n      in\n      fill (len-2) tl\n\nlet of_seq i =\n  let l = Seq.fold_left (fun acc x -> x::acc) [] i in\n  of_rev_list l\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                        Nicolas Ojeda Bar, LexiFi                       *)\n(*                                                                        *)\n(*   Copyright 2018 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\nexternal neg : float -> float = \"%negfloat\"\nexternal add : float -> float -> float = \"%addfloat\"\nexternal sub : float -> float -> float = \"%subfloat\"\nexternal mul : float -> float -> float = \"%mulfloat\"\nexternal div : float -> float -> float = \"%divfloat\"\nexternal rem : float -> float -> float = \"caml_fmod_float\" \"fmod\"\n  [@@unboxed] [@@noalloc]\nexternal fma : float -> float -> float -> float = \"caml_fma_float\" \"caml_fma\"\n  [@@unboxed] [@@noalloc]\nexternal abs : float -> float = \"%absfloat\"\n\nlet zero = 0.\nlet one = 1.\nlet minus_one = -1.\nlet infinity = Stdlib.infinity\nlet neg_infinity = Stdlib.neg_infinity\nlet nan = Stdlib.nan\nlet is_finite (x: float) = x -. x = 0.\nlet is_infinite (x: float) = 1. /. x = 0.\nlet is_nan (x: float) = x <> x\n\nlet pi = 0x1.921fb54442d18p+1\nlet max_float = Stdlib.max_float\nlet min_float = Stdlib.min_float\nlet epsilon = Stdlib.epsilon_float\nexternal of_int : int -> float = \"%floatofint\"\nexternal to_int : float -> int = \"%intoffloat\"\nexternal of_string : string -> float = \"caml_float_of_string\"\nlet of_string_opt = Stdlib.float_of_string_opt\nlet to_string = Stdlib.string_of_float\ntype fpclass = Stdlib.fpclass =\n    FP_normal\n  | FP_subnormal\n  | FP_zero\n  | FP_infinite\n  | FP_nan\nexternal classify_float : (float [@unboxed]) -> fpclass =\n  \"caml_classify_float\" \"caml_classify_float_unboxed\" [@@noalloc]\nexternal pow : float -> float -> float = \"caml_power_float\" \"pow\"\n  [@@unboxed] [@@noalloc]\nexternal sqrt : float -> float = \"caml_sqrt_float\" \"sqrt\"\n  [@@unboxed] [@@noalloc]\nexternal cbrt : float -> float = \"caml_cbrt_float\" \"caml_cbrt\"\n  [@@unboxed] [@@noalloc]\nexternal exp : float -> float = \"caml_exp_float\" \"exp\" [@@unboxed] [@@noalloc]\nexternal exp2 : float -> float = \"caml_exp2_float\" \"caml_exp2\"\n  [@@unboxed] [@@noalloc]\nexternal log : float -> float = \"caml_log_float\" \"log\" [@@unboxed] [@@noalloc]\nexternal log10 : float -> float = \"caml_log10_float\" \"log10\"\n  [@@unboxed] [@@noalloc]\nexternal log2 : float -> float = \"caml_log2_float\" \"caml_log2\"\n  [@@unboxed] [@@noalloc]\nexternal expm1 : float -> float = \"caml_expm1_float\" \"caml_expm1\"\n  [@@unboxed] [@@noalloc]\nexternal log1p : float -> float = \"caml_log1p_float\" \"caml_log1p\"\n  [@@unboxed] [@@noalloc]\nexternal cos : float -> float = \"caml_cos_float\" \"cos\" [@@unboxed] [@@noalloc]\nexternal sin : float -> float = \"caml_sin_float\" \"sin\" [@@unboxed] [@@noalloc]\nexternal tan : float -> float = \"caml_tan_float\" \"tan\" [@@unboxed] [@@noalloc]\nexternal acos : float -> float = \"caml_acos_float\" \"acos\"\n  [@@unboxed] [@@noalloc]\nexternal asin : float -> float = \"caml_asin_float\" \"asin\"\n  [@@unboxed] [@@noalloc]\nexternal atan : float -> float = \"caml_atan_float\" \"atan\"\n  [@@unboxed] [@@noalloc]\nexternal atan2 : float -> float -> float = \"caml_atan2_float\" \"atan2\"\n  [@@unboxed] [@@noalloc]\nexternal hypot : float -> float -> float\n               = \"caml_hypot_float\" \"caml_hypot\" [@@unboxed] [@@noalloc]\nexternal cosh : float -> float = \"caml_cosh_float\" \"cosh\"\n  [@@unboxed] [@@noalloc]\nexternal sinh : float -> float = \"caml_sinh_float\" \"sinh\"\n  [@@unboxed] [@@noalloc]\nexternal tanh : float -> float = \"caml_tanh_float\" \"tanh\"\n  [@@unboxed] [@@noalloc]\nexternal acosh : float -> float = \"caml_acosh_float\" \"caml_acosh\"\n  [@@unboxed] [@@noalloc]\nexternal asinh : float -> float = \"caml_asinh_float\" \"caml_asinh\"\n  [@@unboxed] [@@noalloc]\nexternal atanh : float -> float = \"caml_atanh_float\" \"caml_atanh\"\n  [@@unboxed] [@@noalloc]\nexternal erf : float -> float = \"caml_erf_float\" \"caml_erf\"\n  [@@unboxed] [@@noalloc]\nexternal erfc : float -> float = \"caml_erfc_float\" \"caml_erfc\"\n  [@@unboxed] [@@noalloc]\nexternal trunc : float -> float = \"caml_trunc_float\" \"caml_trunc\"\n  [@@unboxed] [@@noalloc]\nexternal round : float -> float = \"caml_round_float\" \"caml_round\"\n  [@@unboxed] [@@noalloc]\nexternal ceil : float -> float = \"caml_ceil_float\" \"ceil\"\n  [@@unboxed] [@@noalloc]\nexternal floor : float -> float = \"caml_floor_float\" \"floor\"\n[@@unboxed] [@@noalloc]\n\nlet is_integer x = x = trunc x && is_finite x\n\nexternal next_after : float -> float -> float\n  = \"caml_nextafter_float\" \"caml_nextafter\" [@@unboxed] [@@noalloc]\n\nlet succ x = next_after x infinity\nlet pred x = next_after x neg_infinity\n\nexternal copy_sign : float -> float -> float\n                  = \"caml_copysign_float\" \"caml_copysign\"\n                  [@@unboxed] [@@noalloc]\nexternal sign_bit : (float [@unboxed]) -> bool\n  = \"caml_signbit_float\" \"caml_signbit\" [@@noalloc]\n\nexternal frexp : float -> float * int = \"caml_frexp_float\"\nexternal ldexp : (float [@unboxed]) -> (int [@untagged]) -> (float [@unboxed]) =\n  \"caml_ldexp_float\" \"caml_ldexp_float_unboxed\" [@@noalloc]\nexternal modf : float -> float * float = \"caml_modf_float\"\ntype t = float\nexternal compare : float -> float -> int = \"%compare\"\nlet equal x y = compare x y = 0\n\nlet[@inline] min (x: float) (y: float) =\n  if y > x || (not(sign_bit y) && sign_bit x) then\n    if is_nan y then y else x\n  else if is_nan x then x else y\n\nlet[@inline] max (x: float) (y: float) =\n  if y > x || (not(sign_bit y) && sign_bit x) then\n    if is_nan x then x else y\n  else if is_nan y then y else x\n\nlet[@inline] min_max (x: float) (y: float) =\n  if is_nan x || is_nan y then (nan, nan)\n  else if y > x || (not(sign_bit y) && sign_bit x) then (x, y) else (y, x)\n\nlet[@inline] min_num (x: float) (y: float) =\n  if y > x || (not(sign_bit y) && sign_bit x) then\n    if is_nan x then y else x\n  else if is_nan y then x else y\n\nlet[@inline] max_num (x: float) (y: float) =\n  if y > x || (not(sign_bit y) && sign_bit x) then\n    if is_nan y then x else y\n  else if is_nan x then y else x\n\nlet[@inline] min_max_num (x: float) (y: float) =\n  if is_nan x then (y,y)\n  else if is_nan y then (x,x)\n  else if y > x || (not(sign_bit y) && sign_bit x) then (x,y) else (y,x)\n\nexternal seeded_hash_param : int -> int -> int -> float -> int\n                           = \"caml_hash\" [@@noalloc]\nlet hash x = seeded_hash_param 10 100 0 x\n\nmodule Array = struct\n\n  type t = floatarray\n\n  external length : t -> int = \"%floatarray_length\"\n  external get : t -> int -> float = \"%floatarray_safe_get\"\n  external set : t -> int -> float -> unit = \"%floatarray_safe_set\"\n  external create : int -> t = \"caml_floatarray_create\"\n  external unsafe_get : t -> int -> float = \"%floatarray_unsafe_get\"\n  external unsafe_set : t -> int -> float -> unit = \"%floatarray_unsafe_set\"\n\n  let unsafe_fill a ofs len v =\n    for i = ofs to ofs + len - 1 do unsafe_set a i v done\n\n  external unsafe_blit: t -> int -> t -> int -> int -> unit =\n    \"caml_floatarray_blit\" [@@noalloc]\n\n  let check a ofs len msg =\n    if ofs < 0 || len < 0 || ofs + len < 0 || ofs + len > length a then\n      invalid_arg msg\n\n  let make n v =\n    let result = create n in\n    unsafe_fill result 0 n v;\n    result\n\n  let init l f =\n    if l < 0 then invalid_arg \"Float.Array.init\"\n    else\n      let res = create l in\n      for i = 0 to l - 1 do\n        unsafe_set res i (f i)\n      done;\n      res\n\n  let append a1 a2 =\n    let l1 = length a1 in\n    let l2 = length a2 in\n    let result = create (l1 + l2) in\n    unsafe_blit a1 0 result 0 l1;\n    unsafe_blit a2 0 result l1 l2;\n    result\n\n  (* next 3 functions: modified copy of code from string.ml *)\n  let ensure_ge (x:int) y =\n    if x >= y then x else invalid_arg \"Float.Array.concat\"\n\n  let rec sum_lengths acc = function\n    | [] -> acc\n    | hd :: tl -> sum_lengths (ensure_ge (length hd + acc) acc) tl\n\n  let concat l =\n    let len = sum_lengths 0 l in\n    let result = create len in\n    let rec loop l i =\n      match l with\n      | [] -> assert (i = len)\n      | hd :: tl ->\n        let hlen = length hd in\n        unsafe_blit hd 0 result i hlen;\n        loop tl (i + hlen)\n    in\n    loop l 0;\n    result\n\n  let sub a ofs len =\n    check a ofs len \"Float.Array.sub\";\n    let result = create len in\n    unsafe_blit a ofs result 0 len;\n    result\n\n  let copy a =\n    let l = length a in\n    let result = create l in\n    unsafe_blit a 0 result 0 l;\n    result\n\n  let fill a ofs len v =\n    check a ofs len \"Float.Array.fill\";\n    unsafe_fill a ofs len v\n\n  let blit src sofs dst dofs len =\n    check src sofs len \"Float.array.blit\";\n    check dst dofs len \"Float.array.blit\";\n    unsafe_blit src sofs dst dofs len\n\n  let to_list a =\n    List.init (length a) (unsafe_get a)\n\n  let of_list l =\n    let result = create (List.length l) in\n    let rec fill i l =\n      match l with\n      | [] -> result\n      | h :: t -> unsafe_set result i h; fill (i + 1) t\n    in\n    fill 0 l\n\n  (* duplicated from array.ml *)\n  let iter f a =\n    for i = 0 to length a - 1 do f (unsafe_get a i) done\n\n  (* duplicated from array.ml *)\n  let iter2 f a b =\n    if length a <> length b then\n      invalid_arg \"Float.Array.iter2: arrays must have the same length\"\n    else\n      for i = 0 to length a - 1 do f (unsafe_get a i) (unsafe_get b i) done\n\n  let map f a =\n    let l = length a in\n    let r = create l in\n    for i = 0 to l - 1 do\n      unsafe_set r i (f (unsafe_get a i))\n    done;\n    r\n\n  let map2 f a b =\n    let la = length a in\n    let lb = length b in\n    if la <> lb then\n      invalid_arg \"Float.Array.map2: arrays must have the same length\"\n    else begin\n      let r = create la in\n      for i = 0 to la - 1 do\n        unsafe_set r i (f (unsafe_get a i) (unsafe_get b i))\n      done;\n      r\n    end\n\n  (* duplicated from array.ml *)\n  let iteri f a =\n    for i = 0 to length a - 1 do f i (unsafe_get a i) done\n\n  let mapi f a =\n    let l = length a in\n    let r = create l in\n    for i = 0 to l - 1 do\n      unsafe_set r i (f i (unsafe_get a i))\n    done;\n    r\n\n  (* duplicated from array.ml *)\n  let fold_left f x a =\n    let r = ref x in\n    for i = 0 to length a - 1 do\n      r := f !r (unsafe_get a i)\n    done;\n    !r\n\n  (* duplicated from array.ml *)\n  let fold_right f a x =\n    let r = ref x in\n    for i = length a - 1 downto 0 do\n      r := f (unsafe_get a i) !r\n    done;\n    !r\n\n  (* duplicated from array.ml *)\n  let exists p a =\n    let n = length a in\n    let rec loop i =\n      if i = n then false\n      else if p (unsafe_get a i) then true\n      else loop (i + 1) in\n    loop 0\n\n  (* duplicated from array.ml *)\n  let for_all p a =\n    let n = length a in\n    let rec loop i =\n      if i = n then true\n      else if p (unsafe_get a i) then loop (i + 1)\n      else false in\n    loop 0\n\n  (* duplicated from array.ml *)\n  let mem x a =\n    let n = length a in\n    let rec loop i =\n      if i = n then false\n      else if compare (unsafe_get a i) x = 0 then true\n      else loop (i + 1)\n    in\n    loop 0\n\n  (* mostly duplicated from array.ml, but slightly different *)\n  let mem_ieee x a =\n    let n = length a in\n    let rec loop i =\n      if i = n then false\n      else if x = (unsafe_get a i) then true\n      else loop (i + 1)\n    in\n    loop 0\n\n  (* duplicated from array.ml *)\n  exception Bottom of int\n  let sort cmp a =\n    let maxson l i =\n      let i31 = i+i+i+1 in\n      let x = ref i31 in\n      if i31+2 < l then begin\n        if cmp (get a i31) (get a (i31+1)) < 0 then x := i31+1;\n        if cmp (get a !x) (get a (i31+2)) < 0 then x := i31+2;\n        !x\n      end else\n        if i31+1 < l && cmp (get a i31) (get a (i31+1)) < 0\n        then i31+1\n        else if i31 < l then i31 else raise (Bottom i)\n    in\n    let rec trickledown l i e =\n      let j = maxson l i in\n      if cmp (get a j) e > 0 then begin\n        set a i (get a j);\n        trickledown l j e;\n      end else begin\n        set a i e;\n      end;\n    in\n    let trickle l i e = try trickledown l i e with Bottom i -> set a i e in\n    let rec bubbledown l i =\n      let j = maxson l i in\n      set a i (get a j);\n      bubbledown l j\n    in\n    let bubble l i = try bubbledown l i with Bottom i -> i in\n    let rec trickleup i e =\n      let father = (i - 1) / 3 in\n      assert (i <> father);\n      if cmp (get a father) e < 0 then begin\n        set a i (get a father);\n        if father > 0 then trickleup father e else set a 0 e;\n      end else begin\n        set a i e;\n      end;\n    in\n    let l = length a in\n    for i = (l + 1) / 3 - 1 downto 0 do trickle l i (get a i); done;\n    for i = l - 1 downto 2 do\n      let e = (get a i) in\n      set a i (get a 0);\n      trickleup (bubble i 0) e;\n    done;\n    if l > 1 then (let e = (get a 1) in set a 1 (get a 0); set a 0 e)\n\n  (* duplicated from array.ml, except for the call to [create] *)\n  let cutoff = 5\n  let stable_sort cmp a =\n    let merge src1ofs src1len src2 src2ofs src2len dst dstofs =\n      let src1r = src1ofs + src1len and src2r = src2ofs + src2len in\n      let rec loop i1 s1 i2 s2 d =\n        if cmp s1 s2 <= 0 then begin\n          set dst d s1;\n          let i1 = i1 + 1 in\n          if i1 < src1r then\n            loop i1 (get a i1) i2 s2 (d + 1)\n          else\n            blit src2 i2 dst (d + 1) (src2r - i2)\n        end else begin\n          set dst d s2;\n          let i2 = i2 + 1 in\n          if i2 < src2r then\n            loop i1 s1 i2 (get src2 i2) (d + 1)\n          else\n            blit a i1 dst (d + 1) (src1r - i1)\n        end\n      in loop src1ofs (get a src1ofs) src2ofs (get src2 src2ofs) dstofs;\n    in\n    let isortto srcofs dst dstofs len =\n      for i = 0 to len - 1 do\n        let e = (get a (srcofs + i)) in\n        let j = ref (dstofs + i - 1) in\n        while (!j >= dstofs && cmp (get dst !j) e > 0) do\n          set dst (!j + 1) (get dst !j);\n          decr j;\n        done;\n        set dst (!j + 1) e;\n      done;\n    in\n    let rec sortto srcofs dst dstofs len =\n      if len <= cutoff then isortto srcofs dst dstofs len else begin\n        let l1 = len / 2 in\n        let l2 = len - l1 in\n        sortto (srcofs + l1) dst (dstofs + l1) l2;\n        sortto srcofs a (srcofs + l2) l1;\n        merge (srcofs + l2) l1 dst (dstofs + l1) l2 dst dstofs;\n      end;\n    in\n    let l = length a in\n    if l <= cutoff then isortto 0 a 0 l else begin\n      let l1 = l / 2 in\n      let l2 = l - l1 in\n      let t = create l2 in\n      sortto l1 t 0 l2;\n      sortto 0 a l2 l1;\n      merge l2 l1 t 0 l2 a 0;\n    end\n\n  let fast_sort = stable_sort\n\n  (* duplicated from array.ml *)\n  let to_seq a =\n    let rec aux i () =\n      if i < length a\n      then\n        let x = unsafe_get a i in\n        Seq.Cons (x, aux (i+1))\n      else Seq.Nil\n    in\n    aux 0\n\n  (* duplicated from array.ml *)\n  let to_seqi a =\n    let rec aux i () =\n      if i < length a\n      then\n        let x = unsafe_get a i in\n        Seq.Cons ((i,x), aux (i+1))\n      else Seq.Nil\n    in\n    aux 0\n\n  (* mostly duplicated from array.ml *)\n  let of_rev_list l =\n    let len = List.length l in\n    let a = create len in\n    let rec fill i = function\n        [] -> a\n      | hd::tl -> unsafe_set a i hd; fill (i-1) tl\n    in\n    fill (len-1) l\n\n  (* duplicated from array.ml *)\n  let of_seq i =\n    let l = Seq.fold_left (fun acc x -> x::acc) [] i in\n    of_rev_list l\n\n\n  let map_to_array f a =\n    let l = length a in\n    if l = 0 then [| |] else begin\n      let r = Array.make l (f (unsafe_get a 0)) in\n      for i = 1 to l - 1 do\n        Array.unsafe_set r i (f (unsafe_get a i))\n      done;\n      r\n    end\n\n  let map_from_array f a =\n    let l = Array.length a in\n    let r = create l in\n    for i = 0 to l - 1 do\n      unsafe_set r i (f (Array.unsafe_get a i))\n    done;\n    r\n\nend\n\nmodule ArrayLabels = Array\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Module [Int32]: 32-bit integers *)\n\nexternal neg : int32 -> int32 = \"%int32_neg\"\nexternal add : int32 -> int32 -> int32 = \"%int32_add\"\nexternal sub : int32 -> int32 -> int32 = \"%int32_sub\"\nexternal mul : int32 -> int32 -> int32 = \"%int32_mul\"\nexternal div : int32 -> int32 -> int32 = \"%int32_div\"\nexternal rem : int32 -> int32 -> int32 = \"%int32_mod\"\nexternal logand : int32 -> int32 -> int32 = \"%int32_and\"\nexternal logor : int32 -> int32 -> int32 = \"%int32_or\"\nexternal logxor : int32 -> int32 -> int32 = \"%int32_xor\"\nexternal shift_left : int32 -> int -> int32 = \"%int32_lsl\"\nexternal shift_right : int32 -> int -> int32 = \"%int32_asr\"\nexternal shift_right_logical : int32 -> int -> int32 = \"%int32_lsr\"\nexternal of_int : int -> int32 = \"%int32_of_int\"\nexternal to_int : int32 -> int = \"%int32_to_int\"\nexternal of_float : float -> int32\n  = \"caml_int32_of_float\" \"caml_int32_of_float_unboxed\"\n  [@@unboxed] [@@noalloc]\nexternal to_float : int32 -> float\n  = \"caml_int32_to_float\" \"caml_int32_to_float_unboxed\"\n  [@@unboxed] [@@noalloc]\nexternal bits_of_float : float -> int32\n  = \"caml_int32_bits_of_float\" \"caml_int32_bits_of_float_unboxed\"\n  [@@unboxed] [@@noalloc]\nexternal float_of_bits : int32 -> float\n  = \"caml_int32_float_of_bits\" \"caml_int32_float_of_bits_unboxed\"\n  [@@unboxed] [@@noalloc]\n\nlet zero = 0l\nlet one = 1l\nlet minus_one = -1l\nlet succ n = add n 1l\nlet pred n = sub n 1l\nlet abs n = if n >= 0l then n else neg n\nlet min_int = 0x80000000l\nlet max_int = 0x7FFFFFFFl\nlet lognot n = logxor n (-1l)\n\nlet unsigned_to_int =\n  match Sys.word_size with\n  | 32 ->\n      let max_int = of_int Stdlib.max_int in\n      fun n ->\n        if compare zero n <= 0 && compare n max_int <= 0 then\n          Some (to_int n)\n        else\n          None\n  | 64 ->\n      (* So that it compiles in 32-bit *)\n      let mask = 0xFFFF lsl 16 lor 0xFFFF in\n      fun n -> Some (to_int n land mask)\n  | _ ->\n      assert false\n\nexternal format : string -> int32 -> string = \"caml_int32_format\"\nlet to_string n = format \"%d\" n\n\nexternal of_string : string -> int32 = \"caml_int32_of_string\"\n\nlet of_string_opt s =\n  (* TODO: expose a non-raising primitive directly. *)\n  try Some (of_string s)\n  with Failure _ -> None\n\ntype t = int32\n\nlet compare (x: t) (y: t) = Stdlib.compare x y\nlet equal (x: t) (y: t) = compare x y = 0\n\nlet unsigned_compare n m =\n  compare (sub n min_int) (sub m min_int)\n\nlet min x y : t = if x <= y then x else y\nlet max x y : t = if x >= y then x else y\n\n(* Unsigned division from signed division of the same\n   bitness. See Warren Jr., Henry S. (2013). Hacker's Delight (2 ed.), Sec 9-3.\n*)\nlet unsigned_div n d =\n  if d < zero then\n    if unsigned_compare n d < 0 then zero else one\n  else\n    let q = shift_left (div (shift_right_logical n 1) d) 1 in\n    let r = sub n (mul q d) in\n    if unsigned_compare r d >= 0 then succ q else q\n\nlet unsigned_rem n d =\n  sub n (mul (unsigned_div n d) d)\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Module [Int64]: 64-bit integers *)\n\nexternal neg : int64 -> int64 = \"%int64_neg\"\nexternal add : int64 -> int64 -> int64 = \"%int64_add\"\nexternal sub : int64 -> int64 -> int64 = \"%int64_sub\"\nexternal mul : int64 -> int64 -> int64 = \"%int64_mul\"\nexternal div : int64 -> int64 -> int64 = \"%int64_div\"\nexternal rem : int64 -> int64 -> int64 = \"%int64_mod\"\nexternal logand : int64 -> int64 -> int64 = \"%int64_and\"\nexternal logor : int64 -> int64 -> int64 = \"%int64_or\"\nexternal logxor : int64 -> int64 -> int64 = \"%int64_xor\"\nexternal shift_left : int64 -> int -> int64 = \"%int64_lsl\"\nexternal shift_right : int64 -> int -> int64 = \"%int64_asr\"\nexternal shift_right_logical : int64 -> int -> int64 = \"%int64_lsr\"\nexternal of_int : int -> int64 = \"%int64_of_int\"\nexternal to_int : int64 -> int = \"%int64_to_int\"\nexternal of_float : float -> int64\n  = \"caml_int64_of_float\" \"caml_int64_of_float_unboxed\"\n  [@@unboxed] [@@noalloc]\nexternal to_float : int64 -> float\n  = \"caml_int64_to_float\" \"caml_int64_to_float_unboxed\"\n  [@@unboxed] [@@noalloc]\nexternal of_int32 : int32 -> int64 = \"%int64_of_int32\"\nexternal to_int32 : int64 -> int32 = \"%int64_to_int32\"\nexternal of_nativeint : nativeint -> int64 = \"%int64_of_nativeint\"\nexternal to_nativeint : int64 -> nativeint = \"%int64_to_nativeint\"\n\nlet zero = 0L\nlet one = 1L\nlet minus_one = -1L\nlet succ n = add n 1L\nlet pred n = sub n 1L\nlet abs n = if n >= 0L then n else neg n\nlet min_int = 0x8000000000000000L\nlet max_int = 0x7FFFFFFFFFFFFFFFL\nlet lognot n = logxor n (-1L)\n\nlet unsigned_to_int =\n  let max_int = of_int Stdlib.max_int in\n  fun n ->\n    if compare zero n <= 0 && compare n max_int <= 0 then\n      Some (to_int n)\n    else\n      None\n\nexternal format : string -> int64 -> string = \"caml_int64_format\"\nlet to_string n = format \"%d\" n\n\nexternal of_string : string -> int64 = \"caml_int64_of_string\"\n\nlet of_string_opt s =\n  (* TODO: expose a non-raising primitive directly. *)\n  try Some (of_string s)\n  with Failure _ -> None\n\n\n\nexternal bits_of_float : float -> int64\n  = \"caml_int64_bits_of_float\" \"caml_int64_bits_of_float_unboxed\"\n  [@@unboxed] [@@noalloc]\nexternal float_of_bits : int64 -> float\n  = \"caml_int64_float_of_bits\" \"caml_int64_float_of_bits_unboxed\"\n  [@@unboxed] [@@noalloc]\n\ntype t = int64\n\nlet compare (x: t) (y: t) = Stdlib.compare x y\nlet equal (x: t) (y: t) = compare x y = 0\n\nlet unsigned_compare n m =\n  compare (sub n min_int) (sub m min_int)\n\nlet min x y : t = if x <= y then x else y\nlet max x y : t = if x >= y then x else y\n\n(* Unsigned division from signed division of the same\n   bitness. See Warren Jr., Henry S. (2013). Hacker's Delight (2 ed.), Sec 9-3.\n*)\nlet unsigned_div n d =\n  if d < zero then\n    if unsigned_compare n d < 0 then zero else one\n  else\n    let q = shift_left (div (shift_right_logical n 1) d) 1 in\n    let r = sub n (mul q d) in\n    if unsigned_compare r d >= 0 then succ q else q\n\nlet unsigned_rem n d =\n  sub n (mul (unsigned_div n d) d)\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Module [Nativeint]: processor-native integers *)\n\nexternal neg: nativeint -> nativeint = \"%nativeint_neg\"\nexternal add: nativeint -> nativeint -> nativeint = \"%nativeint_add\"\nexternal sub: nativeint -> nativeint -> nativeint = \"%nativeint_sub\"\nexternal mul: nativeint -> nativeint -> nativeint = \"%nativeint_mul\"\nexternal div: nativeint -> nativeint -> nativeint = \"%nativeint_div\"\nexternal rem: nativeint -> nativeint -> nativeint = \"%nativeint_mod\"\nexternal logand: nativeint -> nativeint -> nativeint = \"%nativeint_and\"\nexternal logor: nativeint -> nativeint -> nativeint = \"%nativeint_or\"\nexternal logxor: nativeint -> nativeint -> nativeint = \"%nativeint_xor\"\nexternal shift_left: nativeint -> int -> nativeint = \"%nativeint_lsl\"\nexternal shift_right: nativeint -> int -> nativeint = \"%nativeint_asr\"\nexternal shift_right_logical: nativeint -> int -> nativeint = \"%nativeint_lsr\"\nexternal of_int: int -> nativeint = \"%nativeint_of_int\"\nexternal to_int: nativeint -> int = \"%nativeint_to_int\"\nexternal of_float : float -> nativeint\n  = \"caml_nativeint_of_float\" \"caml_nativeint_of_float_unboxed\"\n  [@@unboxed] [@@noalloc]\nexternal to_float : nativeint -> float\n  = \"caml_nativeint_to_float\" \"caml_nativeint_to_float_unboxed\"\n  [@@unboxed] [@@noalloc]\nexternal of_int32: int32 -> nativeint = \"%nativeint_of_int32\"\nexternal to_int32: nativeint -> int32 = \"%nativeint_to_int32\"\n\nlet zero = 0n\nlet one = 1n\nlet minus_one = -1n\nlet succ n = add n 1n\nlet pred n = sub n 1n\nlet abs n = if n >= 0n then n else neg n\nlet size = Sys.word_size\nlet min_int = shift_left 1n (size - 1)\nlet max_int = sub min_int 1n\nlet lognot n = logxor n (-1n)\n\nlet unsigned_to_int =\n  let max_int = of_int Stdlib.max_int in\n  fun n ->\n    if compare zero n <= 0 && compare n max_int <= 0 then\n      Some (to_int n)\n    else\n      None\n\nexternal format : string -> nativeint -> string = \"caml_nativeint_format\"\nlet to_string n = format \"%d\" n\n\nexternal of_string: string -> nativeint = \"caml_nativeint_of_string\"\n\nlet of_string_opt s =\n  (* TODO: expose a non-raising primitive directly. *)\n  try Some (of_string s)\n  with Failure _ -> None\n\ntype t = nativeint\n\nlet compare (x: t) (y: t) = Stdlib.compare x y\nlet equal (x: t) (y: t) = compare x y = 0\n\nlet unsigned_compare n m =\n  compare (sub n min_int) (sub m min_int)\n\nlet min x y : t = if x <= y then x else y\nlet max x y : t = if x >= y then x else y\n\n(* Unsigned division from signed division of the same\n   bitness. See Warren Jr., Henry S. (2013). Hacker's Delight (2 ed.), Sec 9-3.\n*)\nlet unsigned_div n d =\n  if d < zero then\n    if unsigned_compare n d < 0 then zero else one\n  else\n    let q = shift_left (div (shift_right_logical n 1) d) 1 in\n    let r = sub n (mul q d) in\n    if unsigned_compare r d >= 0 then succ q else q\n\nlet unsigned_rem n d =\n  sub n (mul (unsigned_div n d) d)\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* The run-time library for lexers generated by camllex *)\n\ntype position = {\n  pos_fname : string;\n  pos_lnum : int;\n  pos_bol : int;\n  pos_cnum : int;\n}\n\nlet dummy_pos = {\n  pos_fname = \"\";\n  pos_lnum = 0;\n  pos_bol = 0;\n  pos_cnum = -1;\n}\n\ntype lexbuf =\n  { refill_buff : lexbuf -> unit;\n    mutable lex_buffer : bytes;\n    mutable lex_buffer_len : int;\n    mutable lex_abs_pos : int;\n    mutable lex_start_pos : int;\n    mutable lex_curr_pos : int;\n    mutable lex_last_pos : int;\n    mutable lex_last_action : int;\n    mutable lex_eof_reached : bool;\n    mutable lex_mem : int array;\n    mutable lex_start_p : position;\n    mutable lex_curr_p : position;\n  }\n\ntype lex_tables =\n  { lex_base: string;\n    lex_backtrk: string;\n    lex_default: string;\n    lex_trans: string;\n    lex_check: string;\n    lex_base_code : string;\n    lex_backtrk_code : string;\n    lex_default_code : string;\n    lex_trans_code : string;\n    lex_check_code : string;\n    lex_code: string;}\n\nexternal c_engine : lex_tables -> int -> lexbuf -> int = \"caml_lex_engine\"\nexternal c_new_engine : lex_tables -> int -> lexbuf -> int\n                      = \"caml_new_lex_engine\"\n\nlet engine tbl state buf =\n  let result = c_engine tbl state buf in\n  if result >= 0 && buf.lex_curr_p != dummy_pos then begin\n    buf.lex_start_p <- buf.lex_curr_p;\n    buf.lex_curr_p <- {buf.lex_curr_p\n                       with pos_cnum = buf.lex_abs_pos + buf.lex_curr_pos};\n  end;\n  result\n\n\nlet new_engine tbl state buf =\n  let result = c_new_engine tbl state buf in\n  if result >= 0 && buf.lex_curr_p != dummy_pos then begin\n    buf.lex_start_p <- buf.lex_curr_p;\n    buf.lex_curr_p <- {buf.lex_curr_p\n                       with pos_cnum = buf.lex_abs_pos + buf.lex_curr_pos};\n  end;\n  result\n\nlet lex_refill read_fun aux_buffer lexbuf =\n  let read =\n    read_fun aux_buffer (Bytes.length aux_buffer) in\n  let n =\n    if read > 0\n    then read\n    else (lexbuf.lex_eof_reached <- true; 0) in\n  (* Current state of the buffer:\n        <-------|---------------------|----------->\n        |  junk |      valid data     |   junk    |\n        ^       ^                     ^           ^\n        0    start_pos             buffer_end    Bytes.length buffer\n  *)\n  if lexbuf.lex_buffer_len + n > Bytes.length lexbuf.lex_buffer then begin\n    (* There is not enough space at the end of the buffer *)\n    if lexbuf.lex_buffer_len - lexbuf.lex_start_pos + n\n       <= Bytes.length lexbuf.lex_buffer\n    then begin\n      (* But there is enough space if we reclaim the junk at the beginning\n         of the buffer *)\n      Bytes.blit lexbuf.lex_buffer lexbuf.lex_start_pos\n                  lexbuf.lex_buffer 0\n                  (lexbuf.lex_buffer_len - lexbuf.lex_start_pos)\n    end else begin\n      (* We must grow the buffer.  Doubling its size will provide enough\n         space since n <= String.length aux_buffer <= String.length buffer.\n         Watch out for string length overflow, though. *)\n      let newlen =\n        Int.min (2 * Bytes.length lexbuf.lex_buffer) Sys.max_string_length in\n      if lexbuf.lex_buffer_len - lexbuf.lex_start_pos + n > newlen\n      then failwith \"Lexing.lex_refill: cannot grow buffer\";\n      let newbuf = Bytes.create newlen in\n      (* Copy the valid data to the beginning of the new buffer *)\n      Bytes.blit lexbuf.lex_buffer lexbuf.lex_start_pos\n                  newbuf 0\n                  (lexbuf.lex_buffer_len - lexbuf.lex_start_pos);\n      lexbuf.lex_buffer <- newbuf\n    end;\n    (* Reallocation or not, we have shifted the data left by\n       start_pos characters; update the positions *)\n    let s = lexbuf.lex_start_pos in\n    lexbuf.lex_abs_pos <- lexbuf.lex_abs_pos + s;\n    lexbuf.lex_curr_pos <- lexbuf.lex_curr_pos - s;\n    lexbuf.lex_start_pos <- 0;\n    lexbuf.lex_last_pos <- lexbuf.lex_last_pos - s;\n    lexbuf.lex_buffer_len <- lexbuf.lex_buffer_len - s ;\n    let t = lexbuf.lex_mem in\n    for i = 0 to Array.length t-1 do\n      let v = t.(i) in\n      if v >= 0 then\n        t.(i) <- v-s\n    done\n  end;\n  (* There is now enough space at the end of the buffer *)\n  Bytes.blit aux_buffer 0 lexbuf.lex_buffer lexbuf.lex_buffer_len n;\n  lexbuf.lex_buffer_len <- lexbuf.lex_buffer_len + n\n\nlet zero_pos = {\n  pos_fname = \"\";\n  pos_lnum = 1;\n  pos_bol = 0;\n  pos_cnum = 0;\n}\n\nlet from_function ?(with_positions = true) f =\n  { refill_buff = lex_refill f (Bytes.create 512);\n    lex_buffer = Bytes.create 1024;\n    lex_buffer_len = 0;\n    lex_abs_pos = 0;\n    lex_start_pos = 0;\n    lex_curr_pos = 0;\n    lex_last_pos = 0;\n    lex_last_action = 0;\n    lex_mem = [||];\n    lex_eof_reached = false;\n    lex_start_p = if with_positions then zero_pos else dummy_pos;\n    lex_curr_p = if with_positions then zero_pos else dummy_pos;\n  }\n\nlet from_channel ?with_positions ic =\n  from_function ?with_positions (fun buf n -> input ic buf 0 n)\n\nlet from_string ?(with_positions = true) s =\n  { refill_buff = (fun lexbuf -> lexbuf.lex_eof_reached <- true);\n    lex_buffer = Bytes.of_string s; (* have to make a copy for compatibility\n                                       with unsafe-string mode *)\n    lex_buffer_len = String.length s;\n    lex_abs_pos = 0;\n    lex_start_pos = 0;\n    lex_curr_pos = 0;\n    lex_last_pos = 0;\n    lex_last_action = 0;\n    lex_mem = [||];\n    lex_eof_reached = true;\n    lex_start_p = if with_positions then zero_pos else dummy_pos;\n    lex_curr_p = if with_positions then zero_pos else dummy_pos;\n  }\n\nlet set_position lexbuf position =\n  lexbuf.lex_curr_p  <- {position with pos_fname = lexbuf.lex_curr_p.pos_fname};\n  lexbuf.lex_abs_pos <- position.pos_cnum\n\nlet set_filename lexbuf fname =\n  lexbuf.lex_curr_p <- {lexbuf.lex_curr_p with pos_fname = fname}\n\nlet with_positions lexbuf = lexbuf.lex_curr_p != dummy_pos\n\nlet lexeme lexbuf =\n  let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n  Bytes.sub_string lexbuf.lex_buffer lexbuf.lex_start_pos len\n\nlet sub_lexeme lexbuf i1 i2 =\n  let len = i2-i1 in\n  Bytes.sub_string lexbuf.lex_buffer i1 len\n\nlet sub_lexeme_opt lexbuf i1 i2 =\n  if i1 >= 0 then begin\n    let len = i2-i1 in\n    Some (Bytes.sub_string lexbuf.lex_buffer i1 len)\n  end else begin\n    None\n  end\n\nlet sub_lexeme_char lexbuf i = Bytes.get lexbuf.lex_buffer i\n\nlet sub_lexeme_char_opt lexbuf i =\n  if i >= 0 then\n    Some (Bytes.get lexbuf.lex_buffer i)\n  else\n    None\n\n\nlet lexeme_char lexbuf i =\n  Bytes.get lexbuf.lex_buffer (lexbuf.lex_start_pos + i)\n\nlet lexeme_start lexbuf = lexbuf.lex_start_p.pos_cnum\nlet lexeme_end lexbuf = lexbuf.lex_curr_p.pos_cnum\n\nlet lexeme_start_p lexbuf = lexbuf.lex_start_p\nlet lexeme_end_p lexbuf = lexbuf.lex_curr_p\n\nlet new_line lexbuf =\n  let lcp = lexbuf.lex_curr_p in\n  if lcp != dummy_pos then\n    lexbuf.lex_curr_p <-\n      { lcp with\n        pos_lnum = lcp.pos_lnum + 1;\n        pos_bol = lcp.pos_cnum;\n      }\n\n\n\n(* Discard data left in lexer buffer. *)\n\nlet flush_input lb =\n  lb.lex_curr_pos <- 0;\n  lb.lex_abs_pos <- 0;\n  let lcp = lb.lex_curr_p in\n  if lcp != dummy_pos then\n    lb.lex_curr_p <- {zero_pos with pos_fname = lcp.pos_fname};\n  lb.lex_buffer_len <- 0;\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* The parsing engine *)\n\nopen Lexing\n\n(* Internal interface to the parsing engine *)\n\ntype parser_env =\n  { mutable s_stack : int array;        (* States *)\n    mutable v_stack : Obj.t array;      (* Semantic attributes *)\n    mutable symb_start_stack : position array; (* Start positions *)\n    mutable symb_end_stack : position array;   (* End positions *)\n    mutable stacksize : int;            (* Size of the stacks *)\n    mutable stackbase : int;            (* Base sp for current parse *)\n    mutable curr_char : int;            (* Last token read *)\n    mutable lval : Obj.t;               (* Its semantic attribute *)\n    mutable symb_start : position;      (* Start pos. of the current symbol*)\n    mutable symb_end : position;        (* End pos. of the current symbol *)\n    mutable asp : int;                  (* The stack pointer for attributes *)\n    mutable rule_len : int;             (* Number of rhs items in the rule *)\n    mutable rule_number : int;          (* Rule number to reduce by *)\n    mutable sp : int;                   (* Saved sp for parse_engine *)\n    mutable state : int;                (* Saved state for parse_engine *)\n    mutable errflag : int }             (* Saved error flag for parse_engine *)\n[@@warning \"-unused-field\"]\n\ntype parse_tables =\n  { actions : (parser_env -> Obj.t) array;\n    transl_const : int array;\n    transl_block : int array;\n    lhs : string;\n    len : string;\n    defred : string;\n    dgoto : string;\n    sindex : string;\n    rindex : string;\n    gindex : string;\n    tablesize : int;\n    table : string;\n    check : string;\n    error_function : string -> unit;\n    names_const : string;\n    names_block : string }\n\nexception YYexit of Obj.t\nexception Parse_error\n\ntype parser_input =\n    Start\n  | Token_read\n  | Stacks_grown_1\n  | Stacks_grown_2\n  | Semantic_action_computed\n  | Error_detected\n\ntype parser_output =\n    Read_token\n  | Raise_parse_error\n  | Grow_stacks_1\n  | Grow_stacks_2\n  | Compute_semantic_action\n  | Call_error_function\n\n(* to avoid warnings *)\nlet _ = [Read_token; Raise_parse_error; Grow_stacks_1; Grow_stacks_2;\n         Compute_semantic_action; Call_error_function]\n\nexternal parse_engine :\n    parse_tables -> parser_env -> parser_input -> Obj.t -> parser_output\n    = \"caml_parse_engine\"\n\nexternal set_trace: bool -> bool\n    = \"caml_set_parser_trace\"\n\nlet env =\n  { s_stack = Array.make 100 0;\n    v_stack = Array.make 100 (Obj.repr ());\n    symb_start_stack = Array.make 100 dummy_pos;\n    symb_end_stack = Array.make 100 dummy_pos;\n    stacksize = 100;\n    stackbase = 0;\n    curr_char = 0;\n    lval = Obj.repr ();\n    symb_start = dummy_pos;\n    symb_end = dummy_pos;\n    asp = 0;\n    rule_len = 0;\n    rule_number = 0;\n    sp = 0;\n    state = 0;\n    errflag = 0 }\n\nlet grow_stacks() =\n  let oldsize = env.stacksize in\n  let newsize = oldsize * 2 in\n  let new_s = Array.make newsize 0\n  and new_v = Array.make newsize (Obj.repr ())\n  and new_start = Array.make newsize dummy_pos\n  and new_end = Array.make newsize dummy_pos in\n    Array.blit env.s_stack 0 new_s 0 oldsize;\n    env.s_stack <- new_s;\n    Array.blit env.v_stack 0 new_v 0 oldsize;\n    env.v_stack <- new_v;\n    Array.blit env.symb_start_stack 0 new_start 0 oldsize;\n    env.symb_start_stack <- new_start;\n    Array.blit env.symb_end_stack 0 new_end 0 oldsize;\n    env.symb_end_stack <- new_end;\n    env.stacksize <- newsize\n\nlet clear_parser() =\n  Array.fill env.v_stack 0 env.stacksize (Obj.repr ());\n  env.lval <- Obj.repr ()\n\nlet current_lookahead_fun = ref (fun (_ : Obj.t) -> false)\n\nlet yyparse tables start lexer lexbuf =\n  let rec loop cmd arg =\n    match parse_engine tables env cmd arg with\n      Read_token ->\n        let t = Obj.repr(lexer lexbuf) in\n        env.symb_start <- lexbuf.lex_start_p;\n        env.symb_end <- lexbuf.lex_curr_p;\n        loop Token_read t\n    | Raise_parse_error ->\n        raise Parse_error\n    | Compute_semantic_action ->\n        let (action, value) =\n          try\n            (Semantic_action_computed, tables.actions.(env.rule_number) env)\n          with Parse_error ->\n            (Error_detected, Obj.repr ()) in\n        loop action value\n    | Grow_stacks_1 ->\n        grow_stacks(); loop Stacks_grown_1 (Obj.repr ())\n    | Grow_stacks_2 ->\n        grow_stacks(); loop Stacks_grown_2 (Obj.repr ())\n    | Call_error_function ->\n        tables.error_function \"syntax error\";\n        loop Error_detected (Obj.repr ()) in\n  let init_asp = env.asp\n  and init_sp = env.sp\n  and init_stackbase = env.stackbase\n  and init_state = env.state\n  and init_curr_char = env.curr_char\n  and init_lval = env.lval\n  and init_errflag = env.errflag in\n  env.stackbase <- env.sp + 1;\n  env.curr_char <- start;\n  env.symb_end <- lexbuf.lex_curr_p;\n  try\n    loop Start (Obj.repr ())\n  with exn ->\n    let curr_char = env.curr_char in\n    env.asp <- init_asp;\n    env.sp <- init_sp;\n    env.stackbase <- init_stackbase;\n    env.state <- init_state;\n    env.curr_char <- init_curr_char;\n    env.lval <- init_lval;\n    env.errflag <- init_errflag;\n    match exn with\n      YYexit v ->\n        Obj.magic v\n    | _ ->\n        current_lookahead_fun :=\n          (fun tok ->\n            if Obj.is_block tok\n            then tables.transl_block.(Obj.tag tok) = curr_char\n            else tables.transl_const.(Obj.magic tok) = curr_char);\n        raise exn\n\nlet peek_val env n =\n  Obj.magic env.v_stack.(env.asp - n)\n\nlet symbol_start_pos () =\n  let rec loop i =\n    if i <= 0 then env.symb_end_stack.(env.asp)\n    else begin\n      let st = env.symb_start_stack.(env.asp - i + 1) in\n      let en = env.symb_end_stack.(env.asp - i + 1) in\n      if st <> en then st else loop (i - 1)\n    end\n  in\n  loop env.rule_len\n\nlet symbol_end_pos () = env.symb_end_stack.(env.asp)\nlet rhs_start_pos n = env.symb_start_stack.(env.asp - (env.rule_len - n))\nlet rhs_end_pos n = env.symb_end_stack.(env.asp - (env.rule_len - n))\n\nlet symbol_start () = (symbol_start_pos ()).pos_cnum\nlet symbol_end () = (symbol_end_pos ()).pos_cnum\nlet rhs_start n = (rhs_start_pos n).pos_cnum\nlet rhs_end n = (rhs_end_pos n).pos_cnum\n\nlet is_current_lookahead tok =\n  (!current_lookahead_fun)(Obj.repr tok)\n\nlet parse_error (_ : string) = ()\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Sets over ordered types *)\n\nmodule type OrderedType =\n  sig\n    type t\n    val compare: t -> t -> int\n  end\n\nmodule type S =\n  sig\n    type elt\n    type t\n    val empty: t\n    val is_empty: t -> bool\n    val mem: elt -> t -> bool\n    val add: elt -> t -> t\n    val singleton: elt -> t\n    val remove: elt -> t -> t\n    val union: t -> t -> t\n    val inter: t -> t -> t\n    val disjoint: t -> t -> bool\n    val diff: t -> t -> t\n    val compare: t -> t -> int\n    val equal: t -> t -> bool\n    val subset: t -> t -> bool\n    val iter: (elt -> unit) -> t -> unit\n    val map: (elt -> elt) -> t -> t\n    val fold: (elt -> 'a -> 'a) -> t -> 'a -> 'a\n    val for_all: (elt -> bool) -> t -> bool\n    val exists: (elt -> bool) -> t -> bool\n    val filter: (elt -> bool) -> t -> t\n    val filter_map: (elt -> elt option) -> t -> t\n    val partition: (elt -> bool) -> t -> t * t\n    val cardinal: t -> int\n    val elements: t -> elt list\n    val min_elt: t -> elt\n    val min_elt_opt: t -> elt option\n    val max_elt: t -> elt\n    val max_elt_opt: t -> elt option\n    val choose: t -> elt\n    val choose_opt: t -> elt option\n    val split: elt -> t -> t * bool * t\n    val find: elt -> t -> elt\n    val find_opt: elt -> t -> elt option\n    val find_first: (elt -> bool) -> t -> elt\n    val find_first_opt: (elt -> bool) -> t -> elt option\n    val find_last: (elt -> bool) -> t -> elt\n    val find_last_opt: (elt -> bool) -> t -> elt option\n    val of_list: elt list -> t\n    val to_seq_from : elt -> t -> elt Seq.t\n    val to_seq : t -> elt Seq.t\n    val to_rev_seq : t -> elt Seq.t\n    val add_seq : elt Seq.t -> t -> t\n    val of_seq : elt Seq.t -> t\n  end\n\nmodule Make(Ord: OrderedType) =\n  struct\n    type elt = Ord.t\n    type t = Empty | Node of {l:t; v:elt; r:t; h:int}\n\n    (* Sets are represented by balanced binary trees (the heights of the\n       children differ by at most 2 *)\n\n    let height = function\n        Empty -> 0\n      | Node {h} -> h\n\n    (* Creates a new node with left son l, value v and right son r.\n       We must have all elements of l < v < all elements of r.\n       l and r must be balanced and | height l - height r | <= 2.\n       Inline expansion of height for better speed. *)\n\n    let create l v r =\n      let hl = match l with Empty -> 0 | Node {h} -> h in\n      let hr = match r with Empty -> 0 | Node {h} -> h in\n      Node{l; v; r; h=(if hl >= hr then hl + 1 else hr + 1)}\n\n    (* Same as create, but performs one step of rebalancing if necessary.\n       Assumes l and r balanced and | height l - height r | <= 3.\n       Inline expansion of create for better speed in the most frequent case\n       where no rebalancing is required. *)\n\n    let bal l v r =\n      let hl = match l with Empty -> 0 | Node {h} -> h in\n      let hr = match r with Empty -> 0 | Node {h} -> h in\n      if hl > hr + 2 then begin\n        match l with\n          Empty -> invalid_arg \"Set.bal\"\n        | Node{l=ll; v=lv; r=lr} ->\n            if height ll >= height lr then\n              create ll lv (create lr v r)\n            else begin\n              match lr with\n                Empty -> invalid_arg \"Set.bal\"\n              | Node{l=lrl; v=lrv; r=lrr}->\n                  create (create ll lv lrl) lrv (create lrr v r)\n            end\n      end else if hr > hl + 2 then begin\n        match r with\n          Empty -> invalid_arg \"Set.bal\"\n        | Node{l=rl; v=rv; r=rr} ->\n            if height rr >= height rl then\n              create (create l v rl) rv rr\n            else begin\n              match rl with\n                Empty -> invalid_arg \"Set.bal\"\n              | Node{l=rll; v=rlv; r=rlr} ->\n                  create (create l v rll) rlv (create rlr rv rr)\n            end\n      end else\n        Node{l; v; r; h=(if hl >= hr then hl + 1 else hr + 1)}\n\n    (* Insertion of one element *)\n\n    let rec add x = function\n        Empty -> Node{l=Empty; v=x; r=Empty; h=1}\n      | Node{l; v; r} as t ->\n          let c = Ord.compare x v in\n          if c = 0 then t else\n          if c < 0 then\n            let ll = add x l in\n            if l == ll then t else bal ll v r\n          else\n            let rr = add x r in\n            if r == rr then t else bal l v rr\n\n    let singleton x = Node{l=Empty; v=x; r=Empty; h=1}\n\n    (* Beware: those two functions assume that the added v is *strictly*\n       smaller (or bigger) than all the present elements in the tree; it\n       does not test for equality with the current min (or max) element.\n       Indeed, they are only used during the \"join\" operation which\n       respects this precondition.\n    *)\n\n    let rec add_min_element x = function\n      | Empty -> singleton x\n      | Node {l; v; r} ->\n        bal (add_min_element x l) v r\n\n    let rec add_max_element x = function\n      | Empty -> singleton x\n      | Node {l; v; r} ->\n        bal l v (add_max_element x r)\n\n    (* Same as create and bal, but no assumptions are made on the\n       relative heights of l and r. *)\n\n    let rec join l v r =\n      match (l, r) with\n        (Empty, _) -> add_min_element v r\n      | (_, Empty) -> add_max_element v l\n      | (Node{l=ll; v=lv; r=lr; h=lh}, Node{l=rl; v=rv; r=rr; h=rh}) ->\n          if lh > rh + 2 then bal ll lv (join lr v r) else\n          if rh > lh + 2 then bal (join l v rl) rv rr else\n          create l v r\n\n    (* Smallest and greatest element of a set *)\n\n    let rec min_elt = function\n        Empty -> raise Not_found\n      | Node{l=Empty; v} -> v\n      | Node{l} -> min_elt l\n\n    let rec min_elt_opt = function\n        Empty -> None\n      | Node{l=Empty; v} -> Some v\n      | Node{l} -> min_elt_opt l\n\n    let rec max_elt = function\n        Empty -> raise Not_found\n      | Node{v; r=Empty} -> v\n      | Node{r} -> max_elt r\n\n    let rec max_elt_opt = function\n        Empty -> None\n      | Node{v; r=Empty} -> Some v\n      | Node{r} -> max_elt_opt r\n\n    (* Remove the smallest element of the given set *)\n\n    let rec remove_min_elt = function\n        Empty -> invalid_arg \"Set.remove_min_elt\"\n      | Node{l=Empty; r} -> r\n      | Node{l; v; r} -> bal (remove_min_elt l) v r\n\n    (* Merge two trees l and r into one.\n       All elements of l must precede the elements of r.\n       Assume | height l - height r | <= 2. *)\n\n    let merge t1 t2 =\n      match (t1, t2) with\n        (Empty, t) -> t\n      | (t, Empty) -> t\n      | (_, _) -> bal t1 (min_elt t2) (remove_min_elt t2)\n\n    (* Merge two trees l and r into one.\n       All elements of l must precede the elements of r.\n       No assumption on the heights of l and r. *)\n\n    let concat t1 t2 =\n      match (t1, t2) with\n        (Empty, t) -> t\n      | (t, Empty) -> t\n      | (_, _) -> join t1 (min_elt t2) (remove_min_elt t2)\n\n    (* Splitting.  split x s returns a triple (l, present, r) where\n        - l is the set of elements of s that are < x\n        - r is the set of elements of s that are > x\n        - present is false if s contains no element equal to x,\n          or true if s contains an element equal to x. *)\n\n    let rec split x = function\n        Empty ->\n          (Empty, false, Empty)\n      | Node{l; v; r} ->\n          let c = Ord.compare x v in\n          if c = 0 then (l, true, r)\n          else if c < 0 then\n            let (ll, pres, rl) = split x l in (ll, pres, join rl v r)\n          else\n            let (lr, pres, rr) = split x r in (join l v lr, pres, rr)\n\n    (* Implementation of the set operations *)\n\n    let empty = Empty\n\n    let is_empty = function Empty -> true | _ -> false\n\n    let rec mem x = function\n        Empty -> false\n      | Node{l; v; r} ->\n          let c = Ord.compare x v in\n          c = 0 || mem x (if c < 0 then l else r)\n\n    let rec remove x = function\n        Empty -> Empty\n      | (Node{l; v; r} as t) ->\n          let c = Ord.compare x v in\n          if c = 0 then merge l r\n          else\n            if c < 0 then\n              let ll = remove x l in\n              if l == ll then t\n              else bal ll v r\n            else\n              let rr = remove x r in\n              if r == rr then t\n              else bal l v rr\n\n    let rec union s1 s2 =\n      match (s1, s2) with\n        (Empty, t2) -> t2\n      | (t1, Empty) -> t1\n      | (Node{l=l1; v=v1; r=r1; h=h1}, Node{l=l2; v=v2; r=r2; h=h2}) ->\n          if h1 >= h2 then\n            if h2 = 1 then add v2 s1 else begin\n              let (l2, _, r2) = split v1 s2 in\n              join (union l1 l2) v1 (union r1 r2)\n            end\n          else\n            if h1 = 1 then add v1 s2 else begin\n              let (l1, _, r1) = split v2 s1 in\n              join (union l1 l2) v2 (union r1 r2)\n            end\n\n    let rec inter s1 s2 =\n      match (s1, s2) with\n        (Empty, _) -> Empty\n      | (_, Empty) -> Empty\n      | (Node{l=l1; v=v1; r=r1}, t2) ->\n          match split v1 t2 with\n            (l2, false, r2) ->\n              concat (inter l1 l2) (inter r1 r2)\n          | (l2, true, r2) ->\n              join (inter l1 l2) v1 (inter r1 r2)\n\n    (* Same as split, but compute the left and right subtrees\n       only if the pivot element is not in the set.  The right subtree\n       is computed on demand. *)\n\n    type split_bis =\n      | Found\n      | NotFound of t * (unit -> t)\n\n    let rec split_bis x = function\n        Empty ->\n          NotFound (Empty, (fun () -> Empty))\n      | Node{l; v; r; _} ->\n          let c = Ord.compare x v in\n          if c = 0 then Found\n          else if c < 0 then\n            match split_bis x l with\n            | Found -> Found\n            | NotFound (ll, rl) -> NotFound (ll, (fun () -> join (rl ()) v r))\n          else\n            match split_bis x r with\n            | Found -> Found\n            | NotFound (lr, rr) -> NotFound (join l v lr, rr)\n\n    let rec disjoint s1 s2 =\n      match (s1, s2) with\n        (Empty, _) | (_, Empty) -> true\n      | (Node{l=l1; v=v1; r=r1}, t2) ->\n          if s1 == s2 then false\n          else match split_bis v1 t2 with\n              NotFound(l2, r2) -> disjoint l1 l2 && disjoint r1 (r2 ())\n            | Found -> false\n\n    let rec diff s1 s2 =\n      match (s1, s2) with\n        (Empty, _) -> Empty\n      | (t1, Empty) -> t1\n      | (Node{l=l1; v=v1; r=r1}, t2) ->\n          match split v1 t2 with\n            (l2, false, r2) ->\n              join (diff l1 l2) v1 (diff r1 r2)\n          | (l2, true, r2) ->\n              concat (diff l1 l2) (diff r1 r2)\n\n    type enumeration = End | More of elt * t * enumeration\n\n    let rec cons_enum s e =\n      match s with\n        Empty -> e\n      | Node{l; v; r} -> cons_enum l (More(v, r, e))\n\n    let rec compare_aux e1 e2 =\n        match (e1, e2) with\n        (End, End) -> 0\n      | (End, _)  -> -1\n      | (_, End) -> 1\n      | (More(v1, r1, e1), More(v2, r2, e2)) ->\n          let c = Ord.compare v1 v2 in\n          if c <> 0\n          then c\n          else compare_aux (cons_enum r1 e1) (cons_enum r2 e2)\n\n    let compare s1 s2 =\n      compare_aux (cons_enum s1 End) (cons_enum s2 End)\n\n    let equal s1 s2 =\n      compare s1 s2 = 0\n\n    let rec subset s1 s2 =\n      match (s1, s2) with\n        Empty, _ ->\n          true\n      | _, Empty ->\n          false\n      | Node {l=l1; v=v1; r=r1}, (Node {l=l2; v=v2; r=r2} as t2) ->\n          let c = Ord.compare v1 v2 in\n          if c = 0 then\n            subset l1 l2 && subset r1 r2\n          else if c < 0 then\n            subset (Node {l=l1; v=v1; r=Empty; h=0}) l2 && subset r1 t2\n          else\n            subset (Node {l=Empty; v=v1; r=r1; h=0}) r2 && subset l1 t2\n\n    let rec iter f = function\n        Empty -> ()\n      | Node{l; v; r} -> iter f l; f v; iter f r\n\n    let rec fold f s accu =\n      match s with\n        Empty -> accu\n      | Node{l; v; r} -> fold f r (f v (fold f l accu))\n\n    let rec for_all p = function\n        Empty -> true\n      | Node{l; v; r} -> p v && for_all p l && for_all p r\n\n    let rec exists p = function\n        Empty -> false\n      | Node{l; v; r} -> p v || exists p l || exists p r\n\n    let rec filter p = function\n        Empty -> Empty\n      | (Node{l; v; r}) as t ->\n          (* call [p] in the expected left-to-right order *)\n          let l' = filter p l in\n          let pv = p v in\n          let r' = filter p r in\n          if pv then\n            if l==l' && r==r' then t else join l' v r'\n          else concat l' r'\n\n    let rec partition p = function\n        Empty -> (Empty, Empty)\n      | Node{l; v; r} ->\n          (* call [p] in the expected left-to-right order *)\n          let (lt, lf) = partition p l in\n          let pv = p v in\n          let (rt, rf) = partition p r in\n          if pv\n          then (join lt v rt, concat lf rf)\n          else (concat lt rt, join lf v rf)\n\n    let rec cardinal = function\n        Empty -> 0\n      | Node{l; r} -> cardinal l + 1 + cardinal r\n\n    let rec elements_aux accu = function\n        Empty -> accu\n      | Node{l; v; r} -> elements_aux (v :: elements_aux accu r) l\n\n    let elements s =\n      elements_aux [] s\n\n    let choose = min_elt\n\n    let choose_opt = min_elt_opt\n\n    let rec find x = function\n        Empty -> raise Not_found\n      | Node{l; v; r} ->\n          let c = Ord.compare x v in\n          if c = 0 then v\n          else find x (if c < 0 then l else r)\n\n    let rec find_first_aux v0 f = function\n        Empty ->\n          v0\n      | Node{l; v; r} ->\n          if f v then\n            find_first_aux v f l\n          else\n            find_first_aux v0 f r\n\n    let rec find_first f = function\n        Empty ->\n          raise Not_found\n      | Node{l; v; r} ->\n          if f v then\n            find_first_aux v f l\n          else\n            find_first f r\n\n    let rec find_first_opt_aux v0 f = function\n        Empty ->\n          Some v0\n      | Node{l; v; r} ->\n          if f v then\n            find_first_opt_aux v f l\n          else\n            find_first_opt_aux v0 f r\n\n    let rec find_first_opt f = function\n        Empty ->\n          None\n      | Node{l; v; r} ->\n          if f v then\n            find_first_opt_aux v f l\n          else\n            find_first_opt f r\n\n    let rec find_last_aux v0 f = function\n        Empty ->\n          v0\n      | Node{l; v; r} ->\n          if f v then\n            find_last_aux v f r\n          else\n            find_last_aux v0 f l\n\n    let rec find_last f = function\n        Empty ->\n          raise Not_found\n      | Node{l; v; r} ->\n          if f v then\n            find_last_aux v f r\n          else\n            find_last f l\n\n    let rec find_last_opt_aux v0 f = function\n        Empty ->\n          Some v0\n      | Node{l; v; r} ->\n          if f v then\n            find_last_opt_aux v f r\n          else\n            find_last_opt_aux v0 f l\n\n    let rec find_last_opt f = function\n        Empty ->\n          None\n      | Node{l; v; r} ->\n          if f v then\n            find_last_opt_aux v f r\n          else\n            find_last_opt f l\n\n    let rec find_opt x = function\n        Empty -> None\n      | Node{l; v; r} ->\n          let c = Ord.compare x v in\n          if c = 0 then Some v\n          else find_opt x (if c < 0 then l else r)\n\n    let try_join l v r =\n      (* [join l v r] can only be called when (elements of l < v <\n         elements of r); use [try_join l v r] when this property may\n         not hold, but you hope it does hold in the common case *)\n      if (l = Empty || Ord.compare (max_elt l) v < 0)\n      && (r = Empty || Ord.compare v (min_elt r) < 0)\n      then join l v r\n      else union l (add v r)\n\n    let rec map f = function\n      | Empty -> Empty\n      | Node{l; v; r} as t ->\n         (* enforce left-to-right evaluation order *)\n         let l' = map f l in\n         let v' = f v in\n         let r' = map f r in\n         if l == l' && v == v' && r == r' then t\n         else try_join l' v' r'\n\n    let try_concat t1 t2 =\n      match (t1, t2) with\n        (Empty, t) -> t\n      | (t, Empty) -> t\n      | (_, _) -> try_join t1 (min_elt t2) (remove_min_elt t2)\n\n    let rec filter_map f = function\n      | Empty -> Empty\n      | Node{l; v; r} as t ->\n         (* enforce left-to-right evaluation order *)\n         let l' = filter_map f l in\n         let v' = f v in\n         let r' = filter_map f r in\n         begin match v' with\n           | Some v' ->\n              if l == l' && v == v' && r == r' then t\n              else try_join l' v' r'\n           | None ->\n              try_concat l' r'\n         end\n\n    let of_sorted_list l =\n      let rec sub n l =\n        match n, l with\n        | 0, l -> Empty, l\n        | 1, x0 :: l -> Node {l=Empty; v=x0; r=Empty; h=1}, l\n        | 2, x0 :: x1 :: l ->\n            Node{l=Node{l=Empty; v=x0; r=Empty; h=1}; v=x1; r=Empty; h=2}, l\n        | 3, x0 :: x1 :: x2 :: l ->\n            Node{l=Node{l=Empty; v=x0; r=Empty; h=1}; v=x1;\n                 r=Node{l=Empty; v=x2; r=Empty; h=1}; h=2}, l\n        | n, l ->\n          let nl = n / 2 in\n          let left, l = sub nl l in\n          match l with\n          | [] -> assert false\n          | mid :: l ->\n            let right, l = sub (n - nl - 1) l in\n            create left mid right, l\n      in\n      fst (sub (List.length l) l)\n\n    let of_list l =\n      match l with\n      | [] -> empty\n      | [x0] -> singleton x0\n      | [x0; x1] -> add x1 (singleton x0)\n      | [x0; x1; x2] -> add x2 (add x1 (singleton x0))\n      | [x0; x1; x2; x3] -> add x3 (add x2 (add x1 (singleton x0)))\n      | [x0; x1; x2; x3; x4] -> add x4 (add x3 (add x2 (add x1 (singleton x0))))\n      | _ -> of_sorted_list (List.sort_uniq Ord.compare l)\n\n    let add_seq i m =\n      Seq.fold_left (fun s x -> add x s) m i\n\n    let of_seq i = add_seq i empty\n\n    let rec seq_of_enum_ c () = match c with\n      | End -> Seq.Nil\n      | More (x, t, rest) -> Seq.Cons (x, seq_of_enum_ (cons_enum t rest))\n\n    let to_seq c = seq_of_enum_ (cons_enum c End)\n\n    let rec snoc_enum s e =\n      match s with\n        Empty -> e\n      | Node{l; v; r} -> snoc_enum r (More(v, l, e))\n\n    let rec rev_seq_of_enum_ c () = match c with\n      | End -> Seq.Nil\n      | More (x, t, rest) -> Seq.Cons (x, rev_seq_of_enum_ (snoc_enum t rest))\n\n    let to_rev_seq c = rev_seq_of_enum_ (snoc_enum c End)\n\n    let to_seq_from low s =\n      let rec aux low s c = match s with\n        | Empty -> c\n        | Node {l; r; v; _} ->\n            begin match Ord.compare v low with\n              | 0 -> More (v, r, c)\n              | n when n<0 -> aux low r c\n              | _ -> aux low l (More (v, r, c))\n            end\n      in\n      seq_of_enum_ (aux low s End)\n  end\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\nmodule type OrderedType =\n  sig\n    type t\n    val compare: t -> t -> int\n  end\n\nmodule type S =\n  sig\n    type key\n    type !+'a t\n    val empty: 'a t\n    val is_empty: 'a t -> bool\n    val mem:  key -> 'a t -> bool\n    val add: key -> 'a -> 'a t -> 'a t\n    val update: key -> ('a option -> 'a option) -> 'a t -> 'a t\n    val singleton: key -> 'a -> 'a t\n    val remove: key -> 'a t -> 'a t\n    val merge:\n          (key -> 'a option -> 'b option -> 'c option) -> 'a t -> 'b t -> 'c t\n    val union: (key -> 'a -> 'a -> 'a option) -> 'a t -> 'a t -> 'a t\n    val compare: ('a -> 'a -> int) -> 'a t -> 'a t -> int\n    val equal: ('a -> 'a -> bool) -> 'a t -> 'a t -> bool\n    val iter: (key -> 'a -> unit) -> 'a t -> unit\n    val fold: (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b\n    val for_all: (key -> 'a -> bool) -> 'a t -> bool\n    val exists: (key -> 'a -> bool) -> 'a t -> bool\n    val filter: (key -> 'a -> bool) -> 'a t -> 'a t\n    val filter_map: (key -> 'a -> 'b option) -> 'a t -> 'b t\n    val partition: (key -> 'a -> bool) -> 'a t -> 'a t * 'a t\n    val cardinal: 'a t -> int\n    val bindings: 'a t -> (key * 'a) list\n    val min_binding: 'a t -> (key * 'a)\n    val min_binding_opt: 'a t -> (key * 'a) option\n    val max_binding: 'a t -> (key * 'a)\n    val max_binding_opt: 'a t -> (key * 'a) option\n    val choose: 'a t -> (key * 'a)\n    val choose_opt: 'a t -> (key * 'a) option\n    val split: key -> 'a t -> 'a t * 'a option * 'a t\n    val find: key -> 'a t -> 'a\n    val find_opt: key -> 'a t -> 'a option\n    val find_first: (key -> bool) -> 'a t -> key * 'a\n    val find_first_opt: (key -> bool) -> 'a t -> (key * 'a) option\n    val find_last: (key -> bool) -> 'a t -> key * 'a\n    val find_last_opt: (key -> bool) -> 'a t -> (key * 'a) option\n    val map: ('a -> 'b) -> 'a t -> 'b t\n    val mapi: (key -> 'a -> 'b) -> 'a t -> 'b t\n    val to_seq : 'a t -> (key * 'a) Seq.t\n    val to_rev_seq : 'a t -> (key * 'a) Seq.t\n    val to_seq_from : key -> 'a t -> (key * 'a) Seq.t\n    val add_seq : (key * 'a) Seq.t -> 'a t -> 'a t\n    val of_seq : (key * 'a) Seq.t -> 'a t\n  end\n\nmodule Make(Ord: OrderedType) = struct\n\n    type key = Ord.t\n\n    type 'a t =\n        Empty\n      | Node of {l:'a t; v:key; d:'a; r:'a t; h:int}\n\n    let height = function\n        Empty -> 0\n      | Node {h} -> h\n\n    let create l x d r =\n      let hl = height l and hr = height r in\n      Node{l; v=x; d; r; h=(if hl >= hr then hl + 1 else hr + 1)}\n\n    let singleton x d = Node{l=Empty; v=x; d; r=Empty; h=1}\n\n    let bal l x d r =\n      let hl = match l with Empty -> 0 | Node {h} -> h in\n      let hr = match r with Empty -> 0 | Node {h} -> h in\n      if hl > hr + 2 then begin\n        match l with\n          Empty -> invalid_arg \"Map.bal\"\n        | Node{l=ll; v=lv; d=ld; r=lr} ->\n            if height ll >= height lr then\n              create ll lv ld (create lr x d r)\n            else begin\n              match lr with\n                Empty -> invalid_arg \"Map.bal\"\n              | Node{l=lrl; v=lrv; d=lrd; r=lrr}->\n                  create (create ll lv ld lrl) lrv lrd (create lrr x d r)\n            end\n      end else if hr > hl + 2 then begin\n        match r with\n          Empty -> invalid_arg \"Map.bal\"\n        | Node{l=rl; v=rv; d=rd; r=rr} ->\n            if height rr >= height rl then\n              create (create l x d rl) rv rd rr\n            else begin\n              match rl with\n                Empty -> invalid_arg \"Map.bal\"\n              | Node{l=rll; v=rlv; d=rld; r=rlr} ->\n                  create (create l x d rll) rlv rld (create rlr rv rd rr)\n            end\n      end else\n        Node{l; v=x; d; r; h=(if hl >= hr then hl + 1 else hr + 1)}\n\n    let empty = Empty\n\n    let is_empty = function Empty -> true | _ -> false\n\n    let rec add x data = function\n        Empty ->\n          Node{l=Empty; v=x; d=data; r=Empty; h=1}\n      | Node {l; v; d; r; h} as m ->\n          let c = Ord.compare x v in\n          if c = 0 then\n            if d == data then m else Node{l; v=x; d=data; r; h}\n          else if c < 0 then\n            let ll = add x data l in\n            if l == ll then m else bal ll v d r\n          else\n            let rr = add x data r in\n            if r == rr then m else bal l v d rr\n\n    let rec find x = function\n        Empty ->\n          raise Not_found\n      | Node {l; v; d; r} ->\n          let c = Ord.compare x v in\n          if c = 0 then d\n          else find x (if c < 0 then l else r)\n\n    let rec find_first_aux v0 d0 f = function\n        Empty ->\n          (v0, d0)\n      | Node {l; v; d; r} ->\n          if f v then\n            find_first_aux v d f l\n          else\n            find_first_aux v0 d0 f r\n\n    let rec find_first f = function\n        Empty ->\n          raise Not_found\n      | Node {l; v; d; r} ->\n          if f v then\n            find_first_aux v d f l\n          else\n            find_first f r\n\n    let rec find_first_opt_aux v0 d0 f = function\n        Empty ->\n          Some (v0, d0)\n      | Node {l; v; d; r} ->\n          if f v then\n            find_first_opt_aux v d f l\n          else\n            find_first_opt_aux v0 d0 f r\n\n    let rec find_first_opt f = function\n        Empty ->\n          None\n      | Node {l; v; d; r} ->\n          if f v then\n            find_first_opt_aux v d f l\n          else\n            find_first_opt f r\n\n    let rec find_last_aux v0 d0 f = function\n        Empty ->\n          (v0, d0)\n      | Node {l; v; d; r} ->\n          if f v then\n            find_last_aux v d f r\n          else\n            find_last_aux v0 d0 f l\n\n    let rec find_last f = function\n        Empty ->\n          raise Not_found\n      | Node {l; v; d; r} ->\n          if f v then\n            find_last_aux v d f r\n          else\n            find_last f l\n\n    let rec find_last_opt_aux v0 d0 f = function\n        Empty ->\n          Some (v0, d0)\n      | Node {l; v; d; r} ->\n          if f v then\n            find_last_opt_aux v d f r\n          else\n            find_last_opt_aux v0 d0 f l\n\n    let rec find_last_opt f = function\n        Empty ->\n          None\n      | Node {l; v; d; r} ->\n          if f v then\n            find_last_opt_aux v d f r\n          else\n            find_last_opt f l\n\n    let rec find_opt x = function\n        Empty ->\n          None\n      | Node {l; v; d; r} ->\n          let c = Ord.compare x v in\n          if c = 0 then Some d\n          else find_opt x (if c < 0 then l else r)\n\n    let rec mem x = function\n        Empty ->\n          false\n      | Node {l; v; r} ->\n          let c = Ord.compare x v in\n          c = 0 || mem x (if c < 0 then l else r)\n\n    let rec min_binding = function\n        Empty -> raise Not_found\n      | Node {l=Empty; v; d} -> (v, d)\n      | Node {l} -> min_binding l\n\n    let rec min_binding_opt = function\n        Empty -> None\n      | Node {l=Empty; v; d} -> Some (v, d)\n      | Node {l}-> min_binding_opt l\n\n    let rec max_binding = function\n        Empty -> raise Not_found\n      | Node {v; d; r=Empty} -> (v, d)\n      | Node {r} -> max_binding r\n\n    let rec max_binding_opt = function\n        Empty -> None\n      | Node {v; d; r=Empty} -> Some (v, d)\n      | Node {r} -> max_binding_opt r\n\n    let rec remove_min_binding = function\n        Empty -> invalid_arg \"Map.remove_min_elt\"\n      | Node {l=Empty; r} -> r\n      | Node {l; v; d; r} -> bal (remove_min_binding l) v d r\n\n    let merge t1 t2 =\n      match (t1, t2) with\n        (Empty, t) -> t\n      | (t, Empty) -> t\n      | (_, _) ->\n          let (x, d) = min_binding t2 in\n          bal t1 x d (remove_min_binding t2)\n\n    let rec remove x = function\n        Empty ->\n          Empty\n      | (Node {l; v; d; r} as m) ->\n          let c = Ord.compare x v in\n          if c = 0 then merge l r\n          else if c < 0 then\n            let ll = remove x l in if l == ll then m else bal ll v d r\n          else\n            let rr = remove x r in if r == rr then m else bal l v d rr\n\n    let rec update x f = function\n        Empty ->\n          begin match f None with\n          | None -> Empty\n          | Some data -> Node{l=Empty; v=x; d=data; r=Empty; h=1}\n          end\n      | Node {l; v; d; r; h} as m ->\n          let c = Ord.compare x v in\n          if c = 0 then begin\n            match f (Some d) with\n            | None -> merge l r\n            | Some data ->\n                if d == data then m else Node{l; v=x; d=data; r; h}\n          end else if c < 0 then\n            let ll = update x f l in\n            if l == ll then m else bal ll v d r\n          else\n            let rr = update x f r in\n            if r == rr then m else bal l v d rr\n\n    let rec iter f = function\n        Empty -> ()\n      | Node {l; v; d; r} ->\n          iter f l; f v d; iter f r\n\n    let rec map f = function\n        Empty ->\n          Empty\n      | Node {l; v; d; r; h} ->\n          let l' = map f l in\n          let d' = f d in\n          let r' = map f r in\n          Node{l=l'; v; d=d'; r=r'; h}\n\n    let rec mapi f = function\n        Empty ->\n          Empty\n      | Node {l; v; d; r; h} ->\n          let l' = mapi f l in\n          let d' = f v d in\n          let r' = mapi f r in\n          Node{l=l'; v; d=d'; r=r'; h}\n\n    let rec fold f m accu =\n      match m with\n        Empty -> accu\n      | Node {l; v; d; r} ->\n          fold f r (f v d (fold f l accu))\n\n    let rec for_all p = function\n        Empty -> true\n      | Node {l; v; d; r} -> p v d && for_all p l && for_all p r\n\n    let rec exists p = function\n        Empty -> false\n      | Node {l; v; d; r} -> p v d || exists p l || exists p r\n\n    (* Beware: those two functions assume that the added k is *strictly*\n       smaller (or bigger) than all the present keys in the tree; it\n       does not test for equality with the current min (or max) key.\n\n       Indeed, they are only used during the \"join\" operation which\n       respects this precondition.\n    *)\n\n    let rec add_min_binding k x = function\n      | Empty -> singleton k x\n      | Node {l; v; d; r} ->\n        bal (add_min_binding k x l) v d r\n\n    let rec add_max_binding k x = function\n      | Empty -> singleton k x\n      | Node {l; v; d; r} ->\n        bal l v d (add_max_binding k x r)\n\n    (* Same as create and bal, but no assumptions are made on the\n       relative heights of l and r. *)\n\n    let rec join l v d r =\n      match (l, r) with\n        (Empty, _) -> add_min_binding v d r\n      | (_, Empty) -> add_max_binding v d l\n      | (Node{l=ll; v=lv; d=ld; r=lr; h=lh},\n         Node{l=rl; v=rv; d=rd; r=rr; h=rh}) ->\n          if lh > rh + 2 then bal ll lv ld (join lr v d r) else\n          if rh > lh + 2 then bal (join l v d rl) rv rd rr else\n          create l v d r\n\n    (* Merge two trees l and r into one.\n       All elements of l must precede the elements of r.\n       No assumption on the heights of l and r. *)\n\n    let concat t1 t2 =\n      match (t1, t2) with\n        (Empty, t) -> t\n      | (t, Empty) -> t\n      | (_, _) ->\n          let (x, d) = min_binding t2 in\n          join t1 x d (remove_min_binding t2)\n\n    let concat_or_join t1 v d t2 =\n      match d with\n      | Some d -> join t1 v d t2\n      | None -> concat t1 t2\n\n    let rec split x = function\n        Empty ->\n          (Empty, None, Empty)\n      | Node {l; v; d; r} ->\n          let c = Ord.compare x v in\n          if c = 0 then (l, Some d, r)\n          else if c < 0 then\n            let (ll, pres, rl) = split x l in (ll, pres, join rl v d r)\n          else\n            let (lr, pres, rr) = split x r in (join l v d lr, pres, rr)\n\n    let rec merge f s1 s2 =\n      match (s1, s2) with\n        (Empty, Empty) -> Empty\n      | (Node {l=l1; v=v1; d=d1; r=r1; h=h1}, _) when h1 >= height s2 ->\n          let (l2, d2, r2) = split v1 s2 in\n          concat_or_join (merge f l1 l2) v1 (f v1 (Some d1) d2) (merge f r1 r2)\n      | (_, Node {l=l2; v=v2; d=d2; r=r2}) ->\n          let (l1, d1, r1) = split v2 s1 in\n          concat_or_join (merge f l1 l2) v2 (f v2 d1 (Some d2)) (merge f r1 r2)\n      | _ ->\n          assert false\n\n    let rec union f s1 s2 =\n      match (s1, s2) with\n      | (Empty, s) | (s, Empty) -> s\n      | (Node {l=l1; v=v1; d=d1; r=r1; h=h1},\n         Node {l=l2; v=v2; d=d2; r=r2; h=h2}) ->\n          if h1 >= h2 then\n            let (l2, d2, r2) = split v1 s2 in\n            let l = union f l1 l2 and r = union f r1 r2 in\n            match d2 with\n            | None -> join l v1 d1 r\n            | Some d2 -> concat_or_join l v1 (f v1 d1 d2) r\n          else\n            let (l1, d1, r1) = split v2 s1 in\n            let l = union f l1 l2 and r = union f r1 r2 in\n            match d1 with\n            | None -> join l v2 d2 r\n            | Some d1 -> concat_or_join l v2 (f v2 d1 d2) r\n\n    let rec filter p = function\n        Empty -> Empty\n      | Node {l; v; d; r} as m ->\n          (* call [p] in the expected left-to-right order *)\n          let l' = filter p l in\n          let pvd = p v d in\n          let r' = filter p r in\n          if pvd then if l==l' && r==r' then m else join l' v d r'\n          else concat l' r'\n\n    let rec filter_map f = function\n        Empty -> Empty\n      | Node {l; v; d; r} ->\n          (* call [f] in the expected left-to-right order *)\n          let l' = filter_map f l in\n          let fvd = f v d in\n          let r' = filter_map f r in\n          begin match fvd with\n            | Some d' -> join l' v d' r'\n            | None -> concat l' r'\n          end\n\n    let rec partition p = function\n        Empty -> (Empty, Empty)\n      | Node {l; v; d; r} ->\n          (* call [p] in the expected left-to-right order *)\n          let (lt, lf) = partition p l in\n          let pvd = p v d in\n          let (rt, rf) = partition p r in\n          if pvd\n          then (join lt v d rt, concat lf rf)\n          else (concat lt rt, join lf v d rf)\n\n    type 'a enumeration = End | More of key * 'a * 'a t * 'a enumeration\n\n    let rec cons_enum m e =\n      match m with\n        Empty -> e\n      | Node {l; v; d; r} -> cons_enum l (More(v, d, r, e))\n\n    let compare cmp m1 m2 =\n      let rec compare_aux e1 e2 =\n          match (e1, e2) with\n          (End, End) -> 0\n        | (End, _)  -> -1\n        | (_, End) -> 1\n        | (More(v1, d1, r1, e1), More(v2, d2, r2, e2)) ->\n            let c = Ord.compare v1 v2 in\n            if c <> 0 then c else\n            let c = cmp d1 d2 in\n            if c <> 0 then c else\n            compare_aux (cons_enum r1 e1) (cons_enum r2 e2)\n      in compare_aux (cons_enum m1 End) (cons_enum m2 End)\n\n    let equal cmp m1 m2 =\n      let rec equal_aux e1 e2 =\n          match (e1, e2) with\n          (End, End) -> true\n        | (End, _)  -> false\n        | (_, End) -> false\n        | (More(v1, d1, r1, e1), More(v2, d2, r2, e2)) ->\n            Ord.compare v1 v2 = 0 && cmp d1 d2 &&\n            equal_aux (cons_enum r1 e1) (cons_enum r2 e2)\n      in equal_aux (cons_enum m1 End) (cons_enum m2 End)\n\n    let rec cardinal = function\n        Empty -> 0\n      | Node {l; r} -> cardinal l + 1 + cardinal r\n\n    let rec bindings_aux accu = function\n        Empty -> accu\n      | Node {l; v; d; r} -> bindings_aux ((v, d) :: bindings_aux accu r) l\n\n    let bindings s =\n      bindings_aux [] s\n\n    let choose = min_binding\n\n    let choose_opt = min_binding_opt\n\n    let add_seq i m =\n      Seq.fold_left (fun m (k,v) -> add k v m) m i\n\n    let of_seq i = add_seq i empty\n\n    let rec seq_of_enum_ c () = match c with\n      | End -> Seq.Nil\n      | More (k,v,t,rest) -> Seq.Cons ((k,v), seq_of_enum_ (cons_enum t rest))\n\n    let to_seq m =\n      seq_of_enum_ (cons_enum m End)\n\n    let rec snoc_enum s e =\n      match s with\n        Empty -> e\n      | Node{l; v; d; r} -> snoc_enum r (More(v, d, l, e))\n\n    let rec rev_seq_of_enum_ c () = match c with\n      | End -> Seq.Nil\n      | More (k,v,t,rest) ->\n          Seq.Cons ((k,v), rev_seq_of_enum_ (snoc_enum t rest))\n\n    let to_rev_seq c =\n      rev_seq_of_enum_ (snoc_enum c End)\n\n    let to_seq_from low m =\n      let rec aux low m c = match m with\n        | Empty -> c\n        | Node {l; v; d; r; _} ->\n            begin match Ord.compare v low with\n              | 0 -> More (v, d, r, c)\n              | n when n<0 -> aux low r c\n              | _ -> aux low l (More (v, d, r, c))\n            end\n      in\n      seq_of_enum_ (aux low m End)\nend\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\ntype 'a t = { mutable c : 'a list; mutable len : int; }\n\nexception Empty\n\nlet create () = { c = []; len = 0; }\n\nlet clear s = s.c <- []; s.len <- 0\n\nlet copy s = { c = s.c; len = s.len; }\n\nlet push x s = s.c <- x :: s.c; s.len <- s.len + 1\n\nlet pop s =\n  match s.c with\n  | hd::tl -> s.c <- tl; s.len <- s.len - 1; hd\n  | []     -> raise Empty\n\nlet pop_opt s =\n  match s.c with\n  | hd::tl -> s.c <- tl; s.len <- s.len - 1; Some hd\n  | []     -> None\n\nlet top s =\n  match s.c with\n  | hd::_ -> hd\n  | []    -> raise Empty\n\nlet top_opt s =\n  match s.c with\n  | hd::_ -> Some hd\n  | []    -> None\n\nlet is_empty s = (s.c = [])\n\nlet length s = s.len\n\nlet iter f s = List.iter f s.c\n\nlet fold f acc s = List.fold_left f acc s.c\n\n(** {1 Iterators} *)\n\nlet to_seq s = List.to_seq s.c\n\nlet add_seq q i = Seq.iter (fun x -> push x q) i\n\nlet of_seq g =\n  let s = create() in\n  add_seq s g;\n  s\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*         Francois Pottier, projet Cristal, INRIA Rocquencourt           *)\n(*                  Jeremie Dimino, Jane Street Europe                    *)\n(*                                                                        *)\n(*   Copyright 2002 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\nexception Empty\n\ntype 'a cell =\n  | Nil\n  | Cons of { content: 'a; mutable next: 'a cell }\n\ntype 'a t = {\n  mutable length: int;\n  mutable first: 'a cell;\n  mutable last: 'a cell\n}\n\nlet create () = {\n  length = 0;\n  first = Nil;\n  last = Nil\n}\n\nlet clear q =\n  q.length <- 0;\n  q.first <- Nil;\n  q.last <- Nil\n\nlet add x q =\n  let cell = Cons {\n    content = x;\n    next = Nil\n  } in\n  match q.last with\n  | Nil ->\n    q.length <- 1;\n    q.first <- cell;\n    q.last <- cell\n  | Cons last ->\n    q.length <- q.length + 1;\n    last.next <- cell;\n    q.last <- cell\n\nlet push =\n  add\n\nlet peek q =\n  match q.first with\n  | Nil -> raise Empty\n  | Cons { content } -> content\n\nlet peek_opt q =\n  match q.first with\n  | Nil -> None\n  | Cons { content } -> Some content\n\nlet top =\n  peek\n\nlet take q =\n  match q.first with\n  | Nil -> raise Empty\n  | Cons { content; next = Nil } ->\n    clear q;\n    content\n  | Cons { content; next } ->\n    q.length <- q.length - 1;\n    q.first <- next;\n    content\n\nlet take_opt q =\n  match q.first with\n  | Nil -> None\n  | Cons { content; next = Nil } ->\n    clear q;\n    Some content\n  | Cons { content; next } ->\n    q.length <- q.length - 1;\n    q.first <- next;\n    Some content\n\nlet pop =\n  take\n\nlet copy =\n  let rec copy q_res prev cell =\n    match cell with\n    | Nil -> q_res.last <- prev; q_res\n    | Cons { content; next } ->\n      let res = Cons { content; next = Nil } in\n      begin match prev with\n      | Nil -> q_res.first <- res\n      | Cons p -> p.next <- res\n      end;\n      copy q_res res next\n  in\n  fun q -> copy { length = q.length; first = Nil; last = Nil } Nil q.first\n\nlet is_empty q =\n  q.length = 0\n\nlet length q =\n  q.length\n\nlet iter =\n  let rec iter f cell =\n    match cell with\n    | Nil -> ()\n    | Cons { content; next } ->\n      f content;\n      iter f next\n  in\n  fun f q -> iter f q.first\n\nlet fold =\n  let rec fold f accu cell =\n    match cell with\n    | Nil -> accu\n    | Cons { content; next } ->\n      let accu = f accu content in\n      fold f accu next\n  in\n  fun f accu q -> fold f accu q.first\n\nlet transfer q1 q2 =\n  if q1.length > 0 then\n    match q2.last with\n    | Nil ->\n      q2.length <- q1.length;\n      q2.first <- q1.first;\n      q2.last <- q1.last;\n      clear q1\n    | Cons last ->\n      q2.length <- q2.length + q1.length;\n      last.next <- q1.first;\n      q2.last <- q1.last;\n      clear q1\n\n(** {1 Iterators} *)\n\nlet to_seq q =\n  let rec aux c () = match c with\n    | Nil -> Seq.Nil\n    | Cons { content=x; next; } -> Seq.Cons (x, aux next)\n  in\n  aux q.first\n\nlet add_seq q i = Seq.iter (fun x -> push x q) i\n\nlet of_seq g =\n  let q = create() in\n  add_seq q g;\n  q\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Damien Doligez, projet Para, INRIA Rocquencourt            *)\n(*                                                                        *)\n(*   Copyright 1997 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Internals of forcing lazy values. *)\n\ntype 'a t = 'a lazy_t\n\nexception Undefined\n\nlet raise_undefined = Obj.repr (fun () -> raise Undefined)\n\nexternal make_forward : Obj.t -> Obj.t -> unit = \"caml_obj_make_forward\"\n\n(* Assume [blk] is a block with tag lazy *)\nlet force_lazy_block (blk : 'arg lazy_t) =\n  let closure = (Obj.obj (Obj.field (Obj.repr blk) 0) : unit -> 'arg) in\n  Obj.set_field (Obj.repr blk) 0 raise_undefined;\n  try\n    let result = closure () in\n    make_forward (Obj.repr blk) (Obj.repr result);\n    result\n  with e ->\n    Obj.set_field (Obj.repr blk) 0 (Obj.repr (fun () -> raise e));\n    raise e\n\n\n(* Assume [blk] is a block with tag lazy *)\nlet force_val_lazy_block (blk : 'arg lazy_t) =\n  let closure = (Obj.obj (Obj.field (Obj.repr blk) 0) : unit -> 'arg) in\n  Obj.set_field (Obj.repr blk) 0 raise_undefined;\n  let result = closure () in\n  make_forward (Obj.repr blk) (Obj.repr result);\n  result\n\n\n(* [force] is not used, since [Lazy.force] is declared as a primitive\n   whose code inlines the tag tests of its argument, except when afl\n   instrumentation is turned on. *)\n\nlet force (lzv : 'arg lazy_t) =\n  (* Using [Sys.opaque_identity] prevents two potential problems:\n     - If the value is known to have Forward_tag, then its tag could have\n       changed during GC, so that information must be forgotten (see GPR#713\n       and issue #7301)\n     - If the value is known to be immutable, then if the compiler\n       cannot prove that the last branch is not taken it will issue a\n       warning 59 (modification of an immutable value) *)\n  let lzv = Sys.opaque_identity lzv in\n  let x = Obj.repr lzv in\n  let t = Obj.tag x in\n  if t = Obj.forward_tag then (Obj.obj (Obj.field x 0) : 'arg) else\n  if t <> Obj.lazy_tag then (Obj.obj x : 'arg)\n  else force_lazy_block lzv\n\n\nlet force_val (lzv : 'arg lazy_t) =\n  let x = Obj.repr lzv in\n  let t = Obj.tag x in\n  if t = Obj.forward_tag then (Obj.obj (Obj.field x 0) : 'arg) else\n  if t <> Obj.lazy_tag then (Obj.obj x : 'arg)\n  else force_val_lazy_block lzv\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Damien Doligez, projet Para, INRIA Rocquencourt            *)\n(*                                                                        *)\n(*   Copyright 1997 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Module [Lazy]: deferred computations *)\n\n\n(*\n   WARNING: some purple magic is going on here.  Do not take this file\n   as an example of how to program in OCaml.\n*)\n\n\n(* We make use of two special tags provided by the runtime:\n   [lazy_tag] and [forward_tag].\n\n   A value of type ['a Lazy.t] can be one of three things:\n   1. A block of size 1 with tag [lazy_tag].  Its field is a closure of\n      type [unit -> 'a] that computes the value.\n   2. A block of size 1 with tag [forward_tag].  Its field is the value\n      of type ['a] that was computed.\n   3. Anything else except a float.  This has type ['a] and is the value\n      that was computed.\n   Exceptions are stored in format (1).\n   The GC will magically change things from (2) to (3) according to its\n   fancy.\n\n   If OCaml was configured with the -flat-float-array option (which is\n   currently the default), the following is also true:\n   We cannot use representation (3) for a [float Lazy.t] because\n   [caml_make_array] assumes that only a [float] value can have tag\n   [Double_tag].\n\n   We have to use the built-in type constructor [lazy_t] to\n   let the compiler implement the special typing and compilation\n   rules for the [lazy] keyword.\n*)\n\ntype 'a t = 'a CamlinternalLazy.t\n\nexception Undefined = CamlinternalLazy.Undefined\n\nexternal make_forward : 'a -> 'a lazy_t = \"caml_lazy_make_forward\"\n\nexternal force : 'a t -> 'a = \"%lazy_force\"\n\n\nlet force_val = CamlinternalLazy.force_val\n\nlet from_fun (f : unit -> 'arg) =\n  let x = Obj.new_block Obj.lazy_tag 1 in\n  Obj.set_field x 0 (Obj.repr f);\n  (Obj.obj x : 'arg t)\n\nlet from_val (v : 'arg) =\n  let t = Obj.tag (Obj.repr v) in\n  if t = Obj.forward_tag || t = Obj.lazy_tag || t = Obj.double_tag then begin\n    make_forward v\n  end else begin\n    (Obj.magic v : 'arg t)\n  end\n\n\nlet is_val (l : 'arg t) = Obj.tag (Obj.repr l) <> Obj.lazy_tag\n\nlet lazy_from_fun = from_fun\n\nlet lazy_from_val = from_val\n\nlet lazy_is_val = is_val\n\n\nlet map f x =\n  lazy (f (force x))\n\nlet map_val f x =\n  if is_val x\n  then lazy_from_val (f (force x))\n  else lazy (f (force x))\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*         Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt       *)\n(*                                                                        *)\n(*   Copyright 1997 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\ntype 'a t = 'a cell option\nand 'a cell = { mutable count : int; mutable data : 'a data }\nand 'a data =\n    Sempty\n  | Scons of 'a * 'a data\n  | Sapp of 'a data * 'a data\n  | Slazy of 'a data Lazy.t\n  | Sgen of 'a gen\n  | Sbuffio : buffio -> char data\nand 'a gen = { mutable curr : 'a option option; func : int -> 'a option }\nand buffio =\n  { ic : in_channel; buff : bytes; mutable len : int; mutable ind : int }\n\nexception Failure\nexception Error of string\n\nlet count = function\n  | None -> 0\n  | Some { count } -> count\nlet data = function\n  | None -> Sempty\n  | Some { data } -> data\n\nlet fill_buff b =\n  b.len <- input b.ic b.buff 0 (Bytes.length b.buff); b.ind <- 0\n\n\nlet rec get_data : type v. int -> v data -> v data = fun count d -> match d with\n (* Returns either Sempty or Scons(a, _) even when d is a generator\n    or a buffer. In those cases, the item a is seen as extracted from\n the generator/buffer.\n The count parameter is used for calling `Sgen-functions'.  *)\n   Sempty | Scons (_, _) -> d\n | Sapp (d1, d2) ->\n     begin match get_data count d1 with\n       Scons (a, d11) -> Scons (a, Sapp (d11, d2))\n     | Sempty -> get_data count d2\n     | _ -> assert false\n     end\n | Sgen {curr = Some None} -> Sempty\n | Sgen ({curr = Some(Some a)} as g) ->\n     g.curr <- None; Scons(a, d)\n | Sgen g ->\n     begin match g.func count with\n       None -> g.curr <- Some(None); Sempty\n     | Some a -> Scons(a, d)\n         (* Warning: anyone using g thinks that an item has been read *)\n     end\n | Sbuffio b ->\n     if b.ind >= b.len then fill_buff b;\n     if b.len == 0 then Sempty else\n       let r = Bytes.unsafe_get b.buff b.ind in\n       (* Warning: anyone using g thinks that an item has been read *)\n       b.ind <- succ b.ind; Scons(r, d)\n | Slazy f -> get_data count (Lazy.force f)\n\n\nlet rec peek_data : type v. v cell -> v option = fun s ->\n (* consult the first item of s *)\n match s.data with\n   Sempty -> None\n | Scons (a, _) -> Some a\n | Sapp (_, _) ->\n     begin match get_data s.count s.data with\n       Scons(a, _) as d -> s.data <- d; Some a\n     | Sempty -> None\n     | _ -> assert false\n     end\n | Slazy f -> s.data <- (Lazy.force f); peek_data s\n | Sgen {curr = Some a} -> a\n | Sgen g -> let x = g.func s.count in g.curr <- Some x; x\n | Sbuffio b ->\n     if b.ind >= b.len then fill_buff b;\n     if b.len == 0 then begin s.data <- Sempty; None end\n     else Some (Bytes.unsafe_get b.buff b.ind)\n\n\nlet peek = function\n  | None -> None\n  | Some s -> peek_data s\n\n\nlet rec junk_data : type v. v cell -> unit = fun s ->\n  match s.data with\n    Scons (_, d) -> s.count <- (succ s.count); s.data <- d\n  | Sgen ({curr = Some _} as g) -> s.count <- (succ s.count); g.curr <- None\n  | Sbuffio b ->\n      if b.ind >= b.len then fill_buff b;\n      if b.len == 0 then s.data <- Sempty\n      else (s.count <- (succ s.count); b.ind <- succ b.ind)\n  | _ ->\n      match peek_data s with\n        None -> ()\n      | Some _ -> junk_data s\n\n\nlet junk = function\n  | None -> ()\n  | Some data -> junk_data data\n\nlet rec nget_data n s =\n  if n <= 0 then [], s.data, 0\n  else\n    match peek_data s with\n      Some a ->\n        junk_data s;\n        let (al, d, k) = nget_data (pred n) s in a :: al, Scons (a, d), succ k\n    | None -> [], s.data, 0\n\n\nlet npeek_data n s =\n  let (al, d, len) = nget_data n s in\n  s.count <- (s.count - len);\n  s.data <- d;\n  al\n\n\nlet npeek n = function\n  | None -> []\n  | Some d -> npeek_data n d\n\nlet next s =\n  match peek s with\n    Some a -> junk s; a\n  | None -> raise Failure\n\n\nlet empty s =\n  match peek s with\n    Some _ -> raise Failure\n  | None -> ()\n\n\nlet iter f strm =\n  let rec do_rec () =\n    match peek strm with\n      Some a -> junk strm; ignore(f a); do_rec ()\n    | None -> ()\n  in\n  do_rec ()\n\n\n(* Stream building functions *)\n\nlet from f = Some {count = 0; data = Sgen {curr = None; func = f}}\n\nlet of_list l =\n  Some {count = 0; data = List.fold_right (fun x l -> Scons (x, l)) l Sempty}\n\n\nlet of_string s =\n  let count = ref 0 in\n  from (fun _ ->\n    (* We cannot use the index passed by the [from] function directly\n       because it returns the current stream count, with absolutely no\n       guarantee that it will start from 0. For example, in the case\n       of [Stream.icons 'c' (Stream.from_string \"ab\")], the first\n       access to the string will be made with count [1] already.\n    *)\n    let c = !count in\n    if c < String.length s\n    then (incr count; Some s.[c])\n    else None)\n\n\nlet of_bytes s =\n  let count = ref 0 in\n  from (fun _ ->\n    let c = !count in\n    if c < Bytes.length s\n    then (incr count; Some (Bytes.get s c))\n    else None)\n\n\nlet of_channel ic =\n  Some {count = 0;\n        data = Sbuffio {ic = ic; buff = Bytes.create 4096; len = 0; ind = 0}}\n\n\n(* Stream expressions builders *)\n\nlet iapp i s = Some {count = 0; data = Sapp (data i, data s)}\nlet icons i s = Some {count = 0; data = Scons (i, data s)}\nlet ising i = Some {count = 0; data = Scons (i, Sempty)}\n\nlet lapp f s =\n  Some {count = 0; data = Slazy (lazy(Sapp (data (f ()), data s)))}\n\nlet lcons f s = Some {count = 0; data = Slazy (lazy(Scons (f (), data s)))}\nlet lsing f = Some {count = 0; data = Slazy (lazy(Scons (f (), Sempty)))}\n\nlet sempty = None\nlet slazy f = Some {count = 0; data = Slazy (lazy(data (f ())))}\n\n(* For debugging use *)\n\nlet rec dump : type v. (v -> unit) -> v t -> unit = fun f s ->\n  print_string \"{count = \";\n  print_int (count s);\n  print_string \"; data = \";\n  dump_data f (data s);\n  print_string \"}\";\n  print_newline ()\nand dump_data : type v. (v -> unit) -> v data -> unit = fun f ->\n  function\n    Sempty -> print_string \"Sempty\"\n  | Scons (a, d) ->\n      print_string \"Scons (\";\n      f a;\n      print_string \", \";\n      dump_data f d;\n      print_string \")\"\n  | Sapp (d1, d2) ->\n      print_string \"Sapp (\";\n      dump_data f d1;\n      print_string \", \";\n      dump_data f d2;\n      print_string \")\"\n  | Slazy _ -> print_string \"Slazy\"\n  | Sgen _ -> print_string \"Sgen\"\n  | Sbuffio _ -> print_string \"Sbuffio\"\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*    Pierre Weis and Xavier Leroy, projet Cristal, INRIA Rocquencourt    *)\n(*                                                                        *)\n(*   Copyright 1999 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Extensible buffers *)\n\ntype t =\n {mutable buffer : bytes;\n  mutable position : int;\n  mutable length : int;\n  initial_buffer : bytes}\n(* Invariants: all parts of the code preserve the invariants that:\n   - [0 <= b.position <= b.length]\n   - [b.length = Bytes.length b.buffer]\n\n   Note in particular that [b.position = b.length] is legal,\n   it means that the buffer is full and will have to be extended\n   before any further addition. *)\n\nlet create n =\n let n = if n < 1 then 1 else n in\n let n = if n > Sys.max_string_length then Sys.max_string_length else n in\n let s = Bytes.create n in\n {buffer = s; position = 0; length = n; initial_buffer = s}\n\nlet contents b = Bytes.sub_string b.buffer 0 b.position\nlet to_bytes b = Bytes.sub b.buffer 0 b.position\n\nlet sub b ofs len =\n  if ofs < 0 || len < 0 || ofs > b.position - len\n  then invalid_arg \"Buffer.sub\"\n  else Bytes.sub_string b.buffer ofs len\n\n\nlet blit src srcoff dst dstoff len =\n  if len < 0 || srcoff < 0 || srcoff > src.position - len\n             || dstoff < 0 || dstoff > (Bytes.length dst) - len\n  then invalid_arg \"Buffer.blit\"\n  else\n    Bytes.unsafe_blit src.buffer srcoff dst dstoff len\n\n\nlet nth b ofs =\n  if ofs < 0 || ofs >= b.position then\n   invalid_arg \"Buffer.nth\"\n  else Bytes.unsafe_get b.buffer ofs\n\n\nlet length b = b.position\n\nlet clear b = b.position <- 0\n\nlet reset b =\n  b.position <- 0;\n  b.buffer <- b.initial_buffer;\n  b.length <- Bytes.length b.buffer\n\n(* [resize b more] ensures that [b.position + more <= b.length] holds\n   by dynamically extending [b.buffer] if necessary -- and thus\n   increasing [b.length].\n\n   In particular, after [resize b more] is called, a direct access of\n   size [more] at [b.position] will always be in-bounds, so that\n   (unsafe_{get,set}) may be used for performance.\n*)\nlet resize b more =\n  let old_pos = b.position in\n  let old_len = b.length in\n  let new_len = ref old_len in\n  while old_pos + more > !new_len do new_len := 2 * !new_len done;\n  if !new_len > Sys.max_string_length then begin\n    if old_pos + more <= Sys.max_string_length\n    then new_len := Sys.max_string_length\n    else failwith \"Buffer.add: cannot grow buffer\"\n  end;\n  let new_buffer = Bytes.create !new_len in\n  (* PR#6148: let's keep using [blit] rather than [unsafe_blit] in\n     this tricky function that is slow anyway. *)\n  Bytes.blit b.buffer 0 new_buffer 0 b.position;\n  b.buffer <- new_buffer;\n  b.length <- !new_len;\n  assert (b.position + more <= b.length);\n  assert (old_pos + more <= b.length);\n  ()\n  (* Note: there are various situations (preemptive threads, signals and\n     gc finalizers) where OCaml code may be run asynchronously; in\n     particular, there may be a race with another user of [b], changing\n     its mutable fields in the middle of the [resize] call. The Buffer\n     module does not provide any correctness guarantee if that happens,\n     but we must still ensure that the datastructure invariants hold for\n     memory-safety -- as we plan to use [unsafe_{get,set}].\n\n     There are two potential allocation points in this function,\n     [ref] and [Bytes.create], but all reads and writes to the fields\n     of [b] happen before both of them or after both of them.\n\n     We therefore assume that [b.position] may change at these allocations,\n     and check that the [b.position + more <= b.length] postcondition\n     holds for both values of [b.position], before or after the function\n     is called. More precisely, the following invariants must hold if the\n     function returns correctly, in addition to the usual buffer invariants:\n     - [old(b.position) + more <= new(b.length)]\n     - [new(b.position) + more <= new(b.length)]\n     - [old(b.length) <= new(b.length)]\n\n     Note: [b.position + more <= old(b.length)] does *not*\n     hold in general, as it is precisely the case where you need\n     to call [resize] to increase [b.length].\n\n     Note: [assert] above does not mean that we know the conditions\n     always hold, but that the function may return correctly\n     only if they hold.\n\n     Note: the other functions in this module does not need\n     to be checked with this level of scrutiny, given that they\n     read/write the buffer immediately after checking that\n     [b.position + more <= b.length] hold or calling [resize].\n  *)\n\nlet add_char b c =\n  let pos = b.position in\n  if pos >= b.length then resize b 1;\n  Bytes.unsafe_set b.buffer pos c;\n  b.position <- pos + 1\n\n let add_utf_8_uchar b u = match Uchar.to_int u with\n | u when u < 0 -> assert false\n | u when u <= 0x007F ->\n     add_char b (Char.unsafe_chr u)\n | u when u <= 0x07FF ->\n     let pos = b.position in\n     if pos + 2 > b.length then resize b 2;\n     Bytes.unsafe_set b.buffer (pos    )\n       (Char.unsafe_chr (0xC0 lor (u lsr 6)));\n     Bytes.unsafe_set b.buffer (pos + 1)\n       (Char.unsafe_chr (0x80 lor (u land 0x3F)));\n     b.position <- pos + 2\n | u when u <= 0xFFFF ->\n     let pos = b.position in\n     if pos + 3 > b.length then resize b 3;\n     Bytes.unsafe_set b.buffer (pos    )\n       (Char.unsafe_chr (0xE0 lor (u lsr 12)));\n     Bytes.unsafe_set b.buffer (pos + 1)\n       (Char.unsafe_chr (0x80 lor ((u lsr 6) land 0x3F)));\n     Bytes.unsafe_set b.buffer (pos + 2)\n       (Char.unsafe_chr (0x80 lor (u land 0x3F)));\n     b.position <- pos + 3\n | u when u <= 0x10FFFF ->\n     let pos = b.position in\n     if pos + 4 > b.length then resize b 4;\n     Bytes.unsafe_set b.buffer (pos    )\n       (Char.unsafe_chr (0xF0 lor (u lsr 18)));\n     Bytes.unsafe_set b.buffer (pos + 1)\n       (Char.unsafe_chr (0x80 lor ((u lsr 12) land 0x3F)));\n     Bytes.unsafe_set b.buffer (pos + 2)\n       (Char.unsafe_chr (0x80 lor ((u lsr 6) land 0x3F)));\n     Bytes.unsafe_set b.buffer (pos + 3)\n       (Char.unsafe_chr (0x80 lor (u land 0x3F)));\n     b.position <- pos + 4\n | _ -> assert false\n\n let add_utf_16be_uchar b u = match Uchar.to_int u with\n | u when u < 0 -> assert false\n | u when u <= 0xFFFF ->\n     let pos = b.position in\n     if pos + 2 > b.length then resize b 2;\n     Bytes.unsafe_set b.buffer (pos    ) (Char.unsafe_chr (u lsr 8));\n     Bytes.unsafe_set b.buffer (pos + 1) (Char.unsafe_chr (u land 0xFF));\n     b.position <- pos + 2\n | u when u <= 0x10FFFF ->\n     let u' = u - 0x10000 in\n     let hi = 0xD800 lor (u' lsr 10) in\n     let lo = 0xDC00 lor (u' land 0x3FF) in\n     let pos = b.position in\n     if pos + 4 > b.length then resize b 4;\n     Bytes.unsafe_set b.buffer (pos    ) (Char.unsafe_chr (hi lsr 8));\n     Bytes.unsafe_set b.buffer (pos + 1) (Char.unsafe_chr (hi land 0xFF));\n     Bytes.unsafe_set b.buffer (pos + 2) (Char.unsafe_chr (lo lsr 8));\n     Bytes.unsafe_set b.buffer (pos + 3) (Char.unsafe_chr (lo land 0xFF));\n     b.position <- pos + 4\n | _ -> assert false\n\n let add_utf_16le_uchar b u = match Uchar.to_int u with\n | u when u < 0 -> assert false\n | u when u <= 0xFFFF ->\n     let pos = b.position in\n     if pos + 2 > b.length then resize b 2;\n     Bytes.unsafe_set b.buffer (pos    ) (Char.unsafe_chr (u land 0xFF));\n     Bytes.unsafe_set b.buffer (pos + 1) (Char.unsafe_chr (u lsr 8));\n     b.position <- pos + 2\n | u when u <= 0x10FFFF ->\n     let u' = u - 0x10000 in\n     let hi = 0xD800 lor (u' lsr 10) in\n     let lo = 0xDC00 lor (u' land 0x3FF) in\n     let pos = b.position in\n     if pos + 4 > b.length then resize b 4;\n     Bytes.unsafe_set b.buffer (pos    ) (Char.unsafe_chr (hi land 0xFF));\n     Bytes.unsafe_set b.buffer (pos + 1) (Char.unsafe_chr (hi lsr 8));\n     Bytes.unsafe_set b.buffer (pos + 2) (Char.unsafe_chr (lo land 0xFF));\n     Bytes.unsafe_set b.buffer (pos + 3) (Char.unsafe_chr (lo lsr 8));\n     b.position <- pos + 4\n | _ -> assert false\n\nlet add_substring b s offset len =\n  if offset < 0 || len < 0 || offset > String.length s - len\n  then invalid_arg \"Buffer.add_substring/add_subbytes\";\n  let new_position = b.position + len in\n  if new_position > b.length then resize b len;\n  Bytes.unsafe_blit_string s offset b.buffer b.position len;\n  b.position <- new_position\n\nlet add_subbytes b s offset len =\n  add_substring b (Bytes.unsafe_to_string s) offset len\n\nlet add_string b s =\n  let len = String.length s in\n  let new_position = b.position + len in\n  if new_position > b.length then resize b len;\n  Bytes.unsafe_blit_string s 0 b.buffer b.position len;\n  b.position <- new_position\n\nlet add_bytes b s = add_string b (Bytes.unsafe_to_string s)\n\nlet add_buffer b bs =\n  add_subbytes b bs.buffer 0 bs.position\n\n(* this (private) function could move into the standard library *)\nlet really_input_up_to ic buf ofs len =\n  let rec loop ic buf ~already_read ~ofs ~to_read =\n    if to_read = 0 then already_read\n    else begin\n      let r = input ic buf ofs to_read in\n      if r = 0 then already_read\n      else begin\n        let already_read = already_read + r in\n        let ofs = ofs + r in\n        let to_read = to_read - r in\n        loop ic buf ~already_read ~ofs ~to_read\n      end\n    end\n  in loop ic buf ~already_read:0 ~ofs ~to_read:len\n\n\nlet unsafe_add_channel_up_to b ic len =\n  if b.position + len > b.length then resize b len;\n  let n = really_input_up_to ic b.buffer b.position len in\n  (* The assertion below may fail in weird scenario where\n     threaded/finalizer code, run asynchronously during the\n     [really_input_up_to] call, races on the buffer; we don't ensure\n     correctness in this case, but need to preserve the invariants for\n     memory-safety (see discussion of [resize]). *)\n  assert (b.position + n <= b.length);\n  b.position <- b.position + n;\n  n\n\nlet add_channel b ic len =\n  if len < 0 || len > Sys.max_string_length then   (* PR#5004 *)\n    invalid_arg \"Buffer.add_channel\";\n  let n = unsafe_add_channel_up_to b ic len in\n  (* It is intentional that a consumer catching End_of_file\n     will see the data written (see #6719, #7136). *)\n  if n < len then raise End_of_file;\n  ()\n\nlet output_buffer oc b =\n  output oc b.buffer 0 b.position\n\nlet closing = function\n  | '(' -> ')'\n  | '{' -> '}'\n  | _ -> assert false\n\n(* opening and closing: open and close characters, typically ( and )\n   k: balance of opening and closing chars\n   s: the string where we are searching\n   start: the index where we start the search. *)\nlet advance_to_closing opening closing k s start =\n  let rec advance k i lim =\n    if i >= lim then raise Not_found else\n    if s.[i] = opening then advance (k + 1) (i + 1) lim else\n    if s.[i] = closing then\n      if k = 0 then i else advance (k - 1) (i + 1) lim\n    else advance k (i + 1) lim in\n  advance k start (String.length s)\n\nlet advance_to_non_alpha s start =\n  let rec advance i lim =\n    if i >= lim then lim else\n    match s.[i] with\n    | 'a' .. 'z' | 'A' .. 'Z' | '0' .. '9' | '_' -> advance (i + 1) lim\n    | _ -> i in\n  advance start (String.length s)\n\n(* We are just at the beginning of an ident in s, starting at start. *)\nlet find_ident s start lim =\n  if start >= lim then raise Not_found else\n  match s.[start] with\n  (* Parenthesized ident ? *)\n  | '(' | '{' as c ->\n     let new_start = start + 1 in\n     let stop = advance_to_closing c (closing c) 0 s new_start in\n     String.sub s new_start (stop - start - 1), stop + 1\n  (* Regular ident *)\n  | _ ->\n     let stop = advance_to_non_alpha s (start + 1) in\n     String.sub s start (stop - start), stop\n\n(* Substitute $ident, $(ident), or ${ident} in s,\n    according to the function mapping f. *)\nlet add_substitute b f s =\n  let lim = String.length s in\n  let rec subst previous i =\n    if i < lim then begin\n      match s.[i] with\n      | '$' as current when previous = '\\\\' ->\n         add_char b current;\n         subst ' ' (i + 1)\n      | '$' ->\n         let j = i + 1 in\n         let ident, next_i = find_ident s j lim in\n         add_string b (f ident);\n         subst ' ' next_i\n      | current when previous == '\\\\' ->\n         add_char b '\\\\';\n         add_char b current;\n         subst ' ' (i + 1)\n      | '\\\\' as current ->\n         subst current (i + 1)\n      | current ->\n         add_char b current;\n         subst current (i + 1)\n    end else\n    if previous = '\\\\' then add_char b previous in\n  subst ' ' 0\n\nlet truncate b len =\n    if len < 0 || len > length b then\n      invalid_arg \"Buffer.truncate\"\n    else\n      b.position <- len\n\n(** {1 Iterators} *)\n\nlet to_seq b =\n  let rec aux i () =\n    (* Note that b.position is not a constant and cannot be lifted out of aux *)\n    if i >= b.position then Seq.Nil\n    else\n      let x = Bytes.unsafe_get b.buffer i in\n      Seq.Cons (x, aux (i+1))\n  in\n  aux 0\n\nlet to_seqi b =\n  let rec aux i () =\n    (* Note that b.position is not a constant and cannot be lifted out of aux *)\n    if i >= b.position then Seq.Nil\n    else\n      let x = Bytes.unsafe_get b.buffer i in\n      Seq.Cons ((i,x), aux (i+1))\n  in\n  aux 0\n\nlet add_seq b seq = Seq.iter (add_char b) seq\n\nlet of_seq i =\n  let b = create 32 in\n  add_seq b i;\n  b\n\n(** {6 Binary encoding of integers} *)\n\nexternal unsafe_set_int8 : bytes -> int -> int -> unit = \"%bytes_unsafe_set\"\nexternal unsafe_set_int16 : bytes -> int -> int -> unit = \"%caml_bytes_set16u\"\nexternal unsafe_set_int32 : bytes -> int -> int32 -> unit = \"%caml_bytes_set32u\"\nexternal unsafe_set_int64 : bytes -> int -> int64 -> unit = \"%caml_bytes_set64u\"\nexternal swap16 : int -> int = \"%bswap16\"\nexternal swap32 : int32 -> int32 = \"%bswap_int32\"\nexternal swap64 : int64 -> int64 = \"%bswap_int64\"\n\n\nlet add_int8 b x =\n  let new_position = b.position + 1 in\n  if new_position > b.length then resize b 1;\n  unsafe_set_int8 b.buffer b.position x;\n  b.position <- new_position\n\nlet add_int16_ne b x =\n  let new_position = b.position + 2 in\n  if new_position > b.length then resize b 2;\n  unsafe_set_int16 b.buffer b.position x;\n  b.position <- new_position\n\nlet add_int32_ne b x =\n  let new_position = b.position + 4 in\n  if new_position > b.length then resize b 4;\n  unsafe_set_int32 b.buffer b.position x;\n  b.position <- new_position\n\nlet add_int64_ne b x =\n  let new_position = b.position + 8 in\n  if new_position > b.length then resize b 8;\n  unsafe_set_int64 b.buffer b.position x;\n  b.position <- new_position\n\nlet add_int16_le b x =\n  add_int16_ne b (if Sys.big_endian then swap16 x else x)\n\nlet add_int16_be b x =\n  add_int16_ne b (if Sys.big_endian then x else swap16 x)\n\nlet add_int32_le b x =\n  add_int32_ne b (if Sys.big_endian then swap32 x else x)\n\nlet add_int32_be b x =\n  add_int32_ne b (if Sys.big_endian then x else swap32 x)\n\nlet add_int64_le b x =\n  add_int64_ne b (if Sys.big_endian then swap64 x else x)\n\nlet add_int64_be b x =\n  add_int64_ne b (if Sys.big_endian then x else swap64 x)\n\nlet add_uint8 = add_int8\nlet add_uint16_ne = add_int16_ne\nlet add_uint16_le = add_int16_le\nlet add_uint16_be = add_int16_be\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*                          Benoit Vaugon, ENSTA                          *)\n(*                                                                        *)\n(*   Copyright 2014 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\nopen CamlinternalFormatBasics\n\n(******************************************************************************)\n           (* Tools to manipulate scanning set of chars (see %[...]) *)\n\ntype mutable_char_set = bytes\n\n(* Create a fresh, empty, mutable char set. *)\nlet create_char_set () = Bytes.make 32 '\\000'\n\n(* Add a char in a mutable char set. *)\nlet add_in_char_set char_set c =\n  let ind = int_of_char c in\n  let str_ind = ind lsr 3 and mask = 1 lsl (ind land 0b111) in\n  Bytes.set char_set str_ind\n    (char_of_int (int_of_char (Bytes.get char_set str_ind) lor mask))\n\nlet freeze_char_set char_set =\n  Bytes.to_string char_set\n\n(* Compute the complement of a char set. *)\nlet rev_char_set char_set =\n  let char_set' = create_char_set () in\n  for i = 0 to 31 do\n    Bytes.set char_set' i\n      (char_of_int (int_of_char (String.get char_set i) lxor 0xFF));\n  done;\n  Bytes.unsafe_to_string char_set'\n\n(* Return true if a `c' is in `char_set'. *)\nlet is_in_char_set char_set c =\n  let ind = int_of_char c in\n  let str_ind = ind lsr 3 and mask = 1 lsl (ind land 0b111) in\n  (int_of_char (String.get char_set str_ind) land mask) <> 0\n\n\n(******************************************************************************)\n                         (* Ignored param conversion *)\n\n(* GADT used to abstract an existential type parameter. *)\n(* See param_format_of_ignored_format. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) param_format_ebb = Param_format_EBB :\n    ('x -> 'a, 'b, 'c, 'd, 'e, 'f) fmt ->\n    ('a, 'b, 'c, 'd, 'e, 'f) param_format_ebb\n\n(* Compute a padding associated to a pad_option (see \"%_42d\"). *)\nlet pad_of_pad_opt pad_opt = match pad_opt with\n  | None -> No_padding\n  | Some width -> Lit_padding (Right, width)\n\n(* Compute a precision associated to a prec_option (see \"%_.42f\"). *)\nlet prec_of_prec_opt prec_opt = match prec_opt with\n  | None -> No_precision\n  | Some ndec -> Lit_precision ndec\n\n(* Turn an ignored param into its equivalent not-ignored format node. *)\n(* Used for format pretty-printing and Scanf. *)\nlet param_format_of_ignored_format : type a b c d e f x y .\n    (a, b, c, d, y, x) ignored -> (x, b, c, y, e, f) fmt ->\n      (a, b, c, d, e, f) param_format_ebb =\nfun ign fmt -> match ign with\n  | Ignored_char ->\n    Param_format_EBB (Char fmt)\n  | Ignored_caml_char ->\n    Param_format_EBB (Caml_char fmt)\n  | Ignored_string pad_opt ->\n    Param_format_EBB (String (pad_of_pad_opt pad_opt, fmt))\n  | Ignored_caml_string pad_opt ->\n    Param_format_EBB (Caml_string (pad_of_pad_opt pad_opt, fmt))\n  | Ignored_int (iconv, pad_opt) ->\n    Param_format_EBB (Int (iconv, pad_of_pad_opt pad_opt, No_precision, fmt))\n  | Ignored_int32 (iconv, pad_opt) ->\n    Param_format_EBB\n      (Int32 (iconv, pad_of_pad_opt pad_opt, No_precision, fmt))\n  | Ignored_nativeint (iconv, pad_opt) ->\n    Param_format_EBB\n      (Nativeint (iconv, pad_of_pad_opt pad_opt, No_precision, fmt))\n  | Ignored_int64 (iconv, pad_opt) ->\n    Param_format_EBB\n      (Int64 (iconv, pad_of_pad_opt pad_opt, No_precision, fmt))\n  | Ignored_float (pad_opt, prec_opt) ->\n    Param_format_EBB\n      (Float ((Float_flag_, Float_f),\n              pad_of_pad_opt pad_opt, prec_of_prec_opt prec_opt, fmt))\n  | Ignored_bool pad_opt ->\n    Param_format_EBB (Bool (pad_of_pad_opt pad_opt, fmt))\n  | Ignored_format_arg (pad_opt, fmtty) ->\n    Param_format_EBB (Format_arg (pad_opt, fmtty, fmt))\n  | Ignored_format_subst (pad_opt, fmtty) ->\n    Param_format_EBB\n      (Format_subst (pad_opt, fmtty, fmt))\n  | Ignored_reader ->\n    Param_format_EBB (Reader fmt)\n  | Ignored_scan_char_set (width_opt, char_set) ->\n    Param_format_EBB (Scan_char_set (width_opt, char_set, fmt))\n  | Ignored_scan_get_counter counter ->\n    Param_format_EBB (Scan_get_counter (counter, fmt))\n  | Ignored_scan_next_char ->\n    Param_format_EBB (Scan_next_char fmt)\n\n\n(******************************************************************************)\n                                 (* Types *)\n\ntype ('b, 'c) acc_formatting_gen =\n  | Acc_open_tag of ('b, 'c) acc\n  | Acc_open_box of ('b, 'c) acc\n\n(* Reversed list of printing atoms. *)\n(* Used to accumulate printf arguments. *)\nand ('b, 'c) acc =\n  | Acc_formatting_lit of ('b, 'c) acc * formatting_lit\n      (* Special fmtting (box) *)\n  | Acc_formatting_gen of ('b, 'c) acc * ('b, 'c) acc_formatting_gen\n      (* Special fmtting (box) *)\n  | Acc_string_literal of ('b, 'c) acc * string     (* Literal string *)\n  | Acc_char_literal   of ('b, 'c) acc * char       (* Literal char *)\n  | Acc_data_string    of ('b, 'c) acc * string     (* Generated string *)\n  | Acc_data_char      of ('b, 'c) acc * char       (* Generated char *)\n  | Acc_delay          of ('b, 'c) acc * ('b -> 'c)\n                                                (* Delayed printing (%a, %t) *)\n  | Acc_flush          of ('b, 'c) acc              (* Flush *)\n  | Acc_invalid_arg    of ('b, 'c) acc * string\n      (* Raise Invalid_argument msg *)\n  | End_of_acc\n\n(* List of heterogeneous values. *)\n(* Used to accumulate scanf callback arguments. *)\ntype ('a, 'b) heter_list =\n  | Cons : 'c * ('a, 'b) heter_list -> ('c -> 'a, 'b) heter_list\n  | Nil : ('b, 'b) heter_list\n\n(* Existential Black Boxes. *)\n(* Used to abstract some existential type parameters. *)\n\n(* GADT type associating a padding and an fmtty. *)\n(* See the type_padding function. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) padding_fmtty_ebb = Padding_fmtty_EBB :\n     ('x, 'y) padding * ('y, 'b, 'c, 'd, 'e, 'f) fmtty ->\n     ('x, 'b, 'c, 'd, 'e, 'f) padding_fmtty_ebb\n\n(* GADT type associating a padding, a precision and an fmtty. *)\n(* See the type_padprec function. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) padprec_fmtty_ebb = Padprec_fmtty_EBB :\n     ('x, 'y) padding * ('y, 'z) precision * ('z, 'b, 'c, 'd, 'e, 'f) fmtty ->\n     ('x, 'b, 'c, 'd, 'e, 'f) padprec_fmtty_ebb\n\n(* GADT type associating a padding and an fmt. *)\n(* See make_padding_fmt_ebb and parse_format functions. *)\ntype ('a, 'b, 'c, 'e, 'f) padding_fmt_ebb = Padding_fmt_EBB :\n     (_, 'x -> 'a) padding *\n     ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n     ('x, 'b, 'c, 'e, 'f) padding_fmt_ebb\n\n(* GADT type associating a precision and an fmt. *)\n(* See make_precision_fmt_ebb and parse_format functions. *)\ntype ('a, 'b, 'c, 'e, 'f) precision_fmt_ebb = Precision_fmt_EBB :\n     (_, 'x -> 'a) precision *\n     ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n     ('x, 'b, 'c, 'e, 'f) precision_fmt_ebb\n\n(* GADT type associating a padding, a precision and an fmt. *)\n(* See make_padprec_fmt_ebb and parse_format functions. *)\ntype ('p, 'b, 'c, 'e, 'f) padprec_fmt_ebb = Padprec_fmt_EBB :\n     ('x, 'y) padding * ('y, 'p -> 'a) precision *\n     ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n     ('p, 'b, 'c, 'e, 'f) padprec_fmt_ebb\n\n(* Abstract the 'a and 'd parameters of an fmt. *)\n(* Output type of the format parsing function. *)\ntype ('b, 'c, 'e, 'f) fmt_ebb = Fmt_EBB :\n     ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n     ('b, 'c, 'e, 'f) fmt_ebb\n\n(* GADT type associating an fmtty and an fmt. *)\n(* See the type_format_gen function. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) fmt_fmtty_ebb = Fmt_fmtty_EBB :\n     ('a, 'b, 'c, 'd, 'y, 'x) fmt *\n     ('x, 'b, 'c, 'y, 'e, 'f) fmtty ->\n     ('a, 'b, 'c, 'd, 'e, 'f) fmt_fmtty_ebb\n\n(* GADT type associating an fmtty and an fmt. *)\n(* See the type_ignored_format_substitution function. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) fmtty_fmt_ebb = Fmtty_fmt_EBB :\n     ('a, 'b, 'c, 'd, 'y, 'x) fmtty *\n     ('x, 'b, 'c, 'y, 'e, 'f) fmt_fmtty_ebb ->\n     ('a, 'b, 'c, 'd, 'e, 'f) fmtty_fmt_ebb\n\n(* Abstract all fmtty type parameters. *)\n(* Used to compare format types. *)\ntype fmtty_ebb = Fmtty_EBB : ('a, 'b, 'c, 'd, 'e, 'f) fmtty -> fmtty_ebb\n\n(* Abstract all padding type parameters. *)\n(* Used to compare paddings. *)\ntype padding_ebb = Padding_EBB : ('a, 'b) padding -> padding_ebb\n\n(* Abstract all precision type parameters. *)\n(* Used to compare precisions. *)\ntype precision_ebb = Precision_EBB : ('a, 'b) precision -> precision_ebb\n\n(******************************************************************************)\n                               (* Constants *)\n\n(* Default precision for float printing. *)\nlet default_float_precision fconv =\n  match snd fconv with\n  | Float_f | Float_e | Float_E | Float_g | Float_G | Float_h | Float_H\n  | Float_CF -> -6\n  (* For %h %H and %#F formats, a negative precision means \"as many digits as\n     necessary\".  For the other FP formats, we take the absolute value\n     of the precision, hence 6 digits by default. *)\n  | Float_F -> 12\n  (* Default precision for OCaml float printing (%F). *)\n\n(******************************************************************************)\n                               (* Externals *)\n\nexternal format_float: string -> float -> string\n  = \"caml_format_float\"\nexternal format_int: string -> int -> string\n  = \"caml_format_int\"\nexternal format_int32: string -> int32 -> string\n  = \"caml_int32_format\"\nexternal format_nativeint: string -> nativeint -> string\n  = \"caml_nativeint_format\"\nexternal format_int64: string -> int64 -> string\n  = \"caml_int64_format\"\nexternal hexstring_of_float: float -> int -> char -> string\n  = \"caml_hexstring_of_float\"\n\n(******************************************************************************)\n                     (* Tools to pretty-print formats *)\n\n(* Type of extensible character buffers. *)\ntype buffer = {\n  mutable ind : int;\n  mutable bytes : bytes;\n}\n\n(* Create a fresh buffer. *)\nlet buffer_create init_size = { ind = 0; bytes = Bytes.create init_size }\n\n(* Check size of the buffer and grow it if needed. *)\nlet buffer_check_size buf overhead =\n  let len = Bytes.length buf.bytes in\n  let min_len = buf.ind + overhead in\n  if min_len > len then (\n    let new_len = Int.max (len * 2) min_len in\n    let new_str = Bytes.create new_len in\n    Bytes.blit buf.bytes 0 new_str 0 len;\n    buf.bytes <- new_str;\n  )\n\n(* Add the character `c' to the buffer `buf'. *)\nlet buffer_add_char buf c =\n  buffer_check_size buf 1;\n  Bytes.set buf.bytes buf.ind c;\n  buf.ind <- buf.ind + 1\n\n(* Add the string `s' to the buffer `buf'. *)\nlet buffer_add_string buf s =\n  let str_len = String.length s in\n  buffer_check_size buf str_len;\n  String.blit s 0 buf.bytes buf.ind str_len;\n  buf.ind <- buf.ind + str_len\n\n(* Get the content of the buffer. *)\nlet buffer_contents buf =\n  Bytes.sub_string buf.bytes 0 buf.ind\n\n(***)\n\n(* Convert an integer conversion to char. *)\nlet char_of_iconv iconv = match iconv with\n  | Int_d | Int_pd | Int_sd | Int_Cd -> 'd' | Int_i | Int_pi | Int_si\n  | Int_Ci -> 'i' | Int_x | Int_Cx -> 'x' | Int_X | Int_CX -> 'X' | Int_o\n  | Int_Co -> 'o' | Int_u | Int_Cu -> 'u'\n\n(* Convert a float conversion to char. *)\n(* `cF' will be 'F' for displaying format and 'g' to call libc printf *)\nlet char_of_fconv ?(cF='F') fconv = match snd fconv with\n  | Float_f -> 'f' | Float_e -> 'e'\n  | Float_E -> 'E' | Float_g -> 'g'\n  | Float_G -> 'G' | Float_F -> cF\n  | Float_h -> 'h' | Float_H -> 'H'\n  | Float_CF -> 'F'\n\n\n(* Convert a scanning counter to char. *)\nlet char_of_counter counter = match counter with\n  | Line_counter  -> 'l'\n  | Char_counter  -> 'n'\n  | Token_counter -> 'N'\n\n(***)\n\n(* Print a char_set in a buffer with the OCaml format lexical convention. *)\nlet bprint_char_set buf char_set =\n  let rec print_start set =\n    let is_alone c =\n      let before, after = Char.(chr (code c - 1), chr (code c + 1)) in\n      is_in_char_set set c\n      && not (is_in_char_set set before && is_in_char_set set after) in\n    if is_alone ']' then buffer_add_char buf ']';\n    print_out set 1;\n    if is_alone '-' then buffer_add_char buf '-';\n  and print_out set i =\n    if i < 256 then\n      if is_in_char_set set (char_of_int i) then print_first set i\n      else print_out set (i + 1)\n  and print_first set i =\n    match char_of_int i with\n    | '\\255' -> print_char buf 255;\n    | ']' | '-' -> print_out set (i + 1);\n    | _ -> print_second set (i + 1);\n  and print_second set i =\n    if is_in_char_set set (char_of_int i) then\n      match char_of_int i with\n      | '\\255' ->\n        print_char buf 254;\n        print_char buf 255;\n      | ']' | '-' when not (is_in_char_set set (char_of_int (i + 1))) ->\n        print_char buf (i - 1);\n        print_out set (i + 1);\n      | _ when not (is_in_char_set set (char_of_int (i + 1))) ->\n        print_char buf (i - 1);\n        print_char buf i;\n        print_out set (i + 2);\n      | _ ->\n        print_in set (i - 1) (i + 2);\n    else (\n      print_char buf (i - 1);\n      print_out set (i + 1);\n    )\n  and print_in set i j =\n    if j = 256 || not (is_in_char_set set (char_of_int j)) then (\n      print_char buf i;\n      print_char buf (int_of_char '-');\n      print_char buf (j - 1);\n      if j < 256 then print_out set (j + 1);\n    ) else\n      print_in set i (j + 1);\n  and print_char buf i = match char_of_int i with\n    | '%' -> buffer_add_char buf '%'; buffer_add_char buf '%';\n    | '@' -> buffer_add_char buf '%'; buffer_add_char buf '@';\n    | c   -> buffer_add_char buf c;\n  in\n  buffer_add_char buf '[';\n  print_start (\n    if is_in_char_set char_set '\\000'\n    then ( buffer_add_char buf '^'; rev_char_set char_set )\n    else char_set\n  );\n  buffer_add_char buf ']'\n\n(***)\n\n(* Print a padty in a buffer with the format-like syntax. *)\nlet bprint_padty buf padty = match padty with\n  | Left  -> buffer_add_char buf '-'\n  | Right -> ()\n  | Zeros -> buffer_add_char buf '0'\n\n(* Print the '_' of an ignored flag if needed. *)\nlet bprint_ignored_flag buf ign_flag =\n  if ign_flag then buffer_add_char buf '_'\n\n(***)\n\nlet bprint_pad_opt buf pad_opt = match pad_opt with\n  | None -> ()\n  | Some width -> buffer_add_string buf (Int.to_string width)\n\n(***)\n\n(* Print padding in a buffer with the format-like syntax. *)\nlet bprint_padding : type a b . buffer -> (a, b) padding -> unit =\nfun buf pad -> match pad with\n  | No_padding -> ()\n  | Lit_padding (padty, n) ->\n    bprint_padty buf padty;\n    buffer_add_string buf (Int.to_string n);\n  | Arg_padding padty ->\n    bprint_padty buf padty;\n    buffer_add_char buf '*'\n\n(* Print precision in a buffer with the format-like syntax. *)\nlet bprint_precision : type a b . buffer -> (a, b) precision -> unit =\n  fun buf prec -> match prec with\n  | No_precision -> ()\n  | Lit_precision n ->\n    buffer_add_char buf '.';\n    buffer_add_string buf (Int.to_string n);\n  | Arg_precision ->\n    buffer_add_string buf \".*\"\n\n(***)\n\n(* Print the optional '+', ' ' or '#' associated to an int conversion. *)\nlet bprint_iconv_flag buf iconv = match iconv with\n  | Int_pd | Int_pi -> buffer_add_char buf '+'\n  | Int_sd | Int_si -> buffer_add_char buf ' '\n  | Int_Cx | Int_CX | Int_Co | Int_Cd | Int_Ci | Int_Cu ->\n      buffer_add_char buf '#'\n  | Int_d | Int_i | Int_x | Int_X | Int_o | Int_u -> ()\n\n(* Print an complete int format in a buffer (ex: \"%3.*d\"). *)\nlet bprint_int_fmt buf ign_flag iconv pad prec =\n  buffer_add_char buf '%';\n  bprint_ignored_flag buf ign_flag;\n  bprint_iconv_flag buf iconv;\n  bprint_padding buf pad;\n  bprint_precision buf prec;\n  buffer_add_char buf (char_of_iconv iconv)\n\n(* Print a complete int32, nativeint or int64 format in a buffer. *)\nlet bprint_altint_fmt buf ign_flag iconv pad prec c =\n  buffer_add_char buf '%';\n  bprint_ignored_flag buf ign_flag;\n  bprint_iconv_flag buf iconv;\n  bprint_padding buf pad;\n  bprint_precision buf prec;\n  buffer_add_char buf c;\n  buffer_add_char buf (char_of_iconv iconv)\n\n(***)\n\n(* Print the optional '+', ' ' and/or '#' associated to a float conversion. *)\nlet bprint_fconv_flag buf fconv =\n  begin match fst fconv with\n  | Float_flag_p -> buffer_add_char buf '+'\n  | Float_flag_s -> buffer_add_char buf ' '\n  | Float_flag_ -> () end;\n  match snd fconv with\n  | Float_CF -> buffer_add_char buf '#'\n  | Float_f | Float_e | Float_E | Float_g | Float_G\n  | Float_F | Float_h | Float_H -> ()\n\n(* Print a complete float format in a buffer (ex: \"%+*.3f\"). *)\nlet bprint_float_fmt buf ign_flag fconv pad prec =\n  buffer_add_char buf '%';\n  bprint_ignored_flag buf ign_flag;\n  bprint_fconv_flag buf fconv;\n  bprint_padding buf pad;\n  bprint_precision buf prec;\n  buffer_add_char buf (char_of_fconv fconv)\n\n(* Compute the literal string representation of a Formatting_lit. *)\n(* Used by Printf and Scanf where formatting is not interpreted. *)\nlet string_of_formatting_lit formatting_lit = match formatting_lit with\n  | Close_box            -> \"@]\"\n  | Close_tag            -> \"@}\"\n  | Break (str, _, _)    -> str\n  | FFlush               -> \"@?\"\n  | Force_newline        -> \"@\\n\"\n  | Flush_newline        -> \"@.\"\n  | Magic_size (str, _)  -> str\n  | Escaped_at           -> \"@@\"\n  | Escaped_percent      -> \"@%\"\n  | Scan_indic c -> \"@\" ^ (String.make 1 c)\n\n(***)\n\n(* Print a literal char in a buffer, escape '%' by \"%%\". *)\nlet bprint_char_literal buf chr = match chr with\n  | '%' -> buffer_add_string buf \"%%\"\n  | _ -> buffer_add_char buf chr\n\n(* Print a literal string in a buffer, escape all '%' by \"%%\". *)\nlet bprint_string_literal buf str =\n  for i = 0 to String.length str - 1 do\n    bprint_char_literal buf str.[i]\n  done\n\n(******************************************************************************)\n                          (* Format pretty-printing *)\n\n(* Print a complete format type (an fmtty) in a buffer. *)\nlet rec bprint_fmtty : type a b c d e f g h i j k l .\n    buffer -> (a, b, c, d, e, f, g, h, i, j, k, l) fmtty_rel -> unit =\nfun buf fmtty -> match fmtty with\n  | Char_ty rest      -> buffer_add_string buf \"%c\";  bprint_fmtty buf rest;\n  | String_ty rest    -> buffer_add_string buf \"%s\";  bprint_fmtty buf rest;\n  | Int_ty rest       -> buffer_add_string buf \"%i\";  bprint_fmtty buf rest;\n  | Int32_ty rest     -> buffer_add_string buf \"%li\"; bprint_fmtty buf rest;\n  | Nativeint_ty rest -> buffer_add_string buf \"%ni\"; bprint_fmtty buf rest;\n  | Int64_ty rest     -> buffer_add_string buf \"%Li\"; bprint_fmtty buf rest;\n  | Float_ty rest     -> buffer_add_string buf \"%f\";  bprint_fmtty buf rest;\n  | Bool_ty rest      -> buffer_add_string buf \"%B\";  bprint_fmtty buf rest;\n  | Alpha_ty rest     -> buffer_add_string buf \"%a\";  bprint_fmtty buf rest;\n  | Theta_ty rest     -> buffer_add_string buf \"%t\";  bprint_fmtty buf rest;\n  | Any_ty rest       -> buffer_add_string buf \"%?\";  bprint_fmtty buf rest;\n  | Reader_ty rest    -> buffer_add_string buf \"%r\";  bprint_fmtty buf rest;\n\n  | Ignored_reader_ty rest ->\n    buffer_add_string buf \"%_r\";\n    bprint_fmtty buf rest;\n\n  | Format_arg_ty (sub_fmtty, rest) ->\n    buffer_add_string buf \"%{\"; bprint_fmtty buf sub_fmtty;\n    buffer_add_string buf \"%}\"; bprint_fmtty buf rest;\n  | Format_subst_ty (sub_fmtty, _, rest) ->\n    buffer_add_string buf \"%(\"; bprint_fmtty buf sub_fmtty;\n    buffer_add_string buf \"%)\"; bprint_fmtty buf rest;\n\n  | End_of_fmtty -> ()\n\n(***)\n\nlet rec int_of_custom_arity : type a b c .\n  (a, b, c) custom_arity -> int =\n  function\n  | Custom_zero -> 0\n  | Custom_succ x -> 1 + int_of_custom_arity x\n\n(* Print a complete format in a buffer. *)\nlet bprint_fmt buf fmt =\n  let rec fmtiter : type a b c d e f .\n      (a, b, c, d, e, f) fmt -> bool -> unit =\n  fun fmt ign_flag -> match fmt with\n    | String (pad, rest) ->\n      buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n      bprint_padding buf pad; buffer_add_char buf 's';\n      fmtiter rest false;\n    | Caml_string (pad, rest) ->\n      buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n      bprint_padding buf pad; buffer_add_char buf 'S';\n      fmtiter rest false;\n\n    | Int (iconv, pad, prec, rest) ->\n      bprint_int_fmt buf ign_flag iconv pad prec;\n      fmtiter rest false;\n    | Int32 (iconv, pad, prec, rest) ->\n      bprint_altint_fmt buf ign_flag iconv pad prec 'l';\n      fmtiter rest false;\n    | Nativeint (iconv, pad, prec, rest) ->\n      bprint_altint_fmt buf ign_flag iconv pad prec 'n';\n      fmtiter rest false;\n    | Int64 (iconv, pad, prec, rest) ->\n      bprint_altint_fmt buf ign_flag iconv pad prec 'L';\n      fmtiter rest false;\n    | Float (fconv, pad, prec, rest) ->\n      bprint_float_fmt buf ign_flag fconv pad prec;\n      fmtiter rest false;\n\n    | Char rest ->\n      buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n      buffer_add_char buf 'c'; fmtiter rest false;\n    | Caml_char rest ->\n      buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n      buffer_add_char buf 'C'; fmtiter rest false;\n    | Bool (pad, rest) ->\n      buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n      bprint_padding buf pad; buffer_add_char buf 'B';\n      fmtiter rest false;\n    | Alpha rest ->\n      buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n      buffer_add_char buf 'a'; fmtiter rest false;\n    | Theta rest ->\n      buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n      buffer_add_char buf 't'; fmtiter rest false;\n    | Custom (arity, _, rest) ->\n      for _i = 1 to int_of_custom_arity arity do\n        buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n        buffer_add_char buf '?';\n      done;\n      fmtiter rest false;\n    | Reader rest ->\n      buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n      buffer_add_char buf 'r'; fmtiter rest false;\n    | Flush rest ->\n      buffer_add_string buf \"%!\";\n      fmtiter rest ign_flag;\n\n    | String_literal (str, rest) ->\n      bprint_string_literal buf str;\n      fmtiter rest ign_flag;\n    | Char_literal (chr, rest) ->\n      bprint_char_literal buf chr;\n      fmtiter rest ign_flag;\n\n    | Format_arg (pad_opt, fmtty, rest) ->\n      buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n      bprint_pad_opt buf pad_opt; buffer_add_char buf '{';\n      bprint_fmtty buf fmtty; buffer_add_char buf '%'; buffer_add_char buf '}';\n      fmtiter rest false;\n    | Format_subst (pad_opt, fmtty, rest) ->\n      buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n      bprint_pad_opt buf pad_opt; buffer_add_char buf '(';\n      bprint_fmtty buf fmtty; buffer_add_char buf '%'; buffer_add_char buf ')';\n      fmtiter rest false;\n\n    | Scan_char_set (width_opt, char_set, rest) ->\n      buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n      bprint_pad_opt buf width_opt; bprint_char_set buf char_set;\n      fmtiter rest false;\n    | Scan_get_counter (counter, rest) ->\n      buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n      buffer_add_char buf (char_of_counter counter);\n      fmtiter rest false;\n    | Scan_next_char rest ->\n      buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n      bprint_string_literal buf \"0c\"; fmtiter rest false;\n\n    | Ignored_param (ign, rest) ->\n      let Param_format_EBB fmt' = param_format_of_ignored_format ign rest in\n      fmtiter fmt' true;\n\n    | Formatting_lit (fmting_lit, rest) ->\n      bprint_string_literal buf (string_of_formatting_lit fmting_lit);\n      fmtiter rest ign_flag;\n    | Formatting_gen (fmting_gen, rest) ->\n      begin match fmting_gen with\n      | Open_tag (Format (_, str)) ->\n        buffer_add_string buf \"@{\"; buffer_add_string buf str\n      | Open_box (Format (_, str)) ->\n        buffer_add_string buf \"@[\"; buffer_add_string buf str\n      end;\n      fmtiter rest ign_flag;\n\n    | End_of_format -> ()\n\n  in fmtiter fmt false\n\n(***)\n\n(* Convert a format to string. *)\nlet string_of_fmt fmt =\n  let buf = buffer_create 16 in\n  bprint_fmt buf fmt;\n  buffer_contents buf\n\n(******************************************************************************)\n                          (* Type extraction *)\n\ntype (_, _) eq = Refl : ('a, 'a) eq\n\n(* Invariant: this function is the identity on values.\n\n   In particular, if (ty1, ty2) have equal values, then\n   (trans (symm ty1) ty2) respects the 'trans' precondition. *)\nlet rec symm : type a1 b1 c1 d1 e1 f1 a2 b2 c2 d2 e2 f2 .\n   (a1, b1, c1, d1, e1, f1,\n    a2, b2, c2, d2, e2, f2) fmtty_rel\n-> (a2, b2, c2, d2, e2, f2,\n    a1, b1, c1, d1, e1, f1) fmtty_rel\n= function\n  | Char_ty rest -> Char_ty (symm rest)\n  | Int_ty rest -> Int_ty (symm rest)\n  | Int32_ty rest -> Int32_ty (symm rest)\n  | Int64_ty rest -> Int64_ty (symm rest)\n  | Nativeint_ty rest -> Nativeint_ty (symm rest)\n  | Float_ty rest -> Float_ty (symm rest)\n  | Bool_ty rest -> Bool_ty (symm rest)\n  | String_ty rest -> String_ty (symm rest)\n  | Theta_ty rest -> Theta_ty (symm rest)\n  | Alpha_ty rest -> Alpha_ty (symm rest)\n  | Any_ty rest -> Any_ty (symm rest)\n  | Reader_ty rest -> Reader_ty (symm rest)\n  | Ignored_reader_ty rest -> Ignored_reader_ty (symm rest)\n  | Format_arg_ty (ty, rest) ->\n    Format_arg_ty (ty, symm rest)\n  | Format_subst_ty (ty1, ty2, rest) ->\n    Format_subst_ty (ty2, ty1, symm rest)\n  | End_of_fmtty -> End_of_fmtty\n\nlet rec fmtty_rel_det : type a1 b c d1 e1 f1 a2 d2 e2 f2 .\n  (a1, b, c, d1, e1, f1,\n   a2, b, c, d2, e2, f2) fmtty_rel ->\n    ((f1, f2) eq -> (a1, a2) eq)\n  * ((a1, a2) eq -> (f1, f2) eq)\n  * ((e1, e2) eq -> (d1, d2) eq)\n  * ((d1, d2) eq -> (e1, e2) eq)\n= function\n  | End_of_fmtty ->\n    (fun Refl -> Refl),\n    (fun Refl -> Refl),\n    (fun Refl -> Refl),\n    (fun Refl -> Refl)\n  | Char_ty rest ->\n    let fa, af, ed, de = fmtty_rel_det rest in\n    (fun Refl -> let Refl = fa Refl in Refl),\n    (fun Refl -> let Refl = af Refl in Refl),\n    ed, de\n  | String_ty rest ->\n    let fa, af, ed, de = fmtty_rel_det rest in\n    (fun Refl -> let Refl = fa Refl in Refl),\n    (fun Refl -> let Refl = af Refl in Refl),\n    ed, de\n  | Int_ty rest ->\n    let fa, af, ed, de = fmtty_rel_det rest in\n    (fun Refl -> let Refl = fa Refl in Refl),\n    (fun Refl -> let Refl = af Refl in Refl),\n    ed, de\n  | Int32_ty rest ->\n    let fa, af, ed, de = fmtty_rel_det rest in\n    (fun Refl -> let Refl = fa Refl in Refl),\n    (fun Refl -> let Refl = af Refl in Refl),\n    ed, de\n  | Int64_ty rest ->\n    let fa, af, ed, de = fmtty_rel_det rest in\n    (fun Refl -> let Refl = fa Refl in Refl),\n    (fun Refl -> let Refl = af Refl in Refl),\n    ed, de\n  | Nativeint_ty rest ->\n    let fa, af, ed, de = fmtty_rel_det rest in\n    (fun Refl -> let Refl = fa Refl in Refl),\n    (fun Refl -> let Refl = af Refl in Refl),\n    ed, de\n  | Float_ty rest ->\n    let fa, af, ed, de = fmtty_rel_det rest in\n    (fun Refl -> let Refl = fa Refl in Refl),\n    (fun Refl -> let Refl = af Refl in Refl),\n    ed, de\n  | Bool_ty rest ->\n    let fa, af, ed, de = fmtty_rel_det rest in\n    (fun Refl -> let Refl = fa Refl in Refl),\n    (fun Refl -> let Refl = af Refl in Refl),\n    ed, de\n\n  | Theta_ty rest ->\n    let fa, af, ed, de = fmtty_rel_det rest in\n    (fun Refl -> let Refl = fa Refl in Refl),\n    (fun Refl -> let Refl = af Refl in Refl),\n    ed, de\n  | Alpha_ty rest ->\n    let fa, af, ed, de = fmtty_rel_det rest in\n    (fun Refl -> let Refl = fa Refl in Refl),\n    (fun Refl -> let Refl = af Refl in Refl),\n    ed, de\n  | Any_ty rest ->\n    let fa, af, ed, de = fmtty_rel_det rest in\n    (fun Refl -> let Refl = fa Refl in Refl),\n    (fun Refl -> let Refl = af Refl in Refl),\n    ed, de\n  | Reader_ty rest ->\n    let fa, af, ed, de = fmtty_rel_det rest in\n    (fun Refl -> let Refl = fa Refl in Refl),\n    (fun Refl -> let Refl = af Refl in Refl),\n    (fun Refl -> let Refl = ed Refl in Refl),\n    (fun Refl -> let Refl = de Refl in Refl)\n  | Ignored_reader_ty rest ->\n    let fa, af, ed, de = fmtty_rel_det rest in\n    (fun Refl -> let Refl = fa Refl in Refl),\n    (fun Refl -> let Refl = af Refl in Refl),\n    (fun Refl -> let Refl = ed Refl in Refl),\n    (fun Refl -> let Refl = de Refl in Refl)\n  | Format_arg_ty (_ty, rest) ->\n    let fa, af, ed, de = fmtty_rel_det rest in\n    (fun Refl -> let Refl = fa Refl in Refl),\n    (fun Refl -> let Refl = af Refl in Refl),\n    ed, de\n  | Format_subst_ty (ty1, ty2, rest) ->\n    let fa, af, ed, de = fmtty_rel_det rest in\n    let ty = trans (symm ty1) ty2 in\n    let ag, ga, dj, jd = fmtty_rel_det ty in\n    (fun Refl -> let Refl = fa Refl in let Refl = ag Refl in Refl),\n    (fun Refl -> let Refl = ga Refl in let Refl = af Refl in Refl),\n    (fun Refl -> let Refl = ed Refl in let Refl = dj Refl in Refl),\n    (fun Refl -> let Refl = jd Refl in let Refl = de Refl in Refl)\n\n(* Precondition: we assume that the two fmtty_rel arguments have equal\n   values (at possibly distinct types); this invariant comes from the way\n   fmtty_rel witnesses are produced by the type-checker\n\n   The code below uses (assert false) when this assumption is broken. The\n   code pattern is the following:\n\n     | Foo x, Foo y ->\n       (* case where indeed both values\n          start with constructor Foo *)\n     | Foo _, _\n     | _, Foo _ ->\n       (* different head constructors: broken precondition *)\n       assert false\n*)\nand trans : type\n  a1 b1 c1 d1 e1 f1\n  a2 b2 c2 d2 e2 f2\n  a3 b3 c3 d3 e3 f3\n.\n   (a1, b1, c1, d1, e1, f1,\n    a2, b2, c2, d2, e2, f2) fmtty_rel\n-> (a2, b2, c2, d2, e2, f2,\n    a3, b3, c3, d3, e3, f3) fmtty_rel\n-> (a1, b1, c1, d1, e1, f1,\n    a3, b3, c3, d3, e3, f3) fmtty_rel\n= fun ty1 ty2 -> match ty1, ty2 with\n  | Char_ty rest1, Char_ty rest2 -> Char_ty (trans rest1 rest2)\n  | String_ty rest1, String_ty rest2 -> String_ty (trans rest1 rest2)\n  | Bool_ty rest1, Bool_ty rest2 -> Bool_ty (trans rest1 rest2)\n  | Int_ty rest1, Int_ty rest2 -> Int_ty (trans rest1 rest2)\n  | Int32_ty rest1, Int32_ty rest2 -> Int32_ty (trans rest1 rest2)\n  | Int64_ty rest1, Int64_ty rest2 -> Int64_ty (trans rest1 rest2)\n  | Nativeint_ty rest1, Nativeint_ty rest2 -> Nativeint_ty (trans rest1 rest2)\n  | Float_ty rest1, Float_ty rest2 -> Float_ty (trans rest1 rest2)\n\n  | Alpha_ty rest1, Alpha_ty rest2 -> Alpha_ty (trans rest1 rest2)\n  | Alpha_ty _, _ -> assert false\n  | _, Alpha_ty _ -> assert false\n\n  | Theta_ty rest1, Theta_ty rest2 -> Theta_ty (trans rest1 rest2)\n  | Theta_ty _, _ -> assert false\n  | _, Theta_ty _ -> assert false\n\n  | Any_ty rest1, Any_ty rest2 -> Any_ty (trans rest1 rest2)\n  | Any_ty _, _ -> assert false\n  | _, Any_ty _ -> assert false\n\n  | Reader_ty rest1, Reader_ty rest2 -> Reader_ty (trans rest1 rest2)\n  | Reader_ty _, _ -> assert false\n  | _, Reader_ty _ -> assert false\n\n  | Ignored_reader_ty rest1, Ignored_reader_ty rest2 ->\n    Ignored_reader_ty (trans rest1 rest2)\n  | Ignored_reader_ty _, _ -> assert false\n  | _, Ignored_reader_ty _ -> assert false\n\n  | Format_arg_ty (ty1, rest1), Format_arg_ty (ty2, rest2) ->\n    Format_arg_ty (trans ty1 ty2, trans rest1 rest2)\n  | Format_arg_ty _, _ -> assert false\n  | _, Format_arg_ty _ -> assert false\n\n  | Format_subst_ty (ty11, ty12, rest1),\n    Format_subst_ty (ty21, ty22, rest2) ->\n    let ty = trans (symm ty12) ty21 in\n    let _, f2, _, f4 = fmtty_rel_det ty in\n    let Refl = f2 Refl in\n    let Refl = f4 Refl in\n    Format_subst_ty (ty11, ty22, trans rest1 rest2)\n  | Format_subst_ty _, _ -> assert false\n  | _, Format_subst_ty _ -> assert false\n\n  | End_of_fmtty, End_of_fmtty -> End_of_fmtty\n  | End_of_fmtty, _ -> assert false\n  | _, End_of_fmtty -> assert false\n\nlet rec fmtty_of_formatting_gen : type a b c d e f .\n  (a, b, c, d, e, f) formatting_gen ->\n    (a, b, c, d, e, f) fmtty =\nfun formatting_gen -> match formatting_gen with\n  | Open_tag (Format (fmt, _)) -> fmtty_of_fmt fmt\n  | Open_box (Format (fmt, _)) -> fmtty_of_fmt fmt\n\n(* Extract the type representation (an fmtty) of a format. *)\nand fmtty_of_fmt : type a b c d e f .\n  (a, b, c, d, e, f) fmt -> (a, b, c, d, e, f) fmtty =\nfun fmtty -> match fmtty with\n  | String (pad, rest) ->\n    fmtty_of_padding_fmtty pad (String_ty (fmtty_of_fmt rest))\n  | Caml_string (pad, rest) ->\n    fmtty_of_padding_fmtty pad (String_ty (fmtty_of_fmt rest))\n\n  | Int (_, pad, prec, rest) ->\n    let ty_rest = fmtty_of_fmt rest in\n    let prec_ty = fmtty_of_precision_fmtty prec (Int_ty ty_rest) in\n    fmtty_of_padding_fmtty pad prec_ty\n  | Int32 (_, pad, prec, rest) ->\n    let ty_rest = fmtty_of_fmt rest in\n    let prec_ty = fmtty_of_precision_fmtty prec (Int32_ty ty_rest) in\n    fmtty_of_padding_fmtty pad prec_ty\n  | Nativeint (_, pad, prec, rest) ->\n    let ty_rest = fmtty_of_fmt rest in\n    let prec_ty = fmtty_of_precision_fmtty prec (Nativeint_ty ty_rest) in\n    fmtty_of_padding_fmtty pad prec_ty\n  | Int64 (_, pad, prec, rest) ->\n    let ty_rest = fmtty_of_fmt rest in\n    let prec_ty = fmtty_of_precision_fmtty prec (Int64_ty ty_rest) in\n    fmtty_of_padding_fmtty pad prec_ty\n  | Float (_, pad, prec, rest) ->\n    let ty_rest = fmtty_of_fmt rest in\n    let prec_ty = fmtty_of_precision_fmtty prec (Float_ty ty_rest) in\n    fmtty_of_padding_fmtty pad prec_ty\n\n  | Char rest                  -> Char_ty (fmtty_of_fmt rest)\n  | Caml_char rest             -> Char_ty (fmtty_of_fmt rest)\n  | Bool (pad, rest)           ->\n      fmtty_of_padding_fmtty pad (Bool_ty (fmtty_of_fmt rest))\n  | Alpha rest                 -> Alpha_ty (fmtty_of_fmt rest)\n  | Theta rest                 -> Theta_ty (fmtty_of_fmt rest)\n  | Custom (arity, _, rest)    -> fmtty_of_custom arity (fmtty_of_fmt rest)\n  | Reader rest                -> Reader_ty (fmtty_of_fmt rest)\n\n  | Format_arg (_, ty, rest) ->\n    Format_arg_ty (ty, fmtty_of_fmt rest)\n  | Format_subst (_, ty, rest) ->\n    Format_subst_ty (ty, ty, fmtty_of_fmt rest)\n\n  | Flush rest                 -> fmtty_of_fmt rest\n  | String_literal (_, rest)   -> fmtty_of_fmt rest\n  | Char_literal (_, rest)     -> fmtty_of_fmt rest\n\n  | Scan_char_set (_, _, rest) -> String_ty (fmtty_of_fmt rest)\n  | Scan_get_counter (_, rest) -> Int_ty (fmtty_of_fmt rest)\n  | Scan_next_char rest        -> Char_ty (fmtty_of_fmt rest)\n  | Ignored_param (ign, rest)  -> fmtty_of_ignored_format ign rest\n  | Formatting_lit (_, rest)   -> fmtty_of_fmt rest\n  | Formatting_gen (fmting_gen, rest)  ->\n    concat_fmtty (fmtty_of_formatting_gen fmting_gen) (fmtty_of_fmt rest)\n\n  | End_of_format              -> End_of_fmtty\n\nand fmtty_of_custom : type x y a b c d e f .\n  (a, x, y) custom_arity -> (a, b, c, d, e, f) fmtty ->\n  (y, b, c, d, e, f) fmtty =\nfun arity fmtty -> match arity with\n  | Custom_zero -> fmtty\n  | Custom_succ arity -> Any_ty (fmtty_of_custom arity fmtty)\n\n(* Extract the fmtty of an ignored parameter followed by the rest of\n   the format. *)\nand fmtty_of_ignored_format : type x y a b c d e f .\n    (a, b, c, d, y, x) ignored ->\n    (x, b, c, y, e, f) fmt ->\n    (a, b, c, d, e, f) fmtty =\nfun ign fmt -> match ign with\n  | Ignored_char                    -> fmtty_of_fmt fmt\n  | Ignored_caml_char               -> fmtty_of_fmt fmt\n  | Ignored_string _                -> fmtty_of_fmt fmt\n  | Ignored_caml_string _           -> fmtty_of_fmt fmt\n  | Ignored_int (_, _)              -> fmtty_of_fmt fmt\n  | Ignored_int32 (_, _)            -> fmtty_of_fmt fmt\n  | Ignored_nativeint (_, _)        -> fmtty_of_fmt fmt\n  | Ignored_int64 (_, _)            -> fmtty_of_fmt fmt\n  | Ignored_float (_, _)            -> fmtty_of_fmt fmt\n  | Ignored_bool _                  -> fmtty_of_fmt fmt\n  | Ignored_format_arg _            -> fmtty_of_fmt fmt\n  | Ignored_format_subst (_, fmtty) -> concat_fmtty fmtty (fmtty_of_fmt fmt)\n  | Ignored_reader                  -> Ignored_reader_ty (fmtty_of_fmt fmt)\n  | Ignored_scan_char_set _         -> fmtty_of_fmt fmt\n  | Ignored_scan_get_counter _      -> fmtty_of_fmt fmt\n  | Ignored_scan_next_char          -> fmtty_of_fmt fmt\n\n(* Add an Int_ty node if padding is taken as an extra argument (ex: \"%*s\"). *)\nand fmtty_of_padding_fmtty : type x a b c d e f .\n    (x, a) padding -> (a, b, c, d, e, f) fmtty -> (x, b, c, d, e, f) fmtty =\n  fun pad fmtty -> match pad with\n    | No_padding    -> fmtty\n    | Lit_padding _ -> fmtty\n    | Arg_padding _ -> Int_ty fmtty\n\n(* Add an Int_ty node if precision is taken as an extra argument (ex: \"%.*f\").*)\nand fmtty_of_precision_fmtty : type x a b c d e f .\n    (x, a) precision -> (a, b, c, d, e, f) fmtty -> (x, b, c, d, e, f) fmtty =\n  fun prec fmtty -> match prec with\n    | No_precision    -> fmtty\n    | Lit_precision _ -> fmtty\n    | Arg_precision   -> Int_ty fmtty\n\n(******************************************************************************)\n                            (* Format typing *)\n\n(* Exception raised when a format does not match a given format type. *)\nexception Type_mismatch\n\n(* Type a padding. *)\n(* Take an Int_ty from the fmtty if the integer should be kept as argument. *)\n(* Raise Type_mismatch in case of type mismatch. *)\nlet type_padding : type a b c d e f x y .\n    (x, y) padding -> (a, b, c, d, e, f) fmtty ->\n      (a, b, c, d, e, f) padding_fmtty_ebb =\nfun pad fmtty -> match pad, fmtty with\n  | No_padding, _ -> Padding_fmtty_EBB (No_padding, fmtty)\n  | Lit_padding (padty, w), _ -> Padding_fmtty_EBB (Lit_padding (padty,w),fmtty)\n  | Arg_padding padty, Int_ty rest -> Padding_fmtty_EBB (Arg_padding padty,rest)\n  | _ -> raise Type_mismatch\n\n(* Convert a (upadding, uprecision) to a (padding, precision). *)\n(* Take one or two Int_ty from the fmtty if needed. *)\n(* Raise Type_mismatch in case of type mismatch. *)\nlet type_padprec : type a b c d e f x y z .\n  (x, y) padding -> (y, z) precision -> (a, b, c, d, e, f) fmtty ->\n    (a, b, c, d, e, f) padprec_fmtty_ebb =\nfun pad prec fmtty -> match prec, type_padding pad fmtty with\n  | No_precision, Padding_fmtty_EBB (pad, rest) ->\n    Padprec_fmtty_EBB (pad, No_precision, rest)\n  | Lit_precision p, Padding_fmtty_EBB (pad, rest) ->\n    Padprec_fmtty_EBB (pad, Lit_precision p, rest)\n  | Arg_precision, Padding_fmtty_EBB (pad, Int_ty rest) ->\n    Padprec_fmtty_EBB (pad, Arg_precision, rest)\n  | _, Padding_fmtty_EBB (_, _) -> raise Type_mismatch\n\n(* Type a format according to an fmtty. *)\n(* If typing succeed, generate a copy of the format with the same\n    type parameters as the fmtty. *)\n(* Raise [Failure] with an error message in case of type mismatch. *)\nlet rec type_format :\n  type a1 b1 c1 d1 e1 f1\n       a2 b2 c2 d2 e2 f2  .\n     (a1, b1, c1, d1, e1, f1) fmt\n  -> (a2, b2, c2, d2, e2, f2) fmtty\n  -> (a2, b2, c2, d2, e2, f2) fmt\n= fun fmt fmtty -> match type_format_gen fmt fmtty with\n  | Fmt_fmtty_EBB (fmt', End_of_fmtty) -> fmt'\n  | _ -> raise Type_mismatch\n\nand type_format_gen :\n  type a1 b1 c1 d1 e1 f1\n       a2 b2 c2 d2 e2 f2  .\n     (a1, b1, c1, d1, e1, f1) fmt\n  -> (a2, b2, c2, d2, e2, f2) fmtty\n  -> (a2, b2, c2, d2, e2, f2) fmt_fmtty_ebb\n= fun fmt fmtty -> match fmt, fmtty with\n  | Char fmt_rest, Char_ty fmtty_rest ->\n    let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n    Fmt_fmtty_EBB (Char fmt', fmtty')\n  | Caml_char fmt_rest, Char_ty fmtty_rest ->\n    let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n    Fmt_fmtty_EBB (Caml_char fmt', fmtty')\n  | String (pad, fmt_rest), _ -> (\n    match type_padding pad fmtty with\n    | Padding_fmtty_EBB (pad, String_ty fmtty_rest) ->\n      let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n      Fmt_fmtty_EBB (String (pad, fmt'), fmtty')\n    | Padding_fmtty_EBB (_, _) -> raise Type_mismatch\n  )\n  | Caml_string (pad, fmt_rest), _ -> (\n    match type_padding pad fmtty with\n    | Padding_fmtty_EBB (pad, String_ty fmtty_rest) ->\n      let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n      Fmt_fmtty_EBB (Caml_string (pad, fmt'), fmtty')\n    | Padding_fmtty_EBB (_, _) -> raise Type_mismatch\n  )\n  | Int (iconv, pad, prec, fmt_rest), _ -> (\n    match type_padprec pad prec fmtty with\n    | Padprec_fmtty_EBB (pad, prec, Int_ty fmtty_rest) ->\n      let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n      Fmt_fmtty_EBB (Int (iconv, pad, prec, fmt'), fmtty')\n    | Padprec_fmtty_EBB (_, _, _) -> raise Type_mismatch\n  )\n  | Int32 (iconv, pad, prec, fmt_rest), _ -> (\n    match type_padprec pad prec fmtty with\n    | Padprec_fmtty_EBB (pad, prec, Int32_ty fmtty_rest) ->\n      let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n      Fmt_fmtty_EBB (Int32 (iconv, pad, prec, fmt'), fmtty')\n    | Padprec_fmtty_EBB (_, _, _) -> raise Type_mismatch\n  )\n  | Nativeint (iconv, pad, prec, fmt_rest), _ -> (\n    match type_padprec pad prec fmtty with\n    | Padprec_fmtty_EBB (pad, prec, Nativeint_ty fmtty_rest) ->\n      let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n      Fmt_fmtty_EBB (Nativeint (iconv, pad, prec, fmt'), fmtty')\n    | Padprec_fmtty_EBB (_, _, _) -> raise Type_mismatch\n  )\n  | Int64 (iconv, pad, prec, fmt_rest), _ -> (\n    match type_padprec pad prec fmtty with\n    | Padprec_fmtty_EBB (pad, prec, Int64_ty fmtty_rest) ->\n      let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n      Fmt_fmtty_EBB (Int64 (iconv, pad, prec, fmt'), fmtty')\n    | Padprec_fmtty_EBB (_, _, _) -> raise Type_mismatch\n  )\n  | Float (fconv, pad, prec, fmt_rest), _ -> (\n    match type_padprec pad prec fmtty with\n    | Padprec_fmtty_EBB (pad, prec, Float_ty fmtty_rest) ->\n      let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n      Fmt_fmtty_EBB (Float (fconv, pad, prec, fmt'), fmtty')\n    | Padprec_fmtty_EBB (_, _, _) -> raise Type_mismatch\n  )\n  | Bool (pad, fmt_rest), _ -> (\n    match type_padding pad fmtty with\n    | Padding_fmtty_EBB (pad, Bool_ty fmtty_rest) ->\n      let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n      Fmt_fmtty_EBB (Bool (pad, fmt'), fmtty')\n    | Padding_fmtty_EBB (_, _) -> raise Type_mismatch\n  )\n  | Flush fmt_rest, fmtty_rest ->\n    let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n    Fmt_fmtty_EBB (Flush fmt', fmtty')\n\n  | String_literal (str, fmt_rest), fmtty_rest ->\n    let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n    Fmt_fmtty_EBB (String_literal (str, fmt'), fmtty')\n  | Char_literal (chr, fmt_rest), fmtty_rest ->\n    let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n    Fmt_fmtty_EBB (Char_literal (chr, fmt'), fmtty')\n\n  | Format_arg (pad_opt, sub_fmtty, fmt_rest),\n    Format_arg_ty (sub_fmtty', fmtty_rest) ->\n    if Fmtty_EBB sub_fmtty <> Fmtty_EBB sub_fmtty' then raise Type_mismatch;\n    let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n    Fmt_fmtty_EBB (Format_arg (pad_opt, sub_fmtty', fmt'), fmtty')\n  | Format_subst (pad_opt, sub_fmtty, fmt_rest),\n    Format_subst_ty (sub_fmtty1, _sub_fmtty2, fmtty_rest) ->\n    if Fmtty_EBB (erase_rel sub_fmtty) <> Fmtty_EBB (erase_rel sub_fmtty1) then\n      raise Type_mismatch;\n    let Fmt_fmtty_EBB (fmt', fmtty') =\n      type_format_gen fmt_rest (erase_rel fmtty_rest)\n    in\n    Fmt_fmtty_EBB (Format_subst (pad_opt, sub_fmtty1, fmt'), fmtty')\n  (* Printf and Format specific constructors: *)\n  | Alpha fmt_rest, Alpha_ty fmtty_rest ->\n    let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n    Fmt_fmtty_EBB (Alpha fmt', fmtty')\n  | Theta fmt_rest, Theta_ty fmtty_rest ->\n    let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n    Fmt_fmtty_EBB (Theta fmt', fmtty')\n\n  (* Format specific constructors: *)\n  | Formatting_lit (formatting_lit, fmt_rest), fmtty_rest ->\n    let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n    Fmt_fmtty_EBB (Formatting_lit (formatting_lit, fmt'), fmtty')\n  | Formatting_gen (formatting_gen, fmt_rest), fmtty_rest ->\n    type_formatting_gen formatting_gen fmt_rest fmtty_rest\n\n  (* Scanf specific constructors: *)\n  | Reader fmt_rest, Reader_ty fmtty_rest ->\n    let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n    Fmt_fmtty_EBB (Reader fmt', fmtty')\n  | Scan_char_set (width_opt, char_set, fmt_rest), String_ty fmtty_rest ->\n    let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n    Fmt_fmtty_EBB (Scan_char_set (width_opt, char_set, fmt'), fmtty')\n  | Scan_get_counter (counter, fmt_rest), Int_ty fmtty_rest ->\n    let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n    Fmt_fmtty_EBB (Scan_get_counter (counter, fmt'), fmtty')\n  | Ignored_param (ign, rest), fmtty_rest ->\n    type_ignored_param ign rest fmtty_rest\n\n  | End_of_format, fmtty_rest -> Fmt_fmtty_EBB (End_of_format, fmtty_rest)\n\n  | _ -> raise Type_mismatch\n\nand type_formatting_gen : type a1 a3 b1 b3 c1 c3 d1 d3 e1 e2 e3 f1 f2 f3 .\n    (a1, b1, c1, d1, e1, f1) formatting_gen ->\n    (f1, b1, c1, e1, e2, f2) fmt ->\n    (a3, b3, c3, d3, e3, f3) fmtty ->\n    (a3, b3, c3, d3, e3, f3) fmt_fmtty_ebb =\nfun formatting_gen fmt0 fmtty0 -> match formatting_gen with\n  | Open_tag (Format (fmt1, str)) ->\n    let Fmt_fmtty_EBB (fmt2, fmtty2) = type_format_gen fmt1 fmtty0 in\n    let Fmt_fmtty_EBB (fmt3, fmtty3) = type_format_gen fmt0 fmtty2 in\n    Fmt_fmtty_EBB (Formatting_gen (Open_tag (Format (fmt2, str)), fmt3), fmtty3)\n  | Open_box (Format (fmt1, str)) ->\n    let Fmt_fmtty_EBB (fmt2, fmtty2) = type_format_gen fmt1 fmtty0 in\n    let Fmt_fmtty_EBB (fmt3, fmtty3) = type_format_gen fmt0 fmtty2 in\n    Fmt_fmtty_EBB (Formatting_gen (Open_box (Format (fmt2, str)), fmt3), fmtty3)\n\n(* Type an Ignored_param node according to an fmtty. *)\nand type_ignored_param : type p q x y z t u v a b c d e f .\n    (x, y, z, t, q, p) ignored ->\n    (p, y, z, q, u, v) fmt ->\n    (a, b, c, d, e, f) fmtty ->\n    (a, b, c, d, e, f) fmt_fmtty_ebb =\nfun ign fmt fmtty -> match ign with\n  | Ignored_char               as ign' -> type_ignored_param_one ign' fmt fmtty\n  | Ignored_caml_char          as ign' -> type_ignored_param_one ign' fmt fmtty\n  | Ignored_string _           as ign' -> type_ignored_param_one ign' fmt fmtty\n  | Ignored_caml_string _      as ign' -> type_ignored_param_one ign' fmt fmtty\n  | Ignored_int _              as ign' -> type_ignored_param_one ign' fmt fmtty\n  | Ignored_int32 _            as ign' -> type_ignored_param_one ign' fmt fmtty\n  | Ignored_nativeint _        as ign' -> type_ignored_param_one ign' fmt fmtty\n  | Ignored_int64 _            as ign' -> type_ignored_param_one ign' fmt fmtty\n  | Ignored_float _            as ign' -> type_ignored_param_one ign' fmt fmtty\n  | Ignored_bool _             as ign' -> type_ignored_param_one ign' fmt fmtty\n  | Ignored_scan_char_set _    as ign' -> type_ignored_param_one ign' fmt fmtty\n  | Ignored_scan_get_counter _ as ign' -> type_ignored_param_one ign' fmt fmtty\n  | Ignored_scan_next_char     as ign' -> type_ignored_param_one ign' fmt fmtty\n  | Ignored_format_arg (pad_opt, sub_fmtty) ->\n    type_ignored_param_one (Ignored_format_arg (pad_opt, sub_fmtty)) fmt fmtty\n  | Ignored_format_subst (pad_opt, sub_fmtty) ->\n    let Fmtty_fmt_EBB (sub_fmtty', Fmt_fmtty_EBB (fmt', fmtty')) =\n      type_ignored_format_substitution sub_fmtty fmt fmtty in\n    Fmt_fmtty_EBB (Ignored_param (Ignored_format_subst (pad_opt, sub_fmtty'),\n                                  fmt'),\n                   fmtty')\n  | Ignored_reader -> (\n    match fmtty with\n    | Ignored_reader_ty fmtty_rest ->\n      let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt fmtty_rest in\n      Fmt_fmtty_EBB (Ignored_param (Ignored_reader, fmt'), fmtty')\n    | _ -> raise Type_mismatch\n  )\n\nand type_ignored_param_one : type a1 a2 b1 b2 c1 c2 d1 d2 e1 e2 f1 f2 .\n    (a2, b2, c2, d2, d2, a2) ignored ->\n    (a1, b1, c1, d1, e1, f1) fmt ->\n    (a2, b2, c2, d2, e2, f2) fmtty ->\n    (a2, b2, c2, d2, e2, f2) fmt_fmtty_ebb\n= fun ign fmt fmtty ->\n  let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt fmtty in\n  Fmt_fmtty_EBB (Ignored_param (ign, fmt'), fmtty')\n\n(* Typing of the complex case: \"%_(...%)\". *)\nand type_ignored_format_substitution : type w x y z p s t u a b c d e f .\n    (w, x, y, z, s, p) fmtty ->\n    (p, x, y, s, t, u) fmt ->\n    (a, b, c, d, e, f) fmtty -> (a, b, c, d, e, f) fmtty_fmt_ebb =\nfun sub_fmtty fmt fmtty -> match sub_fmtty, fmtty with\n  | Char_ty sub_fmtty_rest, Char_ty fmtty_rest ->\n    let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n      type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n    Fmtty_fmt_EBB (Char_ty sub_fmtty_rest', fmt')\n  | String_ty sub_fmtty_rest, String_ty fmtty_rest ->\n    let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n      type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n    Fmtty_fmt_EBB (String_ty sub_fmtty_rest', fmt')\n  | Int_ty sub_fmtty_rest, Int_ty fmtty_rest ->\n    let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n      type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n    Fmtty_fmt_EBB (Int_ty sub_fmtty_rest', fmt')\n  | Int32_ty sub_fmtty_rest, Int32_ty fmtty_rest ->\n    let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n      type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n    Fmtty_fmt_EBB (Int32_ty sub_fmtty_rest', fmt')\n  | Nativeint_ty sub_fmtty_rest, Nativeint_ty fmtty_rest ->\n    let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n      type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n    Fmtty_fmt_EBB (Nativeint_ty sub_fmtty_rest', fmt')\n  | Int64_ty sub_fmtty_rest, Int64_ty fmtty_rest ->\n    let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n      type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n    Fmtty_fmt_EBB (Int64_ty sub_fmtty_rest', fmt')\n  | Float_ty sub_fmtty_rest, Float_ty fmtty_rest ->\n    let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n      type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n    Fmtty_fmt_EBB (Float_ty sub_fmtty_rest', fmt')\n  | Bool_ty sub_fmtty_rest, Bool_ty fmtty_rest ->\n    let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n      type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n    Fmtty_fmt_EBB (Bool_ty sub_fmtty_rest', fmt')\n  | Alpha_ty sub_fmtty_rest, Alpha_ty fmtty_rest ->\n    let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n      type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n    Fmtty_fmt_EBB (Alpha_ty sub_fmtty_rest', fmt')\n  | Theta_ty sub_fmtty_rest, Theta_ty fmtty_rest ->\n    let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n      type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n    Fmtty_fmt_EBB (Theta_ty sub_fmtty_rest', fmt')\n  | Reader_ty sub_fmtty_rest, Reader_ty fmtty_rest ->\n    let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n      type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n    Fmtty_fmt_EBB (Reader_ty sub_fmtty_rest', fmt')\n  | Ignored_reader_ty sub_fmtty_rest, Ignored_reader_ty fmtty_rest ->\n    let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n      type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n    Fmtty_fmt_EBB (Ignored_reader_ty sub_fmtty_rest', fmt')\n\n  | Format_arg_ty (sub2_fmtty, sub_fmtty_rest),\n    Format_arg_ty (sub2_fmtty', fmtty_rest) ->\n    if Fmtty_EBB sub2_fmtty <> Fmtty_EBB sub2_fmtty' then raise Type_mismatch;\n    let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n      type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n    Fmtty_fmt_EBB (Format_arg_ty (sub2_fmtty', sub_fmtty_rest'), fmt')\n  | Format_subst_ty (sub1_fmtty,  sub2_fmtty,  sub_fmtty_rest),\n    Format_subst_ty (sub1_fmtty', sub2_fmtty', fmtty_rest) ->\n    (* TODO define Fmtty_rel_EBB to remove those erase_rel *)\n    if Fmtty_EBB (erase_rel sub1_fmtty) <> Fmtty_EBB (erase_rel sub1_fmtty')\n    then raise Type_mismatch;\n    if Fmtty_EBB (erase_rel sub2_fmtty) <> Fmtty_EBB (erase_rel sub2_fmtty')\n    then raise Type_mismatch;\n    let sub_fmtty' = trans (symm sub1_fmtty') sub2_fmtty' in\n    let _, f2, _, f4 = fmtty_rel_det sub_fmtty' in\n    let Refl = f2 Refl in\n    let Refl = f4 Refl in\n    let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n      type_ignored_format_substitution (erase_rel sub_fmtty_rest) fmt fmtty_rest\n    in\n    Fmtty_fmt_EBB (Format_subst_ty (sub1_fmtty', sub2_fmtty',\n                                    symm sub_fmtty_rest'),\n                   fmt')\n  | End_of_fmtty, fmtty ->\n    Fmtty_fmt_EBB (End_of_fmtty, type_format_gen fmt fmtty)\n  | _ -> raise Type_mismatch\n\n(* This implementation of `recast` is a bit disappointing. The\n   invariant provided by the type are very strong: the input format's\n   type is in relation to the output type's as witnessed by the\n   fmtty_rel argument. One would at first expect this function to be\n   total, and implementable by exhaustive pattern matching. Instead,\n   we reuse the highly partial and much less well-defined function\n   `type_format` that has lost all knowledge of the correspondence\n   between the argument's types.\n\n   Besides the fact that this function reuses a lot of the\n   `type_format` logic (eg.: seeing Int_ty in the fmtty parameter does\n   not let you match on Int only, as you may in fact have Float\n   (Arg_padding, ...) (\"%.*d\") beginning with an Int_ty), it is also\n   a partial function, because the typing information in a format is\n   not quite enough to reconstruct it unambiguously. For example, the\n   format types of \"%d%_r\" and \"%_r%d\" have the same format6\n   parameters, but they are not at all exchangeable, and putting one\n   in place of the other must result in a dynamic failure.\n\n   Given that:\n   - we'd have to duplicate a lot of non-trivial typing logic from type_format\n   - this wouldn't even eliminate (all) the dynamic failures\n   we decided to just reuse type_format directly for now.\n*)\nlet recast :\n  type a1 b1 c1 d1 e1 f1\n       a2 b2 c2 d2 e2 f2\n  .\n     (a1, b1, c1, d1, e1, f1) fmt\n  -> (a1, b1, c1, d1, e1, f1,\n      a2, b2, c2, d2, e2, f2) fmtty_rel\n  -> (a2, b2, c2, d2, e2, f2) fmt\n= fun fmt fmtty ->\n  type_format fmt (erase_rel (symm fmtty))\n\n(******************************************************************************)\n                             (* Printing tools *)\n\n(* Add padding spaces around a string. *)\nlet fix_padding padty width str =\n  let len = String.length str in\n  let width, padty =\n    abs width,\n    (* while literal padding widths are always non-negative,\n       dynamically-set widths (Arg_padding, eg. %*d) may be negative;\n       we interpret those as specifying a padding-to-the-left; this\n       means that '0' may get dropped even if it was explicitly set,\n       but:\n       - this is what the legacy implementation does, and\n         we preserve compatibility if possible\n       - we could only signal this issue by failing at runtime,\n         which is not very nice... *)\n    if width < 0 then Left else padty in\n  if width <= len then str else\n    let res = Bytes.make width (if padty = Zeros then '0' else ' ') in\n    begin match padty with\n    | Left  -> String.blit str 0 res 0 len\n    | Right -> String.blit str 0 res (width - len) len\n    | Zeros when len > 0 && (str.[0] = '+' || str.[0] = '-' || str.[0] = ' ') ->\n      Bytes.set res 0 str.[0];\n      String.blit str 1 res (width - len + 1) (len - 1)\n    | Zeros when len > 1 && str.[0] = '0' && (str.[1] = 'x' || str.[1] = 'X') ->\n      Bytes.set res 1 str.[1];\n      String.blit str 2 res (width - len + 2) (len - 2)\n    | Zeros ->\n      String.blit str 0 res (width - len) len\n    end;\n    Bytes.unsafe_to_string res\n\n(* Add '0' padding to int, int32, nativeint or int64 string representation. *)\nlet fix_int_precision prec str =\n  let prec = abs prec in\n  let len = String.length str in\n  match str.[0] with\n  | ('+' | '-' | ' ') as c when prec + 1 > len ->\n    let res = Bytes.make (prec + 1) '0' in\n    Bytes.set res 0 c;\n    String.blit str 1 res (prec - len + 2) (len - 1);\n    Bytes.unsafe_to_string res\n  | '0' when prec + 2 > len && len > 1 && (str.[1] = 'x' || str.[1] = 'X') ->\n    let res = Bytes.make (prec + 2) '0' in\n    Bytes.set res 1 str.[1];\n    String.blit str 2 res (prec - len + 4) (len - 2);\n    Bytes.unsafe_to_string res\n  | '0' .. '9' | 'a' .. 'f' | 'A' .. 'F' when prec > len ->\n    let res = Bytes.make prec '0' in\n    String.blit str 0 res (prec - len) len;\n    Bytes.unsafe_to_string res\n  | _ ->\n    str\n\n(* Escape a string according to the OCaml lexing convention. *)\nlet string_to_caml_string str =\n  let str = String.escaped str in\n  let l = String.length str in\n  let res = Bytes.make (l + 2) '\\\"' in\n  String.unsafe_blit str 0 res 1 l;\n  Bytes.unsafe_to_string res\n\n(* Generate the format_int/int32/nativeint/int64 first argument\n   from an int_conv. *)\nlet format_of_iconv = function\n  | Int_d | Int_Cd -> \"%d\" | Int_pd -> \"%+d\" | Int_sd -> \"% d\"\n  | Int_i | Int_Ci -> \"%i\" | Int_pi -> \"%+i\" | Int_si -> \"% i\"\n  | Int_x -> \"%x\" | Int_Cx -> \"%#x\"\n  | Int_X -> \"%X\" | Int_CX -> \"%#X\"\n  | Int_o -> \"%o\" | Int_Co -> \"%#o\"\n  | Int_u | Int_Cu -> \"%u\"\n\nlet format_of_iconvL = function\n  | Int_d | Int_Cd -> \"%Ld\" | Int_pd -> \"%+Ld\" | Int_sd -> \"% Ld\"\n  | Int_i | Int_Ci -> \"%Li\" | Int_pi -> \"%+Li\" | Int_si -> \"% Li\"\n  | Int_x -> \"%Lx\" | Int_Cx -> \"%#Lx\"\n  | Int_X -> \"%LX\" | Int_CX -> \"%#LX\"\n  | Int_o -> \"%Lo\" | Int_Co -> \"%#Lo\"\n  | Int_u | Int_Cu -> \"%Lu\"\n\nlet format_of_iconvl = function\n  | Int_d | Int_Cd -> \"%ld\" | Int_pd -> \"%+ld\" | Int_sd -> \"% ld\"\n  | Int_i | Int_Ci -> \"%li\" | Int_pi -> \"%+li\" | Int_si -> \"% li\"\n  | Int_x -> \"%lx\" | Int_Cx -> \"%#lx\"\n  | Int_X -> \"%lX\" | Int_CX -> \"%#lX\"\n  | Int_o -> \"%lo\" | Int_Co -> \"%#lo\"\n  | Int_u | Int_Cu -> \"%lu\"\n\nlet format_of_iconvn = function\n  | Int_d | Int_Cd -> \"%nd\" | Int_pd -> \"%+nd\" | Int_sd -> \"% nd\"\n  | Int_i | Int_Ci -> \"%ni\" | Int_pi -> \"%+ni\" | Int_si -> \"% ni\"\n  | Int_x -> \"%nx\" | Int_Cx -> \"%#nx\"\n  | Int_X -> \"%nX\" | Int_CX -> \"%#nX\"\n  | Int_o -> \"%no\" | Int_Co -> \"%#no\"\n  | Int_u | Int_Cu -> \"%nu\"\n\n(* Generate the format_float first argument from a float_conv. *)\nlet format_of_fconv fconv prec =\n    let prec = abs prec in\n    let symb = char_of_fconv ~cF:'g' fconv in\n    let buf = buffer_create 16 in\n    buffer_add_char buf '%';\n    bprint_fconv_flag buf fconv;\n    buffer_add_char buf '.';\n    buffer_add_string buf (Int.to_string prec);\n    buffer_add_char buf symb;\n    buffer_contents buf\n\nlet transform_int_alt iconv s =\n  match iconv with\n  | Int_Cd | Int_Ci | Int_Cu ->\n    let digits =\n      let n = ref 0 in\n      for i = 0 to String.length s - 1 do\n        match String.unsafe_get s i with\n        | '0'..'9' -> incr n\n        | _ -> ()\n      done;\n      !n\n    in\n    let buf = Bytes.create (String.length s + (digits - 1) / 3) in\n    let pos = ref 0 in\n    let put c = Bytes.set buf !pos c; incr pos in\n    let left = ref ((digits - 1) mod 3 + 1) in\n    for i = 0 to String.length s - 1 do\n      match String.unsafe_get s i with\n      | '0'..'9' as c ->\n          if !left = 0 then (put '_'; left := 3); decr left; put c\n      | c -> put c\n    done;\n    Bytes.unsafe_to_string buf\n  | _ -> s\n\n(* Convert an integer to a string according to a conversion. *)\nlet convert_int iconv n =\n  transform_int_alt iconv (format_int (format_of_iconv iconv) n)\nlet convert_int32 iconv n =\n  transform_int_alt iconv (format_int32 (format_of_iconvl iconv) n)\nlet convert_nativeint iconv n =\n  transform_int_alt iconv (format_nativeint (format_of_iconvn iconv) n)\nlet convert_int64 iconv n =\n  transform_int_alt iconv (format_int64 (format_of_iconvL iconv) n)\n\n(* Convert a float to string. *)\n(* Fix special case of \"OCaml float format\". *)\nlet convert_float fconv prec x =\n  let hex () =\n    let sign =\n      match fst fconv with\n      | Float_flag_p -> '+'\n      | Float_flag_s -> ' '\n      | _ -> '-' in\n    hexstring_of_float x prec sign in\n  let add_dot_if_needed str =\n    let len = String.length str in\n    let rec is_valid i =\n      if i = len then false else\n        match str.[i] with\n        | '.' | 'e' | 'E' -> true\n        | _ -> is_valid (i + 1) in\n    if is_valid 0 then str else str ^ \".\" in\n  let caml_special_val str = match classify_float x with\n    | FP_normal | FP_subnormal | FP_zero -> str\n    | FP_infinite -> if x < 0.0 then \"neg_infinity\" else \"infinity\"\n    | FP_nan -> \"nan\" in\n  match snd fconv with\n  | Float_h -> hex ()\n  | Float_H -> String.uppercase_ascii (hex ())\n  | Float_CF -> caml_special_val (hex ())\n  | Float_F ->\n    let str = format_float (format_of_fconv fconv prec) x in\n    caml_special_val (add_dot_if_needed str)\n  | Float_f | Float_e | Float_E | Float_g | Float_G ->\n    format_float (format_of_fconv fconv prec) x\n\n(* Convert a char to a string according to the OCaml lexical convention. *)\nlet format_caml_char c =\n  let str = Char.escaped c in\n  let l = String.length str in\n  let res = Bytes.make (l + 2) '\\'' in\n  String.unsafe_blit str 0 res 1 l;\n  Bytes.unsafe_to_string res\n\n(* Convert a format type to string *)\nlet string_of_fmtty fmtty =\n  let buf = buffer_create 16 in\n  bprint_fmtty buf fmtty;\n  buffer_contents buf\n\n(******************************************************************************)\n                        (* Generic printing function *)\n\n(* Make a generic printing function. *)\n(* Used to generate Printf and Format printing functions. *)\n(* Parameters:\n     k: a continuation finally applied to the output stream and the accumulator.\n     o: the output stream (see k, %a and %t).\n     acc: rev list of printing entities (string, char, flush, formatting, ...).\n     fmt: the format. *)\nlet rec make_printf : type a b c d e f .\n    ((b, c) acc -> f) -> (b, c) acc ->\n    (a, b, c, d, e, f) fmt -> a =\nfun k acc fmt -> match fmt with\n  | Char rest ->\n    fun c ->\n      let new_acc = Acc_data_char (acc, c) in\n      make_printf k new_acc rest\n  | Caml_char rest ->\n    fun c ->\n      let new_acc = Acc_data_string (acc, format_caml_char c) in\n      make_printf k new_acc rest\n  | String (pad, rest) ->\n    make_padding k acc rest pad (fun str -> str)\n  | Caml_string (pad, rest) ->\n    make_padding k acc rest pad string_to_caml_string\n  | Int (iconv, pad, prec, rest) ->\n    make_int_padding_precision k acc rest pad prec convert_int iconv\n  | Int32 (iconv, pad, prec, rest) ->\n    make_int_padding_precision k acc rest pad prec convert_int32 iconv\n  | Nativeint (iconv, pad, prec, rest) ->\n    make_int_padding_precision k acc rest pad prec convert_nativeint iconv\n  | Int64 (iconv, pad, prec, rest) ->\n    make_int_padding_precision k acc rest pad prec convert_int64 iconv\n  | Float (fconv, pad, prec, rest) ->\n    make_float_padding_precision k acc rest pad prec fconv\n  | Bool (pad, rest) ->\n    make_padding k acc rest pad string_of_bool\n  | Alpha rest ->\n    fun f x -> make_printf k (Acc_delay (acc, fun o -> f o x)) rest\n  | Theta rest ->\n    fun f -> make_printf k (Acc_delay (acc, f)) rest\n  | Custom (arity, f, rest) ->\n    make_custom k acc rest arity (f ())\n  | Reader _ ->\n    (* This case is impossible, by typing of formats. *)\n    (* Indeed, since printf and co. take a format4 as argument, the 'd and 'e\n       type parameters of fmt are obviously equals. The Reader is the\n       only constructor which touch 'd and 'e type parameters of the format\n       type, it adds an (->) to the 'd parameters. Consequently, a format4\n       cannot contain a Reader node, except in the sub-format associated to\n       an %{...%}. It's not a problem because make_printf do not call\n       itself recursively on the sub-format associated to %{...%}. *)\n    assert false\n  | Flush rest ->\n    make_printf k (Acc_flush acc) rest\n\n  | String_literal (str, rest) ->\n    make_printf k (Acc_string_literal (acc, str)) rest\n  | Char_literal (chr, rest) ->\n    make_printf k (Acc_char_literal (acc, chr)) rest\n\n  | Format_arg (_, sub_fmtty, rest) ->\n    let ty = string_of_fmtty sub_fmtty in\n    (fun str ->\n      ignore str;\n      make_printf k (Acc_data_string (acc, ty)) rest)\n  | Format_subst (_, fmtty, rest) ->\n    fun (Format (fmt, _)) -> make_printf k acc\n      (concat_fmt (recast fmt fmtty) rest)\n\n  | Scan_char_set (_, _, rest) ->\n    let new_acc = Acc_invalid_arg (acc, \"Printf: bad conversion %[\") in\n    fun _ -> make_printf k new_acc rest\n  | Scan_get_counter (_, rest) ->\n    (* This case should be refused for Printf. *)\n    (* Accepted for backward compatibility. *)\n    (* Interpret %l, %n and %L as %u. *)\n    fun n ->\n      let new_acc = Acc_data_string (acc, format_int \"%u\" n) in\n      make_printf k new_acc rest\n  | Scan_next_char rest ->\n    fun c ->\n      let new_acc = Acc_data_char (acc, c) in\n      make_printf k new_acc rest\n  | Ignored_param (ign, rest) ->\n    make_ignored_param k acc ign rest\n\n  | Formatting_lit (fmting_lit, rest) ->\n    make_printf k (Acc_formatting_lit (acc, fmting_lit)) rest\n  | Formatting_gen (Open_tag (Format (fmt', _)), rest) ->\n    let k' kacc =\n      make_printf k (Acc_formatting_gen (acc, Acc_open_tag kacc)) rest in\n    make_printf k' End_of_acc fmt'\n  | Formatting_gen (Open_box (Format (fmt', _)), rest) ->\n    let k' kacc =\n      make_printf k (Acc_formatting_gen (acc, Acc_open_box kacc)) rest in\n    make_printf k' End_of_acc fmt'\n\n  | End_of_format ->\n    k acc\n\n(* Delay the error (Invalid_argument \"Printf: bad conversion %_\"). *)\n(* Generate functions to take remaining arguments (after the \"%_\"). *)\nand make_ignored_param : type x y a b c d e f .\n    ((b, c) acc -> f) -> (b, c) acc ->\n    (a, b, c, d, y, x) ignored ->\n    (x, b, c, y, e, f) fmt -> a =\nfun k acc ign fmt -> match ign with\n  | Ignored_char                    -> make_invalid_arg k acc fmt\n  | Ignored_caml_char               -> make_invalid_arg k acc fmt\n  | Ignored_string _                -> make_invalid_arg k acc fmt\n  | Ignored_caml_string _           -> make_invalid_arg k acc fmt\n  | Ignored_int (_, _)              -> make_invalid_arg k acc fmt\n  | Ignored_int32 (_, _)            -> make_invalid_arg k acc fmt\n  | Ignored_nativeint (_, _)        -> make_invalid_arg k acc fmt\n  | Ignored_int64 (_, _)            -> make_invalid_arg k acc fmt\n  | Ignored_float (_, _)            -> make_invalid_arg k acc fmt\n  | Ignored_bool _                  -> make_invalid_arg k acc fmt\n  | Ignored_format_arg _            -> make_invalid_arg k acc fmt\n  | Ignored_format_subst (_, fmtty) -> make_from_fmtty k acc fmtty fmt\n  | Ignored_reader                  -> assert false\n  | Ignored_scan_char_set _         -> make_invalid_arg k acc fmt\n  | Ignored_scan_get_counter _      -> make_invalid_arg k acc fmt\n  | Ignored_scan_next_char          -> make_invalid_arg k acc fmt\n\n\n(* Special case of printf \"%_(\". *)\nand make_from_fmtty : type x y a b c d e f .\n    ((b, c) acc -> f) -> (b, c) acc ->\n    (a, b, c, d, y, x) fmtty ->\n    (x, b, c, y, e, f) fmt -> a =\nfun k acc fmtty fmt -> match fmtty with\n  | Char_ty rest            -> fun _ -> make_from_fmtty k acc rest fmt\n  | String_ty rest          -> fun _ -> make_from_fmtty k acc rest fmt\n  | Int_ty rest             -> fun _ -> make_from_fmtty k acc rest fmt\n  | Int32_ty rest           -> fun _ -> make_from_fmtty k acc rest fmt\n  | Nativeint_ty rest       -> fun _ -> make_from_fmtty k acc rest fmt\n  | Int64_ty rest           -> fun _ -> make_from_fmtty k acc rest fmt\n  | Float_ty rest           -> fun _ -> make_from_fmtty k acc rest fmt\n  | Bool_ty rest            -> fun _ -> make_from_fmtty k acc rest fmt\n  | Alpha_ty rest           -> fun _ _ -> make_from_fmtty k acc rest fmt\n  | Theta_ty rest           -> fun _ -> make_from_fmtty k acc rest fmt\n  | Any_ty rest             -> fun _ -> make_from_fmtty k acc rest fmt\n  | Reader_ty _             -> assert false\n  | Ignored_reader_ty _     -> assert false\n  | Format_arg_ty (_, rest) -> fun _ -> make_from_fmtty k acc rest fmt\n  | End_of_fmtty            -> make_invalid_arg k acc fmt\n  | Format_subst_ty (ty1, ty2, rest) ->\n    let ty = trans (symm ty1) ty2 in\n    fun _ -> make_from_fmtty k acc (concat_fmtty ty rest) fmt\n\n(* Insert an Acc_invalid_arg in the accumulator and continue to generate\n   closures to get the remaining arguments. *)\nand make_invalid_arg : type a b c d e f .\n    ((b, c) acc -> f) -> (b, c) acc ->\n    (a, b, c, d, e, f) fmt -> a =\nfun k acc fmt ->\n  make_printf k (Acc_invalid_arg (acc, \"Printf: bad conversion %_\")) fmt\n\n(* Fix padding, take it as an extra integer argument if needed. *)\nand make_padding : type x z a b c d e f .\n    ((b, c) acc -> f) -> (b, c) acc ->\n    (a, b, c, d, e, f) fmt ->\n    (x, z -> a) padding -> (z -> string) -> x =\n  fun k acc fmt pad trans -> match pad with\n  | No_padding ->\n    fun x ->\n      let new_acc = Acc_data_string (acc, trans x) in\n      make_printf k new_acc fmt\n  | Lit_padding (padty, width) ->\n    fun x ->\n      let new_acc = Acc_data_string (acc, fix_padding padty width (trans x)) in\n      make_printf k new_acc fmt\n  | Arg_padding padty ->\n    fun w x ->\n      let new_acc = Acc_data_string (acc, fix_padding padty w (trans x)) in\n      make_printf k new_acc fmt\n\n(* Fix padding and precision for int, int32, nativeint or int64. *)\n(* Take one or two extra integer arguments if needed. *)\nand make_int_padding_precision : type x y z a b c d e f .\n    ((b, c) acc -> f) -> (b, c) acc ->\n    (a, b, c, d, e, f) fmt ->\n    (x, y) padding -> (y, z -> a) precision -> (int_conv -> z -> string) ->\n    int_conv -> x =\n  fun k acc fmt pad prec trans iconv -> match pad, prec with\n  | No_padding, No_precision ->\n    fun x ->\n      let str = trans iconv x in\n      make_printf k (Acc_data_string (acc, str)) fmt\n  | No_padding, Lit_precision p ->\n    fun x ->\n      let str = fix_int_precision p (trans iconv x) in\n      make_printf k (Acc_data_string (acc, str)) fmt\n  | No_padding, Arg_precision ->\n    fun p x ->\n      let str = fix_int_precision p (trans iconv x) in\n      make_printf k (Acc_data_string (acc, str)) fmt\n  | Lit_padding (padty, w), No_precision ->\n    fun x ->\n      let str = fix_padding padty w (trans iconv x) in\n      make_printf k (Acc_data_string (acc, str)) fmt\n  | Lit_padding (padty, w), Lit_precision p ->\n    fun x ->\n      let str = fix_padding padty w (fix_int_precision p (trans iconv x)) in\n      make_printf k (Acc_data_string (acc, str)) fmt\n  | Lit_padding (padty, w), Arg_precision ->\n    fun p x ->\n      let str = fix_padding padty w (fix_int_precision p (trans iconv x)) in\n      make_printf k (Acc_data_string (acc, str)) fmt\n  | Arg_padding padty, No_precision ->\n    fun w x ->\n      let str = fix_padding padty w (trans iconv x) in\n      make_printf k (Acc_data_string (acc, str)) fmt\n  | Arg_padding padty, Lit_precision p ->\n    fun w x ->\n      let str = fix_padding padty w (fix_int_precision p (trans iconv x)) in\n      make_printf k (Acc_data_string (acc, str)) fmt\n  | Arg_padding padty, Arg_precision ->\n    fun w p x ->\n      let str = fix_padding padty w (fix_int_precision p (trans iconv x)) in\n      make_printf k (Acc_data_string (acc, str)) fmt\n\n(* Convert a float, fix padding and precision if needed. *)\n(* Take the float argument and one or two extra integer arguments if needed. *)\nand make_float_padding_precision : type x y a b c d e f .\n    ((b, c) acc -> f) -> (b, c) acc ->\n    (a, b, c, d, e, f) fmt ->\n    (x, y) padding -> (y, float -> a) precision -> float_conv -> x =\n  fun k acc fmt pad prec fconv -> match pad, prec with\n  | No_padding, No_precision ->\n    fun x ->\n      let str = convert_float fconv (default_float_precision fconv) x in\n      make_printf k (Acc_data_string (acc, str)) fmt\n  | No_padding, Lit_precision p ->\n    fun x ->\n      let str = convert_float fconv p x in\n      make_printf k (Acc_data_string (acc, str)) fmt\n  | No_padding, Arg_precision ->\n    fun p x ->\n      let str = convert_float fconv p x in\n      make_printf k (Acc_data_string (acc, str)) fmt\n  | Lit_padding (padty, w), No_precision ->\n    fun x ->\n      let str = convert_float fconv (default_float_precision fconv) x in\n      let str' = fix_padding padty w str in\n      make_printf k (Acc_data_string (acc, str')) fmt\n  | Lit_padding (padty, w), Lit_precision p ->\n    fun x ->\n      let str = fix_padding padty w (convert_float fconv p x) in\n      make_printf k (Acc_data_string (acc, str)) fmt\n  | Lit_padding (padty, w), Arg_precision ->\n    fun p x ->\n      let str = fix_padding padty w (convert_float fconv p x) in\n      make_printf k (Acc_data_string (acc, str)) fmt\n  | Arg_padding padty, No_precision ->\n    fun w x ->\n      let str = convert_float fconv (default_float_precision fconv) x in\n      let str' = fix_padding padty w str in\n      make_printf k (Acc_data_string (acc, str')) fmt\n  | Arg_padding padty, Lit_precision p ->\n    fun w x ->\n      let str = fix_padding padty w (convert_float fconv p x) in\n      make_printf k (Acc_data_string (acc, str)) fmt\n  | Arg_padding padty, Arg_precision ->\n    fun w p x ->\n      let str = fix_padding padty w (convert_float fconv p x) in\n      make_printf k (Acc_data_string (acc, str)) fmt\nand make_custom : type x y a b c d e f .\n  ((b, c) acc -> f) -> (b, c) acc ->\n  (a, b, c, d, e, f) fmt ->\n  (a, x, y) custom_arity -> x -> y =\n  fun k acc rest arity f -> match arity with\n  | Custom_zero -> make_printf k (Acc_data_string (acc, f)) rest\n  | Custom_succ arity ->\n    fun x ->\n      make_custom k acc rest arity (f x)\n\nlet const x _ = x\n\nlet rec make_iprintf : type a b c d e f state.\n  (state -> f) -> state -> (a, b, c, d, e, f) fmt -> a =\n  fun k o fmt -> match fmt with\n    | Char rest ->\n        const (make_iprintf k o rest)\n    | Caml_char rest ->\n        const (make_iprintf k o rest)\n    | String (No_padding, rest) ->\n        const (make_iprintf k o rest)\n    | String (Lit_padding _, rest) ->\n        const (make_iprintf k o rest)\n    | String (Arg_padding _, rest) ->\n        const (const (make_iprintf k o rest))\n    | Caml_string (No_padding, rest) ->\n        const (make_iprintf k o rest)\n    | Caml_string (Lit_padding _, rest) ->\n        const (make_iprintf k o rest)\n    | Caml_string (Arg_padding _, rest) ->\n        const (const (make_iprintf k o rest))\n    | Int (_, pad, prec, rest) ->\n        fn_of_padding_precision k o rest pad prec\n    | Int32 (_, pad, prec, rest) ->\n        fn_of_padding_precision k o rest pad prec\n    | Nativeint (_, pad, prec, rest) ->\n        fn_of_padding_precision k o rest pad prec\n    | Int64 (_, pad, prec, rest) ->\n        fn_of_padding_precision k o rest pad prec\n    | Float (_, pad, prec, rest) ->\n        fn_of_padding_precision k o rest pad prec\n    | Bool (No_padding, rest) ->\n        const (make_iprintf k o rest)\n    | Bool (Lit_padding _, rest) ->\n        const (make_iprintf k o rest)\n    | Bool (Arg_padding _, rest) ->\n        const (const (make_iprintf k o rest))\n    | Alpha rest ->\n        const (const (make_iprintf k o rest))\n    | Theta rest ->\n        const (make_iprintf k o rest)\n    | Custom (arity, _, rest) ->\n        fn_of_custom_arity k o rest arity\n    | Reader _ ->\n        (* This case is impossible, by typing of formats.  See the\n           note in the corresponding case for make_printf. *)\n        assert false\n    | Flush rest ->\n        make_iprintf k o rest\n    | String_literal (_, rest) ->\n        make_iprintf k o rest\n    | Char_literal (_, rest) ->\n        make_iprintf k o rest\n    | Format_arg (_, _, rest) ->\n        const (make_iprintf k o rest)\n    | Format_subst (_, fmtty, rest) ->\n        fun (Format (fmt, _)) ->\n          make_iprintf k o\n            (concat_fmt (recast fmt fmtty) rest)\n    | Scan_char_set (_, _, rest) ->\n        const (make_iprintf k o rest)\n    | Scan_get_counter (_, rest) ->\n        const (make_iprintf k o rest)\n    | Scan_next_char rest ->\n        const (make_iprintf k o rest)\n    | Ignored_param (ign, rest) ->\n        make_ignored_param (fun _ -> k o) (End_of_acc) ign rest\n    | Formatting_lit (_, rest) ->\n        make_iprintf k o rest\n    | Formatting_gen (Open_tag (Format (fmt', _)), rest) ->\n        make_iprintf (fun koc -> make_iprintf k koc rest) o fmt'\n    | Formatting_gen (Open_box (Format (fmt', _)), rest) ->\n        make_iprintf (fun koc -> make_iprintf k koc rest) o fmt'\n    | End_of_format ->\n        k o\nand fn_of_padding_precision :\n  type x y z a b c d e f state.\n  (state -> f) -> state -> (a, b, c, d, e, f) fmt ->\n  (x, y) padding -> (y, z -> a) precision -> x =\n  fun k o fmt pad prec -> match pad, prec with\n    | No_padding   , No_precision    ->\n        const (make_iprintf k o fmt)\n    | No_padding   , Lit_precision _ ->\n        const (make_iprintf k o fmt)\n    | No_padding   , Arg_precision   ->\n        const (const (make_iprintf k o fmt))\n    | Lit_padding _, No_precision    ->\n        const (make_iprintf k o fmt)\n    | Lit_padding _, Lit_precision _ ->\n        const (make_iprintf k o fmt)\n    | Lit_padding _, Arg_precision   ->\n        const (const (make_iprintf k o fmt))\n    | Arg_padding _, No_precision    ->\n        const (const (make_iprintf k o fmt))\n    | Arg_padding _, Lit_precision _ ->\n        const (const (make_iprintf k o fmt))\n    | Arg_padding _, Arg_precision   ->\n        const (const (const (make_iprintf k o fmt)))\nand fn_of_custom_arity : type x y a b c d e f state.\n  (state -> f) ->\n  state -> (a, b, c, d, e, f) fmt -> (a, x, y) custom_arity -> y =\n  fun k o fmt -> function\n    | Custom_zero ->\n        make_iprintf k o fmt\n    | Custom_succ arity ->\n        const (fn_of_custom_arity k o fmt arity)\n\n(******************************************************************************)\n                          (* Continuations for make_printf *)\n\n(* Recursively output an \"accumulator\" containing a reversed list of\n   printing entities (string, char, flus, ...) in an output_stream. *)\n(* Used as a continuation of make_printf. *)\nlet rec output_acc o acc = match acc with\n  | Acc_formatting_lit (p, fmting_lit) ->\n    let s = string_of_formatting_lit fmting_lit in\n    output_acc o p; output_string o s;\n  | Acc_formatting_gen (p, Acc_open_tag acc') ->\n    output_acc o p; output_string o \"@{\"; output_acc o acc';\n  | Acc_formatting_gen (p, Acc_open_box acc') ->\n    output_acc o p; output_string o \"@[\"; output_acc o acc';\n  | Acc_string_literal (p, s)\n  | Acc_data_string (p, s)   -> output_acc o p; output_string o s\n  | Acc_char_literal (p, c)\n  | Acc_data_char (p, c)     -> output_acc o p; output_char o c\n  | Acc_delay (p, f)         -> output_acc o p; f o\n  | Acc_flush p              -> output_acc o p; flush o\n  | Acc_invalid_arg (p, msg) -> output_acc o p; invalid_arg msg;\n  | End_of_acc               -> ()\n\n(* Recursively output an \"accumulator\" containing a reversed list of\n   printing entities (string, char, flus, ...) in a buffer. *)\n(* Used as a continuation of make_printf. *)\nlet rec bufput_acc b acc = match acc with\n  | Acc_formatting_lit (p, fmting_lit) ->\n    let s = string_of_formatting_lit fmting_lit in\n    bufput_acc b p; Buffer.add_string b s;\n  | Acc_formatting_gen (p, Acc_open_tag acc') ->\n    bufput_acc b p; Buffer.add_string b \"@{\"; bufput_acc b acc';\n  | Acc_formatting_gen (p, Acc_open_box acc') ->\n    bufput_acc b p; Buffer.add_string b \"@[\"; bufput_acc b acc';\n  | Acc_string_literal (p, s)\n  | Acc_data_string (p, s)   -> bufput_acc b p; Buffer.add_string b s\n  | Acc_char_literal (p, c)\n  | Acc_data_char (p, c)     -> bufput_acc b p; Buffer.add_char b c\n  | Acc_delay (p, f)         -> bufput_acc b p; f b\n  | Acc_flush p              -> bufput_acc b p;\n  | Acc_invalid_arg (p, msg) -> bufput_acc b p; invalid_arg msg;\n  | End_of_acc               -> ()\n\n(* Recursively output an \"accumulator\" containing a reversed list of\n   printing entities (string, char, flus, ...) in a buffer. *)\n(* Differ from bufput_acc by the interpretation of %a and %t. *)\n(* Used as a continuation of make_printf. *)\nlet rec strput_acc b acc = match acc with\n  | Acc_formatting_lit (p, fmting_lit) ->\n    let s = string_of_formatting_lit fmting_lit in\n    strput_acc b p; Buffer.add_string b s;\n  | Acc_formatting_gen (p, Acc_open_tag acc') ->\n    strput_acc b p; Buffer.add_string b \"@{\"; strput_acc b acc';\n  | Acc_formatting_gen (p, Acc_open_box acc') ->\n    strput_acc b p; Buffer.add_string b \"@[\"; strput_acc b acc';\n  | Acc_string_literal (p, s)\n  | Acc_data_string (p, s)   -> strput_acc b p; Buffer.add_string b s\n  | Acc_char_literal (p, c)\n  | Acc_data_char (p, c)     -> strput_acc b p; Buffer.add_char b c\n  | Acc_delay (p, f)         -> strput_acc b p; Buffer.add_string b (f ())\n  | Acc_flush p              -> strput_acc b p;\n  | Acc_invalid_arg (p, msg) -> strput_acc b p; invalid_arg msg;\n  | End_of_acc               -> ()\n\n(******************************************************************************)\n                          (* Error management *)\n\n(* Raise [Failure] with a pretty-printed error message. *)\nlet failwith_message (Format (fmt, _)) =\n  let buf = Buffer.create 256 in\n  let k acc = strput_acc buf acc; failwith (Buffer.contents buf) in\n  make_printf k End_of_acc fmt\n\n(******************************************************************************)\n                            (* Formatting tools *)\n\n(* Convert a string to an open block description (indent, block_type) *)\nlet open_box_of_string str =\n  if str = \"\" then (0, Pp_box) else\n    let len = String.length str in\n    let invalid_box () = failwith_message \"invalid box description %S\" str in\n    let rec parse_spaces i =\n      if i = len then i else\n        match str.[i] with\n        | ' ' | '\\t' -> parse_spaces (i + 1)\n        | _ -> i\n    and parse_lword i j =\n      if j = len then j else\n        match str.[j] with\n        | 'a' .. 'z' -> parse_lword i (j + 1)\n        | _ -> j\n    and parse_int i j =\n      if j = len then j else\n        match str.[j] with\n        | '0' .. '9' | '-' -> parse_int i (j + 1)\n        | _ -> j in\n    let wstart = parse_spaces 0 in\n    let wend = parse_lword wstart wstart in\n    let box_name = String.sub str wstart (wend - wstart) in\n    let nstart = parse_spaces wend in\n    let nend = parse_int nstart nstart in\n    let indent =\n      if nstart = nend then 0 else\n        try int_of_string (String.sub str nstart (nend - nstart))\n        with Failure _ -> invalid_box () in\n    let exp_end = parse_spaces nend in\n    if exp_end <> len then invalid_box ();\n    let box_type = match box_name with\n      | \"\" | \"b\" -> Pp_box\n      | \"h\"      -> Pp_hbox\n      | \"v\"      -> Pp_vbox\n      | \"hv\"     -> Pp_hvbox\n      | \"hov\"    -> Pp_hovbox\n      | _        -> invalid_box () in\n    (indent, box_type)\n\n(******************************************************************************)\n                            (* Parsing tools *)\n\n(* Create a padding_fmt_ebb from a padding and a format. *)\n(* Copy the padding to disjoin the type parameters of argument and result. *)\nlet make_padding_fmt_ebb : type x y .\n    (x, y) padding -> (_, _, _, _, _, _) fmt ->\n      (_, _, _, _, _) padding_fmt_ebb =\nfun pad fmt -> match pad with\n  | No_padding         -> Padding_fmt_EBB (No_padding, fmt)\n  | Lit_padding (s, w) -> Padding_fmt_EBB (Lit_padding (s, w), fmt)\n  | Arg_padding s      -> Padding_fmt_EBB (Arg_padding s, fmt)\n\n(* Create a precision_fmt_ebb from a precision and a format. *)\n(* Copy the precision to disjoin the type parameters of argument and result. *)\nlet make_precision_fmt_ebb : type x y .\n    (x, y) precision -> (_, _, _, _, _, _) fmt ->\n      (_, _, _, _, _) precision_fmt_ebb =\nfun prec fmt -> match prec with\n  | No_precision    -> Precision_fmt_EBB (No_precision, fmt)\n  | Lit_precision p -> Precision_fmt_EBB (Lit_precision p, fmt)\n  | Arg_precision   -> Precision_fmt_EBB (Arg_precision, fmt)\n\n(* Create a padprec_fmt_ebb from a padding, a precision and a format. *)\n(* Copy the padding and the precision to disjoin type parameters of arguments\n   and result. *)\nlet make_padprec_fmt_ebb : type x y z t .\n    (x, y) padding -> (z, t) precision ->\n    (_, _, _, _, _, _) fmt ->\n    (_, _, _, _, _) padprec_fmt_ebb =\nfun pad prec fmt ->\n  let Precision_fmt_EBB (prec, fmt') = make_precision_fmt_ebb prec fmt in\n  match pad with\n  | No_padding         -> Padprec_fmt_EBB (No_padding, prec, fmt')\n  | Lit_padding (s, w) -> Padprec_fmt_EBB (Lit_padding (s, w), prec, fmt')\n  | Arg_padding s      -> Padprec_fmt_EBB (Arg_padding s, prec, fmt')\n\n(******************************************************************************)\n                             (* Format parsing *)\n\n(* Parse a string representing a format and create a fmt_ebb. *)\n(* Raise [Failure] in case of invalid format. *)\nlet fmt_ebb_of_string ?legacy_behavior str =\n  (* Parameters naming convention:                                    *)\n  (*   - lit_start: start of the literal sequence.                    *)\n  (*   - str_ind: current index in the string.                        *)\n  (*   - end_ind: end of the current (sub-)format.                    *)\n  (*   - pct_ind: index of the '%' in the current micro-format.       *)\n  (*   - zero:  is the '0' flag defined in the current micro-format.  *)\n  (*   - minus: is the '-' flag defined in the current micro-format.  *)\n  (*   - plus:  is the '+' flag defined in the current micro-format.  *)\n  (*   - hash:  is the '#' flag defined in the current micro-format.  *)\n  (*   - space: is the ' ' flag defined in the current micro-format.  *)\n  (*   - ign:   is the '_' flag defined in the current micro-format.  *)\n  (*   - pad: padding of the current micro-format.                    *)\n  (*   - prec: precision of the current micro-format.                 *)\n  (*   - symb: char representing the conversion ('c', 's', 'd', ...). *)\n  (*   - char_set: set of characters as bitmap (see scanf %[...]).    *)\n\n  let legacy_behavior = match legacy_behavior with\n    | Some flag -> flag\n    | None -> true\n  (*  When this flag is enabled, the format parser tries to behave as\n      the <4.02 implementations, in particular it ignores most benine\n      nonsensical format. When the flag is disabled, it will reject any\n      format that is not accepted by the specification.\n\n      A typical example would be \"%+ d\": specifying both '+' (if the\n      number is positive, pad with a '+' to get the same width as\n      negative numbers) and ' ' (if the number is positive, pad with\n      a space) does not make sense, but the legacy (< 4.02)\n      implementation was happy to just ignore the space.\n  *)\n  in\n\n  (* Raise [Failure] with a friendly error message. *)\n  let invalid_format_message str_ind msg =\n    failwith_message\n      \"invalid format %S: at character number %d, %s\"\n      str str_ind msg\n  in\n\n  (* Used when the end of the format (or the current sub-format) was encountered\n      unexpectedly. *)\n  let unexpected_end_of_format end_ind =\n    invalid_format_message end_ind\n      \"unexpected end of format\"\n  in\n\n  (* Used for %0c: no other widths are implemented *)\n  let invalid_nonnull_char_width str_ind =\n    invalid_format_message str_ind\n      \"non-zero widths are unsupported for %c conversions\"\n  in\n  (* Raise [Failure] with a friendly error message about an option dependency\n     problem. *)\n  let invalid_format_without str_ind c s =\n    failwith_message\n      \"invalid format %S: at character number %d, '%c' without %s\"\n      str str_ind c s\n  in\n\n  (* Raise [Failure] with a friendly error message about an unexpected\n     character. *)\n  let expected_character str_ind expected read =\n    failwith_message\n     \"invalid format %S: at character number %d, %s expected, read %C\"\n      str str_ind expected read\n  in\n\n  (* Parse the string from beg_ind (included) to end_ind (excluded). *)\n  let rec parse : type e f . int -> int -> (_, _, e, f) fmt_ebb =\n  fun beg_ind end_ind -> parse_literal beg_ind beg_ind end_ind\n\n  (* Read literal characters up to '%' or '@' special characters. *)\n  and parse_literal : type e f . int -> int -> int -> (_, _, e, f) fmt_ebb =\n  fun lit_start str_ind end_ind ->\n    if str_ind = end_ind then add_literal lit_start str_ind End_of_format else\n      match str.[str_ind] with\n      | '%' ->\n        let Fmt_EBB fmt_rest = parse_format str_ind end_ind in\n        add_literal lit_start str_ind fmt_rest\n      | '@' ->\n        let Fmt_EBB fmt_rest = parse_after_at (str_ind + 1) end_ind in\n        add_literal lit_start str_ind fmt_rest\n      | _ ->\n        parse_literal lit_start (str_ind + 1) end_ind\n\n  (* Parse a format after '%' *)\n  and parse_format : type e f . int -> int -> (_, _, e, f) fmt_ebb =\n  fun pct_ind end_ind -> parse_ign pct_ind (pct_ind + 1) end_ind\n\n  and parse_ign : type e f . int -> int -> int -> (_, _, e, f) fmt_ebb =\n  fun pct_ind str_ind end_ind ->\n    if str_ind = end_ind then unexpected_end_of_format end_ind;\n    match str.[str_ind] with\n      | '_' -> parse_flags pct_ind (str_ind+1) end_ind true\n      | _ -> parse_flags pct_ind str_ind end_ind false\n\n  and parse_flags : type e f . int -> int -> int -> bool -> (_, _, e, f) fmt_ebb\n  =\n  fun pct_ind str_ind end_ind ign ->\n    let zero = ref false and minus = ref false\n    and plus = ref false and space = ref false\n    and hash = ref false in\n    let set_flag str_ind flag =\n      (* in legacy mode, duplicate flags are accepted *)\n      if !flag && not legacy_behavior then\n        failwith_message\n          \"invalid format %S: at character number %d, duplicate flag %C\"\n          str str_ind str.[str_ind];\n      flag := true;\n    in\n    let rec read_flags str_ind =\n      if str_ind = end_ind then unexpected_end_of_format end_ind;\n      begin match str.[str_ind] with\n      | '0' -> set_flag str_ind zero;  read_flags (str_ind + 1)\n      | '-' -> set_flag str_ind minus; read_flags (str_ind + 1)\n      | '+' -> set_flag str_ind plus;  read_flags (str_ind + 1)\n      | '#' -> set_flag str_ind hash; read_flags (str_ind + 1)\n      | ' ' -> set_flag str_ind space; read_flags (str_ind + 1)\n      | _ ->\n        parse_padding pct_ind str_ind end_ind\n          !zero !minus !plus !hash !space ign\n      end\n    in\n    read_flags str_ind\n\n  (* Try to read a digital or a '*' padding. *)\n  and parse_padding : type e f .\n      int -> int -> int -> bool -> bool -> bool -> bool -> bool -> bool ->\n        (_, _, e, f) fmt_ebb =\n  fun pct_ind str_ind end_ind zero minus plus hash space ign ->\n    if str_ind = end_ind then unexpected_end_of_format end_ind;\n    let padty = match zero, minus with\n      | false, false -> Right\n      | false, true  -> Left\n      |  true, false -> Zeros\n      |  true, true  ->\n        if legacy_behavior then Left\n        else incompatible_flag pct_ind str_ind '-' \"0\" in\n    match str.[str_ind] with\n    | '0' .. '9' ->\n      let new_ind, width = parse_positive str_ind end_ind 0 in\n      parse_after_padding pct_ind new_ind end_ind minus plus hash space ign\n        (Lit_padding (padty, width))\n    | '*' ->\n      parse_after_padding pct_ind (str_ind + 1) end_ind minus plus hash space\n        ign (Arg_padding padty)\n    | _ ->\n      begin match padty with\n      | Left  ->\n        if not legacy_behavior then\n          invalid_format_without (str_ind - 1) '-' \"padding\";\n        parse_after_padding pct_ind str_ind end_ind minus plus hash space ign\n          No_padding\n      | Zeros ->\n         (* a '0' padding indication not followed by anything should\n           be interpreted as a Right padding of width 0. This is used\n           by scanning conversions %0s and %0c *)\n        parse_after_padding pct_ind str_ind end_ind minus plus hash space ign\n          (Lit_padding (Right, 0))\n      | Right ->\n        parse_after_padding pct_ind str_ind end_ind minus plus hash space ign\n          No_padding\n      end\n\n  (* Is precision defined? *)\n  and parse_after_padding : type x e f .\n      int -> int -> int -> bool -> bool -> bool -> bool -> bool ->\n        (x, _) padding -> (_, _, e, f) fmt_ebb =\n  fun pct_ind str_ind end_ind minus plus hash space ign pad ->\n    if str_ind = end_ind then unexpected_end_of_format end_ind;\n    match str.[str_ind] with\n    | '.' ->\n      parse_precision pct_ind (str_ind + 1) end_ind minus plus hash space ign\n        pad\n    | symb ->\n      parse_conversion pct_ind (str_ind + 1) end_ind plus hash space ign pad\n        No_precision pad symb\n\n  (* Read the digital or '*' precision. *)\n  and parse_precision : type x e f .\n      int -> int -> int -> bool -> bool -> bool -> bool -> bool ->\n        (x, _) padding -> (_, _, e, f) fmt_ebb =\n  fun pct_ind str_ind end_ind minus plus hash space ign pad ->\n    if str_ind = end_ind then unexpected_end_of_format end_ind;\n    let parse_literal minus str_ind =\n      let new_ind, prec = parse_positive str_ind end_ind 0 in\n      parse_after_precision pct_ind new_ind end_ind minus plus hash space ign\n        pad (Lit_precision prec) in\n    match str.[str_ind] with\n    | '0' .. '9' -> parse_literal minus str_ind\n    | ('+' | '-') as symb when legacy_behavior ->\n      (* Legacy mode would accept and ignore '+' or '-' before the\n         integer describing the desired precision; note that this\n         cannot happen for padding width, as '+' and '-' already have\n         a semantics there.\n\n         That said, the idea (supported by this tweak) that width and\n         precision literals are \"integer literals\" in the OCaml sense is\n         still blatantly wrong, as 123_456 or 0xFF are rejected. *)\n      parse_literal (minus || symb = '-') (str_ind + 1)\n    | '*' ->\n      parse_after_precision pct_ind (str_ind + 1) end_ind minus plus hash space\n        ign pad Arg_precision\n    | _ ->\n      if legacy_behavior then\n        (* note that legacy implementation did not ignore '.' without\n           a number (as it does for padding indications), but\n           interprets it as '.0' *)\n        parse_after_precision pct_ind str_ind end_ind minus plus hash space ign\n          pad (Lit_precision 0)\n      else\n        invalid_format_without (str_ind - 1) '.' \"precision\"\n\n  (* Try to read the conversion. *)\n  and parse_after_precision : type x y z t e f .\n      int -> int -> int -> bool -> bool -> bool -> bool -> bool ->\n        (x, y) padding -> (z, t) precision -> (_, _, e, f) fmt_ebb =\n  fun pct_ind str_ind end_ind minus plus hash space ign pad prec ->\n    if str_ind = end_ind then unexpected_end_of_format end_ind;\n    let parse_conv (type u) (type v) (padprec : (u, v) padding) =\n      parse_conversion pct_ind (str_ind + 1) end_ind plus hash space ign pad\n        prec padprec str.[str_ind] in\n    (* in legacy mode, some formats (%s and %S) accept a weird mix of\n       padding and precision, which is merged as a single padding\n       information. For example, in %.10s the precision is implicitly\n       understood as padding %10s, but the left-padding component may\n       be specified either as a left padding or a negative precision:\n       %-.3s and %.-3s are equivalent to %-3s *)\n    match pad with\n    | No_padding -> (\n      match minus, prec with\n        | _, No_precision -> parse_conv No_padding\n        | false, Lit_precision n -> parse_conv (Lit_padding (Right, n))\n        | true, Lit_precision n -> parse_conv (Lit_padding (Left, n))\n        | false, Arg_precision -> parse_conv (Arg_padding Right)\n        | true, Arg_precision -> parse_conv (Arg_padding Left)\n    )\n    | pad -> parse_conv pad\n\n  (* Case analysis on conversion. *)\n  and parse_conversion : type x y z t u v e f .\n      int -> int -> int -> bool -> bool -> bool -> bool -> (x, y) padding ->\n        (z, t) precision -> (u, v) padding -> char -> (_, _, e, f) fmt_ebb =\n  fun pct_ind str_ind end_ind plus hash space ign pad prec padprec symb ->\n    (* Flags used to check option usages/compatibilities. *)\n    let plus_used  = ref false and hash_used = ref false\n    and space_used = ref false and ign_used   = ref false\n    and pad_used   = ref false and prec_used  = ref false in\n\n    (* Access to options, update flags. *)\n    let get_plus    () = plus_used  := true; plus\n    and get_hash   () = hash_used := true; hash\n    and get_space   () = space_used := true; space\n    and get_ign     () = ign_used   := true; ign\n    and get_pad     () = pad_used   := true; pad\n    and get_prec    () = prec_used  := true; prec\n    and get_padprec () = pad_used   := true; padprec in\n\n    let get_int_pad () : (x,y) padding =\n      (* %5.3d is accepted and meaningful: pad to length 5 with\n         spaces, but first pad with zeros upto length 3 (0-padding\n         is the interpretation of \"precision\" for integer formats).\n\n         %05.3d is redundant: pad to length 5 *with zeros*, but\n         first pad with zeros... To add insult to the injury, the\n         legacy implementation ignores the 0-padding indication and\n         does the 5 padding with spaces instead. We reuse this\n         interpretation for compatibility, but statically reject this\n         format when the legacy mode is disabled, to protect strict\n         users from this corner case. *)\n       match get_pad (), get_prec () with\n         | pad, No_precision -> pad\n         | No_padding, _     -> No_padding\n         | Lit_padding (Zeros, n), _ ->\n           if legacy_behavior then Lit_padding (Right, n)\n           else incompatible_flag pct_ind str_ind '0' \"precision\"\n         | Arg_padding Zeros, _ ->\n           if legacy_behavior then Arg_padding Right\n           else incompatible_flag pct_ind str_ind '0' \"precision\"\n         | Lit_padding _ as pad, _ -> pad\n         | Arg_padding _ as pad, _ -> pad in\n\n    (* Check that padty <> Zeros. *)\n    let check_no_0 symb (type a b) (pad : (a, b) padding) : (a,b) padding =\n      match pad with\n      | No_padding -> pad\n      | Lit_padding ((Left | Right), _) -> pad\n      | Arg_padding (Left | Right) -> pad\n      | Lit_padding (Zeros, width) ->\n        if legacy_behavior then Lit_padding (Right, width)\n        else incompatible_flag pct_ind str_ind symb \"0\"\n      | Arg_padding Zeros ->\n        if legacy_behavior then Arg_padding Right\n        else incompatible_flag pct_ind str_ind symb \"0\"\n    in\n\n    (* Get padding as a pad_option (see \"%_\", \"%{\", \"%(\" and \"%[\").\n       (no need for legacy mode tweaking, those were rejected by the\n       legacy parser as well) *)\n    let opt_of_pad c (type a) (type b) (pad : (a, b) padding) = match pad with\n      | No_padding -> None\n      | Lit_padding (Right, width) -> Some width\n      | Lit_padding (Zeros, width) ->\n        if legacy_behavior then Some width\n        else incompatible_flag pct_ind str_ind c \"'0'\"\n      | Lit_padding (Left, width) ->\n        if legacy_behavior then Some width\n        else incompatible_flag pct_ind str_ind c \"'-'\"\n      | Arg_padding _ -> incompatible_flag pct_ind str_ind c \"'*'\"\n    in\n    let get_pad_opt c = opt_of_pad c (get_pad ()) in\n    let get_padprec_opt c = opt_of_pad c (get_padprec ()) in\n\n    (* Get precision as a prec_option (see \"%_f\").\n       (no need for legacy mode tweaking, those were rejected by the\n       legacy parser as well) *)\n    let get_prec_opt () = match get_prec () with\n      | No_precision       -> None\n      | Lit_precision ndec -> Some ndec\n      | Arg_precision      -> incompatible_flag pct_ind str_ind '_' \"'*'\"\n    in\n\n    let fmt_result = match symb with\n    | ',' ->\n      parse str_ind end_ind\n    | 'c' ->\n      let char_format fmt_rest = (* %c *)\n        if get_ign ()\n        then Fmt_EBB (Ignored_param (Ignored_char, fmt_rest))\n        else Fmt_EBB (Char fmt_rest)\n      in\n      let scan_format fmt_rest = (* %0c *)\n        if get_ign ()\n        then Fmt_EBB (Ignored_param (Ignored_scan_next_char, fmt_rest))\n        else Fmt_EBB (Scan_next_char fmt_rest)\n      in\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      begin match get_pad_opt 'c' with\n        | None -> char_format fmt_rest\n        | Some 0 -> scan_format fmt_rest\n        | Some _n ->\n           if not legacy_behavior\n           then invalid_nonnull_char_width str_ind\n           else (* legacy ignores %c widths *) char_format fmt_rest\n      end\n    | 'C' ->\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      if get_ign () then Fmt_EBB (Ignored_param (Ignored_caml_char,fmt_rest))\n      else Fmt_EBB (Caml_char fmt_rest)\n    | 's' ->\n      let pad = check_no_0 symb (get_padprec ()) in\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      if get_ign () then\n        let ignored = Ignored_string (get_padprec_opt '_') in\n        Fmt_EBB (Ignored_param (ignored, fmt_rest))\n      else\n        let Padding_fmt_EBB (pad', fmt_rest') =\n          make_padding_fmt_ebb pad fmt_rest in\n        Fmt_EBB (String (pad', fmt_rest'))\n    | 'S' ->\n      let pad = check_no_0 symb (get_padprec ()) in\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      if get_ign () then\n        let ignored = Ignored_caml_string (get_padprec_opt '_') in\n        Fmt_EBB (Ignored_param (ignored, fmt_rest))\n      else\n        let Padding_fmt_EBB (pad', fmt_rest') =\n          make_padding_fmt_ebb pad fmt_rest in\n        Fmt_EBB (Caml_string (pad', fmt_rest'))\n    | 'd' | 'i' | 'x' | 'X' | 'o' | 'u' ->\n      let iconv = compute_int_conv pct_ind str_ind (get_plus ()) (get_hash ())\n        (get_space ()) symb in\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      if get_ign () then\n        let ignored = Ignored_int (iconv, get_pad_opt '_') in\n        Fmt_EBB (Ignored_param (ignored, fmt_rest))\n      else\n        let Padprec_fmt_EBB (pad', prec', fmt_rest') =\n          make_padprec_fmt_ebb (get_int_pad ()) (get_prec ()) fmt_rest in\n        Fmt_EBB (Int (iconv, pad', prec', fmt_rest'))\n    | 'N' ->\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      let counter = Token_counter in\n      if get_ign () then\n        let ignored = Ignored_scan_get_counter counter in\n        Fmt_EBB (Ignored_param (ignored, fmt_rest))\n      else\n        Fmt_EBB (Scan_get_counter (counter, fmt_rest))\n    | 'l' | 'n' | 'L' when str_ind=end_ind || not (is_int_base str.[str_ind]) ->\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      let counter = counter_of_char symb in\n      if get_ign () then\n        let ignored = Ignored_scan_get_counter counter in\n        Fmt_EBB (Ignored_param (ignored, fmt_rest))\n      else\n        Fmt_EBB (Scan_get_counter (counter, fmt_rest))\n    | 'l' ->\n      let iconv =\n        compute_int_conv pct_ind (str_ind + 1) (get_plus ()) (get_hash ())\n          (get_space ()) str.[str_ind] in\n      let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n      if get_ign () then\n        let ignored = Ignored_int32 (iconv, get_pad_opt '_') in\n        Fmt_EBB (Ignored_param (ignored, fmt_rest))\n      else\n        let Padprec_fmt_EBB (pad', prec', fmt_rest') =\n          make_padprec_fmt_ebb (get_int_pad ()) (get_prec ()) fmt_rest in\n        Fmt_EBB (Int32 (iconv, pad', prec', fmt_rest'))\n    | 'n' ->\n      let iconv =\n        compute_int_conv pct_ind (str_ind + 1) (get_plus ())\n          (get_hash ()) (get_space ()) str.[str_ind] in\n      let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n      if get_ign () then\n        let ignored = Ignored_nativeint (iconv, get_pad_opt '_') in\n        Fmt_EBB (Ignored_param (ignored, fmt_rest))\n      else\n        let Padprec_fmt_EBB (pad', prec', fmt_rest') =\n          make_padprec_fmt_ebb (get_int_pad ()) (get_prec ()) fmt_rest in\n        Fmt_EBB (Nativeint (iconv, pad', prec', fmt_rest'))\n    | 'L' ->\n      let iconv =\n        compute_int_conv pct_ind (str_ind + 1) (get_plus ()) (get_hash ())\n          (get_space ()) str.[str_ind] in\n      let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n      if get_ign () then\n        let ignored = Ignored_int64 (iconv, get_pad_opt '_') in\n        Fmt_EBB (Ignored_param (ignored, fmt_rest))\n      else\n        let Padprec_fmt_EBB (pad', prec', fmt_rest') =\n          make_padprec_fmt_ebb (get_int_pad ()) (get_prec ()) fmt_rest in\n        Fmt_EBB (Int64 (iconv, pad', prec', fmt_rest'))\n    | 'f' | 'e' | 'E' | 'g' | 'G' | 'F' | 'h' | 'H' ->\n      let fconv =\n        compute_float_conv pct_ind str_ind\n          (get_plus ()) (get_hash ()) (get_space ()) symb in\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      if get_ign () then\n        let ignored = Ignored_float (get_pad_opt '_', get_prec_opt ()) in\n        Fmt_EBB (Ignored_param (ignored, fmt_rest))\n      else\n        let Padprec_fmt_EBB (pad', prec', fmt_rest') =\n          make_padprec_fmt_ebb (get_pad ()) (get_prec ()) fmt_rest in\n        Fmt_EBB (Float (fconv, pad', prec', fmt_rest'))\n    | 'b' | 'B' ->\n      let pad = check_no_0 symb (get_padprec ()) in\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      if get_ign () then\n        let ignored = Ignored_bool (get_padprec_opt '_') in\n        Fmt_EBB (Ignored_param (ignored, fmt_rest))\n      else\n        let Padding_fmt_EBB (pad', fmt_rest') =\n          make_padding_fmt_ebb pad fmt_rest in\n        Fmt_EBB (Bool (pad', fmt_rest'))\n    | 'a' ->\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      Fmt_EBB (Alpha fmt_rest)\n    | 't' ->\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      Fmt_EBB (Theta fmt_rest)\n    | 'r' ->\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      if get_ign () then Fmt_EBB (Ignored_param (Ignored_reader, fmt_rest))\n      else Fmt_EBB (Reader fmt_rest)\n    | '!' ->\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      Fmt_EBB (Flush fmt_rest)\n    | ('%' | '@') as c ->\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      Fmt_EBB (Char_literal (c, fmt_rest))\n    | '{' ->\n      let sub_end = search_subformat_end str_ind end_ind '}' in\n      let Fmt_EBB sub_fmt = parse str_ind sub_end in\n      let Fmt_EBB fmt_rest = parse (sub_end + 2) end_ind in\n      let sub_fmtty = fmtty_of_fmt sub_fmt in\n      if get_ign () then\n        let ignored = Ignored_format_arg (get_pad_opt '_', sub_fmtty) in\n        Fmt_EBB (Ignored_param (ignored, fmt_rest))\n      else\n        Fmt_EBB (Format_arg (get_pad_opt '{', sub_fmtty, fmt_rest))\n    | '(' ->\n      let sub_end = search_subformat_end str_ind end_ind ')' in\n      let Fmt_EBB fmt_rest = parse (sub_end + 2) end_ind in\n      let Fmt_EBB sub_fmt = parse str_ind sub_end in\n      let sub_fmtty = fmtty_of_fmt sub_fmt in\n      if get_ign () then\n        let ignored = Ignored_format_subst (get_pad_opt '_', sub_fmtty) in\n        Fmt_EBB (Ignored_param (ignored, fmt_rest))\n      else\n        Fmt_EBB (Format_subst (get_pad_opt '(', sub_fmtty, fmt_rest))\n    | '[' ->\n      let next_ind, char_set = parse_char_set str_ind end_ind in\n      let Fmt_EBB fmt_rest = parse next_ind end_ind in\n      if get_ign () then\n        let ignored = Ignored_scan_char_set (get_pad_opt '_', char_set) in\n        Fmt_EBB (Ignored_param (ignored, fmt_rest))\n      else\n        Fmt_EBB (Scan_char_set (get_pad_opt '[', char_set, fmt_rest))\n    | '-' | '+' | '#' | ' ' | '_' ->\n      failwith_message\n        \"invalid format %S: at character number %d, \\\n         flag %C is only allowed after the '%%', before padding and precision\"\n        str pct_ind symb\n    | _ ->\n      failwith_message\n        \"invalid format %S: at character number %d, \\\n         invalid conversion \\\"%%%c\\\"\" str (str_ind - 1) symb\n    in\n    (* Check for unused options, and reject them as incompatible.\n\n       Such checks need to be disabled in legacy mode, as the legacy\n       parser silently ignored incompatible flags. *)\n    if not legacy_behavior then begin\n    if not !plus_used && plus then\n      incompatible_flag pct_ind str_ind symb \"'+'\";\n    if not !hash_used && hash then\n      incompatible_flag pct_ind str_ind symb \"'#'\";\n    if not !space_used && space then\n      incompatible_flag pct_ind str_ind symb \"' '\";\n    if not !pad_used  && Padding_EBB pad <> Padding_EBB No_padding then\n      incompatible_flag pct_ind str_ind symb \"`padding'\";\n    if not !prec_used && Precision_EBB prec <> Precision_EBB No_precision then\n      incompatible_flag pct_ind str_ind (if ign then '_' else symb)\n        \"`precision'\";\n    if ign && plus then incompatible_flag pct_ind str_ind '_' \"'+'\";\n    end;\n    (* this last test must not be disabled in legacy mode,\n       as ignoring it would typically result in a different typing\n       than what the legacy parser used *)\n    if not !ign_used && ign then\n      begin match symb with\n        (* argument-less formats can safely be ignored in legacy mode *)\n        | ('@' | '%' | '!' | ',') when legacy_behavior -> ()\n        | _ ->\n          incompatible_flag pct_ind str_ind symb \"'_'\"\n      end;\n    fmt_result\n\n  (* Parse formatting information (after '@'). *)\n  and parse_after_at : type e f . int -> int -> (_, _, e, f) fmt_ebb =\n  fun str_ind end_ind ->\n    if str_ind = end_ind then Fmt_EBB (Char_literal ('@', End_of_format))\n    else\n      match str.[str_ind] with\n      | '[' ->\n        parse_tag false (str_ind + 1) end_ind\n      | ']' ->\n        let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n        Fmt_EBB (Formatting_lit (Close_box, fmt_rest))\n      | '{' ->\n        parse_tag true (str_ind + 1) end_ind\n      | '}' ->\n        let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n        Fmt_EBB (Formatting_lit (Close_tag, fmt_rest))\n      | ',' ->\n        let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n        Fmt_EBB (Formatting_lit (Break (\"@,\", 0, 0), fmt_rest))\n      | ' ' ->\n        let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n        Fmt_EBB (Formatting_lit (Break (\"@ \", 1, 0), fmt_rest))\n      | ';' ->\n        parse_good_break (str_ind + 1) end_ind\n      | '?' ->\n        let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n        Fmt_EBB (Formatting_lit (FFlush, fmt_rest))\n      | '\\n' ->\n        let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n        Fmt_EBB (Formatting_lit (Force_newline, fmt_rest))\n      | '.' ->\n        let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n        Fmt_EBB (Formatting_lit (Flush_newline, fmt_rest))\n      | '<' ->\n        parse_magic_size (str_ind + 1) end_ind\n      | '@' ->\n        let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n        Fmt_EBB (Formatting_lit (Escaped_at, fmt_rest))\n      | '%' when str_ind + 1 < end_ind && str.[str_ind + 1] = '%' ->\n        let Fmt_EBB fmt_rest = parse (str_ind + 2) end_ind in\n        Fmt_EBB (Formatting_lit (Escaped_percent, fmt_rest))\n      | '%' ->\n        let Fmt_EBB fmt_rest = parse str_ind end_ind in\n        Fmt_EBB (Char_literal ('@', fmt_rest))\n      | c ->\n        let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n        Fmt_EBB (Formatting_lit (Scan_indic c, fmt_rest))\n\n  (* Try to read the optional <name> after \"@{\" or \"@[\". *)\n  and parse_tag : type e f . bool -> int -> int -> (_, _, e, f) fmt_ebb =\n  fun is_open_tag str_ind end_ind ->\n    try\n      if str_ind = end_ind then raise Not_found;\n      match str.[str_ind] with\n      | '<' ->\n        let ind = String.index_from str (str_ind + 1) '>' in\n        if ind >= end_ind then raise Not_found;\n        let sub_str = String.sub str str_ind (ind - str_ind + 1) in\n        let Fmt_EBB fmt_rest = parse (ind + 1) end_ind in\n        let Fmt_EBB sub_fmt = parse str_ind (ind + 1) in\n        let sub_format = Format (sub_fmt, sub_str) in\n        let formatting =\n          if is_open_tag then Open_tag sub_format else Open_box sub_format in\n        Fmt_EBB (Formatting_gen (formatting, fmt_rest))\n      | _ ->\n        raise Not_found\n    with Not_found ->\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      let sub_format = Format (End_of_format, \"\") in\n      let formatting =\n        if is_open_tag then Open_tag sub_format else Open_box sub_format in\n      Fmt_EBB (Formatting_gen (formatting, fmt_rest))\n\n  (* Try to read the optional <width offset> after \"@;\". *)\n  and parse_good_break : type e f . int -> int -> (_, _, e, f) fmt_ebb =\n  fun str_ind end_ind ->\n    let next_ind, formatting_lit =\n      try\n        if str_ind = end_ind || str.[str_ind] <> '<' then raise Not_found;\n        let str_ind_1 = parse_spaces (str_ind + 1) end_ind in\n        match str.[str_ind_1] with\n        | '0' .. '9' | '-' -> (\n          let str_ind_2, width = parse_integer str_ind_1 end_ind in\n            let str_ind_3 = parse_spaces str_ind_2 end_ind in\n            match str.[str_ind_3] with\n              | '>' ->\n                let s = String.sub str (str_ind-2) (str_ind_3-str_ind+3) in\n                str_ind_3 + 1, Break (s, width, 0)\n              | '0' .. '9' | '-' ->\n                let str_ind_4, offset = parse_integer str_ind_3 end_ind in\n                let str_ind_5 = parse_spaces str_ind_4 end_ind in\n                if str.[str_ind_5] <> '>' then raise Not_found;\n                let s = String.sub str (str_ind-2) (str_ind_5-str_ind+3) in\n                str_ind_5 + 1, Break (s, width, offset)\n              | _ -> raise Not_found\n        )\n        | _ -> raise Not_found\n      with Not_found | Failure _ ->\n        str_ind, Break (\"@;\", 1, 0)\n    in\n    let Fmt_EBB fmt_rest = parse next_ind end_ind in\n    Fmt_EBB (Formatting_lit (formatting_lit, fmt_rest))\n\n  (* Parse the size in a <n>. *)\n  and parse_magic_size : type e f . int -> int -> (_, _, e, f) fmt_ebb =\n  fun str_ind end_ind ->\n    match\n      try\n        let str_ind_1 = parse_spaces str_ind end_ind in\n        match str.[str_ind_1] with\n        | '0' .. '9' | '-' ->\n          let str_ind_2, size = parse_integer str_ind_1 end_ind in\n          let str_ind_3 = parse_spaces str_ind_2 end_ind in\n          if str.[str_ind_3] <> '>' then raise Not_found;\n          let s = String.sub str (str_ind - 2) (str_ind_3 - str_ind + 3) in\n          Some (str_ind_3 + 1, Magic_size (s, size))\n        | _ -> None\n      with Not_found | Failure _ ->\n        None\n    with\n    | Some (next_ind, formatting_lit) ->\n      let Fmt_EBB fmt_rest = parse next_ind end_ind in\n      Fmt_EBB (Formatting_lit (formatting_lit, fmt_rest))\n    | None ->\n      let Fmt_EBB fmt_rest = parse str_ind end_ind in\n      Fmt_EBB (Formatting_lit (Scan_indic '<', fmt_rest))\n\n  (* Parse and construct a char set. *)\n  and parse_char_set str_ind end_ind =\n    if str_ind = end_ind then unexpected_end_of_format end_ind;\n\n    let char_set = create_char_set () in\n    let add_char c =\n      add_in_char_set char_set c;\n    in\n    let add_range c c' =\n      for i = int_of_char c to int_of_char c' do\n        add_in_char_set char_set (char_of_int i);\n      done;\n    in\n\n    let fail_single_percent str_ind =\n      failwith_message\n        \"invalid format %S: '%%' alone is not accepted in character sets, \\\n         use %%%% instead at position %d.\" str str_ind\n    in\n\n    (* Parse the first character of a char set. *)\n    let rec parse_char_set_start str_ind end_ind =\n      if str_ind = end_ind then unexpected_end_of_format end_ind;\n      let c = str.[str_ind] in\n      parse_char_set_after_char (str_ind + 1) end_ind c\n\n    (* Parse the content of a char set until the first ']'. *)\n    and parse_char_set_content str_ind end_ind =\n      if str_ind = end_ind then unexpected_end_of_format end_ind;\n      match str.[str_ind] with\n      | ']' ->\n        str_ind + 1\n      | '-' ->\n        add_char '-';\n        parse_char_set_content (str_ind + 1) end_ind\n      | c ->\n        parse_char_set_after_char (str_ind + 1) end_ind c\n\n    (* Test for range in char set. *)\n    and parse_char_set_after_char str_ind end_ind c =\n      if str_ind = end_ind then unexpected_end_of_format end_ind;\n      match str.[str_ind] with\n      | ']' ->\n        add_char c;\n        str_ind + 1\n      | '-' ->\n        parse_char_set_after_minus (str_ind + 1) end_ind c\n      | ('%' | '@') as c' when c = '%' ->\n        add_char c';\n        parse_char_set_content (str_ind + 1) end_ind\n      | c' ->\n        if c = '%' then fail_single_percent str_ind;\n        (* note that '@' alone is accepted, as done by the legacy\n           implementation; the documentation specifically requires %@\n           so we could warn on that *)\n        add_char c;\n        parse_char_set_after_char (str_ind + 1) end_ind c'\n\n    (* Manage range in char set (except if the '-' the last char before ']') *)\n    and parse_char_set_after_minus str_ind end_ind c =\n      if str_ind = end_ind then unexpected_end_of_format end_ind;\n      match str.[str_ind] with\n      | ']' ->\n        add_char c;\n        add_char '-';\n        str_ind + 1\n      | '%' ->\n        if str_ind + 1 = end_ind then unexpected_end_of_format end_ind;\n        begin match str.[str_ind + 1] with\n          | ('%' | '@') as c' ->\n            add_range c c';\n            parse_char_set_content (str_ind + 2) end_ind\n          | _ -> fail_single_percent str_ind\n        end\n      | c' ->\n        add_range c c';\n        parse_char_set_content (str_ind + 1) end_ind\n    in\n    let str_ind, reverse =\n      if str_ind = end_ind then unexpected_end_of_format end_ind;\n      match str.[str_ind] with\n        | '^' -> str_ind + 1, true\n        | _ -> str_ind, false in\n    let next_ind = parse_char_set_start str_ind end_ind in\n    let char_set = freeze_char_set char_set in\n    next_ind, (if reverse then rev_char_set char_set else char_set)\n\n  (* Consume all next spaces, raise an Failure if end_ind is reached. *)\n  and parse_spaces str_ind end_ind =\n    if str_ind = end_ind then unexpected_end_of_format end_ind;\n    if str.[str_ind] = ' ' then parse_spaces (str_ind + 1) end_ind else str_ind\n\n  (* Read a positive integer from the string, raise a Failure if end_ind is\n     reached. *)\n  and parse_positive str_ind end_ind acc =\n    if str_ind = end_ind then unexpected_end_of_format end_ind;\n    match str.[str_ind] with\n    | '0' .. '9' as c ->\n      let new_acc = acc * 10 + (int_of_char c - int_of_char '0') in\n      if new_acc > Sys.max_string_length then\n        failwith_message\n          \"invalid format %S: integer %d is greater than the limit %d\"\n          str new_acc Sys.max_string_length\n      else\n        parse_positive (str_ind + 1) end_ind new_acc\n    | _ -> str_ind, acc\n\n  (* Read a positive or negative integer from the string, raise a Failure\n     if end_ind is reached. *)\n  and parse_integer str_ind end_ind =\n    if str_ind = end_ind then unexpected_end_of_format end_ind;\n    match str.[str_ind] with\n    | '0' .. '9' -> parse_positive str_ind end_ind 0\n    | '-' -> (\n      if str_ind + 1 = end_ind then unexpected_end_of_format end_ind;\n      match str.[str_ind + 1] with\n      | '0' .. '9' ->\n        let next_ind, n = parse_positive (str_ind + 1) end_ind 0 in\n        next_ind, -n\n      | c ->\n        expected_character (str_ind + 1) \"digit\" c\n    )\n    | _ -> assert false\n\n  (* Add a literal to a format from a literal character sub-sequence. *)\n  and add_literal : type a d e f .\n      int -> int -> (a, _, _, d, e, f) fmt ->\n      (_, _, e, f) fmt_ebb =\n  fun lit_start str_ind fmt -> match str_ind - lit_start with\n    | 0    -> Fmt_EBB fmt\n    | 1    -> Fmt_EBB (Char_literal (str.[lit_start], fmt))\n    | size -> Fmt_EBB (String_literal (String.sub str lit_start size, fmt))\n\n  (* Search the end of the current sub-format\n     (i.e. the corresponding \"%}\" or \"%)\") *)\n  and search_subformat_end str_ind end_ind c =\n    if str_ind = end_ind then\n      failwith_message\n        \"invalid format %S: unclosed sub-format, \\\n         expected \\\"%%%c\\\" at character number %d\" str c end_ind;\n    match str.[str_ind] with\n    | '%' ->\n      if str_ind + 1 = end_ind then unexpected_end_of_format end_ind;\n      if str.[str_ind + 1] = c then (* End of format found *) str_ind else\n        begin match str.[str_ind + 1] with\n        | '_' ->\n          (* Search for \"%_(\" or \"%_{\". *)\n          if str_ind + 2 = end_ind then unexpected_end_of_format end_ind;\n          begin match str.[str_ind + 2] with\n          | '{' ->\n            let sub_end = search_subformat_end (str_ind + 3) end_ind '}' in\n            search_subformat_end (sub_end + 2) end_ind c\n          | '(' ->\n            let sub_end = search_subformat_end (str_ind + 3) end_ind ')' in\n            search_subformat_end (sub_end + 2) end_ind c\n          | _ -> search_subformat_end (str_ind + 3) end_ind c\n          end\n        | '{' ->\n          (* %{...%} sub-format found. *)\n          let sub_end = search_subformat_end (str_ind + 2) end_ind '}' in\n          search_subformat_end (sub_end + 2) end_ind c\n        | '(' ->\n          (* %(...%) sub-format found. *)\n          let sub_end = search_subformat_end (str_ind + 2) end_ind ')' in\n          search_subformat_end (sub_end + 2) end_ind c\n        | '}' ->\n          (* Error: %(...%}. *)\n          expected_character (str_ind + 1) \"character ')'\" '}'\n        | ')' ->\n          (* Error: %{...%). *)\n          expected_character (str_ind + 1) \"character '}'\" ')'\n        | _ ->\n          search_subformat_end (str_ind + 2) end_ind c\n        end\n    | _ -> search_subformat_end (str_ind + 1) end_ind c\n\n  (* Check if symb is a valid int conversion after \"%l\", \"%n\" or \"%L\" *)\n  and is_int_base symb = match symb with\n    | 'd' | 'i' | 'x' | 'X' | 'o' | 'u' -> true\n    | _ -> false\n\n  (* Convert a char (l, n or L) to its associated counter. *)\n  and counter_of_char symb = match symb with\n    | 'l' -> Line_counter  | 'n' -> Char_counter\n    | 'L' -> Token_counter | _ -> assert false\n\n  (* Convert (plus, symb) to its associated int_conv. *)\n  and compute_int_conv pct_ind str_ind plus hash space symb =\n    match plus, hash, space, symb with\n    | false, false, false, 'd' -> Int_d  | false, false, false, 'i' -> Int_i\n    | false, false,  true, 'd' -> Int_sd | false, false,  true, 'i' -> Int_si\n    |  true, false, false, 'd' -> Int_pd |  true, false, false, 'i' -> Int_pi\n    | false, false, false, 'x' -> Int_x  | false, false, false, 'X' -> Int_X\n    | false,  true, false, 'x' -> Int_Cx | false,  true, false, 'X' -> Int_CX\n    | false, false, false, 'o' -> Int_o\n    | false,  true, false, 'o' -> Int_Co\n    | false, false, false, 'u' -> Int_u\n    | false,  true, false, 'd' -> Int_Cd\n    | false,  true, false, 'i' -> Int_Ci\n    | false,  true, false, 'u' -> Int_Cu\n    | _, true, _, 'x' when legacy_behavior -> Int_Cx\n    | _, true, _, 'X' when legacy_behavior -> Int_CX\n    | _, true, _, 'o' when legacy_behavior -> Int_Co\n    | _, true, _, ('d' | 'i' | 'u') ->\n      if legacy_behavior then (* ignore *)\n        compute_int_conv pct_ind str_ind plus false space symb\n      else incompatible_flag pct_ind str_ind symb \"'#'\"\n    | true, _, true, _ ->\n      if legacy_behavior then\n        (* plus and space: legacy implementation prefers plus *)\n        compute_int_conv pct_ind str_ind plus hash false symb\n      else incompatible_flag pct_ind str_ind ' ' \"'+'\"\n    | false, _, true, _    ->\n      if legacy_behavior then (* ignore *)\n        compute_int_conv pct_ind str_ind plus hash false symb\n      else incompatible_flag pct_ind str_ind symb \"' '\"\n    | true, _, false, _    ->\n      if legacy_behavior then (* ignore *)\n        compute_int_conv pct_ind str_ind false hash space symb\n      else incompatible_flag pct_ind str_ind symb \"'+'\"\n    | false, _, false, _ -> assert false\n\n  (* Convert (plus, space, symb) to its associated float_conv. *)\n  and compute_float_conv pct_ind str_ind plus hash space symb =\n    let flag = match plus, space with\n    | false, false -> Float_flag_\n    | false,  true -> Float_flag_s\n    |  true, false -> Float_flag_p\n    |  true,  true ->\n      (* plus and space: legacy implementation prefers plus *)\n      if legacy_behavior then Float_flag_p\n      else incompatible_flag pct_ind str_ind ' ' \"'+'\" in\n    let kind = match hash, symb with\n    | _, 'f' -> Float_f\n    | _, 'e' -> Float_e\n    | _, 'E' -> Float_E\n    | _, 'g' -> Float_g\n    | _, 'G' -> Float_G\n    | _, 'h' -> Float_h\n    | _, 'H' -> Float_H\n    | false, 'F' -> Float_F\n    | true, 'F' -> Float_CF\n    | _ -> assert false in\n    flag, kind\n\n  (* Raise [Failure] with a friendly error message about incompatible options.*)\n  and incompatible_flag : type a . int -> int -> char -> string -> a =\n    fun pct_ind str_ind symb option ->\n      let subfmt = String.sub str pct_ind (str_ind - pct_ind) in\n      failwith_message\n        \"invalid format %S: at character number %d, \\\n         %s is incompatible with '%c' in sub-format %S\"\n        str pct_ind option symb subfmt\n\n  in parse 0 (String.length str)\n\n(******************************************************************************)\n                  (* Guarded string to format conversions *)\n\n(* Convert a string to a format according to an fmtty. *)\n(* Raise [Failure] with an error message in case of type mismatch. *)\nlet format_of_string_fmtty str fmtty =\n  let Fmt_EBB fmt = fmt_ebb_of_string str in\n  try Format (type_format fmt fmtty, str)\n  with Type_mismatch ->\n    failwith_message\n      \"bad input: format type mismatch between %S and %S\"\n      str (string_of_fmtty fmtty)\n\n(* Convert a string to a format compatible with an other format. *)\n(* Raise [Failure] with an error message in case of type mismatch. *)\nlet format_of_string_format str (Format (fmt', str')) =\n  let Fmt_EBB fmt = fmt_ebb_of_string str in\n  try Format (type_format fmt (fmtty_of_fmt fmt'), str)\n  with Type_mismatch ->\n    failwith_message\n      \"bad input: format type mismatch between %S and %S\" str str'\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*   Xavier Leroy and Pierre Weis, projet Cristal, INRIA Rocquencourt     *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\nopen CamlinternalFormatBasics\nopen CamlinternalFormat\n\nlet kfprintf k o (Format (fmt, _)) =\n  make_printf (fun acc -> output_acc o acc; k o) End_of_acc fmt\nlet kbprintf k b (Format (fmt, _)) =\n  make_printf (fun acc -> bufput_acc b acc; k b) End_of_acc fmt\nlet ikfprintf k oc (Format (fmt, _)) =\n  make_iprintf k oc fmt\nlet ikbprintf = ikfprintf\n\nlet fprintf oc fmt = kfprintf ignore oc fmt\nlet bprintf b fmt = kbprintf ignore b fmt\nlet ifprintf oc fmt = ikfprintf ignore oc fmt\nlet ibprintf b fmt = ikbprintf ignore b fmt\nlet printf fmt = fprintf stdout fmt\nlet eprintf fmt = fprintf stderr fmt\n\nlet ksprintf k (Format (fmt, _)) =\n  let k' acc =\n    let buf = Buffer.create 64 in\n    strput_acc buf acc;\n    k (Buffer.contents buf) in\n  make_printf k' End_of_acc fmt\n\nlet sprintf fmt = ksprintf (fun s -> s) fmt\n\nlet kprintf = ksprintf\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*              Damien Doligez, projet Para, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\ntype key = string\ntype doc = string\ntype usage_msg = string\ntype anon_fun = (string -> unit)\n\ntype spec =\n  | Unit of (unit -> unit)     (* Call the function with unit argument *)\n  | Bool of (bool -> unit)     (* Call the function with a bool argument *)\n  | Set of bool ref            (* Set the reference to true *)\n  | Clear of bool ref          (* Set the reference to false *)\n  | String of (string -> unit) (* Call the function with a string argument *)\n  | Set_string of string ref   (* Set the reference to the string argument *)\n  | Int of (int -> unit)       (* Call the function with an int argument *)\n  | Set_int of int ref         (* Set the reference to the int argument *)\n  | Float of (float -> unit)   (* Call the function with a float argument *)\n  | Set_float of float ref     (* Set the reference to the float argument *)\n  | Tuple of spec list         (* Take several arguments according to the\n                                  spec list *)\n  | Symbol of string list * (string -> unit)\n                               (* Take one of the symbols as argument and\n                                  call the function with the symbol. *)\n  | Rest of (string -> unit)   (* Stop interpreting keywords and call the\n                                  function with each remaining argument *)\n  | Rest_all of (string list -> unit)\n                               (* Stop interpreting keywords and call the\n                                  function with all remaining arguments. *)\n  | Expand of (string -> string array) (* If the remaining arguments to process\n                                          are of the form\n                                          [[\"-foo\"; \"arg\"] @ rest] where \"foo\"\n                                          is registered as [Expand f], then the\n                                          arguments [f \"arg\" @ rest] are\n                                          processed. Only allowed in\n                                          [parse_and_expand_argv_dynamic]. *)\n\nexception Bad of string\nexception Help of string\n\ntype error =\n  | Unknown of string\n  | Wrong of string * string * string  (* option, actual, expected *)\n  | Missing of string\n  | Message of string\n\nexception Stop of error (* used internally *)\n\nopen Printf\n\nlet rec assoc3 x l =\n  match l with\n  | [] -> raise Not_found\n  | (y1, y2, _) :: _ when y1 = x -> y2\n  | _ :: t -> assoc3 x t\n\n\nlet split s =\n  let i = String.index s '=' in\n  let len = String.length s in\n  String.sub s 0 i, String.sub s (i+1) (len-(i+1))\n\n\nlet make_symlist prefix sep suffix l =\n  match l with\n  | [] -> \"<none>\"\n  | h::t -> (List.fold_left (fun x y -> x ^ sep ^ y) (prefix ^ h) t) ^ suffix\n\n\nlet print_spec buf (key, spec, doc) =\n  if String.length doc > 0 then\n    match spec with\n    | Symbol (l, _) ->\n        bprintf buf \"  %s %s%s\\n\" key (make_symlist \"{\" \"|\" \"}\" l) doc\n    | _ ->\n        bprintf buf \"  %s %s\\n\" key doc\n\n\nlet help_action () = raise (Stop (Unknown \"-help\"))\n\nlet add_help speclist =\n  let add1 =\n    try ignore (assoc3 \"-help\" speclist); []\n    with Not_found ->\n            [\"-help\", Unit help_action, \" Display this list of options\"]\n  and add2 =\n    try ignore (assoc3 \"--help\" speclist); []\n    with Not_found ->\n            [\"--help\", Unit help_action, \" Display this list of options\"]\n  in\n  speclist @ (add1 @ add2)\n\n\nlet usage_b buf speclist errmsg =\n  bprintf buf \"%s\\n\" errmsg;\n  List.iter (print_spec buf) (add_help speclist)\n\n\nlet usage_string speclist errmsg =\n  let b = Buffer.create 200 in\n  usage_b b speclist errmsg;\n  Buffer.contents b\n\n\nlet usage speclist errmsg =\n  eprintf \"%s\" (usage_string speclist errmsg)\n\n\nlet current = ref 0\n\nlet bool_of_string_opt x =\n  try Some (bool_of_string x)\n  with Invalid_argument _ -> None\n\nlet int_of_string_opt x =\n  try Some (int_of_string x)\n  with Failure _ -> None\n\nlet float_of_string_opt x =\n  try Some (float_of_string x)\n  with Failure _ -> None\n\nlet parse_and_expand_argv_dynamic_aux allow_expand current argv speclist anonfun\n                                      errmsg =\n  let initpos = !current in\n  let convert_error error =\n    (* convert an internal error to a Bad/Help exception\n       *or* add the program name as a prefix and the usage message as a suffix\n       to an user-raised Bad exception.\n    *)\n    let b = Buffer.create 200 in\n    let progname =\n      if initpos < (Array.length !argv) then !argv.(initpos) else \"(?)\" in\n    begin match error with\n      | Unknown \"-help\" -> ()\n      | Unknown \"--help\" -> ()\n      | Unknown s ->\n          bprintf b \"%s: unknown option '%s'.\\n\" progname s\n      | Missing s ->\n          bprintf b \"%s: option '%s' needs an argument.\\n\" progname s\n      | Wrong (opt, arg, expected) ->\n          bprintf b \"%s: wrong argument '%s'; option '%s' expects %s.\\n\"\n                  progname arg opt expected\n      | Message s -> (* user error message *)\n          bprintf b \"%s: %s.\\n\" progname s\n    end;\n    usage_b b !speclist errmsg;\n    if error = Unknown \"-help\" || error = Unknown \"--help\"\n    then Help (Buffer.contents b)\n    else Bad (Buffer.contents b)\n  in\n  incr current;\n  while !current < (Array.length !argv) do\n    begin try\n      let s = !argv.(!current) in\n      if String.length s >= 1 && s.[0] = '-' then begin\n        let action, follow =\n          try assoc3 s !speclist, None\n          with Not_found ->\n          try\n            let keyword, arg = split s in\n            assoc3 keyword !speclist, Some arg\n          with Not_found -> raise (Stop (Unknown s))\n        in\n        let no_arg () =\n          match follow with\n          | None -> ()\n          | Some arg -> raise (Stop (Wrong (s, arg, \"no argument\"))) in\n        let get_arg () =\n          match follow with\n          | None ->\n              if !current + 1 < (Array.length !argv) then !argv.(!current + 1)\n              else raise (Stop (Missing s))\n          | Some arg -> arg\n        in\n        let consume_arg () =\n          match follow with\n          | None -> incr current\n          | Some _ -> ()\n        in\n        let rec treat_action = function\n        | Unit f -> no_arg (); f ();\n        | Bool f ->\n            let arg = get_arg () in\n            begin match bool_of_string_opt arg with\n            | None -> raise (Stop (Wrong (s, arg, \"a boolean\")))\n            | Some s -> f s\n            end;\n            consume_arg ();\n        | Set r -> no_arg (); r := true;\n        | Clear r -> no_arg (); r := false;\n        | String f ->\n            let arg = get_arg () in\n            f arg;\n            consume_arg ();\n        | Symbol (symb, f) ->\n            let arg = get_arg () in\n            if List.mem arg symb then begin\n              f arg;\n              consume_arg ();\n            end else begin\n              raise (Stop (Wrong (s, arg, \"one of: \"\n                                          ^ (make_symlist \"\" \" \" \"\" symb))))\n            end\n        | Set_string r ->\n            r := get_arg ();\n            consume_arg ();\n        | Int f ->\n            let arg = get_arg () in\n            begin match int_of_string_opt arg with\n            | None -> raise (Stop (Wrong (s, arg, \"an integer\")))\n            | Some x -> f x\n            end;\n            consume_arg ();\n        | Set_int r ->\n            let arg = get_arg () in\n            begin match int_of_string_opt arg with\n            | None -> raise (Stop (Wrong (s, arg, \"an integer\")))\n            | Some x -> r := x\n            end;\n            consume_arg ();\n        | Float f ->\n            let arg = get_arg () in\n            begin match float_of_string_opt arg with\n            | None -> raise (Stop (Wrong (s, arg, \"a float\")))\n            | Some x -> f x\n            end;\n            consume_arg ();\n        | Set_float r ->\n            let arg = get_arg () in\n            begin match float_of_string_opt arg with\n            | None -> raise (Stop (Wrong (s, arg, \"a float\")))\n            | Some x -> r := x\n            end;\n            consume_arg ();\n        | Tuple specs ->\n            no_arg ();\n            List.iter treat_action specs;\n        | Rest f ->\n            no_arg ();\n            while !current < (Array.length !argv) - 1 do\n              f !argv.(!current + 1);\n              consume_arg ();\n            done;\n        | Rest_all f ->\n            no_arg ();\n            let acc = ref [] in\n            while !current < Array.length !argv - 1 do\n              acc := !argv.(!current + 1) :: !acc;\n              consume_arg ();\n            done;\n            f (List.rev !acc)\n        | Expand f ->\n            if not allow_expand then\n              raise (Invalid_argument \"Arg.Expand is is only allowed with \\\n                                       Arg.parse_and_expand_argv_dynamic\");\n            let arg = get_arg () in\n            let newarg = f arg in\n            consume_arg ();\n            let before = Array.sub !argv 0 (!current + 1)\n            and after =\n              Array.sub !argv (!current + 1)\n                        ((Array.length !argv) - !current - 1) in\n            argv:= Array.concat [before;newarg;after];\n        in\n        treat_action action end\n      else anonfun s\n    with | Bad m -> raise (convert_error (Message m));\n         | Stop e -> raise (convert_error e);\n    end;\n    incr current\n  done\n\nlet parse_and_expand_argv_dynamic current argv speclist anonfun errmsg =\n  parse_and_expand_argv_dynamic_aux true current argv speclist anonfun errmsg\n\nlet parse_argv_dynamic ?(current=current) argv speclist anonfun errmsg =\n  parse_and_expand_argv_dynamic_aux false current (ref argv) speclist anonfun\n    errmsg\n\n\nlet parse_argv ?(current=current) argv speclist anonfun errmsg =\n  parse_argv_dynamic ~current:current argv (ref speclist) anonfun errmsg\n\n\nlet parse l f msg =\n  try\n    parse_argv Sys.argv l f msg\n  with\n  | Bad msg -> eprintf \"%s\" msg; exit 2\n  | Help msg -> printf \"%s\" msg; exit 0\n\n\nlet parse_dynamic l f msg =\n  try\n    parse_argv_dynamic Sys.argv l f msg\n  with\n  | Bad msg -> eprintf \"%s\" msg; exit 2\n  | Help msg -> printf \"%s\" msg; exit 0\n\nlet parse_expand l f msg =\n  try\n    let argv = ref Sys.argv in\n    let spec = ref l in\n    let current = ref (!current) in\n    parse_and_expand_argv_dynamic current argv spec f msg\n  with\n  | Bad msg -> eprintf \"%s\" msg; exit 2\n  | Help msg -> printf \"%s\" msg; exit 0\n\n\nlet second_word s =\n  let len = String.length s in\n  let rec loop n =\n    if n >= len then len\n    else if s.[n] = ' ' then loop (n+1)\n    else n\n  in\n  match String.index s '\\t' with\n  | n -> loop (n+1)\n  | exception Not_found ->\n      begin match String.index s ' ' with\n      | n -> loop (n+1)\n      | exception Not_found -> len\n      end\n\n\nlet max_arg_len cur (kwd, spec, doc) =\n  match spec with\n  | Symbol _ -> Int.max cur (String.length kwd)\n  | _ -> Int.max cur (String.length kwd + second_word doc)\n\n\nlet replace_leading_tab s =\n  let seen = ref false in\n  String.map (function '\\t' when not !seen -> seen := true; ' ' | c -> c) s\n\nlet add_padding len ksd =\n  match ksd with\n  | (_, _, \"\") ->\n      (* Do not pad undocumented options, so that they still don't show up when\n       * run through [usage] or [parse]. *)\n      ksd\n  | (kwd, (Symbol _ as spec), msg) ->\n      let cutcol = second_word msg in\n      let spaces = String.make ((Int.max 0 (len - cutcol)) + 3) ' ' in\n      (kwd, spec, \"\\n\" ^ spaces ^ replace_leading_tab msg)\n  | (kwd, spec, msg) ->\n      let cutcol = second_word msg in\n      let kwd_len = String.length kwd in\n      let diff = len - kwd_len - cutcol in\n      if diff <= 0 then\n        (kwd, spec, replace_leading_tab msg)\n      else\n        let spaces = String.make diff ' ' in\n        let prefix = String.sub (replace_leading_tab msg) 0 cutcol in\n        let suffix = String.sub msg cutcol (String.length msg - cutcol) in\n        (kwd, spec, prefix ^ spaces ^ suffix)\n\n\nlet align ?(limit=max_int) speclist =\n  let completed = add_help speclist in\n  let len = List.fold_left max_arg_len 0 completed in\n  let len = Int.min len limit in\n  List.map (add_padding len) completed\n\nlet trim_cr s =\n  let len = String.length s in\n  if len > 0 && String.get s (len - 1) = '\\r' then\n    String.sub s 0 (len - 1)\n  else\n    s\n\nlet read_aux trim sep file =\n  let ic = open_in_bin file in\n  let buf = Buffer.create 200 in\n  let words = ref [] in\n  let stash () =\n    let word = Buffer.contents buf in\n    let word = if trim then trim_cr word else word in\n    words := word :: !words;\n    Buffer.clear buf\n  in\n  begin\n    try while true do\n        let c = input_char ic in\n        if c = sep then stash () else Buffer.add_char buf c\n      done\n    with End_of_file -> ()\n  end;\n  if Buffer.length buf > 0 then stash ();\n  close_in ic;\n  Array.of_list (List.rev !words)\n\nlet read_arg = read_aux true '\\n'\n\nlet read_arg0 = read_aux false '\\x00'\n\nlet write_aux sep file args =\n  let oc = open_out_bin file in\n  Array.iter (fun s -> fprintf oc \"%s%c\" s sep) args;\n  close_out oc\n\nlet write_arg = write_aux '\\n'\n\nlet write_arg0 = write_aux '\\x00'\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\nopen Printf\n\ntype t = exn = ..\n\nlet printers = Atomic.make []\n\nlet locfmt = format_of_string \"File \\\"%s\\\", line %d, characters %d-%d: %s\"\n\nlet field x i =\n  let f = Obj.field x i in\n  if not (Obj.is_block f) then\n    sprintf \"%d\" (Obj.magic f : int)           (* can also be a char *)\n  else if Obj.tag f = Obj.string_tag then\n    sprintf \"%S\" (Obj.magic f : string)\n  else if Obj.tag f = Obj.double_tag then\n    string_of_float (Obj.magic f : float)\n  else\n    \"_\"\n\nlet rec other_fields x i =\n  if i >= Obj.size x then \"\"\n  else sprintf \", %s%s\" (field x i) (other_fields x (i+1))\n\nlet fields x =\n  match Obj.size x with\n  | 0 -> \"\"\n  | 1 -> \"\"\n  | 2 -> sprintf \"(%s)\" (field x 1)\n  | _ -> sprintf \"(%s%s)\" (field x 1) (other_fields x 2)\n\nlet use_printers x =\n  let rec conv = function\n    | hd :: tl ->\n        (match hd x with\n         | None | exception _ -> conv tl\n         | Some s -> Some s)\n    | [] -> None in\n  conv (Atomic.get printers)\n\nlet to_string_default = function\n  | Out_of_memory -> \"Out of memory\"\n  | Stack_overflow -> \"Stack overflow\"\n  | Match_failure(file, line, char) ->\n      sprintf locfmt file line char (char+5) \"Pattern matching failed\"\n  | Assert_failure(file, line, char) ->\n      sprintf locfmt file line char (char+6) \"Assertion failed\"\n  | Undefined_recursive_module(file, line, char) ->\n      sprintf locfmt file line char (char+6) \"Undefined recursive module\"\n  | x ->\n      let x = Obj.repr x in\n      if Obj.tag x <> 0 then\n        (Obj.magic (Obj.field x 0) : string)\n      else\n        let constructor =\n          (Obj.magic (Obj.field (Obj.field x 0) 0) : string) in\n        constructor ^ (fields x)\n\nlet to_string e =\n  match use_printers e with\n  | Some s -> s\n  | None -> to_string_default e\n\nlet print fct arg =\n  try\n    fct arg\n  with x ->\n    eprintf \"Uncaught exception: %s\\n\" (to_string x);\n    flush stderr;\n    raise x\n\nlet catch fct arg =\n  try\n    fct arg\n  with x ->\n    flush stdout;\n    eprintf \"Uncaught exception: %s\\n\" (to_string x);\n    exit 2\n\ntype raw_backtrace_slot\ntype raw_backtrace_entry = private int\ntype raw_backtrace = raw_backtrace_entry array\n\nlet raw_backtrace_entries bt = bt\n\nexternal get_raw_backtrace:\n  unit -> raw_backtrace = \"caml_get_exception_raw_backtrace\"\n\nexternal raise_with_backtrace: exn -> raw_backtrace -> 'a\n  = \"%raise_with_backtrace\"\n\ntype backtrace_slot =\n  | Known_location of {\n      is_raise    : bool;\n      filename    : string;\n      line_number : int;\n      start_char  : int;\n      end_char    : int;\n      is_inline   : bool;\n      defname     : string;\n    }\n  | Unknown_location of {\n      is_raise : bool\n    }\n\n(* to avoid warning *)\nlet _ = [Known_location { is_raise = false; filename = \"\";\n                          line_number = 0; start_char = 0; end_char = 0;\n                          is_inline = false; defname = \"\" };\n         Unknown_location { is_raise = false }]\n\nexternal convert_raw_backtrace_slot:\n  raw_backtrace_slot -> backtrace_slot = \"caml_convert_raw_backtrace_slot\"\n\nexternal convert_raw_backtrace:\n  raw_backtrace -> backtrace_slot array = \"caml_convert_raw_backtrace\"\n\nlet convert_raw_backtrace bt =\n  try Some (convert_raw_backtrace bt)\n  with Failure _ -> None\n\nlet format_backtrace_slot pos slot =\n  let info is_raise =\n    if is_raise then\n      if pos = 0 then \"Raised at\" else \"Re-raised at\"\n    else\n      if pos = 0 then \"Raised by primitive operation at\" else \"Called from\"\n  in\n  match slot with\n  | Unknown_location l ->\n      if l.is_raise then\n        (* compiler-inserted re-raise, skipped *) None\n      else\n        Some (sprintf \"%s unknown location\" (info false))\n  | Known_location l ->\n      Some (sprintf \"%s %s in file \\\"%s\\\"%s, line %d, characters %d-%d\"\n              (info l.is_raise) l.defname l.filename\n              (if l.is_inline then \" (inlined)\" else \"\")\n              l.line_number l.start_char l.end_char)\n\nlet print_exception_backtrace outchan backtrace =\n  match backtrace with\n  | None ->\n      fprintf outchan\n        \"(Program not linked with -g, cannot print stack backtrace)\\n\"\n  | Some a ->\n      for i = 0 to Array.length a - 1 do\n        match format_backtrace_slot i a.(i) with\n          | None -> ()\n          | Some str -> fprintf outchan \"%s\\n\" str\n      done\n\nlet print_raw_backtrace outchan raw_backtrace =\n  print_exception_backtrace outchan (convert_raw_backtrace raw_backtrace)\n\n(* confusingly named: prints the global current backtrace *)\nlet print_backtrace outchan =\n  print_raw_backtrace outchan (get_raw_backtrace ())\n\nlet backtrace_to_string backtrace =\n  match backtrace with\n  | None ->\n     \"(Program not linked with -g, cannot print stack backtrace)\\n\"\n  | Some a ->\n      let b = Buffer.create 1024 in\n      for i = 0 to Array.length a - 1 do\n        match format_backtrace_slot i a.(i) with\n          | None -> ()\n          | Some str -> bprintf b \"%s\\n\" str\n      done;\n      Buffer.contents b\n\nlet raw_backtrace_to_string raw_backtrace =\n  backtrace_to_string (convert_raw_backtrace raw_backtrace)\n\nlet backtrace_slot_is_raise = function\n  | Known_location l -> l.is_raise\n  | Unknown_location l -> l.is_raise\n\nlet backtrace_slot_is_inline = function\n  | Known_location l -> l.is_inline\n  | Unknown_location _ -> false\n\ntype location = {\n  filename : string;\n  line_number : int;\n  start_char : int;\n  end_char : int;\n}\n\nlet backtrace_slot_location = function\n  | Unknown_location _ -> None\n  | Known_location l ->\n    Some {\n      filename    = l.filename;\n      line_number = l.line_number;\n      start_char  = l.start_char;\n      end_char    = l.end_char;\n    }\n\nlet backtrace_slot_defname = function\n  | Unknown_location _\n  | Known_location { defname = \"\" } -> None\n  | Known_location l -> Some l.defname\n\nlet backtrace_slots raw_backtrace =\n  (* The documentation of this function guarantees that Some is\n     returned only if a part of the trace is usable. This gives us\n     a bit more work than just convert_raw_backtrace, but it makes the\n     API more user-friendly -- otherwise most users would have to\n     reimplement the \"Program not linked with -g, sorry\" logic\n     themselves. *)\n  match convert_raw_backtrace raw_backtrace with\n    | None -> None\n    | Some backtrace ->\n      let usable_slot = function\n        | Unknown_location _ -> false\n        | Known_location _ -> true in\n      let rec exists_usable = function\n        | (-1) -> false\n        | i -> usable_slot backtrace.(i) || exists_usable (i - 1) in\n      if exists_usable (Array.length backtrace - 1)\n      then Some backtrace\n      else None\n\nlet backtrace_slots_of_raw_entry entry =\n  backtrace_slots [| entry |]\n\nmodule Slot = struct\n  type t = backtrace_slot\n  let format = format_backtrace_slot\n  let is_raise = backtrace_slot_is_raise\n  let is_inline = backtrace_slot_is_inline\n  let location = backtrace_slot_location\n  let name = backtrace_slot_defname\nend\n\nlet raw_backtrace_length bt = Array.length bt\n\nexternal get_raw_backtrace_slot :\n  raw_backtrace -> int -> raw_backtrace_slot = \"caml_raw_backtrace_slot\"\n\nexternal get_raw_backtrace_next_slot :\n  raw_backtrace_slot -> raw_backtrace_slot option\n  = \"caml_raw_backtrace_next_slot\"\n\n(* confusingly named:\n   returns the *string* corresponding to the global current backtrace *)\nlet get_backtrace () = raw_backtrace_to_string (get_raw_backtrace ())\n\nexternal record_backtrace: bool -> unit = \"caml_record_backtrace\"\nexternal backtrace_status: unit -> bool = \"caml_backtrace_status\"\n\nlet rec register_printer fn =\n  let old_printers = Atomic.get printers in\n  let new_printers = fn :: old_printers in\n  let success = Atomic.compare_and_set printers old_printers new_printers in\n  if not success then register_printer fn\n\nexternal get_callstack: int -> raw_backtrace = \"caml_get_current_callstack\"\n\nlet exn_slot x =\n  let x = Obj.repr x in\n  if Obj.tag x = 0 then Obj.field x 0 else x\n\nlet exn_slot_id x =\n  let slot = exn_slot x in\n  (Obj.obj (Obj.field slot 1) : int)\n\nlet exn_slot_name x =\n  let slot = exn_slot x in\n  (Obj.obj (Obj.field slot 0) : string)\n\nexternal get_debug_info_status : unit -> int = \"caml_ml_debug_info_status\"\n\n(* Descriptions for errors in startup.h. See also backtrace.c *)\nlet errors = [| \"\";\n  (* FILE_NOT_FOUND *)\n  \"(Cannot print locations:\\n \\\n      bytecode executable program file not found)\";\n  (* BAD_BYTECODE *)\n  \"(Cannot print locations:\\n \\\n      bytecode executable program file appears to be corrupt)\";\n  (* WRONG_MAGIC *)\n  \"(Cannot print locations:\\n \\\n      bytecode executable program file has wrong magic number)\";\n  (* NO_FDS *)\n  \"(Cannot print locations:\\n \\\n      bytecode executable program file cannot be opened;\\n \\\n      -- too many open files. Try running with OCAMLRUNPARAM=b=2)\"\n|]\n\nlet default_uncaught_exception_handler exn raw_backtrace =\n  eprintf \"Fatal error: exception %s\\n\" (to_string exn);\n  print_raw_backtrace stderr raw_backtrace;\n  let status = get_debug_info_status () in\n  if status < 0 then\n    prerr_endline errors.(abs status);\n  flush stderr\n\nlet uncaught_exception_handler = ref default_uncaught_exception_handler\n\nlet set_uncaught_exception_handler fn = uncaught_exception_handler := fn\n\nlet empty_backtrace : raw_backtrace = [| |]\n\nlet try_get_raw_backtrace () =\n  try\n    get_raw_backtrace ()\n  with _ (* Out_of_memory? *) ->\n    empty_backtrace\n\nlet handle_uncaught_exception' exn debugger_in_use =\n  try\n    (* Get the backtrace now, in case one of the [at_exit] function\n       destroys it. *)\n    let raw_backtrace =\n      if debugger_in_use (* Same test as in [runtime/printexc.c] *) then\n        empty_backtrace\n      else\n        try_get_raw_backtrace ()\n    in\n    (try Stdlib.do_at_exit () with _ -> ());\n    try\n      !uncaught_exception_handler exn raw_backtrace\n    with exn' ->\n      let raw_backtrace' = try_get_raw_backtrace () in\n      eprintf \"Fatal error: exception %s\\n\" (to_string exn);\n      print_raw_backtrace stderr raw_backtrace;\n      eprintf \"Fatal error in uncaught exception handler: exception %s\\n\"\n        (to_string exn');\n      print_raw_backtrace stderr raw_backtrace';\n      flush stderr\n  with\n    | Out_of_memory ->\n        prerr_endline\n          \"Fatal error: out of memory in uncaught exception handler\"\n\n(* This function is called by [caml_fatal_uncaught_exception] in\n   [runtime/printexc.c] which expects no exception is raised. *)\nlet handle_uncaught_exception exn debugger_in_use =\n  try\n    handle_uncaught_exception' exn debugger_in_use\n  with _ ->\n    (* There is not much we can do at this point *)\n    ()\n\nexternal register_named_value : string -> 'a -> unit\n  = \"caml_register_named_value\"\n\nlet () =\n  register_named_value \"Printexc.handle_uncaught_exception\"\n    handle_uncaught_exception\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*                         The OCaml programmers                          *)\n(*                                                                        *)\n(*   Copyright 2018 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\nexternal id : 'a -> 'a = \"%identity\"\nlet const c _ = c\nlet flip f x y = f y x\nlet negate p v = not (p v)\n\nexception Finally_raised of exn\n\nlet () = Printexc.register_printer @@ function\n| Finally_raised exn -> Some (\"Fun.Finally_raised: \" ^ Printexc.to_string exn)\n| _ -> None\n\nlet protect ~(finally : unit -> unit) work =\n  let finally_no_exn () =\n    try finally () with e ->\n      let bt = Printexc.get_raw_backtrace () in\n      Printexc.raise_with_backtrace (Finally_raised e) bt\n  in\n  match work () with\n  | result -> finally_no_exn () ; result\n  | exception work_exn ->\n      let work_bt = Printexc.get_raw_backtrace () in\n      finally_no_exn () ;\n      Printexc.raise_with_backtrace work_exn work_bt\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*            Damien Doligez, projet Para, INRIA Rocquencourt             *)\n(*            Jacques-Henri Jourdan, projet Gallium, INRIA Paris          *)\n(*                                                                        *)\n(*   Copyright 1996-2016 Institut National de Recherche en Informatique   *)\n(*     et en Automatique.                                                 *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\ntype stat = {\n  minor_words : float;\n  promoted_words : float;\n  major_words : float;\n  minor_collections : int;\n  major_collections : int;\n  heap_words : int;\n  heap_chunks : int;\n  live_words : int;\n  live_blocks : int;\n  free_words : int;\n  free_blocks : int;\n  largest_free : int;\n  fragments : int;\n  compactions : int;\n  top_heap_words : int;\n  stack_size : int;\n  forced_major_collections: int;\n}\n\ntype control = {\n  mutable minor_heap_size : int;\n  mutable major_heap_increment : int;\n  mutable space_overhead : int;\n  mutable verbose : int;\n  mutable max_overhead : int;\n  mutable stack_limit : int;\n  mutable allocation_policy : int;\n  window_size : int;\n  custom_major_ratio : int;\n  custom_minor_ratio : int;\n  custom_minor_max_size : int;\n}\n\nexternal stat : unit -> stat = \"caml_gc_stat\"\nexternal quick_stat : unit -> stat = \"caml_gc_quick_stat\"\nexternal counters : unit -> (float * float * float) = \"caml_gc_counters\"\nexternal minor_words : unit -> (float [@unboxed])\n  = \"caml_gc_minor_words\" \"caml_gc_minor_words_unboxed\"\nexternal get : unit -> control = \"caml_gc_get\"\nexternal set : control -> unit = \"caml_gc_set\"\nexternal minor : unit -> unit = \"caml_gc_minor\"\nexternal major_slice : int -> int = \"caml_gc_major_slice\"\nexternal major : unit -> unit = \"caml_gc_major\"\nexternal full_major : unit -> unit = \"caml_gc_full_major\"\nexternal compact : unit -> unit = \"caml_gc_compaction\"\nexternal get_minor_free : unit -> int = \"caml_get_minor_free\"\nexternal get_bucket : int -> int = \"caml_get_major_bucket\" [@@noalloc]\nexternal get_credit : unit -> int = \"caml_get_major_credit\" [@@noalloc]\nexternal huge_fallback_count : unit -> int = \"caml_gc_huge_fallback_count\"\nexternal eventlog_pause : unit -> unit = \"caml_eventlog_pause\"\nexternal eventlog_resume : unit -> unit = \"caml_eventlog_resume\"\n\nopen Printf\n\nlet print_stat c =\n  let st = stat () in\n  fprintf c \"minor_collections:      %d\\n\" st.minor_collections;\n  fprintf c \"major_collections:      %d\\n\" st.major_collections;\n  fprintf c \"compactions:            %d\\n\" st.compactions;\n  fprintf c \"forced_major_collections: %d\\n\" st.forced_major_collections;\n  fprintf c \"\\n\";\n  let l1 = String.length (sprintf \"%.0f\" st.minor_words) in\n  fprintf c \"minor_words:    %*.0f\\n\" l1 st.minor_words;\n  fprintf c \"promoted_words: %*.0f\\n\" l1 st.promoted_words;\n  fprintf c \"major_words:    %*.0f\\n\" l1 st.major_words;\n  fprintf c \"\\n\";\n  let l2 = String.length (sprintf \"%d\" st.top_heap_words) in\n  fprintf c \"top_heap_words: %*d\\n\" l2 st.top_heap_words;\n  fprintf c \"heap_words:     %*d\\n\" l2 st.heap_words;\n  fprintf c \"live_words:     %*d\\n\" l2 st.live_words;\n  fprintf c \"free_words:     %*d\\n\" l2 st.free_words;\n  fprintf c \"largest_free:   %*d\\n\" l2 st.largest_free;\n  fprintf c \"fragments:      %*d\\n\" l2 st.fragments;\n  fprintf c \"\\n\";\n  fprintf c \"live_blocks: %d\\n\" st.live_blocks;\n  fprintf c \"free_blocks: %d\\n\" st.free_blocks;\n  fprintf c \"heap_chunks: %d\\n\" st.heap_chunks\n\n\nlet allocated_bytes () =\n  let (mi, pro, ma) = counters () in\n  (mi +. ma -. pro) *. float_of_int (Sys.word_size / 8)\n\n\nexternal finalise : ('a -> unit) -> 'a -> unit = \"caml_final_register\"\nexternal finalise_last : (unit -> unit) -> 'a -> unit =\n  \"caml_final_register_called_without_value\"\nexternal finalise_release : unit -> unit = \"caml_final_release\"\n\n\ntype alarm = bool ref\ntype alarm_rec = {active : alarm; f : unit -> unit}\n\nlet rec call_alarm arec =\n  if !(arec.active) then begin\n    finalise call_alarm arec;\n    arec.f ();\n  end\n\n\nlet create_alarm f =\n  let arec = { active = ref true; f = f } in\n  finalise call_alarm arec;\n  arec.active\n\n\nlet delete_alarm a = a := false\n\nmodule Memprof =\n  struct\n    type allocation_source = Normal | Marshal | Custom\n    type allocation =\n      { n_samples : int;\n        size : int;\n        source : allocation_source;\n        callstack : Printexc.raw_backtrace }\n\n    type ('minor, 'major) tracker = {\n      alloc_minor: allocation -> 'minor option;\n      alloc_major: allocation -> 'major option;\n      promote: 'minor -> 'major option;\n      dealloc_minor: 'minor -> unit;\n      dealloc_major: 'major -> unit;\n    }\n\n    let null_tracker = {\n      alloc_minor = (fun _ -> None);\n      alloc_major = (fun _ -> None);\n      promote = (fun _ -> None);\n      dealloc_minor = (fun _ -> ());\n      dealloc_major = (fun _ -> ());\n    }\n\n    external c_start :\n      float -> int -> ('minor, 'major) tracker -> unit\n      = \"caml_memprof_start\"\n\n    let start\n      ~sampling_rate\n      ?(callstack_size = max_int)\n      tracker =\n      c_start sampling_rate callstack_size tracker\n\n    external stop : unit -> unit = \"caml_memprof_stop\"\n  end\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Message digest (MD5) *)\n\ntype t = string\n\nlet compare = String.compare\nlet equal = String.equal\n\nexternal unsafe_string: string -> int -> int -> t = \"caml_md5_string\"\nexternal channel: in_channel -> int -> t = \"caml_md5_chan\"\n\nlet string str =\n  unsafe_string str 0 (String.length str)\n\nlet bytes b = string (Bytes.unsafe_to_string b)\n\nlet substring str ofs len =\n  if ofs < 0 || len < 0 || ofs > String.length str - len\n  then invalid_arg \"Digest.substring\"\n  else unsafe_string str ofs len\n\nlet subbytes b ofs len = substring (Bytes.unsafe_to_string b) ofs len\n\nlet file filename =\n  let ic = open_in_bin filename in\n  match channel ic (-1) with\n    | d -> close_in ic; d\n    | exception e -> close_in ic; raise e\n\nlet output chan digest =\n  output_string chan digest\n\nlet input chan = really_input_string chan 16\n\nlet char_hex n =\n  Char.unsafe_chr (n + if n < 10 then Char.code '0' else (Char.code 'a' - 10))\n\nlet to_hex d =\n  if String.length d <> 16 then invalid_arg \"Digest.to_hex\";\n  let result = Bytes.create 32 in\n  for i = 0 to 15 do\n    let x = Char.code d.[i] in\n    Bytes.unsafe_set result (i*2) (char_hex (x lsr 4));\n    Bytes.unsafe_set result (i*2+1) (char_hex (x land 0x0f));\n  done;\n  Bytes.unsafe_to_string result\n\nlet from_hex s =\n  if String.length s <> 32 then invalid_arg \"Digest.from_hex\";\n  let digit c =\n    match c with\n    | '0'..'9' -> Char.code c - Char.code '0'\n    | 'A'..'F' -> Char.code c - Char.code 'A' + 10\n    | 'a'..'f' -> Char.code c - Char.code 'a' + 10\n    | _ -> raise (Invalid_argument \"Digest.from_hex\")\n  in\n  let byte i = digit s.[i] lsl 4 + digit s.[i+1] in\n  let result = Bytes.create 16 in\n  for i = 0 to 15 do\n    Bytes.set result i (Char.chr (byte (2 * i)));\n  done;\n  Bytes.unsafe_to_string result\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*               Damien Doligez, projet Para, INRIA Rocquencourt          *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Pseudo-random number generator\n   This is a lagged-Fibonacci F(55, 24, +) with a modified addition\n   function to enhance the mixing of bits.\n   If we use normal addition, the low-order bit fails tests 1 and 7\n   of the Diehard test suite, and bits 1 and 2 also fail test 7.\n   If we use multiplication as suggested by Marsaglia, it doesn't fare\n   much better.\n   By mixing the bits of one of the numbers before addition (XOR the\n   5 high-order bits into the low-order bits), we get a generator that\n   passes all the Diehard tests.\n*)\n\nexternal random_seed: unit -> int array = \"caml_sys_random_seed\"\n\nmodule State = struct\n\n  type t = { st : int array; mutable idx : int }\n\n  let new_state () = { st = Array.make 55 0; idx = 0 }\n  let assign st1 st2 =\n    Array.blit st2.st 0 st1.st 0 55;\n    st1.idx <- st2.idx\n\n\n  let full_init s seed =\n    let combine accu x = Digest.string (accu ^ Int.to_string x) in\n    let extract d =\n      Char.code d.[0] + (Char.code d.[1] lsl 8) + (Char.code d.[2] lsl 16)\n      + (Char.code d.[3] lsl 24)\n    in\n    let seed = if Array.length seed = 0 then [| 0 |] else seed in\n    let l = Array.length seed in\n    for i = 0 to 54 do\n      s.st.(i) <- i;\n    done;\n    let accu = ref \"x\" in\n    for i = 0 to 54 + Int.max 55 l do\n      let j = i mod 55 in\n      let k = i mod l in\n      accu := combine !accu seed.(k);\n      s.st.(j) <- (s.st.(j) lxor extract !accu) land 0x3FFFFFFF;  (* PR#5575 *)\n    done;\n    s.idx <- 0\n\n\n  let make seed =\n    let result = new_state () in\n    full_init result seed;\n    result\n\n\n  let make_self_init () = make (random_seed ())\n\n  let copy s =\n    let result = new_state () in\n    assign result s;\n    result\n\n\n  (* Returns 30 random bits as an integer 0 <= x < 1073741824 *)\n  let bits s =\n    s.idx <- (s.idx + 1) mod 55;\n    let curval = s.st.(s.idx) in\n    let newval = s.st.((s.idx + 24) mod 55)\n                 + (curval lxor ((curval lsr 25) land 0x1F)) in\n    let newval30 = newval land 0x3FFFFFFF in  (* PR#5575 *)\n    s.st.(s.idx) <- newval30;\n    newval30\n\n\n  let rec intaux s n =\n    let r = bits s in\n    let v = r mod n in\n    if r - v > 0x3FFFFFFF - n + 1 then intaux s n else v\n\n  let int s bound =\n    if bound > 0x3FFFFFFF || bound <= 0\n    then invalid_arg \"Random.int\"\n    else intaux s bound\n\n  let rec int63aux s n =\n    let max_int_32 = (1 lsl 30) + 0x3FFFFFFF in (* 0x7FFFFFFF *)\n    let b1 = bits s in\n    let b2 = bits s in\n    let (r, max_int) =\n      if n <= max_int_32 then\n        (* 31 random bits on both 64-bit OCaml and JavaScript.\n           Use upper 15 bits of b1 and 16 bits of b2. *)\n        let bpos =\n          (((b2 land 0x3FFFC000) lsl 1) lor (b1 lsr 15))\n        in\n          (bpos, max_int_32)\n      else\n        let b3 = bits s in\n        (* 62 random bits on 64-bit OCaml; unreachable on JavaScript.\n           Use upper 20 bits of b1 and 21 bits of b2 and b3. *)\n        let bpos =\n          ((((b3 land 0x3FFFFE00) lsl 12) lor (b2 lsr 9)) lsl 20)\n            lor (b1 lsr 10)\n        in\n          (bpos, max_int)\n    in\n    let v = r mod n in\n    if r - v > max_int - n + 1 then int63aux s n else v\n\n  let full_int s bound =\n    if bound <= 0 then\n      invalid_arg \"Random.full_int\"\n    else if bound > 0x3FFFFFFF then\n      int63aux s bound\n    else\n      intaux s bound\n\n\n  let rec int32aux s n =\n    let b1 = Int32.of_int (bits s) in\n    let b2 = Int32.shift_left (Int32.of_int (bits s land 1)) 30 in\n    let r = Int32.logor b1 b2 in\n    let v = Int32.rem r n in\n    if Int32.sub r v > Int32.add (Int32.sub Int32.max_int n) 1l\n    then int32aux s n\n    else v\n\n  let int32 s bound =\n    if bound <= 0l\n    then invalid_arg \"Random.int32\"\n    else int32aux s bound\n\n\n  let rec int64aux s n =\n    let b1 = Int64.of_int (bits s) in\n    let b2 = Int64.shift_left (Int64.of_int (bits s)) 30 in\n    let b3 = Int64.shift_left (Int64.of_int (bits s land 7)) 60 in\n    let r = Int64.logor b1 (Int64.logor b2 b3) in\n    let v = Int64.rem r n in\n    if Int64.sub r v > Int64.add (Int64.sub Int64.max_int n) 1L\n    then int64aux s n\n    else v\n\n  let int64 s bound =\n    if bound <= 0L\n    then invalid_arg \"Random.int64\"\n    else int64aux s bound\n\n\n  let nativeint =\n    if Nativeint.size = 32\n    then fun s bound -> Nativeint.of_int32 (int32 s (Nativeint.to_int32 bound))\n    else fun s bound -> Int64.to_nativeint (int64 s (Int64.of_nativeint bound))\n\n\n  (* Returns a float 0 <= x <= 1 with at most 60 bits of precision. *)\n  let rawfloat s =\n    let scale = 1073741824.0  (* 2^30 *)\n    and r1 = Stdlib.float (bits s)\n    and r2 = Stdlib.float (bits s)\n    in (r1 /. scale +. r2) /. scale\n\n\n  let float s bound = rawfloat s *. bound\n\n  let bool s = (bits s land 1 = 0)\n\nend\n\n(* This is the state you get with [init 27182818] and then applying\n   the \"land 0x3FFFFFFF\" filter to them.  See #5575, #5793, #5977. *)\nlet default = {\n  State.st = [|\n      0x3ae2522b; 0x1d8d4634; 0x15b4fad0; 0x18b14ace; 0x12f8a3c4; 0x3b086c47;\n      0x16d467d6; 0x101d91c7; 0x321df177; 0x0176c193; 0x1ff72bf1; 0x1e889109;\n      0x0b464b18; 0x2b86b97c; 0x0891da48; 0x03137463; 0x085ac5a1; 0x15d61f2f;\n      0x3bced359; 0x29c1c132; 0x3a86766e; 0x366d8c86; 0x1f5b6222; 0x3ce1b59f;\n      0x2ebf78e1; 0x27cd1b86; 0x258f3dc3; 0x389a8194; 0x02e4c44c; 0x18c43f7d;\n      0x0f6e534f; 0x1e7df359; 0x055d0b7e; 0x10e84e7e; 0x126198e4; 0x0e7722cb;\n      0x1cbede28; 0x3391b964; 0x3d40e92a; 0x0c59933d; 0x0b8cd0b7; 0x24efff1c;\n      0x2803fdaa; 0x08ebc72e; 0x0f522e32; 0x05398edc; 0x2144a04c; 0x0aef3cbd;\n      0x01ad4719; 0x35b93cd6; 0x2a559d4f; 0x1e6fd768; 0x26e27f36; 0x186f18c3;\n      0x2fbf967a;\n    |];\n  State.idx = 0;\n}\n\nlet bits () = State.bits default\nlet int bound = State.int default bound\nlet full_int bound = State.full_int default bound\nlet int32 bound = State.int32 default bound\nlet nativeint bound = State.nativeint default bound\nlet int64 bound = State.int64 default bound\nlet float scale = State.float default scale\nlet bool () = State.bool default\n\nlet full_init seed = State.full_init default seed\nlet init seed = State.full_init default [| seed |]\nlet self_init () = full_init (random_seed())\n\n(* Manipulating the current state. *)\n\nlet get_state () = State.copy default\nlet set_state s = State.assign default s\n\n(********************\n\n(* Test functions.  Not included in the library.\n   The [chisquare] function should be called with n > 10r.\n   It returns a triple (low, actual, high).\n   If low <= actual <= high, the [g] function passed the test,\n   otherwise it failed.\n\n  Some results:\n\ninit 27182818; chisquare int 100000 1000\ninit 27182818; chisquare int 100000 100\ninit 27182818; chisquare int 100000 5000\ninit 27182818; chisquare int 1000000 1000\ninit 27182818; chisquare int 100000 1024\ninit 299792643; chisquare int 100000 1024\ninit 14142136; chisquare int 100000 1024\ninit 27182818; init_diff 1024; chisquare diff 100000 1024\ninit 27182818; init_diff 100; chisquare diff 100000 100\ninit 27182818; init_diff2 1024; chisquare diff2 100000 1024\ninit 27182818; init_diff2 100; chisquare diff2 100000 100\ninit 14142136; init_diff2 100; chisquare diff2 100000 100\ninit 299792643; init_diff2 100; chisquare diff2 100000 100\n- : float * float * float = (936.754446796632465, 997.5, 1063.24555320336754)\n# - : float * float * float = (80., 89.7400000000052387, 120.)\n# - : float * float * float = (4858.57864376269, 5045.5, 5141.42135623731)\n# - : float * float * float =\n(936.754446796632465, 944.805999999982305, 1063.24555320336754)\n# - : float * float * float = (960., 1019.19744000000355, 1088.)\n# - : float * float * float = (960., 1059.31776000000536, 1088.)\n# - : float * float * float = (960., 1039.98463999999512, 1088.)\n# - : float * float * float = (960., 1054.38207999999577, 1088.)\n# - : float * float * float = (80., 90.096000000005, 120.)\n# - : float * float * float = (960., 1076.78720000000612, 1088.)\n# - : float * float * float = (80., 85.1760000000067521, 120.)\n# - : float * float * float = (80., 85.2160000000003492, 120.)\n# - : float * float * float = (80., 80.6220000000030268, 120.)\n\n*)\n\n(* Return the sum of the squares of v[i0,i1[ *)\nlet rec sumsq v i0 i1 =\n  if i0 >= i1 then 0.0\n  else if i1 = i0 + 1 then Stdlib.float v.(i0) *. Stdlib.float v.(i0)\n  else sumsq v i0 ((i0+i1)/2) +. sumsq v ((i0+i1)/2) i1\n\n\nlet chisquare g n r =\n  if n <= 10 * r then invalid_arg \"chisquare\";\n  let f = Array.make r 0 in\n  for i = 1 to n do\n    let t = g r in\n    f.(t) <- f.(t) + 1\n  done;\n  let t = sumsq f 0 r\n  and r = Stdlib.float r\n  and n = Stdlib.float n in\n  let sr = 2.0 *. sqrt r in\n  (r -. sr,   (r *. t /. n) -. n,   r +. sr)\n\n\n(* This is to test for linear dependencies between successive random numbers.\n*)\nlet st = ref 0\nlet init_diff r = st := int r\nlet diff r =\n  let x1 = !st\n  and x2 = int r\n  in\n  st := x2;\n  if x1 >= x2 then\n    x1 - x2\n  else\n    r + x1 - x2\n\n\nlet st1 = ref 0\nand st2 = ref 0\n\n\n(* This is to test for quadratic dependencies between successive random\n   numbers.\n*)\nlet init_diff2 r = st1 := int r; st2 := int r\nlet diff2 r =\n  let x1 = !st1\n  and x2 = !st2\n  and x3 = int r\n  in\n  st1 := x2;\n  st2 := x3;\n  (x3 - x2 - x2 + x1 + 2*r) mod r\n\n\n********************)\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Hash tables *)\n\n(* We do dynamic hashing, and resize the table and rehash the elements\n   when buckets become too long. *)\n\ntype ('a, 'b) t =\n  { mutable size: int;                        (* number of entries *)\n    mutable data: ('a, 'b) bucketlist array;  (* the buckets *)\n    seed: int;                        (* for randomization *)\n    mutable initial_size: int;                (* initial array size *)\n  }\n\nand ('a, 'b) bucketlist =\n    Empty\n  | Cons of { mutable key: 'a;\n              mutable data: 'b;\n              mutable next: ('a, 'b) bucketlist }\n\n(* The sign of initial_size encodes the fact that a traversal is\n   ongoing or not.\n\n   This disables the efficient in place implementation of resizing.\n*)\n\nlet ongoing_traversal h =\n  Obj.size (Obj.repr h) < 4 (* compatibility with old hash tables *)\n  || h.initial_size < 0\n\nlet flip_ongoing_traversal h =\n  h.initial_size <- - h.initial_size\n\n(* To pick random seeds if requested *)\n\nlet randomized_default =\n  let params =\n    try Sys.getenv \"OCAMLRUNPARAM\" with Not_found ->\n    try Sys.getenv \"CAMLRUNPARAM\" with Not_found -> \"\" in\n  String.contains params 'R'\n\nlet randomized = ref randomized_default\n\nlet randomize () = randomized := true\nlet is_randomized () = !randomized\n\nlet prng = lazy (Random.State.make_self_init())\n\n(* Functions which appear before the functorial interface must either be\n   independent of the hash function or take it as a parameter (see #2202 and\n   code below the functor definitions. *)\n\n(* Creating a fresh, empty table *)\n\nlet rec power_2_above x n =\n  if x >= n then x\n  else if x * 2 > Sys.max_array_length then x\n  else power_2_above (x * 2) n\n\nlet create ?(random = !randomized) initial_size =\n  let s = power_2_above 16 initial_size in\n  let seed = if random then Random.State.bits (Lazy.force prng) else 0 in\n  { initial_size = s; size = 0; seed = seed; data = Array.make s Empty }\n\nlet clear h =\n  if h.size > 0 then begin\n    h.size <- 0;\n    Array.fill h.data 0 (Array.length h.data) Empty\n  end\n\nlet reset h =\n  let len = Array.length h.data in\n  if Obj.size (Obj.repr h) < 4 (* compatibility with old hash tables *)\n    || len = abs h.initial_size then\n    clear h\n  else begin\n    h.size <- 0;\n    h.data <- Array.make (abs h.initial_size) Empty\n  end\n\nlet copy_bucketlist = function\n  | Empty -> Empty\n  | Cons {key; data; next} ->\n      let rec loop prec = function\n        | Empty -> ()\n        | Cons {key; data; next} ->\n            let r = Cons {key; data; next} in\n            begin match prec with\n            | Empty -> assert false\n            | Cons prec ->  prec.next <- r\n            end;\n            loop r next\n      in\n      let r = Cons {key; data; next} in\n      loop r next;\n      r\n\nlet copy h = { h with data = Array.map copy_bucketlist h.data }\n\nlet length h = h.size\n\nlet insert_all_buckets indexfun inplace odata ndata =\n  let nsize = Array.length ndata in\n  let ndata_tail = Array.make nsize Empty in\n  let rec insert_bucket = function\n    | Empty -> ()\n    | Cons {key; data; next} as cell ->\n        let cell =\n          if inplace then cell\n          else Cons {key; data; next = Empty}\n        in\n        let nidx = indexfun key in\n        begin match ndata_tail.(nidx) with\n        | Empty -> ndata.(nidx) <- cell;\n        | Cons tail -> tail.next <- cell;\n        end;\n        ndata_tail.(nidx) <- cell;\n        insert_bucket next\n  in\n  for i = 0 to Array.length odata - 1 do\n    insert_bucket odata.(i)\n  done;\n  if inplace then\n    for i = 0 to nsize - 1 do\n      match ndata_tail.(i) with\n      | Empty -> ()\n      | Cons tail -> tail.next <- Empty\n    done\n\nlet resize indexfun h =\n  let odata = h.data in\n  let osize = Array.length odata in\n  let nsize = osize * 2 in\n  if nsize < Sys.max_array_length then begin\n    let ndata = Array.make nsize Empty in\n    let inplace = not (ongoing_traversal h) in\n    h.data <- ndata;          (* so that indexfun sees the new bucket count *)\n    insert_all_buckets (indexfun h) inplace odata ndata\n  end\n\nlet iter f h =\n  let rec do_bucket = function\n    | Empty ->\n        ()\n    | Cons{key; data; next} ->\n        f key data; do_bucket next in\n  let old_trav = ongoing_traversal h in\n  if not old_trav then flip_ongoing_traversal h;\n  try\n    let d = h.data in\n    for i = 0 to Array.length d - 1 do\n      do_bucket d.(i)\n    done;\n    if not old_trav then flip_ongoing_traversal h;\n  with exn when not old_trav ->\n    flip_ongoing_traversal h;\n    raise exn\n\nlet rec filter_map_inplace_bucket f h i prec = function\n  | Empty ->\n      begin match prec with\n      | Empty -> h.data.(i) <- Empty\n      | Cons c -> c.next <- Empty\n      end\n  | (Cons ({key; data; next} as c)) as slot ->\n      begin match f key data with\n      | None ->\n          h.size <- h.size - 1;\n          filter_map_inplace_bucket f h i prec next\n      | Some data ->\n          begin match prec with\n          | Empty -> h.data.(i) <- slot\n          | Cons c -> c.next <- slot\n          end;\n          c.data <- data;\n          filter_map_inplace_bucket f h i slot next\n      end\n\nlet filter_map_inplace f h =\n  let d = h.data in\n  let old_trav = ongoing_traversal h in\n  if not old_trav then flip_ongoing_traversal h;\n  try\n    for i = 0 to Array.length d - 1 do\n      filter_map_inplace_bucket f h i Empty h.data.(i)\n    done;\n    if not old_trav then flip_ongoing_traversal h\n  with exn when not old_trav ->\n    flip_ongoing_traversal h;\n    raise exn\n\nlet fold f h init =\n  let rec do_bucket b accu =\n    match b with\n      Empty ->\n        accu\n    | Cons{key; data; next} ->\n        do_bucket next (f key data accu) in\n  let old_trav = ongoing_traversal h in\n  if not old_trav then flip_ongoing_traversal h;\n  try\n    let d = h.data in\n    let accu = ref init in\n    for i = 0 to Array.length d - 1 do\n      accu := do_bucket d.(i) !accu\n    done;\n    if not old_trav then flip_ongoing_traversal h;\n    !accu\n  with exn when not old_trav ->\n    flip_ongoing_traversal h;\n    raise exn\n\ntype statistics = {\n  num_bindings: int;\n  num_buckets: int;\n  max_bucket_length: int;\n  bucket_histogram: int array\n}\n\nlet rec bucket_length accu = function\n  | Empty -> accu\n  | Cons{next} -> bucket_length (accu + 1) next\n\nlet stats h =\n  let mbl =\n    Array.fold_left (fun m b -> Int.max m (bucket_length 0 b)) 0 h.data in\n  let histo = Array.make (mbl + 1) 0 in\n  Array.iter\n    (fun b ->\n      let l = bucket_length 0 b in\n      histo.(l) <- histo.(l) + 1)\n    h.data;\n  { num_bindings = h.size;\n    num_buckets = Array.length h.data;\n    max_bucket_length = mbl;\n    bucket_histogram = histo }\n\n(** {1 Iterators} *)\n\nlet to_seq tbl =\n  (* capture current array, so that even if the table is resized we\n     keep iterating on the same array *)\n  let tbl_data = tbl.data in\n  (* state: index * next bucket to traverse *)\n  let rec aux i buck () = match buck with\n    | Empty ->\n        if i = Array.length tbl_data\n        then Seq.Nil\n        else aux(i+1) tbl_data.(i) ()\n    | Cons {key; data; next} ->\n        Seq.Cons ((key, data), aux i next)\n  in\n  aux 0 Empty\n\nlet to_seq_keys m = Seq.map fst (to_seq m)\n\nlet to_seq_values m = Seq.map snd (to_seq m)\n\n(* Functorial interface *)\n\nmodule type HashedType =\n  sig\n    type t\n    val equal: t -> t -> bool\n    val hash: t -> int\n  end\n\nmodule type SeededHashedType =\n  sig\n    type t\n    val equal: t -> t -> bool\n    val hash: int -> t -> int\n  end\n\nmodule type S =\n  sig\n    type key\n    type !'a t\n    val create: int -> 'a t\n    val clear : 'a t -> unit\n    val reset : 'a t -> unit\n    val copy: 'a t -> 'a t\n    val add: 'a t -> key -> 'a -> unit\n    val remove: 'a t -> key -> unit\n    val find: 'a t -> key -> 'a\n    val find_opt: 'a t -> key -> 'a option\n    val find_all: 'a t -> key -> 'a list\n    val replace : 'a t -> key -> 'a -> unit\n    val mem : 'a t -> key -> bool\n    val iter: (key -> 'a -> unit) -> 'a t -> unit\n    val filter_map_inplace: (key -> 'a -> 'a option) -> 'a t -> unit\n    val fold: (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b\n    val length: 'a t -> int\n    val stats: 'a t -> statistics\n    val to_seq : 'a t -> (key * 'a) Seq.t\n    val to_seq_keys : _ t -> key Seq.t\n    val to_seq_values : 'a t -> 'a Seq.t\n    val add_seq : 'a t -> (key * 'a) Seq.t -> unit\n    val replace_seq : 'a t -> (key * 'a) Seq.t -> unit\n    val of_seq : (key * 'a) Seq.t -> 'a t\n  end\n\nmodule type SeededS =\n  sig\n    type key\n    type !'a t\n    val create : ?random:bool -> int -> 'a t\n    val clear : 'a t -> unit\n    val reset : 'a t -> unit\n    val copy : 'a t -> 'a t\n    val add : 'a t -> key -> 'a -> unit\n    val remove : 'a t -> key -> unit\n    val find : 'a t -> key -> 'a\n    val find_opt: 'a t -> key -> 'a option\n    val find_all : 'a t -> key -> 'a list\n    val replace : 'a t -> key -> 'a -> unit\n    val mem : 'a t -> key -> bool\n    val iter : (key -> 'a -> unit) -> 'a t -> unit\n    val filter_map_inplace: (key -> 'a -> 'a option) -> 'a t -> unit\n    val fold : (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b\n    val length : 'a t -> int\n    val stats: 'a t -> statistics\n    val to_seq : 'a t -> (key * 'a) Seq.t\n    val to_seq_keys : _ t -> key Seq.t\n    val to_seq_values : 'a t -> 'a Seq.t\n    val add_seq : 'a t -> (key * 'a) Seq.t -> unit\n    val replace_seq : 'a t -> (key * 'a) Seq.t -> unit\n    val of_seq : (key * 'a) Seq.t -> 'a t\n  end\n\nmodule MakeSeeded(H: SeededHashedType): (SeededS with type key = H.t) =\n  struct\n    type key = H.t\n    type 'a hashtbl = (key, 'a) t\n    type 'a t = 'a hashtbl\n    let create = create\n    let clear = clear\n    let reset = reset\n    let copy = copy\n\n    let key_index h key =\n      (H.hash h.seed key) land (Array.length h.data - 1)\n\n    let add h key data =\n      let i = key_index h key in\n      let bucket = Cons{key; data; next=h.data.(i)} in\n      h.data.(i) <- bucket;\n      h.size <- h.size + 1;\n      if h.size > Array.length h.data lsl 1 then resize key_index h\n\n    let rec remove_bucket h i key prec = function\n      | Empty ->\n          ()\n      | (Cons {key=k; next}) as c ->\n          if H.equal k key\n          then begin\n            h.size <- h.size - 1;\n            match prec with\n            | Empty -> h.data.(i) <- next\n            | Cons c -> c.next <- next\n          end\n          else remove_bucket h i key c next\n\n    let remove h key =\n      let i = key_index h key in\n      remove_bucket h i key Empty h.data.(i)\n\n    let rec find_rec key = function\n      | Empty ->\n          raise Not_found\n      | Cons{key=k; data; next} ->\n          if H.equal key k then data else find_rec key next\n\n    let find h key =\n      match h.data.(key_index h key) with\n      | Empty -> raise Not_found\n      | Cons{key=k1; data=d1; next=next1} ->\n          if H.equal key k1 then d1 else\n          match next1 with\n          | Empty -> raise Not_found\n          | Cons{key=k2; data=d2; next=next2} ->\n              if H.equal key k2 then d2 else\n              match next2 with\n              | Empty -> raise Not_found\n              | Cons{key=k3; data=d3; next=next3} ->\n                  if H.equal key k3 then d3 else find_rec key next3\n\n    let rec find_rec_opt key = function\n      | Empty ->\n          None\n      | Cons{key=k; data; next} ->\n          if H.equal key k then Some data else find_rec_opt key next\n\n    let find_opt h key =\n      match h.data.(key_index h key) with\n      | Empty -> None\n      | Cons{key=k1; data=d1; next=next1} ->\n          if H.equal key k1 then Some d1 else\n          match next1 with\n          | Empty -> None\n          | Cons{key=k2; data=d2; next=next2} ->\n              if H.equal key k2 then Some d2 else\n              match next2 with\n              | Empty -> None\n              | Cons{key=k3; data=d3; next=next3} ->\n                  if H.equal key k3 then Some d3 else find_rec_opt key next3\n\n    let find_all h key =\n      let rec find_in_bucket = function\n      | Empty ->\n          []\n      | Cons{key=k; data=d; next} ->\n          if H.equal k key\n          then d :: find_in_bucket next\n          else find_in_bucket next in\n      find_in_bucket h.data.(key_index h key)\n\n    let rec replace_bucket key data = function\n      | Empty ->\n          true\n      | Cons ({key=k; next} as slot) ->\n          if H.equal k key\n          then (slot.key <- key; slot.data <- data; false)\n          else replace_bucket key data next\n\n    let replace h key data =\n      let i = key_index h key in\n      let l = h.data.(i) in\n      if replace_bucket key data l then begin\n        h.data.(i) <- Cons{key; data; next=l};\n        h.size <- h.size + 1;\n        if h.size > Array.length h.data lsl 1 then resize key_index h\n      end\n\n    let mem h key =\n      let rec mem_in_bucket = function\n      | Empty ->\n          false\n      | Cons{key=k; next} ->\n          H.equal k key || mem_in_bucket next in\n      mem_in_bucket h.data.(key_index h key)\n\n    let add_seq tbl i =\n      Seq.iter (fun (k,v) -> add tbl k v) i\n\n    let replace_seq tbl i =\n      Seq.iter (fun (k,v) -> replace tbl k v) i\n\n    let of_seq i =\n      let tbl = create 16 in\n      replace_seq tbl i;\n      tbl\n\n    let iter = iter\n    let filter_map_inplace = filter_map_inplace\n    let fold = fold\n    let length = length\n    let stats = stats\n    let to_seq = to_seq\n    let to_seq_keys = to_seq_keys\n    let to_seq_values = to_seq_values\n  end\n\nmodule Make(H: HashedType): (S with type key = H.t) =\n  struct\n    include MakeSeeded(struct\n        type t = H.t\n        let equal = H.equal\n        let hash (_seed: int) x = H.hash x\n      end)\n    let create sz = create ~random:false sz\n    let of_seq i =\n      let tbl = create 16 in\n      replace_seq tbl i;\n      tbl\n  end\n\n(* Polymorphic hash function-based tables *)\n(* Code included below the functorial interface to guard against accidental\n   use - see #2202 *)\n\nexternal seeded_hash_param :\n  int -> int -> int -> 'a -> int = \"caml_hash\" [@@noalloc]\n\nlet hash x = seeded_hash_param 10 100 0 x\nlet hash_param n1 n2 x = seeded_hash_param n1 n2 0 x\nlet seeded_hash seed x = seeded_hash_param 10 100 seed x\n\nlet key_index h key =\n  if Obj.size (Obj.repr h) >= 4\n  then (seeded_hash_param 10 100 h.seed key) land (Array.length h.data - 1)\n  else invalid_arg \"Hashtbl: unsupported hash table format\"\n\nlet add h key data =\n  let i = key_index h key in\n  let bucket = Cons{key; data; next=h.data.(i)} in\n  h.data.(i) <- bucket;\n  h.size <- h.size + 1;\n  if h.size > Array.length h.data lsl 1 then resize key_index h\n\nlet rec remove_bucket h i key prec = function\n  | Empty ->\n      ()\n  | (Cons {key=k; next}) as c ->\n      if compare k key = 0\n      then begin\n        h.size <- h.size - 1;\n        match prec with\n        | Empty -> h.data.(i) <- next\n        | Cons c -> c.next <- next\n      end\n      else remove_bucket h i key c next\n\nlet remove h key =\n  let i = key_index h key in\n  remove_bucket h i key Empty h.data.(i)\n\nlet rec find_rec key = function\n  | Empty ->\n      raise Not_found\n  | Cons{key=k; data; next} ->\n      if compare key k = 0 then data else find_rec key next\n\nlet find h key =\n  match h.data.(key_index h key) with\n  | Empty -> raise Not_found\n  | Cons{key=k1; data=d1; next=next1} ->\n      if compare key k1 = 0 then d1 else\n      match next1 with\n      | Empty -> raise Not_found\n      | Cons{key=k2; data=d2; next=next2} ->\n          if compare key k2 = 0 then d2 else\n          match next2 with\n          | Empty -> raise Not_found\n          | Cons{key=k3; data=d3; next=next3} ->\n              if compare key k3 = 0 then d3 else find_rec key next3\n\nlet rec find_rec_opt key = function\n  | Empty ->\n      None\n  | Cons{key=k; data; next} ->\n      if compare key k = 0 then Some data else find_rec_opt key next\n\nlet find_opt h key =\n  match h.data.(key_index h key) with\n  | Empty -> None\n  | Cons{key=k1; data=d1; next=next1} ->\n      if compare key k1 = 0 then Some d1 else\n      match next1 with\n      | Empty -> None\n      | Cons{key=k2; data=d2; next=next2} ->\n          if compare key k2 = 0 then Some d2 else\n          match next2 with\n          | Empty -> None\n          | Cons{key=k3; data=d3; next=next3} ->\n              if compare key k3 = 0 then Some d3 else find_rec_opt key next3\n\nlet find_all h key =\n  let rec find_in_bucket = function\n  | Empty ->\n      []\n  | Cons{key=k; data; next} ->\n      if compare k key = 0\n      then data :: find_in_bucket next\n      else find_in_bucket next in\n  find_in_bucket h.data.(key_index h key)\n\nlet rec replace_bucket key data = function\n  | Empty ->\n      true\n  | Cons ({key=k; next} as slot) ->\n      if compare k key = 0\n      then (slot.key <- key; slot.data <- data; false)\n      else replace_bucket key data next\n\nlet replace h key data =\n  let i = key_index h key in\n  let l = h.data.(i) in\n  if replace_bucket key data l then begin\n    h.data.(i) <- Cons{key; data; next=l};\n    h.size <- h.size + 1;\n    if h.size > Array.length h.data lsl 1 then resize key_index h\n  end\n\nlet mem h key =\n  let rec mem_in_bucket = function\n  | Empty ->\n      false\n  | Cons{key=k; next} ->\n      compare k key = 0 || mem_in_bucket next in\n  mem_in_bucket h.data.(key_index h key)\n\nlet add_seq tbl i =\n  Seq.iter (fun (k,v) -> add tbl k v) i\n\nlet replace_seq tbl i =\n  Seq.iter (fun (k,v) -> replace tbl k v) i\n\nlet of_seq i =\n  let tbl = create 16 in\n  replace_seq tbl i;\n  tbl\n\nlet rebuild ?(random = !randomized) h =\n  let s = power_2_above 16 (Array.length h.data) in\n  let seed =\n    if random then Random.State.bits (Lazy.force prng)\n    else if Obj.size (Obj.repr h) >= 4 then h.seed\n    else 0 in\n  let h' = {\n    size = h.size;\n    data = Array.make s Empty;\n    seed = seed;\n    initial_size = if Obj.size (Obj.repr h) >= 4 then h.initial_size else s\n  } in\n  insert_all_buckets (key_index h') false h.data h'.data;\n  h'\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Damien Doligez, projet Para, INRIA Rocquencourt            *)\n(*                                                                        *)\n(*   Copyright 1997 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(** Weak array operations *)\n\ntype !'a t\n\nexternal create : int -> 'a t = \"caml_weak_create\"\n\nlet create l =\n  if not (0 <= l && l <= Obj.Ephemeron.max_ephe_length) then\n    invalid_arg(\"Weak.create\");\n  create l\n\n(** number of additional values in a weak pointer *)\nlet additional_values = 2\n\nlet length x = Obj.size(Obj.repr x) - additional_values\n\nlet raise_if_invalid_offset e o msg =\n  if not (0 <= o && o < length e) then\n    invalid_arg(msg)\n\nexternal set' : 'a t -> int -> 'a -> unit = \"caml_ephe_set_key\"\nexternal unset : 'a t -> int -> unit = \"caml_ephe_unset_key\"\nlet set e o x =\n  raise_if_invalid_offset e o \"Weak.set\";\n  match x with\n  | None -> unset e o\n  | Some x -> set' e o x\n\nexternal get : 'a t -> int -> 'a option = \"caml_weak_get\"\nlet get e o =\n  raise_if_invalid_offset e o \"Weak.get\";\n  get e o\n\nexternal get_copy : 'a t -> int -> 'a option = \"caml_weak_get_copy\"\nlet get_copy e o =\n  raise_if_invalid_offset e o \"Weak.get_copy\";\n  get_copy e o\n\nexternal check : 'a t -> int -> bool = \"caml_weak_check\"\nlet check e o =\n  raise_if_invalid_offset e o \"Weak.check\";\n  check e o\n\nexternal blit : 'a t -> int -> 'a t -> int -> int -> unit = \"caml_weak_blit\"\n\n(* blit: src srcoff dst dstoff len *)\nlet blit e1 o1 e2 o2 l =\n  if l < 0 || o1 < 0 || o1 > length e1 - l\n     || o2 < 0 || o2 > length e2 - l\n  then invalid_arg \"Weak.blit\"\n  else if l <> 0 then blit e1 o1 e2 o2 l\n\nlet fill ar ofs len x =\n  if ofs < 0 || len < 0 || ofs > length ar - len\n  then raise (Invalid_argument \"Weak.fill\")\n  else begin\n    for i = ofs to (ofs + len - 1) do\n      set ar i x\n    done\n  end\n\n\n(** Weak hash tables *)\n\nmodule type S = sig\n  type data\n  type t\n  val create : int -> t\n  val clear : t -> unit\n  val merge : t -> data -> data\n  val add : t -> data -> unit\n  val remove : t -> data -> unit\n  val find : t -> data -> data\n  val find_opt : t -> data -> data option\n  val find_all : t -> data -> data list\n  val mem : t -> data -> bool\n  val iter : (data -> unit) -> t -> unit\n  val fold : (data -> 'a -> 'a) -> t -> 'a -> 'a\n  val count : t -> int\n  val stats : t -> int * int * int * int * int * int\nend\n\nmodule Make (H : Hashtbl.HashedType) : (S with type data = H.t) = struct\n\n  type 'a weak_t = 'a t\n  let weak_create = create\n  let emptybucket = weak_create 0\n\n  type data = H.t\n\n  type t = {\n    mutable table : data weak_t array;\n    mutable hashes : int array array;\n    mutable limit : int;               (* bucket size limit *)\n    mutable oversize : int;            (* number of oversize buckets *)\n    mutable rover : int;               (* for internal bookkeeping *)\n  }\n\n  let get_index t h = (h land max_int) mod (Array.length t.table)\n\n  let limit = 7\n  let over_limit = 2\n\n  let create sz =\n    let sz = if sz < 7 then 7 else sz in\n    let sz = if sz > Sys.max_array_length then Sys.max_array_length else sz in\n    {\n      table = Array.make sz emptybucket;\n      hashes = Array.make sz [| |];\n      limit = limit;\n      oversize = 0;\n      rover = 0;\n    }\n\n  let clear t =\n    for i = 0 to Array.length t.table - 1 do\n      t.table.(i) <- emptybucket;\n      t.hashes.(i) <- [| |];\n    done;\n    t.limit <- limit;\n    t.oversize <- 0\n\n\n  let fold f t init =\n    let rec fold_bucket i b accu =\n      if i >= length b then accu else\n      match get b i with\n      | Some v -> fold_bucket (i+1) b (f v accu)\n      | None -> fold_bucket (i+1) b accu\n    in\n    Array.fold_right (fold_bucket 0) t.table init\n\n\n  let iter f t =\n    let rec iter_bucket i b =\n      if i >= length b then () else\n      match get b i with\n      | Some v -> f v; iter_bucket (i+1) b\n      | None -> iter_bucket (i+1) b\n    in\n    Array.iter (iter_bucket 0) t.table\n\n\n  let iter_weak f t =\n    let rec iter_bucket i j b =\n      if i >= length b then () else\n      match check b i with\n      | true -> f b t.hashes.(j) i; iter_bucket (i+1) j b\n      | false -> iter_bucket (i+1) j b\n    in\n    Array.iteri (iter_bucket 0) t.table\n\n\n  let rec count_bucket i b accu =\n    if i >= length b then accu else\n    count_bucket (i+1) b (accu + (if check b i then 1 else 0))\n\n\n  let count t =\n    Array.fold_right (count_bucket 0) t.table 0\n\n\n  let next_sz n = Int.min (3 * n / 2 + 3) Sys.max_array_length\n  let prev_sz n = ((n - 3) * 2 + 2) / 3\n\n  let test_shrink_bucket t =\n    let bucket = t.table.(t.rover) in\n    let hbucket = t.hashes.(t.rover) in\n    let len = length bucket in\n    let prev_len = prev_sz len in\n    let live = count_bucket 0 bucket 0 in\n    if live <= prev_len then begin\n      let rec loop i j =\n        if j >= prev_len then begin\n          if check bucket i then loop (i + 1) j\n          else if check bucket j then begin\n            blit bucket j bucket i 1;\n            hbucket.(i) <- hbucket.(j);\n            loop (i + 1) (j - 1);\n          end else loop i (j - 1);\n        end;\n      in\n      loop 0 (length bucket - 1);\n      if prev_len = 0 then begin\n        t.table.(t.rover) <- emptybucket;\n        t.hashes.(t.rover) <- [| |];\n      end else begin\n        let newbucket = weak_create prev_len in\n        blit bucket 0 newbucket 0 prev_len;\n        t.table.(t.rover) <- newbucket;\n        t.hashes.(t.rover) <- Array.sub hbucket 0 prev_len\n      end;\n      if len > t.limit && prev_len <= t.limit then t.oversize <- t.oversize - 1;\n    end;\n    t.rover <- (t.rover + 1) mod (Array.length t.table)\n\n\n  let rec resize t =\n    let oldlen = Array.length t.table in\n    let newlen = next_sz oldlen in\n    if newlen > oldlen then begin\n      let newt = create newlen in\n      let add_weak ob oh oi =\n        let setter nb ni _ = blit ob oi nb ni 1 in\n        let h = oh.(oi) in\n        add_aux newt setter None h (get_index newt h);\n      in\n      iter_weak add_weak t;\n      t.table <- newt.table;\n      t.hashes <- newt.hashes;\n      t.limit <- newt.limit;\n      t.oversize <- newt.oversize;\n      t.rover <- t.rover mod Array.length newt.table;\n    end else begin\n      t.limit <- max_int;             (* maximum size already reached *)\n      t.oversize <- 0;\n    end\n\n  and add_aux t setter d h index =\n    let bucket = t.table.(index) in\n    let hashes = t.hashes.(index) in\n    let sz = length bucket in\n    let rec loop i =\n      if i >= sz then begin\n        let newsz =\n          Int.min (3 * sz / 2 + 3) (Sys.max_array_length - additional_values)\n        in\n        if newsz <= sz then failwith \"Weak.Make: hash bucket cannot grow more\";\n        let newbucket = weak_create newsz in\n        let newhashes = Array.make newsz 0 in\n        blit bucket 0 newbucket 0 sz;\n        Array.blit hashes 0 newhashes 0 sz;\n        setter newbucket sz d;\n        newhashes.(sz) <- h;\n        t.table.(index) <- newbucket;\n        t.hashes.(index) <- newhashes;\n        if sz <= t.limit && newsz > t.limit then begin\n          t.oversize <- t.oversize + 1;\n          for _i = 0 to over_limit do test_shrink_bucket t done;\n        end;\n        if t.oversize > Array.length t.table / over_limit then resize t;\n      end else if check bucket i then begin\n        loop (i + 1)\n      end else begin\n        setter bucket i d;\n        hashes.(i) <- h;\n      end;\n    in\n    loop 0\n\n\n  let add t d =\n    let h = H.hash d in\n    add_aux t set (Some d) h (get_index t h)\n\n\n  let find_or t d ifnotfound =\n    let h = H.hash d in\n    let index = get_index t h in\n    let bucket = t.table.(index) in\n    let hashes = t.hashes.(index) in\n    let sz = length bucket in\n    let rec loop i =\n      if i >= sz then ifnotfound h index\n      else if h = hashes.(i) then begin\n        match get_copy bucket i with\n        | Some v when H.equal v d\n           -> begin match get bucket i with\n              | Some v -> v\n              | None -> loop (i + 1)\n              end\n        | _ -> loop (i + 1)\n      end else loop (i + 1)\n    in\n    loop 0\n\n\n  let merge t d =\n    find_or t d (fun h index -> add_aux t set (Some d) h index; d)\n\n\n  let find t d = find_or t d (fun _h _index -> raise Not_found)\n\n  let find_opt t d =\n    let h = H.hash d in\n    let index = get_index t h in\n    let bucket = t.table.(index) in\n    let hashes = t.hashes.(index) in\n    let sz = length bucket in\n    let rec loop i =\n      if i >= sz then None\n      else if h = hashes.(i) then begin\n        match get_copy bucket i with\n        | Some v when H.equal v d\n           -> begin match get bucket i with\n              | Some _ as v -> v\n              | None -> loop (i + 1)\n              end\n        | _ -> loop (i + 1)\n      end else loop (i + 1)\n    in\n    loop 0\n\n\n  let find_shadow t d iffound ifnotfound =\n    let h = H.hash d in\n    let index = get_index t h in\n    let bucket = t.table.(index) in\n    let hashes = t.hashes.(index) in\n    let sz = length bucket in\n    let rec loop i =\n      if i >= sz then ifnotfound\n      else if h = hashes.(i) then begin\n        match get_copy bucket i with\n        | Some v when H.equal v d -> iffound bucket i\n        | _ -> loop (i + 1)\n      end else loop (i + 1)\n    in\n    loop 0\n\n\n  let remove t d = find_shadow t d (fun w i -> set w i None) ()\n\n\n  let mem t d = find_shadow t d (fun _w _i -> true) false\n\n\n  let find_all t d =\n    let h = H.hash d in\n    let index = get_index t h in\n    let bucket = t.table.(index) in\n    let hashes = t.hashes.(index) in\n    let sz = length bucket in\n    let rec loop i accu =\n      if i >= sz then accu\n      else if h = hashes.(i) then begin\n        match get_copy bucket i with\n        | Some v when H.equal v d\n           -> begin match get bucket i with\n              | Some v -> loop (i + 1) (v :: accu)\n              | None -> loop (i + 1) accu\n              end\n        | _ -> loop (i + 1) accu\n      end else loop (i + 1) accu\n    in\n    loop 0 []\n\n\n  let stats t =\n    let len = Array.length t.table in\n    let lens = Array.map length t.table in\n    Array.sort compare lens;\n    let totlen = Array.fold_left ( + ) 0 lens in\n    (len, count t, totlen, lens.(0), lens.(len/2), lens.(len-1))\n\n\nend\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Pierre Weis, projet Cristal, INRIA Rocquencourt            *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* A pretty-printing facility and definition of formatters for 'parallel'\n   (i.e. unrelated or independent) pretty-printing on multiple out channels. *)\n\n(*\n   The pretty-printing engine internal data structures.\n*)\n\nlet id x = x\n\n(* A devoted type for sizes to avoid confusion\n   between sizes and mere integers. *)\nmodule Size : sig\n  type t\n\n  val to_int : t -> int\n  val of_int : int -> t\n  val zero : t\n  val unknown : t\n  val is_known : t -> bool\nend  = struct\n  type t = int\n\n  let to_int = id\n  let of_int = id\n  let zero = 0\n  let unknown = -1\n  let is_known n = n >= 0\nend\n\n\n\n(* The pretty-printing boxes definition:\n   a pretty-printing box is either\n   - hbox: horizontal box (no line splitting)\n   - vbox: vertical box (every break hint splits the line)\n   - hvbox: horizontal/vertical box\n     (the box behaves as an horizontal box if it fits on\n      the current line, otherwise the box behaves as a vertical box)\n   - hovbox: horizontal or vertical compacting box\n     (the box is compacting material, printing as much material as possible\n      on every lines)\n   - box: horizontal or vertical compacting box with enhanced box structure\n     (the box behaves as an horizontal or vertical box but break hints split\n      the line if splitting would move to the left)\n*)\ntype box_type = CamlinternalFormatBasics.block_type =\n  | Pp_hbox | Pp_vbox | Pp_hvbox | Pp_hovbox | Pp_box | Pp_fits\n\n\n(* The pretty-printing tokens definition:\n   are either text to print or pretty printing\n   elements that drive indentation and line splitting. *)\ntype pp_token =\n  | Pp_text of string          (* normal text *)\n  | Pp_break of {              (* complete break *)\n      fits: string * int * string;   (* line is not split *)\n      breaks: string * int * string; (* line is split *)\n    }\n  | Pp_tbreak of int * int     (* go to next tabulation *)\n  | Pp_stab                    (* set a tabulation *)\n  | Pp_begin of int * box_type (* beginning of a box *)\n  | Pp_end                     (* end of a box *)\n  | Pp_tbegin of tbox          (* beginning of a tabulation box *)\n  | Pp_tend                    (* end of a tabulation box *)\n  | Pp_newline                 (* to force a newline inside a box *)\n  | Pp_if_newline              (* to do something only if this very\n                                  line has been broken *)\n  | Pp_open_tag of stag         (* opening a tag name *)\n  | Pp_close_tag               (* closing the most recently open tag *)\n\nand stag = ..\n\nand tbox = Pp_tbox of int list ref  (* Tabulation box *)\n\ntype tag = string\ntype stag += String_tag of tag\n\n\n(* The pretty-printer queue:\n   pretty-printing material is not written in the output as soon as emitted;\n   instead, the material is simply recorded in the pretty-printer queue,\n   until the enclosing box has a known computed size and proper splitting\n   decisions can be made.\n\n   The pretty-printer queue contains formatting elements to be printed.\n   Each formatting element is a tuple (size, token, length), where\n   - length is the declared length of the token,\n   - size is effective size of the token when it is printed\n     (size is set when the size of the box is known, so that size of break\n      hints are definitive). *)\ntype pp_queue_elem = {\n  mutable size : Size.t;\n  token : pp_token;\n  length : int;\n}\n\n\n(* The pretty-printer queue definition. *)\ntype pp_queue = pp_queue_elem Queue.t\n\n(* The pretty-printer scanning stack. *)\n\n(* The pretty-printer scanning stack: scanning element definition. *)\ntype pp_scan_elem = {\n  left_total : int; (* Value of pp_left_total when the element was enqueued. *)\n  queue_elem : pp_queue_elem\n}\n\n(* The pretty-printer formatting stack:\n   the formatting stack contains the description of all the currently active\n   boxes; the pretty-printer formatting stack is used to split the lines\n   while printing tokens. *)\n\n(* The pretty-printer formatting stack: formatting stack element definition.\n   Each stack element describes a pretty-printing box. *)\ntype pp_format_elem = { box_type : box_type; width : int }\n\n(* The formatter definition.\n   Each formatter value is a pretty-printer instance with all its\n   machinery. *)\ntype formatter = {\n  (* The pretty-printer scanning stack. *)\n  pp_scan_stack : pp_scan_elem Stack.t;\n  (* The pretty-printer formatting stack. *)\n  pp_format_stack : pp_format_elem Stack.t;\n  pp_tbox_stack : tbox Stack.t;\n  (* The pretty-printer semantics tag stack. *)\n  pp_tag_stack : stag Stack.t;\n  pp_mark_stack : stag Stack.t;\n  (* Value of right margin. *)\n  mutable pp_margin : int;\n  (* Minimal space left before margin, when opening a box. *)\n  mutable pp_min_space_left : int;\n  (* Maximum value of indentation:\n     no box can be opened further. *)\n  mutable pp_max_indent : int;\n  (* Space remaining on the current line. *)\n  mutable pp_space_left : int;\n  (* Current value of indentation. *)\n  mutable pp_current_indent : int;\n  (* True when the line has been broken by the pretty-printer. *)\n  mutable pp_is_new_line : bool;\n  (* Total width of tokens already printed. *)\n  mutable pp_left_total : int;\n  (* Total width of tokens ever put in queue. *)\n  mutable pp_right_total : int;\n  (* Current number of open boxes. *)\n  mutable pp_curr_depth : int;\n  (* Maximum number of boxes which can be simultaneously open. *)\n  mutable pp_max_boxes : int;\n  (* Ellipsis string. *)\n  mutable pp_ellipsis : string;\n  (* Output function. *)\n  mutable pp_out_string : string -> int -> int -> unit;\n  (* Flushing function. *)\n  mutable pp_out_flush : unit -> unit;\n  (* Output of new lines. *)\n  mutable pp_out_newline : unit -> unit;\n  (* Output of break hints spaces. *)\n  mutable pp_out_spaces : int -> unit;\n  (* Output of indentation of new lines. *)\n  mutable pp_out_indent : int -> unit;\n  (* Are tags printed ? *)\n  mutable pp_print_tags : bool;\n  (* Are tags marked ? *)\n  mutable pp_mark_tags : bool;\n  (* Find opening and closing markers of tags. *)\n  mutable pp_mark_open_tag : stag -> string;\n  mutable pp_mark_close_tag : stag -> string;\n  mutable pp_print_open_tag : stag -> unit;\n  mutable pp_print_close_tag : stag -> unit;\n  (* The pretty-printer queue. *)\n  pp_queue : pp_queue;\n}\n\n\n(* The formatter specific tag handling functions. *)\ntype formatter_stag_functions = {\n  mark_open_stag : stag -> string;\n  mark_close_stag : stag -> string;\n  print_open_stag : stag -> unit;\n  print_close_stag : stag -> unit;\n}\n\n\n(* The formatter functions to output material. *)\ntype formatter_out_functions = {\n  out_string : string -> int -> int -> unit;\n  out_flush : unit -> unit;\n  out_newline : unit -> unit;\n  out_spaces : int -> unit;\n  out_indent : int -> unit;\n}\n\n\n(*\n\n  Auxiliaries and basic functions.\n\n*)\n\n(* Enter a token in the pretty-printer queue. *)\nlet pp_enqueue state token =\n  state.pp_right_total <- state.pp_right_total + token.length;\n  Queue.add token state.pp_queue\n\n\nlet pp_clear_queue state =\n  state.pp_left_total <- 1; state.pp_right_total <- 1;\n  Queue.clear state.pp_queue\n\n\n(* Pp_infinity: large value for default tokens size.\n\n   Pp_infinity is documented as being greater than 1e10; to avoid\n   confusion about the word 'greater', we choose pp_infinity greater\n   than 1e10 + 1; for correct handling of tests in the algorithm,\n   pp_infinity must be even one more than 1e10 + 1; let's stand on the\n   safe side by choosing 1.e10+10.\n\n   Pp_infinity could probably be 1073741823 that is 2^30 - 1, that is\n   the minimal upper bound for integers; now that max_int is defined,\n   this limit could also be defined as max_int - 1.\n\n   However, before setting pp_infinity to something around max_int, we\n   must carefully double-check all the integer arithmetic operations\n   that involve pp_infinity, since any overflow would wreck havoc the\n   pretty-printing algorithm's invariants. Given that this arithmetic\n   correctness check is difficult and error prone and given that 1e10\n   + 1 is in practice large enough, there is no need to attempt to set\n   pp_infinity to the theoretically maximum limit. It is not worth the\n   burden ! *)\nlet pp_infinity = 1000000010\n\n(* Output functions for the formatter. *)\nlet pp_output_string state s = state.pp_out_string s 0 (String.length s)\nand pp_output_newline state = state.pp_out_newline ()\nand pp_output_spaces state n = state.pp_out_spaces n\nand pp_output_indent state n = state.pp_out_indent n\n\n(* Format a textual token *)\nlet format_pp_text state size text =\n  state.pp_space_left <- state.pp_space_left - size;\n  pp_output_string state text;\n  state.pp_is_new_line <- false\n\n(* Format a string by its length, if not empty *)\nlet format_string state s =\n  if s <> \"\" then format_pp_text state (String.length s) s\n\n(* To format a break, indenting a new line. *)\nlet break_new_line state (before, offset, after) width =\n  format_string state before;\n  pp_output_newline state;\n  state.pp_is_new_line <- true;\n  let indent = state.pp_margin - width + offset in\n  (* Don't indent more than pp_max_indent. *)\n  let real_indent = Int.min state.pp_max_indent indent in\n  state.pp_current_indent <- real_indent;\n  state.pp_space_left <- state.pp_margin - state.pp_current_indent;\n  pp_output_indent state state.pp_current_indent;\n  format_string state after\n\n\n(* To force a line break inside a box: no offset is added. *)\nlet break_line state width = break_new_line state (\"\", 0, \"\") width\n\n(* To format a break that fits on the current line. *)\nlet break_same_line state (before, width, after) =\n  format_string state before;\n  state.pp_space_left <- state.pp_space_left - width;\n  pp_output_spaces state width;\n  format_string state after\n\n\n(* To indent no more than pp_max_indent, if one tries to open a box\n   beyond pp_max_indent, then the box is rejected on the left\n   by simulating a break. *)\nlet pp_force_break_line state =\n  match Stack.top_opt state.pp_format_stack with\n  | None -> pp_output_newline state\n  | Some { box_type; width } ->\n    if width > state.pp_space_left then\n      match box_type with\n      | Pp_fits | Pp_hbox -> ()\n      | Pp_vbox | Pp_hvbox | Pp_hovbox | Pp_box -> break_line state width\n\n\n(* To skip a token, if the previous line has been broken. *)\nlet pp_skip_token state =\n  match Queue.take_opt state.pp_queue with\n  | None -> () (* print_if_newline must have been the last printing command *)\n  | Some { size; length; _ } ->\n    state.pp_left_total <- state.pp_left_total - length;\n    state.pp_space_left <- state.pp_space_left + Size.to_int size\n\n\n(*\n\n  The main pretty printing functions.\n\n*)\n\n(* Formatting a token with a given size. *)\nlet format_pp_token state size = function\n\n  | Pp_text s ->\n    format_pp_text state size s\n\n  | Pp_begin (off, ty) ->\n    let insertion_point = state.pp_margin - state.pp_space_left in\n    if insertion_point > state.pp_max_indent then\n      (* can not open a box right there. *)\n      begin pp_force_break_line state end;\n    let width = state.pp_space_left - off in\n    let box_type =\n      match ty with\n      | Pp_vbox -> Pp_vbox\n      | Pp_hbox | Pp_hvbox | Pp_hovbox | Pp_box | Pp_fits ->\n        if size > state.pp_space_left then ty else Pp_fits in\n    Stack.push { box_type; width } state.pp_format_stack\n\n  | Pp_end ->\n    Stack.pop_opt state.pp_format_stack |> ignore\n\n  | Pp_tbegin (Pp_tbox _ as tbox) ->\n    Stack.push tbox state.pp_tbox_stack\n\n  | Pp_tend ->\n    Stack.pop_opt state.pp_tbox_stack |> ignore\n\n  | Pp_stab ->\n    begin match Stack.top_opt state.pp_tbox_stack with\n    | None -> () (* No open tabulation box. *)\n    | Some (Pp_tbox tabs) ->\n      let rec add_tab n = function\n        | [] -> [n]\n        | x :: l as ls -> if n < x then n :: ls else x :: add_tab n l in\n      tabs := add_tab (state.pp_margin - state.pp_space_left) !tabs\n    end\n\n  | Pp_tbreak (n, off) ->\n    let insertion_point = state.pp_margin - state.pp_space_left in\n    begin match Stack.top_opt state.pp_tbox_stack with\n    | None -> () (* No open tabulation box. *)\n    | Some (Pp_tbox tabs) ->\n      let tab =\n        match !tabs with\n        | [] -> insertion_point\n        | first :: _ ->\n          let rec find = function\n            | head :: tail ->\n              if head >= insertion_point then head else find tail\n            | [] -> first in\n          find !tabs in\n      let offset = tab - insertion_point in\n      if offset >= 0\n      then break_same_line state (\"\", offset + n, \"\")\n      else break_new_line state (\"\", tab + off, \"\") state.pp_margin\n    end\n\n  | Pp_newline ->\n    begin match Stack.top_opt state.pp_format_stack with\n    | None -> pp_output_newline state (* No open box. *)\n    | Some { width; _} -> break_line state width\n    end\n\n  | Pp_if_newline ->\n    if state.pp_current_indent != state.pp_margin - state.pp_space_left\n    then pp_skip_token state\n\n  | Pp_break { fits; breaks } ->\n    let before, off, _ = breaks in\n    begin match Stack.top_opt state.pp_format_stack with\n    | None -> () (* No open box. *)\n    | Some { box_type; width } ->\n      begin match box_type with\n      | Pp_hovbox ->\n        if size + String.length before > state.pp_space_left\n        then break_new_line state breaks width\n        else break_same_line state fits\n      | Pp_box ->\n        (* Have the line just been broken here ? *)\n        if state.pp_is_new_line then break_same_line state fits else\n        if size + String.length before > state.pp_space_left\n          then break_new_line state breaks width else\n        (* break the line here leads to new indentation ? *)\n        if state.pp_current_indent > state.pp_margin - width + off\n        then break_new_line state breaks width\n        else break_same_line state fits\n      | Pp_hvbox -> break_new_line state breaks width\n      | Pp_fits -> break_same_line state fits\n      | Pp_vbox -> break_new_line state breaks width\n      | Pp_hbox -> break_same_line state fits\n      end\n    end\n\n   | Pp_open_tag tag_name ->\n     let marker = state.pp_mark_open_tag tag_name in\n     pp_output_string state marker;\n     Stack.push tag_name state.pp_mark_stack\n\n   | Pp_close_tag ->\n     begin match Stack.pop_opt state.pp_mark_stack with\n     | None -> () (* No more tag to close. *)\n     | Some tag_name ->\n       let marker = state.pp_mark_close_tag tag_name in\n       pp_output_string state marker\n     end\n\n\n(* Print if token size is known else printing is delayed.\n   Printing is delayed when the text waiting in the queue requires\n   more room to format than exists on the current line. *)\nlet rec advance_left state =\n  match Queue.peek_opt state.pp_queue with\n  | None -> () (* No tokens to print *)\n  | Some { size; token; length } ->\n    let pending_count = state.pp_right_total - state.pp_left_total in\n    if Size.is_known size || pending_count >= state.pp_space_left then begin\n      Queue.take state.pp_queue |> ignore; (* Not empty: we peek into it *)\n      let size = if Size.is_known size then Size.to_int size else pp_infinity in\n      format_pp_token state size token;\n      state.pp_left_total <- length + state.pp_left_total;\n      (advance_left [@tailcall]) state\n    end\n\n\n(* To enqueue a token : try to advance. *)\nlet enqueue_advance state tok = pp_enqueue state tok; advance_left state\n\n\n(* To enqueue strings. *)\nlet enqueue_string_as state size s =\n  enqueue_advance state { size; token = Pp_text s; length = Size.to_int size }\n\n\nlet enqueue_string state s =\n  enqueue_string_as state (Size.of_int (String.length s)) s\n\n\n(* Routines for scan stack\n   determine size of boxes. *)\n\n(* The scan_stack is never empty. *)\nlet initialize_scan_stack stack =\n  Stack.clear stack;\n  let queue_elem = { size = Size.unknown; token = Pp_text \"\"; length = 0 } in\n  Stack.push { left_total = -1; queue_elem } stack\n\n(* Setting the size of boxes on scan stack:\n   if ty = true then size of break is set else size of box is set;\n   in each case pp_scan_stack is popped.\n\n   Note:\n   Pattern matching on scan stack is exhaustive, since scan_stack is never\n   empty.\n   Pattern matching on token in scan stack is also exhaustive,\n   since scan_push is used on breaks and opening of boxes. *)\nlet set_size state ty =\n  match Stack.top_opt state.pp_scan_stack with\n  | None -> () (* scan_stack is never empty. *)\n  | Some { left_total; queue_elem } ->\n    let size = Size.to_int queue_elem.size in\n    (* test if scan stack contains any data that is not obsolete. *)\n    if left_total < state.pp_left_total then\n      initialize_scan_stack state.pp_scan_stack\n    else\n      match queue_elem.token with\n      | Pp_break _ | Pp_tbreak (_, _) ->\n        if ty then begin\n          queue_elem.size <- Size.of_int (state.pp_right_total + size);\n          Stack.pop_opt state.pp_scan_stack |> ignore\n        end\n      | Pp_begin (_, _) ->\n        if not ty then begin\n          queue_elem.size <- Size.of_int (state.pp_right_total + size);\n          Stack.pop_opt state.pp_scan_stack |> ignore\n        end\n      | Pp_text _ | Pp_stab | Pp_tbegin _ | Pp_tend | Pp_end\n      | Pp_newline | Pp_if_newline | Pp_open_tag _ | Pp_close_tag ->\n        () (* scan_push is only used for breaks and boxes. *)\n\n\n(* Push a token on pretty-printer scanning stack.\n   If b is true set_size is called. *)\nlet scan_push state b token =\n  pp_enqueue state token;\n  if b then set_size state true;\n  let elem = { left_total = state.pp_right_total; queue_elem = token } in\n  Stack.push elem state.pp_scan_stack\n\n\n(* To open a new box :\n   the user may set the depth bound pp_max_boxes\n   any text nested deeper is printed as the ellipsis string. *)\nlet pp_open_box_gen state indent br_ty =\n  state.pp_curr_depth <- state.pp_curr_depth + 1;\n  if state.pp_curr_depth < state.pp_max_boxes then\n    let size = Size.of_int (- state.pp_right_total) in\n    let elem = { size; token = Pp_begin (indent, br_ty); length = 0 } in\n    scan_push state false elem else\n  if state.pp_curr_depth = state.pp_max_boxes\n  then enqueue_string state state.pp_ellipsis\n\n\n(* The box which is always open. *)\nlet pp_open_sys_box state = pp_open_box_gen state 0 Pp_hovbox\n\n(* Close a box, setting sizes of its sub boxes. *)\nlet pp_close_box state () =\n  if state.pp_curr_depth > 1 then\n  begin\n    if state.pp_curr_depth < state.pp_max_boxes then\n    begin\n      pp_enqueue state { size = Size.zero; token = Pp_end; length = 0 };\n      set_size state true; set_size state false\n    end;\n    state.pp_curr_depth <- state.pp_curr_depth - 1;\n  end\n\n\n(* Open a tag, pushing it on the tag stack. *)\nlet pp_open_stag state tag_name =\n  if state.pp_print_tags then\n  begin\n    Stack.push tag_name state.pp_tag_stack;\n    state.pp_print_open_tag tag_name\n  end;\n  if state.pp_mark_tags then\n    let token = Pp_open_tag tag_name in\n    pp_enqueue state { size = Size.zero; token; length = 0 }\n\n\n(* Close a tag, popping it from the tag stack. *)\nlet pp_close_stag state () =\n  if state.pp_mark_tags then\n    pp_enqueue state { size = Size.zero; token = Pp_close_tag; length = 0 };\n  if state.pp_print_tags then\n    match Stack.pop_opt state.pp_tag_stack with\n    | None -> () (* No more tag to close. *)\n    | Some tag_name ->\n      state.pp_print_close_tag tag_name\n\nlet pp_open_tag state s = pp_open_stag state (String_tag s)\nlet pp_close_tag state () = pp_close_stag state ()\n\nlet pp_set_print_tags state b = state.pp_print_tags <- b\nlet pp_set_mark_tags state b = state.pp_mark_tags <- b\nlet pp_get_print_tags state () = state.pp_print_tags\nlet pp_get_mark_tags state () = state.pp_mark_tags\nlet pp_set_tags state b =\n  pp_set_print_tags state b; pp_set_mark_tags state b\n\n\n(* Handling tag handling functions: get/set functions. *)\nlet pp_get_formatter_stag_functions state () = {\n  mark_open_stag = state.pp_mark_open_tag;\n  mark_close_stag = state.pp_mark_close_tag;\n  print_open_stag = state.pp_print_open_tag;\n  print_close_stag = state.pp_print_close_tag;\n}\n\n\nlet pp_set_formatter_stag_functions state {\n     mark_open_stag = mot;\n     mark_close_stag = mct;\n     print_open_stag = pot;\n     print_close_stag = pct;\n  } =\n  state.pp_mark_open_tag <- mot;\n  state.pp_mark_close_tag <- mct;\n  state.pp_print_open_tag <- pot;\n  state.pp_print_close_tag <- pct\n\n\n(* Initialize pretty-printer. *)\nlet pp_rinit state =\n  pp_clear_queue state;\n  initialize_scan_stack state.pp_scan_stack;\n  Stack.clear state.pp_format_stack;\n  Stack.clear state.pp_tbox_stack;\n  Stack.clear state.pp_tag_stack;\n  Stack.clear state.pp_mark_stack;\n  state.pp_current_indent <- 0;\n  state.pp_curr_depth <- 0;\n  state.pp_space_left <- state.pp_margin;\n  pp_open_sys_box state\n\nlet clear_tag_stack state =\n  Stack.iter (fun _ -> pp_close_tag state ()) state.pp_tag_stack\n\n\n(* Flushing pretty-printer queue. *)\nlet pp_flush_queue state b =\n  clear_tag_stack state;\n  while state.pp_curr_depth > 1 do\n    pp_close_box state ()\n  done;\n  state.pp_right_total <- pp_infinity;\n  advance_left state;\n  if b then pp_output_newline state;\n  pp_rinit state\n\n(*\n\n  Procedures to format values and use boxes.\n\n*)\n\n(* To format a string. *)\nlet pp_print_as_size state size s =\n  if state.pp_curr_depth < state.pp_max_boxes\n  then enqueue_string_as state size s\n\n\nlet pp_print_as state isize s =\n  pp_print_as_size state (Size.of_int isize) s\n\n\nlet pp_print_string state s =\n  pp_print_as state (String.length s) s\n\nlet pp_print_bytes state s =\n  pp_print_as state (Bytes.length s) (Bytes.to_string s)\n\n(* To format an integer. *)\nlet pp_print_int state i = pp_print_string state (Int.to_string i)\n\n(* To format a float. *)\nlet pp_print_float state f = pp_print_string state (string_of_float f)\n\n(* To format a boolean. *)\nlet pp_print_bool state b = pp_print_string state (string_of_bool b)\n\n(* To format a char. *)\nlet pp_print_char state c =\n  pp_print_as state 1 (String.make 1 c)\n\n\n(* Opening boxes. *)\nlet pp_open_hbox state () = pp_open_box_gen state 0 Pp_hbox\nand pp_open_vbox state indent = pp_open_box_gen state indent Pp_vbox\n\nand pp_open_hvbox state indent = pp_open_box_gen state indent Pp_hvbox\nand pp_open_hovbox state indent = pp_open_box_gen state indent Pp_hovbox\nand pp_open_box state indent = pp_open_box_gen state indent Pp_box\n\n\n(* Printing queued text.\n\n   [pp_print_flush] prints all pending items in the pretty-printer queue and\n   then flushes the low level output device of the formatter to actually\n   display printing material.\n\n   [pp_print_newline] behaves as [pp_print_flush] after printing an additional\n   new line. *)\nlet pp_print_newline state () =\n  pp_flush_queue state true; state.pp_out_flush ()\nand pp_print_flush state () =\n  pp_flush_queue state false; state.pp_out_flush ()\n\n\n(* To get a newline when one does not want to close the current box. *)\nlet pp_force_newline state () =\n  if state.pp_curr_depth < state.pp_max_boxes then\n    enqueue_advance state { size = Size.zero; token = Pp_newline; length = 0 }\n\n\n(* To format something, only in case the line has just been broken. *)\nlet pp_print_if_newline state () =\n  if state.pp_curr_depth < state.pp_max_boxes then\n    enqueue_advance state\n      { size = Size.zero; token = Pp_if_newline; length = 0 }\n\n\n(* Generalized break hint that allows printing strings before/after\n   same-line offset (width) or new-line offset *)\nlet pp_print_custom_break state ~fits ~breaks =\n  let before, width, after = fits in\n  if state.pp_curr_depth < state.pp_max_boxes then\n    let size = Size.of_int (- state.pp_right_total) in\n    let token = Pp_break { fits; breaks } in\n    let length = String.length before + width + String.length after in\n    let elem = { size; token; length } in\n    scan_push state true elem\n\n(* Printing break hints:\n   A break hint indicates where a box may be broken.\n   If line is broken then offset is added to the indentation of the current\n   box else (the value of) width blanks are printed. *)\nlet pp_print_break state width offset =\n  pp_print_custom_break state\n    ~fits:(\"\", width, \"\") ~breaks:(\"\", offset, \"\")\n\n\n(* Print a space :\n   a space is a break hint that prints a single space if the break does not\n   split the line;\n   a cut is a break hint that prints nothing if the break does not split the\n   line. *)\nlet pp_print_space state () = pp_print_break state 1 0\nand pp_print_cut state () = pp_print_break state 0 0\n\n\n(* Tabulation boxes. *)\nlet pp_open_tbox state () =\n  state.pp_curr_depth <- state.pp_curr_depth + 1;\n  if state.pp_curr_depth < state.pp_max_boxes then\n    let size = Size.zero in\n    let elem = { size; token = Pp_tbegin (Pp_tbox (ref [])); length = 0 } in\n    enqueue_advance state elem\n\n\n(* Close a tabulation box. *)\nlet pp_close_tbox state () =\n  if state.pp_curr_depth > 1 then\n  begin\n   if state.pp_curr_depth < state.pp_max_boxes then\n     let elem = { size = Size.zero; token = Pp_tend; length = 0 } in\n     enqueue_advance state elem;\n     state.pp_curr_depth <- state.pp_curr_depth - 1\n  end\n\n\n(* Print a tabulation break. *)\nlet pp_print_tbreak state width offset =\n  if state.pp_curr_depth < state.pp_max_boxes then\n    let size = Size.of_int (- state.pp_right_total) in\n    let elem = { size; token = Pp_tbreak (width, offset); length = width } in\n    scan_push state true elem\n\n\nlet pp_print_tab state () = pp_print_tbreak state 0 0\n\nlet pp_set_tab state () =\n  if state.pp_curr_depth < state.pp_max_boxes then\n    let elem = { size = Size.zero; token = Pp_stab; length = 0 } in\n    enqueue_advance state elem\n\n\n(*\n\n  Procedures to control the pretty-printers\n\n*)\n\n(* Set_max_boxes. *)\nlet pp_set_max_boxes state n = if n > 1 then state.pp_max_boxes <- n\n\n(* To know the current maximum number of boxes allowed. *)\nlet pp_get_max_boxes state () = state.pp_max_boxes\n\nlet pp_over_max_boxes state () = state.pp_curr_depth = state.pp_max_boxes\n\n(* Ellipsis. *)\nlet pp_set_ellipsis_text state s = state.pp_ellipsis <- s\nand pp_get_ellipsis_text state () = state.pp_ellipsis\n\n\n(* To set the margin of pretty-printer. *)\nlet pp_limit n =\n  if n < pp_infinity then n else pred pp_infinity\n\n\n(* Internal pretty-printer functions. *)\nlet pp_set_min_space_left state n =\n  if n >= 1 then\n    let n = pp_limit n in\n    state.pp_min_space_left <- n;\n    state.pp_max_indent <- state.pp_margin - state.pp_min_space_left;\n    pp_rinit state\n\n\n(* Initially, we have :\n   pp_max_indent = pp_margin - pp_min_space_left, and\n   pp_space_left = pp_margin. *)\nlet pp_set_max_indent state n =\n  if n > 1 then\n    pp_set_min_space_left state (state.pp_margin - n)\n\n\nlet pp_get_max_indent state () = state.pp_max_indent\n\nlet pp_set_margin state n =\n  if n >= 1 then\n    let n = pp_limit n in\n    state.pp_margin <- n;\n    let new_max_indent =\n      (* Try to maintain max_indent to its actual value. *)\n      if state.pp_max_indent <= state.pp_margin\n      then state.pp_max_indent else\n      (* If possible maintain pp_min_space_left to its actual value,\n         if this leads to a too small max_indent, take half of the\n         new margin, if it is greater than 1. *)\n       Int.max (Int.max (state.pp_margin - state.pp_min_space_left)\n                (state.pp_margin / 2)) 1 in\n    (* Rebuild invariants. *)\n    pp_set_max_indent state new_max_indent\n\n\n(** Geometry functions and types *)\ntype geometry = { max_indent:int; margin: int}\n\nlet validate_geometry {margin; max_indent} =\n  if max_indent < 2 then\n    Error \"max_indent < 2\"\n  else if margin <= max_indent then\n    Error \"margin <= max_indent\"\n  else Ok ()\n\nlet check_geometry geometry =\n  match validate_geometry geometry with\n  | Ok () -> true\n  | Error _ -> false\n\nlet pp_get_margin state () = state.pp_margin\n\nlet pp_set_full_geometry state {margin; max_indent} =\n  pp_set_margin state margin;\n  pp_set_max_indent state max_indent;\n  ()\n\nlet pp_set_geometry state ~max_indent ~margin =\n  let geometry = { max_indent; margin } in\n  match validate_geometry geometry with\n  | Error msg ->\n    raise (Invalid_argument (\"Format.pp_set_geometry: \" ^ msg))\n  | Ok () ->\n    pp_set_full_geometry state geometry\n\nlet pp_safe_set_geometry state ~max_indent ~margin =\n  let geometry = { max_indent; margin } in\n  match validate_geometry geometry with\n  | Error _msg ->\n     ()\n  | Ok () ->\n    pp_set_full_geometry state geometry\n\nlet pp_get_geometry state () =\n  { margin = pp_get_margin state (); max_indent = pp_get_max_indent state () }\n\nlet pp_update_geometry state update =\n  let geometry = pp_get_geometry state () in\n  pp_set_full_geometry state (update geometry)\n\n(* Setting a formatter basic output functions. *)\nlet pp_set_formatter_out_functions state {\n      out_string = f;\n      out_flush = g;\n      out_newline = h;\n      out_spaces = i;\n      out_indent = j;\n    } =\n  state.pp_out_string <- f;\n  state.pp_out_flush <- g;\n  state.pp_out_newline <- h;\n  state.pp_out_spaces <- i;\n  state.pp_out_indent <- j\n\nlet pp_get_formatter_out_functions state () = {\n  out_string = state.pp_out_string;\n  out_flush = state.pp_out_flush;\n  out_newline = state.pp_out_newline;\n  out_spaces = state.pp_out_spaces;\n  out_indent = state.pp_out_indent;\n}\n\n\n(* Setting a formatter basic string output and flush functions. *)\nlet pp_set_formatter_output_functions state f g =\n  state.pp_out_string <- f; state.pp_out_flush <- g\n\nlet pp_get_formatter_output_functions state () =\n  (state.pp_out_string, state.pp_out_flush)\n\n\n(* The default function to output new lines. *)\nlet display_newline state () = state.pp_out_string \"\\n\" 0  1\n\n(* The default function to output spaces. *)\nlet blank_line = String.make 80 ' '\nlet rec display_blanks state n =\n  if n > 0 then\n  if n <= 80 then state.pp_out_string blank_line 0 n else\n  begin\n    state.pp_out_string blank_line 0 80;\n    display_blanks state (n - 80)\n  end\n\n\n(* The default function to output indentation of new lines. *)\nlet display_indent = display_blanks\n\n(* Setting a formatter basic output functions as printing to a given\n   [Pervasive.out_channel] value. *)\nlet pp_set_formatter_out_channel state oc =\n  state.pp_out_string <- output_substring oc;\n  state.pp_out_flush <- (fun () -> flush oc);\n  state.pp_out_newline <- display_newline state;\n  state.pp_out_spaces <- display_blanks state;\n  state.pp_out_indent <- display_indent state\n\n(*\n\n  Defining specific formatters\n\n*)\n\nlet default_pp_mark_open_tag = function\n  | String_tag s -> \"<\" ^ s ^ \">\"\n  | _ -> \"\"\nlet default_pp_mark_close_tag = function\n  | String_tag s -> \"</\" ^ s ^ \">\"\n  | _ -> \"\"\n\nlet default_pp_print_open_tag = ignore\nlet default_pp_print_close_tag = ignore\n\n(* Building a formatter given its basic output functions.\n   Other fields get reasonable default values. *)\nlet pp_make_formatter f g h i j =\n  (* The initial state of the formatter contains a dummy box. *)\n  let pp_queue = Queue.create () in\n  let sys_tok =\n    { size = Size.unknown; token = Pp_begin (0, Pp_hovbox); length = 0 } in\n  Queue.add sys_tok pp_queue;\n  let scan_stack = Stack.create () in\n  initialize_scan_stack scan_stack;\n  Stack.push { left_total = 1; queue_elem = sys_tok } scan_stack;\n  let pp_margin = 78\n  and pp_min_space_left = 10 in\n  {\n    pp_scan_stack = scan_stack;\n    pp_format_stack = Stack.create ();\n    pp_tbox_stack = Stack.create ();\n    pp_tag_stack = Stack.create ();\n    pp_mark_stack = Stack.create ();\n    pp_margin = pp_margin;\n    pp_min_space_left = pp_min_space_left;\n    pp_max_indent = pp_margin - pp_min_space_left;\n    pp_space_left = pp_margin;\n    pp_current_indent = 0;\n    pp_is_new_line = true;\n    pp_left_total = 1;\n    pp_right_total = 1;\n    pp_curr_depth = 1;\n    pp_max_boxes = max_int;\n    pp_ellipsis = \".\";\n    pp_out_string = f;\n    pp_out_flush = g;\n    pp_out_newline = h;\n    pp_out_spaces = i;\n    pp_out_indent = j;\n    pp_print_tags = false;\n    pp_mark_tags = false;\n    pp_mark_open_tag = default_pp_mark_open_tag;\n    pp_mark_close_tag = default_pp_mark_close_tag;\n    pp_print_open_tag = default_pp_print_open_tag;\n    pp_print_close_tag = default_pp_print_close_tag;\n    pp_queue = pp_queue;\n  }\n\n\n(* Build a formatter out of its out functions. *)\nlet formatter_of_out_functions out_funs =\n  pp_make_formatter\n    out_funs.out_string\n    out_funs.out_flush\n    out_funs.out_newline\n    out_funs.out_spaces\n    out_funs.out_indent\n\n\n(* Make a formatter with default functions to output spaces,\n  indentation, and new lines. *)\nlet make_formatter output flush =\n  let ppf = pp_make_formatter output flush ignore ignore ignore in\n  ppf.pp_out_newline <- display_newline ppf;\n  ppf.pp_out_spaces <- display_blanks ppf;\n  ppf.pp_out_indent <- display_indent ppf;\n  ppf\n\n\n(* Make a formatter writing to a given [Pervasive.out_channel] value. *)\nlet formatter_of_out_channel oc =\n  make_formatter (output_substring oc) (fun () -> flush oc)\n\n\n(* Make a formatter writing to a given [Buffer.t] value. *)\nlet formatter_of_buffer b =\n  make_formatter (Buffer.add_substring b) ignore\n\n\n(* Allocating buffer for pretty-printing purposes.\n   Default buffer size is pp_buffer_size or 512.\n*)\nlet pp_buffer_size = 512\nlet pp_make_buffer () = Buffer.create pp_buffer_size\n\n(* The standard (shared) buffer. *)\nlet stdbuf = pp_make_buffer ()\n\n(* Predefined formatters standard formatter to print\n   to [Stdlib.stdout], [Stdlib.stderr], and {!stdbuf}. *)\nlet std_formatter = formatter_of_out_channel Stdlib.stdout\nand err_formatter = formatter_of_out_channel Stdlib.stderr\nand str_formatter = formatter_of_buffer stdbuf\n\n\n(* [flush_buffer_formatter buf ppf] flushes formatter [ppf],\n   then returns the contents of buffer [buf] that is reset.\n   Formatter [ppf] is supposed to print to buffer [buf], otherwise this\n   function is not really useful. *)\nlet flush_buffer_formatter buf ppf =\n  pp_flush_queue ppf false;\n  let s = Buffer.contents buf in\n  Buffer.reset buf;\n  s\n\n\n(* Flush [str_formatter] and get the contents of [stdbuf]. *)\nlet flush_str_formatter () = flush_buffer_formatter stdbuf str_formatter\n\n(*\n  Symbolic pretty-printing\n*)\n\n(*\n  Symbolic pretty-printing is pretty-printing with no low level output.\n\n  When using a symbolic formatter, all regular pretty-printing activities\n  occur but output material is symbolic and stored in a buffer of output\n  items. At the end of pretty-printing, flushing the output buffer allows\n  post-processing of symbolic output before low level output operations.\n*)\n\ntype symbolic_output_item =\n  | Output_flush\n  | Output_newline\n  | Output_string of string\n  | Output_spaces of int\n  | Output_indent of int\n\ntype symbolic_output_buffer = {\n  mutable symbolic_output_contents : symbolic_output_item list;\n}\n\nlet make_symbolic_output_buffer () =\n  { symbolic_output_contents = [] }\n\nlet clear_symbolic_output_buffer sob =\n  sob.symbolic_output_contents <- []\n\nlet get_symbolic_output_buffer sob =\n  List.rev sob.symbolic_output_contents\n\nlet flush_symbolic_output_buffer sob =\n  let items = get_symbolic_output_buffer sob in\n  clear_symbolic_output_buffer sob;\n  items\n\nlet add_symbolic_output_item sob item =\n  sob.symbolic_output_contents <- item :: sob.symbolic_output_contents\n\nlet formatter_of_symbolic_output_buffer sob =\n  let symbolic_flush sob () =\n    add_symbolic_output_item sob Output_flush\n  and symbolic_newline sob () =\n    add_symbolic_output_item sob Output_newline\n  and symbolic_string sob s i n =\n    add_symbolic_output_item sob (Output_string (String.sub s i n))\n  and symbolic_spaces sob n =\n    add_symbolic_output_item sob (Output_spaces n)\n  and symbolic_indent sob n =\n    add_symbolic_output_item sob (Output_indent n) in\n\n  let f = symbolic_string sob\n  and g = symbolic_flush sob\n  and h = symbolic_newline sob\n  and i = symbolic_spaces sob\n  and j = symbolic_indent sob in\n  pp_make_formatter f g h i j\n\n(*\n\n  Basic functions on the 'standard' formatter\n  (the formatter that prints to [Stdlib.stdout]).\n\n*)\n\nlet open_hbox = pp_open_hbox std_formatter\nand open_vbox = pp_open_vbox std_formatter\nand open_hvbox = pp_open_hvbox std_formatter\nand open_hovbox = pp_open_hovbox std_formatter\nand open_box = pp_open_box std_formatter\nand close_box = pp_close_box std_formatter\nand open_tag = pp_open_tag std_formatter\nand close_tag = pp_close_tag std_formatter\nand open_stag = pp_open_stag std_formatter\nand close_stag = pp_close_stag std_formatter\nand print_as = pp_print_as std_formatter\nand print_string = pp_print_string std_formatter\nand print_bytes = pp_print_bytes std_formatter\nand print_int = pp_print_int std_formatter\nand print_float = pp_print_float std_formatter\nand print_char = pp_print_char std_formatter\nand print_bool = pp_print_bool std_formatter\nand print_break = pp_print_break std_formatter\nand print_cut = pp_print_cut std_formatter\nand print_space = pp_print_space std_formatter\nand force_newline = pp_force_newline std_formatter\nand print_flush = pp_print_flush std_formatter\nand print_newline = pp_print_newline std_formatter\nand print_if_newline = pp_print_if_newline std_formatter\n\nand open_tbox = pp_open_tbox std_formatter\nand close_tbox = pp_close_tbox std_formatter\nand print_tbreak = pp_print_tbreak std_formatter\n\nand set_tab = pp_set_tab std_formatter\nand print_tab = pp_print_tab std_formatter\n\nand set_margin = pp_set_margin std_formatter\nand get_margin = pp_get_margin std_formatter\n\nand set_max_indent = pp_set_max_indent std_formatter\nand get_max_indent = pp_get_max_indent std_formatter\n\nand set_geometry = pp_set_geometry std_formatter\nand safe_set_geometry = pp_safe_set_geometry std_formatter\nand get_geometry = pp_get_geometry std_formatter\nand update_geometry = pp_update_geometry std_formatter\n\nand set_max_boxes = pp_set_max_boxes std_formatter\nand get_max_boxes = pp_get_max_boxes std_formatter\nand over_max_boxes = pp_over_max_boxes std_formatter\n\nand set_ellipsis_text = pp_set_ellipsis_text std_formatter\nand get_ellipsis_text = pp_get_ellipsis_text std_formatter\n\nand set_formatter_out_channel =\n  pp_set_formatter_out_channel std_formatter\n\nand set_formatter_out_functions =\n  pp_set_formatter_out_functions std_formatter\nand get_formatter_out_functions =\n  pp_get_formatter_out_functions std_formatter\n\nand set_formatter_output_functions =\n  pp_set_formatter_output_functions std_formatter\nand get_formatter_output_functions =\n  pp_get_formatter_output_functions std_formatter\n\nand set_formatter_stag_functions =\n  pp_set_formatter_stag_functions std_formatter\nand get_formatter_stag_functions =\n  pp_get_formatter_stag_functions std_formatter\nand set_print_tags =\n  pp_set_print_tags std_formatter\nand get_print_tags =\n  pp_get_print_tags std_formatter\nand set_mark_tags =\n  pp_set_mark_tags std_formatter\nand get_mark_tags =\n  pp_get_mark_tags std_formatter\nand set_tags =\n  pp_set_tags std_formatter\n\n\n(* Convenience functions *)\n\n(* To format a list *)\nlet rec pp_print_list ?(pp_sep = pp_print_cut) pp_v ppf = function\n  | [] -> ()\n  | [v] -> pp_v ppf v\n  | v :: vs ->\n    pp_v ppf v;\n    pp_sep ppf ();\n    pp_print_list ~pp_sep pp_v ppf vs\n\n(* To format a sequence *)\nlet rec pp_print_seq_in ~pp_sep pp_v ppf seq =\n  match seq () with\n  | Seq.Nil -> ()\n  | Seq.Cons (v, seq) ->\n    pp_sep ppf ();\n    pp_v ppf v;\n    pp_print_seq_in ~pp_sep pp_v ppf seq\n\nlet pp_print_seq ?(pp_sep = pp_print_cut) pp_v ppf seq =\n  match seq () with\n  | Seq.Nil -> ()\n  | Seq.Cons (v, seq) ->\n    pp_v ppf v;\n    pp_print_seq_in ~pp_sep pp_v ppf seq\n\n(* To format free-flowing text *)\nlet pp_print_text ppf s =\n  let len = String.length s in\n  let left = ref 0 in\n  let right = ref 0 in\n  let flush () =\n    pp_print_string ppf (String.sub s !left (!right - !left));\n    incr right; left := !right;\n  in\n  while (!right <> len) do\n    match s.[!right] with\n      | '\\n' ->\n        flush ();\n        pp_force_newline ppf ()\n      | ' ' ->\n        flush (); pp_print_space ppf ()\n      (* there is no specific support for '\\t'\n         as it is unclear what a right semantics would be *)\n      | _ -> incr right\n  done;\n  if !left <> len then flush ()\n\nlet pp_print_option ?(none = fun _ () -> ()) pp_v ppf = function\n| None -> none ppf ()\n| Some v -> pp_v ppf v\n\nlet pp_print_result ~ok ~error ppf = function\n| Ok v -> ok ppf v\n| Error e -> error ppf e\n\nlet pp_print_either ~left ~right ppf = function\n| Either.Left l -> left ppf l\n| Either.Right r -> right ppf r\n\n (**************************************************************)\n\nlet compute_tag output tag_acc =\n  let buf = Buffer.create 16 in\n  let ppf = formatter_of_buffer buf in\n  output ppf tag_acc;\n  pp_print_flush ppf ();\n  let len = Buffer.length buf in\n  if len < 2 then Buffer.contents buf\n  else Buffer.sub buf 1 (len - 2)\n\n (**************************************************************\n\n  Defining continuations to be passed as arguments of\n  CamlinternalFormat.make_printf.\n\n  **************************************************************)\n\nopen CamlinternalFormatBasics\nopen CamlinternalFormat\n\n(* Interpret a formatting entity on a formatter. *)\nlet output_formatting_lit ppf fmting_lit = match fmting_lit with\n  | Close_box                 -> pp_close_box ppf ()\n  | Close_tag                 -> pp_close_tag ppf ()\n  | Break (_, width, offset)  -> pp_print_break ppf width offset\n  | FFlush                    -> pp_print_flush ppf ()\n  | Force_newline             -> pp_force_newline ppf ()\n  | Flush_newline             -> pp_print_newline ppf ()\n  | Magic_size (_, _)         -> ()\n  | Escaped_at                -> pp_print_char ppf '@'\n  | Escaped_percent           -> pp_print_char ppf '%'\n  | Scan_indic c              -> pp_print_char ppf '@'; pp_print_char ppf c\n\n(* Recursively output an \"accumulator\" containing a reversed list of\n   printing entities (string, char, flus, ...) in an output_stream. *)\n(* Differ from Printf.output_acc by the interpretation of formatting. *)\n(* Used as a continuation of CamlinternalFormat.make_printf. *)\nlet rec output_acc ppf acc = match acc with\n  | Acc_string_literal (Acc_formatting_lit (p, Magic_size (_, size)), s)\n  | Acc_data_string (Acc_formatting_lit (p, Magic_size (_, size)), s) ->\n    output_acc ppf p;\n    pp_print_as_size ppf (Size.of_int size) s;\n  | Acc_char_literal (Acc_formatting_lit (p, Magic_size (_, size)), c)\n  | Acc_data_char (Acc_formatting_lit (p, Magic_size (_, size)), c) ->\n    output_acc ppf p;\n    pp_print_as_size ppf (Size.of_int size) (String.make 1 c);\n  | Acc_formatting_lit (p, f) ->\n    output_acc ppf p;\n    output_formatting_lit ppf f;\n  | Acc_formatting_gen (p, Acc_open_tag acc') ->\n    output_acc ppf p;\n    pp_open_stag ppf (String_tag (compute_tag output_acc acc'))\n  | Acc_formatting_gen (p, Acc_open_box acc') ->\n    output_acc ppf p;\n    let (indent, bty) = open_box_of_string (compute_tag output_acc acc') in\n    pp_open_box_gen ppf indent bty\n  | Acc_string_literal (p, s)\n  | Acc_data_string (p, s)   -> output_acc ppf p; pp_print_string ppf s;\n  | Acc_char_literal (p, c)\n  | Acc_data_char (p, c)     -> output_acc ppf p; pp_print_char ppf c;\n  | Acc_delay (p, f)         -> output_acc ppf p; f ppf;\n  | Acc_flush p              -> output_acc ppf p; pp_print_flush ppf ();\n  | Acc_invalid_arg (p, msg) -> output_acc ppf p; invalid_arg msg;\n  | End_of_acc               -> ()\n\n(* Recursively output an \"accumulator\" containing a reversed list of\n   printing entities (string, char, flus, ...) in a buffer. *)\n(* Differ from Printf.bufput_acc by the interpretation of formatting. *)\n(* Used as a continuation of CamlinternalFormat.make_printf. *)\nlet rec strput_acc ppf acc = match acc with\n  | Acc_string_literal (Acc_formatting_lit (p, Magic_size (_, size)), s)\n  | Acc_data_string (Acc_formatting_lit (p, Magic_size (_, size)), s) ->\n    strput_acc ppf p;\n    pp_print_as_size ppf (Size.of_int size) s;\n  | Acc_char_literal (Acc_formatting_lit (p, Magic_size (_, size)), c)\n  | Acc_data_char (Acc_formatting_lit (p, Magic_size (_, size)), c) ->\n    strput_acc ppf p;\n    pp_print_as_size ppf (Size.of_int size) (String.make 1 c);\n  | Acc_delay (Acc_formatting_lit (p, Magic_size (_, size)), f) ->\n    strput_acc ppf p;\n    pp_print_as_size ppf (Size.of_int size) (f ());\n  | Acc_formatting_lit (p, f) ->\n    strput_acc ppf p;\n    output_formatting_lit ppf f;\n  | Acc_formatting_gen (p, Acc_open_tag acc') ->\n    strput_acc ppf p;\n    pp_open_stag ppf (String_tag (compute_tag strput_acc acc'))\n  | Acc_formatting_gen (p, Acc_open_box acc') ->\n    strput_acc ppf p;\n    let (indent, bty) = open_box_of_string (compute_tag strput_acc acc') in\n    pp_open_box_gen ppf indent bty\n  | Acc_string_literal (p, s)\n  | Acc_data_string (p, s)   -> strput_acc ppf p; pp_print_string ppf s;\n  | Acc_char_literal (p, c)\n  | Acc_data_char (p, c)     -> strput_acc ppf p; pp_print_char ppf c;\n  | Acc_delay (p, f)         -> strput_acc ppf p; pp_print_string ppf (f ());\n  | Acc_flush p              -> strput_acc ppf p; pp_print_flush ppf ();\n  | Acc_invalid_arg (p, msg) -> strput_acc ppf p; invalid_arg msg;\n  | End_of_acc               -> ()\n\n(*\n\n  Defining [fprintf] and various flavors of [fprintf].\n\n*)\n\nlet kfprintf k ppf (Format (fmt, _)) =\n  make_printf\n    (fun acc -> output_acc ppf acc; k ppf)\n    End_of_acc fmt\n\nand ikfprintf k ppf (Format (fmt, _)) =\n  make_iprintf k ppf fmt\n\nlet ifprintf _ppf (Format (fmt, _)) =\n  make_iprintf ignore () fmt\n\nlet fprintf ppf = kfprintf ignore ppf\nlet printf fmt = fprintf std_formatter fmt\nlet eprintf fmt = fprintf err_formatter fmt\n\nlet kdprintf k (Format (fmt, _)) =\n  make_printf\n    (fun acc -> k (fun ppf -> output_acc ppf acc))\n    End_of_acc fmt\n\nlet dprintf fmt = kdprintf (fun i -> i) fmt\n\nlet ksprintf k (Format (fmt, _)) =\n  let b = pp_make_buffer () in\n  let ppf = formatter_of_buffer b in\n  let k acc =\n    strput_acc ppf acc;\n    k (flush_buffer_formatter b ppf) in\n  make_printf k End_of_acc fmt\n\n\nlet sprintf fmt = ksprintf id fmt\n\nlet kasprintf k (Format (fmt, _)) =\n  let b = pp_make_buffer () in\n  let ppf = formatter_of_buffer b in\n  let k acc =\n    output_acc ppf acc;\n    k (flush_buffer_formatter b ppf) in\n  make_printf k End_of_acc fmt\n\n\nlet asprintf fmt = kasprintf id fmt\n\n(* Flushing standard formatters at end of execution. *)\n\nlet flush_standard_formatters () =\n  pp_print_flush std_formatter ();\n  pp_print_flush err_formatter ()\n\nlet () = at_exit flush_standard_formatters\n\n(*\n\n  Deprecated stuff.\n\n*)\n\n(* Deprecated : subsumed by pp_set_formatter_out_functions *)\nlet pp_set_all_formatter_output_functions state\n    ~out:f ~flush:g ~newline:h ~spaces:i =\n  pp_set_formatter_output_functions state f g;\n  state.pp_out_newline <- h;\n  state.pp_out_spaces <- i\n\n(* Deprecated : subsumed by pp_get_formatter_out_functions *)\nlet pp_get_all_formatter_output_functions state () =\n  (state.pp_out_string, state.pp_out_flush,\n   state.pp_out_newline, state.pp_out_spaces)\n\n\n(* Deprecated : subsumed by set_formatter_out_functions *)\nlet set_all_formatter_output_functions =\n  pp_set_all_formatter_output_functions std_formatter\n\n\n(* Deprecated : subsumed by get_formatter_out_functions *)\nlet get_all_formatter_output_functions =\n  pp_get_all_formatter_output_functions std_formatter\n\n\n(* Deprecated : error prone function, do not use it.\n   This function is neither compositional nor incremental, since it flushes\n   the pretty-printer queue at each call.\n   To get the same functionality, define a formatter of your own writing to\n   the buffer argument, as in\n   let ppf = formatter_of_buffer b\n   then use {!fprintf ppf} as usual. *)\nlet bprintf b (Format (fmt, _) : ('a, formatter, unit) format) =\n  let ppf = formatter_of_buffer b in\n  let k acc = output_acc ppf acc; pp_flush_queue ppf false in\n  make_printf k End_of_acc fmt\n\n\n(* Deprecated : alias for ksprintf. *)\nlet kprintf = ksprintf\n\n\n\n(* Deprecated tag functions *)\n\ntype formatter_tag_functions = {\n  mark_open_tag : tag -> string;\n  mark_close_tag : tag -> string;\n  print_open_tag : tag -> unit;\n  print_close_tag : tag -> unit;\n}\n\n\nlet pp_set_formatter_tag_functions state {\n     mark_open_tag = mot;\n     mark_close_tag = mct;\n     print_open_tag = pot;\n     print_close_tag = pct;\n   } =\n  let stringify f e = function String_tag s -> f s | _ -> e in\n  state.pp_mark_open_tag <- stringify mot \"\";\n  state.pp_mark_close_tag <- stringify mct \"\";\n  state.pp_print_open_tag <- stringify pot ();\n  state.pp_print_close_tag <- stringify pct ()\n\nlet pp_get_formatter_tag_functions fmt () =\n  let funs = pp_get_formatter_stag_functions fmt () in\n  let mark_open_tag s = funs.mark_open_stag (String_tag s) in\n  let mark_close_tag s = funs.mark_close_stag (String_tag s) in\n  let print_open_tag s = funs.print_open_stag (String_tag s) in\n  let print_close_tag s = funs.print_close_stag (String_tag s) in\n  {mark_open_tag; mark_close_tag; print_open_tag; print_close_tag}\n\nlet set_formatter_tag_functions =\n  pp_set_formatter_tag_functions std_formatter\nand get_formatter_tag_functions =\n  pp_get_formatter_tag_functions std_formatter\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Pierre Weis, projet Cristal, INRIA Rocquencourt            *)\n(*                                                                        *)\n(*   Copyright 2002 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\nopen CamlinternalFormatBasics\nopen CamlinternalFormat\n\n(* alias to avoid warning for ambiguity between\n   Stdlib.format6\n   and CamlinternalFormatBasics.format6\n\n   (the former is in fact an alias for the latter,\n    but the ambiguity warning doesn't care)\n*)\ntype ('a, 'b, 'c, 'd, 'e, 'f) format6 =\n  ('a, 'b, 'c, 'd, 'e, 'f) Stdlib.format6\n\n\n(* The run-time library for scanners. *)\n\n(* Scanning buffers. *)\nmodule type SCANNING = sig\n\n  type in_channel\n\n  type scanbuf = in_channel\n\n  type file_name = string\n\n  val stdin : in_channel\n  (* The scanning buffer reading from [Stdlib.stdin].\n     [stdib] is equivalent to [Scanning.from_channel Stdlib.stdin]. *)\n\n  val stdib : in_channel\n  (* An alias for [Scanf.stdin], the scanning buffer reading from\n     [Stdlib.stdin]. *)\n\n  val next_char : scanbuf -> char\n  (* [Scanning.next_char ib] advance the scanning buffer for\n     one character.\n     If no more character can be read, sets a end of file condition and\n     returns '\\000'. *)\n\n  val invalidate_current_char : scanbuf -> unit\n  (* [Scanning.invalidate_current_char ib] mark the current_char as already\n     scanned. *)\n\n  val peek_char : scanbuf -> char\n  (* [Scanning.peek_char ib] returns the current char available in\n     the buffer or reads one if necessary (when the current character is\n     already scanned).\n     If no character can be read, sets an end of file condition and\n     returns '\\000'. *)\n\n  val checked_peek_char : scanbuf -> char\n  (* Same as [Scanning.peek_char] above but always returns a valid char or\n     fails: instead of returning a null char when the reading method of the\n     input buffer has reached an end of file, the function raises exception\n     [End_of_file]. *)\n\n  val store_char : int -> scanbuf -> char -> int\n  (* [Scanning.store_char lim ib c] adds [c] to the token buffer\n     of the scanning buffer [ib]. It also advances the scanning buffer for\n     one character and returns [lim - 1], indicating the new limit for the\n     length of the current token. *)\n\n  val skip_char : int -> scanbuf -> int\n  (* [Scanning.skip_char lim ib] ignores the current character. *)\n\n  val ignore_char : int -> scanbuf -> int\n  (* [Scanning.ignore_char ib lim] ignores the current character and\n     decrements the limit. *)\n\n  val token : scanbuf -> string\n  (* [Scanning.token ib] returns the string stored into the token\n     buffer of the scanning buffer: it returns the token matched by the\n     format. *)\n\n  val reset_token : scanbuf -> unit\n  (* [Scanning.reset_token ib] resets the token buffer of\n     the given scanning buffer. *)\n\n  val char_count : scanbuf -> int\n  (* [Scanning.char_count ib] returns the number of characters\n     read so far from the given buffer. *)\n\n  val line_count : scanbuf -> int\n  (* [Scanning.line_count ib] returns the number of new line\n     characters read so far from the given buffer. *)\n\n  val token_count : scanbuf -> int\n  (* [Scanning.token_count ib] returns the number of tokens read\n     so far from [ib]. *)\n\n  val eof : scanbuf -> bool\n  (* [Scanning.eof ib] returns the end of input condition\n     of the given buffer. *)\n\n  val end_of_input : scanbuf -> bool\n  (* [Scanning.end_of_input ib] tests the end of input condition\n     of the given buffer (if no char has ever been read, an attempt to\n     read one is performed). *)\n\n  val beginning_of_input : scanbuf -> bool\n  (* [Scanning.beginning_of_input ib] tests the beginning of input\n     condition of the given buffer. *)\n\n  val name_of_input : scanbuf -> string\n  (* [Scanning.name_of_input ib] returns the name of the character\n     source for input buffer [ib]. *)\n\n  val open_in : file_name -> in_channel\n  val open_in_bin : file_name -> in_channel\n  val from_file : file_name -> in_channel\n  val from_file_bin : file_name -> in_channel\n  val from_string : string -> in_channel\n  val from_function : (unit -> char) -> in_channel\n  val from_channel : Stdlib.in_channel -> in_channel\n\n  val close_in : in_channel -> unit\n\n  val memo_from_channel : Stdlib.in_channel -> in_channel\n  (* Obsolete. *)\n\nend\n\n\nmodule Scanning : SCANNING = struct\n\n  (* The run-time library for scanf. *)\n\n  type file_name = string\n\n  type in_channel_name =\n    | From_channel of Stdlib.in_channel\n    | From_file of file_name * Stdlib.in_channel\n    | From_function\n    | From_string\n\n\n  type in_channel = {\n    mutable ic_eof : bool;\n    mutable ic_current_char : char;\n    mutable ic_current_char_is_valid : bool;\n    mutable ic_char_count : int;\n    mutable ic_line_count : int;\n    mutable ic_token_count : int;\n    ic_get_next_char : unit -> char;\n    ic_token_buffer : Buffer.t;\n    ic_input_name : in_channel_name;\n  }\n\n\n  type scanbuf = in_channel\n\n  let null_char = '\\000'\n\n  (* Reads a new character from input buffer.\n     Next_char never fails, even in case of end of input:\n     it then simply sets the end of file condition. *)\n  let next_char ib =\n    try\n      let c = ib.ic_get_next_char () in\n      ib.ic_current_char <- c;\n      ib.ic_current_char_is_valid <- true;\n      ib.ic_char_count <- succ ib.ic_char_count;\n      if c = '\\n' then ib.ic_line_count <- succ ib.ic_line_count;\n      c with\n    | End_of_file ->\n      let c = null_char in\n      ib.ic_current_char <- c;\n      ib.ic_current_char_is_valid <- false;\n      ib.ic_eof <- true;\n      c\n\n\n  let peek_char ib =\n    if ib.ic_current_char_is_valid\n    then ib.ic_current_char\n    else next_char ib\n\n\n  (* Returns a valid current char for the input buffer. In particular\n     no irrelevant null character (as set by [next_char] in case of end\n     of input) is returned, since [End_of_file] is raised when\n     [next_char] sets the end of file condition while trying to read a\n     new character. *)\n  let checked_peek_char ib =\n    let c = peek_char ib in\n    if ib.ic_eof then raise End_of_file;\n    c\n\n\n  let end_of_input ib =\n    ignore (peek_char ib);\n    ib.ic_eof\n\n\n  let eof ib = ib.ic_eof\n\n  let beginning_of_input ib = ib.ic_char_count = 0\n\n  let name_of_input ib =\n    match ib.ic_input_name with\n    | From_channel _ic -> \"unnamed Stdlib input channel\"\n    | From_file (fname, _ic) -> fname\n    | From_function -> \"unnamed function\"\n    | From_string -> \"unnamed character string\"\n\n\n  let char_count ib =\n    if ib.ic_current_char_is_valid\n    then ib.ic_char_count - 1\n    else ib.ic_char_count\n\n\n  let line_count ib = ib.ic_line_count\n\n  let reset_token ib = Buffer.reset ib.ic_token_buffer\n\n  let invalidate_current_char ib = ib.ic_current_char_is_valid <- false\n\n  let token ib =\n    let token_buffer = ib.ic_token_buffer in\n    let tok = Buffer.contents token_buffer in\n    Buffer.clear token_buffer;\n    ib.ic_token_count <- succ ib.ic_token_count;\n    tok\n\n\n  let token_count ib = ib.ic_token_count\n\n  let skip_char width ib =\n    invalidate_current_char ib;\n    width\n\n\n  let ignore_char width ib = skip_char (width - 1) ib\n\n  let store_char width ib c =\n    Buffer.add_char ib.ic_token_buffer c;\n    ignore_char width ib\n\n\n  let default_token_buffer_size = 1024\n\n  let create iname next = {\n    ic_eof = false;\n    ic_current_char = null_char;\n    ic_current_char_is_valid = false;\n    ic_char_count = 0;\n    ic_line_count = 0;\n    ic_token_count = 0;\n    ic_get_next_char = next;\n    ic_token_buffer = Buffer.create default_token_buffer_size;\n    ic_input_name = iname;\n  }\n\n\n  let from_string s =\n    let i = ref 0 in\n    let len = String.length s in\n    let next () =\n      if !i >= len then raise End_of_file else\n      let c = s.[!i] in\n      incr i;\n      c in\n    create From_string next\n\n\n  let from_function = create From_function\n\n  (* Scanning from an input channel. *)\n\n  (* Position of the problem:\n\n     We cannot prevent the scanning mechanism to use one lookahead character,\n     if needed by the semantics of the format string specifications (e.g. a\n     trailing 'skip space' specification in the format string); in this case,\n     the mandatory lookahead character is indeed read from the input and not\n     used to return the token read. It is thus mandatory to be able to store\n     an unused lookahead character somewhere to get it as the first character\n     of the next scan.\n\n     To circumvent this problem, all the scanning functions get a low level\n     input buffer argument where they store the lookahead character when\n     needed; additionally, the input buffer is the only source of character of\n     a scanner. The [scanbuf] input buffers are defined in module {!Scanning}.\n\n     Now we understand that it is extremely important that related and\n     successive calls to scanners indeed read from the same input buffer.\n     In effect, if a scanner [scan1] is reading from [ib1] and stores an\n     unused lookahead character [c1] into its input buffer [ib1], then\n     another scanner [scan2] not reading from the same buffer [ib1] will miss\n     the character [c1], seemingly vanished in the air from the point of view\n     of [scan2].\n\n     This mechanism works perfectly to read from strings, from files, and from\n     functions, since in those cases, allocating two buffers reading from the\n     same source is unnatural.\n\n     Still, there is a difficulty in the case of scanning from an input\n     channel. In effect, when scanning from an input channel [ic], this channel\n     may not have been allocated from within this library. Hence, it may be\n     shared (two functions of the user's program may successively read from\n     [ic]). This is highly error prone since, one of the function may seek the\n     input channel, while the other function has still an unused lookahead\n     character in its input buffer. In conclusion, you should never mix direct\n     low level reading and high level scanning from the same input channel.\n\n  *)\n\n  (* Perform bufferized input to improve efficiency. *)\n  let file_buffer_size = ref 1024\n\n  (* The scanner closes the input channel at end of input. *)\n  let scan_close_at_end ic = Stdlib.close_in ic; raise End_of_file\n\n  (* The scanner does not close the input channel at end of input:\n     it just raises [End_of_file]. *)\n  let scan_raise_at_end _ic = raise End_of_file\n\n  let from_ic scan_close_ic iname ic =\n    let len = !file_buffer_size in\n    let buf = Bytes.create len in\n    let i = ref 0 in\n    let lim = ref 0 in\n    let eof = ref false in\n    let next () =\n      if !i < !lim then begin let c = Bytes.get buf !i in incr i; c end else\n      if !eof then raise End_of_file else begin\n        lim := input ic buf 0 len;\n        if !lim = 0 then begin eof := true; scan_close_ic ic end else begin\n          i := 1;\n          Bytes.get buf 0\n        end\n      end in\n    create iname next\n\n\n  let from_ic_close_at_end = from_ic scan_close_at_end\n  let from_ic_raise_at_end = from_ic scan_raise_at_end\n\n  (* The scanning buffer reading from [Stdlib.stdin].\n     One could try to define [stdib] as a scanning buffer reading a character\n     at a time (no bufferization at all), but unfortunately the top-level\n     interaction would be wrong. This is due to some kind of\n     'race condition' when reading from [Stdlib.stdin],\n     since the interactive compiler and [Scanf.scanf] will simultaneously\n     read the material they need from [Stdlib.stdin]; then, confusion\n     will result from what should be read by the top-level and what should be\n     read by [Scanf.scanf].\n     This is even more complicated by the one character lookahead that\n     [Scanf.scanf] is sometimes obliged to maintain: the lookahead character\n     will be available for the next [Scanf.scanf] entry, seemingly coming from\n     nowhere.\n     Also no [End_of_file] is raised when reading from stdin: if not enough\n     characters have been read, we simply ask to read more. *)\n  let stdin =\n    from_ic scan_raise_at_end\n      (From_file (\"-\", Stdlib.stdin)) Stdlib.stdin\n\n\n  let stdib = stdin\n\n  let open_in_file open_in fname =\n    match fname with\n    | \"-\" -> stdin\n    | fname ->\n      let ic = open_in fname in\n      from_ic_close_at_end (From_file (fname, ic)) ic\n\n\n  let open_in = open_in_file Stdlib.open_in\n  let open_in_bin = open_in_file Stdlib.open_in_bin\n\n  let from_file = open_in\n  let from_file_bin = open_in_bin\n\n  let from_channel ic =\n    from_ic_raise_at_end (From_channel ic) ic\n\n\n  let close_in ib =\n    match ib.ic_input_name with\n    | From_channel ic ->\n      Stdlib.close_in ic\n    | From_file (_fname, ic) -> Stdlib.close_in ic\n    | From_function | From_string -> ()\n\n\n  (*\n     Obsolete: a memo [from_channel] version to build a [Scanning.in_channel]\n     scanning buffer out of a [Stdlib.in_channel].\n     This function was used to try to preserve the scanning\n     semantics for the (now obsolete) function [fscanf].\n     Given that all scanner must read from a [Scanning.in_channel] scanning\n     buffer, [fscanf] must read from one!\n     More precisely, given [ic], all successive calls [fscanf ic] must read\n     from the same scanning buffer.\n     This obliged this library to allocated scanning buffers that were\n     not properly garbage collectable, hence leading to memory leaks.\n     If you need to read from a [Stdlib.in_channel] input channel\n     [ic], simply define a [Scanning.in_channel] formatted input channel as in\n     [let ib = Scanning.from_channel ic], then use [Scanf.bscanf ib] as usual.\n  *)\n  let memo_from_ic =\n    let memo = ref [] in\n    (fun scan_close_ic ic ->\n     try List.assq ic !memo with\n     | Not_found ->\n       let ib =\n         from_ic scan_close_ic (From_channel ic) ic in\n       memo := (ic, ib) :: !memo;\n       ib)\n\n\n  (* Obsolete: see {!memo_from_ic} above. *)\n  let memo_from_channel = memo_from_ic scan_raise_at_end\n\nend\n\n\n(* Formatted input functions. *)\n\ntype ('a, 'b, 'c, 'd) scanner =\n     ('a, Scanning.in_channel, 'b, 'c, 'a -> 'd, 'd) format6 -> 'c\n\n\n(* Reporting errors. *)\nexception Scan_failure of string\n\nlet bad_input s = raise (Scan_failure s)\n\nlet bad_input_escape c =\n  bad_input (Printf.sprintf \"illegal escape character %C\" c)\n\n\nlet bad_token_length message =\n  bad_input\n    (Printf.sprintf\n       \"scanning of %s failed: \\\n        the specified length was too short for token\"\n       message)\n\n\nlet bad_end_of_input message =\n  bad_input\n    (Printf.sprintf\n       \"scanning of %s failed: \\\n        premature end of file occurred before end of token\"\n       message)\n\n\nlet bad_float () =\n  bad_input \"no dot or exponent part found in float token\"\n\n\nlet bad_hex_float () =\n  bad_input \"not a valid float in hexadecimal notation\"\n\n\nlet character_mismatch_err c ci =\n  Printf.sprintf \"looking for %C, found %C\" c ci\n\n\nlet character_mismatch c ci =\n  bad_input (character_mismatch_err c ci)\n\n\nlet rec skip_whites ib =\n  let c = Scanning.peek_char ib in\n  if not (Scanning.eof ib) then begin\n    match c with\n    | ' ' | '\\t' | '\\n' | '\\r' ->\n      Scanning.invalidate_current_char ib; skip_whites ib\n    | _ -> ()\n  end\n\n\n(* Checking that [c] is indeed in the input, then skips it.\n   In this case, the character [c] has been explicitly specified in the\n   format as being mandatory in the input; hence we should fail with\n   [End_of_file] in case of end_of_input.\n   (Remember that [Scan_failure] is raised only when (we can prove by\n   evidence) that the input does not match the format string given. We must\n   thus differentiate [End_of_file] as an error due to lack of input, and\n   [Scan_failure] which is due to provably wrong input. I am not sure this is\n   worth the burden: it is complex and somehow subliminal; should be clearer\n   to fail with Scan_failure \"Not enough input to complete scanning\"!)\n\n   That's why, waiting for a better solution, we use checked_peek_char here.\n   We are also careful to treat \"\\r\\n\" in the input as an end of line marker:\n   it always matches a '\\n' specification in the input format string. *)\nlet rec check_char ib c =\n  match c with\n  | ' ' -> skip_whites ib\n  | '\\n' -> check_newline ib\n  | c -> check_this_char ib c\n\nand check_this_char ib c =\n  let ci = Scanning.checked_peek_char ib in\n  if ci = c then Scanning.invalidate_current_char ib else\n  character_mismatch c ci\n\nand check_newline ib =\n  let ci = Scanning.checked_peek_char ib in\n  match ci with\n  | '\\n' -> Scanning.invalidate_current_char ib\n  | '\\r' -> Scanning.invalidate_current_char ib; check_this_char ib '\\n'\n  | _ -> character_mismatch '\\n' ci\n\n\n(* Extracting tokens from the output token buffer. *)\n\nlet token_char ib = (Scanning.token ib).[0]\n\nlet token_string = Scanning.token\n\nlet token_bool ib =\n  match Scanning.token ib with\n  | \"true\" -> true\n  | \"false\" -> false\n  | s -> bad_input (Printf.sprintf \"invalid boolean '%s'\" s)\n\n\n(* The type of integer conversions. *)\ntype integer_conversion =\n  | B_conversion (* Unsigned binary conversion *)\n  | D_conversion (* Signed decimal conversion *)\n  | I_conversion (* Signed integer conversion *)\n  | O_conversion (* Unsigned octal conversion *)\n  | U_conversion (* Unsigned decimal conversion *)\n  | X_conversion (* Unsigned hexadecimal conversion *)\n\n\nlet integer_conversion_of_char = function\n  | 'b' -> B_conversion\n  | 'd' -> D_conversion\n  | 'i' -> I_conversion\n  | 'o' -> O_conversion\n  | 'u' -> U_conversion\n  | 'x' | 'X' -> X_conversion\n  | _ -> assert false\n\n\n(* Extract an integer literal token.\n   Since the functions Stdlib.*int*_of_string do not accept a leading +,\n   we skip it if necessary. *)\nlet token_int_literal conv ib =\n  let tok =\n    match conv with\n    | D_conversion | I_conversion -> Scanning.token ib\n    | U_conversion -> \"0u\" ^ Scanning.token ib\n    | O_conversion -> \"0o\" ^ Scanning.token ib\n    | X_conversion -> \"0x\" ^ Scanning.token ib\n    | B_conversion -> \"0b\" ^ Scanning.token ib in\n  let l = String.length tok in\n  if l = 0 || tok.[0] <> '+' then tok else String.sub tok 1 (l - 1)\n\n\n(* All the functions that convert a string to a number raise the exception\n   Failure when the conversion is not possible.\n   This exception is then trapped in [kscanf]. *)\nlet token_int conv ib = int_of_string (token_int_literal conv ib)\n\nlet token_float ib = float_of_string (Scanning.token ib)\n\n(* To scan native ints, int32 and int64 integers.\n   We cannot access to conversions to/from strings for those types,\n   Nativeint.of_string, Int32.of_string, and Int64.of_string,\n   since those modules are not available to [Scanf].\n   However, we can bind and use the corresponding primitives that are\n   available in the runtime. *)\nexternal nativeint_of_string : string -> nativeint\n  = \"caml_nativeint_of_string\"\n\nexternal int32_of_string : string -> int32\n  = \"caml_int32_of_string\"\n\nexternal int64_of_string : string -> int64\n  = \"caml_int64_of_string\"\n\n\nlet token_nativeint conv ib = nativeint_of_string (token_int_literal conv ib)\nlet token_int32 conv ib = int32_of_string (token_int_literal conv ib)\nlet token_int64 conv ib = int64_of_string (token_int_literal conv ib)\n\n(* Scanning numbers. *)\n\n(* Digits scanning functions suppose that one character has been checked and\n   is available, since they return at end of file with the currently found\n   token selected.\n\n   Put it in another way, the digits scanning functions scan for a possibly\n   empty sequence of digits, (hence, a successful scanning from one of those\n   functions does not imply that the token is a well-formed number: to get a\n   true number, it is mandatory to check that at least one valid digit is\n   available before calling one of the digit scanning functions). *)\n\n(* The decimal case is treated especially for optimization purposes. *)\nlet rec scan_decimal_digit_star width ib =\n  if width = 0 then width else\n  let c = Scanning.peek_char ib in\n  if Scanning.eof ib then width else\n  match c with\n  | '0' .. '9' as c ->\n    let width = Scanning.store_char width ib c in\n    scan_decimal_digit_star width ib\n  | '_' ->\n    let width = Scanning.ignore_char width ib in\n    scan_decimal_digit_star width ib\n  | _ -> width\n\n\nlet scan_decimal_digit_plus width ib =\n  if width = 0 then bad_token_length \"decimal digits\" else\n  let c = Scanning.checked_peek_char ib in\n  match c with\n  | '0' .. '9' ->\n    let width = Scanning.store_char width ib c in\n    scan_decimal_digit_star width ib\n  | c ->\n    bad_input (Printf.sprintf \"character %C is not a decimal digit\" c)\n\n\n(* To scan numbers from other bases, we use a predicate argument to\n   scan digits. *)\nlet scan_digit_star digitp width ib =\n  let rec scan_digits width ib =\n    if width = 0 then width else\n    let c = Scanning.peek_char ib in\n    if Scanning.eof ib then width else\n    match c with\n    | c when digitp c ->\n      let width = Scanning.store_char width ib c in\n      scan_digits width ib\n    | '_' ->\n      let width = Scanning.ignore_char width ib in\n      scan_digits width ib\n    | _ -> width in\n  scan_digits width ib\n\n\nlet scan_digit_plus basis digitp width ib =\n  (* Ensure we have got enough width left,\n     and read at least one digit. *)\n  if width = 0 then bad_token_length \"digits\" else\n  let c = Scanning.checked_peek_char ib in\n  if digitp c then\n    let width = Scanning.store_char width ib c in\n    scan_digit_star digitp width ib\n  else\n    bad_input (Printf.sprintf \"character %C is not a valid %s digit\" c basis)\n\n\nlet is_binary_digit = function\n  | '0' .. '1' -> true\n  | _ -> false\n\n\nlet scan_binary_int = scan_digit_plus \"binary\" is_binary_digit\n\nlet is_octal_digit = function\n  | '0' .. '7' -> true\n  | _ -> false\n\n\nlet scan_octal_int = scan_digit_plus \"octal\" is_octal_digit\n\nlet is_hexa_digit = function\n  | '0' .. '9' | 'a' .. 'f' | 'A' .. 'F' -> true\n  | _ -> false\n\n\nlet scan_hexadecimal_int = scan_digit_plus \"hexadecimal\" is_hexa_digit\n\n(* Scan a decimal integer. *)\nlet scan_unsigned_decimal_int = scan_decimal_digit_plus\n\nlet scan_sign width ib =\n  let c = Scanning.checked_peek_char ib in\n  match c with\n  | '+' -> Scanning.store_char width ib c\n  | '-' -> Scanning.store_char width ib c\n  | _ -> width\n\n\nlet scan_optionally_signed_decimal_int width ib =\n  let width = scan_sign width ib in\n  scan_unsigned_decimal_int width ib\n\n\n(* Scan an unsigned integer that could be given in any (common) basis.\n   If digits are prefixed by one of 0x, 0X, 0o, or 0b, the number is\n   assumed to be written respectively in hexadecimal, hexadecimal,\n   octal, or binary. *)\nlet scan_unsigned_int width ib =\n  match Scanning.checked_peek_char ib with\n  | '0' as c ->\n    let width = Scanning.store_char width ib c in\n    if width = 0 then width else\n    let c = Scanning.peek_char ib in\n    if Scanning.eof ib then width else\n    begin match c with\n    | 'x' | 'X' -> scan_hexadecimal_int (Scanning.store_char width ib c) ib\n    | 'o' -> scan_octal_int (Scanning.store_char width ib c) ib\n    | 'b' -> scan_binary_int (Scanning.store_char width ib c) ib\n    | _ -> scan_decimal_digit_star width ib end\n  | _ -> scan_unsigned_decimal_int width ib\n\n\nlet scan_optionally_signed_int width ib =\n  let width = scan_sign width ib in\n  scan_unsigned_int width ib\n\n\nlet scan_int_conversion conv width ib =\n  match conv with\n  | B_conversion -> scan_binary_int width ib\n  | D_conversion -> scan_optionally_signed_decimal_int width ib\n  | I_conversion -> scan_optionally_signed_int width ib\n  | O_conversion -> scan_octal_int width ib\n  | U_conversion -> scan_unsigned_decimal_int width ib\n  | X_conversion -> scan_hexadecimal_int width ib\n\n\n(* Scanning floating point numbers. *)\n\n(* Fractional part is optional and can be reduced to 0 digits. *)\nlet scan_fractional_part width ib =\n  if width = 0 then width else\n  let c = Scanning.peek_char ib in\n  if Scanning.eof ib then width else\n  match c with\n  | '0' .. '9' as c ->\n    scan_decimal_digit_star (Scanning.store_char width ib c) ib\n  | _ -> width\n\n\n(* Exp part is optional and can be reduced to 0 digits. *)\nlet scan_exponent_part width ib =\n  if width = 0 then width else\n  let c = Scanning.peek_char ib in\n  if Scanning.eof ib then width else\n  match c with\n  | 'e' | 'E' as c ->\n    scan_optionally_signed_decimal_int (Scanning.store_char width ib c) ib\n  | _ -> width\n\n\n(* Scan the integer part of a floating point number, (not using the\n   OCaml lexical convention since the integer part can be empty):\n   an optional sign, followed by a possibly empty sequence of decimal\n   digits (e.g. -.1). *)\nlet scan_integer_part width ib =\n  let width = scan_sign width ib in\n  scan_decimal_digit_star width ib\n\n\n(*\n   For the time being we have (as found in scanf.mli):\n   the field width is composed of an optional integer literal\n   indicating the maximal width of the token to read.\n   Unfortunately, the type-checker let the user write an optional precision,\n   since this is valid for printf format strings.\n\n   Thus, the next step for Scanf is to support a full width and precision\n   indication, more or less similar to the one for printf, possibly extended\n   to the specification of a [max, min] range for the width of the token read\n   for strings. Something like the following spec for scanf.mli:\n\n   The optional [width] is an integer indicating the maximal\n   width of the token read. For instance, [%6d] reads an integer,\n   having at most 6 characters.\n\n   The optional [precision] is a dot [.] followed by an integer:\n\n   - in the floating point number conversions ([%f], [%e], [%g], [%F], [%E],\n   and [%F] conversions, the [precision] indicates the maximum number of\n   digits that may follow the decimal point. For instance, [%.4f] reads a\n   [float] with at most 4 fractional digits,\n\n   - in the string conversions ([%s], [%S], [%\\[ range \\]]), and in the\n   integer number conversions ([%i], [%d], [%u], [%x], [%o], and their\n   [int32], [int64], and [native_int] correspondent), the [precision]\n   indicates the required minimum width of the token read,\n\n   - on all other conversions, the width and precision specify the [max, min]\n   range for the width of the token read.\n*)\nlet scan_float width precision ib =\n  let width = scan_integer_part width ib in\n  if width = 0 then width, precision else\n  let c = Scanning.peek_char ib in\n  if Scanning.eof ib then width, precision else\n  match c with\n  | '.' ->\n    let width = Scanning.store_char width ib c in\n    let precision = Int.min width precision in\n    let width = width - (precision - scan_fractional_part precision ib) in\n    scan_exponent_part width ib, precision\n  | _ ->\n    scan_exponent_part width ib, precision\n\n\nlet check_case_insensitive_string width ib error str =\n  let lowercase c =\n    match c with\n    | 'A' .. 'Z' ->\n      char_of_int (int_of_char c - int_of_char 'A' + int_of_char 'a')\n    | _ -> c in\n  let len = String.length str in\n  let width = ref width in\n  for i = 0 to len - 1 do\n    let c = Scanning.peek_char ib in\n    if lowercase c <> lowercase str.[i] then error ();\n    if !width = 0 then error ();\n    width := Scanning.store_char !width ib c;\n  done;\n  !width\n\n\nlet scan_hex_float width precision ib =\n  if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n  let width = scan_sign width ib in\n  if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n  match Scanning.peek_char ib with\n  | '0' as c -> (\n    let width = Scanning.store_char width ib c in\n    if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n    let width = check_case_insensitive_string width ib bad_hex_float \"x\" in\n    if width = 0 || Scanning.end_of_input ib then width else\n      let width = match Scanning.peek_char ib with\n        | '.' | 'p' | 'P' -> width\n        | _ -> scan_hexadecimal_int width ib in\n      if width = 0 || Scanning.end_of_input ib then width else\n        let width = match Scanning.peek_char ib with\n          | '.' as c -> (\n            let width = Scanning.store_char width ib c in\n            if width = 0 || Scanning.end_of_input ib then width else\n              match Scanning.peek_char ib with\n              | 'p' | 'P' -> width\n              | _ ->\n                let precision = Int.min width precision in\n                width - (precision - scan_hexadecimal_int precision ib)\n          )\n          | _ -> width in\n        if width = 0 || Scanning.end_of_input ib then width else\n          match Scanning.peek_char ib with\n          | 'p' | 'P' as c ->\n            let width = Scanning.store_char width ib c in\n            if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n            scan_optionally_signed_decimal_int width ib\n          | _ -> width\n  )\n  | 'n' | 'N' as c ->\n    let width = Scanning.store_char width ib c in\n    if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n    check_case_insensitive_string width ib bad_hex_float \"an\"\n  | 'i' | 'I' as c ->\n    let width = Scanning.store_char width ib c in\n    if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n    check_case_insensitive_string width ib bad_hex_float \"nfinity\"\n  | _ -> bad_hex_float ()\n\n\nlet scan_caml_float_rest width precision ib =\n  if width = 0 || Scanning.end_of_input ib then bad_float ();\n  let width = scan_decimal_digit_star width ib in\n  if width = 0 || Scanning.end_of_input ib then bad_float ();\n  let c = Scanning.peek_char ib in\n  match c with\n  | '.' ->\n    let width = Scanning.store_char width ib c in\n    (* The effective width available for scanning the fractional part is\n       the minimum of declared precision and width left. *)\n    let precision = Int.min width precision in\n    (* After scanning the fractional part with [precision] provisional width,\n       [width_precision] is left. *)\n    let width_precision = scan_fractional_part precision ib in\n    (* Hence, scanning the fractional part took exactly\n       [precision - width_precision] chars. *)\n    let frac_width = precision - width_precision in\n    (* And new provisional width is [width - width_precision. *)\n    let width = width - frac_width in\n    scan_exponent_part width ib\n  | 'e' | 'E' ->\n    scan_exponent_part width ib\n  | _ -> bad_float ()\n\n\nlet scan_caml_float width precision ib =\n  if width = 0 || Scanning.end_of_input ib then bad_float ();\n  let width = scan_sign width ib in\n  if width = 0 || Scanning.end_of_input ib then bad_float ();\n  match Scanning.peek_char ib with\n  | '0' as c -> (\n    let width = Scanning.store_char width ib c in\n    if width = 0 || Scanning.end_of_input ib then bad_float ();\n    match Scanning.peek_char ib with\n    | 'x' | 'X' as c -> (\n      let width = Scanning.store_char width ib c in\n      if width = 0 || Scanning.end_of_input ib then bad_float ();\n      let width = scan_hexadecimal_int width ib in\n      if width = 0 || Scanning.end_of_input ib then bad_float ();\n      let width = match Scanning.peek_char ib with\n        | '.' as c -> (\n          let width = Scanning.store_char width ib c in\n          if width = 0 || Scanning.end_of_input ib then width else\n            match Scanning.peek_char ib with\n            | 'p' | 'P' -> width\n            | _ ->\n              let precision = Int.min width precision in\n              width - (precision - scan_hexadecimal_int precision ib)\n        )\n        | 'p' | 'P' -> width\n        | _ -> bad_float () in\n      if width = 0 || Scanning.end_of_input ib then width else\n        match Scanning.peek_char ib with\n        | 'p' | 'P' as c ->\n          let width = Scanning.store_char width ib c in\n          if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n          scan_optionally_signed_decimal_int width ib\n        | _ -> width\n    )\n    | _ ->\n      scan_caml_float_rest width precision ib\n  )\n  | '1' .. '9' as c ->\n    let width = Scanning.store_char width ib c in\n    if width = 0 || Scanning.end_of_input ib then bad_float ();\n    scan_caml_float_rest width precision ib\n(* Special case of nan and infinity:\n  | 'i' ->\n  | 'n' ->\n*)\n  | _ -> bad_float ()\n\n\n(* Scan a regular string:\n   stops when encountering a space, if no scanning indication has been given;\n   otherwise, stops when encountering the characters in the scanning\n   indication [stp].\n   It also stops at end of file or when the maximum number of characters has\n   been read. *)\nlet scan_string stp width ib =\n  let rec loop width =\n    if width = 0 then width else\n    let c = Scanning.peek_char ib in\n    if Scanning.eof ib then width else\n      match stp with\n      | Some c' when c = c' -> Scanning.skip_char width ib\n      | Some _ -> loop (Scanning.store_char width ib c)\n      | None ->\n        match c with\n        | ' ' | '\\t' | '\\n' | '\\r' -> width\n        | _ -> loop (Scanning.store_char width ib c) in\n  loop width\n\n\n(* Scan a char: peek strictly one character in the input, whatsoever. *)\nlet scan_char width ib =\n  (* The case width = 0 could not happen here, since it is tested before\n     calling scan_char, in the main scanning function.\n    if width = 0 then bad_token_length \"a character\" else *)\n  Scanning.store_char width ib (Scanning.checked_peek_char ib)\n\n\nlet char_for_backslash = function\n  | 'n' -> '\\010'\n  | 'r' -> '\\013'\n  | 'b' -> '\\008'\n  | 't' -> '\\009'\n  | c -> c\n\n\n(* The integer value corresponding to the facial value of a valid\n   decimal digit character. *)\nlet decimal_value_of_char c = int_of_char c - int_of_char '0'\n\nlet char_for_decimal_code c0 c1 c2 =\n  let c =\n    100 * decimal_value_of_char c0 +\n     10 * decimal_value_of_char c1 +\n          decimal_value_of_char c2 in\n  if c < 0 || c > 255 then\n    bad_input\n      (Printf.sprintf\n         \"bad character decimal encoding \\\\%c%c%c\" c0 c1 c2) else\n  char_of_int c\n\n\n(* The integer value corresponding to the facial value of a valid\n   hexadecimal digit character. *)\nlet hexadecimal_value_of_char c =\n  let d = int_of_char c in\n  (* Could also be:\n    if d <= int_of_char '9' then d - int_of_char '0' else\n    if d <= int_of_char 'F' then 10 + d - int_of_char 'A' else\n    if d <= int_of_char 'f' then 10 + d - int_of_char 'a' else assert false\n  *)\n  if d >= int_of_char 'a' then\n    d - 87 (* 10 + int_of_char c - int_of_char 'a' *) else\n  if d >= int_of_char 'A' then\n    d - 55  (* 10 + int_of_char c - int_of_char 'A' *) else\n    d - int_of_char '0'\n\n\nlet char_for_hexadecimal_code c1 c2 =\n  let c =\n    16 * hexadecimal_value_of_char c1 +\n         hexadecimal_value_of_char c2 in\n  if c < 0 || c > 255 then\n    bad_input\n      (Printf.sprintf \"bad character hexadecimal encoding \\\\%c%c\" c1 c2) else\n  char_of_int c\n\n\n(* Called in particular when encountering '\\\\' as starter of a char.\n   Stops before the corresponding '\\''. *)\nlet check_next_char message width ib =\n  if width = 0 then bad_token_length message else\n  let c = Scanning.peek_char ib in\n  if Scanning.eof ib then bad_end_of_input message else\n  c\n\n\nlet check_next_char_for_char = check_next_char \"a Char\"\nlet check_next_char_for_string = check_next_char \"a String\"\n\nlet scan_backslash_char width ib =\n  match check_next_char_for_char width ib with\n  | '\\\\' | '\\'' | '\\\"' | 'n' | 't' | 'b' | 'r' as c ->\n    Scanning.store_char width ib (char_for_backslash c)\n  | '0' .. '9' as c ->\n    let get_digit () =\n      let c = Scanning.next_char ib in\n      match c with\n      | '0' .. '9' as c -> c\n      | c -> bad_input_escape c in\n    let c0 = c in\n    let c1 = get_digit () in\n    let c2 = get_digit () in\n    Scanning.store_char (width - 2) ib (char_for_decimal_code c0 c1 c2)\n  | 'x' ->\n    let get_digit () =\n      let c = Scanning.next_char ib in\n      match c with\n      | '0' .. '9' | 'A' .. 'F' | 'a' .. 'f' as c -> c\n      | c -> bad_input_escape c in\n    let c1 = get_digit () in\n    let c2 = get_digit () in\n    Scanning.store_char (width - 2) ib (char_for_hexadecimal_code c1 c2)\n  | c ->\n    bad_input_escape c\n\n\n(* Scan a character (an OCaml token). *)\nlet scan_caml_char width ib =\n\n  let rec find_start width =\n    match Scanning.checked_peek_char ib with\n    | '\\'' -> find_char (Scanning.ignore_char width ib)\n    | c -> character_mismatch '\\'' c\n\n  and find_char width =\n    match check_next_char_for_char width ib with\n    | '\\\\' ->\n      find_stop (scan_backslash_char (Scanning.ignore_char width ib) ib)\n    | c ->\n      find_stop (Scanning.store_char width ib c)\n\n  and find_stop width =\n    match check_next_char_for_char width ib with\n    | '\\'' -> Scanning.ignore_char width ib\n    | c -> character_mismatch '\\'' c in\n\n  find_start width\n\n\n(* Scan a delimited string (an OCaml token). *)\nlet scan_caml_string width ib =\n\n  let rec find_start width =\n    match Scanning.checked_peek_char ib with\n    | '\\\"' -> find_stop (Scanning.ignore_char width ib)\n    | c -> character_mismatch '\\\"' c\n\n  and find_stop width =\n    match check_next_char_for_string width ib with\n    | '\\\"' -> Scanning.ignore_char width ib\n    | '\\\\' -> scan_backslash (Scanning.ignore_char width ib)\n    | c -> find_stop (Scanning.store_char width ib c)\n\n  and scan_backslash width =\n    match check_next_char_for_string width ib with\n    | '\\r' -> skip_newline (Scanning.ignore_char width ib)\n    | '\\n' -> skip_spaces (Scanning.ignore_char width ib)\n    | _ -> find_stop (scan_backslash_char width ib)\n\n  and skip_newline width =\n    match check_next_char_for_string width ib with\n    | '\\n' -> skip_spaces (Scanning.ignore_char width ib)\n    | _ -> find_stop (Scanning.store_char width ib '\\r')\n\n  and skip_spaces width =\n    match check_next_char_for_string width ib with\n    | ' ' -> skip_spaces (Scanning.ignore_char width ib)\n    | _ -> find_stop width in\n\n  find_start width\n\n\n(* Scan a boolean (an OCaml token). *)\nlet scan_bool ib =\n  let c = Scanning.checked_peek_char ib in\n  let m =\n    match c with\n    | 't' -> 4\n    | 'f' -> 5\n    | c ->\n      bad_input\n        (Printf.sprintf \"the character %C cannot start a boolean\" c) in\n  scan_string None m ib\n\n\n(* Scan a string containing elements in char_set and terminated by scan_indic\n   if provided. *)\nlet scan_chars_in_char_set char_set scan_indic width ib =\n  let rec scan_chars i stp =\n    let c = Scanning.peek_char ib in\n    if i > 0 && not (Scanning.eof ib) &&\n       is_in_char_set char_set c &&\n       int_of_char c <> stp then\n      let _ = Scanning.store_char max_int ib c in\n      scan_chars (i - 1) stp in\n  match scan_indic with\n  | None -> scan_chars width (-1);\n  | Some c ->\n    scan_chars width (int_of_char c);\n    if not (Scanning.eof ib) then\n      let ci = Scanning.peek_char ib in\n      if c = ci\n      then Scanning.invalidate_current_char ib\n      else character_mismatch c ci\n\n\n(* The global error report function for [Scanf]. *)\nlet scanf_bad_input ib = function\n  | Scan_failure s | Failure s ->\n    let i = Scanning.char_count ib in\n    bad_input (Printf.sprintf \"scanf: bad input at char number %i: %s\" i s)\n  | x -> raise x\n\n\n(* Get the content of a counter from an input buffer. *)\nlet get_counter ib counter =\n  match counter with\n  | Line_counter -> Scanning.line_count ib\n  | Char_counter -> Scanning.char_count ib\n  | Token_counter -> Scanning.token_count ib\n\n\n(* Compute the width of a padding option (see \"%42{\" and \"%123(\"). *)\nlet width_of_pad_opt pad_opt = match pad_opt with\n  | None -> max_int\n  | Some width -> width\n\n\nlet stopper_of_formatting_lit fmting =\n  if fmting = Escaped_percent then '%', \"\" else\n    let str = string_of_formatting_lit fmting in\n    let stp = str.[1] in\n    let sub_str = String.sub str 2 (String.length str - 2) in\n    stp, sub_str\n\n\n(******************************************************************************)\n                           (* Reader management *)\n\n(* A call to take_format_readers on a format is evaluated into functions\n   taking readers as arguments and aggregate them into an heterogeneous list *)\n(* When all readers are taken, finally pass the list of the readers to the\n   continuation k. *)\nlet rec take_format_readers : type a c d e f .\n    ((d, e) heter_list -> e) -> (a, Scanning.in_channel, c, d, e, f) fmt ->\n    d =\nfun k fmt -> match fmt with\n  | Reader fmt_rest ->\n    fun reader ->\n      let new_k readers_rest = k (Cons (reader, readers_rest)) in\n      take_format_readers new_k fmt_rest\n  | Char rest                        -> take_format_readers k rest\n  | Caml_char rest                   -> take_format_readers k rest\n  | String (_, rest)                 -> take_format_readers k rest\n  | Caml_string (_, rest)            -> take_format_readers k rest\n  | Int (_, _, _, rest)              -> take_format_readers k rest\n  | Int32 (_, _, _, rest)            -> take_format_readers k rest\n  | Nativeint (_, _, _, rest)        -> take_format_readers k rest\n  | Int64 (_, _, _, rest)            -> take_format_readers k rest\n  | Float (_, _, _, rest)            -> take_format_readers k rest\n  | Bool (_, rest)                   -> take_format_readers k rest\n  | Alpha rest                       -> take_format_readers k rest\n  | Theta rest                       -> take_format_readers k rest\n  | Flush rest                       -> take_format_readers k rest\n  | String_literal (_, rest)         -> take_format_readers k rest\n  | Char_literal (_, rest)           -> take_format_readers k rest\n  | Custom (_, _, rest)              -> take_format_readers k rest\n\n  | Scan_char_set (_, _, rest)       -> take_format_readers k rest\n  | Scan_get_counter (_, rest)       -> take_format_readers k rest\n  | Scan_next_char rest              -> take_format_readers k rest\n\n  | Formatting_lit (_, rest)         -> take_format_readers k rest\n  | Formatting_gen (Open_tag (Format (fmt, _)), rest) ->\n      take_format_readers k (concat_fmt fmt rest)\n  | Formatting_gen (Open_box (Format (fmt, _)), rest) ->\n      take_format_readers k (concat_fmt fmt rest)\n\n  | Format_arg (_, _, rest)          -> take_format_readers k rest\n  | Format_subst (_, fmtty, rest)    ->\n     take_fmtty_format_readers k (erase_rel (symm fmtty)) rest\n  | Ignored_param (ign, rest)        -> take_ignored_format_readers k ign rest\n\n  | End_of_format                    -> k Nil\n\n(* Take readers associated to an fmtty coming from a Format_subst \"%(...%)\". *)\nand take_fmtty_format_readers : type x y a c d e f .\n    ((d, e) heter_list -> e) -> (a, Scanning.in_channel, c, d, x, y) fmtty ->\n      (y, Scanning.in_channel, c, x, e, f) fmt -> d =\nfun k fmtty fmt -> match fmtty with\n  | Reader_ty fmt_rest ->\n    fun reader ->\n      let new_k readers_rest = k (Cons (reader, readers_rest)) in\n      take_fmtty_format_readers new_k fmt_rest fmt\n  | Ignored_reader_ty fmt_rest ->\n    fun reader ->\n      let new_k readers_rest = k (Cons (reader, readers_rest)) in\n      take_fmtty_format_readers new_k fmt_rest fmt\n  | Char_ty rest                -> take_fmtty_format_readers k rest fmt\n  | String_ty rest              -> take_fmtty_format_readers k rest fmt\n  | Int_ty rest                 -> take_fmtty_format_readers k rest fmt\n  | Int32_ty rest               -> take_fmtty_format_readers k rest fmt\n  | Nativeint_ty rest           -> take_fmtty_format_readers k rest fmt\n  | Int64_ty rest               -> take_fmtty_format_readers k rest fmt\n  | Float_ty rest               -> take_fmtty_format_readers k rest fmt\n  | Bool_ty rest                -> take_fmtty_format_readers k rest fmt\n  | Alpha_ty rest               -> take_fmtty_format_readers k rest fmt\n  | Theta_ty rest               -> take_fmtty_format_readers k rest fmt\n  | Any_ty rest                 -> take_fmtty_format_readers k rest fmt\n  | Format_arg_ty (_, rest)     -> take_fmtty_format_readers k rest fmt\n  | End_of_fmtty                -> take_format_readers k fmt\n  | Format_subst_ty (ty1, ty2, rest) ->\n    let ty = trans (symm ty1) ty2 in\n    take_fmtty_format_readers k (concat_fmtty ty rest) fmt\n\n(* Take readers associated to an ignored parameter. *)\nand take_ignored_format_readers : type x y a c d e f .\n    ((d, e) heter_list -> e) -> (a, Scanning.in_channel, c, d, x, y) ignored ->\n      (y, Scanning.in_channel, c, x, e, f) fmt -> d =\nfun k ign fmt -> match ign with\n  | Ignored_reader ->\n    fun reader ->\n      let new_k readers_rest = k (Cons (reader, readers_rest)) in\n      take_format_readers new_k fmt\n  | Ignored_char                    -> take_format_readers k fmt\n  | Ignored_caml_char               -> take_format_readers k fmt\n  | Ignored_string _                -> take_format_readers k fmt\n  | Ignored_caml_string _           -> take_format_readers k fmt\n  | Ignored_int (_, _)              -> take_format_readers k fmt\n  | Ignored_int32 (_, _)            -> take_format_readers k fmt\n  | Ignored_nativeint (_, _)        -> take_format_readers k fmt\n  | Ignored_int64 (_, _)            -> take_format_readers k fmt\n  | Ignored_float (_, _)            -> take_format_readers k fmt\n  | Ignored_bool _                  -> take_format_readers k fmt\n  | Ignored_format_arg _            -> take_format_readers k fmt\n  | Ignored_format_subst (_, fmtty) -> take_fmtty_format_readers k fmtty fmt\n  | Ignored_scan_char_set _         -> take_format_readers k fmt\n  | Ignored_scan_get_counter _      -> take_format_readers k fmt\n  | Ignored_scan_next_char          -> take_format_readers k fmt\n\n(******************************************************************************)\n                          (* Generic scanning *)\n\n(* Make a generic scanning function. *)\n(* Scan a stream according to a format and readers obtained by\n   take_format_readers, and aggregate scanned values into an\n   heterogeneous list. *)\n(* Return the heterogeneous list of scanned values. *)\nlet rec make_scanf : type a c d e f.\n    Scanning.in_channel -> (a, Scanning.in_channel, c, d, e, f) fmt ->\n      (d, e) heter_list -> (a, f) heter_list =\nfun ib fmt readers -> match fmt with\n  | Char rest ->\n    let _ = scan_char 0 ib in\n    let c = token_char ib in\n    Cons (c, make_scanf ib rest readers)\n  | Caml_char rest ->\n    let _ = scan_caml_char 0 ib in\n    let c = token_char ib in\n    Cons (c, make_scanf ib rest readers)\n\n  | String (pad, Formatting_lit (fmting_lit, rest)) ->\n    let stp, str = stopper_of_formatting_lit fmting_lit in\n    let scan width _ ib = scan_string (Some stp) width ib in\n    let str_rest = String_literal (str, rest) in\n    pad_prec_scanf ib str_rest readers pad No_precision scan token_string\n  | String (pad, Formatting_gen (Open_tag (Format (fmt', _)), rest)) ->\n    let scan width _ ib = scan_string (Some '{') width ib in\n    pad_prec_scanf ib (concat_fmt fmt' rest) readers pad No_precision scan\n                   token_string\n  | String (pad, Formatting_gen (Open_box (Format (fmt', _)), rest)) ->\n    let scan width _ ib = scan_string (Some '[') width ib in\n    pad_prec_scanf ib (concat_fmt fmt' rest) readers pad No_precision scan\n                   token_string\n  | String (pad, rest) ->\n    let scan width _ ib = scan_string None width ib in\n    pad_prec_scanf ib rest readers pad No_precision scan token_string\n\n  | Caml_string (pad, rest) ->\n    let scan width _ ib = scan_caml_string width ib in\n    pad_prec_scanf ib rest readers pad No_precision scan token_string\n  | Int (iconv, pad, prec, rest) ->\n    let c = integer_conversion_of_char (char_of_iconv iconv) in\n    let scan width _ ib = scan_int_conversion c width ib in\n    pad_prec_scanf ib rest readers pad prec scan (token_int c)\n  | Int32 (iconv, pad, prec, rest) ->\n    let c = integer_conversion_of_char (char_of_iconv iconv) in\n    let scan width _ ib = scan_int_conversion c width ib in\n    pad_prec_scanf ib rest readers pad prec scan (token_int32 c)\n  | Nativeint (iconv, pad, prec, rest) ->\n    let c = integer_conversion_of_char (char_of_iconv iconv) in\n    let scan width _ ib = scan_int_conversion c width ib in\n    pad_prec_scanf ib rest readers pad prec scan (token_nativeint c)\n  | Int64 (iconv, pad, prec, rest) ->\n    let c = integer_conversion_of_char (char_of_iconv iconv) in\n    let scan width _ ib = scan_int_conversion c width ib in\n    pad_prec_scanf ib rest readers pad prec scan (token_int64 c)\n  | Float ((_, (Float_F | Float_CF)), pad, prec, rest) ->\n    pad_prec_scanf ib rest readers pad prec scan_caml_float token_float\n  | Float ((_, (Float_f | Float_e | Float_E | Float_g | Float_G)),\n           pad, prec, rest) ->\n    pad_prec_scanf ib rest readers pad prec scan_float token_float\n  | Float ((_, (Float_h | Float_H)), pad, prec, rest) ->\n    pad_prec_scanf ib rest readers pad prec scan_hex_float token_float\n  | Bool (pad, rest) ->\n    let scan _ _ ib = scan_bool ib in\n    pad_prec_scanf ib rest readers pad No_precision scan token_bool\n  | Alpha _ ->\n    invalid_arg \"scanf: bad conversion \\\"%a\\\"\"\n  | Theta _ ->\n    invalid_arg \"scanf: bad conversion \\\"%t\\\"\"\n  | Custom _ ->\n    invalid_arg \"scanf: bad conversion \\\"%?\\\" (custom converter)\"\n  | Reader fmt_rest ->\n    begin match readers with\n    | Cons (reader, readers_rest) ->\n        let x = reader ib in\n        Cons (x, make_scanf ib fmt_rest readers_rest)\n    | Nil ->\n        invalid_arg \"scanf: missing reader\"\n    end\n  | Flush rest ->\n    if Scanning.end_of_input ib then make_scanf ib rest readers\n    else bad_input \"end of input not found\"\n\n  | String_literal (str, rest) ->\n    String.iter (check_char ib) str;\n    make_scanf ib rest readers\n  | Char_literal (chr, rest) ->\n    check_char ib chr;\n    make_scanf ib rest readers\n\n  | Format_arg (pad_opt, fmtty, rest) ->\n    let _ = scan_caml_string (width_of_pad_opt pad_opt) ib in\n    let s = token_string ib in\n    let fmt =\n      try format_of_string_fmtty s fmtty\n      with Failure msg -> bad_input msg\n    in\n    Cons (fmt, make_scanf ib rest readers)\n  | Format_subst (pad_opt, fmtty, rest) ->\n    let _ = scan_caml_string (width_of_pad_opt pad_opt) ib in\n    let s = token_string ib in\n    let fmt, fmt' =\n      try\n        let Fmt_EBB fmt = fmt_ebb_of_string s in\n        let Fmt_EBB fmt' = fmt_ebb_of_string s in\n        (* TODO: find a way to avoid reparsing twice *)\n\n        (* TODO: these type-checks below *can* fail because of type\n           ambiguity in presence of ignored-readers: \"%_r%d\" and \"%d%_r\"\n           are typed in the same way.\n\n           # Scanf.sscanf \"\\\"%_r%d\\\"3\" \"%(%d%_r%)\" ignore\n             (fun fmt n -> string_of_format fmt, n)\n           Exception: CamlinternalFormat.Type_mismatch.\n\n           We should properly catch this exception.\n        *)\n        type_format fmt (erase_rel fmtty),\n        type_format fmt' (erase_rel (symm fmtty))\n      with Failure msg -> bad_input msg\n    in\n    Cons (Format (fmt, s),\n          make_scanf ib (concat_fmt fmt' rest) readers)\n\n  | Scan_char_set (width_opt, char_set, Formatting_lit (fmting_lit, rest)) ->\n    let stp, str = stopper_of_formatting_lit fmting_lit in\n    let width = width_of_pad_opt width_opt in\n    scan_chars_in_char_set char_set (Some stp) width ib;\n    let s = token_string ib in\n    let str_rest = String_literal (str, rest) in\n    Cons (s, make_scanf ib str_rest readers)\n  | Scan_char_set (width_opt, char_set, rest) ->\n    let width = width_of_pad_opt width_opt in\n    scan_chars_in_char_set char_set None width ib;\n    let s = token_string ib in\n    Cons (s, make_scanf ib rest readers)\n  | Scan_get_counter (counter, rest) ->\n    let count = get_counter ib counter in\n    Cons (count, make_scanf ib rest readers)\n  | Scan_next_char rest ->\n    let c = Scanning.checked_peek_char ib in\n    Cons (c, make_scanf ib rest readers)\n\n  | Formatting_lit (formatting_lit, rest) ->\n    String.iter (check_char ib) (string_of_formatting_lit formatting_lit);\n    make_scanf ib rest readers\n  | Formatting_gen (Open_tag (Format (fmt', _)), rest) ->\n    check_char ib '@'; check_char ib '{';\n    make_scanf ib (concat_fmt fmt' rest) readers\n  | Formatting_gen (Open_box (Format (fmt', _)), rest) ->\n    check_char ib '@'; check_char ib '[';\n    make_scanf ib (concat_fmt fmt' rest) readers\n\n  | Ignored_param (ign, rest) ->\n    let Param_format_EBB fmt' = param_format_of_ignored_format ign rest in\n    begin match make_scanf ib fmt' readers with\n    | Cons (_, arg_rest) -> arg_rest\n    | Nil -> assert false\n    end\n\n  | End_of_format ->\n    Nil\n\n(* Case analysis on padding and precision. *)\n(* Reject formats containing \"%*\" or \"%.*\". *)\n(* Pass padding and precision to the generic scanner `scan'. *)\nand pad_prec_scanf : type a c d e f x y z t .\n    Scanning.in_channel -> (a, Scanning.in_channel, c, d, e, f) fmt ->\n      (d, e) heter_list -> (x, y) padding -> (y, z -> a) precision ->\n      (int -> int -> Scanning.in_channel -> t) ->\n      (Scanning.in_channel -> z) ->\n      (x, f) heter_list =\nfun ib fmt readers pad prec scan token -> match pad, prec with\n  | No_padding, No_precision ->\n    let _ = scan max_int max_int ib in\n    let x = token ib in\n    Cons (x, make_scanf ib fmt readers)\n  | No_padding, Lit_precision p ->\n    let _ = scan max_int p ib in\n    let x = token ib in\n    Cons (x, make_scanf ib fmt readers)\n  | Lit_padding ((Right | Zeros), w), No_precision ->\n    let _ = scan w max_int ib in\n    let x = token ib in\n    Cons (x, make_scanf ib fmt readers)\n  | Lit_padding ((Right | Zeros), w), Lit_precision p ->\n    let _ = scan w p ib in\n    let x = token ib in\n    Cons (x, make_scanf ib fmt readers)\n  | Lit_padding (Left, _), _ ->\n    invalid_arg \"scanf: bad conversion \\\"%-\\\"\"\n  | Lit_padding ((Right | Zeros), _), Arg_precision ->\n    invalid_arg \"scanf: bad conversion \\\"%*\\\"\"\n  | Arg_padding _, _ ->\n    invalid_arg \"scanf: bad conversion \\\"%*\\\"\"\n  | No_padding, Arg_precision ->\n    invalid_arg \"scanf: bad conversion \\\"%*\\\"\"\n\n(******************************************************************************)\n            (* Defining [scanf] and various flavors of [scanf] *)\n\ntype 'a kscanf_result = Args of 'a | Exc of exn\n\nlet kscanf ib ef (Format (fmt, str)) =\n  let rec apply : type a b . a -> (a, b) heter_list -> b =\n    fun f args -> match args with\n    | Cons (x, r) -> apply (f x) r\n    | Nil -> f\n  in\n  let k readers f =\n    Scanning.reset_token ib;\n    match try Args (make_scanf ib fmt readers) with\n      | (Scan_failure _ | Failure _ | End_of_file) as exc -> Exc exc\n      | Invalid_argument msg ->\n        invalid_arg (msg ^ \" in format \\\"\" ^ String.escaped str ^ \"\\\"\")\n    with\n      | Args args -> apply f args\n      | Exc exc -> ef ib exc\n  in\n  take_format_readers k fmt\n\n(***)\n\nlet kbscanf = kscanf\nlet bscanf ib fmt = kbscanf ib scanf_bad_input fmt\n\nlet ksscanf s ef fmt = kbscanf (Scanning.from_string s) ef fmt\nlet sscanf s fmt = kbscanf (Scanning.from_string s) scanf_bad_input fmt\n\nlet scanf fmt = kscanf Scanning.stdib scanf_bad_input fmt\n\n(***)\n\n(* Scanning format strings. *)\nlet bscanf_format :\n  Scanning.in_channel -> ('a, 'b, 'c, 'd, 'e, 'f) format6 ->\n  (('a, 'b, 'c, 'd, 'e, 'f) format6 -> 'g) -> 'g =\n  fun ib format f ->\n    let _ = scan_caml_string max_int ib in\n    let str = token_string ib in\n    let fmt' =\n      try format_of_string_format str format\n      with Failure msg -> bad_input msg in\n    f fmt'\n\n\nlet sscanf_format :\n  string -> ('a, 'b, 'c, 'd, 'e, 'f) format6 ->\n  (('a, 'b, 'c, 'd, 'e, 'f) format6 -> 'g) -> 'g =\n  fun s format f -> bscanf_format (Scanning.from_string s) format f\n\n\nlet format_from_string s fmt =\n  sscanf_format (\"\\\"\" ^ String.escaped s ^ \"\\\"\") fmt (fun x -> x)\n\n\nlet unescaped s =\n  sscanf (\"\\\"\" ^ s ^ \"\\\"\") \"%S%!\" (fun x -> x)\n\n\n(* Deprecated *)\nlet kfscanf ic ef fmt = kbscanf (Scanning.memo_from_channel ic) ef fmt\nlet fscanf ic fmt = kscanf (Scanning.memo_from_channel ic) scanf_bad_input fmt\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Registering OCaml values with the C runtime for later callbacks *)\n\nexternal register_named_value : string -> Obj.t -> unit\n                              = \"caml_register_named_value\"\n\nlet register name v =\n  register_named_value name (Obj.repr v)\n\nlet register_exception name (exn : exn) =\n  let exn = Obj.repr exn in\n  let slot = if Obj.tag exn = Obj.object_tag then exn else Obj.field exn 0 in\n  register_named_value name slot\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*          Jerome Vouillon, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 2002 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\nopen Obj\n\n(**** Object representation ****)\n\nexternal set_id: 'a -> 'a = \"caml_set_oo_id\" [@@noalloc]\n\n(**** Object copy ****)\n\nlet copy o =\n  let o = (Obj.obj (Obj.dup (Obj.repr o))) in\n  set_id o\n\n(**** Compression options ****)\n(* Parameters *)\ntype params = {\n    mutable compact_table : bool;\n    mutable copy_parent : bool;\n    mutable clean_when_copying : bool;\n    mutable retry_count : int;\n    mutable bucket_small_size : int\n  }\n\nlet params = {\n  compact_table = true;\n  copy_parent = true;\n  clean_when_copying = true;\n  retry_count = 3;\n  bucket_small_size = 16\n}\n\n(**** Parameters ****)\n\nlet initial_object_size = 2\n\n(**** Items ****)\n\ntype item = DummyA | DummyB | DummyC of int\nlet _ = [DummyA; DummyB; DummyC 0] (* to avoid warnings *)\n\nlet dummy_item = (magic () : item)\n\n(**** Types ****)\n\ntype tag\ntype label = int\ntype closure = item\ntype t = DummyA | DummyB | DummyC of int\nlet _ = [DummyA; DummyB; DummyC 0] (* to avoid warnings *)\n\ntype obj = t array\nexternal ret : (obj -> 'a) -> closure = \"%identity\"\n\n(**** Labels ****)\n\nlet public_method_label s : tag =\n  let accu = ref 0 in\n  for i = 0 to String.length s - 1 do\n    accu := 223 * !accu + Char.code s.[i]\n  done;\n  (* reduce to 31 bits *)\n  accu := !accu land (1 lsl 31 - 1);\n  (* make it signed for 64 bits architectures *)\n  let tag = if !accu > 0x3FFFFFFF then !accu - (1 lsl 31) else !accu in\n  (* Printf.eprintf \"%s = %d\\n\" s tag; flush stderr; *)\n  magic tag\n\n(**** Sparse array ****)\n\nmodule Vars =\n  Map.Make(struct type t = string let compare (x:t) y = compare x y end)\ntype vars = int Vars.t\n\nmodule Meths =\n  Map.Make(struct type t = string let compare (x:t) y = compare x y end)\ntype meths = label Meths.t\nmodule Labs =\n  Map.Make(struct type t = label let compare (x:t) y = compare x y end)\ntype labs = bool Labs.t\n\n(* The compiler assumes that the first field of this structure is [size]. *)\ntype table =\n { mutable size: int;\n   mutable methods: closure array;\n   mutable methods_by_name: meths;\n   mutable methods_by_label: labs;\n   mutable previous_states:\n     (meths * labs * (label * item) list * vars *\n      label list * string list) list;\n   mutable hidden_meths: (label * item) list;\n   mutable vars: vars;\n   mutable initializers: (obj -> unit) list }\n\nlet dummy_table =\n  { methods = [| dummy_item |];\n    methods_by_name = Meths.empty;\n    methods_by_label = Labs.empty;\n    previous_states = [];\n    hidden_meths = [];\n    vars = Vars.empty;\n    initializers = [];\n    size = 0 }\n\nlet table_count = ref 0\n\n(* dummy_met should be a pointer, so use an atom *)\nlet dummy_met : item = obj (Obj.new_block 0 0)\n(* if debugging is needed, this could be a good idea: *)\n(* let dummy_met () = failwith \"Undefined method\" *)\n\nlet rec fit_size n =\n  if n <= 2 then n else\n  fit_size ((n+1)/2) * 2\n\nlet new_table pub_labels =\n  incr table_count;\n  let len = Array.length pub_labels in\n  let methods = Array.make (len*2+2) dummy_met in\n  methods.(0) <- magic len;\n  methods.(1) <- magic (fit_size len * Sys.word_size / 8 - 1);\n  for i = 0 to len - 1 do methods.(i*2+3) <- magic pub_labels.(i) done;\n  { methods = methods;\n    methods_by_name = Meths.empty;\n    methods_by_label = Labs.empty;\n    previous_states = [];\n    hidden_meths = [];\n    vars = Vars.empty;\n    initializers = [];\n    size = initial_object_size }\n\nlet resize array new_size =\n  let old_size = Array.length array.methods in\n  if new_size > old_size then begin\n    let new_buck = Array.make new_size dummy_met in\n    Array.blit array.methods 0 new_buck 0 old_size;\n    array.methods <- new_buck\n end\n\nlet put array label element =\n  resize array (label + 1);\n  array.methods.(label) <- element\n\n(**** Classes ****)\n\nlet method_count = ref 0\nlet inst_var_count = ref 0\n\n(* type t *)\ntype meth = item\n\nlet new_method table =\n  let index = Array.length table.methods in\n  resize table (index + 1);\n  index\n\nlet get_method_label table name =\n  try\n    Meths.find name table.methods_by_name\n  with Not_found ->\n    let label = new_method table in\n    table.methods_by_name <- Meths.add name label table.methods_by_name;\n    table.methods_by_label <- Labs.add label true table.methods_by_label;\n    label\n\nlet get_method_labels table names =\n  Array.map (get_method_label table) names\n\nlet set_method table label element =\n  incr method_count;\n  if Labs.find label table.methods_by_label then\n    put table label element\n  else\n    table.hidden_meths <- (label, element) :: table.hidden_meths\n\nlet get_method table label =\n  try List.assoc label table.hidden_meths\n  with Not_found -> table.methods.(label)\n\nlet to_list arr =\n  if arr == magic 0 then [] else Array.to_list arr\n\nlet narrow table vars virt_meths concr_meths =\n  let vars = to_list vars\n  and virt_meths = to_list virt_meths\n  and concr_meths = to_list concr_meths in\n  let virt_meth_labs = List.map (get_method_label table) virt_meths in\n  let concr_meth_labs = List.map (get_method_label table) concr_meths in\n  table.previous_states <-\n     (table.methods_by_name, table.methods_by_label, table.hidden_meths,\n      table.vars, virt_meth_labs, vars)\n     :: table.previous_states;\n  table.vars <-\n    Vars.fold\n      (fun lab info tvars ->\n        if List.mem lab vars then Vars.add lab info tvars else tvars)\n      table.vars Vars.empty;\n  let by_name = ref Meths.empty in\n  let by_label = ref Labs.empty in\n  List.iter2\n    (fun met label ->\n       by_name := Meths.add met label !by_name;\n       by_label :=\n          Labs.add label\n            (try Labs.find label table.methods_by_label with Not_found -> true)\n            !by_label)\n    concr_meths concr_meth_labs;\n  List.iter2\n    (fun met label ->\n       by_name := Meths.add met label !by_name;\n       by_label := Labs.add label false !by_label)\n    virt_meths virt_meth_labs;\n  table.methods_by_name <- !by_name;\n  table.methods_by_label <- !by_label;\n  table.hidden_meths <-\n     List.fold_right\n       (fun ((lab, _) as met) hm ->\n          if List.mem lab virt_meth_labs then hm else met::hm)\n       table.hidden_meths\n       []\n\nlet widen table =\n  let (by_name, by_label, saved_hidden_meths, saved_vars, virt_meths, vars) =\n    List.hd table.previous_states\n  in\n  table.previous_states <- List.tl table.previous_states;\n  table.vars <-\n     List.fold_left\n       (fun s v -> Vars.add v (Vars.find v table.vars) s)\n       saved_vars vars;\n  table.methods_by_name <- by_name;\n  table.methods_by_label <- by_label;\n  table.hidden_meths <-\n     List.fold_right\n       (fun ((lab, _) as met) hm ->\n          if List.mem lab virt_meths then hm else met::hm)\n       table.hidden_meths\n       saved_hidden_meths\n\nlet new_slot table =\n  let index = table.size in\n  table.size <- index + 1;\n  index\n\nlet new_variable table name =\n  try Vars.find name table.vars\n  with Not_found ->\n    let index = new_slot table in\n    if name <> \"\" then table.vars <- Vars.add name index table.vars;\n    index\n\nlet to_array arr =\n  if arr = Obj.magic 0 then [||] else arr\n\nlet new_methods_variables table meths vals =\n  let meths = to_array meths in\n  let nmeths = Array.length meths and nvals = Array.length vals in\n  let res = Array.make (nmeths + nvals) 0 in\n  for i = 0 to nmeths - 1 do\n    res.(i) <- get_method_label table meths.(i)\n  done;\n  for i = 0 to nvals - 1 do\n    res.(i+nmeths) <- new_variable table vals.(i)\n  done;\n  res\n\nlet get_variable table name =\n  try Vars.find name table.vars with Not_found -> assert false\n\nlet get_variables table names =\n  Array.map (get_variable table) names\n\nlet add_initializer table f =\n  table.initializers <- f::table.initializers\n\n(*\nmodule Keys =\n  Map.Make(struct type t = tag array let compare (x:t) y = compare x y end)\nlet key_map = ref Keys.empty\nlet get_key tags : item =\n  try magic (Keys.find tags !key_map : tag array)\n  with Not_found ->\n    key_map := Keys.add tags tags !key_map;\n    magic tags\n*)\n\nlet create_table public_methods =\n  if public_methods == magic 0 then new_table [||] else\n  (* [public_methods] must be in ascending order for bytecode *)\n  let tags = Array.map public_method_label public_methods in\n  let table = new_table tags in\n  Array.iteri\n    (fun i met ->\n      let lab = i*2+2 in\n      table.methods_by_name  <- Meths.add met lab table.methods_by_name;\n      table.methods_by_label <- Labs.add lab true table.methods_by_label)\n    public_methods;\n  table\n\nlet init_class table =\n  inst_var_count := !inst_var_count + table.size - 1;\n  table.initializers <- List.rev table.initializers;\n  resize table (3 + magic table.methods.(1) * 16 / Sys.word_size)\n\nlet inherits cla vals virt_meths concr_meths (_, super, _, env) top =\n  narrow cla vals virt_meths concr_meths;\n  let init =\n    if top then super cla env else Obj.repr (super cla) in\n  widen cla;\n  Array.concat\n    [[| repr init |];\n     magic (Array.map (get_variable cla) (to_array vals) : int array);\n     Array.map\n       (fun nm -> repr (get_method cla (get_method_label cla nm) : closure))\n       (to_array concr_meths) ]\n\nlet make_class pub_meths class_init =\n  let table = create_table pub_meths in\n  let env_init = class_init table in\n  init_class table;\n  (env_init (Obj.repr 0), class_init, env_init, Obj.repr 0)\n\ntype init_table = { mutable env_init: t; mutable class_init: table -> t }\n[@@warning \"-unused-field\"]\n\nlet make_class_store pub_meths class_init init_table =\n  let table = create_table pub_meths in\n  let env_init = class_init table in\n  init_class table;\n  init_table.class_init <- class_init;\n  init_table.env_init <- env_init\n\nlet dummy_class loc =\n  let undef = fun _ -> raise (Undefined_recursive_module loc) in\n  (Obj.magic undef, undef, undef, Obj.repr 0)\n\n(**** Objects ****)\n\nlet create_object table =\n  (* XXX Appel de [obj_block] | Call to [obj_block]  *)\n  let obj = Obj.new_block Obj.object_tag table.size in\n  (* XXX Appel de [caml_modify] | Call to [caml_modify] *)\n  Obj.set_field obj 0 (Obj.repr table.methods);\n  Obj.obj (set_id obj)\n\nlet create_object_opt obj_0 table =\n  if (Obj.magic obj_0 : bool) then obj_0 else begin\n    (* XXX Appel de [obj_block] | Call to [obj_block]  *)\n    let obj = Obj.new_block Obj.object_tag table.size in\n    (* XXX Appel de [caml_modify] | Call to [caml_modify] *)\n    Obj.set_field obj 0 (Obj.repr table.methods);\n    Obj.obj (set_id obj)\n  end\n\nlet rec iter_f obj =\n  function\n    []   -> ()\n  | f::l -> f obj; iter_f obj l\n\nlet run_initializers obj table =\n  let inits = table.initializers in\n  if inits <> [] then\n    iter_f obj inits\n\nlet run_initializers_opt obj_0 obj table =\n  if (Obj.magic obj_0 : bool) then obj else begin\n    let inits = table.initializers in\n    if inits <> [] then iter_f obj inits;\n    obj\n  end\n\nlet create_object_and_run_initializers obj_0 table =\n  if (Obj.magic obj_0 : bool) then obj_0 else begin\n    let obj = create_object table in\n    run_initializers obj table;\n    obj\n  end\n\n(* Equivalent primitive below\nlet sendself obj lab =\n  (magic obj : (obj -> t) array array).(0).(lab) obj\n*)\nexternal send : obj -> tag -> 'a = \"%send\"\nexternal sendcache : obj -> tag -> t -> int -> 'a = \"%sendcache\"\nexternal sendself : obj -> label -> 'a = \"%sendself\"\nexternal get_public_method : obj -> tag -> closure\n    = \"caml_get_public_method\" [@@noalloc]\n\n(**** table collection access ****)\n\ntype tables =\n  | Empty\n  | Cons of {key : closure; mutable data: tables; mutable next: tables}\n\nlet set_data tables v = match tables with\n  | Empty -> assert false\n  | Cons tables -> tables.data <- v\nlet set_next tables v = match tables with\n  | Empty -> assert false\n  | Cons tables -> tables.next <- v\nlet get_key = function\n  | Empty -> assert false\n  | Cons tables -> tables.key\nlet get_data = function\n  | Empty -> assert false\n  | Cons tables -> tables.data\nlet get_next = function\n  | Empty -> assert false\n  | Cons tables -> tables.next\n\nlet build_path n keys tables =\n  let res = Cons {key = Obj.magic 0; data = Empty; next = Empty} in\n  let r = ref res in\n  for i = 0 to n do\n    r := Cons {key = keys.(i); data = !r; next = Empty}\n  done;\n  set_data tables !r;\n  res\n\nlet rec lookup_keys i keys tables =\n  if i < 0 then tables else\n  let key = keys.(i) in\n  let rec lookup_key (tables:tables) =\n    if get_key tables == key then\n      match get_data tables with\n      | Empty -> assert false\n      | Cons _ as tables_data ->\n          lookup_keys (i-1) keys tables_data\n    else\n      match get_next tables with\n      | Cons _ as next -> lookup_key next\n      | Empty ->\n          let next : tables = Cons {key; data = Empty; next = Empty} in\n          set_next tables next;\n          build_path (i-1) keys next\n  in\n  lookup_key tables\n\nlet lookup_tables root keys =\n  match get_data root with\n  | Cons _ as root_data ->\n    lookup_keys (Array.length keys - 1) keys root_data\n  | Empty ->\n    build_path (Array.length keys - 1) keys root\n\n(**** builtin methods ****)\n\nlet get_const x = ret (fun _obj -> x)\nlet get_var n   = ret (fun obj -> Array.unsafe_get obj n)\nlet get_env e n =\n  ret (fun obj ->\n    Array.unsafe_get (Obj.magic (Array.unsafe_get obj e) : obj) n)\nlet get_meth n  = ret (fun obj -> sendself obj n)\nlet set_var n   = ret (fun obj x -> Array.unsafe_set obj n x)\nlet app_const f x = ret (fun _obj -> f x)\nlet app_var f n   = ret (fun obj -> f (Array.unsafe_get obj n))\nlet app_env f e n =\n  ret (fun obj ->\n    f (Array.unsafe_get (Obj.magic (Array.unsafe_get obj e) : obj) n))\nlet app_meth f n  = ret (fun obj -> f (sendself obj n))\nlet app_const_const f x y = ret (fun _obj -> f x y)\nlet app_const_var f x n   = ret (fun obj -> f x (Array.unsafe_get obj n))\nlet app_const_meth f x n = ret (fun obj -> f x (sendself obj n))\nlet app_var_const f n x = ret (fun obj -> f (Array.unsafe_get obj n) x)\nlet app_meth_const f n x = ret (fun obj -> f (sendself obj n) x)\nlet app_const_env f x e n =\n  ret (fun obj ->\n    f x (Array.unsafe_get (Obj.magic (Array.unsafe_get obj e) : obj) n))\nlet app_env_const f e n x =\n  ret (fun obj ->\n    f (Array.unsafe_get (Obj.magic (Array.unsafe_get obj e) : obj) n) x)\nlet meth_app_const n x = ret (fun obj -> (sendself obj n : _ -> _) x)\nlet meth_app_var n m =\n  ret (fun obj -> (sendself obj n : _ -> _) (Array.unsafe_get obj m))\nlet meth_app_env n e m =\n  ret (fun obj -> (sendself obj n : _ -> _)\n      (Array.unsafe_get (Obj.magic (Array.unsafe_get obj e) : obj) m))\nlet meth_app_meth n m =\n  ret (fun obj -> (sendself obj n : _ -> _) (sendself obj m))\nlet send_const m x c =\n  ret (fun obj -> sendcache x m (Array.unsafe_get obj 0) c)\nlet send_var m n c =\n  ret (fun obj ->\n    sendcache (Obj.magic (Array.unsafe_get obj n) : obj) m\n      (Array.unsafe_get obj 0) c)\nlet send_env m e n c =\n  ret (fun obj ->\n    sendcache\n      (Obj.magic (Array.unsafe_get\n                    (Obj.magic (Array.unsafe_get obj e) : obj) n) : obj)\n      m (Array.unsafe_get obj 0) c)\nlet send_meth m n c =\n  ret (fun obj ->\n    sendcache (sendself obj n) m (Array.unsafe_get obj 0) c)\nlet new_cache table =\n  let n = new_method table in\n  let n =\n    if n mod 2 = 0 || n > 2 + magic table.methods.(1) * 16 / Sys.word_size\n    then n else new_method table\n  in\n  table.methods.(n) <- Obj.magic 0;\n  n\n\ntype impl =\n    GetConst\n  | GetVar\n  | GetEnv\n  | GetMeth\n  | SetVar\n  | AppConst\n  | AppVar\n  | AppEnv\n  | AppMeth\n  | AppConstConst\n  | AppConstVar\n  | AppConstEnv\n  | AppConstMeth\n  | AppVarConst\n  | AppEnvConst\n  | AppMethConst\n  | MethAppConst\n  | MethAppVar\n  | MethAppEnv\n  | MethAppMeth\n  | SendConst\n  | SendVar\n  | SendEnv\n  | SendMeth\n  | Closure of closure\n\nlet method_impl table i arr =\n  let next () = incr i; magic arr.(!i) in\n  match next() with\n    GetConst -> let x : t = next() in get_const x\n  | GetVar   -> let n = next() in get_var n\n  | GetEnv   -> let e = next() in let n = next() in get_env e n\n  | GetMeth  -> let n = next() in get_meth n\n  | SetVar   -> let n = next() in set_var n\n  | AppConst -> let f = next() in let x = next() in app_const f x\n  | AppVar   -> let f = next() in let n = next () in app_var f n\n  | AppEnv   ->\n      let f = next() in  let e = next() in let n = next() in\n      app_env f e n\n  | AppMeth  -> let f = next() in let n = next () in app_meth f n\n  | AppConstConst ->\n      let f = next() in let x = next() in let y = next() in\n      app_const_const f x y\n  | AppConstVar ->\n      let f = next() in let x = next() in let n = next() in\n      app_const_var f x n\n  | AppConstEnv ->\n      let f = next() in let x = next() in let e = next () in let n = next() in\n      app_const_env f x e n\n  | AppConstMeth ->\n      let f = next() in let x = next() in let n = next() in\n      app_const_meth f x n\n  | AppVarConst ->\n      let f = next() in let n = next() in let x = next() in\n      app_var_const f n x\n  | AppEnvConst ->\n      let f = next() in let e = next () in let n = next() in let x = next() in\n      app_env_const f e n x\n  | AppMethConst ->\n      let f = next() in let n = next() in let x = next() in\n      app_meth_const f n x\n  | MethAppConst ->\n      let n = next() in let x = next() in meth_app_const n x\n  | MethAppVar ->\n      let n = next() in let m = next() in meth_app_var n m\n  | MethAppEnv ->\n      let n = next() in let e = next() in let m = next() in\n      meth_app_env n e m\n  | MethAppMeth ->\n      let n = next() in let m = next() in meth_app_meth n m\n  | SendConst ->\n      let m = next() in let x = next() in send_const m x (new_cache table)\n  | SendVar ->\n      let m = next() in let n = next () in send_var m n (new_cache table)\n  | SendEnv ->\n      let m = next() in let e = next() in let n = next() in\n      send_env m e n (new_cache table)\n  | SendMeth ->\n      let m = next() in let n = next () in send_meth m n (new_cache table)\n  | Closure _ as clo -> magic clo\n\nlet set_methods table methods =\n  let len = Array.length methods in let i = ref 0 in\n  while !i < len do\n    let label = methods.(!i) in let clo = method_impl table i methods in\n    set_method table label clo;\n    incr i\n  done\n\n(**** Statistics ****)\n\ntype stats =\n  { classes: int; methods: int; inst_vars: int; }\n\nlet stats () =\n  { classes = !table_count;\n    methods = !method_count; inst_vars = !inst_var_count; }\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*          Xavier Leroy, projet Cristal, INRIA Rocquencourt              *)\n(*                                                                        *)\n(*   Copyright 2004 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\ntype shape =\n  | Function\n  | Lazy\n  | Class\n  | Module of shape array\n  | Value of Obj.t\n\nlet rec init_mod_field modu i loc shape =\n  let init =\n    match shape with\n    | Function ->\n       let rec fn (x : 'a) =\n         let fn' : 'a -> 'b = Obj.obj (Obj.field modu i) in\n         if fn == fn' then\n           raise (Undefined_recursive_module loc)\n         else\n           fn' x in\n       Obj.repr fn\n    | Lazy ->\n       let rec l =\n         lazy (\n           let l' = Obj.obj (Obj.field modu i) in\n           if l == l' then\n             raise (Undefined_recursive_module loc)\n           else\n             Lazy.force l') in\n       Obj.repr l\n    | Class ->\n       Obj.repr (CamlinternalOO.dummy_class loc)\n    | Module comps ->\n       Obj.repr (init_mod_block loc comps)\n    | Value v -> v\n  in\n  Obj.set_field modu i init\n\nand init_mod_block loc comps =\n  let length = Array.length comps in\n  let modu = Obj.new_block 0 length in\n  for i = 0 to length - 1 do\n    init_mod_field modu i loc comps.(i)\n  done;\n  modu\n\nlet init_mod loc shape =\n  match shape with\n  | Module comps ->\n     Obj.repr (init_mod_block loc comps)\n  | _ -> failwith \"CamlinternalMod.init_mod: not a module\"\n\nlet rec update_mod_field modu i shape n =\n  match shape with\n  | Function | Lazy ->\n     Obj.set_field modu i n\n  | Value _ ->\n     () (* the value is already there *)\n  | Class ->\n     assert (Obj.tag n = 0 && Obj.size n = 4);\n     let cl = Obj.field modu i in\n     for j = 0 to 3 do\n       Obj.set_field cl j (Obj.field n j)\n     done\n  | Module comps ->\n     update_mod_block comps (Obj.field modu i) n\n\nand update_mod_block comps o n =\n  assert (Obj.tag n = 0 && Obj.size n >= Array.length comps);\n  for i = 0 to Array.length comps - 1 do\n    update_mod_field o i comps.(i) (Obj.field n i)\n  done\n\nlet update_mod shape o n =\n  match shape with\n  | Module comps ->\n     update_mod_block comps o n\n  | _ -> failwith \"CamlinternalMod.update_mod: not a module\"\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*               Xavier Leroy, projet Cristal, INRIA Rocquencourt         *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\ntype token =\n    Kwd of string\n  | Ident of string\n  | Int of int\n  | Float of float\n  | String of string\n  | Char of char\n\n(* The string buffering machinery *)\n\nlet initial_buffer = Bytes.create 32\n\nlet buffer = ref initial_buffer\nlet bufpos = ref 0\n\nlet reset_buffer () = buffer := initial_buffer; bufpos := 0\n\nlet store c =\n  if !bufpos >= Bytes.length !buffer then begin\n    let newbuffer = Bytes.create (2 * !bufpos) in\n    Bytes.blit !buffer 0 newbuffer 0 !bufpos;\n    buffer := newbuffer\n  end;\n  Bytes.set !buffer !bufpos c;\n  incr bufpos\n\nlet get_string () =\n  let s = Bytes.sub_string !buffer 0 !bufpos in buffer := initial_buffer; s\n\n(* The lexer *)\n\nlet make_lexer keywords =\n  let kwd_table = Hashtbl.create 17 in\n  List.iter (fun s -> Hashtbl.add kwd_table s (Kwd s)) keywords;\n  let ident_or_keyword id =\n    try Hashtbl.find kwd_table id with\n      Not_found -> Ident id\n  and keyword_or_error c =\n    let s = String.make 1 c in\n    try Hashtbl.find kwd_table s with\n      Not_found -> raise (Stream.Error (\"Illegal character \" ^ s))\n  in\n  let rec next_token (strm__ : _ Stream.t) =\n    match Stream.peek strm__ with\n      Some (' ' | '\\010' | '\\013' | '\\009' | '\\026' | '\\012') ->\n        Stream.junk strm__; next_token strm__\n    | Some ('A'..'Z' | 'a'..'z' | '_' | '\\192'..'\\255' as c) ->\n        Stream.junk strm__;\n        let s = strm__ in reset_buffer (); store c; ident s\n    | Some\n        ('!' | '%' | '&' | '$' | '#' | '+' | '/' | ':' | '<' | '=' | '>' |\n         '?' | '@' | '\\\\' | '~' | '^' | '|' | '*' as c) ->\n        Stream.junk strm__;\n        let s = strm__ in reset_buffer (); store c; ident2 s\n    | Some ('0'..'9' as c) ->\n        Stream.junk strm__;\n        let s = strm__ in reset_buffer (); store c; number s\n    | Some '\\'' ->\n        Stream.junk strm__;\n        let c =\n          try char strm__ with\n            Stream.Failure -> raise (Stream.Error \"\")\n        in\n        begin match Stream.peek strm__ with\n          Some '\\'' -> Stream.junk strm__; Some (Char c)\n        | _ -> raise (Stream.Error \"\")\n        end\n    | Some '\\\"' ->\n        Stream.junk strm__;\n        let s = strm__ in reset_buffer (); Some (String (string s))\n    | Some '-' -> Stream.junk strm__; neg_number strm__\n    | Some '(' -> Stream.junk strm__; maybe_comment strm__\n    | Some c -> Stream.junk strm__; Some (keyword_or_error c)\n    | _ -> None\n  and ident (strm__ : _ Stream.t) =\n    match Stream.peek strm__ with\n      Some\n        ('A'..'Z' | 'a'..'z' | '\\192'..'\\255' | '0'..'9' | '_' | '\\'' as c) ->\n        Stream.junk strm__; let s = strm__ in store c; ident s\n    | _ -> Some (ident_or_keyword (get_string ()))\n  and ident2 (strm__ : _ Stream.t) =\n    match Stream.peek strm__ with\n      Some\n        ('!' | '%' | '&' | '$' | '#' | '+' | '-' | '/' | ':' | '<' | '=' |\n         '>' | '?' | '@' | '\\\\' | '~' | '^' | '|' | '*' as c) ->\n        Stream.junk strm__; let s = strm__ in store c; ident2 s\n    | _ -> Some (ident_or_keyword (get_string ()))\n  and neg_number (strm__ : _ Stream.t) =\n    match Stream.peek strm__ with\n      Some ('0'..'9' as c) ->\n        Stream.junk strm__;\n        let s = strm__ in reset_buffer (); store '-'; store c; number s\n    | _ -> let s = strm__ in reset_buffer (); store '-'; ident2 s\n  and number (strm__ : _ Stream.t) =\n    match Stream.peek strm__ with\n      Some ('0'..'9' as c) ->\n        Stream.junk strm__; let s = strm__ in store c; number s\n    | Some '.' ->\n        Stream.junk strm__; let s = strm__ in store '.'; decimal_part s\n    | Some ('e' | 'E') ->\n        Stream.junk strm__; let s = strm__ in store 'E'; exponent_part s\n    | _ -> Some (Int (int_of_string (get_string ())))\n  and decimal_part (strm__ : _ Stream.t) =\n    match Stream.peek strm__ with\n      Some ('0'..'9' as c) ->\n        Stream.junk strm__; let s = strm__ in store c; decimal_part s\n    | Some ('e' | 'E') ->\n        Stream.junk strm__; let s = strm__ in store 'E'; exponent_part s\n    | _ -> Some (Float (float_of_string (get_string ())))\n  and exponent_part (strm__ : _ Stream.t) =\n    match Stream.peek strm__ with\n      Some ('+' | '-' as c) ->\n        Stream.junk strm__; let s = strm__ in store c; end_exponent_part s\n    | _ -> end_exponent_part strm__\n  and end_exponent_part (strm__ : _ Stream.t) =\n    match Stream.peek strm__ with\n      Some ('0'..'9' as c) ->\n        Stream.junk strm__; let s = strm__ in store c; end_exponent_part s\n    | _ -> Some (Float (float_of_string (get_string ())))\n  and string (strm__ : _ Stream.t) =\n    match Stream.peek strm__ with\n      Some '\\\"' -> Stream.junk strm__; get_string ()\n    | Some '\\\\' ->\n        Stream.junk strm__;\n        let c =\n          try escape strm__ with\n            Stream.Failure -> raise (Stream.Error \"\")\n        in\n        let s = strm__ in store c; string s\n    | Some c -> Stream.junk strm__; let s = strm__ in store c; string s\n    | _ -> raise Stream.Failure\n  and char (strm__ : _ Stream.t) =\n    match Stream.peek strm__ with\n      Some '\\\\' ->\n        Stream.junk strm__;\n        begin try escape strm__ with\n          Stream.Failure -> raise (Stream.Error \"\")\n        end\n    | Some c -> Stream.junk strm__; c\n    | _ -> raise Stream.Failure\n  and escape (strm__ : _ Stream.t) =\n    match Stream.peek strm__ with\n      Some 'n' -> Stream.junk strm__; '\\n'\n    | Some 'r' -> Stream.junk strm__; '\\r'\n    | Some 't' -> Stream.junk strm__; '\\t'\n    | Some ('0'..'9' as c1) ->\n        Stream.junk strm__;\n        begin match Stream.peek strm__ with\n          Some ('0'..'9' as c2) ->\n            Stream.junk strm__;\n            begin match Stream.peek strm__ with\n              Some ('0'..'9' as c3) ->\n                Stream.junk strm__;\n                Char.chr\n                  ((Char.code c1 - 48) * 100 + (Char.code c2 - 48) * 10 +\n                     (Char.code c3 - 48))\n            | _ -> raise (Stream.Error \"\")\n            end\n        | _ -> raise (Stream.Error \"\")\n        end\n    | Some c -> Stream.junk strm__; c\n    | _ -> raise Stream.Failure\n  and maybe_comment (strm__ : _ Stream.t) =\n    match Stream.peek strm__ with\n      Some '*' ->\n        Stream.junk strm__; let s = strm__ in comment s; next_token s\n    | _ -> Some (keyword_or_error '(')\n  and comment (strm__ : _ Stream.t) =\n    match Stream.peek strm__ with\n      Some '(' -> Stream.junk strm__; maybe_nested_comment strm__\n    | Some '*' -> Stream.junk strm__; maybe_end_comment strm__\n    | Some _ -> Stream.junk strm__; comment strm__\n    | _ -> raise Stream.Failure\n  and maybe_nested_comment (strm__ : _ Stream.t) =\n    match Stream.peek strm__ with\n      Some '*' -> Stream.junk strm__; let s = strm__ in comment s; comment s\n    | Some _ -> Stream.junk strm__; comment strm__\n    | _ -> raise Stream.Failure\n  and maybe_end_comment (strm__ : _ Stream.t) =\n    match Stream.peek strm__ with\n      Some ')' -> Stream.junk strm__; ()\n    | Some '*' -> Stream.junk strm__; maybe_end_comment strm__\n    | Some _ -> Stream.junk strm__; comment strm__\n    | _ -> raise Stream.Failure\n  in\n  fun input -> Stream.from (fun _count -> next_token input)\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Damien Doligez, projet Para, INRIA Rocquencourt            *)\n(*                                                                        *)\n(*   Copyright 1997 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\nmodule type SeededS = sig\n  include Hashtbl.SeededS\n  val clean: 'a t -> unit\n  val stats_alive: 'a t -> Hashtbl.statistics\n    (** same as {!stats} but only count the alive bindings *)\nend\n\nmodule type S = sig\n  include Hashtbl.S\n  val clean: 'a t -> unit\n  val stats_alive: 'a t -> Hashtbl.statistics\n    (** same as {!stats} but only count the alive bindings *)\nend\n\nmodule GenHashTable = struct\n\n  type equal =\n  | ETrue | EFalse\n  | EDead (** the garbage collector reclaimed the data *)\n\n  module MakeSeeded(H: sig\n    type t\n    type 'a container\n    val create: t -> 'a -> 'a container\n    val hash: int -> t -> int\n    val equal: 'a container -> t -> equal\n    val get_data: 'a container -> 'a option\n    val get_key: 'a container -> t option\n    val set_key_data: 'a container -> t -> 'a -> unit\n    val check_key: 'a container -> bool\n  end) : SeededS with type key = H.t\n  = struct\n\n    type 'a t =\n      { mutable size: int;                  (* number of entries *)\n        mutable data: 'a bucketlist array;  (* the buckets *)\n        seed: int;                          (* for randomization *)\n        initial_size: int;                  (* initial array size *)\n      }\n\n    and 'a bucketlist =\n    | Empty\n    | Cons of int (* hash of the key *) * 'a H.container * 'a bucketlist\n\n    (** the hash of the key is kept in order to test the equality of the hash\n      before the key. Same reason as for Weak.Make *)\n\n    type key = H.t\n\n    let rec power_2_above x n =\n      if x >= n then x\n      else if x * 2 > Sys.max_array_length then x\n      else power_2_above (x * 2) n\n\n    let prng = lazy (Random.State.make_self_init())\n\n    let create ?(random = (Hashtbl.is_randomized ())) initial_size =\n      let s = power_2_above 16 initial_size in\n      let seed = if random then Random.State.bits (Lazy.force prng) else 0 in\n      { initial_size = s; size = 0; seed = seed; data = Array.make s Empty }\n\n    let clear h =\n      h.size <- 0;\n      let len = Array.length h.data in\n      for i = 0 to len - 1 do\n        h.data.(i) <- Empty\n      done\n\n    let reset h =\n      let len = Array.length h.data in\n      if len = h.initial_size then\n        clear h\n      else begin\n        h.size <- 0;\n        h.data <- Array.make h.initial_size Empty\n      end\n\n    let copy h = { h with data = Array.copy h.data }\n\n    let key_index h hkey =\n      hkey land (Array.length h.data - 1)\n\n    let clean h =\n      let rec do_bucket = function\n        | Empty ->\n            Empty\n        | Cons(_, c, rest) when not (H.check_key c) ->\n            h.size <- h.size - 1;\n            do_bucket rest\n        | Cons(hkey, c, rest) ->\n            Cons(hkey, c, do_bucket rest)\n      in\n      let d = h.data in\n      for i = 0 to Array.length d - 1 do\n        d.(i) <- do_bucket d.(i)\n      done\n\n    (** resize is the only function to do the actual cleaning of dead keys\n        (remove does it just because it could).\n\n        The goal is to:\n\n        - not resize infinitely when the actual number of alive keys is\n        bounded but keys are continuously added. That would happen if\n        this function always resize.\n        - not call this function after each addition, that would happen if this\n        function don't resize even when only one key is dead.\n\n        So the algorithm:\n        - clean the keys before resizing\n        - if the number of remaining keys is less than half the size of the\n        array, don't resize.\n        - if it is more, resize.\n\n        The second problem remains if the table reaches {!Sys.max_array_length}.\n\n    *)\n    let resize h =\n      let odata = h.data in\n      let osize = Array.length odata in\n      let nsize = osize * 2 in\n      clean h;\n      if nsize < Sys.max_array_length && h.size >= osize lsr 1 then begin\n        let ndata = Array.make nsize Empty in\n        h.data <- ndata;       (* so that key_index sees the new bucket count *)\n        let rec insert_bucket = function\n            Empty -> ()\n          | Cons(hkey, data, rest) ->\n              insert_bucket rest; (* preserve original order of elements *)\n              let nidx = key_index h hkey in\n              ndata.(nidx) <- Cons(hkey, data, ndata.(nidx)) in\n        for i = 0 to osize - 1 do\n          insert_bucket odata.(i)\n        done\n      end\n\n    let add h key info =\n      let hkey = H.hash h.seed key in\n      let i = key_index h hkey in\n      let container = H.create key info in\n      let bucket = Cons(hkey, container, h.data.(i)) in\n      h.data.(i) <- bucket;\n      h.size <- h.size + 1;\n      if h.size > Array.length h.data lsl 1 then resize h\n\n    let remove h key =\n      let hkey = H.hash h.seed key in\n      let rec remove_bucket = function\n        | Empty -> Empty\n        | Cons(hk, c, next) when hkey = hk ->\n            begin match H.equal c key with\n            | ETrue -> h.size <- h.size - 1; next\n            | EFalse -> Cons(hk, c, remove_bucket next)\n            | EDead ->\n                (* The dead key is automatically removed. It is acceptable\n                    for this function since it already removes a binding *)\n                h.size <- h.size - 1;\n                remove_bucket next\n            end\n        | Cons(hk,c,next) -> Cons(hk, c, remove_bucket next) in\n      let i = key_index h hkey in\n      h.data.(i) <- remove_bucket h.data.(i)\n\n    (** {!find} don't remove dead keys because it would be surprising for\n        the user that a read-only function mutates the state (eg. concurrent\n        access). Same for {!iter}, {!fold}, {!mem}.\n    *)\n    let rec find_rec key hkey = function\n      | Empty ->\n          raise Not_found\n      | Cons(hk, c, rest) when hkey = hk  ->\n          begin match H.equal c key with\n          | ETrue ->\n              begin match H.get_data c with\n              | None ->\n                  (* This case is not impossible because the gc can run between\n                      H.equal and H.get_data *)\n                  find_rec key hkey rest\n              | Some d -> d\n              end\n          | EFalse -> find_rec key hkey rest\n          | EDead ->\n              find_rec key hkey rest\n          end\n      | Cons(_, _, rest) ->\n          find_rec key hkey rest\n\n    let find h key =\n      let hkey = H.hash h.seed key in\n      (* TODO inline 3 iterations *)\n      find_rec key hkey (h.data.(key_index h hkey))\n\n    let rec find_rec_opt key hkey = function\n      | Empty ->\n          None\n      | Cons(hk, c, rest) when hkey = hk  ->\n          begin match H.equal c key with\n          | ETrue ->\n              begin match H.get_data c with\n              | None ->\n                  (* This case is not impossible because the gc can run between\n                      H.equal and H.get_data *)\n                  find_rec_opt key hkey rest\n              | Some _ as d -> d\n              end\n          | EFalse -> find_rec_opt key hkey rest\n          | EDead ->\n              find_rec_opt key hkey rest\n          end\n      | Cons(_, _, rest) ->\n          find_rec_opt key hkey rest\n\n    let find_opt h key =\n      let hkey = H.hash h.seed key in\n      (* TODO inline 3 iterations *)\n      find_rec_opt key hkey (h.data.(key_index h hkey))\n\n    let find_all h key =\n      let hkey = H.hash h.seed key in\n      let rec find_in_bucket = function\n      | Empty -> []\n      | Cons(hk, c, rest) when hkey = hk  ->\n          begin match H.equal c key with\n          | ETrue -> begin match H.get_data c with\n              | None ->\n                  find_in_bucket rest\n              | Some d -> d::find_in_bucket rest\n            end\n          | EFalse -> find_in_bucket rest\n          | EDead ->\n              find_in_bucket rest\n          end\n      | Cons(_, _, rest) ->\n          find_in_bucket rest in\n      find_in_bucket h.data.(key_index h hkey)\n\n\n    let replace h key info =\n      let hkey = H.hash h.seed key in\n      let rec replace_bucket = function\n        | Empty -> raise Not_found\n        | Cons(hk, c, next) when hkey = hk ->\n            begin match H.equal c key with\n            | ETrue -> H.set_key_data c key info\n            | EFalse | EDead -> replace_bucket next\n            end\n        | Cons(_,_,next) -> replace_bucket next\n      in\n      let i = key_index h hkey in\n      let l = h.data.(i) in\n      try\n        replace_bucket l\n      with Not_found ->\n        let container = H.create key info in\n        h.data.(i) <- Cons(hkey, container, l);\n        h.size <- h.size + 1;\n        if h.size > Array.length h.data lsl 1 then resize h\n\n    let mem h key =\n      let hkey = H.hash h.seed key in\n      let rec mem_in_bucket = function\n      | Empty ->\n          false\n      | Cons(hk, c, rest) when hk = hkey ->\n          begin match H.equal c key with\n          | ETrue -> true\n          | EFalse | EDead -> mem_in_bucket rest\n          end\n      | Cons(_hk, _c, rest) -> mem_in_bucket rest in\n      mem_in_bucket h.data.(key_index h hkey)\n\n    let iter f h =\n      let rec do_bucket = function\n        | Empty ->\n            ()\n        | Cons(_, c, rest) ->\n            begin match H.get_key c, H.get_data c with\n            | None, _ | _, None -> ()\n            | Some k, Some d -> f k d\n            end; do_bucket rest in\n      let d = h.data in\n      for i = 0 to Array.length d - 1 do\n        do_bucket d.(i)\n      done\n\n    let fold f h init =\n      let rec do_bucket b accu =\n        match b with\n          Empty ->\n            accu\n        | Cons(_, c, rest) ->\n            let accu = begin match H.get_key c, H.get_data c with\n              | None, _ | _, None -> accu\n              | Some k, Some d -> f k d accu\n            end in\n            do_bucket rest accu  in\n      let d = h.data in\n      let accu = ref init in\n      for i = 0 to Array.length d - 1 do\n        accu := do_bucket d.(i) !accu\n      done;\n      !accu\n\n    let filter_map_inplace f h =\n      let rec do_bucket = function\n        | Empty ->\n            Empty\n        | Cons(hk, c, rest) ->\n            match H.get_key c, H.get_data c with\n            | None, _ | _, None ->\n                do_bucket rest\n            | Some k, Some d ->\n                match f k d with\n                | None ->\n                    do_bucket rest\n                | Some new_d ->\n                    H.set_key_data c k new_d;\n                    Cons(hk, c, do_bucket rest)\n      in\n      let d = h.data in\n      for i = 0 to Array.length d - 1 do\n        d.(i) <- do_bucket d.(i)\n      done\n\n    let length h = h.size\n\n    let rec bucket_length accu = function\n      | Empty -> accu\n      | Cons(_, _, rest) -> bucket_length (accu + 1) rest\n\n    let stats h =\n      let mbl =\n        Array.fold_left (fun m b -> Int.max m (bucket_length 0 b)) 0 h.data in\n      let histo = Array.make (mbl + 1) 0 in\n      Array.iter\n        (fun b ->\n           let l = bucket_length 0 b in\n           histo.(l) <- histo.(l) + 1)\n        h.data;\n      { Hashtbl.num_bindings = h.size;\n        num_buckets = Array.length h.data;\n        max_bucket_length = mbl;\n        bucket_histogram = histo }\n\n    let rec bucket_length_alive accu = function\n      | Empty -> accu\n      | Cons(_, c, rest) when H.check_key c ->\n          bucket_length_alive (accu + 1) rest\n      | Cons(_, _, rest) -> bucket_length_alive accu rest\n\n    let stats_alive h =\n      let size = ref 0 in\n      let mbl =\n        Array.fold_left\n          (fun m b -> Int.max m (bucket_length_alive 0 b)) 0 h.data\n      in\n      let histo = Array.make (mbl + 1) 0 in\n      Array.iter\n        (fun b ->\n           let l = bucket_length_alive 0 b in\n           size := !size + l;\n           histo.(l) <- histo.(l) + 1)\n        h.data;\n      { Hashtbl.num_bindings = !size;\n        num_buckets = Array.length h.data;\n        max_bucket_length = mbl;\n        bucket_histogram = histo }\n\n    let to_seq tbl =\n      (* capture current array, so that even if the table is resized we\n         keep iterating on the same array *)\n      let tbl_data = tbl.data in\n      (* state: index * next bucket to traverse *)\n      let rec aux i buck () = match buck with\n        | Empty ->\n            if i = Array.length tbl_data\n            then Seq.Nil\n            else aux(i+1) tbl_data.(i) ()\n        | Cons (_, c, next) ->\n            begin match H.get_key c, H.get_data c with\n              | None, _ | _, None -> aux i next ()\n              | Some key, Some data ->\n                  Seq.Cons ((key, data), aux i next)\n            end\n      in\n      aux 0 Empty\n\n    let to_seq_keys m = Seq.map fst (to_seq m)\n\n    let to_seq_values m = Seq.map snd (to_seq m)\n\n    let add_seq tbl i =\n      Seq.iter (fun (k,v) -> add tbl k v) i\n\n    let replace_seq tbl i =\n      Seq.iter (fun (k,v) -> replace tbl k v) i\n\n    let of_seq i =\n      let tbl = create 16 in\n      replace_seq tbl i;\n      tbl\n\n  end\nend\n\nmodule ObjEph = Obj.Ephemeron\n\nlet _obj_opt : Obj.t option -> 'a option = fun x ->\n  match x with\n  | None -> x\n  | Some v -> Some (Obj.obj v)\n\n(** The previous function is typed so this one is also correct *)\nlet obj_opt : Obj.t option -> 'a option = fun x -> Obj.magic x\n\n\nmodule K1 = struct\n  type ('k,'d) t = ObjEph.t\n\n  let create () : ('k,'d) t = ObjEph.create 1\n\n  let get_key (t:('k,'d) t) : 'k option = obj_opt (ObjEph.get_key t 0)\n  let get_key_copy (t:('k,'d) t) : 'k option = obj_opt (ObjEph.get_key_copy t 0)\n  let set_key (t:('k,'d) t) (k:'k) : unit = ObjEph.set_key t 0 (Obj.repr k)\n  let unset_key (t:('k,'d) t) : unit = ObjEph.unset_key t 0\n  let check_key (t:('k,'d) t) : bool = ObjEph.check_key t 0\n\n  let blit_key (t1:('k,'d) t) (t2:('k,'d) t): unit =\n    ObjEph.blit_key t1 0 t2 0 1\n\n  let get_data (t:('k,'d) t) : 'd option = obj_opt (ObjEph.get_data t)\n  let get_data_copy (t:('k,'d) t) : 'd option = obj_opt (ObjEph.get_data_copy t)\n  let set_data (t:('k,'d) t) (d:'d) : unit = ObjEph.set_data t (Obj.repr d)\n  let unset_data (t:('k,'d) t) : unit = ObjEph.unset_data t\n  let check_data (t:('k,'d) t) : bool = ObjEph.check_data t\n  let blit_data (t1:(_,'d) t) (t2:(_,'d) t) : unit = ObjEph.blit_data t1 t2\n\n  module MakeSeeded (H:Hashtbl.SeededHashedType) =\n    GenHashTable.MakeSeeded(struct\n      type 'a container = (H.t,'a) t\n      type t = H.t\n      let create k d =\n        let c = create () in\n        set_data c d;\n        set_key c k;\n        c\n      let hash = H.hash\n      let equal c k =\n        (* {!get_key_copy} is not used because the equality of the user can be\n            the physical equality *)\n        match get_key c with\n        | None -> GenHashTable.EDead\n        | Some k' ->\n            if H.equal k k' then GenHashTable.ETrue else GenHashTable.EFalse\n      let get_data = get_data\n      let get_key = get_key\n      let set_key_data c k d =\n        unset_data c;\n        set_key c k;\n        set_data c d\n      let check_key = check_key\n    end)\n\n  module Make(H: Hashtbl.HashedType): (S with type key = H.t) =\n  struct\n    include MakeSeeded(struct\n        type t = H.t\n        let equal = H.equal\n        let hash (_seed: int) x = H.hash x\n      end)\n    let create sz = create ~random:false sz\n    let of_seq i =\n      let tbl = create 16 in\n      replace_seq tbl i;\n      tbl\n  end\n\nend\n\nmodule K2 = struct\n  type ('k1, 'k2, 'd) t = ObjEph.t\n\n  let create () : ('k1,'k2,'d) t = ObjEph.create 2\n\n  let get_key1 (t:('k1,'k2,'d) t) : 'k1 option = obj_opt (ObjEph.get_key t 0)\n  let get_key1_copy (t:('k1,'k2,'d) t) : 'k1 option =\n    obj_opt (ObjEph.get_key_copy t 0)\n  let set_key1 (t:('k1,'k2,'d) t) (k:'k1) : unit =\n    ObjEph.set_key t 0 (Obj.repr k)\n  let unset_key1 (t:('k1,'k2,'d) t) : unit = ObjEph.unset_key t 0\n  let check_key1 (t:('k1,'k2,'d) t) : bool = ObjEph.check_key t 0\n\n  let get_key2 (t:('k1,'k2,'d) t) : 'k2 option = obj_opt (ObjEph.get_key t 1)\n  let get_key2_copy (t:('k1,'k2,'d) t) : 'k2 option =\n    obj_opt (ObjEph.get_key_copy t 1)\n  let set_key2 (t:('k1,'k2,'d) t) (k:'k2) : unit =\n    ObjEph.set_key t 1 (Obj.repr k)\n  let unset_key2 (t:('k1,'k2,'d) t) : unit = ObjEph.unset_key t 1\n  let check_key2 (t:('k1,'k2,'d) t) : bool = ObjEph.check_key t 1\n\n\n  let blit_key1 (t1:('k1,_,_) t) (t2:('k1,_,_) t) : unit =\n    ObjEph.blit_key t1 0 t2 0 1\n  let blit_key2 (t1:(_,'k2,_) t) (t2:(_,'k2,_) t) : unit =\n    ObjEph.blit_key t1 1 t2 1 1\n  let blit_key12 (t1:('k1,'k2,_) t) (t2:('k1,'k2,_) t) : unit =\n    ObjEph.blit_key t1 0 t2 0 2\n\n  let get_data (t:('k1,'k2,'d) t) : 'd option = obj_opt (ObjEph.get_data t)\n  let get_data_copy (t:('k1,'k2,'d) t) : 'd option =\n    obj_opt (ObjEph.get_data_copy t)\n  let set_data (t:('k1,'k2,'d) t) (d:'d) : unit =\n    ObjEph.set_data t (Obj.repr d)\n  let unset_data (t:('k1,'k2,'d) t) : unit = ObjEph.unset_data t\n  let check_data (t:('k1,'k2,'d) t) : bool = ObjEph.check_data t\n  let blit_data (t1:(_,_,'d) t) (t2:(_,_,'d) t) : unit = ObjEph.blit_data t1 t2\n\n  module MakeSeeded\n      (H1:Hashtbl.SeededHashedType)\n      (H2:Hashtbl.SeededHashedType) =\n    GenHashTable.MakeSeeded(struct\n      type 'a container = (H1.t,H2.t,'a) t\n      type t = H1.t * H2.t\n      let create (k1,k2) d =\n        let c = create () in\n        set_data c d;\n        set_key1 c k1; set_key2 c k2;\n        c\n      let hash seed (k1,k2) =\n        H1.hash seed k1 + H2.hash seed k2 * 65599\n      let equal c (k1,k2) =\n        match get_key1 c, get_key2 c with\n        | None, _ | _ , None -> GenHashTable.EDead\n        | Some k1', Some k2' ->\n            if H1.equal k1 k1' && H2.equal k2 k2'\n            then GenHashTable.ETrue else GenHashTable.EFalse\n      let get_data = get_data\n      let get_key c =\n        match get_key1 c, get_key2 c with\n        | None, _ | _ , None -> None\n        | Some k1', Some k2' -> Some (k1', k2')\n      let set_key_data c (k1,k2) d =\n        unset_data c;\n        set_key1 c k1; set_key2 c k2;\n        set_data c d\n      let check_key c = check_key1 c && check_key2 c\n    end)\n\n  module Make(H1: Hashtbl.HashedType)(H2: Hashtbl.HashedType):\n    (S with type key = H1.t * H2.t) =\n  struct\n    include MakeSeeded\n        (struct\n          type t = H1.t\n          let equal = H1.equal\n          let hash (_seed: int) x = H1.hash x\n        end)\n        (struct\n          type t = H2.t\n          let equal = H2.equal\n          let hash (_seed: int) x = H2.hash x\n        end)\n    let create sz = create ~random:false sz\n    let of_seq i =\n      let tbl = create 16 in\n      replace_seq tbl i;\n      tbl\n  end\n\nend\n\nmodule Kn = struct\n  type ('k,'d) t = ObjEph.t\n\n  let create n : ('k,'d) t = ObjEph.create n\n  let length (k:('k,'d) t) : int = ObjEph.length k\n\n  let get_key (t:('k,'d) t) (n:int) : 'k option = obj_opt (ObjEph.get_key t n)\n  let get_key_copy (t:('k,'d) t) (n:int) : 'k option =\n    obj_opt (ObjEph.get_key_copy t n)\n  let set_key (t:('k,'d) t) (n:int) (k:'k) : unit =\n    ObjEph.set_key t n (Obj.repr k)\n  let unset_key (t:('k,'d) t) (n:int) : unit = ObjEph.unset_key t n\n  let check_key (t:('k,'d) t) (n:int) : bool = ObjEph.check_key t n\n\n  let blit_key (t1:('k,'d) t) (o1:int) (t2:('k,'d) t) (o2:int) (l:int) : unit =\n    ObjEph.blit_key t1 o1 t2 o2 l\n\n  let get_data (t:('k,'d) t) : 'd option = obj_opt (ObjEph.get_data t)\n  let get_data_copy (t:('k,'d) t) : 'd option = obj_opt (ObjEph.get_data_copy t)\n  let set_data (t:('k,'d) t) (d:'d) : unit = ObjEph.set_data t (Obj.repr d)\n  let unset_data (t:('k,'d) t) : unit = ObjEph.unset_data t\n  let check_data (t:('k,'d) t) : bool = ObjEph.check_data t\n  let blit_data (t1:(_,'d) t) (t2:(_,'d) t) : unit = ObjEph.blit_data t1 t2\n\n  module MakeSeeded (H:Hashtbl.SeededHashedType) =\n    GenHashTable.MakeSeeded(struct\n      type 'a container = (H.t,'a) t\n      type t = H.t array\n      let create k d =\n        let c = create (Array.length k) in\n        set_data c d;\n        for i=0 to Array.length k -1 do\n          set_key c i k.(i);\n        done;\n        c\n      let hash seed k =\n        let h = ref 0 in\n        for i=0 to Array.length k -1 do\n          h := H.hash seed k.(i) * 65599 + !h;\n        done;\n        !h\n      let equal c k =\n        let len  = Array.length k in\n        let len' = length c in\n        if len != len' then GenHashTable.EFalse\n        else\n          let rec equal_array k c i =\n            if i < 0 then GenHashTable.ETrue\n            else\n              match get_key c i with\n              | None -> GenHashTable.EDead\n              | Some ki ->\n                  if H.equal k.(i) ki\n                  then equal_array k c (i-1)\n                  else GenHashTable.EFalse\n          in\n          equal_array k c (len-1)\n      let get_data = get_data\n      let get_key c =\n        let len = length c in\n        if len = 0 then Some [||]\n        else\n          match get_key c 0 with\n          | None -> None\n          | Some k0 ->\n              let rec fill a i =\n                if i < 1 then Some a\n                else\n                  match get_key c i with\n                  | None -> None\n                  | Some ki ->\n                      a.(i) <- ki;\n                      fill a (i-1)\n              in\n              let a = Array.make len k0 in\n              fill a (len-1)\n      let set_key_data c k d =\n        unset_data c;\n        for i=0 to Array.length k -1 do\n          set_key c i k.(i);\n        done;\n        set_data c d\n      let check_key c =\n        let rec check c i =\n          i < 0 || (check_key c i && check c (i-1)) in\n        check c (length c - 1)\n    end)\n\n  module Make(H: Hashtbl.HashedType): (S with type key = H.t array) =\n  struct\n    include MakeSeeded(struct\n        type t = H.t\n        let equal = H.equal\n        let hash (_seed: int) x = H.hash x\n      end)\n    let create sz = create ~random:false sz\n    let of_seq i =\n      let tbl = create 16 in\n      replace_seq tbl i;\n      tbl\n  end\nend\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*           Xavier Leroy and Damien Doligez, INRIA Rocquencourt          *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\nlet generic_quote quotequote s =\n  let l = String.length s in\n  let b = Buffer.create (l + 20) in\n  Buffer.add_char b '\\'';\n  for i = 0 to l - 1 do\n    if s.[i] = '\\''\n    then Buffer.add_string b quotequote\n    else Buffer.add_char b  s.[i]\n  done;\n  Buffer.add_char b '\\'';\n  Buffer.contents b\n\n(* This function implements the Open Group specification found here:\n  [[1]] http://pubs.opengroup.org/onlinepubs/9699919799/utilities/basename.html\n  In step 1 of [[1]], we choose to return \".\" for empty input.\n    (for compatibility with previous versions of OCaml)\n  In step 2, we choose to process \"//\" normally.\n  Step 6 is not implemented: we consider that the [suffix] operand is\n    always absent.  Suffixes are handled by [chop_suffix] and [chop_extension].\n*)\nlet generic_basename is_dir_sep current_dir_name name =\n  let rec find_end n =\n    if n < 0 then String.sub name 0 1\n    else if is_dir_sep name n then find_end (n - 1)\n    else find_beg n (n + 1)\n  and find_beg n p =\n    if n < 0 then String.sub name 0 p\n    else if is_dir_sep name n then String.sub name (n + 1) (p - n - 1)\n    else find_beg (n - 1) p\n  in\n  if name = \"\"\n  then current_dir_name\n  else find_end (String.length name - 1)\n\n(* This function implements the Open Group specification found here:\n  [[2]] http://pubs.opengroup.org/onlinepubs/9699919799/utilities/dirname.html\n  In step 6 of [[2]], we choose to process \"//\" normally.\n*)\nlet generic_dirname is_dir_sep current_dir_name name =\n  let rec trailing_sep n =\n    if n < 0 then String.sub name 0 1\n    else if is_dir_sep name n then trailing_sep (n - 1)\n    else base n\n  and base n =\n    if n < 0 then current_dir_name\n    else if is_dir_sep name n then intermediate_sep n\n    else base (n - 1)\n  and intermediate_sep n =\n    if n < 0 then String.sub name 0 1\n    else if is_dir_sep name n then intermediate_sep (n - 1)\n    else String.sub name 0 (n + 1)\n  in\n  if name = \"\"\n  then current_dir_name\n  else trailing_sep (String.length name - 1)\n\nmodule type SYSDEPS = sig\n  val null : string\n  val current_dir_name : string\n  val parent_dir_name : string\n  val dir_sep : string\n  val is_dir_sep : string -> int -> bool\n  val is_relative : string -> bool\n  val is_implicit : string -> bool\n  val check_suffix : string -> string -> bool\n  val chop_suffix_opt : suffix:string -> string -> string option\n  val temp_dir_name : string\n  val quote : string -> string\n  val quote_command :\n    string -> ?stdin: string -> ?stdout: string -> ?stderr: string\n           -> string list -> string\n  val basename : string -> string\n  val dirname : string -> string\nend\n\nmodule Unix : SYSDEPS = struct\n  let null = \"/dev/null\"\n  let current_dir_name = \".\"\n  let parent_dir_name = \"..\"\n  let dir_sep = \"/\"\n  let is_dir_sep s i = s.[i] = '/'\n  let is_relative n = String.length n < 1 || n.[0] <> '/'\n  let is_implicit n =\n    is_relative n\n    && (String.length n < 2 || String.sub n 0 2 <> \"./\")\n    && (String.length n < 3 || String.sub n 0 3 <> \"../\")\n  let check_suffix name suff =\n    String.ends_with ~suffix:suff name\n\n  let chop_suffix_opt ~suffix filename =\n    let len_s = String.length suffix and len_f = String.length filename in\n    if len_f >= len_s then\n      let r = String.sub filename (len_f - len_s) len_s in\n      if r = suffix then\n        Some (String.sub filename 0 (len_f - len_s))\n      else\n        None\n    else\n      None\n\n  let temp_dir_name =\n    try Sys.getenv \"TMPDIR\" with Not_found -> \"/tmp\"\n  let quote = generic_quote \"'\\\\''\"\n  let quote_command cmd ?stdin ?stdout ?stderr args =\n    String.concat \" \" (List.map quote (cmd :: args))\n    ^ (match stdin  with None -> \"\" | Some f -> \" <\" ^ quote f)\n    ^ (match stdout with None -> \"\" | Some f -> \" >\" ^ quote f)\n    ^ (match stderr with None -> \"\" | Some f -> if stderr = stdout\n                                                then \" 2>&1\"\n                                                else \" 2>\" ^ quote f)\n  let basename = generic_basename is_dir_sep current_dir_name\n  let dirname = generic_dirname is_dir_sep current_dir_name\nend\n\nmodule Win32 : SYSDEPS = struct\n  let null = \"NUL\"\n  let current_dir_name = \".\"\n  let parent_dir_name = \"..\"\n  let dir_sep = \"\\\\\"\n  let is_dir_sep s i = let c = s.[i] in c = '/' || c = '\\\\' || c = ':'\n  let is_relative n =\n    (String.length n < 1 || n.[0] <> '/')\n    && (String.length n < 1 || n.[0] <> '\\\\')\n    && (String.length n < 2 || n.[1] <> ':')\n  let is_implicit n =\n    is_relative n\n    && (String.length n < 2 || String.sub n 0 2 <> \"./\")\n    && (String.length n < 2 || String.sub n 0 2 <> \".\\\\\")\n    && (String.length n < 3 || String.sub n 0 3 <> \"../\")\n    && (String.length n < 3 || String.sub n 0 3 <> \"..\\\\\")\n  let check_suffix name suff =\n   String.length name >= String.length suff &&\n   (let s = String.sub name (String.length name - String.length suff)\n                            (String.length suff) in\n    String.lowercase_ascii s = String.lowercase_ascii suff)\n\n  let chop_suffix_opt ~suffix filename =\n    let len_s = String.length suffix and len_f = String.length filename in\n    if len_f >= len_s then\n      let r = String.sub filename (len_f - len_s) len_s in\n      if String.lowercase_ascii r = String.lowercase_ascii suffix then\n        Some (String.sub filename 0 (len_f - len_s))\n      else\n        None\n    else\n      None\n\n\n  let temp_dir_name =\n    try Sys.getenv \"TEMP\" with Not_found -> \".\"\n  let quote s =\n    let l = String.length s in\n    let b = Buffer.create (l + 20) in\n    Buffer.add_char b '\\\"';\n    let rec loop i =\n      if i = l then Buffer.add_char b '\\\"' else\n      match s.[i] with\n      | '\\\"' -> loop_bs 0 i;\n      | '\\\\' -> loop_bs 0 i;\n      | c    -> Buffer.add_char b c; loop (i+1);\n    and loop_bs n i =\n      if i = l then begin\n        Buffer.add_char b '\\\"';\n        add_bs n;\n      end else begin\n        match s.[i] with\n        | '\\\"' -> add_bs (2*n+1); Buffer.add_char b '\\\"'; loop (i+1);\n        | '\\\\' -> loop_bs (n+1) (i+1);\n        | _    -> add_bs n; loop i\n      end\n    and add_bs n = for _j = 1 to n do Buffer.add_char b '\\\\'; done\n    in\n    loop 0;\n    Buffer.contents b\n(*\nQuoting commands for execution by cmd.exe is difficult.\n1- Each argument is first quoted using the \"quote\" function above, to\n   protect it against the processing performed by the C runtime system,\n   then cmd.exe's special characters are escaped with '^', using\n   the \"quote_cmd\" function below.  For more details, see\n   https://blogs.msdn.microsoft.com/twistylittlepassagesallalike/2011/04/23\n2- The command and the redirection files, if any, must be double-quoted\n   in case they contain spaces.  This quoting is interpreted by cmd.exe,\n   not by the C runtime system, hence the \"quote\" function above\n   cannot be used.  The two characters we don't know how to quote\n   inside a double-quoted cmd.exe string are double-quote and percent.\n   We just fail if the command name or the redirection file names\n   contain a double quote (not allowed in Windows file names, anyway)\n   or a percent.  See function \"quote_cmd_filename\" below.\n3- The whole string passed to Sys.command is then enclosed in double\n   quotes, which are immediately stripped by cmd.exe.  Otherwise,\n   some of the double quotes from step 2 above can be misparsed.\n   See e.g. https://stackoverflow.com/a/9965141\n*)\n  let quote_cmd s =\n    let b = Buffer.create (String.length s + 20) in\n    String.iter\n      (fun c ->\n        match c with\n        | '(' | ')' | '!' | '^' | '%' | '\\\"' | '<' | '>' | '&' | '|' ->\n            Buffer.add_char b '^'; Buffer.add_char b c\n        | _ ->\n            Buffer.add_char b c)\n      s;\n    Buffer.contents b\n  let quote_cmd_filename f =\n    if String.contains f '\\\"' || String.contains f '%' then\n      failwith (\"Filename.quote_command: bad file name \" ^ f)\n    else if String.contains f ' ' then\n      \"\\\"\" ^ f ^ \"\\\"\"\n    else\n      f\n  (* Redirections in cmd.exe: see https://ss64.com/nt/syntax-redirection.html\n     and https://docs.microsoft.com/en-us/previous-versions/windows/it-pro/windows-xp/bb490982(v=technet.10)\n  *)\n  let quote_command cmd ?stdin ?stdout ?stderr args =\n    String.concat \"\" [\n      \"\\\"\";\n      quote_cmd_filename cmd;\n      \" \";\n      quote_cmd (String.concat \" \" (List.map quote args));\n      (match stdin  with None -> \"\" | Some f -> \" <\" ^ quote_cmd_filename f);\n      (match stdout with None -> \"\" | Some f -> \" >\" ^ quote_cmd_filename f);\n      (match stderr with None -> \"\" | Some f ->\n                                        if stderr = stdout\n                                        then \" 2>&1\"\n                                        else \" 2>\" ^ quote_cmd_filename f);\n      \"\\\"\"\n    ]\n  let has_drive s =\n    let is_letter = function\n      | 'A' .. 'Z' | 'a' .. 'z' -> true\n      | _ -> false\n    in\n    String.length s >= 2 && is_letter s.[0] && s.[1] = ':'\n  let drive_and_path s =\n    if has_drive s\n    then (String.sub s 0 2, String.sub s 2 (String.length s - 2))\n    else (\"\", s)\n  let dirname s =\n    let (drive, path) = drive_and_path s in\n    let dir = generic_dirname is_dir_sep current_dir_name path in\n    drive ^ dir\n  let basename s =\n    let (_drive, path) = drive_and_path s in\n    generic_basename is_dir_sep current_dir_name path\nend\n\nmodule Cygwin : SYSDEPS = struct\n  let null = \"/dev/null\"\n  let current_dir_name = \".\"\n  let parent_dir_name = \"..\"\n  let dir_sep = \"/\"\n  let is_dir_sep = Win32.is_dir_sep\n  let is_relative = Win32.is_relative\n  let is_implicit = Win32.is_implicit\n  let check_suffix = Win32.check_suffix\n  let chop_suffix_opt = Win32.chop_suffix_opt\n  let temp_dir_name = Unix.temp_dir_name\n  let quote = Unix.quote\n  let quote_command = Unix.quote_command\n  let basename = generic_basename is_dir_sep current_dir_name\n  let dirname = generic_dirname is_dir_sep current_dir_name\nend\n\nmodule Sysdeps =\n  (val (match Sys.os_type with\n       | \"Win32\" -> (module Win32: SYSDEPS)\n       | \"Cygwin\" -> (module Cygwin: SYSDEPS)\n       | _ -> (module Unix: SYSDEPS)))\n\ninclude Sysdeps\n\nlet concat dirname filename =\n  let l = String.length dirname in\n  if l = 0 || is_dir_sep dirname (l-1)\n  then dirname ^ filename\n  else dirname ^ dir_sep ^ filename\n\nlet chop_suffix name suff =\n  let n = String.length name - String.length suff in\n  if n < 0 then invalid_arg \"Filename.chop_suffix\" else String.sub name 0 n\n\nlet extension_len name =\n  let rec check i0 i =\n    if i < 0 || is_dir_sep name i then 0\n    else if name.[i] = '.' then check i0 (i - 1)\n    else String.length name - i0\n  in\n  let rec search_dot i =\n    if i < 0 || is_dir_sep name i then 0\n    else if name.[i] = '.' then check i (i - 1)\n    else search_dot (i - 1)\n  in\n  search_dot (String.length name - 1)\n\nlet extension name =\n  let l = extension_len name in\n  if l = 0 then \"\" else String.sub name (String.length name - l) l\n\nlet chop_extension name =\n  let l = extension_len name in\n  if l = 0 then invalid_arg \"Filename.chop_extension\"\n  else String.sub name 0 (String.length name - l)\n\nlet remove_extension name =\n  let l = extension_len name in\n  if l = 0 then name else String.sub name 0 (String.length name - l)\n\nexternal open_desc: string -> open_flag list -> int -> int = \"caml_sys_open\"\nexternal close_desc: int -> unit = \"caml_sys_close\"\n\nlet prng = lazy(Random.State.make_self_init ())\n\nlet temp_file_name temp_dir prefix suffix =\n  let rnd = (Random.State.bits (Lazy.force prng)) land 0xFFFFFF in\n  concat temp_dir (Printf.sprintf \"%s%06x%s\" prefix rnd suffix)\n\n\nlet current_temp_dir_name = ref temp_dir_name\n\nlet set_temp_dir_name s = current_temp_dir_name := s\nlet get_temp_dir_name () = !current_temp_dir_name\n\nlet temp_file ?(temp_dir = !current_temp_dir_name) prefix suffix =\n  let rec try_name counter =\n    let name = temp_file_name temp_dir prefix suffix in\n    try\n      close_desc(open_desc name [Open_wronly; Open_creat; Open_excl] 0o600);\n      name\n    with Sys_error _ as e ->\n      if counter >= 1000 then raise e else try_name (counter + 1)\n  in try_name 0\n\nlet open_temp_file ?(mode = [Open_text]) ?(perms = 0o600)\n                   ?(temp_dir = !current_temp_dir_name) prefix suffix =\n  let rec try_name counter =\n    let name = temp_file_name temp_dir prefix suffix in\n    try\n      (name,\n       open_out_gen (Open_wronly::Open_creat::Open_excl::mode) perms name)\n    with Sys_error _ as e ->\n      if counter >= 1000 then raise e else try_name (counter + 1)\n  in try_name 0\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 2002 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Complex numbers *)\n\ntype t = { re: float; im: float }\n\nlet zero = { re = 0.0; im = 0.0 }\nlet one = { re = 1.0; im = 0.0 }\nlet i = { re = 0.0; im = 1.0 }\n\nlet add x y = { re = x.re +. y.re; im = x.im +. y.im }\n\nlet sub x y = { re = x.re -. y.re; im = x.im -. y.im }\n\nlet neg x = { re = -. x.re; im = -. x.im }\n\nlet conj x = { re = x.re; im = -. x.im }\n\nlet mul x y = { re = x.re *. y.re -. x.im *. y.im;\n                im = x.re *. y.im +. x.im *. y.re }\n\nlet div x y =\n  if abs_float y.re >= abs_float y.im then\n    let r = y.im /. y.re in\n    let d = y.re +. r *. y.im in\n    { re = (x.re +. r *. x.im) /. d;\n      im = (x.im -. r *. x.re) /. d }\n  else\n    let r = y.re /. y.im in\n    let d = y.im +. r *. y.re in\n    { re = (r *. x.re +. x.im) /. d;\n      im = (r *. x.im -. x.re) /. d }\n\nlet inv x = div one x\n\nlet norm2 x = x.re *. x.re +. x.im *. x.im\n\nlet norm x =\n  (* Watch out for overflow in computing re^2 + im^2 *)\n  let r = abs_float x.re and i = abs_float x.im in\n  if r = 0.0 then i\n  else if i = 0.0 then r\n  else if r >= i then\n    let q = i /. r in r *. sqrt(1.0 +. q *. q)\n  else\n    let q = r /. i in i *. sqrt(1.0 +. q *. q)\n\nlet arg x = atan2 x.im x.re\n\nlet polar n a = { re = cos a *. n; im = sin a *. n }\n\nlet sqrt x =\n  if x.re = 0.0 && x.im = 0.0 then { re = 0.0; im = 0.0 }\n  else begin\n    let r = abs_float x.re and i = abs_float x.im in\n    let w =\n      if r >= i then begin\n        let q = i /. r in\n        sqrt(r) *. sqrt(0.5 *. (1.0 +. sqrt(1.0 +. q *. q)))\n      end else begin\n        let q = r /. i in\n        sqrt(i) *. sqrt(0.5 *. (q +. sqrt(1.0 +. q *. q)))\n      end in\n    if x.re >= 0.0\n    then { re = w;  im = 0.5 *. x.im /. w }\n    else { re = 0.5 *. i /. w;  im = if x.im >= 0.0 then w else -. w }\n  end\n\nlet exp x =\n  let e = exp x.re in { re = e *. cos x.im; im = e *. sin x.im }\n\nlet log x = { re = log (norm x); im = atan2 x.im x.re }\n\nlet pow x y = exp (mul y (log x))\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*           Manuel Serrano et Xavier Leroy, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 2000 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Module [Bigarray]: large, multi-dimensional, numerical arrays *)\n\n(* These types in must be kept in sync with the tables in\n   ../typing/typeopt.ml *)\n\ntype float32_elt = Float32_elt\ntype float64_elt = Float64_elt\ntype int8_signed_elt = Int8_signed_elt\ntype int8_unsigned_elt = Int8_unsigned_elt\ntype int16_signed_elt = Int16_signed_elt\ntype int16_unsigned_elt = Int16_unsigned_elt\ntype int32_elt = Int32_elt\ntype int64_elt = Int64_elt\ntype int_elt = Int_elt\ntype nativeint_elt = Nativeint_elt\ntype complex32_elt = Complex32_elt\ntype complex64_elt = Complex64_elt\n\ntype ('a, 'b) kind =\n    Float32 : (float, float32_elt) kind\n  | Float64 : (float, float64_elt) kind\n  | Int8_signed : (int, int8_signed_elt) kind\n  | Int8_unsigned : (int, int8_unsigned_elt) kind\n  | Int16_signed : (int, int16_signed_elt) kind\n  | Int16_unsigned : (int, int16_unsigned_elt) kind\n  | Int32 : (int32, int32_elt) kind\n  | Int64 : (int64, int64_elt) kind\n  | Int : (int, int_elt) kind\n  | Nativeint : (nativeint, nativeint_elt) kind\n  | Complex32 : (Complex.t, complex32_elt) kind\n  | Complex64 : (Complex.t, complex64_elt) kind\n  | Char : (char, int8_unsigned_elt) kind\n\ntype c_layout = C_layout_typ\ntype fortran_layout = Fortran_layout_typ (**)\n\ntype 'a layout =\n    C_layout: c_layout layout\n  | Fortran_layout: fortran_layout layout\n\n(* Keep those constants in sync with the caml_ba_kind enumeration\n   in bigarray.h *)\n\nlet float32 = Float32\nlet float64 = Float64\nlet int8_signed = Int8_signed\nlet int8_unsigned = Int8_unsigned\nlet int16_signed = Int16_signed\nlet int16_unsigned = Int16_unsigned\nlet int32 = Int32\nlet int64 = Int64\nlet int = Int\nlet nativeint = Nativeint\nlet complex32 = Complex32\nlet complex64 = Complex64\nlet char = Char\n\nlet kind_size_in_bytes : type a b. (a, b) kind -> int = function\n  | Float32 -> 4\n  | Float64 -> 8\n  | Int8_signed -> 1\n  | Int8_unsigned -> 1\n  | Int16_signed -> 2\n  | Int16_unsigned -> 2\n  | Int32 -> 4\n  | Int64 -> 8\n  | Int -> Sys.word_size / 8\n  | Nativeint -> Sys.word_size / 8\n  | Complex32 -> 8\n  | Complex64 -> 16\n  | Char -> 1\n\n(* Keep those constants in sync with the caml_ba_layout enumeration\n   in bigarray.h *)\n\nlet c_layout = C_layout\nlet fortran_layout = Fortran_layout\n\nmodule Genarray = struct\n  type (!'a, !'b, !'c) t\n  external create: ('a, 'b) kind -> 'c layout -> int array -> ('a, 'b, 'c) t\n     = \"caml_ba_create\"\n  external get: ('a, 'b, 'c) t -> int array -> 'a\n     = \"caml_ba_get_generic\"\n  external set: ('a, 'b, 'c) t -> int array -> 'a -> unit\n     = \"caml_ba_set_generic\"\n\n  let rec cloop arr idx f col max =\n    if col = Array.length idx then set arr idx (f idx)\n    else for j = 0 to pred max.(col) do\n           idx.(col) <- j;\n           cloop arr idx f (succ col) max\n         done\n  let rec floop arr idx f col max =\n    if col < 0 then set arr idx (f idx)\n    else for j = 1 to max.(col) do\n           idx.(col) <- j;\n           floop arr idx f (pred col) max\n         done\n  let init (type t) kind (layout : t layout) dims f =\n    let arr = create kind layout dims in\n    match Array.length dims, layout with\n    | 0, _ -> arr\n    | dlen, C_layout -> cloop arr (Array.make dlen 0) f 0 dims; arr\n    | dlen, Fortran_layout -> floop arr (Array.make dlen 1) f (pred dlen) dims;\n                              arr\n\n  external num_dims: ('a, 'b, 'c) t -> int = \"caml_ba_num_dims\"\n  external nth_dim: ('a, 'b, 'c) t -> int -> int = \"caml_ba_dim\"\n  let dims a =\n    let n = num_dims a in\n    let d = Array.make n 0 in\n    for i = 0 to n-1 do d.(i) <- nth_dim a i done;\n    d\n\n  external kind: ('a, 'b, 'c) t -> ('a, 'b) kind = \"caml_ba_kind\"\n  external layout: ('a, 'b, 'c) t -> 'c layout = \"caml_ba_layout\"\n  external change_layout: ('a, 'b, 'c) t -> 'd layout -> ('a, 'b, 'd) t\n     = \"caml_ba_change_layout\"\n\n  let size_in_bytes arr =\n    (kind_size_in_bytes (kind arr)) * (Array.fold_left ( * ) 1 (dims arr))\n\n  external sub_left: ('a, 'b, c_layout) t -> int -> int -> ('a, 'b, c_layout) t\n     = \"caml_ba_sub\"\n  external sub_right: ('a, 'b, fortran_layout) t -> int -> int ->\n                          ('a, 'b, fortran_layout) t\n     = \"caml_ba_sub\"\n  external slice_left: ('a, 'b, c_layout) t -> int array ->\n                          ('a, 'b, c_layout) t\n     = \"caml_ba_slice\"\n  external slice_right: ('a, 'b, fortran_layout) t -> int array ->\n                          ('a, 'b, fortran_layout) t\n     = \"caml_ba_slice\"\n  external blit: ('a, 'b, 'c) t -> ('a, 'b, 'c) t -> unit\n     = \"caml_ba_blit\"\n  external fill: ('a, 'b, 'c) t -> 'a -> unit = \"caml_ba_fill\"\nend\n\nmodule Array0 = struct\n  type (!'a, !'b, !'c) t = ('a, 'b, 'c) Genarray.t\n  let create kind layout =\n    Genarray.create kind layout [||]\n  let get arr = Genarray.get arr [||]\n  let set arr = Genarray.set arr [||]\n  external kind: ('a, 'b, 'c) t -> ('a, 'b) kind = \"caml_ba_kind\"\n  external layout: ('a, 'b, 'c) t -> 'c layout = \"caml_ba_layout\"\n\n  external change_layout: ('a, 'b, 'c) t -> 'd layout -> ('a, 'b, 'd) t\n    = \"caml_ba_change_layout\"\n\n  let size_in_bytes arr = kind_size_in_bytes (kind arr)\n\n  external blit: ('a, 'b, 'c) t -> ('a, 'b, 'c) t -> unit = \"caml_ba_blit\"\n  external fill: ('a, 'b, 'c) t -> 'a -> unit = \"caml_ba_fill\"\n\n  let of_value kind layout v =\n    let a = create kind layout in\n    set a v;\n    a\n  let init = of_value\nend\n\nmodule Array1 = struct\n  type (!'a, !'b, !'c) t = ('a, 'b, 'c) Genarray.t\n  let create kind layout dim =\n    Genarray.create kind layout [|dim|]\n  external get: ('a, 'b, 'c) t -> int -> 'a = \"%caml_ba_ref_1\"\n  external set: ('a, 'b, 'c) t -> int -> 'a -> unit = \"%caml_ba_set_1\"\n  external unsafe_get: ('a, 'b, 'c) t -> int -> 'a = \"%caml_ba_unsafe_ref_1\"\n  external unsafe_set: ('a, 'b, 'c) t -> int -> 'a -> unit\n     = \"%caml_ba_unsafe_set_1\"\n  external dim: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_1\"\n  external kind: ('a, 'b, 'c) t -> ('a, 'b) kind = \"caml_ba_kind\"\n  external layout: ('a, 'b, 'c) t -> 'c layout = \"caml_ba_layout\"\n\n  external change_layout: ('a, 'b, 'c) t -> 'd layout -> ('a, 'b, 'd) t\n    = \"caml_ba_change_layout\"\n\n  let size_in_bytes arr =\n    (kind_size_in_bytes (kind arr)) * (dim arr)\n\n  external sub: ('a, 'b, 'c) t -> int -> int -> ('a, 'b, 'c) t = \"caml_ba_sub\"\n  let slice (type t) (a : (_, _, t) Genarray.t) n =\n    match layout a with\n    | C_layout -> (Genarray.slice_left a [|n|] : (_, _, t) Genarray.t)\n    | Fortran_layout -> (Genarray.slice_right a [|n|]: (_, _, t) Genarray.t)\n  external blit: ('a, 'b, 'c) t -> ('a, 'b, 'c) t -> unit = \"caml_ba_blit\"\n  external fill: ('a, 'b, 'c) t -> 'a -> unit = \"caml_ba_fill\"\n  let c_init arr dim f =\n    for i = 0 to pred dim do unsafe_set arr i (f i) done\n  let fortran_init arr dim f =\n    for i = 1 to dim do unsafe_set arr i (f i) done\n  let init (type t) kind (layout : t layout) dim f =\n    let arr = create kind layout dim in\n    match layout with\n    | C_layout -> c_init arr dim f; arr\n    | Fortran_layout -> fortran_init arr dim f; arr\n  let of_array (type t) kind (layout: t layout) data =\n    let ba = create kind layout (Array.length data) in\n    let ofs =\n      match layout with\n        C_layout -> 0\n      | Fortran_layout -> 1\n    in\n    for i = 0 to Array.length data - 1 do unsafe_set ba (i + ofs) data.(i) done;\n    ba\nend\n\nmodule Array2 = struct\n  type (!'a, !'b, !'c) t = ('a, 'b, 'c) Genarray.t\n  let create kind layout dim1 dim2 =\n    Genarray.create kind layout [|dim1; dim2|]\n  external get: ('a, 'b, 'c) t -> int -> int -> 'a = \"%caml_ba_ref_2\"\n  external set: ('a, 'b, 'c) t -> int -> int -> 'a -> unit = \"%caml_ba_set_2\"\n  external unsafe_get: ('a, 'b, 'c) t -> int -> int -> 'a\n     = \"%caml_ba_unsafe_ref_2\"\n  external unsafe_set: ('a, 'b, 'c) t -> int -> int -> 'a -> unit\n     = \"%caml_ba_unsafe_set_2\"\n  external dim1: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_1\"\n  external dim2: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_2\"\n  external kind: ('a, 'b, 'c) t -> ('a, 'b) kind = \"caml_ba_kind\"\n  external layout: ('a, 'b, 'c) t -> 'c layout = \"caml_ba_layout\"\n\n  external change_layout: ('a, 'b, 'c) t -> 'd layout -> ('a, 'b, 'd) t\n    = \"caml_ba_change_layout\"\n\n  let size_in_bytes arr =\n    (kind_size_in_bytes (kind arr)) * (dim1 arr) * (dim2 arr)\n\n  external sub_left: ('a, 'b, c_layout) t -> int -> int -> ('a, 'b, c_layout) t\n     = \"caml_ba_sub\"\n  external sub_right:\n    ('a, 'b, fortran_layout) t -> int -> int -> ('a, 'b, fortran_layout) t\n     = \"caml_ba_sub\"\n  let slice_left a n = Genarray.slice_left a [|n|]\n  let slice_right a n = Genarray.slice_right a [|n|]\n  external blit: ('a, 'b, 'c) t -> ('a, 'b, 'c) t -> unit = \"caml_ba_blit\"\n  external fill: ('a, 'b, 'c) t -> 'a -> unit = \"caml_ba_fill\"\n  let c_init arr dim1 dim2 f =\n    for i = 0 to pred dim1 do\n      for j = 0 to pred dim2 do\n        unsafe_set arr i j (f i j)\n      done\n    done\n  let fortran_init arr dim1 dim2 f =\n    for j = 1 to dim2 do\n      for i = 1 to dim1 do\n        unsafe_set arr i j (f i j)\n      done\n    done\n  let init (type t) kind (layout : t layout) dim1 dim2 f =\n    let arr = create kind layout dim1 dim2 in\n    match layout with\n    | C_layout -> c_init arr dim1 dim2 f; arr\n    | Fortran_layout -> fortran_init arr dim1 dim2 f; arr\n  let of_array (type t) kind (layout: t layout) data =\n    let dim1 = Array.length data in\n    let dim2 = if dim1 = 0 then 0 else Array.length data.(0) in\n    let ba = create kind layout dim1 dim2 in\n    let ofs =\n      match layout with\n        C_layout -> 0\n      | Fortran_layout -> 1\n    in\n    for i = 0 to dim1 - 1 do\n      let row = data.(i) in\n      if Array.length row <> dim2 then\n        invalid_arg(\"Bigarray.Array2.of_array: non-rectangular data\");\n      for j = 0 to dim2 - 1 do\n        unsafe_set ba (i + ofs) (j + ofs) row.(j)\n      done\n    done;\n    ba\nend\n\nmodule Array3 = struct\n  type (!'a, !'b, !'c) t = ('a, 'b, 'c) Genarray.t\n  let create kind layout dim1 dim2 dim3 =\n    Genarray.create kind layout [|dim1; dim2; dim3|]\n  external get: ('a, 'b, 'c) t -> int -> int -> int -> 'a = \"%caml_ba_ref_3\"\n  external set: ('a, 'b, 'c) t -> int -> int -> int -> 'a -> unit\n     = \"%caml_ba_set_3\"\n  external unsafe_get: ('a, 'b, 'c) t -> int -> int -> int -> 'a\n     = \"%caml_ba_unsafe_ref_3\"\n  external unsafe_set: ('a, 'b, 'c) t -> int -> int -> int -> 'a -> unit\n     = \"%caml_ba_unsafe_set_3\"\n  external dim1: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_1\"\n  external dim2: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_2\"\n  external dim3: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_3\"\n  external kind: ('a, 'b, 'c) t -> ('a, 'b) kind = \"caml_ba_kind\"\n  external layout: ('a, 'b, 'c) t -> 'c layout = \"caml_ba_layout\"\n\n  external change_layout: ('a, 'b, 'c) t -> 'd layout -> ('a, 'b, 'd) t\n    = \"caml_ba_change_layout\"\n\n  let size_in_bytes arr =\n    (kind_size_in_bytes (kind arr)) * (dim1 arr) * (dim2 arr) * (dim3 arr)\n\n  external sub_left: ('a, 'b, c_layout) t -> int -> int -> ('a, 'b, c_layout) t\n     = \"caml_ba_sub\"\n  external sub_right:\n     ('a, 'b, fortran_layout) t -> int -> int -> ('a, 'b, fortran_layout) t\n     = \"caml_ba_sub\"\n  let slice_left_1 a n m = Genarray.slice_left a [|n; m|]\n  let slice_right_1 a n m = Genarray.slice_right a [|n; m|]\n  let slice_left_2 a n = Genarray.slice_left a [|n|]\n  let slice_right_2 a n = Genarray.slice_right a [|n|]\n  external blit: ('a, 'b, 'c) t -> ('a, 'b, 'c) t -> unit = \"caml_ba_blit\"\n  external fill: ('a, 'b, 'c) t -> 'a -> unit = \"caml_ba_fill\"\n  let c_init arr dim1 dim2 dim3 f =\n    for i = 0 to pred dim1 do\n      for j = 0 to pred dim2 do\n        for k = 0 to pred dim3 do\n          unsafe_set arr i j k (f i j k)\n        done\n      done\n    done\n  let fortran_init arr dim1 dim2 dim3 f =\n    for k = 1 to dim3 do\n      for j = 1 to dim2 do\n        for i = 1 to dim1 do\n          unsafe_set arr i j k (f i j k)\n        done\n      done\n    done\n  let init (type t) kind (layout : t layout) dim1 dim2 dim3 f =\n    let arr = create kind layout dim1 dim2 dim3 in\n    match layout with\n    | C_layout -> c_init arr dim1 dim2 dim3 f; arr\n    | Fortran_layout -> fortran_init arr dim1 dim2 dim3 f; arr\n  let of_array (type t) kind (layout: t layout) data =\n    let dim1 = Array.length data in\n    let dim2 = if dim1 = 0 then 0 else Array.length data.(0) in\n    let dim3 = if dim2 = 0 then 0 else Array.length data.(0).(0) in\n    let ba = create kind layout dim1 dim2 dim3 in\n    let ofs =\n      match layout with\n        C_layout -> 0\n      | Fortran_layout -> 1\n    in\n    for i = 0 to dim1 - 1 do\n      let row = data.(i) in\n      if Array.length row <> dim2 then\n        invalid_arg(\"Bigarray.Array3.of_array: non-cubic data\");\n      for j = 0 to dim2 - 1 do\n        let col = row.(j) in\n        if Array.length col <> dim3 then\n          invalid_arg(\"Bigarray.Array3.of_array: non-cubic data\");\n        for k = 0 to dim3 - 1 do\n          unsafe_set ba (i + ofs) (j + ofs) (k + ofs) col.(k)\n        done\n      done\n    done;\n    ba\nend\n\nexternal genarray_of_array0: ('a, 'b, 'c) Array0.t -> ('a, 'b, 'c) Genarray.t\n   = \"%identity\"\nexternal genarray_of_array1: ('a, 'b, 'c) Array1.t -> ('a, 'b, 'c) Genarray.t\n   = \"%identity\"\nexternal genarray_of_array2: ('a, 'b, 'c) Array2.t -> ('a, 'b, 'c) Genarray.t\n   = \"%identity\"\nexternal genarray_of_array3: ('a, 'b, 'c) Array3.t -> ('a, 'b, 'c) Genarray.t\n   = \"%identity\"\nlet array0_of_genarray a =\n  if Genarray.num_dims a = 0 then a\n  else invalid_arg \"Bigarray.array0_of_genarray\"\nlet array1_of_genarray a =\n  if Genarray.num_dims a = 1 then a\n  else invalid_arg \"Bigarray.array1_of_genarray\"\nlet array2_of_genarray a =\n  if Genarray.num_dims a = 2 then a\n  else invalid_arg \"Bigarray.array2_of_genarray\"\nlet array3_of_genarray a =\n  if Genarray.num_dims a = 3 then a\n  else invalid_arg \"Bigarray.array3_of_genarray\"\n\nexternal reshape:\n   ('a, 'b, 'c) Genarray.t -> int array -> ('a, 'b, 'c) Genarray.t\n   = \"caml_ba_reshape\"\nlet reshape_0 a = reshape a [||]\nlet reshape_1 a dim1 = reshape a [|dim1|]\nlet reshape_2 a dim1 dim2 = reshape a [|dim1;dim2|]\nlet reshape_3 a dim1 dim2 dim3 = reshape a [|dim1;dim2;dim3|]\n\n(* Force caml_ba_get_{1,2,3,N} to be linked in, since we don't refer\n   to those primitives directly in this file *)\n\nlet _ =\n  let _ = Genarray.get in\n  let _ = Array1.get in\n  let _ = Array2.get in\n  let _ = Array3.get in\n  ()\n\n[@@@ocaml.warning \"-32\"]\nexternal get1: unit -> unit = \"caml_ba_get_1\"\nexternal get2: unit -> unit = \"caml_ba_get_2\"\nexternal get3: unit -> unit = \"caml_ba_get_3\"\nexternal set1: unit -> unit = \"caml_ba_set_1\"\nexternal set2: unit -> unit = \"caml_ba_set_2\"\nexternal set3: unit -> unit = \"caml_ba_set_3\"\n","(* generated by dune *)\n\n(** @canonical Jsoo_runtime.Runtime_version *)\nmodule Runtime_version = Jsoo_runtime__Runtime_version\n\nmodule Jsoo_runtime__ = struct end\n[@@deprecated \"this module is shadowed\"]\n","module Js = struct\n  type t\n\n  type 'a js_array = t\n\n  type ('a, 'b) meth_callback = t\n\n  external string : string -> t = \"caml_jsstring_of_string\"\n\n  external to_string : t -> string = \"caml_string_of_jsstring\"\n\n  external bytestring : string -> t = \"caml_jsbytes_of_string\"\n\n  external to_bytestring : t -> string = \"caml_string_of_jsbytes\"\n\n  external bool : bool -> t = \"caml_js_from_bool\"\n\n  external to_bool : t -> bool = \"caml_js_to_bool\"\n\n  external array : 'a array -> t = \"caml_js_from_array\"\n\n  external to_array : t -> 'a array = \"caml_js_to_array\"\n\n  external number_of_float : float -> t = \"caml_js_from_float\"\n\n  external float_of_number : t -> float = \"caml_js_to_float\"\n\n  external number_of_int32 : int32 -> t = \"caml_js_from_int32\"\n\n  external int32_of_number : t -> int32 = \"caml_js_to_int32\"\n\n  external number_of_nativeint : nativeint -> t = \"caml_js_from_nativeint\"\n\n  external nativeint_of_number : t -> nativeint = \"caml_js_to_nativeint\"\n\n  external typeof : t -> t = \"caml_js_typeof\"\n\n  external instanceof : t -> t -> bool = \"caml_js_instanceof\"\n\n  external debugger : unit -> unit = \"debugger\"\n\n  external get : t -> t -> t = \"caml_js_get\"\n\n  external set : t -> t -> t -> unit = \"caml_js_set\"\n\n  external delete : t -> t -> unit = \"caml_js_delete\"\n\n  external call : t -> t -> t array -> t = \"caml_js_call\"\n\n  external fun_call : t -> t array -> t = \"caml_js_fun_call\"\n\n  external meth_call : t -> string -> t array -> t = \"caml_js_meth_call\"\n\n  external new_obj : t -> t array -> t = \"caml_js_new\"\n\n  external new_obj_arr : t -> t js_array -> t = \"caml_ojs_new_arr\"\n\n  external obj : (string * t) array -> t = \"caml_js_object\"\n\n  external equals : t -> t -> bool = \"caml_js_equals\"\n\n  external strict_equals : t -> t -> bool = \"caml_js_strict_equals\"\n\n  external pure_expr : (unit -> 'a) -> 'a = \"caml_js_pure_expr\"\n\n  external eval_string : string -> 'a = \"caml_js_eval_string\"\n\n  external js_expr : string -> 'a = \"caml_js_expr\"\n\n  external pure_js_expr : string -> 'a = \"caml_pure_js_expr\"\n\n  external callback : ('b -> 'a) -> ('b, 'a) meth_callback\n    = \"caml_js_wrap_callback_unsafe\"\n\n  external callback_with_arguments :\n    (t js_array -> 'b) -> ('c, t js_array -> 'b) meth_callback\n    = \"caml_js_wrap_callback_arguments\"\n\n  external callback_with_arity : int -> ('a -> 'b) -> ('c, 'a -> 'b) meth_callback\n    = \"caml_js_wrap_callback_strict\"\n\n  external meth_callback : ('b -> 'a) -> ('b, 'a) meth_callback\n    = \"caml_js_wrap_meth_callback_unsafe\"\n\n  external meth_callback_with_arity : int -> ('b -> 'a) -> ('b, 'a) meth_callback\n    = \"caml_js_wrap_meth_callback_strict\"\n\n  external meth_callback_with_arguments :\n    ('b -> t js_array -> 'a) -> ('b, t js_array -> 'a) meth_callback\n    = \"caml_js_wrap_meth_callback_arguments\"\n\n  external wrap_callback : ('a -> 'b) -> ('c, 'a -> 'b) meth_callback\n    = \"caml_js_wrap_callback\"\n\n  external wrap_meth_callback : ('a -> 'b) -> ('a, 'b) meth_callback\n    = \"caml_js_wrap_meth_callback\"\nend\n\nmodule Sys = struct\n  type 'a callback = 'a\n\n  external create_file : name:string -> content:string -> unit = \"caml_create_file\"\n\n  external read_file : name:string -> string = \"caml_read_file_content\"\n\n  external set_channel_output' : out_channel -> (js_string:Js.t -> unit) callback -> unit\n    = \"caml_ml_set_channel_output\"\n\n  external set_channel_input' : in_channel -> (unit -> string) callback -> unit\n    = \"caml_ml_set_channel_refill\"\n\n  external mount_point : unit -> string list = \"caml_list_mount_point\"\n\n  external mount_autoload : string -> (string -> string -> string option) callback -> unit\n    = \"caml_mount_autoload\"\n\n  external unmount : string -> unit = \"caml_unmount\"\n\n  type redirection\n\n  external redirect_channel : out_channel -> into:out_channel -> redirection\n    = \"caml_ml_channel_redirect\"\n\n  external restore_channel : out_channel -> redirection -> unit\n    = \"caml_ml_channel_restore\"\n\n  module Config = struct\n    external use_js_string : unit -> bool = \"caml_jsoo_flags_use_js_string\"\n\n    external effects : unit -> bool = \"caml_jsoo_flags_effects\"\n  end\n\n  let version = Runtime_version.s\n\n  let git_version = Runtime_version.git_version\nend\n\nmodule Error : sig\n  type t\n\n  val raise_ : t -> 'a\n\n  val attach_js_backtrace : exn -> force:bool -> exn\n  (** Attach a JavasScript error to an OCaml exception.  if [force = false] and a\n    JavasScript error is already attached, it will do nothing. This function is useful to\n    store and retrieve information about JavaScript stack traces.\n\n    Attaching JavasScript errors will happen automatically when compiling with\n    [--enable with-js-error]. *)\n\n  val of_exn : exn -> t option\n  (** Extract a JavaScript error attached to an OCaml exception, if any.  This is useful to\n      inspect an eventual stack strace, especially when sourcemap is enabled. *)\n\n  exception Exn of t\n  (** The [Error] exception wrap javascript exceptions when caught by OCaml code.\n      In case the javascript exception is not an instance of javascript [Error],\n      it will be serialized and wrapped into a [Failure] exception.\n  *)\nend = struct\n  type t\n\n  exception Exn of t\n\n  let _ = Callback.register_exception \"jsError\" (Exn (Obj.magic [||]))\n\n  let raise_ : t -> 'a = Js.js_expr \"(function (exn) { throw exn })\"\n\n  external of_exn : exn -> t option = \"caml_js_error_option_of_exception\"\n\n  external attach_js_backtrace : exn -> force:bool -> exn = \"caml_exn_with_js_backtrace\"\nend\n\n[@@@ocaml.warning \"-32-60\"]\n\nmodule For_compatibility_only = struct\n  (* Add primitives for compatibility reasons. Existing users might\n     depend on it (e.g. gen_js_api), we dont want the ocaml compiler\n     to complain about theses missing primitives. *)\n\n  external caml_js_from_string : string -> Js.t = \"caml_js_from_string\"\n\n  external caml_js_to_byte_string : Js.t -> string = \"caml_js_to_byte_string\"\n\n  external caml_js_to_string : Js.t -> string = \"caml_js_to_string\"\n\n  external caml_list_of_js_array : 'a Js.js_array -> 'a list = \"caml_list_of_js_array\"\n\n  external caml_list_to_js_array : 'a list -> 'a Js.js_array = \"caml_list_to_js_array\"\n\n  external variable : string -> 'a = \"caml_js_var\"\nend\n\nmodule Typed_array = struct\n  type ('a, 'b) typedArray = Js.t\n\n  type arrayBuffer = Js.t\n\n  type uint8Array = Js.t\n\n  external kind : ('a, 'b) typedArray -> ('a, 'b) Bigarray.kind\n    = \"caml_ba_kind_of_typed_array\"\n\n  external from_genarray :\n    ('a, 'b, Bigarray.c_layout) Bigarray.Genarray.t -> ('a, 'b) typedArray\n    = \"caml_ba_to_typed_array\"\n\n  external to_genarray :\n    ('a, 'b) typedArray -> ('a, 'b, Bigarray.c_layout) Bigarray.Genarray.t\n    = \"caml_ba_from_typed_array\"\n\n  module Bigstring = struct\n    type t = (char, Bigarray.int8_unsigned_elt, Bigarray.c_layout) Bigarray.Array1.t\n\n    external to_arrayBuffer : t -> arrayBuffer = \"bigstring_to_array_buffer\"\n\n    external to_uint8Array : t -> uint8Array = \"bigstring_to_typed_array\"\n\n    external of_arrayBuffer : arrayBuffer -> t = \"bigstring_of_array_buffer\"\n\n    external of_uint8Array : uint8Array -> t = \"bigstring_of_typed_array\"\n  end\n\n  external of_uint8Array : uint8Array -> string = \"caml_string_of_array\"\nend\n\nmodule Int64 = struct\n  external create_int64_lo_mi_hi : int -> int -> int -> Int64.t\n    = \"caml_int64_create_lo_mi_hi\"\nend\n","(* generated by dune *)\n\n(** @canonical Js_of_ocaml.CSS *)\nmodule CSS = Js_of_ocaml__CSS\n\n(** @canonical Js_of_ocaml.Dom *)\nmodule Dom = Js_of_ocaml__Dom\n\n(** @canonical Js_of_ocaml.Dom_events *)\nmodule Dom_events = Js_of_ocaml__Dom_events\n\n(** @canonical Js_of_ocaml.Dom_html *)\nmodule Dom_html = Js_of_ocaml__Dom_html\n\n(** @canonical Js_of_ocaml.Dom_svg *)\nmodule Dom_svg = Js_of_ocaml__Dom_svg\n\n(** @canonical Js_of_ocaml.EventSource *)\nmodule EventSource = Js_of_ocaml__EventSource\n\n(** @canonical Js_of_ocaml.File *)\nmodule File = Js_of_ocaml__File\n\n(** @canonical Js_of_ocaml.Firebug *)\nmodule Firebug = Js_of_ocaml__Firebug\n\n(** @canonical Js_of_ocaml.Form *)\nmodule Form = Js_of_ocaml__Form\n\n(** @canonical Js_of_ocaml.Geolocation *)\nmodule Geolocation = Js_of_ocaml__Geolocation\n\n(** @canonical Js_of_ocaml.Import *)\nmodule Import = Js_of_ocaml__Import\n\n(** @canonical Js_of_ocaml.IntersectionObserver *)\nmodule IntersectionObserver = Js_of_ocaml__IntersectionObserver\n\n(** @canonical Js_of_ocaml.Intl *)\nmodule Intl = Js_of_ocaml__Intl\n\n(** @canonical Js_of_ocaml.Js *)\nmodule Js = Js_of_ocaml__Js\n\n(** @canonical Js_of_ocaml.Json *)\nmodule Json = Js_of_ocaml__Json\n\n(** @canonical Js_of_ocaml.Jstable *)\nmodule Jstable = Js_of_ocaml__Jstable\n\n(** @canonical Js_of_ocaml.Lib_version *)\nmodule Lib_version = Js_of_ocaml__Lib_version\n\n(** @canonical Js_of_ocaml.MutationObserver *)\nmodule MutationObserver = Js_of_ocaml__MutationObserver\n\n(** @canonical Js_of_ocaml.PerformanceObserver *)\nmodule PerformanceObserver = Js_of_ocaml__PerformanceObserver\n\n(** @canonical Js_of_ocaml.Regexp *)\nmodule Regexp = Js_of_ocaml__Regexp\n\n(** @canonical Js_of_ocaml.ResizeObserver *)\nmodule ResizeObserver = Js_of_ocaml__ResizeObserver\n\n(** @canonical Js_of_ocaml.Sys_js *)\nmodule Sys_js = Js_of_ocaml__Sys_js\n\n(** @canonical Js_of_ocaml.Typed_array *)\nmodule Typed_array = Js_of_ocaml__Typed_array\n\n(** @canonical Js_of_ocaml.Url *)\nmodule Url = Js_of_ocaml__Url\n\n(** @canonical Js_of_ocaml.WebGL *)\nmodule WebGL = Js_of_ocaml__WebGL\n\n(** @canonical Js_of_ocaml.WebSockets *)\nmodule WebSockets = Js_of_ocaml__WebSockets\n\n(** @canonical Js_of_ocaml.Worker *)\nmodule Worker = Js_of_ocaml__Worker\n\n(** @canonical Js_of_ocaml.XmlHttpRequest *)\nmodule XmlHttpRequest = Js_of_ocaml__XmlHttpRequest\n\nmodule Js_of_ocaml__ = struct end\n[@@deprecated \"this module is shadowed\"]\n","(* Js_of_ocaml\n * http://www.ocsigen.org/js_of_ocaml/\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\nmodule Poly = struct\n  external ( < ) : 'a -> 'a -> bool = \"%lessthan\"\n\n  external ( <= ) : 'a -> 'a -> bool = \"%lessequal\"\n\n  external ( <> ) : 'a -> 'a -> bool = \"%notequal\"\n\n  external ( = ) : 'a -> 'a -> bool = \"%equal\"\n\n  external ( > ) : 'a -> 'a -> bool = \"%greaterthan\"\n\n  external ( >= ) : 'a -> 'a -> bool = \"%greaterequal\"\n\n  external compare : 'a -> 'a -> int = \"%compare\"\n\n  external equal : 'a -> 'a -> bool = \"%equal\"\nend\n\nmodule Int_replace_polymorphic_compare = struct\n  external ( < ) : int -> int -> bool = \"%lessthan\"\n\n  external ( <= ) : int -> int -> bool = \"%lessequal\"\n\n  external ( <> ) : int -> int -> bool = \"%notequal\"\n\n  external ( = ) : int -> int -> bool = \"%equal\"\n\n  external ( > ) : int -> int -> bool = \"%greaterthan\"\n\n  external ( >= ) : int -> int -> bool = \"%greaterequal\"\n\n  external compare : int -> int -> int = \"%compare\"\n\n  external equal : int -> int -> bool = \"%equal\"\n\n  let max (x : int) y = if x >= y then x else y\n\n  let min (x : int) y = if x <= y then x else y\nend\n\nmodule String = struct\n  include String\n\n  let equal (x : string) (y : string) = Poly.equal x y\nend\n\nmodule Char = struct\n  include Char\n\n  let equal (x : char) (y : char) = Poly.equal x y\nend\n\ninclude Int_replace_polymorphic_compare\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2010 Jérôme Vouillon\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\nopen! Import\n\n(* This local module [Js] is needed so that the ppx_js extension work within that file. *)\nmodule Js = struct\n  type +'a t\n\n  type (-'a, +'b) meth_callback\n\n  module Unsafe = struct\n    type top\n\n    type any = top t\n\n    type any_js_array = any\n\n    external inject : 'a -> any = \"%identity\"\n\n    external coerce : _ t -> _ t = \"%identity\"\n\n    external get : 'a -> 'b -> 'c = \"caml_js_get\"\n\n    external set : 'a -> 'b -> 'c -> unit = \"caml_js_set\"\n\n    external delete : 'a -> 'b -> unit = \"caml_js_delete\"\n\n    external call : 'a -> 'b -> any array -> 'c = \"caml_js_call\"\n\n    external fun_call : 'a -> any array -> 'b = \"caml_js_fun_call\"\n\n    external meth_call : 'a -> string -> any array -> 'b = \"caml_js_meth_call\"\n\n    external new_obj : 'a -> any array -> 'b = \"caml_js_new\"\n\n    external new_obj_arr : 'a -> any_js_array -> 'b = \"caml_ojs_new_arr\"\n\n    external obj : (string * any) array -> 'a = \"caml_js_object\"\n\n    external equals : 'a -> 'b -> bool = \"caml_js_equals\"\n\n    external strict_equals : 'a -> 'b -> bool = \"caml_js_strict_equals\"\n\n    external pure_expr : (unit -> 'a) -> 'a = \"caml_js_pure_expr\"\n\n    external eval_string : string -> 'a = \"caml_js_eval_string\"\n\n    external js_expr : string -> 'a = \"caml_js_expr\"\n\n    external pure_js_expr : string -> 'a = \"caml_pure_js_expr\"\n\n    let global = pure_js_expr \"globalThis\"\n\n    external callback : ('a -> 'b) -> ('c, 'a -> 'b) meth_callback\n      = \"caml_js_wrap_callback_unsafe\"\n\n    external callback_with_arguments :\n      (any_js_array -> 'b) -> ('c, any_js_array -> 'b) meth_callback\n      = \"caml_js_wrap_callback_arguments\"\n\n    external callback_with_arity : int -> ('a -> 'b) -> ('c, 'a -> 'b) meth_callback\n      = \"caml_js_wrap_callback_strict\"\n\n    external meth_callback : ('b -> 'a) -> ('b, 'a) meth_callback\n      = \"caml_js_wrap_meth_callback_unsafe\"\n\n    external meth_callback_with_arity : int -> ('b -> 'a) -> ('b, 'a) meth_callback\n      = \"caml_js_wrap_meth_callback_strict\"\n\n    external meth_callback_with_arguments :\n      ('b -> any_js_array -> 'a) -> ('b, any_js_array -> 'a) meth_callback\n      = \"caml_js_wrap_meth_callback_arguments\"\n\n    (* DEPRECATED *)\n    external variable : string -> 'a = \"caml_js_var\"\n  end\n\n  (****)\n\n  type 'a opt = 'a\n\n  type 'a optdef = 'a\n\n  external debugger : unit -> unit = \"debugger\"\n\n  let null : 'a opt = Unsafe.pure_js_expr \"null\"\n\n  external some : 'a -> 'a opt = \"%identity\"\n\n  let undefined : 'a optdef = Unsafe.pure_js_expr \"undefined\"\n\n  external def : 'a -> 'a optdef = \"%identity\"\n\n  module type OPT = sig\n    type 'a t\n\n    val empty : 'a t\n\n    val return : 'a -> 'a t\n\n    val map : 'a t -> ('a -> 'b) -> 'b t\n\n    val bind : 'a t -> ('a -> 'b t) -> 'b t\n\n    val test : 'a t -> bool\n\n    val iter : 'a t -> ('a -> unit) -> unit\n\n    val case : 'a t -> (unit -> 'b) -> ('a -> 'b) -> 'b\n\n    val get : 'a t -> (unit -> 'a) -> 'a\n\n    val option : 'a option -> 'a t\n\n    val to_option : 'a t -> 'a option\n\n    external equals : _ t -> _ t -> bool = \"caml_js_equals\"\n\n    external strict_equals : _ t -> _ t -> bool = \"caml_js_strict_equals\"\n  end\n\n  module Opt : OPT with type 'a t = 'a opt = struct\n    type 'a t = 'a opt\n\n    let empty = null\n\n    let return = some\n\n    external equals : _ t -> _ t -> bool = \"caml_js_equals\"\n\n    external strict_equals : _ t -> _ t -> bool = \"caml_js_strict_equals\"\n\n    let map x f = if equals x null then null else return (f x)\n\n    let bind x f = if equals x null then null else f x\n\n    let test x = not (equals x null)\n\n    let iter x f = if not (equals x null) then f x\n\n    let case x f g = if equals x null then f () else g x\n\n    let get x f = if equals x null then f () else x\n\n    let option x =\n      match x with\n      | None -> empty\n      | Some x -> return x\n\n    let to_option x = case x (fun () -> None) (fun x -> Some x)\n  end\n\n  module Optdef : OPT with type 'a t = 'a optdef = struct\n    type 'a t = 'a optdef\n\n    let empty = undefined\n\n    let return = def\n\n    external equals : _ t -> _ t -> bool = \"caml_js_equals\"\n\n    external strict_equals : _ t -> _ t -> bool = \"caml_js_strict_equals\"\n\n    let map x f = if strict_equals x undefined then undefined else return (f x)\n\n    let bind x f = if strict_equals x undefined then undefined else f x\n\n    let test x = not (strict_equals x undefined)\n\n    let iter x f = if not (strict_equals x undefined) then f x\n\n    let case x f g = if strict_equals x undefined then f () else g x\n\n    let get x f = if strict_equals x undefined then f () else x\n\n    let option x =\n      match x with\n      | None -> empty\n      | Some x -> return x\n\n    let to_option x = case x (fun () -> None) (fun x -> Some x)\n  end\n\n  (****)\n\n  let coerce x f g = Opt.get (f x) (fun () -> g x)\n\n  let coerce_opt x f g = Opt.get (Opt.bind x f) (fun () -> g x)\n\n  (****)\n\n  type +'a meth\n\n  type +'a gen_prop\n\n  type 'a readonly_prop = < get : 'a > gen_prop\n\n  type 'a writeonly_prop = < set : 'a -> unit > gen_prop\n\n  type 'a prop = < get : 'a ; set : 'a -> unit > gen_prop\n\n  type 'a optdef_prop = < get : 'a optdef ; set : 'a -> unit > gen_prop\n\n  type +'a constr\n\n  (****)\n\n  type 'a callback = (unit, 'a) meth_callback\n\n  external wrap_callback : ('a -> 'b) -> ('c, 'a -> 'b) meth_callback\n    = \"caml_js_wrap_callback\"\n\n  external wrap_meth_callback : ('a -> 'b) -> ('a, 'b) meth_callback\n    = \"caml_js_wrap_meth_callback\"\n\n  (****)\n\n  external equals : _ t -> _ t -> bool = \"caml_js_equals\"\n\n  external strict_equals : _ t -> _ t -> bool = \"caml_js_strict_equals\"\n\n  (****)\n\n  let _true = Unsafe.pure_js_expr \"true\"\n\n  let _false = Unsafe.pure_js_expr \"false\"\n\n  type match_result_handle\n\n  type string_array\n\n  type number_t = float\n\n  class type number = object\n    method toString : js_string t meth\n\n    method toString_radix : int -> js_string t meth\n\n    method toLocaleString : js_string t meth\n\n    method toFixed : int -> js_string t meth\n\n    method toExponential : js_string t meth\n\n    method toExponential_digits : int -> js_string t meth\n\n    method toPrecision : int -> js_string t meth\n  end\n\n  and js_string = object\n    method toString : js_string t meth\n\n    method valueOf : js_string t meth\n\n    method charAt : int -> js_string t meth\n\n    method charCodeAt : int -> number_t meth\n\n    (* This may return NaN... *)\n    method concat : js_string t -> js_string t meth\n\n    method concat_2 : js_string t -> js_string t -> js_string t meth\n\n    method concat_3 : js_string t -> js_string t -> js_string t -> js_string t meth\n\n    method concat_4 :\n      js_string t -> js_string t -> js_string t -> js_string t -> js_string t meth\n\n    method indexOf : js_string t -> int meth\n\n    method indexOf_from : js_string t -> int -> int meth\n\n    method lastIndexOf : js_string t -> int meth\n\n    method lastIndexOf_from : js_string t -> int -> int meth\n\n    method localeCompare : js_string t -> number_t meth\n\n    method _match : regExp t -> match_result_handle t opt meth\n\n    method normalize : js_string t meth\n\n    method normalize_form : normalization t -> js_string t meth\n\n    method replace : regExp t -> js_string t -> js_string t meth\n\n    method replace_string : js_string t -> js_string t -> js_string t meth\n\n    method search : regExp t -> int meth\n\n    method slice : int -> int -> js_string t meth\n\n    method slice_end : int -> js_string t meth\n\n    method split : js_string t -> string_array t meth\n\n    method split_limited : js_string t -> int -> string_array t meth\n\n    method split_regExp : regExp t -> string_array t meth\n\n    method split_regExpLimited : regExp t -> int -> string_array t meth\n\n    method substring : int -> int -> js_string t meth\n\n    method substring_toEnd : int -> js_string t meth\n\n    method toLowerCase : js_string t meth\n\n    method toLocaleLowerCase : js_string t meth\n\n    method toUpperCase : js_string t meth\n\n    method toLocaleUpperCase : js_string t meth\n\n    method trim : js_string t meth\n\n    method length : int readonly_prop\n  end\n\n  and regExp = object\n    method exec : js_string t -> match_result_handle t opt meth\n\n    method test : js_string t -> bool t meth\n\n    method toString : js_string t meth\n\n    method source : js_string t readonly_prop\n\n    method global : bool t readonly_prop\n\n    method ignoreCase : bool t readonly_prop\n\n    method multiline : bool t readonly_prop\n\n    method lastIndex : int prop\n  end\n\n  and normalization = js_string\n\n  (* string is used by ppx_js, it needs to come before any use of the\n     new syntax in this file *)\n  external string : string -> js_string t = \"caml_jsstring_of_string\"\n\n  external to_string : js_string t -> string = \"caml_string_of_jsstring\"\n\n  let nfc = string \"NFC\"\n\n  let nfd = string \"NFD\"\n\n  let nfkc = string \"NFKC\"\n\n  let nfkd = string \"NFKD\"\nend\n\ninclude Js\n\nclass type string_constr = object\n  method fromCharCode : int -> js_string t meth\nend\n\nlet string_constr = Unsafe.global##._String\n\nlet regExp = Unsafe.global##._RegExp\n\nlet regExp_copy = regExp\n\nlet regExp_withFlags = regExp\n\nclass type ['a] js_array = object\n  method toString : js_string t meth\n\n  method toLocaleString : js_string t meth\n\n  method concat : 'a js_array t -> 'a js_array t meth\n\n  method join : js_string t -> js_string t meth\n\n  method pop : 'a optdef meth\n\n  method push : 'a -> int meth\n\n  method push_2 : 'a -> 'a -> int meth\n\n  method push_3 : 'a -> 'a -> 'a -> int meth\n\n  method push_4 : 'a -> 'a -> 'a -> 'a -> int meth\n\n  method reverse : 'a js_array t meth\n\n  method shift : 'a optdef meth\n\n  method slice : int -> int -> 'a js_array t meth\n\n  method slice_end : int -> 'a js_array t meth\n\n  method sort : ('a -> 'a -> number_t) callback -> 'a js_array t meth\n\n  method sort_asStrings : 'a js_array t meth\n\n  method splice : int -> int -> 'a js_array t meth\n\n  method splice_1 : int -> int -> 'a -> 'a js_array t meth\n\n  method splice_2 : int -> int -> 'a -> 'a -> 'a js_array t meth\n\n  method splice_3 : int -> int -> 'a -> 'a -> 'a -> 'a js_array t meth\n\n  method splice_4 : int -> int -> 'a -> 'a -> 'a -> 'a -> 'a js_array t meth\n\n  method unshift : 'a -> int meth\n\n  method unshift_2 : 'a -> 'a -> int meth\n\n  method unshift_3 : 'a -> 'a -> 'a -> int meth\n\n  method unshift_4 : 'a -> 'a -> 'a -> 'a -> int meth\n\n  method some : ('a -> int -> 'a js_array t -> bool t) callback -> bool t meth\n\n  method every : ('a -> int -> 'a js_array t -> bool t) callback -> bool t meth\n\n  method forEach : ('a -> int -> 'a js_array t -> unit) callback -> unit meth\n\n  method map : ('a -> int -> 'a js_array t -> 'b) callback -> 'b js_array t meth\n\n  method filter : ('a -> int -> 'a js_array t -> bool t) callback -> 'a js_array t meth\n\n  method reduce_init : ('b -> 'a -> int -> 'a js_array t -> 'b) callback -> 'b -> 'b meth\n\n  method reduce : ('a -> 'a -> int -> 'a js_array t -> 'a) callback -> 'a meth\n\n  method reduceRight_init :\n    ('b -> 'a -> int -> 'a js_array t -> 'b) callback -> 'b -> 'b meth\n\n  method reduceRight : ('a -> 'a -> int -> 'a js_array t -> 'a) callback -> 'a meth\n\n  method length : int prop\nend\n\nlet object_constructor = Unsafe.global##._Object\n\nlet object_keys o : js_string t js_array t = object_constructor##keys o\n\nlet array_constructor = Unsafe.global##._Array\n\nlet array_empty = array_constructor\n\nlet array_length = array_constructor\n\nlet array_get : 'a #js_array t -> int -> 'a optdef = Unsafe.get\n\nlet array_set : 'a #js_array t -> int -> 'a -> unit = Unsafe.set\n\nlet array_map_poly :\n    'a #js_array t -> ('a -> int -> 'a #js_array t -> 'b) callback -> 'b #js_array t =\n fun a cb -> (Unsafe.coerce a)##map cb\n\nlet array_map f a = array_map_poly a (wrap_callback (fun x _idx _ -> f x))\n\nlet array_mapi f a = array_map_poly a (wrap_callback (fun x idx _ -> f idx x))\n\nclass type match_result = object\n  inherit [js_string t] js_array\n\n  method index : int readonly_prop\n\n  method input : js_string t readonly_prop\nend\n\nlet str_array : string_array t -> js_string t js_array t = Unsafe.coerce\n\nlet match_result : match_result_handle t -> match_result t = Unsafe.coerce\n\nclass type date = object\n  method toString : js_string t meth\n\n  method toDateString : js_string t meth\n\n  method toTimeString : js_string t meth\n\n  method toLocaleString : js_string t meth\n\n  method toLocaleDateString : js_string t meth\n\n  method toLocaleTimeString : js_string t meth\n\n  method valueOf : number_t meth\n\n  method getTime : number_t meth\n\n  method getFullYear : int meth\n\n  method getUTCFullYear : int meth\n\n  method getMonth : int meth\n\n  method getUTCMonth : int meth\n\n  method getDate : int meth\n\n  method getUTCDate : int meth\n\n  method getDay : int meth\n\n  method getUTCDay : int meth\n\n  method getHours : int meth\n\n  method getUTCHours : int meth\n\n  method getMinutes : int meth\n\n  method getUTCMinutes : int meth\n\n  method getSeconds : int meth\n\n  method getUTCSeconds : int meth\n\n  method getMilliseconds : int meth\n\n  method getUTCMilliseconds : int meth\n\n  method getTimezoneOffset : int meth\n\n  method setTime : number_t -> number_t meth\n\n  method setFullYear : int -> number_t meth\n\n  method setUTCFullYear : int -> number_t meth\n\n  method setMonth : int -> number_t meth\n\n  method setUTCMonth : int -> number_t meth\n\n  method setDate : int -> number_t meth\n\n  method setUTCDate : int -> number_t meth\n\n  method setDay : int -> number_t meth\n\n  method setUTCDay : int -> number_t meth\n\n  method setHours : int -> number_t meth\n\n  method setUTCHours : int -> number_t meth\n\n  method setMinutes : int -> number_t meth\n\n  method setUTCMinutes : int -> number_t meth\n\n  method setSeconds : int -> number_t meth\n\n  method setUTCSeconds : int -> number_t meth\n\n  method setMilliseconds : int -> number_t meth\n\n  method setUTCMilliseconds : int -> number_t meth\n\n  method toUTCString : js_string t meth\n\n  method toISOString : js_string t meth\n\n  method toJSON : 'a -> js_string t meth\nend\n\nclass type date_constr = object\n  method parse : js_string t -> number_t meth\n\n  method _UTC_month : int -> int -> number_t meth\n\n  method _UTC_day : int -> int -> number_t meth\n\n  method _UTC_hour : int -> int -> int -> int -> number_t meth\n\n  method _UTC_min : int -> int -> int -> int -> int -> number_t meth\n\n  method _UTC_sec : int -> int -> int -> int -> int -> int -> number_t meth\n\n  method _UTC_ms : int -> int -> int -> int -> int -> int -> int -> number_t meth\n\n  method now : number_t meth\nend\n\nlet date_constr = Unsafe.global##._Date\n\nlet date : date_constr t = date_constr\n\nlet date_now : date t constr = date_constr\n\nlet date_fromTimeValue : (number_t -> date t) constr = date_constr\n\nlet date_month : (int -> int -> date t) constr = date_constr\n\nlet date_day : (int -> int -> int -> date t) constr = date_constr\n\nlet date_hour : (int -> int -> int -> int -> date t) constr = date_constr\n\nlet date_min : (int -> int -> int -> int -> int -> date t) constr = date_constr\n\nlet date_sec : (int -> int -> int -> int -> int -> int -> date t) constr = date_constr\n\nlet date_ms : (int -> int -> int -> int -> int -> int -> int -> date t) constr =\n  date_constr\n\nclass type math = object\n  method _E : number_t readonly_prop\n\n  method _LN2 : number_t readonly_prop\n\n  method _LN10 : number_t readonly_prop\n\n  method _LOG2E : number_t readonly_prop\n\n  method _LOG10E : number_t readonly_prop\n\n  method _PI : number_t readonly_prop\n\n  method _SQRT1_2_ : number_t readonly_prop\n\n  method _SQRT2 : number_t readonly_prop\n\n  method abs : number_t -> number_t meth\n\n  method acos : number_t -> number_t meth\n\n  method asin : number_t -> number_t meth\n\n  method atan : number_t -> number_t meth\n\n  method atan2 : number_t -> number_t -> number_t meth\n\n  method ceil : number_t -> number_t meth\n\n  method cos : number_t -> number_t meth\n\n  method exp : number_t -> number_t meth\n\n  method floor : number_t -> number_t meth\n\n  method log : number_t -> number_t meth\n\n  method max : number_t -> number_t -> number_t meth\n\n  method max_3 : number_t -> number_t -> number_t -> number_t meth\n\n  method max_4 : number_t -> number_t -> number_t -> number_t -> number_t meth\n\n  method min : number_t -> number_t -> number_t meth\n\n  method min_3 : number_t -> number_t -> number_t -> number_t meth\n\n  method min_4 : number_t -> number_t -> number_t -> number_t -> number_t meth\n\n  method pow : number_t -> number_t -> number_t meth\n\n  method random : number_t meth\n\n  method round : number_t -> number_t meth\n\n  method sin : number_t -> number_t meth\n\n  method sqrt : number_t -> number_t meth\n\n  method tan : number_t -> number_t meth\nend\n\nlet math = Unsafe.global##._Math\n\nclass type error = object\n  method name : js_string t prop\n\n  method message : js_string t prop\n\n  method stack : js_string t optdef prop\n\n  method toString : js_string t meth\nend\n\nlet error_constr = Unsafe.global##._Error\n\nmodule Js_error = struct\n  type error_t = error t\n\n  include Jsoo_runtime.Error\n\n  external of_error : error_t -> t = \"%identity\"\n\n  external to_error : t -> error_t = \"%identity\"\n\n  let name e = to_string (to_error e)##.name\n\n  let message e = to_string (to_error e)##.message\n\n  let stack (e : t) : string option =\n    Opt.to_option (Opt.map (to_error e)##.stack to_string)\n\n  let to_string e = to_string (to_error e)##toString\nend\n\nmodule Magic = struct\n  module type T = sig\n    exception Error of error t\n  end\n\n  type ('a, 'b) eq = Eq : ('a, 'a) eq\n\n  let (eq : (error t, Js_error.t) eq) = Obj.magic Eq\n\n  let m =\n    match eq with\n    | Eq ->\n        (module struct\n          exception Error = Js_error.Exn\n        end : T)\n\n  module Error = (val m : T)\nend\n\ninclude Magic.Error\n\nlet raise_js_error e = Js_error.raise_ (Js_error.of_error e)\n\nlet string_of_error e = Js_error.to_string (Js_error.of_error e)\n\nlet exn_with_js_backtrace = Js_error.attach_js_backtrace\n\nexternal js_error_of_exn : exn -> error t opt = \"caml_js_error_of_exception\"\n\nclass type json = object\n  method parse : js_string t -> 'a meth\n\n  method stringify : 'a -> js_string t meth\nend\n\nlet _JSON : json t = Unsafe.global##._JSON\n\nlet decodeURI (s : js_string t) : js_string t =\n  Unsafe.fun_call Unsafe.global##.decodeURI [| Unsafe.inject s |]\n\nlet decodeURIComponent (s : js_string t) : js_string t =\n  Unsafe.fun_call Unsafe.global##.decodeURIComponent [| Unsafe.inject s |]\n\nlet encodeURI (s : js_string t) : js_string t =\n  Unsafe.fun_call Unsafe.global##.encodeURI [| Unsafe.inject s |]\n\nlet encodeURIComponent (s : js_string t) : js_string t =\n  Unsafe.fun_call Unsafe.global##.encodeURIComponent [| Unsafe.inject s |]\n\nlet escape (s : js_string t) : js_string t =\n  Unsafe.fun_call Unsafe.global##.escape [| Unsafe.inject s |]\n\nlet unescape (s : js_string t) : js_string t =\n  Unsafe.fun_call Unsafe.global##.unescape [| Unsafe.inject s |]\n\nexternal bool : bool -> bool t = \"caml_js_from_bool\"\n\nexternal to_bool : bool t -> bool = \"caml_js_to_bool\"\n\nexternal array : 'a array -> 'a js_array t = \"caml_js_from_array\"\n\nexternal to_array : 'a js_array t -> 'a array = \"caml_js_to_array\"\n\nexternal bytestring : string -> js_string t = \"caml_jsbytes_of_string\"\n\nexternal to_bytestring : js_string t -> string = \"caml_string_of_jsbytes\"\n\nexternal float : float -> number_t = \"caml_js_from_float\"\n\nexternal to_float : number_t -> float = \"caml_js_to_float\"\n\nexternal number_of_float : float -> number t = \"caml_js_from_float\"\n\nexternal float_of_number : number t -> float = \"caml_js_to_float\"\n\nexternal int32 : int32 -> number_t = \"caml_js_from_int32\"\n\nexternal to_int32 : number_t -> int32 = \"caml_js_to_int32\"\n\nexternal nativeint : nativeint -> number_t = \"caml_js_from_nativeint\"\n\nexternal to_nativeint : number_t -> nativeint = \"caml_js_to_nativeint\"\n\nexternal typeof : _ t -> js_string t = \"caml_js_typeof\"\n\nexternal instanceof : _ t -> _ constr -> bool = \"caml_js_instanceof\"\n\nlet isNaN (i : 'a) : bool =\n  to_bool (Unsafe.fun_call Unsafe.global##.isNaN [| Unsafe.inject i |])\n\nlet parseInt (s : js_string t) : int =\n  let s = Unsafe.fun_call Unsafe.global##.parseInt [| Unsafe.inject s |] in\n  if isNaN s then failwith \"parseInt\" else s\n\nlet parseFloat (s : js_string t) : number_t =\n  let s = Unsafe.fun_call Unsafe.global##.parseFloat [| Unsafe.inject s |] in\n  if isNaN s then failwith \"parseFloat\" else s\n\nlet _ =\n  Printexc.register_printer (function\n      | Js_error.Exn e -> Some (Js_error.to_string e)\n      | _ -> None)\n\nlet _ =\n  Printexc.register_printer (fun e ->\n      let e : < .. > t = Obj.magic e in\n      if instanceof e array_constructor then None else Some (to_string e##toString))\n\nlet export_js (field : js_string t) x =\n  Unsafe.set\n    (Unsafe.pure_js_expr \"jsoo_exports\")\n    field\n    (if String.equal (Js.to_string (typeof (Obj.magic x))) \"function\"\n        (* function with arity/length equal to zero are already wrapped *)\n        && Unsafe.get (Obj.magic x) (Js.string \"length\") > 0\n     then Obj.magic (wrap_callback (Obj.magic x))\n     else x)\n\nlet export field x = export_js (string field) x\n\nlet export_all obj =\n  let keys = object_keys obj in\n  keys##forEach\n    (wrap_callback (fun (key : js_string t) _ _ -> export_js key (Unsafe.get obj key)))\n\n(****)\n\n(* DEPRECATED *)\n\ntype float_prop = number_t prop\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2010 Jérôme Vouillon\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\nopen Js\nopen! Import\n\nclass type ['node] nodeList = object\n  method item : int -> 'node t opt meth\n\n  method length : int readonly_prop\nend\n\nlet list_of_nodeList (nodeList : 'a nodeList t) =\n  let length = nodeList##.length in\n  let rec add_item acc i =\n    if i < length\n    then\n      match Opt.to_option (nodeList##item i) with\n      | None -> add_item acc (i + 1)\n      | Some e -> add_item (e :: acc) (i + 1)\n    else List.rev acc\n  in\n  add_item [] 0\n\ntype nodeType =\n  | OTHER\n  (* Will not happen *)\n  | ELEMENT\n  | ATTRIBUTE\n  | TEXT\n  | CDATA_SECTION\n  | ENTITY_REFERENCE\n  | ENTITY\n  | PROCESSING_INSTRUCTION\n  | COMMENT\n  | DOCUMENT\n  | DOCUMENT_TYPE\n  | DOCUMENT_FRAGMENT\n  | NOTATION\n\nmodule DocumentPosition = struct\n  type t = int\n\n  type mask = int\n\n  let disconnected = 0x01\n\n  let preceding = 0x02\n\n  let following = 0x04\n\n  let contains = 0x08\n\n  let contained_by = 0x10\n\n  let implementation_specific = 0x20\n\n  let has t mask = t land mask = mask\n\n  let add x y = x lor y\n\n  let ( + ) = add\nend\n\nclass type node = object\n  method nodeName : js_string t readonly_prop\n\n  method nodeValue : js_string t opt readonly_prop\n\n  method nodeType : nodeType readonly_prop\n\n  method parentNode : node t opt prop\n\n  method childNodes : node nodeList t prop\n\n  method firstChild : node t opt prop\n\n  method lastChild : node t opt prop\n\n  method previousSibling : node t opt prop\n\n  method nextSibling : node t opt prop\n\n  method namespaceURI : js_string t opt prop\n\n  method insertBefore : node t -> node t opt -> node t meth\n\n  method replaceChild : node t -> node t -> node t meth\n\n  method removeChild : node t -> node t meth\n\n  method appendChild : node t -> node t meth\n\n  method hasChildNodes : bool t meth\n\n  method cloneNode : bool t -> node t meth\n\n  method compareDocumentPosition : node t -> DocumentPosition.t meth\n\n  method lookupNamespaceURI : js_string t -> js_string t opt meth\n\n  method lookupPrefix : js_string t -> js_string t opt meth\nend\n\nlet appendChild (p : #node t) (n : #node t) = ignore (p##appendChild (n :> node t))\n\nlet removeChild (p : #node t) (n : #node t) = ignore (p##removeChild (n :> node t))\n\nlet replaceChild (p : #node t) (n : #node t) (o : #node t) =\n  ignore (p##replaceChild (n :> node t) (o :> node t))\n\nlet insertBefore (p : #node t) (n : #node t) (o : #node t opt) =\n  ignore (p##insertBefore (n :> node t) (o :> node t opt))\n\n(** Specification of [Attr] objects. *)\nclass type attr = object\n  inherit node\n\n  method name : js_string t readonly_prop\n\n  method specified : bool t readonly_prop\n\n  method value : js_string t prop\n\n  method ownerElement : element t prop\nend\n\n(** Specification of [NamedNodeMap] objects. *)\nand ['node] namedNodeMap = object\n  method getNamedItem : js_string t -> 'node t opt meth\n\n  method setNamedItem : 'node t -> 'node t opt meth\n\n  method removeNamedItem : js_string t -> 'node t opt meth\n\n  method item : int -> 'node t opt meth\n\n  method length : int readonly_prop\nend\n\n(** Specification of [Element] objects. *)\nand element = object\n  inherit node\n\n  method tagName : js_string t readonly_prop\n\n  method getAttribute : js_string t -> js_string t opt meth\n\n  method setAttribute : js_string t -> js_string t -> unit meth\n\n  method removeAttribute : js_string t -> unit meth\n\n  method hasAttribute : js_string t -> bool t meth\n\n  method getAttributeNS : js_string t -> js_string t -> js_string t opt meth\n\n  method setAttributeNS : js_string t -> js_string t -> js_string t -> unit meth\n\n  method removeAttributeNS : js_string t -> js_string t -> unit meth\n\n  method hasAttributeNS : js_string t -> js_string t -> bool t meth\n\n  method getAttributeNode : js_string t -> attr t opt meth\n\n  method setAttributeNode : attr t -> attr t opt meth\n\n  method removeAttributeNode : attr t -> attr t meth\n\n  method getAttributeNodeNS : js_string t -> js_string t -> attr t opt meth\n\n  method setAttributeNodeNS : attr t -> attr t opt meth\n\n  method getElementsByTagName : js_string t -> element nodeList t meth\n\n  method attributes : attr namedNodeMap t readonly_prop\nend\n\nclass type characterData = object\n  inherit node\n\n  method data : js_string t prop\n\n  method length : int readonly_prop\n\n  method subjs_stringData : int -> int -> js_string t meth\n\n  method appendData : js_string t -> unit meth\n\n  method insertData : int -> js_string t -> unit meth\n\n  method deleteData : int -> int -> unit meth\n\n  method replaceData : int -> int -> js_string t -> unit meth\nend\n\nclass type comment = characterData\n\nclass type text = characterData\n\nclass type documentFragment = node\n\nclass type ['element] document = object\n  inherit node\n\n  method documentElement : 'element t readonly_prop\n\n  method createDocumentFragment : documentFragment t meth\n\n  method createElement : js_string t -> 'element t meth\n\n  method createElementNS : js_string t -> js_string t -> 'element t meth\n\n  method createTextNode : js_string t -> text t meth\n\n  method createAttribute : js_string t -> attr t meth\n\n  method createComment : js_string t -> comment t meth\n\n  method getElementById : js_string t -> 'element t opt meth\n\n  method getElementsByTagName : js_string t -> 'element nodeList t meth\n\n  method importNode : element t -> bool t -> 'element t meth\n\n  method adoptNode : element t -> 'element t meth\nend\n\ntype node_type =\n  | Element of element t\n  | Attr of attr t\n  | Text of text t\n  | Other of node t\n\nlet nodeType e =\n  match e##.nodeType with\n  | ELEMENT -> Element (Js.Unsafe.coerce e)\n  | ATTRIBUTE -> Attr (Js.Unsafe.coerce e)\n  | CDATA_SECTION | TEXT -> Text (Js.Unsafe.coerce e)\n  | _ -> Other (e :> node t)\n\nmodule CoerceTo = struct\n  let cast (e : #node Js.t) t =\n    if e##.nodeType == t then Js.some (Js.Unsafe.coerce e) else Js.null\n\n  let element e : element Js.t Js.opt = cast e ELEMENT\n\n  let text e : text Js.t Js.opt =\n    if e##.nodeType == TEXT || e##.nodeType == CDATA_SECTION\n    then Js.some (Js.Unsafe.coerce e)\n    else Js.null\n\n  let attr e : attr Js.t Js.opt = cast e ATTRIBUTE\nend\n\ntype ('a, 'b) event_listener = ('a, 'b -> bool t) meth_callback opt\n(** The type of event listener functions.  The first type parameter\n      ['a] is the type of the target object; the second parameter\n      ['b] is the type of the event object. *)\n\nclass type ['a] event = object\n  method _type : js_string t readonly_prop\n\n  method target : 'a t opt readonly_prop\n\n  method currentTarget : 'a t opt readonly_prop\n\n  (* Legacy methods *)\n  method srcElement : 'a t opt readonly_prop\nend\n\nclass type ['a, 'b] customEvent = object\n  inherit ['a] event\n\n  method detail : 'b Js.opt Js.readonly_prop\nend\n\nlet no_handler : ('a, 'b) event_listener = Js.null\n\nlet window_event () : 'a #event t = Js.Unsafe.pure_js_expr \"event\"\n\n(* The function preventDefault must be called explicitly when\n   using addEventListener... *)\nlet handler f =\n  Js.some\n    (Js.Unsafe.callback (fun e ->\n         (* depending on the internet explorer version, e can be null or undefined. *)\n         if not (Js.Opt.test (some e))\n         then (\n           let e = window_event () in\n           let res = f e in\n           if not (Js.to_bool res) then e##.returnValue := res;\n           res)\n         else\n           let res = f e in\n           if not (Js.to_bool res) then (Js.Unsafe.coerce e)##preventDefault;\n           res))\n\nlet full_handler f =\n  Js.some\n    (Js.Unsafe.meth_callback (fun this e ->\n         (* depending on the internet explorer version, e can be null or undefined *)\n         if not (Js.Opt.test (some e))\n         then (\n           let e = window_event () in\n           let res = f this e in\n           if not (Js.to_bool res) then e##.returnValue := res;\n           res)\n         else\n           let res = f this e in\n           if not (Js.to_bool res) then (Js.Unsafe.coerce e)##preventDefault;\n           res))\n\nlet invoke_handler (f : ('a, 'b) event_listener) (this : 'a) (event : 'b) : bool t =\n  Js.Unsafe.call f this [| Js.Unsafe.inject event |]\n\nlet eventTarget (e : (< .. > as 'a) #event t) : 'a t =\n  let target =\n    Opt.get e##.target (fun () -> Opt.get e##.srcElement (fun () -> raise Not_found))\n  in\n  if Js.instanceof target Js.Unsafe.global##._Node\n  then\n    (* Workaround for Safari bug *)\n    let target' : node Js.t = Js.Unsafe.coerce target in\n    if target'##.nodeType == TEXT\n    then Js.Unsafe.coerce (Opt.get target'##.parentNode (fun () -> assert false))\n    else target\n  else target\n\nmodule Event = struct\n  type 'a typ = Js.js_string Js.t\n\n  let make s = Js.string s\nend\n\ntype event_listener_id = unit -> unit\n\nclass type event_listener_options = object\n  method capture : bool t writeonly_prop\n\n  method once : bool t writeonly_prop\n\n  method passive : bool t writeonly_prop\nend\n\nlet addEventListenerWithOptions (e : (< .. > as 'a) t) typ ?capture ?once ?passive h =\n  if not (Js.Optdef.test (Js.Unsafe.coerce e)##.addEventListener)\n  then\n    let ev = (Js.string \"on\")##concat typ in\n    let callback e = Js.Unsafe.call (h, e, [||]) in\n    let () = (Js.Unsafe.coerce e)##attachEvent ev callback in\n    fun () -> (Js.Unsafe.coerce e)##detachEvent ev callback\n  else\n    let opts : event_listener_options t = Js.Unsafe.obj [||] in\n    let iter t f =\n      match t with\n      | None -> ()\n      | Some b -> f b\n    in\n    iter capture (fun b -> opts##.capture := b);\n    iter once (fun b -> opts##.once := b);\n    iter passive (fun b -> opts##.passive := b);\n    let () = (Js.Unsafe.coerce e)##addEventListener typ h opts in\n    fun () -> (Js.Unsafe.coerce e)##removeEventListener typ h opts\n\nlet addEventListener (e : (< .. > as 'a) t) typ h capt =\n  addEventListenerWithOptions e typ ~capture:capt h\n\nlet removeEventListener id = id ()\n\nlet preventDefault ev =\n  if Js.Optdef.test (Js.Unsafe.coerce ev)##.preventDefault (* IE hack *)\n  then (Js.Unsafe.coerce ev)##preventDefault\n  else (Js.Unsafe.coerce ev)##.returnValue := Js.bool false\n\nlet createCustomEvent ?bubbles ?cancelable ?detail typ =\n  let opt_iter f = function\n    | None -> ()\n    | Some x -> f x\n  in\n  let opts = Unsafe.obj [||] in\n  opt_iter (fun x -> opts##.bubbles := bool x) bubbles;\n  opt_iter (fun x -> opts##.cancelable := bool x) cancelable;\n  opt_iter (fun x -> opts##.detail := some x) detail;\n  let constr :\n      (   ('a, 'b) #customEvent Js.t Event.typ\n       -> < detail : 'b opt prop > t\n       -> ('a, 'b) customEvent t)\n      constr =\n    Unsafe.global##._CustomEvent\n  in\n  new%js constr typ opts\n\n(* IE < 9 *)\n\nclass type stringList = object\n  method item : int -> js_string t opt meth\n\n  method length : int readonly_prop\n\n  method contains : js_string t -> bool t meth\nend\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2012 Jérôme Vouillon\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\nopen! Import\nopen Js\n\ntype uint32 = float\n\nclass type arrayBuffer = object\n  method byteLength : int readonly_prop\n\n  method slice : int -> int -> arrayBuffer t meth\n\n  method slice_toEnd : int -> arrayBuffer t meth\nend\n\nlet arrayBuffer : (int -> arrayBuffer t) constr = Js.Unsafe.global##._ArrayBuffer\n\nclass type arrayBufferView = object\n  method buffer : arrayBuffer t readonly_prop\n\n  method byteOffset : int readonly_prop\n\n  method byteLength : int readonly_prop\nend\n\nclass type ['a, 'b] typedArray = object\n  inherit arrayBufferView\n\n  method _BYTES_PER_ELEMENT : int readonly_prop\n\n  method length : int readonly_prop\n\n  method set_fromArray : 'a js_array t -> int -> unit meth\n\n  method set_fromTypedArray : ('a, 'b) typedArray t -> int -> unit meth\n\n  method subarray : int -> int -> ('a, 'b) typedArray t meth\n\n  method subarray_toEnd : int -> ('a, 'b) typedArray t meth\n\n  method slice : int -> int -> ('a, 'b) typedArray t meth\n\n  method slice_toEnd : int -> ('a, 'b) typedArray t meth\n\n  (* This fake method is needed for typing purposes.\n     Without it, ['b] would not be constrained. *)\n  method _content_type_ : 'b optdef readonly_prop\nend\n\ntype int8Array = (int, Bigarray.int8_signed_elt) typedArray\n\ntype uint8Array = (int, Bigarray.int8_unsigned_elt) typedArray\n\ntype int16Array = (int, Bigarray.int16_signed_elt) typedArray\n\ntype uint16Array = (int, Bigarray.int16_unsigned_elt) typedArray\n\ntype int32Array = (int32, Bigarray.int32_elt) typedArray\n\ntype uint32Array = (int32, Bigarray.int32_elt) typedArray\n\ntype float32Array = (float, Bigarray.float32_elt) typedArray\n\ntype float64Array = (float, Bigarray.float64_elt) typedArray\n\nexternal kind : ('a, 'b) typedArray t -> ('a, 'b) Bigarray.kind\n  = \"caml_ba_kind_of_typed_array\"\n\nexternal from_genarray :\n  ('a, 'b, Bigarray.c_layout) Bigarray.Genarray.t -> ('a, 'b) typedArray t\n  = \"caml_ba_to_typed_array\"\n\nexternal to_genarray :\n  ('a, 'b) typedArray t -> ('a, 'b, Bigarray.c_layout) Bigarray.Genarray.t\n  = \"caml_ba_from_typed_array\"\n\nlet int8Array = Js.Unsafe.global##._Int8Array\n\nlet int8Array_fromArray = int8Array\n\nlet int8Array_fromTypedArray = int8Array\n\nlet int8Array_fromBuffer = int8Array\n\nlet int8Array_inBuffer = int8Array\n\nlet uint8Array = Js.Unsafe.global##._Uint8Array\n\nlet uint8Array_fromArray = uint8Array\n\nlet uint8Array_fromTypedArray = uint8Array\n\nlet uint8Array_fromBuffer = uint8Array\n\nlet uint8Array_inBuffer = uint8Array\n\nlet int16Array = Js.Unsafe.global##._Int16Array\n\nlet int16Array_fromArray = int16Array\n\nlet int16Array_fromTypedArray = int16Array\n\nlet int16Array_fromBuffer = int16Array\n\nlet int16Array_inBuffer = int16Array\n\nlet uint16Array = Js.Unsafe.global##._Uint16Array\n\nlet uint16Array_fromArray = uint16Array\n\nlet uint16Array_fromTypedArray = uint16Array\n\nlet uint16Array_fromBuffer = uint16Array\n\nlet uint16Array_inBuffer = uint16Array\n\nlet int32Array = Js.Unsafe.global##._Int32Array\n\nlet int32Array_fromArray = int32Array\n\nlet int32Array_fromTypedArray = int32Array\n\nlet int32Array_fromBuffer = int32Array\n\nlet int32Array_inBuffer = int32Array\n\nlet uint32Array = Js.Unsafe.global##._Uint32Array\n\nlet uint32Array_fromArray = uint32Array\n\nlet uint32Array_fromTypedArray = uint32Array\n\nlet uint32Array_fromBuffer = uint32Array\n\nlet uint32Array_inBuffer = uint32Array\n\nlet float32Array = Js.Unsafe.global##._Float32Array\n\nlet float32Array_fromArray = float32Array\n\nlet float32Array_fromTypedArray = float32Array\n\nlet float32Array_fromBuffer = float32Array\n\nlet float32Array_inBuffer = float32Array\n\nlet float64Array = Js.Unsafe.global##._Float64Array\n\nlet float64Array_fromArray = float64Array\n\nlet float64Array_fromTypedArray = float64Array\n\nlet float64Array_fromBuffer = float64Array\n\nlet float64Array_inBuffer = float64Array\n\nlet set : ('a, 'b) typedArray t -> int -> 'a -> unit =\n fun a i v -> array_set (Unsafe.coerce a) i v\n\nlet get : ('a, 'b) typedArray t -> int -> 'a optdef = fun a i -> Js.Unsafe.get a i\n\nlet unsafe_get : ('a, 'b) typedArray t -> int -> 'a = fun a i -> Js.Unsafe.get a i\n\nclass type dataView = object\n  inherit arrayBufferView\n\n  method getInt8 : int -> int meth\n\n  method getUint8 : int -> int meth\n\n  method getInt16 : int -> int meth\n\n  method getInt16_ : int -> bool t -> int meth\n\n  method getUint16 : int -> int meth\n\n  method getUint16_ : int -> bool t -> int meth\n\n  method getInt32 : int -> int meth\n\n  method getInt32_ : int -> bool t -> int meth\n\n  method getUint32 : int -> uint32 meth\n\n  method getUint32_ : int -> bool t -> uint32 meth\n\n  method getFloat32 : int -> number_t meth\n\n  method getFloat32_ : int -> bool t -> number_t meth\n\n  method getFloat64 : int -> number_t meth\n\n  method getFloat64_ : int -> bool t -> number_t meth\n\n  method setInt8 : int -> int -> unit meth\n\n  method setUint8 : int -> int -> unit meth\n\n  method setInt16 : int -> int -> unit meth\n\n  method setInt16_ : int -> int -> bool t -> unit meth\n\n  method setUint16 : int -> int -> unit meth\n\n  method setUint16_ : int -> int -> bool t -> unit meth\n\n  method setInt32 : int -> int -> unit meth\n\n  method setInt32_ : int -> int -> bool t -> unit meth\n\n  method setUint32 : int -> uint32 -> unit meth\n\n  method setUint32_ : int -> uint32 -> bool t -> unit meth\n\n  method setFloat32 : int -> number_t -> unit meth\n\n  method setFloat32_ : int -> number_t -> bool t -> unit meth\n\n  method setFloat64 : int -> number_t -> unit meth\n\n  method setFloat64_ : int -> number_t -> bool t -> unit meth\nend\n\nlet dataView = Js.Unsafe.global##._DataView\n\nlet dataView_inBuffer = dataView\n\nmodule Bigstring = struct\n  type t = (char, Bigarray.int8_unsigned_elt, Bigarray.c_layout) Bigarray.Array1.t\n\n  external to_arrayBuffer : t -> arrayBuffer Js.t = \"bigstring_to_array_buffer\"\n\n  external to_uint8Array : t -> uint8Array Js.t = \"bigstring_to_typed_array\"\n\n  external of_arrayBuffer : arrayBuffer Js.t -> t = \"bigstring_of_array_buffer\"\n\n  external of_uint8Array : uint8Array Js.t -> t = \"bigstring_of_typed_array\"\nend\n\nmodule String = struct\n  external of_uint8Array : uint8Array Js.t -> string = \"caml_string_of_array\"\n\n  let of_arrayBuffer ab =\n    let uint8 = new%js uint8Array_fromBuffer ab in\n    of_uint8Array uint8\nend\n\nmodule Bytes = struct\n  external of_uint8Array : uint8Array Js.t -> bytes = \"caml_bytes_of_array\"\n\n  external to_uint8Array : bytes -> uint8Array Js.t = \"caml_uint8_array_of_bytes\"\n\n  let of_arrayBuffer ab =\n    let uint8 = new%js uint8Array_fromBuffer ab in\n    of_uint8Array uint8\nend\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2011 Pierre Chambart\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\nopen Js\nopen Dom\nopen! Import\n\nclass type blob = object\n  method size : int readonly_prop\n\n  method _type : js_string t readonly_prop\n\n  method slice : int -> int -> blob t meth\n\n  method slice_withContentType : int -> int -> js_string t -> blob t meth\nend\n\nlet blob_constr = Unsafe.global##._Blob\n\ntype 'a make_blob =\n  ?contentType:string -> ?endings:[ `Transparent | `Native ] -> 'a -> blob t\n\nlet rec filter_map f = function\n  | [] -> []\n  | v :: q -> (\n      match f v with\n      | None -> filter_map f q\n      | Some v' -> v' :: filter_map f q)\n\nlet make_blob_options contentType endings =\n  let options =\n    filter_map\n      (fun (name, v) ->\n        match v with\n        | None -> None\n        | Some v -> Some (name, Unsafe.inject (string v)))\n      [ \"type\", contentType\n      ; ( \"endings\"\n        , match endings with\n          | None -> None\n          | Some `Transparent -> Some \"transparent\"\n          | Some `Native -> Some \"native\" )\n      ]\n  in\n  match options with\n  | [] -> undefined\n  | l -> Unsafe.obj (Array.of_list l)\n\nlet blob_raw ?contentType ?endings a =\n  let options = make_blob_options contentType endings in\n  new%js blob_constr (array a) options\n\nlet blob_from_string ?contentType ?endings s =\n  blob_raw ?contentType ?endings [| string s |]\n\nlet blob_from_any ?contentType ?endings l =\n  let l =\n    List.map\n      (function\n        | `arrayBuffer a -> Unsafe.inject a\n        | `arrayBufferView a -> Unsafe.inject a\n        | `string s -> Unsafe.inject (string s)\n        | `js_string s -> Unsafe.inject s\n        | `blob b -> Unsafe.inject b)\n      l\n  in\n  blob_raw ?contentType ?endings (Array.of_list l)\n\nclass type file = object\n  inherit blob\n\n  method name : js_string t readonly_prop\n\n  method lastModifiedDate : js_string t readonly_prop\nend\n\n(* in firefox 3.0-3.5 file.name is not available, we use the nonstandard fileName instead *)\nclass type file_name_only = object\n  method name : js_string t optdef readonly_prop\n\n  method fileName : js_string t optdef readonly_prop\nend\n\nlet filename file =\n  let file : file_name_only t = Js.Unsafe.coerce file in\n  match Optdef.to_option file##.name with\n  | None -> (\n      match Optdef.to_option file##.fileName with\n      | None -> failwith \"can't retrieve file name: not implemented\"\n      | Some name -> name)\n  | Some name -> name\n\ntype file_any = < > t\n\nlet doc_constr = Unsafe.global##._Document\n\nmodule CoerceTo = struct\n  external json : file_any -> 'a Opt.t = \"%identity\"\n\n  let document (e : file_any) =\n    if instanceof e doc_constr\n    then Js.some (Unsafe.coerce e : element document t)\n    else Js.null\n\n  let blob (e : file_any) =\n    if instanceof e blob_constr then Js.some (Unsafe.coerce e : #blob t) else Js.null\n\n  let string (e : file_any) =\n    if Js.equals (typeof e) (string \"string\")\n    then Js.some (Unsafe.coerce e : js_string t)\n    else Js.null\n\n  let arrayBuffer (e : file_any) =\n    if instanceof e Typed_array.arrayBuffer\n    then Js.some (Unsafe.coerce e : Typed_array.arrayBuffer t)\n    else Js.null\nend\n\nclass type fileList = object\n  inherit [file] Dom.nodeList\nend\n\nclass type fileError = object\n  method code : int readonly_prop\nend\n\nclass type ['a] progressEvent = object\n  inherit ['a] event\n\n  method lengthComputable : bool t readonly_prop\n\n  method loaded : int readonly_prop\n\n  method total : int readonly_prop\nend\n\nclass type progressEventTarget = object ('self)\n  method onloadstart : ('self t, 'self progressEvent t) event_listener writeonly_prop\n\n  method onprogress : ('self t, 'self progressEvent t) event_listener writeonly_prop\n\n  method onload : ('self t, 'self progressEvent t) event_listener writeonly_prop\n\n  method onabort : ('self t, 'self progressEvent t) event_listener writeonly_prop\n\n  method onerror : ('self t, 'self progressEvent t) event_listener writeonly_prop\n\n  method onloadend : ('self t, 'self progressEvent t) event_listener writeonly_prop\nend\n\ntype readyState =\n  | EMPTY\n  | LOADING\n  | DONE\n\nclass type fileReader = object ('self)\n  method readAsArrayBuffer : #blob t -> unit meth\n\n  method readAsBinaryString : #blob t -> unit meth\n\n  method readAsText : #blob t -> unit meth\n\n  method readAsText_withEncoding : #blob t -> js_string t -> unit meth\n\n  method readAsDataURL : #blob t -> unit meth\n\n  method abort : unit meth\n\n  method readyState : readyState readonly_prop\n\n  method result : file_any readonly_prop\n\n  method error : fileError t readonly_prop\n\n  inherit progressEventTarget\nend\n\nmodule ReaderEvent = struct\n  type typ = fileReader progressEvent t Dom.Event.typ\n\n  let loadstart = Event.make \"loadstart\"\n\n  let progress = Event.make \"progress\"\n\n  let abort = Event.make \"abort\"\n\n  let error = Event.make \"error\"\n\n  let load = Event.make \"load\"\n\n  let loadend = Event.make \"loadend\"\nend\n\nlet fileReader : fileReader t constr = Js.Unsafe.global##._FileReader\n\nlet addEventListener = Dom.addEventListener\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2010 Jérôme Vouillon\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\nopen Js\nopen! Import\n\nexternal caml_js_on_ie : unit -> bool t = \"caml_js_on_ie\"\n\nlet onIE = Js.to_bool (caml_js_on_ie ())\n\nexternal html_escape : js_string t -> js_string t = \"caml_js_html_escape\"\n\nexternal decode_html_entities : js_string t -> js_string t = \"caml_js_html_entities\"\n\nclass type cssStyleDeclaration = object\n  method setProperty :\n    js_string t -> js_string t -> js_string t optdef -> js_string t meth\n\n  method getPropertyValue : js_string t -> js_string t meth\n\n  method getPropertyPriority : js_string t -> js_string t meth\n\n  method removeProperty : js_string t -> js_string t meth\n\n  method animation : js_string t prop\n\n  method animationDelay : js_string t prop\n\n  method animationDirection : js_string t prop\n\n  method animationDuration : js_string t prop\n\n  method animationFillMode : js_string t prop\n\n  method animationIterationCount : js_string t prop\n\n  method animationName : js_string t prop\n\n  method animationPlayState : js_string t prop\n\n  method animationTimingFunction : js_string t prop\n\n  method background : js_string t prop\n\n  method backgroundAttachment : js_string t prop\n\n  method backgroundColor : js_string t prop\n\n  method backgroundImage : js_string t prop\n\n  method backgroundPosition : js_string t prop\n\n  method backgroundRepeat : js_string t prop\n\n  method border : js_string t prop\n\n  method borderBottom : js_string t prop\n\n  method borderBottomColor : js_string t prop\n\n  method borderBottomStyle : js_string t prop\n\n  method borderBottomWidth : js_string t prop\n\n  method borderCollapse : js_string t prop\n\n  method borderColor : js_string t prop\n\n  method borderLeft : js_string t prop\n\n  method borderLeftColor : js_string t prop\n\n  method borderLeftStyle : js_string t prop\n\n  method borderLeftWidth : js_string t prop\n\n  method borderRadius : js_string t prop\n\n  method borderRight : js_string t prop\n\n  method borderRightColor : js_string t prop\n\n  method borderRightStyle : js_string t prop\n\n  method borderRightWidth : js_string t prop\n\n  method borderSpacing : js_string t prop\n\n  method borderStyle : js_string t prop\n\n  method borderTop : js_string t prop\n\n  method borderTopColor : js_string t prop\n\n  method borderTopStyle : js_string t prop\n\n  method borderTopWidth : js_string t prop\n\n  method borderWidth : js_string t prop\n\n  method bottom : js_string t prop\n\n  method captionSide : js_string t prop\n\n  method clear : js_string t prop\n\n  method clip : js_string t prop\n\n  method color : js_string t prop\n\n  method content : js_string t prop\n\n  method counterIncrement : js_string t prop\n\n  method counterReset : js_string t prop\n\n  method cssFloat : js_string t prop\n\n  method cssText : js_string t prop\n\n  method cursor : js_string t prop\n\n  method direction : js_string t prop\n\n  method display : js_string t prop\n\n  method emptyCells : js_string t prop\n\n  method fill : js_string t prop\n\n  method font : js_string t prop\n\n  method fontFamily : js_string t prop\n\n  method fontSize : js_string t prop\n\n  method fontStyle : js_string t prop\n\n  method fontVariant : js_string t prop\n\n  method fontWeight : js_string t prop\n\n  method height : js_string t prop\n\n  method left : js_string t prop\n\n  method letterSpacing : js_string t prop\n\n  method lineHeight : js_string t prop\n\n  method listStyle : js_string t prop\n\n  method listStyleImage : js_string t prop\n\n  method listStylePosition : js_string t prop\n\n  method listStyleType : js_string t prop\n\n  method margin : js_string t prop\n\n  method marginBottom : js_string t prop\n\n  method marginLeft : js_string t prop\n\n  method marginRight : js_string t prop\n\n  method marginTop : js_string t prop\n\n  method maxHeight : js_string t prop\n\n  method maxWidth : js_string t prop\n\n  method minHeight : js_string t prop\n\n  method minWidth : js_string t prop\n\n  method opacity : js_string t optdef prop\n\n  method outline : js_string t prop\n\n  method outlineColor : js_string t prop\n\n  method outlineOffset : js_string t prop\n\n  method outlineStyle : js_string t prop\n\n  method outlineWidth : js_string t prop\n\n  method overflow : js_string t prop\n\n  method overflowX : js_string t prop\n\n  method overflowY : js_string t prop\n\n  method padding : js_string t prop\n\n  method paddingBottom : js_string t prop\n\n  method paddingLeft : js_string t prop\n\n  method paddingRight : js_string t prop\n\n  method paddingTop : js_string t prop\n\n  method pageBreakAfter : js_string t prop\n\n  method pageBreakBefore : js_string t prop\n\n  method pointerEvents : js_string t prop\n\n  method position : js_string t prop\n\n  method right : js_string t prop\n\n  method stroke : js_string t prop\n\n  method strokeWidth : js_string t prop\n\n  method tableLayout : js_string t prop\n\n  method textAlign : js_string t prop\n\n  method textAnchor : js_string t prop\n\n  method textDecoration : js_string t prop\n\n  method textIndent : js_string t prop\n\n  method textTransform : js_string t prop\n\n  method top : js_string t prop\n\n  method transform : js_string t prop\n\n  method verticalAlign : js_string t prop\n\n  method visibility : js_string t prop\n\n  method whiteSpace : js_string t prop\n\n  method width : js_string t prop\n\n  method wordSpacing : js_string t prop\n\n  method zIndex : js_string t prop\nend\n\ntype ('a, 'b) event_listener = ('a, 'b) Dom.event_listener\n\ntype mouse_button =\n  | No_button\n  | Left_button\n  | Middle_button\n  | Right_button\n\ntype delta_mode =\n  | Delta_pixel\n  | Delta_line\n  | Delta_page\n\nclass type event = object\n  inherit [element] Dom.event\nend\n\nand ['a] customEvent = object\n  inherit [element, 'a] Dom.customEvent\nend\n\nand focusEvent = object\n  inherit event\n\n  method relatedTarget : element t opt optdef readonly_prop\nend\n\nand mouseEvent = object\n  inherit event\n\n  method relatedTarget : element t opt optdef readonly_prop\n\n  method clientX : int readonly_prop\n\n  method clientY : int readonly_prop\n\n  method screenX : int readonly_prop\n\n  method screenY : int readonly_prop\n\n  method offsetX : int readonly_prop\n\n  method offsetY : int readonly_prop\n\n  method ctrlKey : bool t readonly_prop\n\n  method shiftKey : bool t readonly_prop\n\n  method altKey : bool t readonly_prop\n\n  method metaKey : bool t readonly_prop\n\n  method button : int readonly_prop\n\n  method which : mouse_button optdef readonly_prop\n\n  method fromElement : element t opt optdef readonly_prop\n\n  method toElement : element t opt optdef readonly_prop\n\n  method pageX : int optdef readonly_prop\n\n  method pageY : int optdef readonly_prop\nend\n\nand keyboardEvent = object\n  inherit event\n\n  method altKey : bool t readonly_prop\n\n  method shiftKey : bool t readonly_prop\n\n  method ctrlKey : bool t readonly_prop\n\n  method metaKey : bool t readonly_prop\n\n  method location : int readonly_prop\n\n  method key : js_string t optdef readonly_prop\n\n  method code : js_string t optdef readonly_prop\n\n  method which : int optdef readonly_prop\n\n  method charCode : int optdef readonly_prop\n\n  method keyCode : int readonly_prop\n\n  method getModifierState : js_string t -> bool t meth\n\n  method keyIdentifier : js_string t optdef readonly_prop\nend\n\nand mousewheelEvent = object\n  (* All modern browsers *)\n  inherit mouseEvent\n\n  method wheelDelta : int readonly_prop\n\n  method wheelDeltaX : int optdef readonly_prop\n\n  method wheelDeltaY : int optdef readonly_prop\n\n  method deltaX : number_t readonly_prop\n\n  method deltaY : number_t readonly_prop\n\n  method deltaZ : number_t readonly_prop\n\n  method deltaMode : delta_mode readonly_prop\nend\n\nand mouseScrollEvent = object\n  (* Firefox *)\n  inherit mouseEvent\n\n  method detail : int readonly_prop\n\n  method axis : int optdef readonly_prop\n\n  method _HORIZONTAL_AXIS : int optdef readonly_prop\n\n  method _VERTICAL_AXIS : int optdef readonly_prop\nend\n\nand touchEvent = object\n  inherit event\n\n  method touches : touchList t readonly_prop\n\n  method targetTouches : touchList t readonly_prop\n\n  method changedTouches : touchList t readonly_prop\n\n  method ctrlKey : bool t readonly_prop\n\n  method shiftKey : bool t readonly_prop\n\n  method altKey : bool t readonly_prop\n\n  method metaKey : bool t readonly_prop\n\n  method relatedTarget : element t opt optdef readonly_prop\nend\n\nand touchList = object\n  method length : int readonly_prop\n\n  method item : int -> touch t optdef meth\nend\n\nand touch = object\n  method identifier : int readonly_prop\n\n  method target : element t optdef readonly_prop\n\n  method screenX : int readonly_prop\n\n  method screenY : int readonly_prop\n\n  method clientX : int readonly_prop\n\n  method clientY : int readonly_prop\n\n  method pageX : int readonly_prop\n\n  method pageY : int readonly_prop\nend\n\nand submitEvent = object\n  inherit event\n\n  method submitter : element t optdef readonly_prop\nend\n\nand dragEvent = object\n  inherit mouseEvent\n\n  method dataTransfer : dataTransfer t readonly_prop\nend\n\nand clipboardEvent = object\n  inherit event\n\n  method clipboardData : dataTransfer t readonly_prop\nend\n\nand dataTransfer = object\n  method dropEffect : js_string t prop\n\n  method effectAllowed : js_string t prop\n\n  method files : File.fileList t readonly_prop\n\n  method types : js_string t js_array t readonly_prop\n\n  method addElement : element t -> unit meth\n\n  method clearData : js_string t -> unit meth\n\n  method clearData_all : unit meth\n\n  method getData : js_string t -> js_string t meth\n\n  method setData : js_string t -> js_string t -> unit meth\n\n  method setDragImage : element t -> int -> int -> unit meth\nend\n\nand eventTarget = object ('self)\n  method onclick : ('self t, mouseEvent t) event_listener writeonly_prop\n\n  method ondblclick : ('self t, mouseEvent t) event_listener writeonly_prop\n\n  method onmousedown : ('self t, mouseEvent t) event_listener writeonly_prop\n\n  method onmouseup : ('self t, mouseEvent t) event_listener writeonly_prop\n\n  method onmouseover : ('self t, mouseEvent t) event_listener writeonly_prop\n\n  method onmousemove : ('self t, mouseEvent t) event_listener writeonly_prop\n\n  method onmouseout : ('self t, mouseEvent t) event_listener writeonly_prop\n\n  method onkeypress : ('self t, keyboardEvent t) event_listener writeonly_prop\n\n  method onkeydown : ('self t, keyboardEvent t) event_listener writeonly_prop\n\n  method onkeyup : ('self t, keyboardEvent t) event_listener writeonly_prop\n\n  method onscroll : ('self t, event t) event_listener writeonly_prop\n\n  method onwheel : ('self t, mousewheelEvent t) event_listener writeonly_prop\n\n  method ondragstart : ('self t, dragEvent t) event_listener writeonly_prop\n\n  method ondragend : ('self t, dragEvent t) event_listener writeonly_prop\n\n  method ondragenter : ('self t, dragEvent t) event_listener writeonly_prop\n\n  method ondragover : ('self t, dragEvent t) event_listener writeonly_prop\n\n  method ondragleave : ('self t, dragEvent t) event_listener writeonly_prop\n\n  method ondrag : ('self t, dragEvent t) event_listener writeonly_prop\n\n  method ondrop : ('self t, dragEvent t) event_listener writeonly_prop\n\n  method onanimationstart : ('self t, animationEvent t) event_listener writeonly_prop\n\n  method onanimationend : ('self t, animationEvent t) event_listener writeonly_prop\n\n  method onanimationiteration : ('self t, animationEvent t) event_listener writeonly_prop\n\n  method onanimationcancel : ('self t, animationEvent t) event_listener writeonly_prop\n\n  method ontransitionrun : ('self t, transitionEvent t) event_listener writeonly_prop\n\n  method ontransitionstart : ('self t, transitionEvent t) event_listener writeonly_prop\n\n  method ontransitionend : ('self t, transitionEvent t) event_listener writeonly_prop\n\n  method ontransitioncancel : ('self t, transitionEvent t) event_listener writeonly_prop\n\n  method ongotpointercapture : ('self t, pointerEvent t) event_listener writeonly_prop\n\n  method onlostpointercapture : ('self t, pointerEvent t) event_listener writeonly_prop\n\n  method onpointerenter : ('self t, pointerEvent t) event_listener writeonly_prop\n\n  method onpointercancel : ('self t, pointerEvent t) event_listener writeonly_prop\n\n  method onpointerdown : ('self t, pointerEvent t) event_listener writeonly_prop\n\n  method onpointerleave : ('self t, pointerEvent t) event_listener writeonly_prop\n\n  method onpointermove : ('self t, pointerEvent t) event_listener writeonly_prop\n\n  method onpointerout : ('self t, pointerEvent t) event_listener writeonly_prop\n\n  method onpointerover : ('self t, pointerEvent t) event_listener writeonly_prop\n\n  method onpointerup : ('self t, pointerEvent t) event_listener writeonly_prop\n\n  method dispatchEvent : event t -> bool t meth\nend\n\nand popStateEvent = object\n  inherit event\n\n  method state : Js.Unsafe.any readonly_prop\nend\n\nand pointerEvent = object\n  inherit mouseEvent\n\n  method pointerId : int Js.readonly_prop\n\n  method width : number_t Js.readonly_prop\n\n  method height : number_t Js.readonly_prop\n\n  method pressure : number_t Js.readonly_prop\n\n  method tangentialPressure : number_t Js.readonly_prop\n\n  method tiltX : int Js.readonly_prop\n\n  method tiltY : int Js.readonly_prop\n\n  method twist : int Js.readonly_prop\n\n  method pointerType : Js.js_string Js.t Js.readonly_prop\n\n  method isPrimary : bool Js.t Js.readonly_prop\nend\n\nand storageEvent = object\n  inherit event\n\n  method key : js_string t opt readonly_prop\n\n  method oldValue : js_string t opt readonly_prop\n\n  method newValue : js_string t opt readonly_prop\n\n  method url : js_string t readonly_prop\n\n  method storageArea : storage t opt readonly_prop\nend\n\nand storage = object\n  method length : int readonly_prop\n\n  method key : int -> js_string t opt meth\n\n  method getItem : js_string t -> js_string t opt meth\n\n  method setItem : js_string t -> js_string t -> unit meth\n\n  method removeItem : js_string t -> unit meth\n\n  method clear : unit meth\nend\n\nand hashChangeEvent = object\n  inherit event\n\n  method oldURL : js_string t readonly_prop\n\n  method newURL : js_string t readonly_prop\nend\n\nand animationEvent = object\n  inherit event\n\n  method animationName : js_string t readonly_prop\n\n  method elapsedTime : number_t readonly_prop\n\n  method pseudoElement : js_string t readonly_prop\nend\n\nand transitionEvent = object\n  inherit event\n\n  method propertyName : js_string t readonly_prop\n\n  method elapsedTime : number_t readonly_prop\n\n  method pseudoElement : js_string t readonly_prop\nend\n\nand mediaEvent = object\n  inherit event\nend\n\nand messageEvent = object\n  inherit event\n\n  method data : Unsafe.any opt readonly_prop\n\n  method source : Unsafe.any opt readonly_prop\nend\n\nand nodeSelector = object\n  method querySelector : js_string t -> element t opt meth\n\n  method querySelectorAll : js_string t -> element Dom.nodeList t meth\nend\n\nand tokenList = object\n  method length : int readonly_prop\n\n  method item : int -> js_string t optdef meth\n\n  method contains : js_string t -> bool t meth\n\n  method add : js_string t -> unit meth\n\n  method remove : js_string t -> unit meth\n\n  method toggle : js_string t -> bool t meth\n\n  method stringifier : js_string t prop\nend\n\nand element = object\n  inherit Dom.element\n\n  inherit nodeSelector\n\n  method id : js_string t prop\n\n  method title : js_string t prop\n\n  method lang : js_string t prop\n\n  method dir : js_string t prop\n\n  method className : js_string t prop\n\n  method classList : tokenList t readonly_prop\n\n  method closest : js_string t -> element t opt meth\n\n  method style : cssStyleDeclaration t prop\n\n  method innerHTML : js_string t prop\n\n  method outerHTML : js_string t prop\n\n  method textContent : js_string t opt prop\n\n  method innerText : js_string t prop\n\n  method clientLeft : int readonly_prop\n\n  method clientTop : int readonly_prop\n\n  method clientWidth : int readonly_prop\n\n  method clientHeight : int readonly_prop\n\n  method offsetLeft : int readonly_prop\n\n  method offsetTop : int readonly_prop\n\n  method offsetParent : element t opt readonly_prop\n\n  method offsetWidth : int readonly_prop\n\n  method offsetHeight : int readonly_prop\n\n  method scrollLeft : int prop\n\n  method scrollTop : int prop\n\n  method scrollWidth : int prop\n\n  method scrollHeight : int prop\n\n  method getClientRects : clientRectList t meth\n\n  method getBoundingClientRect : clientRect t meth\n\n  method scrollIntoView : bool t -> unit meth\n\n  method click : unit meth\n\n  method focus : unit meth\n\n  method blur : unit meth\n\n  inherit eventTarget\nend\n\nand clientRect = object\n  method top : number_t readonly_prop\n\n  method right : number_t readonly_prop\n\n  method bottom : number_t readonly_prop\n\n  method left : number_t readonly_prop\n\n  method width : number_t optdef readonly_prop\n\n  method height : number_t optdef readonly_prop\nend\n\nand clientRectList = object\n  method length : int readonly_prop\n\n  method item : int -> clientRect t opt meth\nend\n\nlet no_handler : ('a, 'b) event_listener = Dom.no_handler\n\nlet handler = Dom.handler\n\nlet full_handler = Dom.full_handler\n\nlet invoke_handler = Dom.invoke_handler\n\nmodule Event = struct\n  type 'a typ = 'a Dom.Event.typ\n\n  let cancel = Dom.Event.make \"cancel\"\n\n  let click = Dom.Event.make \"click\"\n\n  let close = Dom.Event.make \"close\"\n\n  let copy = Dom.Event.make \"copy\"\n\n  let cut = Dom.Event.make \"cut\"\n\n  let paste = Dom.Event.make \"paste\"\n\n  let dblclick = Dom.Event.make \"dblclick\"\n\n  let mousedown = Dom.Event.make \"mousedown\"\n\n  let mouseup = Dom.Event.make \"mouseup\"\n\n  let mouseover = Dom.Event.make \"mouseover\"\n\n  let mousemove = Dom.Event.make \"mousemove\"\n\n  let mouseout = Dom.Event.make \"mouseout\"\n\n  let keypress = Dom.Event.make \"keypress\"\n\n  let keydown = Dom.Event.make \"keydown\"\n\n  let keyup = Dom.Event.make \"keyup\"\n\n  let mousewheel = Dom.Event.make \"mousewheel\"\n\n  let wheel = Dom.Event.make \"wheel\"\n\n  let _DOMMouseScroll = Dom.Event.make \"DOMMouseScroll\"\n\n  let touchstart = Dom.Event.make \"touchstart\"\n\n  let touchmove = Dom.Event.make \"touchmove\"\n\n  let touchend = Dom.Event.make \"touchend\"\n\n  let touchcancel = Dom.Event.make \"touchcancel\"\n\n  let dragstart = Dom.Event.make \"dragstart\"\n\n  let dragend = Dom.Event.make \"dragend\"\n\n  let dragenter = Dom.Event.make \"dragenter\"\n\n  let dragover = Dom.Event.make \"dragover\"\n\n  let dragleave = Dom.Event.make \"dragleave\"\n\n  let drag = Dom.Event.make \"drag\"\n\n  let drop = Dom.Event.make \"drop\"\n\n  let hashchange = Dom.Event.make \"hashchange\"\n\n  let change = Dom.Event.make \"change\"\n\n  let input = Dom.Event.make \"input\"\n\n  let timeupdate = Dom.Event.make \"timeupdate\"\n\n  let submit = Dom.Event.make \"submit\"\n\n  let scroll = Dom.Event.make \"scroll\"\n\n  let focus = Dom.Event.make \"focus\"\n\n  let blur = Dom.Event.make \"blur\"\n\n  let load = Dom.Event.make \"load\"\n\n  let unload = Dom.Event.make \"unload\"\n\n  let beforeunload = Dom.Event.make \"beforeunload\"\n\n  let resize = Dom.Event.make \"resize\"\n\n  let orientationchange = Dom.Event.make \"orientationchange\"\n\n  let popstate = Dom.Event.make \"popstate\"\n\n  let error = Dom.Event.make \"error\"\n\n  let abort = Dom.Event.make \"abort\"\n\n  let select = Dom.Event.make \"select\"\n\n  let online = Dom.Event.make \"online\"\n\n  let offline = Dom.Event.make \"offline\"\n\n  let checking = Dom.Event.make \"checking\"\n\n  let noupdate = Dom.Event.make \"noupdate\"\n\n  let downloading = Dom.Event.make \"downloading\"\n\n  let progress = Dom.Event.make \"progress\"\n\n  let updateready = Dom.Event.make \"updateready\"\n\n  let cached = Dom.Event.make \"cached\"\n\n  let obsolete = Dom.Event.make \"obsolete\"\n\n  let domContentLoaded = Dom.Event.make \"DOMContentLoaded\"\n\n  let animationstart = Dom.Event.make \"animationstart\"\n\n  let animationend = Dom.Event.make \"animationend\"\n\n  let animationiteration = Dom.Event.make \"animationiteration\"\n\n  let animationcancel = Dom.Event.make \"animationcancel\"\n\n  let transitionrun = Dom.Event.make \"transitionrun\"\n\n  let transitionstart = Dom.Event.make \"transitionstart\"\n\n  let transitionend = Dom.Event.make \"transitionend\"\n\n  let transitioncancel = Dom.Event.make \"transitioncancel\"\n\n  let canplay = Dom.Event.make \"canplay\"\n\n  let canplaythrough = Dom.Event.make \"canplaythrough\"\n\n  let durationchange = Dom.Event.make \"durationchange\"\n\n  let emptied = Dom.Event.make \"emptied\"\n\n  let ended = Dom.Event.make \"ended\"\n\n  let gotpointercapture = Dom.Event.make \"gotpointercapture\"\n\n  let loadeddata = Dom.Event.make \"loadeddata\"\n\n  let loadedmetadata = Dom.Event.make \"loadedmetadata\"\n\n  let loadstart = Dom.Event.make \"loadstart\"\n\n  let lostpointercapture = Dom.Event.make \"lostpointercapture\"\n\n  let message = Dom.Event.make \"message\"\n\n  let pause = Dom.Event.make \"pause\"\n\n  let play = Dom.Event.make \"play\"\n\n  let playing = Dom.Event.make \"playing\"\n\n  let pointerenter = Dom.Event.make \"pointerenter\"\n\n  let pointercancel = Dom.Event.make \"pointercancel\"\n\n  let pointerdown = Dom.Event.make \"pointerdown\"\n\n  let pointerleave = Dom.Event.make \"pointerleave\"\n\n  let pointermove = Dom.Event.make \"pointermove\"\n\n  let pointerout = Dom.Event.make \"pointerout\"\n\n  let pointerover = Dom.Event.make \"pointerover\"\n\n  let pointerup = Dom.Event.make \"pointerup\"\n\n  let ratechange = Dom.Event.make \"ratechange\"\n\n  let seeked = Dom.Event.make \"seeked\"\n\n  let seeking = Dom.Event.make \"seeking\"\n\n  let stalled = Dom.Event.make \"stalled\"\n\n  let suspend = Dom.Event.make \"suspend\"\n\n  let volumechange = Dom.Event.make \"volumechange\"\n\n  let waiting = Dom.Event.make \"waiting\"\n\n  let make = Dom.Event.make\nend\n\ntype event_listener_id = Dom.event_listener_id\n\nlet addEventListener = Dom.addEventListener\n\nlet addEventListenerWithOptions = Dom.addEventListenerWithOptions\n\nlet removeEventListener = Dom.removeEventListener\n\nlet createCustomEvent = Dom.createCustomEvent\n\nclass type ['node] collection = object\n  method length : int readonly_prop\n\n  method item : int -> 'node t opt meth\n\n  method namedItem : js_string t -> 'node t opt meth\nend\n\nclass type htmlElement = element\n\nclass type headElement = object\n  inherit element\n\n  method profile : js_string t prop\nend\n\nclass type linkElement = object\n  inherit element\n\n  method disabled : bool t prop\n\n  method charset : js_string t prop\n\n  method crossorigin : js_string t prop\n\n  method href : js_string t prop\n\n  method hreflang : js_string t prop\n\n  method media : js_string t prop\n\n  method rel : js_string t prop\n\n  method rev : js_string t prop\n\n  method target : js_string t prop\n\n  method _type : js_string t prop\nend\n\nclass type titleElement = object\n  inherit element\n\n  method text : js_string t prop\nend\n\nclass type metaElement = object\n  inherit element\n\n  method content : js_string t prop\n\n  method httpEquiv : js_string t prop\n\n  method name : js_string t prop\n\n  method scheme : js_string t prop\nend\n\nclass type baseElement = object\n  inherit element\n\n  method href : js_string t prop\n\n  method target : js_string t prop\nend\n\nclass type styleElement = object\n  inherit element\n\n  method disabled : bool t prop\n\n  method media : js_string t prop\n\n  method _type : js_string t prop\nend\n\nclass type bodyElement = element\n\nclass type formElement = object\n  inherit element\n\n  method elements : element collection t readonly_prop\n\n  method length : int readonly_prop\n\n  method acceptCharset : js_string t prop\n\n  method action : js_string t prop\n\n  method enctype : js_string t prop\n\n  method _method : js_string t prop\n\n  method target : js_string t prop\n\n  method submit : unit meth\n\n  method reset : unit meth\n\n  method onsubmit : ('self t, submitEvent t) event_listener writeonly_prop\nend\n\nclass type optGroupElement = object\n  inherit element\n\n  method disabled : bool t prop\n\n  method label : js_string t prop\nend\n\nclass type optionElement = object\n  inherit optGroupElement\n\n  method form : formElement t opt readonly_prop\n\n  method defaultSelected : bool t prop\n\n  method text : js_string t readonly_prop\n\n  method index : int readonly_prop\n\n  method selected : bool t prop\n\n  method value : js_string t prop\nend\n\nclass type selectElement = object ('self)\n  inherit element\n\n  method _type : js_string t readonly_prop\n\n  method selectedIndex : int prop\n\n  method value : js_string t prop\n\n  method length : int prop\n\n  method form : formElement t opt readonly_prop\n\n  method options : optionElement collection t readonly_prop\n\n  method disabled : bool t prop\n\n  method multiple : bool t prop\n\n  method name : js_string t readonly_prop\n\n  method size : int prop\n\n  method tabIndex : int prop\n\n  method add : #optGroupElement t -> #optGroupElement t opt -> unit meth\n\n  method remove : int -> unit meth\n\n  method required : bool t writeonly_prop\n\n  method onchange : ('self t, event t) event_listener prop\n\n  method oninput : ('self t, event t) event_listener prop\nend\n\nclass type inputElement = object ('self)\n  inherit element\n\n  method defaultValue : js_string t prop\n\n  method defaultChecked : js_string t prop\n\n  method form : formElement t opt readonly_prop\n\n  method accept : js_string t prop\n\n  method accessKey : js_string t prop\n\n  method align : js_string t prop\n\n  method alt : js_string t prop\n\n  method checked : bool t prop\n\n  method disabled : bool t prop\n\n  method maxLength : int prop\n\n  method name : js_string t readonly_prop\n\n  method readOnly : bool t prop\n\n  method required : bool t writeonly_prop\n\n  method size : int prop\n\n  method src : js_string t prop\n\n  method tabIndex : int prop\n\n  method _type : js_string t readonly_prop\n\n  method useMap : js_string t prop\n\n  method value : js_string t prop\n\n  method select : unit meth\n\n  method files : File.fileList t optdef readonly_prop\n\n  method placeholder : js_string t writeonly_prop\n\n  method selectionDirection : js_string t prop\n\n  method selectionStart : int prop\n\n  method selectionEnd : int prop\n\n  method onselect : ('self t, event t) event_listener prop\n\n  method onchange : ('self t, event t) event_listener prop\n\n  method oninput : ('self t, event t) event_listener prop\n\n  method onblur : ('self t, focusEvent t) event_listener prop\n\n  method onfocus : ('self t, focusEvent t) event_listener prop\nend\n\nclass type textAreaElement = object ('self)\n  inherit element\n\n  method defaultValue : js_string t prop\n\n  method form : formElement t opt readonly_prop\n\n  method accessKey : js_string t prop\n\n  method cols : int prop\n\n  method disabled : bool t prop\n\n  method name : js_string t readonly_prop\n\n  method readOnly : bool t prop\n\n  method rows : int prop\n\n  method selectionDirection : js_string t prop\n\n  method selectionEnd : int prop\n\n  method selectionStart : int prop\n\n  method tabIndex : int prop\n\n  method _type : js_string t readonly_prop\n\n  method value : js_string t prop\n\n  method select : unit meth\n\n  method required : bool t writeonly_prop\n\n  method placeholder : js_string t writeonly_prop\n\n  method onselect : ('self t, event t) event_listener prop\n\n  method onchange : ('self t, event t) event_listener prop\n\n  method oninput : ('self t, event t) event_listener prop\n\n  method onblur : ('self t, focusEvent t) event_listener prop\n\n  method onfocus : ('self t, focusEvent t) event_listener prop\nend\n\nclass type buttonElement = object\n  inherit element\n\n  method form : formElement t opt readonly_prop\n\n  method accessKey : js_string t prop\n\n  method disabled : bool t prop\n\n  method name : js_string t readonly_prop\n\n  method tabIndex : int prop\n\n  method _type : js_string t readonly_prop\n\n  method value : js_string t prop\nend\n\nclass type labelElement = object\n  inherit element\n\n  method form : formElement t opt readonly_prop\n\n  method accessKey : js_string t prop\n\n  method htmlFor : js_string t prop\nend\n\nclass type fieldSetElement = object\n  inherit element\n\n  method form : formElement t opt readonly_prop\nend\n\nclass type legendElement = object\n  inherit element\n\n  method form : formElement t opt readonly_prop\n\n  method accessKey : js_string t prop\nend\n\nclass type uListElement = element\n\nclass type oListElement = element\n\nclass type dListElement = element\n\nclass type liElement = element\n\nclass type dialogElement = object\n  inherit element\n\n  method close : unit meth\n\n  method close_returnValue : js_string t -> unit meth\n\n  method open_ : bool t prop\n\n  method returnValue : js_string t prop\n\n  method show : unit meth\n\n  method showModal : unit meth\n\n  method oncancel : ('self t, event t) event_listener prop\n\n  method onclose : ('self t, event t) event_listener prop\nend\n\nclass type divElement = element\n\nclass type paragraphElement = element\n\nclass type headingElement = element\n\nclass type quoteElement = object\n  inherit element\n\n  method cite : js_string t prop\nend\n\nclass type preElement = element\n\nclass type brElement = element\n\nclass type hrElement = element\n\nclass type modElement = object\n  inherit element\n\n  method cite : js_string t prop\n\n  method dateTime : js_string t prop\nend\n\nclass type anchorElement = object\n  inherit element\n\n  method accessKey : js_string t prop\n\n  method charset : js_string t prop\n\n  method coords : js_string t prop\n\n  method download : js_string t prop\n\n  method href : js_string t prop\n\n  method hreflang : js_string t prop\n\n  method name : js_string t prop\n\n  method rel : js_string t prop\n\n  method rev : js_string t prop\n\n  method shape : js_string t prop\n\n  method tabIndex : int prop\n\n  method target : js_string t prop\n\n  method _type : js_string t prop\nend\n\nclass type imageElement = object ('self)\n  inherit element\n\n  method alt : js_string t prop\n\n  method src : js_string t prop\n\n  method useMap : js_string t prop\n\n  method isMap : bool t prop\n\n  method width : int prop\n\n  method height : int prop\n\n  method naturalWidth : int optdef readonly_prop\n\n  method naturalHeight : int optdef readonly_prop\n\n  method complete : bool t prop\n\n  method onload : ('self t, event t) event_listener prop\n\n  method onerror : ('self t, event t) event_listener prop\n\n  method onabort : ('self t, event t) event_listener prop\nend\n\nclass type objectElement = object\n  inherit element\n\n  method form : formElement t opt readonly_prop\n\n  method code : js_string t prop\n\n  method archive : js_string t prop\n\n  method codeBase : js_string t prop\n\n  method codeType : js_string t prop\n\n  method data : js_string t prop\n\n  method declare : bool t prop\n\n  method height : js_string t prop\n\n  method name : js_string t prop\n\n  method standby : js_string t prop\n\n  method tabIndex : int prop\n\n  method _type : js_string t prop\n\n  method useMap : js_string t prop\n\n  method width : js_string t prop\n\n  method document : Dom.element Dom.document t opt readonly_prop\nend\n\nclass type paramElement = object\n  inherit element\n\n  method name : js_string t prop\n\n  method _type : js_string t prop\n\n  method value : js_string t prop\n\n  method valueType : js_string t prop\nend\n\nclass type areaElement = object\n  inherit element\n\n  method accessKey : js_string t prop\n\n  method alt : js_string t prop\n\n  method coords : js_string t prop\n\n  method href : js_string t prop\n\n  method noHref : bool t prop\n\n  method shape : js_string t prop\n\n  method tabIndex : int prop\n\n  method target : js_string t prop\nend\n\nclass type mapElement = object\n  inherit element\n\n  method areas : areaElement collection t readonly_prop\n\n  method name : js_string t prop\nend\n\nclass type scriptElement = object\n  inherit element\n\n  method text : js_string t prop\n\n  method charset : js_string t prop\n\n  method defer : bool t prop\n\n  method src : js_string t prop\n\n  method _type : js_string t prop\n\n  method async : bool t prop\nend\n\nclass type embedElement = object\n  inherit element\n\n  method src : js_string t prop\n\n  method height : js_string t prop\n\n  method width : js_string t prop\n\n  method _type : js_string t prop\nend\n\nclass type tableCellElement = object\n  inherit element\n\n  method cellIndex : int readonly_prop\n\n  method abbr : js_string t prop\n\n  method align : js_string t prop\n\n  method axis : js_string t prop\n\n  method ch : js_string t prop\n\n  method chOff : js_string t prop\n\n  method colSpan : int prop\n\n  method headers : js_string t prop\n\n  method rowSpan : int prop\n\n  method scope : js_string t prop\n\n  method vAlign : js_string t prop\nend\n\nclass type tableRowElement = object\n  inherit element\n\n  method rowIndex : int readonly_prop\n\n  method sectionRowIndex : int readonly_prop\n\n  method cells : tableCellElement collection t readonly_prop\n\n  method align : js_string t prop\n\n  method ch : js_string t prop\n\n  method chOff : js_string t prop\n\n  method vAlign : js_string t prop\n\n  method insertCell : int -> tableCellElement t meth\n\n  method deleteCell : int -> unit meth\nend\n\nclass type tableColElement = object\n  inherit element\n\n  method align : js_string t prop\n\n  method ch : js_string t prop\n\n  method chOff : js_string t prop\n\n  method span : int prop\n\n  method vAlign : js_string t prop\n\n  method width : js_string t prop\nend\n\nclass type tableSectionElement = object\n  inherit element\n\n  method align : js_string t prop\n\n  method ch : js_string t prop\n\n  method chOff : js_string t prop\n\n  method vAlign : js_string t prop\n\n  method rows : tableRowElement collection t readonly_prop\n\n  method insertRow : int -> tableRowElement t meth\n\n  method deleteRow : int -> unit meth\nend\n\nclass type tableCaptionElement = element\n\nclass type tableElement = object\n  inherit element\n\n  method caption : tableCaptionElement t prop\n\n  method tHead : tableSectionElement t prop\n\n  method tFoot : tableSectionElement t prop\n\n  method rows : tableRowElement collection t readonly_prop\n\n  method tBodies : tableSectionElement collection t readonly_prop\n\n  method align : js_string t prop\n\n  method border : js_string t prop\n\n  method cellPadding : js_string t prop\n\n  method cellSpacing : js_string t prop\n\n  method frame : js_string t prop\n\n  method rules : js_string t prop\n\n  method summary : js_string t prop\n\n  method width : js_string t prop\n\n  method createTHead : tableSectionElement t meth\n\n  method deleteTHead : unit meth\n\n  method createTFoot : tableSectionElement t meth\n\n  method deleteTFoot : unit meth\n\n  method createCaption : tableCaptionElement t meth\n\n  method deleteCaption : unit meth\n\n  method insertRow : int -> tableRowElement t meth\n\n  method deleteRow : int -> unit meth\nend\n\nclass type timeRanges = object\n  method length : int readonly_prop\n\n  method start : int -> number_t meth\n\n  method end_ : int -> number_t meth\nend\n\ntype networkState =\n  | NETWORK_EMPTY\n  | NETWORK_IDLE\n  | NETWORK_LOADING\n  | NETWORK_NO_SOURCE\n\ntype readyState =\n  | HAVE_NOTHING\n  | HAVE_METADATA\n  | HAVE_CURRENT_DATA\n  | HAVE_FUTURE_DATA\n  | HAVE_ENOUGH_DATA\n\n(* http://www.w3schools.com/tags/ref_av_dom.asp *)\n(* only features supported by all browser. (IE9+) *)\nclass type mediaElement = object\n  inherit element\n\n  method canPlayType : js_string t -> js_string t meth\n\n  method load : unit meth\n\n  method play : unit meth\n\n  method pause : unit meth\n\n  method autoplay : bool t prop\n\n  method buffered : timeRanges t readonly_prop\n\n  method controls : bool t prop\n\n  method currentSrc : js_string t readonly_prop\n\n  method currentTime : number_t prop\n\n  method duration : number_t readonly_prop\n\n  method ended : bool t readonly_prop\n\n  method loop : bool t prop\n\n  method mediagroup : js_string t prop\n\n  method muted : bool t prop\n\n  method networkState_int : int readonly_prop\n\n  method networkState : networkState readonly_prop\n\n  method paused : bool t readonly_prop\n\n  method playbackRate : number_t prop\n\n  method played : timeRanges t readonly_prop\n\n  method preload : js_string t prop\n\n  method readyState_int : int readonly_prop\n\n  method readyState : readyState readonly_prop\n\n  method seekable : timeRanges t readonly_prop\n\n  method seeking : bool t readonly_prop\n\n  method src : js_string t prop\n\n  method volume : number_t prop\n\n  method oncanplay : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method oncanplaythrough : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method ondurationchange : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method onemptied : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method onended : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method onloadeddata : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method onloadedmetadata : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method onloadstart : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method onpause : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method onplay : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method onplaying : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method onratechange : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method onseeked : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method onseeking : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method onstalled : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method onsuspend : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method onvolumechange : ('self t, mediaEvent t) event_listener writeonly_prop\n\n  method onwaiting : ('self t, mediaEvent t) event_listener writeonly_prop\nend\n\nclass type audioElement = object\n  inherit mediaElement\nend\n\nclass type videoElement = object\n  inherit mediaElement\nend\n\ntype context = js_string t\n\nlet _2d_ = Js.string \"2d\"\n\ntype canvasPattern\n\nclass type canvasElement = object\n  inherit element\n\n  method width : int prop\n\n  method height : int prop\n\n  method toDataURL : js_string t meth\n\n  method toDataURL_type : js_string t -> js_string t meth\n\n  method toDataURL_type_compression : js_string t -> number_t -> js_string t meth\n\n  method getContext : js_string t -> canvasRenderingContext2D t meth\nend\n\nand canvasRenderingContext2D = object\n  method canvas : canvasElement t readonly_prop\n\n  method save : unit meth\n\n  method restore : unit meth\n\n  method scale : number_t -> number_t -> unit meth\n\n  method rotate : number_t -> unit meth\n\n  method translate : number_t -> number_t -> unit meth\n\n  method transform :\n    number_t -> number_t -> number_t -> number_t -> number_t -> number_t -> unit meth\n\n  method setTransform :\n    number_t -> number_t -> number_t -> number_t -> number_t -> number_t -> unit meth\n\n  method globalAlpha : number_t prop\n\n  method globalCompositeOperation : js_string t prop\n\n  method strokeStyle : js_string t writeonly_prop\n\n  method strokeStyle_gradient : canvasGradient t writeonly_prop\n\n  method strokeStyle_pattern : canvasPattern t writeonly_prop\n\n  method fillStyle : js_string t writeonly_prop\n\n  method fillStyle_gradient : canvasGradient t writeonly_prop\n\n  method fillStyle_pattern : canvasPattern t writeonly_prop\n\n  method createLinearGradient :\n    number_t -> number_t -> number_t -> number_t -> canvasGradient t meth\n\n  method createRadialGradient :\n       number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> canvasGradient t meth\n\n  method createPattern : imageElement t -> js_string t -> canvasPattern t meth\n\n  method createPattern_fromCanvas : canvasElement t -> js_string t -> canvasPattern t meth\n\n  method createPattern_fromVideo : videoElement t -> js_string t -> canvasPattern t meth\n\n  method lineWidth : number_t prop\n\n  method lineCap : js_string t prop\n\n  method lineJoin : js_string t prop\n\n  method miterLimit : number_t prop\n\n  method shadowOffsetX : number_t prop\n\n  method shadowOffsetY : number_t prop\n\n  method shadowBlur : number_t prop\n\n  method shadowColor : js_string t prop\n\n  method clearRect : number_t -> number_t -> number_t -> number_t -> unit meth\n\n  method fillRect : number_t -> number_t -> number_t -> number_t -> unit meth\n\n  method strokeRect : number_t -> number_t -> number_t -> number_t -> unit meth\n\n  method beginPath : unit meth\n\n  method closePath : unit meth\n\n  method moveTo : number_t -> number_t -> unit meth\n\n  method lineTo : number_t -> number_t -> unit meth\n\n  method quadraticCurveTo : number_t -> number_t -> number_t -> number_t -> unit meth\n\n  method bezierCurveTo :\n    number_t -> number_t -> number_t -> number_t -> number_t -> number_t -> unit meth\n\n  method arcTo : number_t -> number_t -> number_t -> number_t -> number_t -> unit meth\n\n  method rect : number_t -> number_t -> number_t -> number_t -> unit meth\n\n  method arc :\n    number_t -> number_t -> number_t -> number_t -> number_t -> bool t -> unit meth\n\n  method ellipse :\n       number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> bool t\n    -> unit meth\n\n  method fill : unit meth\n\n  method stroke : unit meth\n\n  method clip : unit meth\n\n  method isPointInPath : number_t -> number_t -> bool t meth\n\n  method drawFocusRing : #element t -> number_t -> number_t -> bool t -> bool t meth\n\n  method font : js_string t prop\n\n  method textAlign : js_string t prop\n\n  method textBaseline : js_string t prop\n\n  method fillText : js_string t -> number_t -> number_t -> unit meth\n\n  method fillText_withWidth : js_string t -> number_t -> number_t -> number_t -> unit meth\n\n  method strokeText : js_string t -> number_t -> number_t -> unit meth\n\n  method strokeText_withWidth :\n    js_string t -> number_t -> number_t -> number_t -> unit meth\n\n  method measureText : js_string t -> textMetrics t meth\n\n  method drawImage : imageElement t -> number_t -> number_t -> unit meth\n\n  method drawImage_withSize :\n    imageElement t -> number_t -> number_t -> number_t -> number_t -> unit meth\n\n  method drawImage_full :\n       imageElement t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> unit meth\n\n  method drawImage_fromCanvas : canvasElement t -> number_t -> number_t -> unit meth\n\n  method drawImage_fromCanvasWithSize :\n    canvasElement t -> number_t -> number_t -> number_t -> number_t -> unit meth\n\n  method drawImage_fullFromCanvas :\n       canvasElement t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> unit meth\n\n  method drawImage_fromVideoWithVideo :\n    videoElement t -> number_t -> number_t -> unit meth\n\n  method drawImage_fromVideoWithSize :\n    videoElement t -> number_t -> number_t -> number_t -> number_t -> unit meth\n\n  method drawImage_fullFromVideo :\n       videoElement t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> unit meth\n\n  method createImageData : int -> int -> imageData t meth\n\n  method getImageData : number_t -> number_t -> number_t -> number_t -> imageData t meth\n\n  method putImageData : imageData t -> number_t -> number_t -> unit meth\nend\n\nand canvasGradient = object\n  method addColorStop : number_t -> js_string t -> unit meth\nend\n\nand textMetrics = object\n  method width : number_t readonly_prop\nend\n\nand imageData = object\n  method width : int readonly_prop\n\n  method height : int readonly_prop\n\n  method data : canvasPixelArray t readonly_prop\nend\n\nand canvasPixelArray = object\n  method length : int readonly_prop\nend\n\nexternal pixel_get : canvasPixelArray t -> int -> int = \"caml_js_get\"\n\nexternal pixel_set : canvasPixelArray t -> int -> int -> unit = \"caml_js_set\"\n\nclass type range = object\n  method collapsed : bool t readonly_prop\n\n  method startOffset : int readonly_prop\n\n  method endOffset : int readonly_prop\n\n  method startContainer : Dom.node t readonly_prop\n\n  method endContainer : Dom.node t readonly_prop\n\n  method setStart : Dom.node t -> int -> unit meth\n\n  method setEnd : Dom.node t -> int -> unit meth\n\n  method setStartBefore : Dom.node t -> unit meth\n\n  method setEndBefore : Dom.node t -> unit meth\n\n  method setStartAfter : Dom.node t -> unit meth\n\n  method setEndAfter : Dom.node t -> unit meth\n\n  method selectNode : Dom.node t -> unit meth\n\n  method selectNodeContents : Dom.node t -> unit meth\n\n  method collapse : bool t -> unit meth\n\n  method cloneContents : Dom.documentFragment t meth\n\n  method extractContents : Dom.documentFragment t meth\n\n  method deleteContents : unit meth\n\n  method insertNode : Dom.node t -> unit meth\n\n  method surroundContents : Dom.node t -> unit meth\n\n  method cloneRange : range t meth\n\n  method toString : js_string t meth\nend\n\n(** Information on current selection *)\nclass type selection = object\n  method anchorNode : Dom.node t readonly_prop\n\n  method anchorOffset : int readonly_prop\n\n  method focusNode : Dom.node t readonly_prop\n\n  method focusOffset : int readonly_prop\n\n  method isCollapsed : bool t readonly_prop\n\n  method rangeCount : int readonly_prop\n\n  method getRangeAt : int -> range t meth\n\n  method collapse : bool t -> unit meth\n\n  method extend : Dom.node t -> int -> unit meth\n\n  method modify : js_string t -> js_string t -> js_string t -> unit meth\n\n  method collapseToStart : unit meth\n\n  method collapseToEnd : unit meth\n\n  method selectAllChildren : Dom.node t -> unit meth\n\n  method addRange : range t -> unit meth\n\n  method removeRange : range t -> unit meth\n\n  method removeAllRanges : unit meth\n\n  method deleteFromDocument : unit meth\n\n  method containsNode : Dom.node t -> bool t -> bool t meth\n\n  method toString : js_string t meth\nend\n\nclass type document = object\n  inherit [element] Dom.document\n\n  inherit nodeSelector\n\n  inherit eventTarget\n\n  method title : js_string t prop\n\n  method referrer : js_string t readonly_prop\n\n  method domain : js_string t prop\n\n  method _URL : js_string t readonly_prop\n\n  method head : headElement t prop\n\n  method body : bodyElement t prop\n\n  method documentElement : htmlElement t readonly_prop\n\n  method images : imageElement collection t readonly_prop\n\n  method applets : element collection t readonly_prop\n\n  method links : element collection t readonly_prop\n\n  method forms : formElement collection t readonly_prop\n\n  method anchors : element collection t readonly_prop\n\n  method cookie : js_string t prop\n\n  method designMode : js_string t prop\n\n  method open_ : unit meth\n\n  method close : unit meth\n\n  method write : js_string t -> unit meth\n\n  method execCommand : js_string t -> bool t -> js_string t opt -> unit meth\n\n  method createRange : range t meth\n\n  method readyState : js_string t readonly_prop\n\n  method getElementsByClassName : js_string t -> element Dom.nodeList t meth\n\n  method getElementsByName : js_string t -> element Dom.nodeList t meth\n\n  method activeElement : element t opt readonly_prop\n\n  method hidden : bool t readonly_prop\n\n  method onfullscreenchange : (document t, event t) event_listener writeonly_prop\n\n  method onwebkitfullscreenchange : (document t, event t) event_listener writeonly_prop\n\n  inherit eventTarget\nend\n\ntype interval_id\n\ntype timeout_id\n\ntype animation_frame_request_id\n\nclass type location = object\n  method href : js_string t prop\n\n  method protocol : js_string t prop\n\n  method host : js_string t prop\n\n  method hostname : js_string t prop\n\n  method origin : js_string t optdef readonly_prop\n\n  method port : js_string t prop\n\n  method pathname : js_string t prop\n\n  method search : js_string t prop\n\n  method hash : js_string t prop\n\n  method assign : js_string t -> unit meth\n\n  method replace : js_string t -> unit meth\n\n  method reload : unit meth\nend\n\nlet location_origin (loc : location t) =\n  Optdef.case\n    loc##.origin\n    (fun () ->\n      let protocol = loc##.protocol in\n      let hostname = loc##.hostname in\n      let port = loc##.port in\n      if protocol##.length = 0 && hostname##.length = 0\n      then Js.string \"\"\n      else\n        let origin = protocol##concat_2 (Js.string \"//\") hostname in\n        if port##.length > 0 then origin##concat_2 (Js.string \":\") loc##.port else origin)\n    (fun o -> o)\n\nclass type history = object\n  method length : int readonly_prop\n\n  method state : Js.Unsafe.any readonly_prop\n\n  method go : int opt -> unit meth\n\n  method back : unit meth\n\n  method forward : unit meth\n\n  method pushState : 'a. 'a -> js_string t -> js_string t opt -> unit meth\n\n  method replaceState : 'a. 'a -> js_string t -> js_string t opt -> unit meth\nend\n\nclass type undoManager = object end\n\nclass type navigator = object\n  method appCodeName : js_string t readonly_prop\n\n  method appName : js_string t readonly_prop\n\n  method appVersion : js_string t readonly_prop\n\n  method cookieEnabled : bool t readonly_prop\n\n  method onLine : bool t readonly_prop\n\n  method platform : js_string t readonly_prop\n\n  method vendor : js_string t readonly_prop\n\n  method userAgent : js_string t readonly_prop\n\n  method language : js_string t optdef readonly_prop\n\n  method userLanguage : js_string t optdef readonly_prop\n\n  method maxTouchPoints : int readonly_prop\nend\n\nclass type screen = object\n  method width : int readonly_prop\n\n  method height : int readonly_prop\n\n  method availWidth : int readonly_prop\n\n  method availHeight : int readonly_prop\nend\n\nclass type applicationCache = object\n  method status : int readonly_prop\n\n  method update : unit meth\n\n  method abort : unit meth\n\n  method swapCache : unit meth\n\n  method onchecking : (applicationCache t, event t) event_listener prop\n\n  method onerror : (applicationCache t, event t) event_listener prop\n\n  method onnoupdate : (applicationCache t, event t) event_listener prop\n\n  method ondownloading : (applicationCache t, event t) event_listener prop\n\n  method onprogress : (applicationCache t, event t) event_listener prop\n\n  method onupdateready : (applicationCache t, event t) event_listener prop\n\n  method oncached : (applicationCache t, event t) event_listener prop\n\n  method onobsolete : (applicationCache t, event t) event_listener prop\n\n  inherit eventTarget\nend\n\nclass type _URL = object\n  method createObjectURL : #File.blob t -> js_string t meth\n\n  method revokeObjectURL : js_string t -> unit meth\nend\n\nclass type window = object\n  inherit eventTarget\n\n  method document : document t readonly_prop\n\n  method applicationCache : applicationCache t readonly_prop\n\n  method name : js_string t prop\n\n  method location : location t readonly_prop\n\n  method history : history t readonly_prop\n\n  method undoManager : undoManager t readonly_prop\n\n  method navigator : navigator t readonly_prop\n\n  method getSelection : selection t meth\n\n  method close : unit meth\n\n  method closed : bool t readonly_prop\n\n  method stop : unit meth\n\n  method focus : unit meth\n\n  method blur : unit meth\n\n  method scroll : int -> int -> unit meth\n\n  method scrollBy : int -> int -> unit meth\n\n  method sessionStorage : storage t optdef readonly_prop\n\n  method localStorage : storage t optdef readonly_prop\n\n  method top : window t readonly_prop\n\n  method parent : window t readonly_prop\n\n  method frameElement : element t opt readonly_prop\n\n  method open_ : js_string t -> js_string t -> js_string t opt -> window t opt meth\n\n  method alert : js_string t -> unit meth\n\n  method confirm : js_string t -> bool t meth\n\n  method prompt : js_string t -> js_string t -> js_string t opt meth\n\n  method print : unit meth\n\n  method setInterval : (unit -> unit) Js.callback -> number_t -> interval_id meth\n\n  method clearInterval : interval_id -> unit meth\n\n  method setTimeout : (unit -> unit) Js.callback -> number_t -> timeout_id meth\n\n  method clearTimeout : timeout_id -> unit meth\n\n  method requestAnimationFrame :\n    (number_t -> unit) Js.callback -> animation_frame_request_id meth\n\n  method cancelAnimationFrame : animation_frame_request_id -> unit meth\n\n  method screen : screen t readonly_prop\n\n  method innerWidth : int readonly_prop\n\n  method innerHeight : int readonly_prop\n\n  method outerWidth : int readonly_prop\n\n  method outerHeight : int readonly_prop\n\n  method getComputedStyle : #element t -> cssStyleDeclaration t meth\n\n  method getComputedStyle_pseudoElt :\n    #element t -> js_string t -> cssStyleDeclaration t meth\n\n  method atob : js_string t -> js_string t meth\n\n  method btoa : js_string t -> js_string t meth\n\n  method onload : (window t, event t) event_listener prop\n\n  method onunload : (window t, event t) event_listener prop\n\n  method onbeforeunload : (window t, event t) event_listener prop\n\n  method onblur : (window t, focusEvent t) event_listener prop\n\n  method onfocus : (window t, focusEvent t) event_listener prop\n\n  method onresize : (window t, event t) event_listener prop\n\n  method onorientationchange : (window t, event t) event_listener prop\n\n  method onpopstate : (window t, popStateEvent t) event_listener prop\n\n  method onhashchange : (window t, hashChangeEvent t) event_listener prop\n\n  method ononline : (window t, event t) event_listener writeonly_prop\n\n  method onoffline : (window t, event t) event_listener writeonly_prop\n\n  method _URL : _URL t readonly_prop\n\n  method devicePixelRatio : number_t readonly_prop\nend\n\nlet window : window t = Js.Unsafe.global\n\n(* The toplevel object *)\n\nlet document = window##.document\n\nlet getElementById id =\n  Js.Opt.case\n    (document##getElementById (Js.string id))\n    (fun () -> raise Not_found)\n    (fun pnode -> pnode)\n\nlet getElementById_exn id =\n  Js.Opt.case\n    (document##getElementById (Js.string id))\n    (fun () -> failwith (Printf.sprintf \"getElementById_exn: %S not found\" id))\n    (fun pnode -> pnode)\n\nlet getElementById_opt id = Js.Opt.to_option (document##getElementById (Js.string id))\n\nlet getElementById_coerce id coerce =\n  Js.Opt.case\n    (document##getElementById (Js.string id))\n    (fun () -> None)\n    (fun e -> Js.Opt.to_option (coerce e))\n\n(****)\n\nclass type frameSetElement = object\n  inherit element\n\n  method cols : js_string t prop\n\n  method rows : js_string t prop\nend\n\nclass type frameElement = object\n  inherit element\n\n  method frameBorder : js_string t prop\n\n  method longDesc : js_string t prop\n\n  method marginHeight : js_string t prop\n\n  method marginWidth : js_string t prop\n\n  method name : js_string t prop\n\n  method noResize : bool t prop\n\n  method scrolling : js_string t prop\n\n  method src : js_string t prop\n\n  method contentDocument : document t opt readonly_prop\nend\n\nclass type iFrameElement = object\n  inherit element\n\n  method frameBorder : js_string t prop\n\n  method height : js_string t prop\n\n  method width : js_string t prop\n\n  method longDesc : js_string t prop\n\n  method marginHeight : js_string t prop\n\n  method marginWidth : js_string t prop\n\n  method name : js_string t prop\n\n  method scrolling : js_string t prop\n\n  method src : js_string t prop\n\n  method contentDocument : document t opt readonly_prop\n\n  method contentWindow : window t readonly_prop\nend\n\n(****)\n\n(*XXX Should provide creation functions a la lablgtk... *)\n\nlet opt_iter x f =\n  match x with\n  | None -> ()\n  | Some v -> f v\n\nlet createElement (doc : document t) name = doc##createElement (Js.string name)\n\nlet unsafeCreateElement doc name = Js.Unsafe.coerce (createElement doc name)\n\nlet createElementSyntax = ref `Unknown\n\nlet rec unsafeCreateElementEx ?_type ?name doc elt =\n  if Poly.(_type = None) && Poly.(name = None)\n  then Js.Unsafe.coerce (createElement doc elt)\n  else\n    match !createElementSyntax with\n    | `Standard ->\n        let res = Js.Unsafe.coerce (createElement doc elt) in\n        opt_iter _type (fun t -> res##._type := t);\n        opt_iter name (fun n -> res##.name := n);\n        res\n    | `Extended ->\n        let a = new%js Js.array_empty in\n        ignore (a##push_2 (Js.string \"<\") (Js.string elt));\n        opt_iter _type (fun t ->\n            ignore (a##push_3 (Js.string \" type=\\\"\") (html_escape t) (Js.string \"\\\"\")));\n        opt_iter name (fun n ->\n            ignore (a##push_3 (Js.string \" name=\\\"\") (html_escape n) (Js.string \"\\\"\")));\n        ignore (a##push (Js.string \">\"));\n        Js.Unsafe.coerce (doc##createElement (a##join (Js.string \"\")))\n    | `Unknown ->\n        createElementSyntax :=\n          if try\n               let el : inputElement Js.t =\n                 Js.Unsafe.coerce\n                   (document##createElement (Js.string \"<input name=\\\"x\\\">\"))\n               in\n               Js.equals el##.tagName##toLowerCase (Js.string \"input\")\n               && Js.equals el##.name (Js.string \"x\")\n             with _ -> false\n          then `Extended\n          else `Standard;\n        unsafeCreateElementEx ?_type ?name doc elt\n\nlet createHtml doc : htmlElement t = unsafeCreateElement doc \"html\"\n\nlet createHead doc : headElement t = unsafeCreateElement doc \"head\"\n\nlet createLink doc : linkElement t = unsafeCreateElement doc \"link\"\n\nlet createTitle doc : titleElement t = unsafeCreateElement doc \"title\"\n\nlet createMeta doc : metaElement t = unsafeCreateElement doc \"meta\"\n\nlet createBase doc : baseElement t = unsafeCreateElement doc \"base\"\n\nlet createStyle doc : styleElement t = unsafeCreateElement doc \"style\"\n\nlet createBody doc : bodyElement t = unsafeCreateElement doc \"body\"\n\nlet createForm doc : formElement t = unsafeCreateElement doc \"form\"\n\nlet createOptgroup doc : optGroupElement t = unsafeCreateElement doc \"optgroup\"\n\nlet createOption doc : optionElement t = unsafeCreateElement doc \"option\"\n\nlet createSelect ?_type ?name doc : selectElement t =\n  unsafeCreateElementEx ?_type ?name doc \"select\"\n\nlet createInput ?_type ?name doc : inputElement t =\n  unsafeCreateElementEx ?_type ?name doc \"input\"\n\nlet createTextarea ?_type ?name doc : textAreaElement t =\n  unsafeCreateElementEx ?_type ?name doc \"textarea\"\n\nlet createButton ?_type ?name doc : buttonElement t =\n  unsafeCreateElementEx ?_type ?name doc \"button\"\n\nlet createLabel doc : labelElement t = unsafeCreateElement doc \"label\"\n\nlet createFieldset doc : fieldSetElement t = unsafeCreateElement doc \"fieldset\"\n\nlet createLegend doc : legendElement t = unsafeCreateElement doc \"legend\"\n\nlet createUl doc : uListElement t = unsafeCreateElement doc \"ul\"\n\nlet createOl doc : oListElement t = unsafeCreateElement doc \"ol\"\n\nlet createDl doc : dListElement t = unsafeCreateElement doc \"dl\"\n\nlet createLi doc : liElement t = unsafeCreateElement doc \"li\"\n\nlet createDialog doc : dialogElement t = unsafeCreateElement doc \"dialog\"\n\nlet createDiv doc : divElement t = unsafeCreateElement doc \"div\"\n\nlet createEmbed doc : embedElement t = unsafeCreateElement doc \"embed\"\n\nlet createP doc : paragraphElement t = unsafeCreateElement doc \"p\"\n\nlet createH1 doc : headingElement t = unsafeCreateElement doc \"h1\"\n\nlet createH2 doc : headingElement t = unsafeCreateElement doc \"h2\"\n\nlet createH3 doc : headingElement t = unsafeCreateElement doc \"h3\"\n\nlet createH4 doc : headingElement t = unsafeCreateElement doc \"h4\"\n\nlet createH5 doc : headingElement t = unsafeCreateElement doc \"h5\"\n\nlet createH6 doc : headingElement t = unsafeCreateElement doc \"h6\"\n\nlet createQ doc : quoteElement t = unsafeCreateElement doc \"q\"\n\nlet createBlockquote doc : quoteElement t = unsafeCreateElement doc \"blockquote\"\n\nlet createPre doc : preElement t = unsafeCreateElement doc \"pre\"\n\nlet createBr doc : brElement t = unsafeCreateElement doc \"br\"\n\nlet createHr doc : hrElement t = unsafeCreateElement doc \"hr\"\n\nlet createIns doc : modElement t = unsafeCreateElement doc \"ins\"\n\nlet createDel doc : modElement t = unsafeCreateElement doc \"del\"\n\nlet createA doc : anchorElement t = unsafeCreateElement doc \"a\"\n\nlet createImg doc : imageElement t = unsafeCreateElement doc \"img\"\n\nlet createObject doc : objectElement t = unsafeCreateElement doc \"object\"\n\nlet createParam doc : paramElement t = unsafeCreateElement doc \"param\"\n\nlet createMap doc : mapElement t = unsafeCreateElement doc \"map\"\n\nlet createArea doc : areaElement t = unsafeCreateElement doc \"area\"\n\nlet createScript doc : scriptElement t = unsafeCreateElement doc \"script\"\n\nlet createTable doc : tableElement t = unsafeCreateElement doc \"table\"\n\nlet createCaption doc : tableCaptionElement t = unsafeCreateElement doc \"caption\"\n\nlet createCol doc : tableColElement t = unsafeCreateElement doc \"col\"\n\nlet createColgroup doc : tableColElement t = unsafeCreateElement doc \"colgroup\"\n\nlet createThead doc : tableSectionElement t = unsafeCreateElement doc \"thead\"\n\nlet createTfoot doc : tableSectionElement t = unsafeCreateElement doc \"tfoot\"\n\nlet createTbody doc : tableSectionElement t = unsafeCreateElement doc \"tbody\"\n\nlet createTr doc : tableRowElement t = unsafeCreateElement doc \"tr\"\n\nlet createTh doc : tableCellElement t = unsafeCreateElement doc \"th\"\n\nlet createTd doc : tableCellElement t = unsafeCreateElement doc \"td\"\n\nlet createSub doc = createElement doc \"sub\"\n\nlet createSup doc = createElement doc \"sup\"\n\nlet createSpan doc = createElement doc \"span\"\n\nlet createTt doc = createElement doc \"tt\"\n\nlet createI doc = createElement doc \"i\"\n\nlet createB doc = createElement doc \"b\"\n\nlet createBig doc = createElement doc \"big\"\n\nlet createSmall doc = createElement doc \"small\"\n\nlet createEm doc = createElement doc \"em\"\n\nlet createStrong doc = createElement doc \"strong\"\n\nlet createCite doc = createElement doc \"cite\"\n\nlet createDfn doc = createElement doc \"dfn\"\n\nlet createCode doc = createElement doc \"code\"\n\nlet createSamp doc = createElement doc \"samp\"\n\nlet createKbd doc = createElement doc \"kbd\"\n\nlet createVar doc = createElement doc \"var\"\n\nlet createAbbr doc = createElement doc \"abbr\"\n\nlet createDd doc = createElement doc \"dd\"\n\nlet createDt doc = createElement doc \"dt\"\n\nlet createNoscript doc = createElement doc \"noscript\"\n\nlet createAddress doc = createElement doc \"address\"\n\nlet createFrameset doc : frameSetElement t = unsafeCreateElement doc \"frameset\"\n\nlet createFrame doc : frameElement t = unsafeCreateElement doc \"frame\"\n\nlet createIframe doc : iFrameElement t = unsafeCreateElement doc \"iframe\"\n\nlet createAudio doc : audioElement t = unsafeCreateElement doc \"audio\"\n\nlet createVideo doc : audioElement t = unsafeCreateElement doc \"video\"\n\nexception Canvas_not_available\n\nlet createCanvas doc : canvasElement t =\n  let c = unsafeCreateElement doc \"canvas\" in\n  if not (Opt.test c##.getContext) then raise Canvas_not_available;\n  c\n\nlet html_element : htmlElement t constr = Js.Unsafe.global##._HTMLElement\n\nmodule CoerceTo = struct\n  let element : #Dom.node Js.t -> element Js.t Js.opt =\n    if not (Js.Optdef.test (def html_element))\n    then\n      (* ie < 9 does not have HTMLElement: we have to cheat to check\n         that something is an html element *)\n      fun e ->\n      if not (Js.Optdef.test (def (Js.Unsafe.coerce e)##.innerHTML))\n      then Js.null\n      else Js.some (Js.Unsafe.coerce e)\n    else\n      fun e ->\n      if Js.instanceof e html_element then Js.some (Js.Unsafe.coerce e) else Js.null\n\n  let unsafeCoerce tag (e : #element t) =\n    if Js.equals e##.tagName##toLowerCase (Js.string tag)\n    then Js.some (Js.Unsafe.coerce e)\n    else Js.null\n\n  let a e = unsafeCoerce \"a\" e\n\n  let area e = unsafeCoerce \"area\" e\n\n  let base e = unsafeCoerce \"base\" e\n\n  let blockquote e = unsafeCoerce \"blockquote\" e\n\n  let body e = unsafeCoerce \"body\" e\n\n  let br e = unsafeCoerce \"br\" e\n\n  let button e = unsafeCoerce \"button\" e\n\n  let canvas e = unsafeCoerce \"canvas\" e\n\n  let caption e = unsafeCoerce \"caption\" e\n\n  let col e = unsafeCoerce \"col\" e\n\n  let colgroup e = unsafeCoerce \"colgroup\" e\n\n  let del e = unsafeCoerce \"del\" e\n\n  let div e = unsafeCoerce \"div\" e\n\n  let dl e = unsafeCoerce \"dl\" e\n\n  let fieldset e = unsafeCoerce \"fieldset\" e\n\n  let embed e = unsafeCoerce \"embed\" e\n\n  let form e = unsafeCoerce \"form\" e\n\n  let frameset e = unsafeCoerce \"frameset\" e\n\n  let frame e = unsafeCoerce \"frame\" e\n\n  let h1 e = unsafeCoerce \"h1\" e\n\n  let h2 e = unsafeCoerce \"h2\" e\n\n  let h3 e = unsafeCoerce \"h3\" e\n\n  let h4 e = unsafeCoerce \"h4\" e\n\n  let h5 e = unsafeCoerce \"h5\" e\n\n  let h6 e = unsafeCoerce \"h6\" e\n\n  let head e = unsafeCoerce \"head\" e\n\n  let hr e = unsafeCoerce \"hr\" e\n\n  let html e = unsafeCoerce \"html\" e\n\n  let iframe e = unsafeCoerce \"iframe\" e\n\n  let img e = unsafeCoerce \"img\" e\n\n  let input e = unsafeCoerce \"input\" e\n\n  let ins e = unsafeCoerce \"ins\" e\n\n  let label e = unsafeCoerce \"label\" e\n\n  let legend e = unsafeCoerce \"legend\" e\n\n  let li e = unsafeCoerce \"li\" e\n\n  let link e = unsafeCoerce \"link\" e\n\n  let map e = unsafeCoerce \"map\" e\n\n  let meta e = unsafeCoerce \"meta\" e\n\n  let _object e = unsafeCoerce \"object\" e\n\n  let ol e = unsafeCoerce \"ol\" e\n\n  let optgroup e = unsafeCoerce \"optgroup\" e\n\n  let option e = unsafeCoerce \"option\" e\n\n  let p e = unsafeCoerce \"p\" e\n\n  let param e = unsafeCoerce \"param\" e\n\n  let pre e = unsafeCoerce \"pre\" e\n\n  let q e = unsafeCoerce \"q\" e\n\n  let script e = unsafeCoerce \"script\" e\n\n  let select e = unsafeCoerce \"select\" e\n\n  let style e = unsafeCoerce \"style\" e\n\n  let table e = unsafeCoerce \"table\" e\n\n  let tbody e = unsafeCoerce \"tbody\" e\n\n  let td e = unsafeCoerce \"td\" e\n\n  let textarea e = unsafeCoerce \"textarea\" e\n\n  let tfoot e = unsafeCoerce \"tfoot\" e\n\n  let th e = unsafeCoerce \"th\" e\n\n  let thead e = unsafeCoerce \"thead\" e\n\n  let title e = unsafeCoerce \"title\" e\n\n  let tr e = unsafeCoerce \"tr\" e\n\n  let ul e = unsafeCoerce \"ul\" e\n\n  let audio e = unsafeCoerce \"audio\" e\n\n  let video e = unsafeCoerce \"video\" e\n\n  let unsafeCoerceEvent constr (ev : #event t) =\n    if Js.Optdef.test (def constr) && Js.instanceof ev constr\n    then Js.some (Js.Unsafe.coerce ev)\n    else Js.null\n\n  let mouseEvent ev = unsafeCoerceEvent Js.Unsafe.global##._MouseEvent ev\n\n  let keyboardEvent ev = unsafeCoerceEvent Js.Unsafe.global##._KeyboardEvent ev\n\n  let wheelEvent ev = unsafeCoerceEvent Js.Unsafe.global##._WheelEvent ev\n\n  let mouseScrollEvent ev = unsafeCoerceEvent Js.Unsafe.global##._MouseScrollEvent ev\n\n  let popStateEvent ev = unsafeCoerceEvent Js.Unsafe.global##._PopStateEvent ev\n\n  let messageEvent ev = unsafeCoerceEvent Js.Unsafe.global##._MessageEvent ev\nend\n\n(****)\n\nlet eventTarget = Dom.eventTarget\n\nlet eventRelatedTarget (e : #mouseEvent t) =\n  Optdef.get e##.relatedTarget (fun () ->\n      match Js.to_string e##._type with\n      | \"mouseover\" -> Optdef.get e##.fromElement (fun () -> assert false)\n      | \"mouseout\" -> Optdef.get e##.toElement (fun () -> assert false)\n      | _ -> Js.null)\n\nlet eventAbsolutePosition' (e : #mouseEvent t) =\n  let body = document##.body in\n  let html = document##.documentElement in\n  ( e##.clientX + body##.scrollLeft + html##.scrollLeft\n  , e##.clientY + body##.scrollTop + html##.scrollTop )\n\nlet eventAbsolutePosition (e : #mouseEvent t) =\n  Optdef.case\n    e##.pageX\n    (fun () -> eventAbsolutePosition' e)\n    (fun x -> Optdef.case e##.pageY (fun () -> eventAbsolutePosition' e) (fun y -> x, y))\n\nlet elementClientPosition (e : #element t) =\n  let r = e##getBoundingClientRect in\n  let body = document##.body in\n  let html = document##.documentElement in\n  ( truncate (Js.to_float r##.left) - body##.clientLeft - html##.clientLeft\n  , truncate (Js.to_float r##.top) - body##.clientTop - html##.clientTop )\n\nlet getDocumentScroll () =\n  let body = document##.body in\n  let html = document##.documentElement in\n  body##.scrollLeft + html##.scrollLeft, body##.scrollTop + html##.scrollTop\n\nlet buttonPressed (ev : #mouseEvent Js.t) =\n  Js.Optdef.case\n    ev##.which\n    (fun () ->\n      match ev##.button with\n      | 1 -> Left_button\n      | 2 -> Right_button\n      | 4 -> Middle_button\n      | _ -> No_button)\n    (fun x -> x)\n\nlet addMousewheelEventListenerWithOptions e ?capture ?once ?passive h =\n  addEventListenerWithOptions\n    ?capture\n    ?once\n    ?passive\n    e\n    Event.wheel\n    (handler (fun (e : mousewheelEvent t) ->\n         let dx = -Optdef.get e##.wheelDeltaX (fun () -> 0) / 40 in\n         let dy = -Optdef.get e##.wheelDeltaY (fun () -> e##.wheelDelta) / 40 in\n         h (e :> mouseEvent t) ~dx ~dy))\n\nlet addMousewheelEventListener e h capt =\n  addMousewheelEventListenerWithOptions ~capture:capt e h\n\n(*****)\n\nmodule Keyboard_code = struct\n  type t =\n    | Unidentified\n    (* Alphabetic Characters *)\n    | KeyA\n    | KeyB\n    | KeyC\n    | KeyD\n    | KeyE\n    | KeyF\n    | KeyG\n    | KeyH\n    | KeyI\n    | KeyJ\n    | KeyK\n    | KeyL\n    | KeyM\n    | KeyN\n    | KeyO\n    | KeyP\n    | KeyQ\n    | KeyR\n    | KeyS\n    | KeyT\n    | KeyU\n    | KeyV\n    | KeyW\n    | KeyX\n    | KeyY\n    | KeyZ\n    (* Digits *)\n    | Digit0\n    | Digit1\n    | Digit2\n    | Digit3\n    | Digit4\n    | Digit5\n    | Digit6\n    | Digit7\n    | Digit8\n    | Digit9\n    | Minus\n    | Equal\n    (* Whitespace *)\n    | Tab\n    | Enter\n    | Space\n    (* Editing *)\n    | Escape\n    | Backspace\n    | Insert\n    | Delete\n    | CapsLock\n    (* Misc Printable *)\n    | BracketLeft\n    | BracketRight\n    | Semicolon\n    | Quote\n    | Backquote\n    | Backslash\n    | Comma\n    | Period\n    | Slash\n    (* Function keys *)\n    | F1\n    | F2\n    | F3\n    | F4\n    | F5\n    | F6\n    | F7\n    | F8\n    | F9\n    | F10\n    | F11\n    | F12\n    (* Numpad keys *)\n    | Numpad0\n    | Numpad1\n    | Numpad2\n    | Numpad3\n    | Numpad4\n    | Numpad5\n    | Numpad6\n    | Numpad7\n    | Numpad8\n    | Numpad9\n    | NumpadMultiply\n    | NumpadSubtract\n    | NumpadAdd\n    | NumpadDecimal\n    | NumpadEqual\n    | NumpadEnter\n    | NumpadDivide\n    | NumLock\n    (* Modifier keys *)\n    | ControlLeft\n    | ControlRight\n    | MetaLeft\n    | MetaRight\n    | ShiftLeft\n    | ShiftRight\n    | AltLeft\n    | AltRight\n    (* Arrow keys *)\n    | ArrowLeft\n    | ArrowRight\n    | ArrowUp\n    | ArrowDown\n    (* Navigation *)\n    | PageUp\n    | PageDown\n    | Home\n    | End\n    (* Sound *)\n    | VolumeMute\n    | VolumeDown\n    | VolumeUp\n    (* Media *)\n    | MediaTrackPrevious\n    | MediaTrackNext\n    | MediaPlayPause\n    | MediaStop\n    (* Browser special *)\n    | ContextMenu\n    | BrowserSearch\n    | BrowserHome\n    | BrowserFavorites\n    | BrowserRefresh\n    | BrowserStop\n    | BrowserForward\n    | BrowserBack\n    (* Misc *)\n    | OSLeft\n    | OSRight\n    | ScrollLock\n    | PrintScreen\n    | IntlBackslash\n    | IntlYen\n    | Pause\n\n  let try_code v =\n    match Js.to_string v with\n    (* Alphabetic Characters *)\n    | \"KeyA\" -> KeyA\n    | \"KeyB\" -> KeyB\n    | \"KeyC\" -> KeyC\n    | \"KeyD\" -> KeyD\n    | \"KeyE\" -> KeyE\n    | \"KeyF\" -> KeyF\n    | \"KeyG\" -> KeyG\n    | \"KeyH\" -> KeyH\n    | \"KeyI\" -> KeyI\n    | \"KeyJ\" -> KeyJ\n    | \"KeyK\" -> KeyK\n    | \"KeyL\" -> KeyL\n    | \"KeyM\" -> KeyM\n    | \"KeyN\" -> KeyN\n    | \"KeyO\" -> KeyO\n    | \"KeyP\" -> KeyP\n    | \"KeyQ\" -> KeyQ\n    | \"KeyR\" -> KeyR\n    | \"KeyS\" -> KeyS\n    | \"KeyT\" -> KeyT\n    | \"KeyU\" -> KeyU\n    | \"KeyV\" -> KeyV\n    | \"KeyW\" -> KeyW\n    | \"KeyX\" -> KeyX\n    | \"KeyY\" -> KeyY\n    | \"KeyZ\" -> KeyZ\n    (* Digits *)\n    | \"Digit0\" -> Digit0\n    | \"Digit1\" -> Digit1\n    | \"Digit2\" -> Digit2\n    | \"Digit3\" -> Digit3\n    | \"Digit4\" -> Digit4\n    | \"Digit5\" -> Digit5\n    | \"Digit6\" -> Digit6\n    | \"Digit7\" -> Digit7\n    | \"Digit8\" -> Digit8\n    | \"Digit9\" -> Digit9\n    | \"Minus\" -> Minus\n    | \"Equal\" -> Equal\n    (* Whitespace *)\n    | \"Tab\" -> Tab\n    | \"Enter\" -> Enter\n    | \"Space\" -> Space\n    (* Editing *)\n    | \"Escape\" -> Escape\n    | \"Backspace\" -> Backspace\n    | \"Insert\" -> Insert\n    | \"Delete\" -> Delete\n    | \"CapsLock\" -> CapsLock\n    (* Misc Printable *)\n    | \"BracketLeft\" -> BracketLeft\n    | \"BracketRight\" -> BracketRight\n    | \"Semicolon\" -> Semicolon\n    | \"Quote\" -> Quote\n    | \"Backquote\" -> Backquote\n    | \"Backslash\" -> Backslash\n    | \"Comma\" -> Comma\n    | \"Period\" -> Period\n    | \"Slash\" -> Slash\n    (* Function keys *)\n    | \"F1\" -> F1\n    | \"F2\" -> F2\n    | \"F3\" -> F3\n    | \"F4\" -> F4\n    | \"F5\" -> F5\n    | \"F6\" -> F6\n    | \"F7\" -> F7\n    | \"F8\" -> F8\n    | \"F9\" -> F9\n    | \"F10\" -> F10\n    | \"F11\" -> F11\n    | \"F12\" -> F12\n    (* Numpad keys *)\n    | \"Numpad0\" -> Numpad0\n    | \"Numpad1\" -> Numpad1\n    | \"Numpad2\" -> Numpad2\n    | \"Numpad3\" -> Numpad3\n    | \"Numpad4\" -> Numpad4\n    | \"Numpad5\" -> Numpad5\n    | \"Numpad6\" -> Numpad6\n    | \"Numpad7\" -> Numpad7\n    | \"Numpad8\" -> Numpad8\n    | \"Numpad9\" -> Numpad9\n    | \"NumpadMultiply\" -> NumpadMultiply\n    | \"NumpadSubtract\" -> NumpadSubtract\n    | \"NumpadAdd\" -> NumpadAdd\n    | \"NumpadDecimal\" -> NumpadDecimal\n    | \"NumpadEqual\" -> NumpadEqual\n    | \"NumpadEnter\" -> NumpadEnter\n    | \"NumpadDivide\" -> NumpadDivide\n    | \"NumLock\" -> NumLock\n    (* Modifier keys *)\n    | \"ControlLeft\" -> ControlLeft\n    | \"ControlRight\" -> ControlRight\n    | \"MetaLeft\" -> MetaLeft\n    | \"MetaRight\" -> MetaRight\n    | \"ShiftLeft\" -> ShiftLeft\n    | \"ShiftRight\" -> ShiftRight\n    | \"AltLeft\" -> AltLeft\n    | \"AltRight\" -> AltRight\n    (* Arrow keys *)\n    | \"ArrowLeft\" -> ArrowLeft\n    | \"ArrowRight\" -> ArrowRight\n    | \"ArrowUp\" -> ArrowUp\n    | \"ArrowDown\" -> ArrowDown\n    (* Navigation *)\n    | \"PageUp\" -> PageUp\n    | \"PageDown\" -> PageDown\n    | \"Home\" -> Home\n    | \"End\" -> End\n    (* Sound *)\n    | \"VolumeMute\" -> VolumeMute\n    | \"VolumeDown\" -> VolumeDown\n    | \"VolumeUp\" -> VolumeUp\n    (* Media *)\n    | \"MediaTrackPrevious\" -> MediaTrackPrevious\n    | \"MediaTrackNext\" -> MediaTrackNext\n    | \"MediaPlayPause\" -> MediaPlayPause\n    | \"MediaStop\" -> MediaStop\n    (* Browser special *)\n    | \"ContextMenu\" -> ContextMenu\n    | \"BrowserSearch\" -> BrowserSearch\n    | \"BrowserHome\" -> BrowserHome\n    | \"BrowserFavorites\" -> BrowserFavorites\n    | \"BrowserRefresh\" -> BrowserRefresh\n    | \"BrowserStop\" -> BrowserStop\n    | \"BrowserForward\" -> BrowserForward\n    | \"BrowserBack\" -> BrowserBack\n    (* Misc *)\n    | \"OSLeft\" -> OSLeft\n    | \"OSRight\" -> OSRight\n    | \"ScrollLock\" -> ScrollLock\n    | \"PrintScreen\" -> PrintScreen\n    | \"IntlBackslash\" -> IntlBackslash\n    | \"IntlYen\" -> IntlYen\n    | \"Pause\" -> Pause\n    | _ -> Unidentified\n\n  let try_key_code_left = function\n    | 16 -> ShiftLeft\n    | 17 -> ControlLeft\n    | 18 -> AltLeft\n    | 91 -> MetaLeft\n    | _ -> Unidentified\n\n  let try_key_code_right = function\n    | 16 -> ShiftRight\n    | 17 -> ControlRight\n    | 18 -> AltRight\n    | 91 -> MetaRight\n    | _ -> Unidentified\n\n  let try_key_code_numpad = function\n    | 46 -> NumpadDecimal\n    | 45 -> Numpad0\n    | 35 -> Numpad1\n    | 40 -> Numpad2\n    | 34 -> Numpad3\n    | 37 -> Numpad4\n    | 12 -> Numpad5\n    | 39 -> Numpad6\n    | 36 -> Numpad7\n    | 38 -> Numpad8\n    | 33 -> Numpad9\n    | 13 -> NumpadEnter\n    | 111 -> NumpadDivide\n    | 107 -> NumpadAdd\n    | 109 -> NumpadSubtract\n    | 106 -> NumpadMultiply\n    | 110 -> NumpadDecimal\n    | 96 -> Numpad0\n    | 97 -> Numpad1\n    | 98 -> Numpad2\n    | 99 -> Numpad3\n    | 100 -> Numpad4\n    | 101 -> Numpad5\n    | 102 -> Numpad6\n    | 103 -> Numpad7\n    | 104 -> Numpad8\n    | 105 -> Numpad9\n    | _ -> Unidentified\n\n  let try_key_code_normal = function\n    | 27 -> Escape\n    | 112 -> F1\n    | 113 -> F2\n    | 114 -> F3\n    | 115 -> F4\n    | 116 -> F5\n    | 117 -> F6\n    | 118 -> F7\n    | 119 -> F8\n    | 120 -> F9\n    | 121 -> F10\n    | 122 -> F11\n    | 123 -> F12\n    | 42 -> PrintScreen\n    | 145 -> ScrollLock\n    | 19 -> Pause\n    | 192 -> Backquote\n    | 49 -> Digit1\n    | 50 -> Digit2\n    | 51 -> Digit3\n    | 52 -> Digit4\n    | 53 -> Digit5\n    | 54 -> Digit6\n    | 55 -> Digit7\n    | 56 -> Digit8\n    | 57 -> Digit9\n    | 48 -> Digit0\n    | 189 -> Minus\n    | 187 -> Equal\n    | 8 -> Backspace\n    | 9 -> Tab\n    | 81 -> KeyQ\n    | 87 -> KeyW\n    | 69 -> KeyE\n    | 82 -> KeyR\n    | 84 -> KeyT\n    | 89 -> KeyY\n    | 85 -> KeyU\n    | 73 -> KeyI\n    | 79 -> KeyO\n    | 80 -> KeyP\n    | 219 -> BracketLeft\n    | 221 -> BracketRight\n    | 220 -> Backslash\n    | 20 -> CapsLock\n    | 65 -> KeyA\n    | 83 -> KeyS\n    | 68 -> KeyD\n    | 70 -> KeyF\n    | 71 -> KeyG\n    | 72 -> KeyH\n    | 74 -> KeyJ\n    | 75 -> KeyK\n    | 76 -> KeyL\n    | 186 -> Semicolon\n    | 222 -> Quote\n    | 13 -> Enter\n    | 90 -> KeyZ\n    | 88 -> KeyX\n    | 67 -> KeyC\n    | 86 -> KeyV\n    | 66 -> KeyB\n    | 78 -> KeyN\n    | 77 -> KeyM\n    | 188 -> Comma\n    | 190 -> Period\n    | 191 -> Slash\n    | 32 -> Space\n    | 93 -> ContextMenu\n    | 45 -> Insert\n    | 36 -> Home\n    | 33 -> PageUp\n    | 46 -> Delete\n    | 35 -> End\n    | 34 -> PageDown\n    | 37 -> ArrowLeft\n    | 40 -> ArrowDown\n    | 39 -> ArrowRight\n    | 38 -> ArrowUp\n    | _ -> Unidentified\n\n  let make_unidentified _ = Unidentified\n\n  let try_next value f = function\n    | Unidentified -> Optdef.case value make_unidentified f\n    | v -> v\n\n  let run_next value f = function\n    | Unidentified -> f value\n    | v -> v\n\n  let get_key_code evt = evt##.keyCode\n\n  let try_key_location evt =\n    match evt##.location with\n    | 1 -> run_next (get_key_code evt) try_key_code_left\n    | 2 -> run_next (get_key_code evt) try_key_code_right\n    | 3 -> run_next (get_key_code evt) try_key_code_numpad\n    | _ -> make_unidentified\n\n  let ( |> ) x f = f x\n\n  let of_event evt =\n    Unidentified\n    |> try_next evt##.code try_code\n    |> try_key_location evt\n    |> run_next (get_key_code evt) try_key_code_normal\n\n  let of_key_code = try_key_code_normal\nend\n\nmodule Keyboard_key = struct\n  type t = Uchar.t option\n\n  let char_of_int value =\n    if 0 < value then try Some (Uchar.of_int value) with _ -> None else None\n\n  let empty_string _ = Js.string \"\"\n\n  let none _ = None\n\n  let of_event evt =\n    let key = Optdef.get evt##.key empty_string in\n    match key##.length with\n    | 0 -> Optdef.case evt##.charCode none char_of_int\n    | 1 -> char_of_int (int_of_float (Js.to_float (key##charCodeAt 0)))\n    | _ -> None\nend\n\n(*****)\n\nlet element : #Dom.element t -> element t = Js.Unsafe.coerce\n\ntype taggedElement =\n  | A of anchorElement t\n  | Area of areaElement t\n  | Audio of audioElement t\n  | Base of baseElement t\n  | Blockquote of quoteElement t\n  | Body of bodyElement t\n  | Br of brElement t\n  | Button of buttonElement t\n  | Canvas of canvasElement t\n  | Caption of tableCaptionElement t\n  | Col of tableColElement t\n  | Colgroup of tableColElement t\n  | Del of modElement t\n  | Dialog of dialogElement t\n  | Div of divElement t\n  | Dl of dListElement t\n  | Embed of embedElement t\n  | Fieldset of fieldSetElement t\n  | Form of formElement t\n  | Frameset of frameSetElement t\n  | Frame of frameElement t\n  | H1 of headingElement t\n  | H2 of headingElement t\n  | H3 of headingElement t\n  | H4 of headingElement t\n  | H5 of headingElement t\n  | H6 of headingElement t\n  | Head of headElement t\n  | Hr of hrElement t\n  | Html of htmlElement t\n  | Iframe of iFrameElement t\n  | Img of imageElement t\n  | Input of inputElement t\n  | Ins of modElement t\n  | Label of labelElement t\n  | Legend of legendElement t\n  | Li of liElement t\n  | Link of linkElement t\n  | Map of mapElement t\n  | Meta of metaElement t\n  | Object of objectElement t\n  | Ol of oListElement t\n  | Optgroup of optGroupElement t\n  | Option of optionElement t\n  | P of paragraphElement t\n  | Param of paramElement t\n  | Pre of preElement t\n  | Q of quoteElement t\n  | Script of scriptElement t\n  | Select of selectElement t\n  | Style of styleElement t\n  | Table of tableElement t\n  | Tbody of tableSectionElement t\n  | Td of tableCellElement t\n  | Textarea of textAreaElement t\n  | Tfoot of tableSectionElement t\n  | Th of tableCellElement t\n  | Thead of tableSectionElement t\n  | Title of titleElement t\n  | Tr of tableRowElement t\n  | Ul of uListElement t\n  | Video of videoElement t\n  | Other of element t\n\nlet other e = Other (e : #element t :> element t)\n\nlet tagged (e : #element t) =\n  let tag = Js.to_bytestring e##.tagName##toLowerCase in\n  if String.length tag = 0\n  then other e\n  else\n    match String.unsafe_get tag 0 with\n    | 'a' -> (\n        match tag with\n        | \"a\" -> A (Js.Unsafe.coerce e)\n        | \"area\" -> Area (Js.Unsafe.coerce e)\n        | \"audio\" -> Audio (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 'b' -> (\n        match tag with\n        | \"base\" -> Base (Js.Unsafe.coerce e)\n        | \"blockquote\" -> Blockquote (Js.Unsafe.coerce e)\n        | \"body\" -> Body (Js.Unsafe.coerce e)\n        | \"br\" -> Br (Js.Unsafe.coerce e)\n        | \"button\" -> Button (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 'c' -> (\n        match tag with\n        | \"canvas\" -> Canvas (Js.Unsafe.coerce e)\n        | \"caption\" -> Caption (Js.Unsafe.coerce e)\n        | \"col\" -> Col (Js.Unsafe.coerce e)\n        | \"colgroup\" -> Colgroup (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 'd' -> (\n        match tag with\n        | \"del\" -> Del (Js.Unsafe.coerce e)\n        | \"div\" -> Div (Js.Unsafe.coerce e)\n        | \"dl\" -> Dl (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 'e' -> (\n        match tag with\n        | \"embed\" -> Embed (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 'f' -> (\n        match tag with\n        | \"fieldset\" -> Fieldset (Js.Unsafe.coerce e)\n        | \"form\" -> Form (Js.Unsafe.coerce e)\n        | \"frameset\" -> Frameset (Js.Unsafe.coerce e)\n        | \"frame\" -> Frame (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 'h' -> (\n        match tag with\n        | \"h1\" -> H1 (Js.Unsafe.coerce e)\n        | \"h2\" -> H2 (Js.Unsafe.coerce e)\n        | \"h3\" -> H3 (Js.Unsafe.coerce e)\n        | \"h4\" -> H4 (Js.Unsafe.coerce e)\n        | \"h5\" -> H5 (Js.Unsafe.coerce e)\n        | \"h6\" -> H6 (Js.Unsafe.coerce e)\n        | \"head\" -> Head (Js.Unsafe.coerce e)\n        | \"hr\" -> Hr (Js.Unsafe.coerce e)\n        | \"html\" -> Html (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 'i' -> (\n        match tag with\n        | \"iframe\" -> Iframe (Js.Unsafe.coerce e)\n        | \"img\" -> Img (Js.Unsafe.coerce e)\n        | \"input\" -> Input (Js.Unsafe.coerce e)\n        | \"ins\" -> Ins (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 'l' -> (\n        match tag with\n        | \"label\" -> Label (Js.Unsafe.coerce e)\n        | \"legend\" -> Legend (Js.Unsafe.coerce e)\n        | \"li\" -> Li (Js.Unsafe.coerce e)\n        | \"link\" -> Link (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 'm' -> (\n        match tag with\n        | \"map\" -> Map (Js.Unsafe.coerce e)\n        | \"meta\" -> Meta (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 'o' -> (\n        match tag with\n        | \"object\" -> Object (Js.Unsafe.coerce e)\n        | \"ol\" -> Ol (Js.Unsafe.coerce e)\n        | \"optgroup\" -> Optgroup (Js.Unsafe.coerce e)\n        | \"option\" -> Option (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 'p' -> (\n        match tag with\n        | \"p\" -> P (Js.Unsafe.coerce e)\n        | \"param\" -> Param (Js.Unsafe.coerce e)\n        | \"pre\" -> Pre (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 'q' -> (\n        match tag with\n        | \"q\" -> Q (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 's' -> (\n        match tag with\n        | \"script\" -> Script (Js.Unsafe.coerce e)\n        | \"select\" -> Select (Js.Unsafe.coerce e)\n        | \"style\" -> Style (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 't' -> (\n        match tag with\n        | \"table\" -> Table (Js.Unsafe.coerce e)\n        | \"tbody\" -> Tbody (Js.Unsafe.coerce e)\n        | \"td\" -> Td (Js.Unsafe.coerce e)\n        | \"textarea\" -> Textarea (Js.Unsafe.coerce e)\n        | \"tfoot\" -> Tfoot (Js.Unsafe.coerce e)\n        | \"th\" -> Th (Js.Unsafe.coerce e)\n        | \"thead\" -> Thead (Js.Unsafe.coerce e)\n        | \"title\" -> Title (Js.Unsafe.coerce e)\n        | \"tr\" -> Tr (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 'u' -> (\n        match tag with\n        | \"ul\" -> Ul (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | 'v' -> (\n        match tag with\n        | \"video\" -> Video (Js.Unsafe.coerce e)\n        | _ -> other e)\n    | _ -> other e\n\nlet opt_tagged e = Opt.case e (fun () -> None) (fun e -> Some (tagged e))\n\ntype taggedEvent =\n  | MouseEvent of mouseEvent t\n  | KeyboardEvent of keyboardEvent t\n  | MessageEvent of messageEvent t\n  | MousewheelEvent of mousewheelEvent t\n  | MouseScrollEvent of mouseScrollEvent t\n  | PopStateEvent of popStateEvent t\n  | OtherEvent of event t\n\nlet taggedEvent (ev : #event Js.t) =\n  Js.Opt.case\n    (CoerceTo.mouseEvent ev)\n    (fun () ->\n      Js.Opt.case\n        (CoerceTo.keyboardEvent ev)\n        (fun () ->\n          Js.Opt.case\n            (CoerceTo.wheelEvent ev)\n            (fun () ->\n              Js.Opt.case\n                (CoerceTo.mouseScrollEvent ev)\n                (fun () ->\n                  Js.Opt.case\n                    (CoerceTo.popStateEvent ev)\n                    (fun () ->\n                      Js.Opt.case\n                        (CoerceTo.messageEvent ev)\n                        (fun () -> OtherEvent (ev :> event t))\n                        (fun ev -> MessageEvent ev))\n                    (fun ev -> PopStateEvent ev))\n                (fun ev -> MouseScrollEvent ev))\n            (fun ev -> MousewheelEvent ev))\n        (fun ev -> KeyboardEvent ev))\n    (fun ev -> MouseEvent ev)\n\nlet opt_taggedEvent ev = Opt.case ev (fun () -> None) (fun ev -> Some (taggedEvent ev))\n\nlet stopPropagation ev =\n  let e = Js.Unsafe.coerce ev in\n  Optdef.case\n    e##.stopPropagation\n    (fun () -> e##.cancelBubble := Js._true)\n    (fun _ -> e##_stopPropagation)\n\nlet _requestAnimationFrame : (unit -> unit) Js.callback -> unit =\n  Js.Unsafe.pure_expr (fun _ ->\n      let w = Js.Unsafe.coerce window in\n      let l =\n        [ w##.requestAnimationFrame\n        ; w##.mozRequestAnimationFrame\n        ; w##.webkitRequestAnimationFrame\n        ; w##.oRequestAnimationFrame\n        ; w##.msRequestAnimationFrame\n        ]\n      in\n      try\n        let req = List.find (fun c -> Js.Optdef.test c) l in\n        fun callback -> Js.Unsafe.fun_call req [| Js.Unsafe.inject callback |]\n      with Not_found ->\n        let now () = Js.to_float (new%js Js.date_now)##getTime in\n        let last = ref (now ()) in\n        fun callback ->\n          let t = now () in\n          let dt = !last +. (1000. /. 60.) -. t in\n          let dt = if Poly.(dt < 0.) then 0. else dt in\n          last := t;\n          ignore (window##setTimeout callback (Js.float dt)))\n\n(****)\n\nlet hasPushState () = Js.Optdef.test (Js.Unsafe.coerce window##.history)##.pushState\n\nlet hasPlaceholder () =\n  let i = createInput document in\n  Js.Optdef.test (Js.Unsafe.coerce i)##.placeholder\n\nlet hasRequired () =\n  let i = createInput document in\n  Js.Optdef.test (Js.Unsafe.coerce i)##.required\n\nlet overflow_limit = 2147483_000.\n\n(* ms *)\n\ntype timeout_id_safe = timeout_id option ref\n\nlet setTimeout callback d : timeout_id_safe =\n  let id = ref None in\n  let rec loop d () =\n    let step, remain =\n      if Poly.(d > overflow_limit) then overflow_limit, d -. overflow_limit else d, 0.\n    in\n    let cb = if Poly.(remain = 0.) then callback else loop remain in\n    id := Some (window##setTimeout (Js.wrap_callback cb) (Js.float step))\n  in\n  loop d ();\n  id\n\nlet clearTimeout (id : timeout_id_safe) =\n  match !id with\n  | None -> ()\n  | Some x ->\n      id := None;\n      window##clearTimeout x\n\nlet js_array_of_collection (c : #element collection Js.t) : #element Js.t Js.js_array Js.t\n    =\n  Js.Unsafe.(meth_call (js_expr \"[].slice\") \"call\" [| inject c |])\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2011 Pierre Chambart\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\nopen Js\nopen Dom_html\nopen! Import\n\nclass type formData = object\n  method append : js_string t -> js_string t -> unit meth\n\n  method append_blob : js_string t -> File.blob t -> unit meth\nend\n\nlet formData : formData t constr = Js.Unsafe.global##._FormData\n\nlet formData_form : (formElement t -> formData t) constr = Js.Unsafe.global##._FormData\n\ntype form_elt =\n  [ `String of js_string t\n  | `File of File.file t\n  ]\n\ntype form_contents =\n  [ `Fields of (string * form_elt) list ref\n  | `FormData of formData t\n  ]\n\nlet rec filter_map f = function\n  | [] -> []\n  | v :: q -> (\n      match f v with\n      | None -> filter_map f q\n      | Some v' -> v' :: filter_map f q)\n\nclass type submittableElement = object\n  method disabled : bool t prop\n\n  method name : js_string t readonly_prop\n\n  method value : js_string t prop\nend\n\nlet have_content (elt : submittableElement t) =\n  elt##.name##.length > 0 && not (Js.to_bool elt##.disabled)\n\nlet get_textarea_val (elt : textAreaElement t) =\n  if have_content (elt :> submittableElement t)\n  then\n    let name = to_string elt##.name in\n    [ name, `String elt##.value ]\n  else []\n\nlet get_select_val (elt : selectElement t) =\n  if have_content (elt :> submittableElement t)\n  then\n    let name = to_string elt##.name in\n    if to_bool elt##.multiple\n    then\n      let options =\n        Array.init elt##.options##.length (fun i -> Opt.to_option (elt##.options##item i))\n      in\n      filter_map\n        (function\n          | None -> None\n          | Some e ->\n              if Js.to_bool e##.selected then Some (name, `String e##.value) else None)\n        (Array.to_list options)\n    else [ name, `String elt##.value ]\n  else []\n\nclass type file_input = object\n  inherit inputElement\n\n  method files : File.fileList t optdef readonly_prop\n\n  method multiple : bool optdef readonly_prop\nend\n\nlet get_input_val ?(get = false) (elt : inputElement t) =\n  if have_content (elt :> submittableElement t)\n  then\n    let name = to_string elt##.name in\n    let value = elt##.value in\n    match to_bytestring elt##._type##toLowerCase with\n    | \"checkbox\" | \"radio\" ->\n        if to_bool elt##.checked then [ name, `String value ] else []\n    | \"submit\" | \"reset\" -> []\n    | \"text\" | \"password\" -> [ name, `String value ]\n    | \"file\" -> (\n        if get\n        then [ name, `String value ]\n        else\n          let elt : file_input t = Unsafe.coerce elt in\n          match Optdef.to_option elt##.files with\n          | None -> []\n          | Some list -> (\n              if list##.length = 0\n              then [ name, `String (Js.string \"\") ]\n              else\n                match Optdef.to_option elt##.multiple with\n                | None | Some false -> (\n                    match Opt.to_option (list##item 0) with\n                    | None -> []\n                    | Some file -> [ name, `File file ])\n                | Some true ->\n                    filter_map\n                      (fun f ->\n                        match Opt.to_option f with\n                        | None -> None\n                        | Some file -> Some (name, `File file))\n                      (Array.to_list (Array.init list##.length (fun i -> list##item i)))))\n    | _ -> [ name, `String value ]\n  else []\n\nlet get_form_elements (form : formElement t) =\n  let rec loop acc i =\n    if i < 0\n    then acc\n    else\n      match Opt.to_option (form##.elements##item i) with\n      | None -> loop acc (i - i)\n      | Some x -> loop (x :: acc) (i - 1)\n  in\n  loop [] (form##.elements##.length - 1)\n\nlet get_element_content ?get v =\n  match tagged v with\n  | Select v -> get_select_val v\n  | Input v -> get_input_val ?get v\n  | Textarea v -> get_textarea_val v\n  | _ -> []\n\nlet form_elements ?get (form : formElement t) =\n  List.flatten (List.map (fun v -> get_element_content ?get v) (get_form_elements form))\n\nlet append (form_contents : form_contents) (form_elt : string * form_elt) =\n  match form_contents with\n  | `Fields list -> list := form_elt :: !list\n  | `FormData f -> (\n      match form_elt with\n      | name, `String s -> f##append (string name) s\n      | name, `File file -> f##append_blob (string name) (file :> File.blob t))\n\nlet empty_form_contents () =\n  match Optdef.to_option (Js.def formData) with\n  | None -> `Fields (ref [])\n  | Some constr -> `FormData (new%js constr)\n\nlet post_form_contents form =\n  let contents = empty_form_contents () in\n  List.iter (append contents) (form_elements form);\n  contents\n\nlet get_form_contents form =\n  List.map\n    (function\n      | name, `String s -> name, to_string s\n      | _ -> assert false)\n    (form_elements ~get:true form)\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2010 Jérôme Vouillon\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\nopen Js\nopen! Import\n\ntype readyState =\n  | UNSENT\n  | OPENED\n  | HEADERS_RECEIVED\n  | LOADING\n  | DONE\n\ntype _ response =\n  | ArrayBuffer : Typed_array.arrayBuffer t Opt.t response\n  | Blob : #File.blob t Opt.t response\n  | Document : Dom.element Dom.document t Opt.t response\n  | JSON : 'a Opt.t response\n  | Text : js_string t response\n  | Default : string response\n\nclass type xmlHttpRequest = object ('self)\n  method onreadystatechange : (unit -> unit) Js.callback Js.writeonly_prop\n\n  method readyState : readyState readonly_prop\n\n  method _open : js_string t -> js_string t -> bool t -> unit meth\n\n  method _open_full :\n       js_string t\n    -> js_string t\n    -> bool t\n    -> js_string t opt\n    -> js_string t opt\n    -> unit meth\n\n  method setRequestHeader : js_string t -> js_string t -> unit meth\n\n  method overrideMimeType : js_string t -> unit meth\n\n  method send : js_string t opt -> unit meth\n\n  method send_blob : #File.blob t -> unit meth\n\n  method send_document : Dom.element Dom.document t -> unit meth\n\n  method send_formData : Form.formData t -> unit meth\n\n  method abort : unit meth\n\n  method status : int readonly_prop\n\n  method statusText : js_string t readonly_prop\n\n  method getResponseHeader : js_string t -> js_string t opt meth\n\n  method getAllResponseHeaders : js_string t meth\n\n  method response : File.file_any readonly_prop\n\n  method responseText : js_string t opt readonly_prop\n\n  method responseXML : Dom.element Dom.document t opt readonly_prop\n\n  method responseType : js_string t prop\n\n  method withCredentials : bool t writeonly_prop\n\n  inherit File.progressEventTarget\n\n  method ontimeout :\n    ('self t, 'self File.progressEvent t) Dom.event_listener writeonly_prop\n\n  method upload : xmlHttpRequestUpload t optdef readonly_prop\nend\n\nand xmlHttpRequestUpload = object ('self)\n  inherit File.progressEventTarget\nend\n\nmodule Event = struct\n  type typ = xmlHttpRequest File.progressEvent t Dom.Event.typ\n\n  let readystatechange = Dom.Event.make \"readystatechange\"\n\n  let loadstart = Dom.Event.make \"loadstart\"\n\n  let progress = Dom.Event.make \"progress\"\n\n  let abort = Dom.Event.make \"abort\"\n\n  let error = Dom.Event.make \"error\"\n\n  let load = Dom.Event.make \"load\"\n\n  let timeout = Dom.Event.make \"timeout\"\n\n  let loadend = Dom.Event.make \"loadend\"\nend\n\nexternal create : unit -> xmlHttpRequest Js.t = \"caml_xmlhttprequest_create\"\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2015 OCamlPro: Grégoire Henry, Çağdaş Bozman.\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\nopen Js\nopen Dom_html\nopen! Import\n\nclass type ['a, 'b] worker = object ('self)\n  inherit eventTarget\n\n  method onerror : ('self t, errorEvent t) event_listener writeonly_prop\n\n  method onmessage : ('self t, 'b messageEvent t) event_listener writeonly_prop\n\n  method postMessage : 'a -> unit meth\n\n  method terminate : unit meth\nend\n\nand errorEvent = object\n  inherit event\n\n  method message : js_string t readonly_prop\n\n  method filename : js_string t readonly_prop\n\n  method lineno : int readonly_prop\n\n  method colno : int readonly_prop\n\n  method error : Unsafe.any readonly_prop\nend\n\nand ['a] messageEvent = object\n  inherit event\n\n  method data : 'a readonly_prop\nend\n\nlet worker = Unsafe.global##._Worker\n\nlet create script = new%js worker (string script)\n\nlet import_scripts scripts : unit =\n  if not (Js.Optdef.test Unsafe.global##.importScripts)\n  then invalid_arg \"Worker.import_scripts is undefined\";\n  Unsafe.fun_call\n    Unsafe.global##.importScripts\n    (Array.map (fun s -> Unsafe.inject (string s)) (Array.of_list scripts))\n\nlet set_onmessage handler =\n  if not (Js.Optdef.test Unsafe.global##.onmessage)\n  then invalid_arg \"Worker.onmessage is undefined\";\n  let js_handler (ev : 'a messageEvent Js.t) = handler ev##.data in\n  Unsafe.global##.onmessage := wrap_callback js_handler\n\nlet post_message msg =\n  if not (Js.Optdef.test Unsafe.global##.postMessage)\n  then invalid_arg \"Worker.onmessage is undefined\";\n  Unsafe.global##postMessage msg\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2012 Jacques-Pascal Deplaix\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\nopen! Import\n\ntype readyState =\n  | CONNECTING\n  | OPEN\n  | CLOSING\n  | CLOSED\n\nclass type ['a] closeEvent = object\n  inherit ['a] Dom.event\n\n  method code : int Js.readonly_prop\n\n  method reason : Js.js_string Js.t Js.readonly_prop\n\n  method wasClean : bool Js.t Js.readonly_prop\nend\n\nclass type ['a] messageEvent = object\n  inherit ['a] Dom.event\n\n  method data : Js.js_string Js.t Js.readonly_prop\n\n  method data_buffer : Typed_array.arrayBuffer Js.t Js.readonly_prop\n\n  method data_blob : File.blob Js.t Js.readonly_prop\nend\n\nclass type webSocket = object ('self)\n  inherit Dom_html.eventTarget\n\n  method url : Js.js_string Js.t Js.readonly_prop\n\n  method readyState : readyState Js.readonly_prop\n\n  method bufferedAmount : int Js.readonly_prop\n\n  method onopen : ('self Js.t, 'self Dom.event Js.t) Dom.event_listener Js.writeonly_prop\n\n  method onclose :\n    ('self Js.t, 'self closeEvent Js.t) Dom.event_listener Js.writeonly_prop\n\n  method onerror : ('self Js.t, 'self Dom.event Js.t) Dom.event_listener Js.writeonly_prop\n\n  method extensions : Js.js_string Js.t Js.readonly_prop\n\n  method protocol : Js.js_string Js.t Js.readonly_prop\n\n  method close : unit Js.meth\n\n  method close_withCode : int -> unit Js.meth\n\n  method close_withCodeAndReason : int -> Js.js_string Js.t -> unit Js.meth\n\n  method onmessage :\n    ('self Js.t, 'self messageEvent Js.t) Dom.event_listener Js.writeonly_prop\n\n  method binaryType : Js.js_string Js.t Js.prop\n\n  method send : Js.js_string Js.t -> unit Js.meth\n\n  method send_buffer : Typed_array.arrayBuffer Js.t -> unit Js.meth\n\n  method send_blob : File.blob Js.t -> unit Js.meth\nend\n\nlet webSocket = Js.Unsafe.global##._WebSocket\n\nlet webSocket_withProtocol = webSocket\n\nlet webSocket_withProtocols = webSocket\n\nlet is_supported () = Js.Optdef.test webSocket\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2012 Jérôme Vouillon\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\nopen Js\nopen! Import\n\n(** 5.1 Types *)\n\ntype sizei = int\n\ntype sizeiptr = int\n\ntype intptr = int\n\ntype uint = int\n\ntype clampf = number_t\n\ntype void\n\ntype clearBufferMask = int\n\ntype beginMode\n\ntype blendingFactor\n\ntype blendMode\n\ntype bufferTarget\n\ntype bufferUsage\n\ntype cullFaceMode\n\ntype depthFunction\n\ntype enableCap\n\ntype errorCode\n\ntype frontFaceDir\n\ntype hintTarget\n\ntype hintMode\n\ntype textureUnit = int\n\ntype 'a pixelStoreParam\n\ntype stencilOp\n\ntype fbTarget\n\ntype attachmentPoint\n\ntype rbTarget\n\ntype texTarget\n\ntype 'a parameter\n\ntype 'a bufferParameter\n\ntype 'a vertexAttribParam\n\ntype vertexAttribPointerParam\n\ntype 'a attachParam\n\ntype framebufferStatus\n\ntype 'a renderbufferParam\n\ntype format\n\ntype pixelFormat\n\ntype pixelType\n\ntype 'a texParam\n\ntype dataType\n\ntype shaderType\n\ntype 'a programParam\n\ntype 'a shaderParam\n\ntype textureFilter\n\ntype wrapMode\n\ntype texFilter\n\ntype uniformType\n\ntype colorspaceConversion\n\ntype shaderPrecisionType\n\ntype objectType\n\n(** 5.2 WebGLContextAttributes *)\nclass type contextAttributes = object\n  method alpha : bool t prop\n\n  method depth : bool t prop\n\n  method stencil : bool t prop\n\n  method antialias : bool t prop\n\n  method premultipliedAlpha : bool t prop\n\n  method preserveDrawingBuffer : bool t prop\n\n  method preferLowPowerToHighPerformance : bool t prop\n\n  method failIfMajorPerformanceCaveat : bool t prop\nend\n\nlet defaultContextAttributes =\n  Js.Unsafe.(\n    obj\n      [| \"alpha\", inject _true\n       ; \"depth\", inject _true\n       ; \"stencil\", inject _false\n       ; \"antialias\", inject _true\n       ; \"premultipliedAlpha\", inject _false\n       ; \"preserveDrawingBuffer\", inject _false\n       ; \"preferLowPowerToHighPerformance\", inject _false\n       ; \"failIfMajorPerformanceCaveat\", inject _false\n      |])\n\ntype buffer\n\ntype framebuffer\n\ntype program\n\ntype renderbuffer\n\ntype shader\n\ntype texture\n\ntype 'a uniformLocation\n\nclass type activeInfo = object\n  method size : int readonly_prop\n\n  method _type : uniformType readonly_prop\n\n  method name : js_string t readonly_prop\nend\n\nclass type shaderPrecisionFormat = object\n  method rangeMin : int readonly_prop\n\n  method rangeMax : int readonly_prop\n\n  method precision : int readonly_prop\nend\n\nclass type renderingContext = object\n  (** 5.13.1 Attributes *)\n\n  method canvas : Dom_html.canvasElement t readonly_prop\n\n  method drawingBufferWidth : sizei readonly_prop\n\n  method drawingBufferHeight : sizei readonly_prop\n\n  (** 5.13.2 Getting information about the context *)\n\n  method getContextAttributes : contextAttributes t meth\n\n  (** 5.13.3 Setting and getting state *)\n\n  method activeTexture : textureUnit -> unit meth\n\n  method blendColor : clampf -> clampf -> clampf -> clampf -> unit meth\n\n  method blendEquation : blendMode -> unit meth\n\n  method blendEquationSeparate : blendMode -> blendMode -> unit meth\n\n  method blendFunc : blendingFactor -> blendingFactor -> unit meth\n\n  method blendFuncSeparate :\n    blendingFactor -> blendingFactor -> blendingFactor -> blendingFactor -> unit meth\n\n  method clearColor : clampf -> clampf -> clampf -> clampf -> unit meth\n\n  method clearDepth : clampf -> unit meth\n\n  method clearStencil : int -> unit meth\n\n  method colorMask : bool t -> bool t -> bool t -> bool t -> unit meth\n\n  method cullFace : cullFaceMode -> unit meth\n\n  method depthFunc : depthFunction -> unit meth\n\n  method depthMask : bool t -> unit meth\n\n  method depthRange : clampf -> clampf -> unit meth\n\n  method disable : enableCap -> unit meth\n\n  method enable : enableCap -> unit meth\n\n  method frontFace : frontFaceDir -> unit meth\n\n  method getParameter : 'a. 'a parameter -> 'a meth\n\n  method getError : errorCode meth\n\n  method hint : hintTarget -> hintMode -> unit meth\n\n  method isEnabled : enableCap -> bool t meth\n\n  method lineWidth : number_t -> unit meth\n\n  method pixelStorei : 'a. 'a pixelStoreParam -> 'a -> unit meth\n\n  method polygonOffset : number_t -> number_t -> unit meth\n\n  method sampleCoverage : clampf -> bool t -> unit meth\n\n  method stencilFunc : depthFunction -> int -> uint -> unit meth\n\n  method stencilFuncSeparate : cullFaceMode -> depthFunction -> int -> uint -> unit meth\n\n  method stencilMask : uint -> unit meth\n\n  method stencilMaskSeparate : cullFaceMode -> uint -> unit meth\n\n  method stencilOp : stencilOp -> stencilOp -> stencilOp -> unit meth\n\n  method stencilOpSeparate :\n    cullFaceMode -> stencilOp -> stencilOp -> stencilOp -> unit meth\n\n  (** 5.13.4 Viewing and clipping *)\n\n  method scissor : int -> int -> sizei -> sizei -> unit meth\n\n  method viewport : int -> int -> sizei -> sizei -> unit meth\n\n  (** 5.13.5 Buffer objects *)\n\n  method bindBuffer : bufferTarget -> buffer t -> unit meth\n\n  method bindBuffer_ : bufferTarget -> buffer t opt -> unit meth\n\n  method bufferData_create : bufferTarget -> sizeiptr -> bufferUsage -> unit meth\n\n  method bufferData :\n    bufferTarget -> #Typed_array.arrayBufferView t -> bufferUsage -> unit meth\n\n  method bufferData_raw :\n    bufferTarget -> Typed_array.arrayBuffer t -> bufferUsage -> unit meth\n\n  method bufferSubData :\n    bufferTarget -> intptr -> #Typed_array.arrayBufferView t -> unit meth\n\n  method bufferSubData_raw :\n    bufferTarget -> intptr -> Typed_array.arrayBuffer t -> unit meth\n\n  method createBuffer : buffer t meth\n\n  method deleteBuffer : buffer t -> unit meth\n\n  method getBufferParameter : 'a. bufferTarget -> 'a bufferParameter -> 'a meth\n\n  method isBuffer : buffer t -> bool t meth\n\n  (** 5.13.6 Framebuffer objects *)\n\n  method bindFramebuffer : fbTarget -> framebuffer t -> unit meth\n\n  method bindFramebuffer_ : fbTarget -> framebuffer t opt -> unit meth\n\n  method checkFramebufferStatus : fbTarget -> framebufferStatus meth\n\n  method createFramebuffer : framebuffer t meth\n\n  method deleteFramebuffer : framebuffer t -> unit meth\n\n  method framebufferRenderbuffer :\n    fbTarget -> attachmentPoint -> rbTarget -> renderbuffer t -> unit meth\n\n  method framebufferTexture2D :\n    fbTarget -> attachmentPoint -> texTarget -> texture t -> int -> unit meth\n\n  method getFramebufferAttachmentParameter :\n    'a. fbTarget -> attachmentPoint -> 'a attachParam -> 'a meth\n\n  method isFramebuffer : framebuffer t -> bool t meth\n\n  (** 5.13.7 Renderbuffer objects *)\n\n  method bindRenderbuffer : rbTarget -> renderbuffer t -> unit meth\n\n  method bindRenderbuffer_ : rbTarget -> renderbuffer t opt -> unit meth\n\n  method createRenderbuffer : renderbuffer t meth\n\n  method deleteRenderbuffer : renderbuffer t -> unit meth\n\n  method getRenderbufferParameter : 'a. rbTarget -> 'a renderbufferParam -> 'a meth\n\n  method isRenderbuffer : renderbuffer t -> bool t meth\n\n  method renderbufferStorage : rbTarget -> format -> sizei -> sizei -> unit meth\n\n  (** 5.13.8 Texture objects *)\n\n  method bindTexture : texTarget -> texture t -> unit meth\n\n  method bindTexture_ : texTarget -> texture t opt -> unit meth\n\n  method compressedTexImage2D :\n       texTarget\n    -> int\n    -> pixelFormat\n    -> sizei\n    -> sizei\n    -> int\n    -> #Typed_array.arrayBufferView t\n    -> unit meth\n\n  method compressedTexSubImage2D :\n       texTarget\n    -> int\n    -> int\n    -> int\n    -> sizei\n    -> sizei\n    -> pixelFormat\n    -> #Typed_array.arrayBufferView t\n    -> unit meth\n\n  method copyTexImage2D :\n    texTarget -> int -> pixelFormat -> int -> int -> sizei -> sizei -> int -> unit meth\n\n  method copyTexSubImage2D :\n    texTarget -> int -> int -> int -> int -> int -> sizei -> sizei -> unit meth\n\n  method createTexture : texture t meth\n\n  method deleteTexture : texture t -> unit meth\n\n  method generateMipmap : texTarget -> unit meth\n\n  method getTexParameter : texTarget -> 'a texParam -> 'a meth\n\n  method isTexture : texture t -> bool t meth\n\n  method texImage2D_new :\n       texTarget\n    -> int\n    -> pixelFormat\n    -> sizei\n    -> sizei\n    -> int\n    -> pixelFormat\n    -> pixelType\n    -> void opt\n    -> unit meth\n\n  method texImage2D_fromView :\n       texTarget\n    -> int\n    -> pixelFormat\n    -> sizei\n    -> sizei\n    -> int\n    -> pixelFormat\n    -> pixelType\n    -> #Typed_array.arrayBufferView t\n    -> unit meth\n\n  method texImage2D_fromImageData :\n       texTarget\n    -> int\n    -> pixelFormat\n    -> pixelFormat\n    -> pixelType\n    -> Dom_html.imageData t\n    -> unit meth\n\n  method texImage2D_fromImage :\n       texTarget\n    -> int\n    -> pixelFormat\n    -> pixelFormat\n    -> pixelType\n    -> Dom_html.imageElement t\n    -> unit meth\n\n  method texImage2D_fromCanvas :\n       texTarget\n    -> int\n    -> pixelFormat\n    -> pixelFormat\n    -> pixelType\n    -> Dom_html.canvasElement t\n    -> unit meth\n\n  method texImage2D_fromVideo :\n       texTarget\n    -> int\n    -> pixelFormat\n    -> pixelFormat\n    -> pixelType\n    -> Dom_html.videoElement t\n    -> unit meth\n\n  (* {[\n      method texParameterf : texTarget -> texParam -> number_t -> unit meth\n     ]}\n  *)\n  method texParameteri : texTarget -> 'a texParam -> 'a -> unit meth\n\n  method texSubImage2D_fromView :\n       texTarget\n    -> int\n    -> int\n    -> int\n    -> sizei\n    -> sizei\n    -> pixelFormat\n    -> pixelType\n    -> #Typed_array.arrayBufferView t\n    -> unit meth\n\n  method texSubImage2D_fromImageData :\n       texTarget\n    -> int\n    -> int\n    -> int\n    -> pixelFormat\n    -> pixelType\n    -> Dom_html.imageData t\n    -> unit meth\n\n  method texSubImage2D_fromImage :\n       texTarget\n    -> int\n    -> int\n    -> int\n    -> pixelFormat\n    -> pixelType\n    -> Dom_html.imageElement t\n    -> unit meth\n\n  method texSubImage2D_fromCanvas :\n       texTarget\n    -> int\n    -> int\n    -> int\n    -> pixelFormat\n    -> pixelType\n    -> Dom_html.canvasElement t\n    -> unit meth\n\n  method texSubImage2D_fromVideo :\n       texTarget\n    -> int\n    -> int\n    -> int\n    -> pixelFormat\n    -> pixelType\n    -> Dom_html.videoElement t\n    -> unit meth\n\n  (** 5.13.9 Programs and Shaders *)\n\n  method attachShader : program t -> shader t -> unit meth\n\n  method bindAttribLocation : program t -> uint -> js_string t -> unit meth\n\n  method compileShader : shader t -> unit meth\n\n  method createProgram : program t meth\n\n  method createShader : shaderType -> shader t meth\n\n  method deleteProgram : program t -> unit meth\n\n  method deleteShader : shader t -> unit meth\n\n  method detachShader : program t -> shader t -> unit meth\n\n  method getAttachedShaders : program t -> shader t js_array t meth\n\n  method getProgramParameter : 'a. program t -> 'a programParam -> 'a meth\n\n  method getProgramInfoLog : program t -> js_string t meth\n\n  method getShaderParameter : 'a. shader t -> 'a shaderParam -> 'a meth\n\n  method getShaderPrecisionFormat :\n    shaderType -> shaderPrecisionType -> shaderPrecisionFormat t meth\n\n  method getShaderInfoLog : shader t -> js_string t meth\n\n  method getShaderSource : shader t -> js_string t meth\n\n  method isProgram : program t -> bool t meth\n\n  method isShader : shader t -> bool t meth\n\n  method linkProgram : program t -> unit meth\n\n  method shaderSource : shader t -> js_string t -> unit meth\n\n  method useProgram : program t -> unit meth\n\n  method validateProgram : program t -> unit meth\n\n  (** 5.13.10 Uniforms and attributes *)\n\n  method disableVertexAttribArray : uint -> unit meth\n\n  method enableVertexAttribArray : uint -> unit meth\n\n  method getActiveAttrib : program t -> uint -> activeInfo t meth\n\n  method getActiveUniform : program t -> uint -> activeInfo t meth\n\n  method getAttribLocation : program t -> js_string t -> int meth\n\n  method getUniform : 'a 'b. program t -> 'a uniformLocation t -> 'b meth\n\n  method getUniformLocation : 'a. program t -> js_string t -> 'a uniformLocation t meth\n\n  method getVertexAttrib : 'a. uint -> 'a vertexAttribParam -> 'a meth\n\n  method getVertexAttribOffset : uint -> vertexAttribPointerParam -> sizeiptr meth\n\n  method uniform1f : number_t uniformLocation t -> number_t -> unit meth\n\n  method uniform1fv_typed :\n    number_t uniformLocation t -> Typed_array.float32Array t -> unit meth\n\n  method uniform1fv : number_t uniformLocation t -> number_t js_array t -> unit meth\n\n  method uniform1i : int uniformLocation t -> int -> unit meth\n\n  method uniform1iv_typed : int uniformLocation t -> Typed_array.int32Array t -> unit meth\n\n  method uniform1iv : int uniformLocation t -> int js_array t -> unit meth\n\n  method uniform2f : [ `vec2 ] uniformLocation t -> number_t -> number_t -> unit meth\n\n  method uniform2fv_typed :\n    [ `vec2 ] uniformLocation t -> Typed_array.float32Array t -> unit meth\n\n  method uniform2fv : [ `vec2 ] uniformLocation t -> number_t js_array t -> unit meth\n\n  method uniform2i : [ `ivec2 ] uniformLocation t -> int -> int -> unit meth\n\n  method uniform2iv : [ `ivec2 ] uniformLocation t -> int js_array t -> unit meth\n\n  method uniform2iv_typed :\n    [ `ivec2 ] uniformLocation t -> Typed_array.int32Array t -> unit meth\n\n  method uniform3f :\n    [ `vec3 ] uniformLocation t -> number_t -> number_t -> number_t -> unit meth\n\n  method uniform3fv_typed :\n    [ `vec3 ] uniformLocation t -> Typed_array.float32Array t -> unit meth\n\n  method uniform3fv : [ `vec3 ] uniformLocation t -> number_t js_array t -> unit meth\n\n  method uniform3i : [ `ivec3 ] uniformLocation t -> int -> int -> int -> unit meth\n\n  method uniform3iv : [ `ivec3 ] uniformLocation t -> int js_array t -> unit meth\n\n  method uniform3iv_typed :\n    [ `ivec3 ] uniformLocation t -> Typed_array.int32Array t -> unit meth\n\n  method uniform4f :\n       [ `vec4 ] uniformLocation t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> unit meth\n\n  method uniform4fv_typed :\n    [ `vec4 ] uniformLocation t -> Typed_array.float32Array t -> unit meth\n\n  method uniform4fv : [ `vec4 ] uniformLocation t -> number_t js_array t -> unit meth\n\n  method uniform4i : [ `ivec4 ] uniformLocation t -> int -> int -> int -> int -> unit meth\n\n  method uniform4iv : [ `ivec4 ] uniformLocation t -> int js_array t -> unit meth\n\n  method uniform4iv_typed :\n    [ `ivec4 ] uniformLocation t -> Typed_array.int32Array t -> unit meth\n\n  method uniformMatrix2fv :\n    [ `mat2 ] uniformLocation t -> bool t -> number_t js_array t -> unit meth\n\n  method uniformMatrix2fv_typed :\n    [ `mat2 ] uniformLocation t -> bool t -> Typed_array.float32Array t -> unit meth\n\n  method uniformMatrix3fv :\n    [ `mat3 ] uniformLocation t -> bool t -> number_t js_array t -> unit meth\n\n  method uniformMatrix3fv_typed :\n    [ `mat3 ] uniformLocation t -> bool t -> Typed_array.float32Array t -> unit meth\n\n  method uniformMatrix4fv :\n    [ `mat4 ] uniformLocation t -> bool t -> number_t js_array t -> unit meth\n\n  method uniformMatrix4fv_typed :\n    [ `mat4 ] uniformLocation t -> bool t -> Typed_array.float32Array t -> unit meth\n\n  method vertexAttrib1f : uint -> number_t -> unit meth\n\n  method vertexAttrib1fv : uint -> number_t js_array t -> unit meth\n\n  method vertexAttrib1fv_typed : uint -> Typed_array.float32Array t -> unit meth\n\n  method vertexAttrib2f : uint -> number_t -> number_t -> unit meth\n\n  method vertexAttrib2fv : uint -> number_t js_array t -> unit meth\n\n  method vertexAttrib2fv_typed : uint -> Typed_array.float32Array t -> unit meth\n\n  method vertexAttrib3f : uint -> number_t -> number_t -> number_t -> unit meth\n\n  method vertexAttrib3fv : uint -> number_t js_array t -> unit meth\n\n  method vertexAttrib3fv_typed : uint -> Typed_array.float32Array t -> unit meth\n\n  method vertexAttrib4f :\n    uint -> number_t -> number_t -> number_t -> number_t -> unit meth\n\n  method vertexAttrib4fv : uint -> number_t js_array t -> unit meth\n\n  method vertexAttrib4fv_typed : uint -> Typed_array.float32Array t -> unit meth\n\n  method vertexAttribPointer :\n    uint -> int -> dataType -> bool t -> sizei -> intptr -> unit meth\n\n  (** 5.13.11 Writing to the drawing buffer *)\n\n  method clear : clearBufferMask -> unit meth\n\n  method drawArrays : beginMode -> int -> sizei -> unit meth\n\n  method drawElements : beginMode -> sizei -> dataType -> intptr -> unit meth\n\n  method finish : unit meth\n\n  method flush : unit meth\n\n  (** 5.13.12 Reading back pixels *)\n\n  method readPixels :\n       int\n    -> int\n    -> sizei\n    -> sizei\n    -> pixelFormat\n    -> pixelType\n    -> #Typed_array.arrayBufferView t\n    -> unit meth\n\n  (** 5.13.13 Detecting context lost events *)\n\n  method isContextLost : bool t meth\n\n  (** 5.13.14 Detecting and enabling extensions *)\n\n  method getSupportedExtensions : js_string t js_array t meth\n\n  method getExtension : 'a. js_string t -> 'a t opt meth\n\n  (* Untyped! *)\n  (** Constants *)\n\n  method _DEPTH_BUFFER_BIT_ : clearBufferMask readonly_prop\n\n  method _STENCIL_BUFFER_BIT_ : clearBufferMask readonly_prop\n\n  method _COLOR_BUFFER_BIT_ : clearBufferMask readonly_prop\n\n  method _POINTS : beginMode readonly_prop\n\n  method _LINES : beginMode readonly_prop\n\n  method _LINE_LOOP_ : beginMode readonly_prop\n\n  method _LINE_STRIP_ : beginMode readonly_prop\n\n  method _TRIANGLES : beginMode readonly_prop\n\n  method _TRIANGLE_STRIP_ : beginMode readonly_prop\n\n  method _TRIANGLE_FAN_ : beginMode readonly_prop\n\n  method _ZERO : blendingFactor readonly_prop\n\n  method _ONE : blendingFactor readonly_prop\n\n  method _SRC_COLOR_ : blendingFactor readonly_prop\n\n  method _ONE_MINUS_SRC_COLOR_ : blendingFactor readonly_prop\n\n  method _SRC_ALPHA_ : blendingFactor readonly_prop\n\n  method _ONE_MINUS_SRC_ALPHA_ : blendingFactor readonly_prop\n\n  method _DST_ALPHA_ : blendingFactor readonly_prop\n\n  method _ONE_MINUS_DST_ALPHA_ : blendingFactor readonly_prop\n\n  method _DST_COLOR_ : blendingFactor readonly_prop\n\n  method _ONE_MINUS_DST_COLOR_ : blendingFactor readonly_prop\n\n  method _SRC_ALPHA_SATURATE_ : blendingFactor readonly_prop\n\n  method _FUNC_ADD_ : blendMode readonly_prop\n\n  method _FUNC_SUBTRACT_ : blendMode readonly_prop\n\n  method _FUNC_REVERSE_SUBTRACT_ : blendMode readonly_prop\n\n  method _CONSTANT_COLOR_ : blendMode readonly_prop\n\n  method _ONE_MINUS_CONSTANT_COLOR_ : blendMode readonly_prop\n\n  method _CONSTANT_ALPHA_ : blendMode readonly_prop\n\n  method _ONE_MINUS_CONSTANT_ALPHA_ : blendMode readonly_prop\n\n  method _ARRAY_BUFFER_ : bufferTarget readonly_prop\n\n  method _ELEMENT_ARRAY_BUFFER_ : bufferTarget readonly_prop\n\n  method _STREAM_DRAW_ : bufferUsage readonly_prop\n\n  method _STATIC_DRAW_ : bufferUsage readonly_prop\n\n  method _DYNAMIC_DRAW_ : bufferUsage readonly_prop\n\n  method _FRONT : cullFaceMode readonly_prop\n\n  method _BACK : cullFaceMode readonly_prop\n\n  method _FRONT_AND_BACK_ : cullFaceMode readonly_prop\n\n  method _CULL_FACE_ : enableCap readonly_prop\n\n  method _BLEND : enableCap readonly_prop\n\n  method _DITHER : enableCap readonly_prop\n\n  method _STENCIL_TEST_ : enableCap readonly_prop\n\n  method _DEPTH_TEST_ : enableCap readonly_prop\n\n  method _SCISSOR_TEST_ : enableCap readonly_prop\n\n  method _POLYGON_OFFSET_FILL_ : enableCap readonly_prop\n\n  method _SAMPLE_ALPHA_TO_COVERAGE_ : enableCap readonly_prop\n\n  method _SAMPLE_COVERAGE_ : enableCap readonly_prop\n\n  method _NO_ERROR_ : errorCode readonly_prop\n\n  method _INVALID_ENUM_ : errorCode readonly_prop\n\n  method _INVALID_VALUE_ : errorCode readonly_prop\n\n  method _INVALID_OPERATION_ : errorCode readonly_prop\n\n  method _OUT_OF_MEMORY_ : errorCode readonly_prop\n\n  method _CONTEXT_LOST_WEBGL_ : errorCode readonly_prop\n\n  method _INVALID_FRAMEBUFFER_OPERATION_ : errorCode readonly_prop\n\n  method _CW : frontFaceDir readonly_prop\n\n  method _CCW : frontFaceDir readonly_prop\n\n  method _DONT_CARE_ : hintMode readonly_prop\n\n  method _FASTEST : hintMode readonly_prop\n\n  method _NICEST : hintMode readonly_prop\n\n  method _GENERATE_MIPMAP_HINT_ : hintTarget readonly_prop\n\n  method _BLEND_EQUATION_ : blendMode parameter readonly_prop\n\n  method _BLEND_EQUATION_RGB_ : blendMode parameter readonly_prop\n\n  method _BLEND_EQUATION_ALPHA_ : blendMode parameter readonly_prop\n\n  method _BLEND_DST_RGB_ : blendingFactor parameter readonly_prop\n\n  method _BLEND_SRC_RGB_ : blendingFactor parameter readonly_prop\n\n  method _BLEND_DST_ALPHA_ : blendingFactor parameter readonly_prop\n\n  method _BLEND_SRC_ALPHA_ : blendingFactor parameter readonly_prop\n\n  method _BLEND_COLOR_ : Typed_array.float32Array t parameter readonly_prop\n\n  method _ARRAY_BUFFER_BINDING_ : buffer t opt parameter readonly_prop\n\n  method _ELEMENT_ARRAY_BUFFER_BINDING_ : buffer t opt parameter readonly_prop\n\n  method _CULL_FACE_PARAM : bool t parameter readonly_prop\n\n  method _BLEND_PARAM : bool t parameter readonly_prop\n\n  method _DITHER_PARAM : bool t parameter readonly_prop\n\n  method _STENCIL_TEST_PARAM : bool t parameter readonly_prop\n\n  method _DEPTH_TEST_PARAM : bool t parameter readonly_prop\n\n  method _SCISSOR_TEST_PARAM : bool t parameter readonly_prop\n\n  method _POLYGON_OFFSET_FILL_PARAM : bool t parameter readonly_prop\n\n  method _LINE_WIDTH_ : number_t parameter readonly_prop\n\n  method _ALIASED_POINT_SIZE_RANGE_ : Typed_array.float32Array t parameter readonly_prop\n\n  method _ALIASED_LINE_WIDTH_RANGE_ : Typed_array.float32Array t parameter readonly_prop\n\n  method _CULL_FACE_MODE_ : cullFaceMode parameter readonly_prop\n\n  method _FRONT_FACE_ : frontFaceDir parameter readonly_prop\n\n  method _DEPTH_RANGE_ : Typed_array.float32Array t parameter readonly_prop\n\n  method _DEPTH_WRITEMASK_ : bool t parameter readonly_prop\n\n  method _DEPTH_CLEAR_VALUE_ : number_t parameter readonly_prop\n\n  method _DEPTH_FUNC_ : depthFunction parameter readonly_prop\n\n  method _STENCIL_CLEAR_VALUE_ : int parameter readonly_prop\n\n  method _STENCIL_FUNC_ : int parameter readonly_prop\n\n  method _STENCIL_FAIL_ : int parameter readonly_prop\n\n  method _STENCIL_PASS_DEPTH_FAIL_ : int parameter readonly_prop\n\n  method _STENCIL_PASS_DEPTH_PASS_ : int parameter readonly_prop\n\n  method _STENCIL_REF_ : int parameter readonly_prop\n\n  method _STENCIL_VALUE_MASK_ : int parameter readonly_prop\n\n  method _STENCIL_WRITEMASK_ : int parameter readonly_prop\n\n  method _STENCIL_BACK_FUNC_ : int parameter readonly_prop\n\n  method _STENCIL_BACK_FAIL_ : int parameter readonly_prop\n\n  method _STENCIL_BACK_PASS_DEPTH_FAIL_ : int parameter readonly_prop\n\n  method _STENCIL_BACK_PASS_DEPTH_PASS_ : int parameter readonly_prop\n\n  method _STENCIL_BACK_REF_ : int parameter readonly_prop\n\n  method _STENCIL_BACK_VALUE_MASK_ : int parameter readonly_prop\n\n  method _STENCIL_BACK_WRITEMASK_ : int parameter readonly_prop\n\n  method _VIEWPORT : Typed_array.int32Array t parameter readonly_prop\n\n  method _SCISSOR_BOX_ : Typed_array.int32Array t parameter readonly_prop\n\n  method _COLOR_CLEAR_VALUE_ : Typed_array.float32Array t parameter readonly_prop\n\n  method _COLOR_WRITEMASK_ : bool t js_array t parameter readonly_prop\n\n  method _UNPACK_ALIGNMENT_PARAM : int parameter readonly_prop\n\n  method _PACK_ALIGNMENT_ : int parameter readonly_prop\n\n  method _MAX_TEXTURE_SIZE_ : int parameter readonly_prop\n\n  method _MAX_VIEWPORT_DIMS_ : Typed_array.int32Array t parameter readonly_prop\n\n  method _SUBPIXEL_BITS_ : int parameter readonly_prop\n\n  method _RED_BITS_ : int parameter readonly_prop\n\n  method _GREEN_BITS_ : int parameter readonly_prop\n\n  method _BLUE_BITS_ : int parameter readonly_prop\n\n  method _ALPHA_BITS_ : int parameter readonly_prop\n\n  method _DEPTH_BITS_ : int parameter readonly_prop\n\n  method _STENCIL_BITS_ : int parameter readonly_prop\n\n  method _POLYGON_OFFSET_UNITS_ : number_t parameter readonly_prop\n\n  method _POLYGON_OFFSET_FACTOR_ : number_t parameter readonly_prop\n\n  method _TEXTURE_BINDING_2D_ : texture t opt parameter readonly_prop\n\n  method _TEXTURE_BINDING_CUBE_MAP_ : texture t opt parameter readonly_prop\n\n  method _SAMPLE_BUFFERS_ : int parameter readonly_prop\n\n  method _SAMPLES_ : int parameter readonly_prop\n\n  method _SAMPLE_COVERAGE_VALUE_ : number_t parameter readonly_prop\n\n  method _SAMPLE_COVERAGE_INVERT_ : bool t parameter readonly_prop\n\n  method _NUM_COMPRESSED_TEXTURE_FORMATS_ : int parameter readonly_prop\n\n  method _COMPRESSED_TEXTURE_FORMATS_ : Typed_array.uint32Array t parameter readonly_prop\n\n  method _GENERATE_MIPMAP_HINT_PARAM_ : hintMode parameter readonly_prop\n\n  method _BUFFER_SIZE_ : int bufferParameter readonly_prop\n\n  method _BUFFER_USAGE_ : bufferUsage bufferParameter readonly_prop\n\n  method _BYTE : dataType readonly_prop\n\n  method _UNSIGNED_BYTE_DT : dataType readonly_prop\n\n  method _SHORT : dataType readonly_prop\n\n  method _UNSIGNED_SHORT_ : dataType readonly_prop\n\n  method _INT : dataType readonly_prop\n\n  method _UNSIGNED_INT_ : dataType readonly_prop\n\n  method _FLOAT : dataType readonly_prop\n\n  method _UNSIGNED_BYTE_ : pixelType readonly_prop\n\n  method _UNSIGNED_SHORT_4_4_4_4_ : pixelType readonly_prop\n\n  method _UNSIGNED_SHORT_5_5_5_1_ : pixelType readonly_prop\n\n  method _UNSIGNED_SHORT_5_6_5_ : pixelType readonly_prop\n\n  method _ALPHA : pixelFormat readonly_prop\n\n  method _RGB : pixelFormat readonly_prop\n\n  method _RGBA : pixelFormat readonly_prop\n\n  method _LUMINANCE : pixelFormat readonly_prop\n\n  method _LUMINANCE_ALPHA_ : pixelFormat readonly_prop\n\n  method _STENCIL_INDEX_ : pixelFormat readonly_prop\n\n  method _DEPTH_STENCIL_ : pixelFormat readonly_prop\n\n  method _DEPTH_COMPONENT_ : pixelFormat readonly_prop\n\n  method _FRAGMENT_SHADER_ : shaderType readonly_prop\n\n  method _VERTEX_SHADER_ : shaderType readonly_prop\n\n  method _MAX_VERTEX_ATTRIBS_ : int parameter readonly_prop\n\n  method _MAX_VERTEX_UNIFORM_VECTORS_ : int parameter readonly_prop\n\n  method _MAX_VARYING_VECTORS_ : int parameter readonly_prop\n\n  method _MAX_COMBINED_TEXTURE_IMAGE_UNITS_ : int parameter readonly_prop\n\n  method _MAX_VERTEX_TEXTURE_IMAGE_UNITS_ : int parameter readonly_prop\n\n  method _MAX_TEXTURE_IMAGE_UNITS_ : int parameter readonly_prop\n\n  method _MAX_FRAGMENT_UNIFORM_VECTORS_ : int parameter readonly_prop\n\n  method _SHADER_TYPE_ : shaderType shaderParam readonly_prop\n\n  method _DELETE_STATUS_ : bool t shaderParam readonly_prop\n\n  method _COMPILE_STATUS_ : bool t shaderParam readonly_prop\n\n  method _DELETE_STATUS_PROG : bool t programParam readonly_prop\n\n  method _LINK_STATUS_ : bool t programParam readonly_prop\n\n  method _VALIDATE_STATUS_ : bool t programParam readonly_prop\n\n  method _ATTACHED_SHADERS_ : int programParam readonly_prop\n\n  method _ACTIVE_UNIFORMS_ : int programParam readonly_prop\n\n  method _ACTIVE_ATTRIBUTES_ : int programParam readonly_prop\n\n  method _SHADING_LANGUAGE_VERSION_ : js_string t parameter readonly_prop\n\n  method _CURRENT_PROGRAM_ : program t opt parameter readonly_prop\n\n  method _VENDOR : js_string t parameter readonly_prop\n\n  method _RENDERER : js_string t parameter readonly_prop\n\n  method _VERSION : js_string t parameter readonly_prop\n\n  method _MAX_CUBE_MAP_TEXTURE_SIZE_ : int parameter readonly_prop\n\n  method _ACTIVE_TEXTURE_ : int parameter readonly_prop\n\n  method _FRAMEBUFFER_BINDING_ : framebuffer t opt parameter readonly_prop\n\n  method _RENDERBUFFER_BINDING_ : renderbuffer t opt parameter readonly_prop\n\n  method _MAX_RENDERBUFFER_SIZE : int parameter readonly_prop\n\n  method _NEVER : depthFunction readonly_prop\n\n  method _LESS : depthFunction readonly_prop\n\n  method _EQUAL : depthFunction readonly_prop\n\n  method _LEQUAL : depthFunction readonly_prop\n\n  method _GREATER : depthFunction readonly_prop\n\n  method _NOTEQUAL : depthFunction readonly_prop\n\n  method _GEQUAL : depthFunction readonly_prop\n\n  method _ALWAYS : depthFunction readonly_prop\n\n  method _KEEP : stencilOp readonly_prop\n\n  method _REPLACE : stencilOp readonly_prop\n\n  method _INCR : stencilOp readonly_prop\n\n  method _DECR : stencilOp readonly_prop\n\n  method _INVERT : stencilOp readonly_prop\n\n  method _INCR_WRAP_ : stencilOp readonly_prop\n\n  method _DECR_WRAP_ : stencilOp readonly_prop\n\n  method _ZERO_ : stencilOp readonly_prop\n\n  method _NEAREST : texFilter readonly_prop\n\n  method _LINEAR : texFilter readonly_prop\n\n  method _NEAREST_MIPMAP_NEAREST_ : texFilter readonly_prop\n\n  method _LINEAR_MIPMAP_NEAREST_ : texFilter readonly_prop\n\n  method _NEAREST_MIPMAP_LINEAR_ : texFilter readonly_prop\n\n  method _LINEAR_MIPMAP_LINEAR_ : texFilter readonly_prop\n\n  method _TEXTURE_MAG_FILTER_ : texFilter texParam readonly_prop\n\n  method _TEXTURE_MIN_FILTER_ : texFilter texParam readonly_prop\n\n  method _TEXTURE_WRAP_S_ : wrapMode texParam readonly_prop\n\n  method _TEXTURE_WRAP_T_ : wrapMode texParam readonly_prop\n\n  method _NONE_OT : objectType readonly_prop\n\n  method _TEXTURE_OT : objectType readonly_prop\n\n  method _RENDERBUFFER_OT : objectType readonly_prop\n\n  method _TEXTURE_2D_ : texTarget readonly_prop\n\n  method _TEXTURE_CUBE_MAP_ : texTarget readonly_prop\n\n  method _TEXTURE_CUBE_MAP_POSITIVE_X_ : texTarget readonly_prop\n\n  method _TEXTURE_CUBE_MAP_NEGATIVE_X_ : texTarget readonly_prop\n\n  method _TEXTURE_CUBE_MAP_POSITIVE_Y_ : texTarget readonly_prop\n\n  method _TEXTURE_CUBE_MAP_NEGATIVE_Y_ : texTarget readonly_prop\n\n  method _TEXTURE_CUBE_MAP_POSITIVE_Z_ : texTarget readonly_prop\n\n  method _TEXTURE_CUBE_MAP_NEGATIVE_Z_ : texTarget readonly_prop\n\n  method _TEXTURE0 : textureUnit readonly_prop\n\n  method _TEXTURE1 : textureUnit readonly_prop\n\n  method _TEXTURE2 : textureUnit readonly_prop\n\n  method _TEXTURE3 : textureUnit readonly_prop\n\n  method _TEXTURE4 : textureUnit readonly_prop\n\n  method _TEXTURE5 : textureUnit readonly_prop\n\n  method _TEXTURE6 : textureUnit readonly_prop\n\n  method _TEXTURE7 : textureUnit readonly_prop\n\n  method _TEXTURE8 : textureUnit readonly_prop\n\n  method _TEXTURE9 : textureUnit readonly_prop\n\n  method _TEXTURE10 : textureUnit readonly_prop\n\n  method _TEXTURE11 : textureUnit readonly_prop\n\n  method _TEXTURE12 : textureUnit readonly_prop\n\n  method _TEXTURE13 : textureUnit readonly_prop\n\n  method _TEXTURE14 : textureUnit readonly_prop\n\n  method _TEXTURE15 : textureUnit readonly_prop\n\n  method _TEXTURE16 : textureUnit readonly_prop\n\n  method _TEXTURE17 : textureUnit readonly_prop\n\n  method _TEXTURE18 : textureUnit readonly_prop\n\n  method _TEXTURE19 : textureUnit readonly_prop\n\n  method _TEXTURE20 : textureUnit readonly_prop\n\n  method _TEXTURE21 : textureUnit readonly_prop\n\n  method _TEXTURE22 : textureUnit readonly_prop\n\n  method _TEXTURE23 : textureUnit readonly_prop\n\n  method _TEXTURE24 : textureUnit readonly_prop\n\n  method _TEXTURE25 : textureUnit readonly_prop\n\n  method _TEXTURE26 : textureUnit readonly_prop\n\n  method _TEXTURE27 : textureUnit readonly_prop\n\n  method _TEXTURE28 : textureUnit readonly_prop\n\n  method _TEXTURE29 : textureUnit readonly_prop\n\n  method _TEXTURE30 : textureUnit readonly_prop\n\n  method _TEXTURE31 : textureUnit readonly_prop\n\n  method _REPEAT : wrapMode readonly_prop\n\n  method _CLAMP_TO_EDGE_ : wrapMode readonly_prop\n\n  method _MIRRORED_REPEAT_ : wrapMode readonly_prop\n\n  method _FLOAT_ : uniformType readonly_prop\n\n  method _FLOAT_VEC2_ : uniformType readonly_prop\n\n  method _FLOAT_VEC3_ : uniformType readonly_prop\n\n  method _FLOAT_VEC4_ : uniformType readonly_prop\n\n  method _INT_ : uniformType readonly_prop\n\n  method _INT_VEC2_ : uniformType readonly_prop\n\n  method _INT_VEC3_ : uniformType readonly_prop\n\n  method _INT_VEC4_ : uniformType readonly_prop\n\n  method _BOOL_ : uniformType readonly_prop\n\n  method _BOOL_VEC2_ : uniformType readonly_prop\n\n  method _BOOL_VEC3_ : uniformType readonly_prop\n\n  method _BOOL_VEC4_ : uniformType readonly_prop\n\n  method _FLOAT_MAT2_ : uniformType readonly_prop\n\n  method _FLOAT_MAT3_ : uniformType readonly_prop\n\n  method _FLOAT_MAT4_ : uniformType readonly_prop\n\n  method _SAMPLER_2D_ : uniformType readonly_prop\n\n  method _SAMPLER_CUBE_ : uniformType readonly_prop\n\n  method _VERTEX_ATTRIB_ARRAY_ENABLED_ : bool t vertexAttribParam readonly_prop\n\n  method _VERTEX_ATTRIB_ARRAY_SIZE_ : int vertexAttribParam readonly_prop\n\n  method _VERTEX_ATTRIB_ARRAY_STRIDE_ : int vertexAttribParam readonly_prop\n\n  method _VERTEX_ATTRIB_ARRAY_TYPE_ : int vertexAttribParam readonly_prop\n\n  method _VERTEX_ATTRIB_ARRAY_NORMALIZED_ : bool t vertexAttribParam readonly_prop\n\n  method _VERTEX_ATTRIB_ARRAY_POINTER_ : vertexAttribPointerParam readonly_prop\n\n  method _VERTEX_ATTRIB_ARRAY_BUFFER_BINDING_ :\n    buffer t opt vertexAttribParam readonly_prop\n\n  method _CURRENT_VERTEX_ATTRIB_ :\n    Typed_array.float32Array t vertexAttribParam readonly_prop\n\n  method _LOW_FLOAT_ : shaderPrecisionType readonly_prop\n\n  method _MEDIUM_FLOAT_ : shaderPrecisionType readonly_prop\n\n  method _HIGH_FLOAT_ : shaderPrecisionType readonly_prop\n\n  method _LOW_INT_ : shaderPrecisionType readonly_prop\n\n  method _MEDIUM_INT_ : shaderPrecisionType readonly_prop\n\n  method _HIGH_INT_ : shaderPrecisionType readonly_prop\n\n  method _FRAMEBUFFER : fbTarget readonly_prop\n\n  method _RENDERBUFFER : rbTarget readonly_prop\n\n  method _RGBA4 : format readonly_prop\n\n  method _RGB5_A1_ : format readonly_prop\n\n  method _RGB565 : format readonly_prop\n\n  method _DEPTH_COMPONENT16_ : format readonly_prop\n\n  method _STENCIL_INDEX8_ : format readonly_prop\n\n  method _RENDERBUFFER_WIDTH_ : int renderbufferParam readonly_prop\n\n  method _RENDERBUFFER_HEIGHT_ : int renderbufferParam readonly_prop\n\n  method _RENDERBUFFER_INTERNAL_FORMAT_ : format renderbufferParam readonly_prop\n\n  method _RENDERBUFFER_RED_SIZE_ : int renderbufferParam readonly_prop\n\n  method _RENDERBUFFER_GREEN_SIZE_ : int renderbufferParam readonly_prop\n\n  method _RENDERBUFFER_BLUE_SIZE_ : int renderbufferParam readonly_prop\n\n  method _RENDERBUFFER_ALPHA_SIZE_ : int renderbufferParam readonly_prop\n\n  method _RENDERBUFFER_DEPTH_SIZE_ : int renderbufferParam readonly_prop\n\n  method _RENDERBUFFER_STENCIL_SIZE_ : int renderbufferParam readonly_prop\n\n  method _FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE_ : objectType attachParam readonly_prop\n\n  method _FRAMEBUFFER_ATTACHMENT_OBJECT_NAME_RENDERBUFFER :\n    renderbuffer t attachParam readonly_prop\n\n  method _FRAMEBUFFER_ATTACHMENT_OBJECT_NAME_TEXTURE : texture t attachParam readonly_prop\n\n  method _FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL_ : int attachParam readonly_prop\n\n  method _FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE_ : int attachParam readonly_prop\n\n  method _COLOR_ATTACHMENT0_ : attachmentPoint readonly_prop\n\n  method _DEPTH_ATTACHMENT_ : attachmentPoint readonly_prop\n\n  method _STENCIL_ATTACHMENT_ : attachmentPoint readonly_prop\n\n  method _DEPTH_STENCIL_ATTACHMENT_ : attachmentPoint readonly_prop\n\n  method _FRAMEBUFFER_COMPLETE_ : framebufferStatus readonly_prop\n\n  method _FRAMEBUFFER_INCOMPLETE_ATTACHMENT_ : framebufferStatus readonly_prop\n\n  method _FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT_ : framebufferStatus readonly_prop\n\n  method _FRAMEBUFFER_INCOMPLETE_DIMENSIONS_ : framebufferStatus readonly_prop\n\n  method _FRAMEBUFFER_UNSUPPORTED_ : framebufferStatus readonly_prop\n\n  method _UNPACK_FLIP_Y_WEBGL_PARAM : bool t parameter readonly_prop\n\n  method _UNPACK_PREMULTIPLY_ALPHA_WEBGL_PARAM : bool t parameter readonly_prop\n\n  method _UNPACK_COLORSPACE_CONVERSION_WEBGL_PARAM :\n    colorspaceConversion parameter readonly_prop\n\n  method _NONE : colorspaceConversion readonly_prop\n\n  method _BROWSER_DEFAULT_WEBGL_ : colorspaceConversion readonly_prop\n\n  method _UNPACK_ALIGNMENT_ : int pixelStoreParam readonly_prop\n\n  method _UNPACK_FLIP_Y_WEBGL_ : bool t pixelStoreParam readonly_prop\n\n  method _UNPACK_PREMULTIPLY_ALPHA_WEBGL_ : bool t pixelStoreParam readonly_prop\n\n  method _UNPACK_COLORSPACE_CONVERSION_WEBGL_ : int pixelStoreParam readonly_prop\nend\n\n(** 5.14 WebGLContextEvent *)\n\nclass type contextEvent = object\n  inherit Dom_html.event\n\n  method statusMessage : js_string t readonly_prop\nend\n\nmodule Event = struct\n  let webglcontextlost = Dom_html.Event.make \"webglcontextlost\"\n\n  let webglcontextrestored = Dom_html.Event.make \"webglcontextrestored\"\n\n  let webglcontextcreationerror = Dom_html.Event.make \"webglcontextcreationerror\"\nend\n\n(****)\n\nclass type canvasElement = object\n  method getContext : js_string t -> renderingContext t opt meth\n\n  method getContext_ : js_string t -> contextAttributes t -> renderingContext t opt meth\nend\n\nlet getContext (c : Dom_html.canvasElement t) =\n  let c : canvasElement t = Js.Unsafe.coerce c in\n  let ctx = c##getContext (Js.string \"webgl\") in\n  if Opt.test ctx then ctx else c ## (getContext (Js.string \"experimental-webgl\"))\n\nlet getContextWithAttributes (c : Dom_html.canvasElement t) attribs =\n  let c : canvasElement t = Js.Unsafe.coerce c in\n  let ctx = c##getContext_ (Js.string \"webgl\") attribs in\n  if Opt.test ctx then ctx else c##getContext_ (Js.string \"experimental-webgl\") attribs\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2010 Raphaël Proust, Jérôme Vouillon\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\nopen! Import\n\ntype regexp = Js.regExp Js.t\n\ntype result = Js.match_result Js.t\n\nlet regexp s = new%js Js.regExp_withFlags (Js.bytestring s) (Js.string \"g\")\n\nlet regexp_case_fold s = new%js Js.regExp_withFlags (Js.bytestring s) (Js.string \"gi\")\n\nlet regexp_with_flag s f =\n  new%js Js.regExp_withFlags (Js.bytestring s) (Js.string (\"g\" ^ f))\n\nlet blunt_str_array_get a i =\n  Js.to_bytestring (Js.Optdef.get (Js.array_get a i) (fun () -> assert false))\n\nlet string_match r s i =\n  r##.lastIndex := i;\n  Js.Opt.to_option (Js.Opt.map (r##exec (Js.bytestring s)) Js.match_result)\n\nlet search r s i =\n  r##.lastIndex := i;\n  Js.Opt.to_option\n    (Js.Opt.map\n       (r##exec (Js.bytestring s))\n       (fun res_pre ->\n         let res = Js.match_result res_pre in\n         res##.index, res))\n\nlet search_forward = search\n\nlet matched_string r = blunt_str_array_get r 0\n\nlet matched_group r i =\n  Js.Optdef.to_option (Js.Optdef.map (Js.array_get r i) Js.to_bytestring)\n\nlet quote_repl_re = new%js Js.regExp_withFlags (Js.string \"[$]\") (Js.string \"g\")\n\nlet quote_repl s = (Js.bytestring s)##replace quote_repl_re (Js.string \"$$$$\")\n\nlet global_replace r s s_by =\n  r##.lastIndex := 0;\n  Js.to_bytestring (Js.bytestring s) ## (replace r (quote_repl s_by))\n\nlet replace_first r s s_by =\n  let flags =\n    match Js.to_bool r##.ignoreCase, Js.to_bool r##.multiline with\n    | false, false -> Js.string \"\"\n    | false, true -> Js.string \"m\"\n    | true, false -> Js.string \"i\"\n    | true, true -> Js.string \"mi\"\n  in\n  let r' = new%js Js.regExp_withFlags r##.source flags in\n  Js.to_bytestring (Js.bytestring s) ## (replace r' (quote_repl s_by))\n\nlet list_of_js_array a =\n  let rec aux accu idx =\n    if idx < 0 then accu else aux (blunt_str_array_get a idx :: accu) (idx - 1)\n  in\n  aux [] (a##.length - 1)\n\nlet split r s =\n  r##.lastIndex := 0;\n  list_of_js_array (Js.str_array (Js.bytestring s) ## (split_regExp r))\n\nlet bounded_split r s i =\n  r##.lastIndex := 0;\n  list_of_js_array (Js.str_array (Js.bytestring s) ## (split_regExpLimited r i))\n\n(* More constructors *)\n\nlet quote_re = regexp \"[\\\\][()\\\\\\\\|+*.?{}^$]\"\n\nlet quote s = Js.to_bytestring (Js.bytestring s) ## (replace quote_re (Js.string \"\\\\$&\"))\n\nlet regexp_string s = regexp (quote s)\n\nlet regexp_string_case_fold s = regexp_case_fold (quote s)\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2010 Raphaël Proust\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\nopen! Import\n\n(* Url tampering. *)\n\nlet split c s = Js.str_array (s##split (Js.string (String.make 1 c)))\n\nlet split_2 c s =\n  let index = s##indexOf (Js.string (String.make 1 c)) in\n  if index < 0 then Js.undefined else Js.def (s##slice 0 index, s##slice_end (index + 1))\n\nexception Local_exn\n\nlet interrupt () = raise Local_exn\n\n(* url (AKA percent) encoding/decoding *)\n\nlet plus_re = Regexp.regexp_string \"+\"\n\nlet escape_plus s = Regexp.global_replace plus_re s \"%2B\"\n\nlet unescape_plus s = Regexp.global_replace plus_re s \" \"\n\nlet plus_re_js_string = new%js Js.regExp_withFlags (Js.string \"\\\\+\") (Js.string \"g\")\n\nlet unescape_plus_js_string s =\n  plus_re_js_string##.lastIndex := 0;\n  s##replace plus_re_js_string (Js.string \" \")\n\nlet urldecode_js_string_string s =\n  Js.to_bytestring (Js.unescape (unescape_plus_js_string s))\n\nlet urldecode s = Js.to_bytestring (Js.unescape (Js.bytestring (unescape_plus s)))\n\n(*let urlencode_js_string_string s =\n  Js.to_bytestring (Js.escape s)*)\n\nlet urlencode ?(with_plus = true) s =\n  if with_plus\n  then escape_plus (Js.to_bytestring (Js.escape (Js.bytestring s)))\n  else Js.to_bytestring (Js.escape (Js.bytestring s))\n\ntype http_url =\n  { hu_host : string  (** The host part of the url. *)\n  ; hu_port : int  (** The port for the connection if any. *)\n  ; hu_path : string list  (** The path split on ['/'] characters. *)\n  ; hu_path_string : string  (** The original entire path. *)\n  ; hu_arguments : (string * string) list\n        (** Arguments as a field-value\n                                             association list.*)\n  ; hu_fragment : string  (** The fragment part (after the ['#'] character). *)\n  }\n(** The type for HTTP url. *)\n\ntype file_url =\n  { fu_path : string list\n  ; fu_path_string : string\n  ; fu_arguments : (string * string) list\n  ; fu_fragment : string\n  }\n(** The type for local file urls. *)\n\ntype url =\n  | Http of http_url\n  | Https of http_url\n  | File of file_url\n      (** The type for urls. [File] is for local files and [Exotic s] is for\n    unknown/unsupported protocols. *)\n\nexception Not_an_http_protocol\n\nlet is_secure prot_string =\n  match Js.to_bytestring prot_string##toLowerCase with\n  | \"https:\" | \"https\" -> true\n  | \"http:\" | \"http\" -> false\n  | \"file:\" | \"file\" | _ -> raise Not_an_http_protocol\n\n(* port number *)\nlet default_http_port = 80\n\nlet default_https_port = 443\n\n(* path *)\nlet path_of_path_string s =\n  let l = String.length s in\n  let rec aux i =\n    let j = try String.index_from s i '/' with Not_found -> l in\n    let word = String.sub s i (j - i) in\n    if j >= l then [ word ] else word :: aux (j + 1)\n  in\n  match aux 0 with\n  | [ \"\" ] -> []\n  | [ \"\"; \"\" ] -> [ \"\" ]\n  | a -> a\n\n(* Arguments *)\nlet encode_arguments l =\n  String.concat \"&\" (List.map (fun (n, v) -> urlencode n ^ \"=\" ^ urlencode v) l)\n\nlet decode_arguments_js_string s =\n  let arr = split '&' s in\n  let len = arr##.length in\n  let name_value_split s = split_2 '=' s in\n  let rec aux acc idx =\n    if idx < 0\n    then acc\n    else\n      try\n        aux\n          (Js.Optdef.case (Js.array_get arr idx) interrupt (fun s ->\n               Js.Optdef.case (name_value_split s) interrupt (fun (x, y) ->\n                   let get = urldecode_js_string_string in\n                   get x, get y))\n          :: acc)\n          (pred idx)\n      with Local_exn -> aux acc (pred idx)\n  in\n  aux [] (len - 1)\n\nlet decode_arguments s = decode_arguments_js_string (Js.bytestring s)\n\nlet url_re =\n  new%js Js.regExp\n    (Js.bytestring\n       \"^([Hh][Tt][Tt][Pp][Ss]?)://([0-9a-zA-Z.-]+|\\\\[[0-9a-zA-Z.-]+\\\\]|\\\\[[0-9A-Fa-f:.]+\\\\])?(:([0-9]+))?(/([^\\\\?#]*)(\\\\?([^#]*))?(#(.*))?)?$\")\n\nlet file_re =\n  new%js Js.regExp\n    (Js.bytestring \"^([Ff][Ii][Ll][Ee])://([^\\\\?#]*)(\\\\?([^#]*))?(#(.*))?$\")\n\nlet url_of_js_string s =\n  Js.Opt.case\n    (url_re##exec s)\n    (fun () ->\n      Js.Opt.case\n        (file_re##exec s)\n        (fun () -> None)\n        (fun handle ->\n          let res = Js.match_result handle in\n          let path_str =\n            urldecode_js_string_string (Js.Optdef.get (Js.array_get res 2) interrupt)\n          in\n          Some\n            (File\n               { fu_path = path_of_path_string path_str\n               ; fu_path_string = path_str\n               ; fu_arguments =\n                   decode_arguments_js_string\n                     (Js.Optdef.get (Js.array_get res 4) (fun () -> Js.bytestring \"\"))\n               ; fu_fragment =\n                   Js.to_bytestring\n                     (Js.Optdef.get (Js.array_get res 6) (fun () -> Js.bytestring \"\"))\n               })))\n    (fun handle ->\n      let res = Js.match_result handle in\n      let ssl = is_secure (Js.Optdef.get (Js.array_get res 1) interrupt) in\n      let port_of_string = function\n        | \"\" -> if ssl then 443 else 80\n        | s -> int_of_string s\n      in\n      let path_str =\n        urldecode_js_string_string\n          (Js.Optdef.get (Js.array_get res 6) (fun () -> Js.bytestring \"\"))\n      in\n      let url =\n        { hu_host =\n            urldecode_js_string_string (Js.Optdef.get (Js.array_get res 2) interrupt)\n        ; hu_port =\n            port_of_string\n              (Js.to_bytestring\n                 (Js.Optdef.get (Js.array_get res 4) (fun () -> Js.bytestring \"\")))\n        ; hu_path = path_of_path_string path_str\n        ; hu_path_string = path_str\n        ; hu_arguments =\n            decode_arguments_js_string\n              (Js.Optdef.get (Js.array_get res 8) (fun () -> Js.bytestring \"\"))\n        ; hu_fragment =\n            urldecode_js_string_string\n              (Js.Optdef.get (Js.array_get res 10) (fun () -> Js.bytestring \"\"))\n        }\n      in\n      Some (if ssl then Https url else Http url))\n\nlet url_of_string s = url_of_js_string (Js.bytestring s)\n\nlet string_of_url = function\n  | File { fu_path = path; fu_arguments = args; fu_fragment = frag; _ } -> (\n      \"file://\"\n      ^ String.concat \"/\" (List.map (fun x -> urlencode x) path)\n      ^ (match args with\n        | [] -> \"\"\n        | l -> \"?\" ^ encode_arguments l)\n      ^\n      match frag with\n      | \"\" -> \"\"\n      | s -> \"#\" ^ urlencode s)\n  | Http\n      { hu_host = host\n      ; hu_port = port\n      ; hu_path = path\n      ; hu_arguments = args\n      ; hu_fragment = frag\n      ; _\n      } -> (\n      \"http://\"\n      ^ urlencode host\n      ^ (match port with\n        | 80 -> \"\"\n        | n -> \":\" ^ string_of_int n)\n      ^ \"/\"\n      ^ String.concat \"/\" (List.map (fun x -> urlencode x) path)\n      ^ (match args with\n        | [] -> \"\"\n        | l -> \"?\" ^ encode_arguments l)\n      ^\n      match frag with\n      | \"\" -> \"\"\n      | s -> \"#\" ^ urlencode s)\n  | Https\n      { hu_host = host\n      ; hu_port = port\n      ; hu_path = path\n      ; hu_arguments = args\n      ; hu_fragment = frag\n      ; _\n      } -> (\n      \"https://\"\n      ^ urlencode host\n      ^ (match port with\n        | 443 -> \"\"\n        | n -> \":\" ^ string_of_int n)\n      ^ \"/\"\n      ^ String.concat \"/\" (List.map (fun x -> urlencode x) path)\n      ^ (match args with\n        | [] -> \"\"\n        | l -> \"?\" ^ encode_arguments l)\n      ^\n      match frag with\n      | \"\" -> \"\"\n      | s -> \"#\" ^ urlencode s)\n\nmodule Current = struct\n  let l =\n    if Js.Optdef.test (Js.Optdef.return Dom_html.window##.location)\n    then Dom_html.window##.location\n    else\n      let empty = Js.string \"\" in\n      object%js\n        val mutable href = empty\n\n        val mutable protocol = empty\n\n        val mutable host = empty\n\n        val mutable hostname = empty\n\n        val mutable port = empty\n\n        val mutable pathname = empty\n\n        val mutable search = empty\n\n        val mutable hash = empty\n\n        val origin = Js.undefined\n\n        method reload = ()\n\n        method replace _ = ()\n\n        method assign _ = ()\n      end\n\n  let host = urldecode_js_string_string l##.hostname\n\n  let protocol = urldecode_js_string_string l##.protocol\n\n  let port =\n    (fun () ->\n      try Some (int_of_string (Js.to_bytestring l##.port)) with Failure _ -> None)\n      ()\n\n  let path_string = urldecode_js_string_string l##.pathname\n\n  let path = path_of_path_string path_string\n\n  let arguments =\n    decode_arguments_js_string\n      (if Js.equals (l##.search##charAt 0) (Js.string \"?\")\n       then l##.search##slice_end 1\n       else l##.search)\n\n  let get_fragment () =\n    let s = Js.to_bytestring l##.hash in\n    if String.length s > 0 && Char.equal s.[0] '#'\n    then String.sub s 1 (String.length s - 1)\n    else s\n\n  let set_fragment s = l##.hash := Js.bytestring s\n\n  let get () = url_of_js_string l##.href\n\n  let set u = l##.href := Js.bytestring (string_of_url u)\n\n  let as_string = urldecode_js_string_string l##.href\nend\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2014 Hugo Heuzard\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\nopen! Import\n\nexternal create_file : name:string -> content:string -> unit = \"caml_create_file\"\n\nexternal read_file : name:string -> string = \"caml_read_file_content\"\n\nlet update_file ~name ~content =\n  let oc = open_out name in\n  output_string oc content;\n  close_out oc\n\nexternal set_channel_output' :\n  out_channel -> (Js.js_string Js.t -> unit) Js.callback -> unit\n  = \"caml_ml_set_channel_output\"\n\nexternal set_channel_input' : in_channel -> (unit -> string) Js.callback -> unit\n  = \"caml_ml_set_channel_refill\"\n\nlet set_channel_flusher (out_channel : out_channel) (f : string -> unit) =\n  let f' : (Js.js_string Js.t -> unit) Js.callback =\n    Js.wrap_callback (fun s -> f (Js.to_bytestring s))\n  in\n  set_channel_output' out_channel f'\n\nlet set_channel_filler (in_channel : in_channel) (f : unit -> string) =\n  let f' : (unit -> string) Js.callback = Js.wrap_callback f in\n  set_channel_input' in_channel f'\n\nexternal mount_point : unit -> string list = \"caml_list_mount_point\"\n\nexternal mount_autoload :\n  string -> (string -> string -> string option) Js.callback -> unit\n  = \"caml_mount_autoload\"\n\nexternal unmount : string -> unit = \"caml_unmount\"\n\nlet mount ~path f =\n  mount_autoload path (Js.wrap_callback (fun prefix path -> f ~prefix ~path))\n\nlet unmount ~path = unmount path\n\nlet js_of_ocaml_version =\n  if String.equal Lib_version.git_version \"\"\n  then Lib_version.s\n  else Lib_version.s ^ \"+\" ^ Lib_version.git_version\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2019 Alexander Yanin\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\nopen! Import\n\nclass type resizeObserverSize = object\n  method inlineSize : Js.number_t Js.readonly_prop\n\n  method blockSize : Js.number_t Js.readonly_prop\nend\n\nclass type resizeObserverEntry = object\n  method target : Dom.node Js.t Js.readonly_prop\n\n  method contentRect : Dom_html.clientRect Js.t Js.readonly_prop\n\n  method borderBoxSize : resizeObserverSize Js.t Js.js_array Js.t Js.readonly_prop\n\n  method contentBoxSize : resizeObserverSize Js.t Js.js_array Js.t Js.readonly_prop\nend\n\nclass type resizeObserverOptions = object\n  method box : Js.js_string Js.t Js.writeonly_prop\nend\n\nclass type resizeObserver = object\n  method observe : #Dom.node Js.t -> unit Js.meth\n\n  method observe_withOptions :\n    #Dom.node Js.t -> resizeObserverOptions Js.t -> unit Js.meth\n\n  method unobserve : #Dom.node Js.t -> unit Js.meth\n\n  method disconnect : unit Js.meth\nend\n\nlet empty_resize_observer_options () : resizeObserverOptions Js.t = Js.Unsafe.obj [||]\n\nlet resizeObserver = Js.Unsafe.global##._ResizeObserver\n\nlet is_supported () = Js.Optdef.test resizeObserver\n\nlet resizeObserver :\n    (   (resizeObserverEntry Js.t Js.js_array Js.t -> resizeObserver Js.t -> unit)\n        Js.callback\n     -> resizeObserver Js.t)\n    Js.constr =\n  resizeObserver\n\nlet observe\n    ~(node : #Dom.node Js.t)\n    ~(f : resizeObserverEntry Js.t Js.js_array Js.t -> resizeObserver Js.t -> unit)\n    ?(box : Js.js_string Js.t option)\n    () : resizeObserver Js.t =\n  let obs = new%js resizeObserver (Js.wrap_callback f) in\n  (match box with\n  | None -> obs##observe node\n  | Some box ->\n      let opts = empty_resize_observer_options () in\n      opts##.box := box;\n      obs##observe_withOptions node opts);\n  obs\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2021 Philip White\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\nopen! Import\n\nclass type performanceObserverInit = object\n  method entryTypes : Js.js_string Js.t Js.js_array Js.t Js.writeonly_prop\nend\n\nclass type performanceEntry = object\n  method name : Js.js_string Js.t Js.readonly_prop\n\n  method entryType : Js.js_string Js.t Js.readonly_prop\n\n  method startTime : Js.number_t Js.readonly_prop\n\n  method duration : Js.number_t Js.readonly_prop\nend\n\nclass type performanceObserverEntryList = object\n  method getEntries : performanceEntry Js.t Js.js_array Js.t Js.meth\nend\n\nclass type performanceObserver = object\n  method observe : performanceObserverInit Js.t -> unit Js.meth\n\n  method disconnect : unit Js.meth\n\n  method takeRecords : performanceEntry Js.t Js.js_array Js.t Js.meth\nend\n\nlet performanceObserver = Js.Unsafe.global##._PerformanceObserver\n\nlet is_supported () = Js.Optdef.test performanceObserver\n\nlet performanceObserver :\n    (   (performanceObserverEntryList Js.t -> performanceObserver Js.t -> unit) Js.callback\n     -> performanceObserver Js.t)\n    Js.constr =\n  performanceObserver\n\nlet observe ~entry_types ~f =\n  let entry_types = entry_types |> List.map Js.string |> Array.of_list |> Js.array in\n  let performance_observer_init : performanceObserverInit Js.t = Js.Unsafe.obj [||] in\n  let () = performance_observer_init##.entryTypes := entry_types in\n  let obs = new%js performanceObserver (Js.wrap_callback f) in\n  let () = obs##observe performance_observer_init in\n  obs\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2015 Stéphane Legrand\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\nopen! Import\n\nclass type mutationObserverInit = object\n  method childList : bool Js.writeonly_prop\n\n  method attributes : bool Js.writeonly_prop\n\n  method characterData : bool Js.writeonly_prop\n\n  method subtree : bool Js.writeonly_prop\n\n  method attributeOldValue : bool Js.writeonly_prop\n\n  method characterDataOldValue : bool Js.writeonly_prop\n\n  method attributeFilter : Js.js_string Js.t Js.js_array Js.t Js.writeonly_prop\nend\n\nclass type mutationRecord = object\n  method _type : Js.js_string Js.t Js.readonly_prop\n\n  method target : Dom.node Js.t Js.readonly_prop\n\n  method addedNodes : Dom.node Dom.nodeList Js.t Js.readonly_prop\n\n  method removedNodes : Dom.node Dom.nodeList Js.t Js.readonly_prop\n\n  method previousSibling : Dom.node Js.t Js.opt Js.readonly_prop\n\n  method nextSibling : Dom.node Js.t Js.opt Js.readonly_prop\n\n  method attributeName : Js.js_string Js.t Js.opt Js.readonly_prop\n\n  method attributeNamespace : Js.js_string Js.t Js.opt Js.readonly_prop\n\n  method oldValue : Js.js_string Js.t Js.opt Js.readonly_prop\nend\n\nclass type mutationObserver = object\n  method observe : #Dom.node Js.t -> mutationObserverInit Js.t -> unit Js.meth\n\n  method disconnect : unit Js.meth\n\n  method takeRecords : mutationRecord Js.t Js.js_array Js.t Js.meth\nend\n\nlet empty_mutation_observer_init () : mutationObserverInit Js.t = Js.Unsafe.obj [||]\n\nlet mutationObserver = Js.Unsafe.global##._MutationObserver\n\nlet is_supported () = Js.Optdef.test mutationObserver\n\nlet mutationObserver :\n    (   (mutationRecord Js.t Js.js_array Js.t -> mutationObserver Js.t -> unit) Js.callback\n     -> mutationObserver Js.t)\n    Js.constr =\n  mutationObserver\n\nlet observe\n    ~(node : #Dom.node Js.t)\n    ~(f : mutationRecord Js.t Js.js_array Js.t -> mutationObserver Js.t -> unit)\n    ?(child_list : bool option)\n    ?(attributes : bool option)\n    ?(character_data : bool option)\n    ?(subtree : bool option)\n    ?(attribute_old_value : bool option)\n    ?(character_data_old_value : bool option)\n    ?(attribute_filter : Js.js_string Js.t list option)\n    () : mutationObserver Js.t =\n  let opt_iter x f =\n    match x with\n    | None -> ()\n    | Some x -> f x\n  in\n  let obs = new%js mutationObserver (Js.wrap_callback f) in\n  let cfg = empty_mutation_observer_init () in\n  let () = opt_iter child_list (fun v -> cfg##.childList := v) in\n  let () = opt_iter attributes (fun v -> cfg##.attributes := v) in\n  let () = opt_iter character_data (fun v -> cfg##.characterData := v) in\n  let () = opt_iter subtree (fun v -> cfg##.subtree := v) in\n  let () = opt_iter attribute_old_value (fun v -> cfg##.attributeOldValue := v) in\n  let () =\n    opt_iter character_data_old_value (fun v -> cfg##.characterDataOldValue := v)\n  in\n  let () =\n    opt_iter attribute_filter (fun l ->\n        cfg##.attributeFilter := Js.array (Array.of_list l))\n  in\n  let () = obs##observe node cfg in\n  obs\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright Pierre Chambart 2012.\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\nopen! Import\n\ntype 'a t = < > Js.t\n\nlet obj = Js.Unsafe.global##._Object\n\nlet create () : 'a t = new%js obj\n\nlet add (t : 'a t) (k : Js.js_string Js.t) (v : 'a) =\n  (* '_' is added to avoid conflicts with objects methods *)\n  Js.Unsafe.set t (k##concat (Js.string \"_\")) v\n\nlet remove (t : 'a t) (k : Js.js_string Js.t) =\n  Js.Unsafe.delete t (k##concat (Js.string \"_\"))\n\nlet find (t : 'a t) (k : Js.js_string Js.t) : 'a Js.Optdef.t =\n  Js.Unsafe.get t (k##concat (Js.string \"_\"))\n\nlet keys (t : 'a t) : Js.js_string Js.t list =\n  let key_array : Js.js_string Js.t Js.js_array Js.t =\n    Js.Unsafe.global##._Object##keys t\n  in\n  let res = ref [] in\n  for i = 0 to pred key_array##.length do\n    let key =\n      Js.Optdef.get (Js.array_get key_array i) (fun () -> failwith \"Jstable.keys\")\n    in\n    res := key##substring 0 (pred key##.length) :: !res\n  done;\n  List.rev !res\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright Grégoire Henry 2010.\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\nopen Js\nopen! Import\n\nclass type json = object\n  method parse : 'a. js_string t -> 'a meth\n\n  method parse_ :\n    'a 'b 'c 'd. js_string t -> ('b t, js_string t -> 'c -> 'd) meth_callback -> 'a meth\n\n  method stringify : 'a. 'a -> js_string t meth\n\n  method stringify_ :\n    'a 'b 'c 'd. 'a -> ('b, js_string t -> 'c -> 'd) meth_callback -> js_string t meth\nend\n\nlet json : json Js.t = Unsafe.global##._JSON\n\nlet input_reviver =\n  let reviver _this _key (value : Unsafe.any) : Obj.t =\n    if Js.equals (typeof value) (string \"string\")\n    then Obj.repr (to_bytestring (Unsafe.coerce value))\n    else if instanceof value Js.array_empty\n            && (Unsafe.coerce value)##.length == 4\n            && Unsafe.get value 0 == 255\n    then\n      Obj.repr\n        (Jsoo_runtime.Int64.create_int64_lo_mi_hi\n           (Unsafe.get value 1)\n           (Unsafe.get value 2)\n           (Unsafe.get value 3))\n    else Obj.repr value\n  in\n  wrap_meth_callback reviver\n\nlet unsafe_input s = json##parse_ s input_reviver\n\nclass type obj = object\n  method constructor : 'a. 'a constr Js.readonly_prop\nend\n\nlet mlInt64_constr =\n  let dummy_int64 = 1L in\n  let dummy_obj : obj t = Obj.magic dummy_int64 in\n  dummy_obj##.constructor\n\nlet output_reviver _key (value : Unsafe.any) : Obj.t =\n  if Obj.tag (Obj.repr value) = Obj.string_tag\n  then Obj.repr (bytestring (Obj.magic value : string))\n  else if instanceof value mlInt64_constr\n  then\n    let value = Unsafe.coerce value in\n    Obj.repr (array [| 255; value##.lo; value##.mi; value##.hi |])\n  else Obj.repr value\n\nlet output obj = json##stringify_ obj (Js.wrap_callback output_reviver)\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2010 Raphaël Proust\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\nopen! Import\n\nmodule Color = struct\n  (* The type of CSS colors. First by name and then by constructor. *)\n  type name =\n    | Aliceblue\n    | Antiquewhite\n    | Aqua\n    | Aquamarine\n    | Azure\n    | Beige\n    | Bisque\n    | Black\n    | Blanchedalmond\n    | Blue\n    | Blueviolet\n    | Brown\n    | Burlywood\n    | Cadetblue\n    | Chartreuse\n    | Chocolate\n    | Coral\n    | Cornflowerblue\n    | Cornsilk\n    | Crimson\n    | Cyan\n    | Darkblue\n    | Darkcyan\n    | Darkgoldenrod\n    | Darkgray\n    | Darkgreen\n    | Darkgrey\n    | Darkkhaki\n    | Darkmagenta\n    | Darkolivegreen\n    | Darkorange\n    | Darkorchid\n    | Darkred\n    | Darksalmon\n    | Darkseagreen\n    | Darkslateblue\n    | Darkslategray\n    | Darkslategrey\n    | Darkturquoise\n    | Darkviolet\n    | Deeppink\n    | Deepskyblue\n    | Dimgray\n    | Dimgrey\n    | Dodgerblue\n    | Firebrick\n    | Floralwhite\n    | Forestgreen\n    | Fuchsia\n    | Gainsboro\n    | Ghostwhite\n    | Gold\n    | Goldenrod\n    | Gray\n    | Grey\n    | Green\n    | Greenyellow\n    | Honeydew\n    | Hotpink\n    | Indianred\n    | Indigo\n    | Ivory\n    | Khaki\n    | Lavender\n    | Lavenderblush\n    | Lawngreen\n    | Lemonchiffon\n    | Lightblue\n    | Lightcoral\n    | Lightcyan\n    | Lightgoldenrodyellow\n    | Lightgray\n    | Lightgreen\n    | Lightgrey\n    | Lightpink\n    | Lightsalmon\n    | Lightseagreen\n    | Lightskyblue\n    | Lightslategray\n    | Lightslategrey\n    | Lightsteelblue\n    | Lightyellow\n    | Lime\n    | Limegreen\n    | Linen\n    | Magenta\n    | Maroon\n    | Mediumaquamarine\n    | Mediumblue\n    | Mediumorchid\n    | Mediumpurple\n    | Mediumseagreen\n    | Mediumslateblue\n    | Mediumspringgreen\n    | Mediumturquoise\n    | Mediumvioletred\n    | Midnightblue\n    | Mintcream\n    | Mistyrose\n    | Moccasin\n    | Navajowhite\n    | Navy\n    | Oldlace\n    | Olive\n    | Olivedrab\n    | Orange\n    | Orangered\n    | Orchid\n    | Palegoldenrod\n    | Palegreen\n    | Paleturquoise\n    | Palevioletred\n    | Papayawhip\n    | Peachpuff\n    | Peru\n    | Pink\n    | Plum\n    | Powderblue\n    | Purple\n    | Red\n    | Rosybrown\n    | Royalblue\n    | Saddlebrown\n    | Salmon\n    | Sandybrown\n    | Seagreen\n    | Seashell\n    | Sienna\n    | Silver\n    | Skyblue\n    | Slateblue\n    | Slategray\n    | Slategrey\n    | Snow\n    | Springgreen\n    | Steelblue\n    | Tan\n    | Teal\n    | Thistle\n    | Tomato\n    | Turquoise\n    | Violet\n    | Wheat\n    | White\n    | Whitesmoke\n    | Yellow\n    | Yellowgreen\n\n  let string_of_name = function\n    | Aliceblue -> \"aliceblue\"\n    | Antiquewhite -> \"antiquewhite\"\n    | Aqua -> \"aqua\"\n    | Aquamarine -> \"aquamarine\"\n    | Azure -> \"azure\"\n    | Beige -> \"beige\"\n    | Bisque -> \"bisque\"\n    | Black -> \"black\"\n    | Blanchedalmond -> \"blanchedalmond\"\n    | Blue -> \"blue\"\n    | Blueviolet -> \"blueviolet\"\n    | Brown -> \"brown\"\n    | Burlywood -> \"burlywood\"\n    | Cadetblue -> \"cadetblue\"\n    | Chartreuse -> \"chartreuse\"\n    | Chocolate -> \"chocolate\"\n    | Coral -> \"coral\"\n    | Cornflowerblue -> \"cornflowerblue\"\n    | Cornsilk -> \"cornsilk\"\n    | Crimson -> \"crimson\"\n    | Cyan -> \"cyan\"\n    | Darkblue -> \"darkblue\"\n    | Darkcyan -> \"darkcyan\"\n    | Darkgoldenrod -> \"darkgoldenrod\"\n    | Darkgray -> \"darkgray\"\n    | Darkgreen -> \"darkgreen\"\n    | Darkgrey -> \"darkgrey\"\n    | Darkkhaki -> \"darkkhaki\"\n    | Darkmagenta -> \"darkmagenta\"\n    | Darkolivegreen -> \"darkolivegreen\"\n    | Darkorange -> \"darkorange\"\n    | Darkorchid -> \"darkorchid\"\n    | Darkred -> \"darkred\"\n    | Darksalmon -> \"darksalmon\"\n    | Darkseagreen -> \"darkseagreen\"\n    | Darkslateblue -> \"darkslateblue\"\n    | Darkslategray -> \"darkslategray\"\n    | Darkslategrey -> \"darkslategrey\"\n    | Darkturquoise -> \"darkturquoise\"\n    | Darkviolet -> \"darkviolet\"\n    | Deeppink -> \"deeppink\"\n    | Deepskyblue -> \"deepskyblue\"\n    | Dimgray -> \"dimgray\"\n    | Dimgrey -> \"dimgrey\"\n    | Dodgerblue -> \"dodgerblue\"\n    | Firebrick -> \"firebrick\"\n    | Floralwhite -> \"floralwhite\"\n    | Forestgreen -> \"forestgreen\"\n    | Fuchsia -> \"fuchsia\"\n    | Gainsboro -> \"gainsboro\"\n    | Ghostwhite -> \"ghostwhite\"\n    | Gold -> \"gold\"\n    | Goldenrod -> \"goldenrod\"\n    | Gray -> \"gray\"\n    | Green -> \"green\"\n    | Greenyellow -> \"greenyellow\"\n    | Grey -> \"grey\"\n    | Honeydew -> \"honeydew\"\n    | Hotpink -> \"hotpink\"\n    | Indianred -> \"indianred\"\n    | Indigo -> \"indigo\"\n    | Ivory -> \"ivory\"\n    | Khaki -> \"khaki\"\n    | Lavender -> \"lavender\"\n    | Lavenderblush -> \"lavenderblush\"\n    | Lawngreen -> \"lawngreen\"\n    | Lemonchiffon -> \"lemonchiffon\"\n    | Lightblue -> \"lightblue\"\n    | Lightcoral -> \"lightcoral\"\n    | Lightcyan -> \"lightcyan\"\n    | Lightgoldenrodyellow -> \"lightgoldenrodyellow\"\n    | Lightgray -> \"lightgray\"\n    | Lightgreen -> \"lightgreen\"\n    | Lightgrey -> \"lightgrey\"\n    | Lightpink -> \"lightpink\"\n    | Lightsalmon -> \"lightsalmon\"\n    | Lightseagreen -> \"lightseagreen\"\n    | Lightskyblue -> \"lightskyblue\"\n    | Lightslategray -> \"lightslategray\"\n    | Lightslategrey -> \"lightslategrey\"\n    | Lightsteelblue -> \"lightsteelblue\"\n    | Lightyellow -> \"lightyellow\"\n    | Lime -> \"lime\"\n    | Limegreen -> \"limegreen\"\n    | Linen -> \"linen\"\n    | Magenta -> \"magenta\"\n    | Maroon -> \"maroon\"\n    | Mediumaquamarine -> \"mediumaquamarine\"\n    | Mediumblue -> \"mediumblue\"\n    | Mediumorchid -> \"mediumorchid\"\n    | Mediumpurple -> \"mediumpurple\"\n    | Mediumseagreen -> \"mediumseagreen\"\n    | Mediumslateblue -> \"mediumslateblue\"\n    | Mediumspringgreen -> \"mediumspringgreen\"\n    | Mediumturquoise -> \"mediumturquoise\"\n    | Mediumvioletred -> \"mediumvioletred\"\n    | Midnightblue -> \"midnightblue\"\n    | Mintcream -> \"mintcream\"\n    | Mistyrose -> \"mistyrose\"\n    | Moccasin -> \"moccasin\"\n    | Navajowhite -> \"navajowhite\"\n    | Navy -> \"navy\"\n    | Oldlace -> \"oldlace\"\n    | Olive -> \"olive\"\n    | Olivedrab -> \"olivedrab\"\n    | Orange -> \"orange\"\n    | Orangered -> \"orangered\"\n    | Orchid -> \"orchid\"\n    | Palegoldenrod -> \"palegoldenrod\"\n    | Palegreen -> \"palegreen\"\n    | Paleturquoise -> \"paleturquoise\"\n    | Palevioletred -> \"palevioletred\"\n    | Papayawhip -> \"papayawhip\"\n    | Peachpuff -> \"peachpuff\"\n    | Peru -> \"peru\"\n    | Pink -> \"pink\"\n    | Plum -> \"plum\"\n    | Powderblue -> \"powderblue\"\n    | Purple -> \"purple\"\n    | Red -> \"red\"\n    | Rosybrown -> \"rosybrown\"\n    | Royalblue -> \"royalblue\"\n    | Saddlebrown -> \"saddlebrown\"\n    | Salmon -> \"salmon\"\n    | Sandybrown -> \"sandybrown\"\n    | Seagreen -> \"seagreen\"\n    | Seashell -> \"seashell\"\n    | Sienna -> \"sienna\"\n    | Silver -> \"silver\"\n    | Skyblue -> \"skyblue\"\n    | Slateblue -> \"slateblue\"\n    | Slategray -> \"slategray\"\n    | Slategrey -> \"slategrey\"\n    | Snow -> \"snow\"\n    | Springgreen -> \"springgreen\"\n    | Steelblue -> \"steelblue\"\n    | Tan -> \"tan\"\n    | Teal -> \"teal\"\n    | Thistle -> \"thistle\"\n    | Tomato -> \"tomato\"\n    | Turquoise -> \"turquoise\"\n    | Violet -> \"violet\"\n    | Wheat -> \"wheat\"\n    | White -> \"white\"\n    | Whitesmoke -> \"whitesmoke\"\n    | Yellow -> \"yellow\"\n    | Yellowgreen -> \"yellowgreen\"\n\n  let name_of_string = function\n    | \"aliceblue\" -> Aliceblue\n    | \"antiquewhite\" -> Antiquewhite\n    | \"aqua\" -> Aqua\n    | \"aquamarine\" -> Aquamarine\n    | \"azure\" -> Azure\n    | \"beige\" -> Beige\n    | \"bisque\" -> Bisque\n    | \"black\" -> Black\n    | \"blanchedalmond\" -> Blanchedalmond\n    | \"blue\" -> Blue\n    | \"blueviolet\" -> Blueviolet\n    | \"brown\" -> Brown\n    | \"burlywood\" -> Burlywood\n    | \"cadetblue\" -> Cadetblue\n    | \"chartreuse\" -> Chartreuse\n    | \"chocolate\" -> Chocolate\n    | \"coral\" -> Coral\n    | \"cornflowerblue\" -> Cornflowerblue\n    | \"cornsilk\" -> Cornsilk\n    | \"crimson\" -> Crimson\n    | \"cyan\" -> Cyan\n    | \"darkblue\" -> Darkblue\n    | \"darkcyan\" -> Darkcyan\n    | \"darkgoldenrod\" -> Darkgoldenrod\n    | \"darkgray\" -> Darkgray\n    | \"darkgreen\" -> Darkgreen\n    | \"darkgrey\" -> Darkgrey\n    | \"darkkhaki\" -> Darkkhaki\n    | \"darkmagenta\" -> Darkmagenta\n    | \"darkolivegreen\" -> Darkolivegreen\n    | \"darkorange\" -> Darkorange\n    | \"darkorchid\" -> Darkorchid\n    | \"darkred\" -> Darkred\n    | \"darksalmon\" -> Darksalmon\n    | \"darkseagreen\" -> Darkseagreen\n    | \"darkslateblue\" -> Darkslateblue\n    | \"darkslategray\" -> Darkslategray\n    | \"darkslategrey\" -> Darkslategrey\n    | \"darkturquoise\" -> Darkturquoise\n    | \"darkviolet\" -> Darkviolet\n    | \"deeppink\" -> Deeppink\n    | \"deepskyblue\" -> Deepskyblue\n    | \"dimgray\" -> Dimgray\n    | \"dimgrey\" -> Dimgrey\n    | \"dodgerblue\" -> Dodgerblue\n    | \"firebrick\" -> Firebrick\n    | \"floralwhite\" -> Floralwhite\n    | \"forestgreen\" -> Forestgreen\n    | \"fuchsia\" -> Fuchsia\n    | \"gainsboro\" -> Gainsboro\n    | \"ghostwhite\" -> Ghostwhite\n    | \"gold\" -> Gold\n    | \"goldenrod\" -> Goldenrod\n    | \"gray\" -> Gray\n    | \"green\" -> Green\n    | \"greenyellow\" -> Greenyellow\n    | \"grey\" -> Grey\n    | \"honeydew\" -> Honeydew\n    | \"hotpink\" -> Hotpink\n    | \"indianred\" -> Indianred\n    | \"indigo\" -> Indigo\n    | \"ivory\" -> Ivory\n    | \"khaki\" -> Khaki\n    | \"lavender\" -> Lavender\n    | \"lavenderblush\" -> Lavenderblush\n    | \"lawngreen\" -> Lawngreen\n    | \"lemonchiffon\" -> Lemonchiffon\n    | \"lightblue\" -> Lightblue\n    | \"lightcoral\" -> Lightcoral\n    | \"lightcyan\" -> Lightcyan\n    | \"lightgoldenrodyellow\" -> Lightgoldenrodyellow\n    | \"lightgray\" -> Lightgray\n    | \"lightgreen\" -> Lightgreen\n    | \"lightgrey\" -> Lightgrey\n    | \"lightpink\" -> Lightpink\n    | \"lightsalmon\" -> Lightsalmon\n    | \"lightseagreen\" -> Lightseagreen\n    | \"lightskyblue\" -> Lightskyblue\n    | \"lightslategray\" -> Lightslategray\n    | \"lightslategrey\" -> Lightslategrey\n    | \"lightsteelblue\" -> Lightsteelblue\n    | \"lightyellow\" -> Lightyellow\n    | \"lime\" -> Lime\n    | \"limegreen\" -> Limegreen\n    | \"linen\" -> Linen\n    | \"magenta\" -> Magenta\n    | \"maroon\" -> Maroon\n    | \"mediumaquamarine\" -> Mediumaquamarine\n    | \"mediumblue\" -> Mediumblue\n    | \"mediumorchid\" -> Mediumorchid\n    | \"mediumpurple\" -> Mediumpurple\n    | \"mediumseagreen\" -> Mediumseagreen\n    | \"mediumslateblue\" -> Mediumslateblue\n    | \"mediumspringgreen\" -> Mediumspringgreen\n    | \"mediumturquoise\" -> Mediumturquoise\n    | \"mediumvioletred\" -> Mediumvioletred\n    | \"midnightblue\" -> Midnightblue\n    | \"mintcream\" -> Mintcream\n    | \"mistyrose\" -> Mistyrose\n    | \"moccasin\" -> Moccasin\n    | \"navajowhite\" -> Navajowhite\n    | \"navy\" -> Navy\n    | \"oldlace\" -> Oldlace\n    | \"olive\" -> Olive\n    | \"olivedrab\" -> Olivedrab\n    | \"orange\" -> Orange\n    | \"orangered\" -> Orangered\n    | \"orchid\" -> Orchid\n    | \"palegoldenrod\" -> Palegoldenrod\n    | \"palegreen\" -> Palegreen\n    | \"paleturquoise\" -> Paleturquoise\n    | \"palevioletred\" -> Palevioletred\n    | \"papayawhip\" -> Papayawhip\n    | \"peachpuff\" -> Peachpuff\n    | \"peru\" -> Peru\n    | \"pink\" -> Pink\n    | \"plum\" -> Plum\n    | \"powderblue\" -> Powderblue\n    | \"purple\" -> Purple\n    | \"red\" -> Red\n    | \"rosybrown\" -> Rosybrown\n    | \"royalblue\" -> Royalblue\n    | \"saddlebrown\" -> Saddlebrown\n    | \"salmon\" -> Salmon\n    | \"sandybrown\" -> Sandybrown\n    | \"seagreen\" -> Seagreen\n    | \"seashell\" -> Seashell\n    | \"sienna\" -> Sienna\n    | \"silver\" -> Silver\n    | \"skyblue\" -> Skyblue\n    | \"slateblue\" -> Slateblue\n    | \"slategray\" -> Slategray\n    | \"slategrey\" -> Slategrey\n    | \"snow\" -> Snow\n    | \"springgreen\" -> Springgreen\n    | \"steelblue\" -> Steelblue\n    | \"tan\" -> Tan\n    | \"teal\" -> Teal\n    | \"thistle\" -> Thistle\n    | \"tomato\" -> Tomato\n    | \"turquoise\" -> Turquoise\n    | \"violet\" -> Violet\n    | \"wheat\" -> Wheat\n    | \"white\" -> White\n    | \"whitesmoke\" -> Whitesmoke\n    | \"yellow\" -> Yellow\n    | \"yellowgreen\" -> Yellowgreen\n    | s -> raise (Invalid_argument (s ^ \" is not a valid color name\"))\n\n  let rgb_of_name = function\n    | Aliceblue -> 240, 248, 255\n    | Antiquewhite -> 250, 235, 215\n    | Aqua -> 0, 255, 255\n    | Aquamarine -> 127, 255, 212\n    | Azure -> 240, 255, 255\n    | Beige -> 245, 245, 220\n    | Bisque -> 255, 228, 196\n    | Black -> 0, 0, 0\n    | Blanchedalmond -> 255, 235, 205\n    | Blue -> 0, 0, 255\n    | Blueviolet -> 138, 43, 226\n    | Brown -> 165, 42, 42\n    | Burlywood -> 222, 184, 135\n    | Cadetblue -> 95, 158, 160\n    | Chartreuse -> 127, 255, 0\n    | Chocolate -> 210, 105, 30\n    | Coral -> 255, 127, 80\n    | Cornflowerblue -> 100, 149, 237\n    | Cornsilk -> 255, 248, 220\n    | Crimson -> 220, 20, 60\n    | Cyan -> 0, 255, 255\n    | Darkblue -> 0, 0, 139\n    | Darkcyan -> 0, 139, 139\n    | Darkgoldenrod -> 184, 134, 11\n    | Darkgray -> 169, 169, 169\n    | Darkgreen -> 0, 100, 0\n    | Darkgrey -> 169, 169, 169\n    | Darkkhaki -> 189, 183, 107\n    | Darkmagenta -> 139, 0, 139\n    | Darkolivegreen -> 85, 107, 47\n    | Darkorange -> 255, 140, 0\n    | Darkorchid -> 153, 50, 204\n    | Darkred -> 139, 0, 0\n    | Darksalmon -> 233, 150, 122\n    | Darkseagreen -> 143, 188, 143\n    | Darkslateblue -> 72, 61, 139\n    | Darkslategray -> 47, 79, 79\n    | Darkslategrey -> 47, 79, 79\n    | Darkturquoise -> 0, 206, 209\n    | Darkviolet -> 148, 0, 211\n    | Deeppink -> 255, 20, 147\n    | Deepskyblue -> 0, 191, 255\n    | Dimgray -> 105, 105, 105\n    | Dimgrey -> 105, 105, 105\n    | Dodgerblue -> 30, 144, 255\n    | Firebrick -> 178, 34, 34\n    | Floralwhite -> 255, 250, 240\n    | Forestgreen -> 34, 139, 34\n    | Fuchsia -> 255, 0, 255\n    | Gainsboro -> 220, 220, 220\n    | Ghostwhite -> 248, 248, 255\n    | Gold -> 255, 215, 0\n    | Goldenrod -> 218, 165, 32\n    | Gray -> 128, 128, 128\n    | Green -> 0, 128, 0\n    | Greenyellow -> 173, 255, 47\n    | Grey -> 128, 128, 128\n    | Honeydew -> 240, 255, 240\n    | Hotpink -> 255, 105, 180\n    | Indianred -> 205, 92, 92\n    | Indigo -> 75, 0, 130\n    | Ivory -> 255, 255, 240\n    | Khaki -> 240, 230, 140\n    | Lavender -> 230, 230, 250\n    | Lavenderblush -> 255, 240, 245\n    | Lawngreen -> 124, 252, 0\n    | Lemonchiffon -> 255, 250, 205\n    | Lightblue -> 173, 216, 230\n    | Lightcoral -> 240, 128, 128\n    | Lightcyan -> 224, 255, 255\n    | Lightgoldenrodyellow -> 250, 250, 210\n    | Lightgray -> 211, 211, 211\n    | Lightgreen -> 144, 238, 144\n    | Lightgrey -> 211, 211, 211\n    | Lightpink -> 255, 182, 193\n    | Lightsalmon -> 255, 160, 122\n    | Lightseagreen -> 32, 178, 170\n    | Lightskyblue -> 135, 206, 250\n    | Lightslategray -> 119, 136, 153\n    | Lightslategrey -> 119, 136, 153\n    | Lightsteelblue -> 176, 196, 222\n    | Lightyellow -> 255, 255, 224\n    | Lime -> 0, 255, 0\n    | Limegreen -> 50, 205, 50\n    | Linen -> 250, 240, 230\n    | Magenta -> 255, 0, 255\n    | Maroon -> 128, 0, 0\n    | Mediumaquamarine -> 102, 205, 170\n    | Mediumblue -> 0, 0, 205\n    | Mediumorchid -> 186, 85, 211\n    | Mediumpurple -> 147, 112, 219\n    | Mediumseagreen -> 60, 179, 113\n    | Mediumslateblue -> 123, 104, 238\n    | Mediumspringgreen -> 0, 250, 154\n    | Mediumturquoise -> 72, 209, 204\n    | Mediumvioletred -> 199, 21, 133\n    | Midnightblue -> 25, 25, 112\n    | Mintcream -> 245, 255, 250\n    | Mistyrose -> 255, 228, 225\n    | Moccasin -> 255, 228, 181\n    | Navajowhite -> 255, 222, 173\n    | Navy -> 0, 0, 128\n    | Oldlace -> 253, 245, 230\n    | Olive -> 128, 128, 0\n    | Olivedrab -> 107, 142, 35\n    | Orange -> 255, 165, 0\n    | Orangered -> 255, 69, 0\n    | Orchid -> 218, 112, 214\n    | Palegoldenrod -> 238, 232, 170\n    | Palegreen -> 152, 251, 152\n    | Paleturquoise -> 175, 238, 238\n    | Palevioletred -> 219, 112, 147\n    | Papayawhip -> 255, 239, 213\n    | Peachpuff -> 255, 218, 185\n    | Peru -> 205, 133, 63\n    | Pink -> 255, 192, 203\n    | Plum -> 221, 160, 221\n    | Powderblue -> 176, 224, 230\n    | Purple -> 128, 0, 128\n    | Red -> 255, 0, 0\n    | Rosybrown -> 188, 143, 143\n    | Royalblue -> 65, 105, 225\n    | Saddlebrown -> 139, 69, 19\n    | Salmon -> 250, 128, 114\n    | Sandybrown -> 244, 164, 96\n    | Seagreen -> 46, 139, 87\n    | Seashell -> 255, 245, 238\n    | Sienna -> 160, 82, 45\n    | Silver -> 192, 192, 192\n    | Skyblue -> 135, 206, 235\n    | Slateblue -> 106, 90, 205\n    | Slategray -> 112, 128, 144\n    | Slategrey -> 112, 128, 144\n    | Snow -> 255, 250, 250\n    | Springgreen -> 0, 255, 127\n    | Steelblue -> 70, 130, 180\n    | Tan -> 210, 180, 140\n    | Teal -> 0, 128, 128\n    | Thistle -> 216, 191, 216\n    | Tomato -> 255, 99, 71\n    | Turquoise -> 64, 224, 208\n    | Violet -> 238, 130, 238\n    | Wheat -> 245, 222, 179\n    | White -> 255, 255, 255\n    | Whitesmoke -> 245, 245, 245\n    | Yellow -> 255, 255, 0\n    | Yellowgreen -> 154, 205, 50\n\n  type t =\n    | Name of name\n    | RGB of (int * int * int)\n        (** Red, Green and Blue values. Clipped to [[0..255]] by most (All?)\n            browsers. *)\n    | RGB_percent of (int * int * int)\n        (** RGB channels are specified as a percentage of their maximal value. *)\n    | RGBA of (int * int * int * float)\n        (** Same as RGB with additional transparency argument. Opacity should be in\n            [0.] (completely transparent) and [1.] (completely opaque). *)\n    | RGBA_percent of (int * int * int * float)\n        (** RGB channels specified as percentage of their maximal value. Alpha\n            channel (opacity) is still a [0.] to [1.] float. *)\n    | HSL of (int * int * int)\n        (** Hue, Saturation and Lightness values. Hue is an angle in degree (in\n            interval [[0..360[]). Saturation is a percentage ([[0..100]]) with [0]\n            being colorless. Lightness is also a percentage ([[0..100]]) with [0]\n            being black. *)\n    | HSLA of (int * int * int * float)\n        (** Same as HSL with an opacity argument between [0.] and [1.]. *)\n\n  let rgb ?a r g b =\n    match a with\n    | None -> RGB (r, g, b)\n    | Some a -> RGBA (r, g, b, a)\n\n  let hsl ?a h s l =\n    match a with\n    | None -> HSL (h, s, l)\n    | Some a -> HSLA (h, s, l, a)\n\n  let string_of_t = function\n    | Name n -> string_of_name n\n    | RGB (r, g, b) -> Printf.sprintf \"rgb(%d,%d,%d)\" r g b\n    | RGB_percent (r, g, b) -> Printf.sprintf \"rgb(%d%%,%d%%,%d%%)\" r g b\n    | RGBA (r, g, b, a) -> Printf.sprintf \"rgba(%d,%d,%d,%f)\" r g b a\n    | RGBA_percent (r, g, b, a) -> Printf.sprintf \"rgba(%d%%,%d%%,%d%%,%f)\" r g b a\n    | HSL (h, s, l) -> Printf.sprintf \"hsl(%d,%d%%,%d%%)\" h s l\n    | HSLA (h, s, l, a) -> Printf.sprintf \"hsla(%d,%d%%,%d%%,%f)\" h s l a\n\n  let hex_of_rgb (red, green, blue) =\n    let in_range i =\n      if i < 0 || i > 255\n      then raise (Invalid_argument (string_of_int i ^ \" is out of valid range\"))\n    in\n    in_range red;\n    in_range green;\n    in_range blue;\n    Printf.sprintf \"#%02X%02X%02X\" red green blue\n\n  (* Ocaml <-> JS representation *)\n  type js_t = Js.js_string Js.t\n\n  (* TODO? be more restrictive, clip values into standard range *)\n  let js_t_of_js_string s =\n    let rgb_re =\n      new%js Js.regExp (Js.bytestring \"^rgb\\\\(\\\\s*\\\\d*,\\\\s*\\\\d*,\\\\s*\\\\d*\\\\)$\")\n    in\n    let rgb_pct_re =\n      new%js Js.regExp (Js.bytestring \"^rgb\\\\(\\\\s*\\\\d*%,\\\\s*\\\\d*%,\\\\s*\\\\d*%\\\\)$\")\n    in\n    let rgba_re =\n      new%js Js.regExp\n        (Js.bytestring \"^rgba\\\\(\\\\s*\\\\d*,\\\\s*\\\\d*,\\\\s*\\\\d*,\\\\d*\\\\.?\\\\d*\\\\)$\")\n    in\n    let rgba_pct_re =\n      new%js Js.regExp\n        (Js.bytestring \"^rgba\\\\(\\\\s*\\\\d*%,\\\\s*\\\\d*%,\\\\s*\\\\d*%,\\\\d*\\\\.?\\\\d*\\\\)$\")\n    in\n    let hsl_re =\n      new%js Js.regExp (Js.bytestring \"^hsl\\\\(\\\\s*\\\\d*,\\\\s*\\\\d*%,\\\\s*\\\\d*%\\\\)$\")\n    in\n    let hsla_re =\n      new%js Js.regExp\n        (Js.bytestring \"^hsla\\\\(\\\\s*\\\\d*,\\\\s*\\\\d*%,\\\\s*\\\\d*%,\\\\d*\\\\.?\\\\d*\\\\)$\")\n    in\n    if Js.to_bool (rgb_re##test s)\n       || Js.to_bool (rgba_re##test s)\n       || Js.to_bool (rgb_pct_re##test s)\n       || Js.to_bool (rgba_pct_re##test s)\n       || Js.to_bool (hsl_re##test s)\n       || Js.to_bool (hsla_re##test s)\n    then s\n    else if List.mem\n              (Js.to_string s)\n              [ \"aliceblue\"\n              ; \"antiquewhite\"\n              ; \"aqua\"\n              ; \"aquamarine\"\n              ; \"azure\"\n              ; \"beige\"\n              ; \"bisque\"\n              ; \"black\"\n              ; \"blanchedalmond\"\n              ; \"blue\"\n              ; \"blueviolet\"\n              ; \"brown\"\n              ; \"burlywood\"\n              ; \"cadetblue\"\n              ; \"chartreuse\"\n              ; \"chocolate\"\n              ; \"coral\"\n              ; \"cornflowerblue\"\n              ; \"cornsilk\"\n              ; \"crimson\"\n              ; \"cyan\"\n              ; \"darkblue\"\n              ; \"darkcyan\"\n              ; \"darkgoldenrod\"\n              ; \"darkgray\"\n              ; \"darkgreen\"\n              ; \"darkgrey\"\n              ; \"darkkhaki\"\n              ; \"darkmagenta\"\n              ; \"darkolivegreen\"\n              ; \"darkorange\"\n              ; \"darkorchid\"\n              ; \"darkred\"\n              ; \"darksalmon\"\n              ; \"darkseagreen\"\n              ; \"darkslateblue\"\n              ; \"darkslategray\"\n              ; \"darkslategrey\"\n              ; \"darkturquoise\"\n              ; \"darkviolet\"\n              ; \"deeppink\"\n              ; \"deepskyblue\"\n              ; \"dimgray\"\n              ; \"dimgrey\"\n              ; \"dodgerblue\"\n              ; \"firebrick\"\n              ; \"floralwhite\"\n              ; \"forestgreen\"\n              ; \"fuchsia\"\n              ; \"gainsboro\"\n              ; \"ghostwhite\"\n              ; \"gold\"\n              ; \"goldenrod\"\n              ; \"gray\"\n              ; \"green\"\n              ; \"greenyellow\"\n              ; \"grey\"\n              ; \"honeydew\"\n              ; \"hotpink\"\n              ; \"indianred\"\n              ; \"indigo\"\n              ; \"ivory\"\n              ; \"khaki\"\n              ; \"lavender\"\n              ; \"lavenderblush\"\n              ; \"lawngreen\"\n              ; \"lemonchiffon\"\n              ; \"lightblue\"\n              ; \"lightcoral\"\n              ; \"lightcyan\"\n              ; \"lightgoldenrodyellow\"\n              ; \"lightgray\"\n              ; \"lightgreen\"\n              ; \"lightgrey\"\n              ; \"lightpink\"\n              ; \"lightsalmon\"\n              ; \"lightseagreen\"\n              ; \"lightskyblue\"\n              ; \"lightslategray\"\n              ; \"lightslategrey\"\n              ; \"lightsteelblue\"\n              ; \"lightyellow\"\n              ; \"lime\"\n              ; \"limegreen\"\n              ; \"linen\"\n              ; \"magenta\"\n              ; \"maroon\"\n              ; \"mediumaquamarine\"\n              ; \"mediumblue\"\n              ; \"mediumorchid\"\n              ; \"mediumpurple\"\n              ; \"mediumseagreen\"\n              ; \"mediumslateblue\"\n              ; \"mediumspringgreen\"\n              ; \"mediumturquoise\"\n              ; \"mediumvioletred\"\n              ; \"midnightblue\"\n              ; \"mintcream\"\n              ; \"mistyrose\"\n              ; \"moccasin\"\n              ; \"navajowhite\"\n              ; \"navy\"\n              ; \"oldlace\"\n              ; \"olive\"\n              ; \"olivedrab\"\n              ; \"orange\"\n              ; \"orangered\"\n              ; \"orchid\"\n              ; \"palegoldenrod\"\n              ; \"palegreen\"\n              ; \"paleturquoise\"\n              ; \"palevioletred\"\n              ; \"papayawhip\"\n              ; \"peachpuff\"\n              ; \"peru\"\n              ; \"pink\"\n              ; \"plum\"\n              ; \"powderblue\"\n              ; \"purple\"\n              ; \"red\"\n              ; \"rosybrown\"\n              ; \"royalblue\"\n              ; \"saddlebrown\"\n              ; \"salmon\"\n              ; \"sandybrown\"\n              ; \"seagreen\"\n              ; \"seashell\"\n              ; \"sienna\"\n              ; \"silver\"\n              ; \"skyblue\"\n              ; \"slateblue\"\n              ; \"slategray\"\n              ; \"slategrey\"\n              ; \"snow\"\n              ; \"springgreen\"\n              ; \"steelblue\"\n              ; \"tan\"\n              ; \"teal\"\n              ; \"thistle\"\n              ; \"tomato\"\n              ; \"turquoise\"\n              ; \"violet\"\n              ; \"wheat\"\n              ; \"white\"\n              ; \"whitesmoke\"\n              ; \"yellow\"\n              ; \"yellowgreen\"\n              ]\n    then s\n    else raise (Invalid_argument (Js.to_string s ^ \" is not a valid color\"))\n\n  let name cn = Js.string (string_of_name cn)\n\n  let js = function\n    | Name n -> name n\n    | (RGB _ | RGB_percent _ | RGBA _ | RGBA_percent _ | HSL _ | HSLA _) as c ->\n        Js.string (string_of_t c)\n\n  let ml c =\n    let s = Js.to_string c in\n    try Name (name_of_string s)\n    with Invalid_argument _ -> (\n      let fail () = raise (Invalid_argument (s ^ \" is not a valid color\")) in\n      let re_rgb =\n        Regexp.regexp \"(rgba?)\\\\((?:(\\\\d*),(\\\\d*),(\\\\d*)(?:,(\\\\d*(?:\\\\.\\\\d*)?))?)\\\\)\"\n      in\n      let re_rgb_pct =\n        Regexp.regexp \"(rgba?)\\\\((?:(\\\\d*)%,(\\\\d*)%,(\\\\d*)%(?:,(\\\\d*(?:\\\\.\\\\d*)?))?)\\\\)\"\n      in\n      let re_hsl =\n        Regexp.regexp \"(hsla?)\\\\((?:(\\\\d*),(\\\\d*)%,(\\\\d*)%(?:,(\\\\d*(?:\\\\.\\\\d*)?))?)\\\\)\"\n      in\n      let i_of_s_o = function\n        | None -> fail ()\n        | Some i -> (\n            try int_of_string i\n            with Invalid_argument s | Failure s ->\n              raise (Invalid_argument (\"color conversion error (\" ^ i ^ \"): \" ^ s)))\n      in\n      let f_of_s f =\n        try float_of_string f\n        with Invalid_argument s | Failure s ->\n          raise (Invalid_argument (\"color conversion error (\" ^ f ^ \"): \" ^ s))\n      in\n      match Regexp.string_match re_rgb s 0 with\n      | Some r -> (\n          let red = Regexp.matched_group r 2 in\n          let green = Regexp.matched_group r 3 in\n          let blue = Regexp.matched_group r 4 in\n          let alpha = Regexp.matched_group r 5 in\n          match Regexp.matched_group r 1 with\n          | Some \"rgb\" -> (\n              match alpha with\n              | Some _ -> fail ()\n              | None -> RGB (i_of_s_o red, i_of_s_o green, i_of_s_o blue))\n          | Some \"rgba\" -> (\n              match alpha with\n              | None -> fail ()\n              | Some a -> RGBA (i_of_s_o red, i_of_s_o green, i_of_s_o blue, f_of_s a))\n          | Some _ | None -> fail ())\n      | None -> (\n          match Regexp.string_match re_rgb_pct s 0 with\n          | Some r -> (\n              let red = Regexp.matched_group r 2 in\n              let green = Regexp.matched_group r 3 in\n              let blue = Regexp.matched_group r 4 in\n              let alpha = Regexp.matched_group r 5 in\n              match Regexp.matched_group r 1 with\n              | Some \"rgb\" -> (\n                  match alpha with\n                  | Some _ -> fail ()\n                  | None -> RGB_percent (i_of_s_o red, i_of_s_o green, i_of_s_o blue))\n              | Some \"rgba\" -> (\n                  match alpha with\n                  | None -> fail ()\n                  | Some a ->\n                      RGBA_percent (i_of_s_o red, i_of_s_o green, i_of_s_o blue, f_of_s a)\n                  )\n              | Some _ | None -> fail ())\n          | None -> (\n              match Regexp.string_match re_hsl s 0 with\n              | Some r -> (\n                  let red = Regexp.matched_group r 2 in\n                  let green = Regexp.matched_group r 3 in\n                  let blue = Regexp.matched_group r 4 in\n                  let alpha = Regexp.matched_group r 5 in\n                  match Regexp.matched_group r 1 with\n                  | Some \"hsl\" -> (\n                      match alpha with\n                      | Some _ -> fail ()\n                      | None -> HSL (i_of_s_o red, i_of_s_o green, i_of_s_o blue))\n                  | Some \"hsla\" -> (\n                      match alpha with\n                      | None -> fail ()\n                      | Some a ->\n                          HSLA (i_of_s_o red, i_of_s_o green, i_of_s_o blue, f_of_s a))\n                  | Some _ | None -> fail ())\n              | None -> fail ())))\nend\n\nmodule Length = struct\n  (* http://www.w3.org/TR/css3-values/#lengths *)\n\n  (* TODO:\n     {[\n       type js_t = private Js.string Js.t\n       val js_t_of_t\n       val t_of_js_t\n       val t_of_string\n     ]}\n  *)\n\n  type t =\n    | Zero\n    (* relative *)\n    | Em of float\n    | Ex of float\n    | Px of float\n    | Gd of float\n    | Rem of float\n    | Vw of float\n    | Vh of float\n    | Vm of float\n    | Ch of float\n    (* absolute *)\n    | Mm of float\n    | Cm of float\n    | In of float\n    | Pt of float\n    | Pc of float\n\n  let string_of_t = function\n    | Zero -> \"0\"\n    | Em f -> Printf.sprintf \"%f%s\" f \"em\"\n    | Ex f -> Printf.sprintf \"%f%s\" f \"ex\"\n    | Px f -> Printf.sprintf \"%f%s\" f \"px\"\n    | Gd f -> Printf.sprintf \"%f%s\" f \"gd\"\n    | Rem f -> Printf.sprintf \"%f%s\" f \"rem\"\n    | Vw f -> Printf.sprintf \"%f%s\" f \"vw\"\n    | Vh f -> Printf.sprintf \"%f%s\" f \"vh\"\n    | Vm f -> Printf.sprintf \"%f%s\" f \"vm\"\n    | Ch f -> Printf.sprintf \"%f%s\" f \"ch\"\n    | Mm f -> Printf.sprintf \"%f%s\" f \"mm\"\n    | Cm f -> Printf.sprintf \"%f%s\" f \"cm\"\n    | In f -> Printf.sprintf \"%f%s\" f \"in\"\n    | Pt f -> Printf.sprintf \"%f%s\" f \"pt\"\n    | Pc f -> Printf.sprintf \"%f%s\" f \"pc\"\n\n  type js_t = Js.js_string Js.t\n\n  let js t = Js.string (string_of_t t)\n\n  let ml t =\n    let s = Js.to_string t in\n    if String.equal s \"0\"\n    then Zero\n    else\n      let fail () = raise (Invalid_argument (s ^ \" is not a valid length\")) in\n      let re = Regexp.regexp \"^(\\\\d*(?:\\\\.\\\\d*)?)\\\\s*(\\\\S*)$\" in\n      match Regexp.string_match re s 0 with\n      | None -> fail ()\n      | Some r -> (\n          let f =\n            match Regexp.matched_group r 1 with\n            | None -> fail ()\n            | Some f -> (\n                try float_of_string f\n                with Invalid_argument s ->\n                  raise (Invalid_argument (\"length conversion error: \" ^ s)))\n          in\n          match Regexp.matched_group r 2 with\n          | None -> fail ()\n          | Some \"em\" -> Em f\n          | Some \"ex\" -> Ex f\n          | Some \"px\" -> Px f\n          | Some \"gd\" -> Gd f\n          | Some \"rem\" -> Rem f\n          | Some \"vw\" -> Vw f\n          | Some \"vh\" -> Vh f\n          | Some \"vm\" -> Vm f\n          | Some \"ch\" -> Ch f\n          | Some \"mm\" -> Mm f\n          | Some \"cm\" -> Cm f\n          | Some \"in\" -> In f\n          | Some \"pt\" -> Pt f\n          | Some \"pc\" -> Pc f\n          | Some _ -> fail ())\nend\n\nmodule Angle = struct\n  type t =\n    | Deg of float\n    | Grad of float\n    | Rad of float\n    | Turns of float\n\n  let string_of_t = function\n    | Deg f -> Printf.sprintf \"%f%s\" f \"deg\"\n    | Grad f -> Printf.sprintf \"%f%s\" f \"grad\"\n    | Rad f -> Printf.sprintf \"%f%s\" f \"rad\"\n    | Turns f -> Printf.sprintf \"%f%s\" f \"turns\"\n\n  type js_t = Js.js_string Js.t\n\n  let js t = Js.string (string_of_t t)\n\n  let ml j =\n    let s = Js.to_string j in\n    let re = Regexp.regexp \"^(\\\\d*(?:\\\\.\\\\d*))(deg|grad|rad|turns)$\" in\n    let fail () = raise (Invalid_argument (s ^ \" is not a valid length\")) in\n    match Regexp.string_match re s 0 with\n    | None -> fail ()\n    | Some r -> (\n        let f =\n          match Regexp.matched_group r 1 with\n          | None -> fail ()\n          | Some f -> (\n              try float_of_string f\n              with Invalid_argument s ->\n                raise (Invalid_argument (\"length conversion error: \" ^ s)))\n        in\n        match Regexp.matched_group r 2 with\n        | Some \"deg\" -> Deg f\n        | Some \"grad\" -> Grad f\n        | Some \"rad\" -> Rad f\n        | Some \"turns\" -> Turns f\n        | Some _ | None -> fail ())\nend\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2010 Jérôme Vouillon\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\n(** Javascript events. *)\n\nopen! Import\nmodule Typ = Dom_html.Event\n\ntype listener = Dom_html.event_listener_id\n\nlet listen ?(capture = false) target typ cb =\n  Dom_html.addEventListener\n    target\n    typ\n    (Dom_html.full_handler (fun n e -> Js.bool (cb n e)))\n    (Js.bool capture)\n\nlet stop_listen = Dom_html.removeEventListener\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2014 Hugo Heuzard\n * Copyright (C) 2014 Jérôme Vouillon\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\nopen Js\nopen! Import\n\nlet xmlns = Js.string \"http://www.w3.org/2000/svg\"\n\n(* translate spec from http://www.w3.org/TR/SVG/idl.html *)\n(* http://www.w3.org/TR/SVG/struct.html *)\n\ntype error_code =\n  | WRONG_TYPE_ERR\n  | INVALID_VALUE_ERR\n  | MATRIX_NOT_INVERTABLE\n\nclass type svg_error = object\n  inherit Js.error\n\n  method code : error_code t readonly_prop\nend\n\nexception SVGError of svg_error\n\ntype lengthUnitType =\n  | LENGTHTYPE_UNKNOWN\n  | LENGTHTYPE_NUMBER\n  | LENGTHTYPE_PERCENTAGE\n  | LENGTHTYPE_EMS\n  | LENGTHTYPE_EXS\n  | LENGTHTYPE_PX\n  | LENGTHTYPE_CM\n  | LENGTHTYPE_MM\n  | LENGTHTYPE_IN\n  | LENGTHTYPE_PT\n  | LENGTHTYPE_PC\n\ntype angleUnitType =\n  | ANGLETYPE_UNKNOWN\n  | ANGLETYPE_UNSPECIFIED\n  | ANGLETYPE_DEG\n  | ANGLETYPE_RAD\n  | ANGLETYPE_GRAD\n\ntype colorType =\n  | COLORTYPE_UNKNOWN\n  | COLORTYPE_RGBCOLOR\n  | COLORTYPE_RGBCOLOR_ICCCOLOR\n  | COLORTYPE_CURRENTCOLOR\n\ntype alignmentType =\n  | PRESERVEASPECTRATIO_UNKNOWN\n  | PRESERVEASPECTRATIO_NONE\n  | PRESERVEASPECTRATIO_XMINYMIN\n  | PRESERVEASPECTRATIO_XMIDYMIN\n  | PRESERVEASPECTRATIO_XMAXYMIN\n  | PRESERVEASPECTRATIO_XMINYMID\n  | PRESERVEASPECTRATIO_XMIDYMID\n  | PRESERVEASPECTRATIO_XMAXYMID\n  | PRESERVEASPECTRATIO_XMINYMAX\n  | PRESERVEASPECTRATIO_XMIDYMAX\n  | PRESERVEASPECTRATIO_XMAXYMAX\n\ntype meetOrSliceType =\n  | MEETORSLICE_UNKNOWN\n  | MEETORSLICE_MEET\n  | MEETORSLICE_SLICE\n\ntype transformType =\n  | TRANSFORM_UNKNOWN\n  | TRANSFORM_MATRIX\n  | TRANSFORM_TRANSLATE\n  | TRANSFORM_SCALE\n  | TRANSFORM_ROTATE\n  | TRANSFORM_SKEWX\n  | TRANSFORM_SKEWY\n\ntype zoomAndPanType =\n  | ZOOMANDPAN_UNKNOWN\n  | ZOOMANDPAN_DISABLE\n  | ZOOMANDPAN_MAGNIFY\n\ntype lengthAdjust =\n  | LENGTHADJUST_UNKNOWN\n  | LENGTHADJUST_SPACING\n  | LENGTHADJUST_SPACINGANDGLYPHS\n\ntype unitType =\n  | UNIT_TYPE_UNKNOWN\n  | UNIT_TYPE_USERSPACEONUSE\n  | UNIT_TYPE_OBJECTBOUNDINGBOX\n\n(* interface SVGRenderingIntent *)\ntype intentType =\n  | RENDERING_INTENT_UNKNOWN\n  | RENDERING_INTENT_AUTO\n  | RENDERING_INTENT_PERCEPTUAL\n  | RENDERING_INTENT_RELATIVE_COLORIMETRIC\n  | RENDERING_INTENT_SATURATION\n  | RENDERING_INTENT_ABSOLUTE_COLORIMETRIC\n\n(* Path Segment Types *)\ntype pathSegmentType =\n  | PATHSEG_UNKNOWN\n  | PATHSEG_CLOSEPATH\n  | PATHSEG_MOVETO_ABS\n  | PATHSEG_MOVETO_REL\n  | PATHSEG_LINETO_ABS\n  | PATHSEG_LINETO_REL\n  | PATHSEG_CURVETO_CUBIC_ABS\n  | PATHSEG_CURVETO_CUBIC_REL\n  | PATHSEG_CURVETO_QUADRATIC_ABS\n  | PATHSEG_CURVETO_QUADRATIC_REL\n  | PATHSEG_ARC_ABS\n  | PATHSEG_ARC_REL\n  | PATHSEG_LINETO_HORIZONTAL_ABS\n  | PATHSEG_LINETO_HORIZONTAL_REL\n  | PATHSEG_LINETO_VERTICAL_ABS\n  | PATHSEG_LINETO_VERTICAL_REL\n  | PATHSEG_CURVETO_CUBIC_SMOOTH_ABS\n  | PATHSEG_CURVETO_CUBIC_SMOOTH_REL\n  | PATHSEG_CURVETO_QUADRATIC_SMOOTH_ABS\n  | PATHSEG_CURVETO_QUADRATIC_SMOOTH_REL\n\n(* textPath Method Types *)\ntype textPathMethodType =\n  | TEXTPATH_METHODTYPE_UNKNOWN\n  | TEXTPATH_METHODTYPE_ALIGN\n  | TEXTPATH_METHODTYPE_STRETCH\n\n(* textPath Spacing Types *)\ntype textPathSpacingType =\n  | TEXTPATH_SPACINGTYPE_UNKNOWN\n  | TEXTPATH_SPACINGTYPE_AUTO\n  | TEXTPATH_SPACINGTYPE_EXACT\n\n(* Spread Method Types *)\ntype spreadMethodType =\n  | SPREADMETHOD_UNKNOWN\n  | SPREADMETHOD_PAD\n  | SPREADMETHOD_REFLECT\n  | SPREADMETHOD_REPEAT\n\ntype suspendHandleID\n\n(****)\n\nclass type ['a] animated = object\n  method baseVal : 'a prop\n\n  method animVal : 'a prop\nend\n\nclass type ['a] list = object\n  method numberOfItems : int readonly_prop\n\n  method clear : unit meth\n\n  method initialize : 'a -> 'a meth\n\n  method getItem : int -> 'a meth\n\n  method insertItemBefore : 'a -> int -> 'a meth\n\n  method replaceItem : 'a -> int -> 'a meth\n\n  method removeItem : int -> 'a meth\n\n  method appendItem : 'a -> 'a meth\nend\n\n(****)\n\n(* interface SVGElement *)\nclass type element = object\n  inherit Dom.element\n\n  method id : js_string t prop\n\n  method xmlbase : js_string t prop\n\n  method ownerSVGElement : svgElement t readonly_prop\n\n  method viewportElement : element t readonly_prop\nend\n\n(* interface SVGAnimatedString *)\nand animatedString = [js_string t] animated\n\n(* interface SVGAnimatedBoolean *)\nand animatedBoolean = [bool t] animated\n\n(* interface SVGStringList *)\nand stringList = [js_string t] list\n\n(* interface SVGAnimatedEnumeration *)\nand animatedEnumeration = [int (*short*)] animated\n\n(* interface SVGAnimatedInteger *)\nand animatedInteger = [int] animated\n\n(* interface SVGAnimatedNumber *)\nand animatedNumber = [number_t] animated\n\n(* interface SVGNumberList *)\nand numberList = [number t] list\n\n(* interface SVGAnimatedNumberList *)\nand animatedNumberList = [numberList t] animated\n\n(* interface SVGLength *)\nand length = object\n  method unitType : lengthUnitType readonly_prop\n\n  method value : number_t prop\n\n  method valueInSpecifiedUnits : number_t prop\n\n  method valueAsString : js_string t prop\n\n  method newValueSpecifiedUnits : lengthUnitType -> number_t -> unit meth\n\n  method convertToSpecifiedUnits : lengthUnitType -> unit meth\nend\n\n(* interface SVGAnimatedLength *)\nand animatedLength = [length t] animated\n\n(* interface SVGLengthList *)\nand lengthList = [length t] list\n\n(* interface SVGAnimatedLengthList *)\nand animatedLengthList = [lengthList t] animated\n\n(* interface SVGAngle *)\nand angle = object\n  method unitType : angleUnitType readonly_prop\n\n  method value : number_t prop\n\n  method valueInSpecifiedUnits : number_t prop\n\n  method valueAsString : js_string t prop\n\n  method newValueSpecifiedUnits : angleUnitType -> number_t -> unit meth\n\n  method convertToSpecifiedUnits : angleUnitType -> unit meth\nend\n\n(* interface SVGAnimatedAngle *)\nand animatedAngle = [angle t] animated\n\n(* XXXXX Move it *)\nand rgbColor = object end\n\n(* interface SVGColor *)\nand color = object\n  (* XXX inherit cssValue *)\n  method colorType : colorType readonly_prop\n\n  method rgbColor : rgbColor t readonly_prop\n\n  method iccColor : iccColor t readonly_prop\n\n  method setRGBColor : js_string t -> unit meth\n\n  method setRGBColorICCColor : js_string t -> js_string t -> unit meth\n\n  method setColor : colorType -> js_string t -> js_string t -> unit meth\nend\n\n(* interface SVGICCColor *)\nand iccColor = object\n  method colorProfile : js_string t prop\n\n  method colors : numberList t readonly_prop\nend\n\n(* interface SVGRect *)\nand rect = object\n  method x : number_t prop\n\n  method y : number_t prop\n\n  method width : number_t prop\n\n  method height : number_t prop\nend\n\n(* interface SVGAnimatedRect *)\nand animatedRect = [rect t] animated\n\n(* interface SVGStylable *)\nand stylable = object\n  method className : animatedString t readonly_prop\n\n  method style : Dom_html.cssStyleDeclaration t readonly_prop\n  (*   CSSValue getPresentationAttribute(in DOMString name); *)\nend\n\n(* interface SVGLocatable *)\nand locatable = object\n  method nearestViewportElement : element t readonly_prop\n\n  method farthestViewportElement : element t readonly_prop\n\n  method getBBox : rect t meth\n\n  method getCTM : matrix t meth\n\n  method getScreenCTM : matrix t meth\n\n  method getTransformToElement : element t -> matrix t meth\nend\n\n(* interface SVGTransformable *)\nand transformable = object\n  inherit locatable\n\n  method transform : animatedTransformList t readonly_prop\nend\n\n(* interface SVGTests *)\nand tests = object\n  method requiredFeatures : stringList t readonly_prop\n\n  method requiredExtensions : stringList t readonly_prop\n\n  method systemLanguage : stringList t readonly_prop\n\n  method hasExtension : js_string t -> bool t meth\nend\n\n(* interface SVGLangSpace *)\nand langSpace = object\n  method xmllang : js_string t prop\n\n  method xmlspace : js_string t prop\nend\n\n(* interface SVGExternalResourcesRequired *)\nand externalResourcesRequired = object\n  method externalResourcesRequired : animatedBoolean t readonly_prop\nend\n\n(* interface SVGFitToViewBox *)\nand fitToViewBox = object\n  method viewBox : animatedRect t readonly_prop\n\n  method preserveAspectRatio : animatedPreserveAspectRatio t readonly_prop\nend\n\n(* interface SVGZoomAndPan *)\nand zoomAndPan = object\n  method zoomAndPan : zoomAndPanType prop\nend\n\n(* interface SVGViewSpec *)\nand viewSpec = object\n  inherit zoomAndPan\n\n  inherit fitToViewBox\n\n  method transform : transformList t readonly_prop\n\n  method viewTarget : element t readonly_prop\n\n  method viewBoxString : js_string t readonly_prop\n\n  method preserveAspectRatioString : js_string t readonly_prop\n\n  method transformString : js_string t readonly_prop\n\n  method viewTargetString : js_string t readonly_prop\nend\n\n(* interface SVGURIReference *)\nand uriReference = object\n  method href : animatedString t readonly_prop\nend\n\n(* interface SVGCSSRule : CSSRule *)\n(*   const unsigned short COLOR_PROFILE_RULE = 7; *)\n(* }; *)\n\n(* interface SVGDocument *)\nand document = object\n  inherit [element] Dom.document\n\n  (*XXX inherit documentEvent *)\n  method title : js_string t prop\n\n  method referrer : js_string t readonly_prop\n\n  method domain : js_string t prop\n\n  method _URL : js_string t readonly_prop\n\n  method rootElement : svgElement t opt readonly_prop\n  (* rootElement will be null or undefined in an html context *)\nend\n\n(* interface SVGSVGElement *)\nand svgElement = object\n  inherit element\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit locatable\n\n  inherit fitToViewBox\n\n  inherit zoomAndPan\n\n  (*XXX inherit documentevent, viewcss, documentcss *)\n  method x : animatedLength t readonly_prop\n\n  method y : animatedLength t readonly_prop\n\n  method width : animatedLength t readonly_prop\n\n  method height : animatedLength t readonly_prop\n\n  method contentScriptType : js_string t prop\n\n  method contentStyleType : js_string t prop\n\n  method viewport : rect t readonly_prop\n\n  method pixelUnitToMillimeterX : number_t readonly_prop\n\n  method pixelUnitToMillimeterY : number_t readonly_prop\n\n  method screenPixelUnitToMillimeterX : number_t readonly_prop\n\n  method screenPixelUnitToMillimeterY : number_t readonly_prop\n\n  method useCurrentView : bool t readonly_prop\n\n  method currentView : viewSpec t readonly_prop\n\n  method currentScale : number_t prop\n\n  method currentTranslate : point t readonly_prop\n\n  method suspendRedraw : int -> suspendHandleID meth\n\n  method unsuspendRedraw : suspendHandleID -> unit meth\n\n  method unsuspendRedrawAll : unit meth\n\n  method forceRedraw : unit meth\n\n  method pauseAnimations : unit meth\n\n  method unpauseAnimations : unit meth\n\n  method animationsPaused : bool t meth\n\n  method getCurrentTime : number_t meth\n\n  method setCurrentTime : int -> unit meth\n\n  method getIntersectionList : rect t -> element t -> element Dom.nodeList t meth\n\n  method getEnclosureList : rect t -> element t -> element Dom.nodeList t meth\n\n  method checkIntersection : element t -> rect t -> bool t\n\n  method checkEnclosure : element t -> rect t -> bool t\n\n  method deselectAll : unit meth\n\n  method createSVGNumber : number t meth\n\n  method createSVGLength : length t meth\n\n  method createSVGAngle : angle t meth\n\n  method createSVGPoint : point t meth\n\n  method createSVGMatrix : matrix t meth\n\n  method createSVGRect : rect t meth\n\n  method createSVGTransform : transform t meth\n\n  method createSVGTransformFromMatrix : matrix t -> transform t meth\n\n  method getElementById : js_string t -> Dom.element t meth\nend\n\n(* interface SVGGElement *)\nand gElement = object\n  inherit element\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit transformable\n\n  inherit Dom_html.eventTarget\nend\n\n(* interface SVGDefsElement *)\nand defsElement = object\n  inherit element\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit transformable\n  (* XXXXXXX ? inherit Dom_html.eventTarget *)\nend\n\n(* interface SVGDescElement *)\nand descElement = object\n  inherit element\n\n  inherit langSpace\n\n  inherit stylable\n  (* XXXXXXX ? inherit Dom_html.eventTarget *)\nend\n\n(* interface SVGTitleElement *)\nand titleElement = object\n  inherit element\n\n  inherit langSpace\n\n  inherit stylable\nend\n\n(* interface SVGSymbolElement *)\nand symbolElement = object\n  inherit element\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit fitToViewBox\n\n  inherit Dom_html.eventTarget\nend\n\n(* interface SVGUseElement *)\nand useElement = object\n  inherit element\n\n  inherit uriReference\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit transformable\n\n  method x : animatedLength t readonly_prop\n\n  method y : animatedLength t readonly_prop\n\n  method width : animatedLength t readonly_prop\n\n  method height : animatedLength t readonly_prop\n\n  method instanceRoot : elementInstance t readonly_prop\n\n  method animatedInstanceRoot : elementInstance t readonly_prop\nend\n\nand elementInstance = object\n  inherit Dom_html.eventTarget\n\n  method correspondingElement : element t readonly_prop\n\n  method correspondingUseElement : useElement t readonly_prop\n\n  method parentNode : elementInstance t readonly_prop\n\n  method childNodes : elementInstanceList t readonly_prop\n\n  method firstChild : elementInstance t readonly_prop\n\n  method lastChild : elementInstance t readonly_prop\n\n  method previousSibling : elementInstance t readonly_prop\n\n  method nextSibling : elementInstance t readonly_prop\nend\n\n(* interface SVGElementInstanceList *)\nand elementInstanceList = object\n  method length : int readonly_prop\n\n  method item : int -> elementInstance t\nend\n\n(* interface SVGImageElement *)\nand imageElement = object\n  inherit element\n\n  inherit uriReference\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit transformable\n\n  method x : animatedLength t readonly_prop\n\n  method y : animatedLength t readonly_prop\n\n  method width : animatedLength t readonly_prop\n\n  method height : animatedLength t readonly_prop\n  (* readonly attribute SVGAnimatedPreserveAspectRatio preserveAspectRatio *)\nend\n\nand switchElement = object\n  inherit element\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit transformable\nend\n\n(* XXX deprecated => interface GetSVGDocument => SVGDocument getSVGDocument() *)\n\n(* interface SVGStyleElement *)\nand styleElement = object\n  inherit element\n\n  inherit langSpace\n\n  method type_ : js_string t prop\n\n  method media : js_string t prop\n\n  method title : js_string t prop\nend\n\n(* interface SVGPoint *)\nand point = object\n  method x : number_t readonly_prop\n\n  method y : number_t readonly_prop\n\n  method matrixTransform : matrix t -> point t meth\nend\n\n(* interface SVGPointList *)\nand pointList = [point t] list\n\n(* interface SVGMatrix *)\nand matrix = object\n  method a : number_t readonly_prop\n\n  method b : number_t readonly_prop\n\n  method c : number_t readonly_prop\n\n  method d : number_t readonly_prop\n\n  method e : number_t readonly_prop\n\n  method f : number_t readonly_prop\n\n  method multiply : matrix t -> matrix t meth\n\n  method inverse : matrix t meth\n\n  method translate : number_t -> number_t -> matrix t meth\n\n  method scale : number_t -> matrix t meth\n\n  method scaleNonUniform : number_t -> number_t -> matrix t meth\n\n  method rotate : number_t -> matrix t meth\n\n  method rotateFromVector : number_t -> number_t -> matrix t meth\n\n  method flipX : matrix t meth\n\n  method flipY : matrix t meth\n\n  method skewX : number_t -> matrix t meth\n\n  method skewY : number_t -> matrix t meth\nend\n\n(* interface SVGTransform *)\nand transform = object\n  method _type : transformType readonly_prop\n\n  method matrix : matrix t readonly_prop\n\n  method angle : number_t readonly_prop\n\n  method setMatrix : matrix t -> unit meth\n\n  method setTranslate : number_t -> number_t -> unit meth\n\n  method setScale : number_t -> number_t -> unit meth\n\n  method setRotate : number_t -> number_t -> number_t -> unit meth\n\n  method setSkewX : number_t -> unit meth\n\n  method setSkewY : number_t -> unit meth\nend\n\n(* interface SVGTransformList *)\nand transformList = object\n  inherit [transform t] list\n\n  method createSVGTransformFromMatrix : matrix -> transform t meth\n\n  method consolidate : transform t meth\nend\n\n(* interface SVGAnimatedTransformList *)\nand animatedTransformList = [transformList t] animated\n\n(* interface SVGPreserveAspectRatio *)\nand preserveAspectRatio = object\n  method align : alignmentType readonly_prop\n\n  method meetOrSlice : meetOrSliceType readonly_prop\nend\n\n(* interface SVGAnimatedPreserveAspectRatio *)\nand animatedPreserveAspectRatio = [preserveAspectRatio t] animated\n\n(* interface SVGPathSeg *)\nand pathSeg = object\n  method pathSegType : pathSegmentType readonly_prop\n\n  method pathSegTypeAsLetter : js_string t readonly_prop\nend\n\n(* interface SVGPathSegClosePath *)\nand pathSegClosePath = pathSeg\n\n(* interface SVGPathSegMovetoAbs *)\n(* interface SVGPathSegMovetoRel *)\nand pathSegMoveto = object\n  inherit pathSeg\n\n  method x : number_t prop\n\n  method y : number_t prop\nend\n\n(* interface SVGPathSegLinetoAbs *)\n(* interface SVGPathSegLinetoRel *)\nand pathSegLineto = object\n  inherit pathSeg\n\n  method x : number_t prop\n\n  method y : number_t prop\nend\n\n(* interface SVGPathSegCurvetoCubicAbs *)\n(* interface SVGPathSegCurvetoCubicRel *)\nand pathSegCurvetoCubic = object\n  inherit pathSeg\n\n  method x : number_t prop\n\n  method y : number_t prop\n\n  method x1 : number_t prop\n\n  method y1 : number_t prop\n\n  method x2 : number_t prop\n\n  method y2 : number_t prop\nend\n\n(* interface SVGPathSegCurvetoQuadraticAbs *)\n(* interface SVGPathSegCurvetoQuadraticRel *)\nand pathSegCurvetoQuadratic = object\n  inherit pathSeg\n\n  method x : number_t prop\n\n  method y : number_t prop\n\n  method x1 : number_t prop\n\n  method y1 : number_t prop\nend\n\n(* interface SVGPathSegArcAbs *)\n(* interface SVGPathSegArcRel*)\nand pathSegArc = object\n  inherit pathSeg\n\n  method y : number_t prop\n\n  method r1 : number_t prop\n\n  method r2 : number_t prop\n\n  method angle : number_t prop\n\n  method largeArcFlag : bool t prop\n\n  method sweepFlag : bool t prop\nend\n\n(* interface SVGPathSegLinetoHorizontalAbs *)\n(* interface SVGPathSegLinetoHorizontalRel *)\nand pathSegLinetoHorizontal = object\n  inherit pathSeg\n\n  method x : number_t\nend\n\n(* interface SVGPathSegLinetoVerticalAbs *)\n(* interface SVGPathSegLinetoVerticalRel *)\nand pathSegLinetoVertical = object\n  inherit pathSeg\n\n  method y : number_t\nend\n\nand pathSegCurvetoCubicSmooth = object\n  inherit pathSeg\n\n  method x : number_t\n\n  method y : number_t\n\n  method x2 : number_t\n\n  method y2 : number_t\nend\n\n(* interface SVGPathSegCurvetoQuadraticSmoothAbs *)\n(* interface SVGPathSegCurvetoQuadraticSmoothRel  *)\nand pathSegCurvetoQuadraticSmooth = object\n  inherit pathSeg\n\n  method x : number_t\n\n  method y : number_t\nend\n\nand pathSegList = [pathSeg t] list\n\n(* interface SVGAnimatedPathData *)\nand animatedPathData = object\n  method pathSegList : pathSegList t prop\n\n  method normalizedPathSegList : pathSegList t prop\n\n  method animatedPathSegList : pathSegList t prop\n\n  method animatedNormalizedPathSegList : pathSegList t prop\nend\n\n(* interface SVGPathElement *)\nand pathElement = object\n  inherit element\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit transformable\n\n  inherit animatedPathData\n\n  method pathLength : animatedNumber t readonly_prop\n\n  method getTotalLength : number_t meth\n\n  method getPointAtLength : number_t -> point t meth\n\n  method getPathSegAtLength : number_t -> int\n\n  method createSVGPathSegClosePath : pathSegClosePath meth\n\n  method createSVGPathSegMovetoAbs : number_t -> number_t -> pathSegMoveto meth\n\n  method createSVGPathSegMovetoRel : number_t -> number_t -> pathSegMoveto meth\n\n  method createSVGPathSegLinetoAbs : number_t -> number_t -> pathSegLineto meth\n\n  method createSVGPathSegLinetoRel : number_t -> number_t -> pathSegLineto meth\n\n  method createSVGPathSegCurvetoCubicAbs :\n       number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> pathSegCurvetoCubic meth\n\n  method createSVGPathSegCurvetoCubicRel :\n       number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> pathSegCurvetoCubic meth\n\n  method createSVGPathSegCurvetoQuadraticAbs :\n    number_t -> number_t -> number_t -> number_t -> pathSegCurvetoQuadratic meth\n\n  method createSVGPathSegCurvetoQuadraticRel :\n    number_t -> number_t -> number_t -> number_t -> pathSegCurvetoQuadratic meth\n\n  method createSVGPathSegArcAbs :\n       number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> bool t\n    -> bool t\n    -> pathSegArc meth\n\n  method createSVGPathSegArcRel :\n       number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> number_t\n    -> bool t\n    -> bool t\n    -> pathSegArc meth\n\n  method createSVGPathSegLinetoHorizontalAbs : number_t -> pathSegLinetoHorizontal meth\n\n  method createSVGPathSegLinetoHorizontalRel : number_t -> pathSegLinetoHorizontal meth\n\n  method createSVGPathSegLinetoVerticalAbs : number_t -> pathSegLinetoVertical meth\n\n  method createSVGPathSegLinetoVerticalRel : number_t -> pathSegLinetoVertical meth\n\n  method createSVGPathSegCurvetoCubicSmoothAbs :\n    number_t -> number_t -> number_t -> number_t -> pathSegCurvetoCubicSmooth meth\n\n  method createSVGPathSegCurvetoCubicSmoothRel :\n    number_t -> number_t -> number_t -> number_t -> pathSegCurvetoCubicSmooth meth\n\n  method createSVGPathSegCurvetoQuadraticSmoothAbs :\n    number_t -> number_t -> pathSegCurvetoQuadraticSmooth meth\n\n  method createSVGPathSegCurvetoQuadraticSmoothRel :\n    number_t -> number_t -> pathSegCurvetoQuadraticSmooth meth\nend\n\n(* interface SVGRectElement *)\nand rectElement = object\n  inherit element\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit transformable\n\n  method x : animatedLength t readonly_prop\n\n  method y : animatedLength t readonly_prop\n\n  method width : animatedLength t readonly_prop\n\n  method height : animatedLength t readonly_prop\n\n  method rx : animatedLength t readonly_prop\n\n  method ry : animatedLength t readonly_prop\nend\n\n(* interface SVGCircleElement *)\nand circleElement = object\n  inherit element\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit transformable\n\n  method cx : animatedLength t readonly_prop\n\n  method cy : animatedLength t readonly_prop\n\n  method r : animatedLength t readonly_prop\nend\n\n(* interface SVGEllipseElement *)\nand ellipseElement = object\n  inherit element\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit transformable\n\n  method cx : animatedLength t readonly_prop\n\n  method cy : animatedLength t readonly_prop\n\n  method rx : animatedLength t readonly_prop\n\n  method ry : animatedLength t readonly_prop\nend\n\n(* interface SVGLineElement *)\nclass type lineElement = object\n  inherit element\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit transformable\n\n  inherit Dom_html.eventTarget\n\n  method x1 : animatedLength t readonly_prop\n\n  method y1 : animatedLength t readonly_prop\n\n  method x2 : animatedLength t readonly_prop\n\n  method y2 : animatedLength t readonly_prop\nend\n\n(* interface SVGAnimatedPoints *)\nand animatedPoints = object\n  method points : pointList t readonly_prop\n\n  method animatedpoints : pointList t readonly_prop\nend\n\n(* interface SVGPolylineElement *)\nand polyLineElement = object\n  inherit element\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit transformable\n\n  inherit animatedPoints\nend\n\n(* interface SVGPolygonElement *)\nand polygonElement = object\n  inherit element\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit transformable\n\n  inherit animatedPoints\nend\n\n(* interface SVGTextContentElement *)\nand textContentElement = object\n  inherit element\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit Dom_html.eventTarget\n\n  method textLength : animatedLength t readonly_prop\n\n  method lengthAdjust : lengthAdjust animated t readonly_prop\n\n  method getNumberOfChars : int meth\n\n  method getComputedTextLength : number_t meth\n\n  method getSubStringLength : int -> int -> number_t meth\n\n  method getStartPositionOfChar : int -> point t meth\n\n  method getEndPositionOfChar : int -> point t meth\n\n  method getExtentOfChar : int -> rect t meth\n\n  method getRotationOfChar : int -> number_t meth\n\n  method getCharNumAtPosition : point -> int meth\n\n  method selectSubString : int -> int -> unit meth\nend\n\n(* interface SVGTextPositioningElement *)\nand textPositioningElement = object\n  inherit textContentElement\n\n  method x : animatedLengthList t readonly_prop\n\n  method y : animatedLengthList t readonly_prop\n\n  method dx : animatedLengthList t readonly_prop\n\n  method dy : animatedLengthList t readonly_prop\n\n  method rotate : animatedNumberList t readonly_prop\nend\n\n(* interface SVGTextElement *)\nand textElement = object\n  inherit textPositioningElement\n\n  inherit transformable\nend\n\nand tspanElement = textPositioningElement\n\nand trefElement = object\n  inherit textPositioningElement\n\n  inherit uriReference\nend\n\n(* interface SVGTextPathElement *)\nand textPathElementMethod = [textPathMethodType] animated\n\nand textPathElementSpacing = [textPathSpacingType] animated\n\nand textPathElement = object\n  inherit textContentElement\n\n  inherit uriReference\n\n  method startOffset : animatedLength t readonly_prop\n\n  method method_ : textPathElementMethod readonly_prop\n\n  method spacing : textPathElementSpacing readonly_prop\nend\n\n(* interface SVGAltGlyphElement *)\nand altGlyphElement = object\n  inherit textPositioningElement\n\n  inherit uriReference\n\n  method glyphRef : js_string t prop\n\n  method format : js_string t prop\nend\n\n(* interface SVGAltGlyphDefElement *)\nand altGlyphDefElement = element\n\n(* interface SVGAltGlyphItemElement *)\nand altGlyphItemElement = element\n\n(* interface SVGGlyphRefElement *)\nand glyphRefElement = object\n  inherit element\n\n  inherit uriReference\n\n  inherit stylable\n\n  method glyphRef : js_string t prop\n\n  method format : js_string t prop\n\n  method x : number_t prop\n\n  method y : number_t prop\n\n  method dx : number_t prop\n\n  method dy : number_t prop\nend\n\n(* interface SVGPaint : SVGColor { *)\n\n(*   // Paint Types *)\n(*   const unsigned short SVG_PAINTTYPE_UNKNOWN = 0; *)\n(*   const unsigned short SVG_PAINTTYPE_RGBCOLOR = 1; *)\n(*   const unsigned short SVG_PAINTTYPE_RGBCOLOR_ICCCOLOR = 2; *)\n(*   const unsigned short SVG_PAINTTYPE_NONE = 101; *)\n(*   const unsigned short SVG_PAINTTYPE_CURRENTCOLOR = 102; *)\n(*   const unsigned short SVG_PAINTTYPE_URI_NONE = 103; *)\n(*   const unsigned short SVG_PAINTTYPE_URI_CURRENTCOLOR = 104; *)\n(*   const unsigned short SVG_PAINTTYPE_URI_RGBCOLOR = 105; *)\n(*   const unsigned short SVG_PAINTTYPE_URI_RGBCOLOR_ICCCOLOR = 106; *)\n(*   const unsigned short SVG_PAINTTYPE_URI = 107; *)\n\n(*   readonly attribute unsigned short paintType; *)\n(*   readonly attribute DOMString uri; *)\n\n(*   void setUri(in DOMString uri); *)\n(*   void setPaint(in unsigned short paintType, in DOMString uri, in DOMString rgbColor, in DOMString iccColor) raises(SVGException); *)\n(* }; *)\n\n(* interface SVGMarkerElement : SVGElement, *)\n(*                              SVGLangSpace, *)\n(*                              SVGExternalResourcesRequired, *)\n(*                              SVGStylable, *)\n(*                              SVGFitToViewBox { *)\n\n(*   // Marker Unit Types *)\n(*   const unsigned short SVG_MARKERUNITS_UNKNOWN = 0; *)\n(*   const unsigned short SVG_MARKERUNITS_USERSPACEONUSE = 1; *)\n(*   const unsigned short SVG_MARKERUNITS_STROKEWIDTH = 2; *)\n\n(*   // Marker Orientation Types *)\n(*   const unsigned short SVG_MARKER_ORIENT_UNKNOWN = 0; *)\n(*   const unsigned short SVG_MARKER_ORIENT_AUTO = 1; *)\n(*   const unsigned short SVG_MARKER_ORIENT_ANGLE = 2; *)\n\n(*   readonly attribute SVGAnimatedLength refX; *)\n(*   readonly attribute SVGAnimatedLength refY; *)\n(*   readonly attribute SVGAnimatedEnumeration markerUnits; *)\n(*   readonly attribute SVGAnimatedLength markerWidth; *)\n(*   readonly attribute SVGAnimatedLength markerHeight; *)\n(*   readonly attribute SVGAnimatedEnumeration orientType; *)\n(*   readonly attribute SVGAnimatedAngle orientAngle; *)\n\n(*   void setOrientToAuto() raises(DOMException); *)\n(*   void setOrientToAngle(in SVGAngle angle) raises(DOMException); *)\n(* }; *)\n\n(* interface SVGColorProfileElement : SVGElement, *)\n(*                                    SVGURIReference, *)\n(*                                    SVGRenderingIntent { *)\n(*   attribute DOMString local; *)\n(*   attribute DOMString name; *)\n(*   attribute unsigned short renderingIntent; *)\n(* }; *)\n\n(* interface SVGColorProfileRule : SVGCSSRule, *)\n(*                                 SVGRenderingIntent { *)\n(*   attribute DOMString src setraises(DOMException); *)\n(*   attribute DOMString name setraises(DOMException); *)\n(*   attribute unsigned short renderingIntent setraises(DOMException); *)\n(* }; *)\n\n(* interface SVGGradientElement *)\nand animatedSpreadMethod = [spreadMethodType] animated\n\nand gradientElement = object\n  inherit element\n\n  inherit uriReference\n\n  inherit stylable\n\n  (*   readonly attribute SVGAnimatedEnumeration gradientUnits; *)\n  method gradientTransform : animatedTransformList t readonly_prop\n\n  method spreadMethod : animatedSpreadMethod t readonly_prop\nend\n\n(* interface SVGLinearGradientElement *)\nand linearGradientElement = object\n  inherit gradientElement\n\n  method x1 : animatedLength t readonly_prop\n\n  method y1 : animatedLength t readonly_prop\n\n  method x2 : animatedLength t readonly_prop\n\n  method y2 : animatedLength t readonly_prop\nend\n\n(* interface SVGRadialGradientElement *)\nand radialGradientElement = object\n  inherit gradientElement\n\n  method cx : animatedLength t readonly_prop\n\n  method cy : animatedLength t readonly_prop\n\n  method r : animatedLength t readonly_prop\n\n  method fx : animatedLength t readonly_prop\n\n  method fy : animatedLength t readonly_prop\nend\n\n(* interface SVGStopElement *)\nand stopElement = object\n  inherit element\n\n  inherit stylable\n\n  method offset : animatedNumber t readonly_prop\nend\n\n(* interface SVGPatternElement *)\nand patternElement = object\n  inherit element\n\n  inherit uriReference\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit fitToViewBox\n\n  (*   readonly attribute SVGAnimatedEnumeration patternUnits; *)\n  (*   readonly attribute SVGAnimatedEnumeration patternContentUnits; *)\n  method patternTransform : animatedTransformList t readonly_prop\n\n  method x : animatedLength t readonly_prop\n\n  method y : animatedLength t readonly_prop\n\n  method width : animatedLength t readonly_prop\n\n  method height : animatedLength t readonly_prop\nend\n\n(* interface SVGClipPathElement *)\nand clipPathElement = object\n  inherit element\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit transformable\n  (*   readonly attribute SVGAnimatedEnumeration clipPathUnits; *)\nend\n\n(* interface SVGMaskElement *)\nand maskElement = object\n  inherit element\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  (*   readonly attribute SVGAnimatedEnumeration maskUnits; *)\n  (*   readonly attribute SVGAnimatedEnumeration maskContentUnits; *)\n  method x : animatedLength t readonly_prop\n\n  method y : animatedLength t readonly_prop\n\n  method width : animatedLength t readonly_prop\n\n  method height : animatedLength t readonly_prop\nend\n\n(* interface SVGFilterElement *)\nand filterElement = object\n  inherit element\n\n  inherit uriReference\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  (*   readonly attribute SVGAnimatedEnumeration filterUnits; *)\n  (*   readonly attribute SVGAnimatedEnumeration primitiveUnits; *)\n  method x : animatedLength t readonly_prop\n\n  method y : animatedLength t readonly_prop\n\n  method width : animatedLength t readonly_prop\n\n  method height : animatedLength t readonly_prop\n\n  method filterResX : animatedInteger t readonly_prop\n\n  method filterResY : animatedInteger t readonly_prop\n\n  method setFilterRes : int -> int -> unit meth\nend\n\n(* interface SVGFilterPrimitiveStandardAttributes : SVGStylable { *)\n(*   readonly attribute SVGAnimatedLength x; *)\n(*   readonly attribute SVGAnimatedLength y; *)\n(*   readonly attribute SVGAnimatedLength width; *)\n(*   readonly attribute SVGAnimatedLength height; *)\n(*   readonly attribute SVGAnimatedString result; *)\n(* }; *)\n\n(* interface SVGFEBlendElement : SVGElement, *)\n(*                               SVGFilterPrimitiveStandardAttributes { *)\n\n(*   // Blend Mode Types *)\n(*   const unsigned short SVG_FEBLEND_MODE_UNKNOWN = 0; *)\n(*   const unsigned short SVG_FEBLEND_MODE_NORMAL = 1; *)\n(*   const unsigned short SVG_FEBLEND_MODE_MULTIPLY = 2; *)\n(*   const unsigned short SVG_FEBLEND_MODE_SCREEN = 3; *)\n(*   const unsigned short SVG_FEBLEND_MODE_DARKEN = 4; *)\n(*   const unsigned short SVG_FEBLEND_MODE_LIGHTEN = 5; *)\n\n(*   readonly attribute SVGAnimatedString in1; *)\n(*   readonly attribute SVGAnimatedString in2; *)\n(*   readonly attribute SVGAnimatedEnumeration mode; *)\n(* }; *)\n\n(* interface SVGFEColorMatrixElement : SVGElement, *)\n(*                                     SVGFilterPrimitiveStandardAttributes { *)\n\n(*   // Color Matrix Types *)\n(*   const unsigned short SVG_FECOLORMATRIX_TYPE_UNKNOWN = 0; *)\n(*   const unsigned short SVG_FECOLORMATRIX_TYPE_MATRIX = 1; *)\n(*   const unsigned short SVG_FECOLORMATRIX_TYPE_SATURATE = 2; *)\n(*   const unsigned short SVG_FECOLORMATRIX_TYPE_HUEROTATE = 3; *)\n(*   const unsigned short SVG_FECOLORMATRIX_TYPE_LUMINANCETOALPHA = 4; *)\n\n(*   readonly attribute SVGAnimatedString in1; *)\n(*   readonly attribute SVGAnimatedEnumeration type; *)\n(*   readonly attribute SVGAnimatedNumberList values; *)\n(* }; *)\n\n(* interface SVGFEComponentTransferElement : SVGElement, *)\n(*                                           SVGFilterPrimitiveStandardAttributes { *)\n(*   readonly attribute SVGAnimatedString in1; *)\n(* }; *)\n\n(* interface SVGComponentTransferFunctionElement : SVGElement { *)\n\n(*   // Component Transfer Types *)\n(*   const unsigned short SVG_FECOMPONENTTRANSFER_TYPE_UNKNOWN = 0; *)\n(*   const unsigned short SVG_FECOMPONENTTRANSFER_TYPE_IDENTITY = 1; *)\n(*   const unsigned short SVG_FECOMPONENTTRANSFER_TYPE_TABLE = 2; *)\n(*   const unsigned short SVG_FECOMPONENTTRANSFER_TYPE_DISCRETE = 3; *)\n(*   const unsigned short SVG_FECOMPONENTTRANSFER_TYPE_LINEAR = 4; *)\n(*   const unsigned short SVG_FECOMPONENTTRANSFER_TYPE_GAMMA = 5; *)\n\n(*   readonly attribute SVGAnimatedEnumeration type; *)\n(*   readonly attribute SVGAnimatedNumberList tableValues; *)\n(*   readonly attribute SVGAnimatedNumber slope; *)\n(*   readonly attribute SVGAnimatedNumber intercept; *)\n(*   readonly attribute SVGAnimatedNumber amplitude; *)\n(*   readonly attribute SVGAnimatedNumber exponent; *)\n(*   readonly attribute SVGAnimatedNumber offset; *)\n(* }; *)\n\n(* interface SVGFEFuncRElement : SVGComponentTransferFunctionElement { *)\n(* }; *)\n\n(* interface SVGFEFuncGElement : SVGComponentTransferFunctionElement { *)\n(* }; *)\n\n(* interface SVGFEFuncBElement : SVGComponentTransferFunctionElement { *)\n(* }; *)\n\n(* interface SVGFEFuncAElement : SVGComponentTransferFunctionElement { *)\n(* }; *)\n\n(* interface SVGFECompositeElement : SVGElement, *)\n(*                                   SVGFilterPrimitiveStandardAttributes { *)\n\n(*   // Composite Operators *)\n(*   const unsigned short SVG_FECOMPOSITE_OPERATOR_UNKNOWN = 0; *)\n(*   const unsigned short SVG_FECOMPOSITE_OPERATOR_OVER = 1; *)\n(*   const unsigned short SVG_FECOMPOSITE_OPERATOR_IN = 2; *)\n(*   const unsigned short SVG_FECOMPOSITE_OPERATOR_OUT = 3; *)\n(*   const unsigned short SVG_FECOMPOSITE_OPERATOR_ATOP = 4; *)\n(*   const unsigned short SVG_FECOMPOSITE_OPERATOR_XOR = 5; *)\n(*   const unsigned short SVG_FECOMPOSITE_OPERATOR_ARITHMETIC = 6; *)\n\n(*   readonly attribute SVGAnimatedString in1; *)\n(*   readonly attribute SVGAnimatedString in2; *)\n(*   readonly attribute SVGAnimatedEnumeration operator; *)\n(*   readonly attribute SVGAnimatedNumber k1; *)\n(*   readonly attribute SVGAnimatedNumber k2; *)\n(*   readonly attribute SVGAnimatedNumber k3; *)\n(*   readonly attribute SVGAnimatedNumber k4; *)\n(* }; *)\n\n(* interface SVGFEConvolveMatrixElement : SVGElement, *)\n(*                                        SVGFilterPrimitiveStandardAttributes { *)\n\n(*   // Edge Mode Values *)\n(*   const unsigned short SVG_EDGEMODE_UNKNOWN = 0; *)\n(*   const unsigned short SVG_EDGEMODE_DUPLICATE = 1; *)\n(*   const unsigned short SVG_EDGEMODE_WRAP = 2; *)\n(*   const unsigned short SVG_EDGEMODE_NONE = 3; *)\n\n(*   readonly attribute SVGAnimatedString in1; *)\n(*   readonly attribute SVGAnimatedInteger orderX; *)\n(*   readonly attribute SVGAnimatedInteger orderY; *)\n(*   readonly attribute SVGAnimatedNumberList kernelMatrix; *)\n(*   readonly attribute SVGAnimatedNumber divisor; *)\n(*   readonly attribute SVGAnimatedNumber bias; *)\n(*   readonly attribute SVGAnimatedInteger targetX; *)\n(*   readonly attribute SVGAnimatedInteger targetY; *)\n(*   readonly attribute SVGAnimatedEnumeration edgeMode; *)\n(*   readonly attribute SVGAnimatedNumber kernelUnitLengthX; *)\n(*   readonly attribute SVGAnimatedNumber kernelUnitLengthY; *)\n(*   readonly attribute SVGAnimatedBoolean preserveAlpha; *)\n(* }; *)\n\n(* interface SVGFEDiffuseLightingElement : SVGElement, *)\n(*                                         SVGFilterPrimitiveStandardAttributes { *)\n(*   readonly attribute SVGAnimatedString in1; *)\n(*   readonly attribute SVGAnimatedNumber surfaceScale; *)\n(*   readonly attribute SVGAnimatedNumber diffuseConstant; *)\n(*   readonly attribute SVGAnimatedNumber kernelUnitLengthX; *)\n(*   readonly attribute SVGAnimatedNumber kernelUnitLengthY; *)\n(* }; *)\n\n(* interface SVGFEDistantLightElement : SVGElement { *)\n(*   readonly attribute SVGAnimatedNumber azimuth; *)\n(*   readonly attribute SVGAnimatedNumber elevation; *)\n(* }; *)\n\n(* interface SVGFEPointLightElement : SVGElement { *)\n(*   readonly attribute SVGAnimatedNumber x; *)\n(*   readonly attribute SVGAnimatedNumber y; *)\n(*   readonly attribute SVGAnimatedNumber z; *)\n(* }; *)\n\n(* interface SVGFESpotLightElement : SVGElement { *)\n(*   readonly attribute SVGAnimatedNumber x; *)\n(*   readonly attribute SVGAnimatedNumber y; *)\n(*   readonly attribute SVGAnimatedNumber z; *)\n(*   readonly attribute SVGAnimatedNumber pointsAtX; *)\n(*   readonly attribute SVGAnimatedNumber pointsAtY; *)\n(*   readonly attribute SVGAnimatedNumber pointsAtZ; *)\n(*   readonly attribute SVGAnimatedNumber specularExponent; *)\n(*   readonly attribute SVGAnimatedNumber limitingConeAngle; *)\n(* }; *)\n\n(* interface SVGFEDisplacementMapElement : SVGElement, *)\n(*                                         SVGFilterPrimitiveStandardAttributes { *)\n\n(*   // Channel Selectors *)\n(*   const unsigned short SVG_CHANNEL_UNKNOWN = 0; *)\n(*   const unsigned short SVG_CHANNEL_R = 1; *)\n(*   const unsigned short SVG_CHANNEL_G = 2; *)\n(*   const unsigned short SVG_CHANNEL_B = 3; *)\n(*   const unsigned short SVG_CHANNEL_A = 4; *)\n\n(*   readonly attribute SVGAnimatedString in1; *)\n(*   readonly attribute SVGAnimatedString in2; *)\n(*   readonly attribute SVGAnimatedNumber scale; *)\n(*   readonly attribute SVGAnimatedEnumeration xChannelSelector; *)\n(*   readonly attribute SVGAnimatedEnumeration yChannelSelector; *)\n(* }; *)\n\n(* interface SVGFEFloodElement : SVGElement, *)\n(*                               SVGFilterPrimitiveStandardAttributes { *)\n(* }; *)\n\n(* interface SVGFEGaussianBlurElement : SVGElement, *)\n(*                                      SVGFilterPrimitiveStandardAttributes { *)\n\n(*   readonly attribute SVGAnimatedString in1; *)\n(*   readonly attribute SVGAnimatedNumber stdDeviationX; *)\n(*   readonly attribute SVGAnimatedNumber stdDeviationY; *)\n\n(*   void setStdDeviation(in float stdDeviationX, in float stdDeviationY) raises(DOMException); *)\n(* }; *)\n\n(* interface SVGFEImageElement : SVGElement, *)\n(*                               SVGURIReference, *)\n(*                               SVGLangSpace, *)\n(*                               SVGExternalResourcesRequired, *)\n(*                               SVGFilterPrimitiveStandardAttributes { *)\n(*   readonly attribute SVGAnimatedPreserveAspectRatio preserveAspectRatio; *)\n(* }; *)\n\n(* interface SVGFEMergeElement : SVGElement, *)\n(*                               SVGFilterPrimitiveStandardAttributes { *)\n(* }; *)\n\n(* interface SVGFEMergeNodeElement : SVGElement { *)\n(*   readonly attribute SVGAnimatedString in1; *)\n(* }; *)\n\n(* interface SVGFEMorphologyElement : SVGElement, *)\n(*                                    SVGFilterPrimitiveStandardAttributes { *)\n\n(*   // Morphology Operators *)\n(*   const unsigned short SVG_MORPHOLOGY_OPERATOR_UNKNOWN = 0; *)\n(*   const unsigned short SVG_MORPHOLOGY_OPERATOR_ERODE = 1; *)\n(*   const unsigned short SVG_MORPHOLOGY_OPERATOR_DILATE = 2; *)\n\n(*   readonly attribute SVGAnimatedString in1; *)\n(*   readonly attribute SVGAnimatedEnumeration operator; *)\n(*   readonly attribute SVGAnimatedNumber radiusX; *)\n(*   readonly attribute SVGAnimatedNumber radiusY; *)\n(* }; *)\n\n(* interface SVGFEOffsetElement : SVGElement, *)\n(*                                SVGFilterPrimitiveStandardAttributes { *)\n(*   readonly attribute SVGAnimatedString in1; *)\n(*   readonly attribute SVGAnimatedNumber dx; *)\n(*   readonly attribute SVGAnimatedNumber dy; *)\n(* }; *)\n\n(* interface SVGFESpecularLightingElement : SVGElement, *)\n(*                                          SVGFilterPrimitiveStandardAttributes { *)\n(*   readonly attribute SVGAnimatedString in1; *)\n(*   readonly attribute SVGAnimatedNumber surfaceScale; *)\n(*   readonly attribute SVGAnimatedNumber specularConstant; *)\n(*   readonly attribute SVGAnimatedNumber specularExponent; *)\n(*   readonly attribute SVGAnimatedNumber kernelUnitLengthX; *)\n(*   readonly attribute SVGAnimatedNumber kernelUnitLengthY; *)\n(* }; *)\n\n(* interface SVGFETileElement : SVGElement, *)\n(*                              SVGFilterPrimitiveStandardAttributes { *)\n(*   readonly attribute SVGAnimatedString in1; *)\n(* }; *)\n\n(* interface SVGFETurbulenceElement : SVGElement, *)\n(*                                    SVGFilterPrimitiveStandardAttributes { *)\n\n(*   // Turbulence Types *)\n(*   const unsigned short SVG_TURBULENCE_TYPE_UNKNOWN = 0; *)\n(*   const unsigned short SVG_TURBULENCE_TYPE_FRACTALNOISE = 1; *)\n(*   const unsigned short SVG_TURBULENCE_TYPE_TURBULENCE = 2; *)\n\n(*   // Stitch Options *)\n(*   const unsigned short SVG_STITCHTYPE_UNKNOWN = 0; *)\n(*   const unsigned short SVG_STITCHTYPE_STITCH = 1; *)\n(*   const unsigned short SVG_STITCHTYPE_NOSTITCH = 2; *)\n\n(*   readonly attribute SVGAnimatedNumber baseFrequencyX; *)\n(*   readonly attribute SVGAnimatedNumber baseFrequencyY; *)\n(*   readonly attribute SVGAnimatedInteger numOctaves; *)\n(*   readonly attribute SVGAnimatedNumber seed; *)\n(*   readonly attribute SVGAnimatedEnumeration stitchTiles; *)\n(*   readonly attribute SVGAnimatedEnumeration type; *)\n(* }; *)\n\n(* interface SVGCursorElement *)\nand cursorElement = object\n  inherit element\n\n  inherit uriReference\n\n  inherit tests\n\n  inherit externalResourcesRequired\n\n  method x : animatedLength t readonly_prop\n\n  method y : animatedLength t readonly_prop\nend\n\n(* interface SVGAElement *)\nand aElement = object\n  inherit element\n\n  inherit uriReference\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit transformable\n\n  method target : animatedString t readonly_prop\nend\n\n(* interface SVGViewElement *)\nand viewElement = object\n  inherit element\n\n  inherit externalResourcesRequired\n\n  inherit fitToViewBox\n\n  inherit zoomAndPan\n\n  method viewTarget : stringList t readonly_prop\nend\n\n(* interface SVGScriptElement *)\nand scriptElement = object\n  inherit element\n\n  inherit uriReference\n\n  inherit externalResourcesRequired\n\n  method type_ : js_string t prop\nend\n\n(* interface SVGZoomEvent : UIEvent *)\n(*   readonly attribute SVGRect zoomRectScreen; *)\n(*   readonly attribute float previousScale; *)\n(*   readonly attribute SVGPoint previousTranslate; *)\n(*   readonly attribute float newScale; *)\n(*   readonly attribute SVGPoint newTranslate; *)\n(* }; *)\n\n(* interface SVGAnimationElement *)\nand animationElement = object\n  inherit element\n\n  inherit tests\n\n  inherit externalResourcesRequired\n\n  (* inherit elementTimeControl *)\n  method targetElement : element t readonly_prop\n\n  method getStartTime : number_t meth\n\n  method getCurrentTime : number_t meth\n\n  method getSimpleDuration : number_t meth\nend\n\n(* interface SVGAnimateElement *)\nand animateElement = object\n  inherit animationElement\n\n  inherit stylable\nend\n\n(* interface SVGSetElement *)\nand setElement = animationElement\n\n(* interface SVGAnimateMotionElement *)\nand animateMotionElement = animationElement\n\n(* interface SVGMPathElement *)\nand mPathElement = object\n  inherit element\n\n  inherit uriReference\n\n  inherit externalResourcesRequired\nend\n\n(* interface SVGAnimateColorElement *)\nand animateColorElement = object\n  inherit animationElement\n\n  inherit stylable\nend\n\n(* interface SVGAnimateTransformElement *)\nand animateTransformElement = animationElement\n\n(* interface SVGFontElement *)\nand fontElement = object\n  inherit element\n\n  inherit stylable\nend\n\n(* interface SVGGlyphElement *)\n(* interface SVGMissingGlyphElement*)\nand glyphElement = object\n  inherit element\n\n  inherit stylable\nend\n\n(* interface SVGHKernElement : SVGElement *)\n(* interface SVGVKernElement : SVGElement *)\n\n(* interface SVGFontFaceElement *)\nclass type fontFaceElement = element\n\n(* interface SVGFontFaceSrcElement *)\nclass type fontFaceSrcElement = element\n\n(* interface SVGFontFaceUriElement *)\nclass type fontFaceUriElement = element\n\n(* interface SVGFontFaceFormatElement *)\nclass type fontFaceFormatElement = element\n\n(* interface SVGFontFaceNameElement *)\nclass type fontFaceNameElement = element\n\n(* interface SVGMetadataElement *)\nclass type metadataElement = element\n\n(* interface SVGForeignObjectElement *)\nclass type foreignObjectElement = object\n  inherit element\n\n  inherit tests\n\n  inherit langSpace\n\n  inherit externalResourcesRequired\n\n  inherit stylable\n\n  inherit transformable\n\n  method x : animatedLength t readonly_prop\n\n  method y : animatedLength t readonly_prop\n\n  method width : animatedLength t readonly_prop\n\n  method height : animatedLength t readonly_prop\nend\n\nlet createElement (doc : document t) name = doc##createElementNS xmlns (Js.string name)\n\nlet unsafeCreateElement doc name = Js.Unsafe.coerce (createElement doc name)\n\nlet createA doc : aElement t = unsafeCreateElement doc \"a\"\n\nlet createAltGlyph doc : altGlyphElement t = unsafeCreateElement doc \"altglyph\"\n\nlet createAltGlyphDef doc : altGlyphDefElement t = unsafeCreateElement doc \"altglyphdef\"\n\nlet createAltGlyphItem doc : altGlyphItemElement t =\n  unsafeCreateElement doc \"altglyphitem\"\n\nlet createAnimate doc : animateElement t = unsafeCreateElement doc \"animate\"\n\nlet createAnimateColor doc : animateColorElement t =\n  unsafeCreateElement doc \"animatecolor\"\n\nlet createAnimateMotion doc : animateMotionElement t =\n  unsafeCreateElement doc \"animatemotion\"\n\nlet createAnimateTransform doc : animateTransformElement t =\n  unsafeCreateElement doc \"animatetransform\"\n\nlet createCircle doc : circleElement t = unsafeCreateElement doc \"circle\"\n\nlet createClipPath doc : clipPathElement t = unsafeCreateElement doc \"clippath\"\n\n(* let createColorProfile doc : colorProfile t = unsafeCreateElement doc \"color-profile\" *)\nlet createCursor doc : cursorElement t = unsafeCreateElement doc \"cursor\"\n\nlet createDefs doc : defsElement t = unsafeCreateElement doc \"defs\"\n\nlet createDesc doc : descElement t = unsafeCreateElement doc \"desc\"\n\nlet createEllipse doc : ellipseElement t = unsafeCreateElement doc \"ellipse\"\n\n(* let createFe* *)\nlet createFilter doc : filterElement t = unsafeCreateElement doc \"filter\"\n\nlet createFont doc : fontElement t = unsafeCreateElement doc \"font\"\n\nlet createFontFace doc : fontElement t = unsafeCreateElement doc \"font-face\"\n\nlet createFontFaceFormat doc : fontElement t = unsafeCreateElement doc \"font-face-format\"\n\nlet createFontFaceName doc : fontElement t = unsafeCreateElement doc \"font-face-name\"\n\nlet createFontFaceSrc doc : fontElement t = unsafeCreateElement doc \"font-face-src\"\n\nlet createFontFaceUri doc : fontElement t = unsafeCreateElement doc \"font-face-uri\"\n\nlet createForeignObject doc : foreignObjectElement t =\n  unsafeCreateElement doc \"foreignObject\"\n\nlet createG doc : gElement t = unsafeCreateElement doc \"g\"\n\nlet createGlyph doc : glyphElement t = unsafeCreateElement doc \"glyph\"\n\nlet createGlyphRef doc : glyphElement t = unsafeCreateElement doc \"glyphref\"\n\nlet createhkern doc : element t = unsafeCreateElement doc \"hkern\"\n\nlet createImage doc : imageElement t = unsafeCreateElement doc \"image\"\n\nlet createLineElement doc : lineElement t = unsafeCreateElement doc \"line\"\n\nlet createLinearElement doc : linearGradientElement t =\n  unsafeCreateElement doc \"lineargradient\"\n\n(* let createMarker doc : markerElement *)\nlet createMask doc : maskElement t = unsafeCreateElement doc \"mask\"\n\nlet createMetaData doc : metadataElement t = unsafeCreateElement doc \"metadata\"\n\nlet createMissingGlyph doc : glyphElement t = unsafeCreateElement doc \"missing-glyph\"\n\nlet createMPath doc : mPathElement t = unsafeCreateElement doc \"mpath\"\n\nlet createPath doc : pathElement t = unsafeCreateElement doc \"path\"\n\nlet createPattern doc : patternElement t = unsafeCreateElement doc \"pattern\"\n\nlet createPolygon doc : polygonElement t = unsafeCreateElement doc \"polygon\"\n\nlet createPolyline doc : polyLineElement t = unsafeCreateElement doc \"polyline\"\n\nlet createRadialgradient doc : radialGradientElement t =\n  unsafeCreateElement doc \"radialgradient\"\n\nlet createRect doc : rectElement t = unsafeCreateElement doc \"rect\"\n\nlet createScript doc : scriptElement t = unsafeCreateElement doc \"script\"\n\nlet createSet doc : setElement t = unsafeCreateElement doc \"set\"\n\nlet createStop doc : stopElement t = unsafeCreateElement doc \"stop\"\n\nlet createStyle doc : styleElement t = unsafeCreateElement doc \"style\"\n\nlet createSvg doc : svgElement t = unsafeCreateElement doc \"svg\"\n\nlet createSwitch doc : switchElement t = unsafeCreateElement doc \"switch\"\n\nlet createSymbol doc : symbolElement t = unsafeCreateElement doc \"symbol\"\n\nlet createTextElement doc : textElement t = unsafeCreateElement doc \"text\"\n\nlet createTextpath doc : textPathElement t = unsafeCreateElement doc \"textpath\"\n\nlet createTitle doc : titleElement t = unsafeCreateElement doc \"title\"\n\nlet createTref doc : trefElement t = unsafeCreateElement doc \"tref\"\n\nlet createTspan doc : tspanElement t = unsafeCreateElement doc \"tspan\"\n\nlet createUse doc : useElement t = unsafeCreateElement doc \"use\"\n\nlet createView doc : viewElement t = unsafeCreateElement doc \"view\"\n\nlet createvkern doc : element t = unsafeCreateElement doc \"vkern\"\n\n(****)\n\nlet svg_element : element t constr = Js.Unsafe.global##._SVGElement\n\nlet document = Js.Unsafe.global##.document\n\nlet getElementById id : element t =\n  Js.Opt.case\n    (Js.Unsafe.global##.document##getElementById (Js.string id))\n    (fun () -> raise Not_found)\n    (fun e -> if Js.instanceof e svg_element then e else raise Not_found)\n\nmodule CoerceTo = struct\n  let element (e : #Dom.node Js.t) : element Js.t Js.opt =\n    if Js.instanceof e svg_element then Js.some (Js.Unsafe.coerce e) else Js.null\n\n  let unsafeCoerce (e : #element t) tag =\n    if Js.equals e##.tagName##toLowerCase (Js.string tag)\n    then Js.some (Js.Unsafe.coerce e)\n    else Js.null\n\n  let a e : aElement t opt = unsafeCoerce e \"a\"\n\n  let altGlyph e : altGlyphElement t opt = unsafeCoerce e \"altglyph\"\n\n  let altGlyphDef e : altGlyphDefElement t opt = unsafeCoerce e \"altglyphdef\"\n\n  let altGlyphItem e : altGlyphItemElement t opt = unsafeCoerce e \"altglyphitem\"\n\n  let animate e : animateElement t opt = unsafeCoerce e \"animate\"\n\n  let animateColor e : animateColorElement t opt = unsafeCoerce e \"animatecolor\"\n\n  let animateMotion e : animateMotionElement t opt = unsafeCoerce e \"animatemotion\"\n\n  let animateTransform e : animateTransformElement t opt =\n    unsafeCoerce e \"animatetransform\"\n\n  let circle e : circleElement t opt = unsafeCoerce e \"circle\"\n\n  let clipPath e : clipPathElement t opt = unsafeCoerce e \"clippath\"\n\n  (* let ColorProfile e : colorProfile t opt = unsafeCoerce e \"color-profile\" *)\n  let cursor e : cursorElement t opt = unsafeCoerce e \"cursor\"\n\n  let defs e : defsElement t opt = unsafeCoerce e \"defs\"\n\n  let desc e : descElement t opt = unsafeCoerce e \"desc\"\n\n  let ellipse e : ellipseElement t opt = unsafeCoerce e \"ellipse\"\n\n  (* let Fe* *)\n  let filter e : filterElement t opt = unsafeCoerce e \"filter\"\n\n  let font e : fontElement t opt = unsafeCoerce e \"font\"\n\n  let fontFace e : fontElement t opt = unsafeCoerce e \"font-face\"\n\n  let fontFaceFormat e : fontElement t opt = unsafeCoerce e \"font-face-format\"\n\n  let fontFaceName e : fontElement t opt = unsafeCoerce e \"font-face-name\"\n\n  let fontFaceSrc e : fontElement t opt = unsafeCoerce e \"font-face-src\"\n\n  let fontFaceUri e : fontElement t opt = unsafeCoerce e \"font-face-uri\"\n\n  let foreignObject e : foreignObjectElement t opt = unsafeCoerce e \"foreignobject\"\n\n  let g e : gElement t opt = unsafeCoerce e \"g\"\n\n  let glyph e : glyphElement t opt = unsafeCoerce e \"glyph\"\n\n  let glyphRef e : glyphElement t opt = unsafeCoerce e \"glyphref\"\n\n  let hkern e : element t opt = unsafeCoerce e \"hkern\"\n\n  let image e : imageElement t opt = unsafeCoerce e \"image\"\n\n  let lineElement e : lineElement t opt = unsafeCoerce e \"line\"\n\n  let linearElement e : linearGradientElement t opt = unsafeCoerce e \"lineargradient\"\n\n  (* let Marker e : markerElement *)\n  let mask e : maskElement t opt = unsafeCoerce e \"mask\"\n\n  let metaData e : metadataElement t opt = unsafeCoerce e \"metadata\"\n\n  let missingGlyph e : glyphElement t opt = unsafeCoerce e \"missing-glyph\"\n\n  let mPath e : mPathElement t opt = unsafeCoerce e \"mpath\"\n\n  let path e : pathElement t opt = unsafeCoerce e \"path\"\n\n  let pattern e : patternElement t opt = unsafeCoerce e \"pattern\"\n\n  let polygon e : polygonElement t opt = unsafeCoerce e \"polygon\"\n\n  let polyline e : polyLineElement t opt = unsafeCoerce e \"polyline\"\n\n  let radialgradient e : radialGradientElement t opt = unsafeCoerce e \"radialgradient\"\n\n  let rect e : rectElement t opt = unsafeCoerce e \"rect\"\n\n  let script e : scriptElement t opt = unsafeCoerce e \"script\"\n\n  let set e : setElement t opt = unsafeCoerce e \"set\"\n\n  let stop e : stopElement t opt = unsafeCoerce e \"stop\"\n\n  let style e : styleElement t opt = unsafeCoerce e \"style\"\n\n  let svg e : svgElement t opt = unsafeCoerce e \"svg\"\n\n  let switch e : switchElement t opt = unsafeCoerce e \"switch\"\n\n  let symbol e : symbolElement t opt = unsafeCoerce e \"symbol\"\n\n  let textElement e : textElement t opt = unsafeCoerce e \"text\"\n\n  let textpath e : textPathElement t opt = unsafeCoerce e \"textpath\"\n\n  let title e : titleElement t opt = unsafeCoerce e \"title\"\n\n  let tref e : trefElement t opt = unsafeCoerce e \"tref\"\n\n  let tspan e : tspanElement t opt = unsafeCoerce e \"tspan\"\n\n  let use e : useElement t opt = unsafeCoerce e \"use\"\n\n  let view e : viewElement t opt = unsafeCoerce e \"view\"\n\n  let vkern e : element t opt = unsafeCoerce e \"vkern\"\nend\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2014 Hugo Heuzard\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\n(* https://developer.mozilla.org/en-US/docs/Web/API/EventSource *)\nopen Js\nopen Dom\nopen! Import\n\ntype state =\n  | CONNECTING\n  | OPEN\n  | CLOSED\n\nclass type ['a] messageEvent = object\n  inherit ['a] Dom.event\n\n  method data : js_string t readonly_prop\n\n  method origin : js_string t readonly_prop\n\n  method lastEventId : js_string t readonly_prop\n  (* method source : unit *)\nend\n\nclass type eventSource = object ('self)\n  method url : string t readonly_prop\n\n  method withCredentials : bool t readonly_prop\n\n  method readyState : state readonly_prop\n\n  method close : unit meth\n\n  method onopen : ('self t, 'self messageEvent t) event_listener writeonly_prop\n\n  method onmessage : ('self t, 'self messageEvent t) event_listener writeonly_prop\n\n  method onerror : ('self t, 'self messageEvent t) event_listener writeonly_prop\nend\n\nclass type options = object\n  method withCredentials : bool t writeonly_prop\nend\n\nlet withCredentials b : options t =\n  let init = Js.Unsafe.obj [||] in\n  init##.withCredentials := Js.bool b;\n  init\n\nlet eventSource = Js.Unsafe.global##._EventSource\n\nlet eventSource_options = Js.Unsafe.global##._EventSource\n\nlet addEventListener = Dom.addEventListener\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2010 Jérôme Vouillon\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\n\nopen Js\nopen! Import\n\nclass type console = object\n  method log : _ -> unit meth\n\n  method log_2 : _ -> _ -> unit meth\n\n  method log_3 : _ -> _ -> _ -> unit meth\n\n  method log_4 : _ -> _ -> _ -> _ -> unit meth\n\n  method log_5 : _ -> _ -> _ -> _ -> _ -> unit meth\n\n  method log_6 : _ -> _ -> _ -> _ -> _ -> _ -> unit meth\n\n  method log_7 : _ -> _ -> _ -> _ -> _ -> _ -> _ -> unit meth\n\n  method log_8 : _ -> _ -> _ -> _ -> _ -> _ -> _ -> _ -> unit meth\n\n  method debug : _ -> unit meth\n\n  method debug_2 : _ -> _ -> unit meth\n\n  method debug_3 : _ -> _ -> _ -> unit meth\n\n  method debug_4 : _ -> _ -> _ -> _ -> unit meth\n\n  method debug_5 : _ -> _ -> _ -> _ -> _ -> unit meth\n\n  method info : _ -> unit meth\n\n  method info_2 : _ -> _ -> unit meth\n\n  method info_3 : _ -> _ -> _ -> unit meth\n\n  method info_4 : _ -> _ -> _ -> _ -> unit meth\n\n  method info_5 : _ -> _ -> _ -> _ -> _ -> unit meth\n\n  method warn : _ -> unit meth\n\n  method warn_2 : _ -> _ -> unit meth\n\n  method warn_3 : _ -> _ -> _ -> unit meth\n\n  method warn_4 : _ -> _ -> _ -> _ -> unit meth\n\n  method warn_5 : _ -> _ -> _ -> _ -> _ -> unit meth\n\n  method error : _ -> unit meth\n\n  method error_2 : _ -> _ -> unit meth\n\n  method error_3 : _ -> _ -> _ -> unit meth\n\n  method error_4 : _ -> _ -> _ -> _ -> unit meth\n\n  method error_5 : _ -> _ -> _ -> _ -> _ -> unit meth\n\n  method assert_ : bool t -> unit meth\n\n  method assert_1 : bool t -> _ -> unit meth\n\n  method assert_2 : bool t -> _ -> _ -> unit meth\n\n  method assert_3 : bool t -> _ -> _ -> _ -> unit meth\n\n  method assert_4 : bool t -> _ -> _ -> _ -> _ -> unit meth\n\n  method assert_5 : bool t -> _ -> _ -> _ -> _ -> _ -> unit meth\n\n  method dir : _ -> unit meth\n\n  method dirxml : Dom.node t -> unit meth\n\n  method trace : unit meth\n\n  method group : _ -> unit meth\n\n  method group_2 : _ -> _ -> unit meth\n\n  method group_3 : _ -> _ -> _ -> unit meth\n\n  method group_4 : _ -> _ -> _ -> _ -> unit meth\n\n  method group_5 : _ -> _ -> _ -> _ -> _ -> unit meth\n\n  method groupCollapsed : _ -> unit meth\n\n  method groupCollapsed_2 : _ -> _ -> unit meth\n\n  method groupCollapsed_3 : _ -> _ -> _ -> unit meth\n\n  method groupCollapsed_4 : _ -> _ -> _ -> _ -> unit meth\n\n  method groupCollapsed_5 : _ -> _ -> _ -> _ -> _ -> unit meth\n\n  method groupEnd : unit meth\n\n  method time : js_string t -> unit meth\n\n  method timeEnd : js_string t -> unit meth\nend\n\nexternal get_console : unit -> console t = \"caml_js_get_console\"\n\nlet console = get_console ()\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2015 Stéphane Legrand\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\nopen! Import\n\ntype positionErrorCode\n\ntype watchId\n\nclass type coordinates = object\n  method latitude : Js.number_t Js.readonly_prop\n\n  method longitude : Js.number_t Js.readonly_prop\n\n  method altitude : Js.number_t Js.opt Js.readonly_prop\n\n  method accuracy : Js.number_t Js.readonly_prop\n\n  method altitudeAccuracy : Js.number_t Js.opt Js.readonly_prop\n\n  method heading : Js.number_t Js.opt Js.readonly_prop\n\n  method speed : Js.number_t Js.opt Js.readonly_prop\nend\n\nclass type position = object\n  method coords : coordinates Js.t Js.readonly_prop\n\n  method timestamp : Js.date Js.readonly_prop\nend\n\nclass type positionOptions = object\n  method enableHighAccuracy : bool Js.writeonly_prop\n\n  method timeout : int Js.writeonly_prop\n\n  method maximumAge : int Js.writeonly_prop\nend\n\nclass type positionError = object\n  method _PERMISSION_DENIED_ : positionErrorCode Js.readonly_prop\n\n  method _POSITION_UNAVAILABLE_ : positionErrorCode Js.readonly_prop\n\n  method _TIMEOUT : positionErrorCode Js.readonly_prop\n\n  method code : positionErrorCode Js.readonly_prop\n\n  method message : Js.js_string Js.t Js.readonly_prop\nend\n\nclass type geolocation = object\n  method getCurrentPosition :\n       (position Js.t -> unit) Js.callback\n    -> (positionError Js.t -> unit) Js.callback\n    -> positionOptions Js.t\n    -> unit Js.meth\n\n  method watchPosition :\n       (position Js.t -> unit) Js.callback\n    -> (positionError Js.t -> unit) Js.callback\n    -> positionOptions Js.t\n    -> watchId Js.meth\n\n  method clearWatch : watchId -> unit Js.meth\nend\n\nlet empty_position_options () = Js.Unsafe.obj [||]\n\nlet geolocation =\n  let x = Js.Unsafe.global##.navigator in\n  if Js.Optdef.test x then x##.geolocation else x\n\n(* undefined *)\n\nlet is_supported () = Js.Optdef.test geolocation\n","class type intersectionObserverEntry = object\n  method target : Dom.node Js.t Js.readonly_prop\n\n  method boundingClientRect : Dom_html.clientRect Js.t Js.readonly_prop\n\n  method rootBounds : Dom_html.clientRect Js.t Js.opt Js.readonly_prop\n\n  method intersectionRect : Dom_html.clientRect Js.t Js.readonly_prop\n\n  method intersectionRatio : Js.number_t Js.readonly_prop\n\n  method isIntersecting : bool Js.t Js.readonly_prop\n\n  method time : Js.number_t Js.readonly_prop\nend\n\nclass type intersectionObserverOptions = object\n  method root : Dom.node Js.t Js.writeonly_prop\n\n  method rootMargin : Js.js_string Js.t Js.writeonly_prop\n\n  method threshold : Js.number_t Js.js_array Js.t Js.writeonly_prop\nend\n\nclass type intersectionObserver = object\n  method root : Dom.node Js.t Js.opt Js.readonly_prop\n\n  method rootMargin : Js.js_string Js.t Js.readonly_prop\n\n  method thresholds : Js.number_t Js.js_array Js.t Js.readonly_prop\n\n  method observe : #Dom.node Js.t -> unit Js.meth\n\n  method unobserve : #Dom.node Js.t -> unit Js.meth\n\n  method disconnect : unit Js.meth\n\n  method takeRecords : intersectionObserverEntry Js.t Js.js_array Js.meth\nend\n\nlet empty_intersection_observer_options () : intersectionObserverOptions Js.t =\n  Js.Unsafe.obj [||]\n\nlet intersectionObserver_unsafe = Js.Unsafe.global##._IntersectionObserver\n\nlet is_supported () = Js.Optdef.test intersectionObserver_unsafe\n\nlet intersectionObserver :\n    (   (   intersectionObserverEntry Js.t Js.js_array Js.t\n         -> intersectionObserver Js.t\n         -> unit)\n        Js.callback\n     -> intersectionObserverOptions Js.t\n     -> intersectionObserver Js.t)\n    Js.constr =\n  intersectionObserver_unsafe\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2018 Stéphane Legrand\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\nopen! Import\n\nmodule type Shared = sig\n  class type object_options = object\n    method localeMatcher : Js.js_string Js.t Js.prop\n  end\n\n  val object_options : unit -> object_options Js.t\n\n  class type _object = object\n    method supportedLocalesOf :\n         Js.js_string Js.t Js.js_array Js.t\n      -> object_options Js.t Js.optdef\n      -> Js.js_string Js.t Js.js_array Js.t Js.meth\n  end\nend\n\nmodule Shared : Shared = struct\n  class type object_options = object\n    method localeMatcher : Js.js_string Js.t Js.prop\n  end\n\n  let object_options () =\n    object%js\n      val mutable localeMatcher = Js.string \"best fit\"\n    end\n\n  class type _object = object\n    method supportedLocalesOf :\n         Js.js_string Js.t Js.js_array Js.t\n      -> object_options Js.t Js.optdef\n      -> Js.js_string Js.t Js.js_array Js.t Js.meth\n  end\nend\n\nmodule Collator = struct\n  include Shared\n\n  class type resolved_options = object\n    method locale : Js.js_string Js.t Js.readonly_prop\n\n    method usage : Js.js_string Js.t Js.readonly_prop\n\n    method sensitivity : Js.js_string Js.t Js.readonly_prop\n\n    method ignorePunctuation : bool Js.t Js.readonly_prop\n\n    method collation : Js.js_string Js.t Js.readonly_prop\n\n    method numeric : bool Js.t Js.readonly_prop\n\n    method caseFirst : Js.js_string Js.t Js.readonly_prop\n  end\n\n  class type options = object\n    method localeMatcher : Js.js_string Js.t Js.prop\n\n    method usage : Js.js_string Js.t Js.prop\n\n    method sensitivity : Js.js_string Js.t Js.prop\n\n    method ignorePunctuation : bool Js.t Js.prop\n\n    method numeric : bool Js.t Js.prop\n\n    method caseFirst : Js.js_string Js.t Js.prop\n  end\n\n  let options () =\n    object%js\n      val mutable localeMatcher = Js.string \"best fit\"\n\n      val mutable usage = Js.string \"sort\"\n\n      val mutable sensitivity = Js.string \"variant\"\n\n      val mutable ignorePunctuation = Js._false\n\n      val mutable numeric = Js._false\n\n      val mutable caseFirst = Js.string \"false\"\n    end\n\n  class type t = object\n    method compare : (Js.js_string Js.t -> Js.js_string Js.t -> int) Js.readonly_prop\n\n    method resolvedOptions : unit -> resolved_options Js.t Js.meth\n  end\nend\n\nmodule DateTimeFormat = struct\n  include Shared\n\n  class type resolved_options = object\n    method locale : Js.js_string Js.t Js.readonly_prop\n\n    method calendar : Js.js_string Js.t Js.readonly_prop\n\n    method numberingSystem : Js.js_string Js.t Js.readonly_prop\n\n    method timeZone : Js.js_string Js.t Js.readonly_prop\n\n    method hour12 : bool Js.t Js.readonly_prop\n\n    method weekday : Js.js_string Js.t Js.optdef_prop\n\n    method era : Js.js_string Js.t Js.optdef_prop\n\n    method year : Js.js_string Js.t Js.optdef_prop\n\n    method month : Js.js_string Js.t Js.optdef_prop\n\n    method day : Js.js_string Js.t Js.optdef_prop\n\n    method hour : Js.js_string Js.t Js.optdef_prop\n\n    method minute : Js.js_string Js.t Js.optdef_prop\n\n    method second : Js.js_string Js.t Js.optdef_prop\n\n    method timeZoneName : Js.js_string Js.t Js.optdef_prop\n  end\n\n  class type options = object\n    method dateStyle : Js.js_string Js.t Js.optdef Js.prop\n\n    method timeStyle : Js.js_string Js.t Js.optdef Js.prop\n\n    method calendar : Js.js_string Js.t Js.optdef Js.prop\n\n    method dayPeriod : Js.js_string Js.t Js.optdef Js.prop\n\n    method numberingSystem : Js.js_string Js.t Js.optdef Js.prop\n\n    method localeMatcher : Js.js_string Js.t Js.prop\n\n    method timeZone : Js.js_string Js.t Js.optdef Js.prop\n\n    method hour12 : bool Js.t Js.optdef Js.prop\n\n    method hourCycle : Js.js_string Js.t Js.optdef Js.prop\n\n    method formatMatcher : Js.js_string Js.t Js.prop\n\n    method weekday : Js.js_string Js.t Js.optdef Js.prop\n\n    method era : Js.js_string Js.t Js.optdef Js.prop\n\n    method year : Js.js_string Js.t Js.optdef Js.prop\n\n    method month : Js.js_string Js.t Js.optdef Js.prop\n\n    method day : Js.js_string Js.t Js.optdef Js.prop\n\n    method hour : Js.js_string Js.t Js.optdef Js.prop\n\n    method minute : Js.js_string Js.t Js.optdef Js.prop\n\n    method second : Js.js_string Js.t Js.optdef Js.prop\n\n    method fractionalSecondDigits : int Js.optdef Js.prop\n\n    method timeZoneName : Js.js_string Js.t Js.optdef Js.prop\n  end\n\n  let options () : options Js.t =\n    object%js\n      val mutable dateStyle = Js.undefined\n\n      val mutable timeStyle = Js.undefined\n\n      val mutable calendar = Js.undefined\n\n      val mutable dayPeriod = Js.undefined\n\n      val mutable numberingSystem = Js.undefined\n\n      val mutable localeMatcher = Js.string \"best fit\"\n\n      val mutable timeZone = Js.undefined\n\n      val mutable hour12 = Js.undefined\n\n      val mutable hourCycle = Js.undefined\n\n      val mutable formatMatcher = Js.string \"best fit\"\n\n      val mutable weekday = Js.undefined\n\n      val mutable era = Js.undefined\n\n      val mutable year = Js.undefined\n\n      val mutable month = Js.undefined\n\n      val mutable day = Js.undefined\n\n      val mutable hour = Js.undefined\n\n      val mutable minute = Js.undefined\n\n      val mutable second = Js.undefined\n\n      val mutable fractionalSecondDigits = Js.undefined\n\n      val mutable timeZoneName = Js.undefined\n    end\n\n  class type format_part = object\n    method _type : Js.js_string Js.t Js.readonly_prop\n\n    method _value : Js.js_string Js.t Js.readonly_prop\n  end\n\n  class type t = object\n    method format : (Js.date Js.t -> Js.js_string Js.t) Js.readonly_prop\n\n    method formatToParts :\n      Js.date Js.t Js.optdef -> format_part Js.t Js.js_array Js.t Js.meth\n\n    method resolvedOptions : unit -> resolved_options Js.t Js.meth\n  end\nend\n\nmodule NumberFormat = struct\n  include Shared\n\n  class type resolved_options = object\n    method locale : Js.js_string Js.t Js.readonly_prop\n\n    method numberingSystem : Js.js_string Js.t Js.readonly_prop\n\n    method style : Js.js_string Js.t Js.readonly_prop\n\n    method currency : Js.js_string Js.t Js.optdef_prop\n\n    method currencyDisplay : Js.js_string Js.t Js.optdef_prop\n\n    method useGrouping : bool Js.t Js.readonly_prop\n\n    method minimumIntegerDigits : int Js.optdef_prop\n\n    method minimumFractionDigits : int Js.optdef_prop\n\n    method maximumFractionDigits : int Js.optdef_prop\n\n    method minimumSignificantDigits : int Js.optdef_prop\n\n    method maximumSignificantDigits : int Js.optdef_prop\n  end\n\n  class type options = object\n    method compactDisplay : Js.js_string Js.t Js.optdef Js.prop\n\n    method currency : Js.js_string Js.t Js.optdef Js.prop\n\n    method currencyDisplay : Js.js_string Js.t Js.optdef Js.prop\n\n    method currencySign : Js.js_string Js.t Js.optdef Js.prop\n\n    method localeMatcher : Js.js_string Js.t Js.prop\n\n    method notation : Js.js_string Js.t Js.optdef Js.prop\n\n    method numberingSystem : Js.js_string Js.t Js.optdef Js.prop\n\n    method signDisplay : Js.js_string Js.t Js.optdef Js.prop\n\n    method style : Js.js_string Js.t Js.prop\n\n    method unit : Js.js_string Js.t Js.optdef Js.prop\n\n    method unitDisplay : Js.js_string Js.t Js.optdef Js.prop\n\n    method useGrouping : bool Js.t Js.prop\n\n    method roundingMode : Js.js_string Js.t Js.optdef Js.prop\n\n    method roundingPriority : Js.js_string Js.t Js.optdef Js.prop\n\n    method roundingIncrement : Js.js_string Js.t Js.optdef Js.prop\n\n    method trailingZeroDisplay : Js.js_string Js.t Js.optdef Js.prop\n\n    method minimumIntegerDigits : int Js.optdef Js.prop\n\n    method minimumFractionDigits : int Js.optdef Js.prop\n\n    method maximumFractionDigits : int Js.optdef Js.prop\n\n    method minimumSignificantDigits : int Js.optdef Js.prop\n\n    method maximumSignificantDigits : int Js.optdef Js.prop\n  end\n\n  let options () : options Js.t =\n    object%js\n      val mutable compactDisplay = Js.undefined\n\n      val mutable currency = Js.undefined\n\n      val mutable currencyDisplay = Js.undefined\n\n      val mutable currencySign = Js.undefined\n\n      val mutable localeMatcher = Js.string \"best fit\"\n\n      val mutable notation = Js.undefined\n\n      val mutable numberingSystem = Js.undefined\n\n      val mutable signDisplay = Js.undefined\n\n      val mutable style = Js.string \"decimal\"\n\n      val mutable unit = Js.undefined\n\n      val mutable unitDisplay = Js.undefined\n\n      val mutable useGrouping = Js._true\n\n      val mutable roundingMode = Js.undefined\n\n      val mutable roundingPriority = Js.undefined\n\n      val mutable roundingIncrement = Js.undefined\n\n      val mutable trailingZeroDisplay = Js.undefined\n\n      val mutable minimumIntegerDigits = Js.undefined\n\n      val mutable minimumFractionDigits = Js.undefined\n\n      val mutable maximumFractionDigits = Js.undefined\n\n      val mutable minimumSignificantDigits = Js.undefined\n\n      val mutable maximumSignificantDigits = Js.undefined\n    end\n\n  class type format_part = object\n    method _type : Js.js_string Js.t Js.readonly_prop\n\n    method _value : Js.js_string Js.t Js.readonly_prop\n  end\n\n  class type t = object\n    method format : (Js.number Js.t -> Js.js_string Js.t) Js.readonly_prop\n\n    method formatToParts :\n      Js.number Js.t Js.optdef -> format_part Js.t Js.js_array Js.t Js.meth\n\n    method resolvedOptions : unit -> resolved_options Js.t Js.meth\n  end\nend\n\nmodule PluralRules = struct\n  include Shared\n\n  class type resolved_options = object\n    method locale : Js.js_string Js.t Js.readonly_prop\n\n    method pluralCategories : Js.js_string Js.t Js.js_array Js.t Js.readonly_prop\n\n    method _type : Js.js_string Js.t Js.readonly_prop\n\n    method minimumIntegerDigits : int Js.optdef_prop\n\n    method minimumFractionDigits : int Js.optdef_prop\n\n    method maximumFractionDigits : int Js.optdef_prop\n\n    method minimumSignificantDigits : int Js.optdef_prop\n\n    method maximumSignificantDigits : int Js.optdef_prop\n  end\n\n  class type options = object\n    method localeMatcher : Js.js_string Js.t Js.prop\n\n    method _type : Js.js_string Js.t Js.prop\n  end\n\n  let options () : options Js.t =\n    object%js\n      val mutable localeMatcher = Js.string \"best fit\"\n\n      val mutable _type = Js.string \"cardinal\"\n    end\n\n  class type t = object\n    method select : Js.number Js.t -> Js.js_string Js.t Js.meth\n\n    method resolvedOptions : unit -> resolved_options Js.t Js.meth\n  end\nend\n\nclass type intl = object\n  method _Collator : Collator._object Js.t Js.readonly_prop\n\n  method _DateTimeFormat : DateTimeFormat._object Js.t Js.readonly_prop\n\n  method _NumberFormat : NumberFormat._object Js.t Js.readonly_prop\n\n  method _PluralRules : PluralRules._object Js.t Js.readonly_prop\n\n  method getCanonicalLocales :\n    Js.js_string Js.t Js.js_array Js.t -> Js.js_string Js.t Js.js_array Js.t Js.meth\nend\n\nlet intl = Js.Unsafe.global##._Intl\n\nlet collator_constr = Js.Unsafe.global##._Intl##._Collator\n\nlet dateTimeFormat_constr = Js.Unsafe.global##._Intl##._DateTimeFormat\n\nlet numberFormat_constr = Js.Unsafe.global##._Intl##._NumberFormat\n\nlet pluralRules_constr = Js.Unsafe.global##._Intl##._PluralRules\n\nlet is_supported () = Js.Optdef.test intl\n","\ntype coq_Decision = bool\n\n(** val decide : coq_Decision -> bool **)\n\nlet decide decision =\n  decision\n\ntype ('a, 'b) coq_RelDecision = 'a -> 'b -> coq_Decision\n\n(** val decide_rel :\n    ('a1, 'a2) coq_RelDecision -> 'a1 -> 'a2 -> coq_Decision **)\n\nlet decide_rel relDecision =\n  relDecision\n\ntype 'a coq_Top = 'a\n\n(** val top : 'a1 coq_Top -> 'a1 **)\n\nlet top top0 =\n  top0\n\ntype 'a coq_Bottom = 'a\n\n(** val bottom : 'a1 coq_Bottom -> 'a1 **)\n\nlet bottom bottom0 =\n  bottom0\n","open Univ_gen_ext\n\ntype __ = Obj.t\n\ntype coq_MPropF =\n| Var of char list\n| Bot\n| Imp of coq_MPropF * coq_MPropF\n| Box of coq_MPropF\n\n(** val coq_Top : coq_MPropF **)\n\nlet coq_Top =\n  Imp (Bot, Bot)\n\n(** val coq_Neg : coq_MPropF -> coq_MPropF **)\n\nlet coq_Neg a =\n  Imp (a, Bot)\n\n(** val coq_And : coq_MPropF -> coq_MPropF -> coq_MPropF **)\n\nlet coq_And a b =\n  coq_Neg (Imp (a, (coq_Neg b)))\n\n(** val coq_Or : coq_MPropF -> coq_MPropF -> coq_MPropF **)\n\nlet coq_Or a b =\n  Imp ((coq_Neg a), b)\n\n(** val coq_Diam : coq_MPropF -> coq_MPropF **)\n\nlet coq_Diam a =\n  coq_Neg (Box (coq_Neg a))\n\n(** val eq_dec_form : coq_MPropF -> coq_MPropF -> bool **)\n\nlet rec eq_dec_form m x0 =\n  match m with\n  | Var s ->\n    (match x0 with\n     | Var s0 ->\n       let rec f s1 x1 =\n         match s1 with\n         | [] -> (match x1 with\n                  | [] -> true\n                  | _::_ -> false)\n         | a::s2 ->\n           (match x1 with\n            | [] -> false\n            | a0::s3 ->\n              (* If this appears, you're using Ascii internals. Please don't *)\n (fun f c ->\n  let n = Char.code c in\n  let h i = (n land (1 lsl i)) <> 0 in\n  f (h 0) (h 1) (h 2) (h 3) (h 4) (h 5) (h 6) (h 7))\n                (fun b b0 b1 b2 b3 b4 b5 b6 ->\n                (* If this appears, you're using Ascii internals. Please don't *)\n (fun f c ->\n  let n = Char.code c in\n  let h i = (n land (1 lsl i)) <> 0 in\n  f (h 0) (h 1) (h 2) (h 3) (h 4) (h 5) (h 6) (h 7))\n                  (fun b7 b8 b9 b10 b11 b12 b13 b14 ->\n                  if b\n                  then if b7\n                       then if b0\n                            then if b8\n                                 then if b1\n                                      then if b9\n                                           then if b2\n                                                then if b10\n                                                     then if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                     else false\n                                                else if b10\n                                                     then false\n                                                     else if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                           else false\n                                      else if b9\n                                           then false\n                                           else if b2\n                                                then if b10\n                                                     then if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                     else false\n                                                else if b10\n                                                     then false\n                                                     else if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                 else false\n                            else if b8\n                                 then false\n                                 else if b1\n                                      then if b9\n                                           then if b2\n                                                then if b10\n                                                     then if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                     else false\n                                                else if b10\n                                                     then false\n                                                     else if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                           else false\n                                      else if b9\n                                           then false\n                                           else if b2\n                                                then if b10\n                                                     then if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                     else false\n                                                else if b10\n                                                     then false\n                                                     else if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                       else false\n                  else if b7\n                       then false\n                       else if b0\n                            then if b8\n                                 then if b1\n                                      then if b9\n                                           then if b2\n                                                then if b10\n                                                     then if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                     else false\n                                                else if b10\n                                                     then false\n                                                     else if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                           else false\n                                      else if b9\n                                           then false\n                                           else if b2\n                                                then if b10\n                                                     then if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                     else false\n                                                else if b10\n                                                     then false\n                                                     else if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                 else false\n                            else if b8\n                                 then false\n                                 else if b1\n                                      then if b9\n                                           then if b2\n                                                then if b10\n                                                     then if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                     else false\n                                                else if b10\n                                                     then false\n                                                     else if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                           else false\n                                      else if b9\n                                           then false\n                                           else if b2\n                                                then if b10\n                                                     then if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                     else false\n                                                else if b10\n                                                     then false\n                                                     else if b3\n                                                          then if b11\n                                                               then if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                               else false\n                                                          else if b11\n                                                               then false\n                                                               else if b4\n                                                                    then \n                                                                    if b12\n                                                                    then \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b12\n                                                                    then false\n                                                                    else \n                                                                    if b5\n                                                                    then \n                                                                    if b13\n                                                                    then \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b13\n                                                                    then false\n                                                                    else \n                                                                    if b6\n                                                                    then \n                                                                    if b14\n                                                                    then \n                                                                    f s2 s3\n                                                                    else false\n                                                                    else \n                                                                    if b14\n                                                                    then false\n                                                                    else \n                                                                    f s2 s3)\n                  a0)\n                a)\n       in f s s0\n     | _ -> false)\n  | Bot -> (match x0 with\n            | Bot -> true\n            | _ -> false)\n  | Imp (m0, m1) ->\n    (match x0 with\n     | Imp (m2, m3) -> if eq_dec_form m0 m2 then eq_dec_form m1 m3 else false\n     | _ -> false)\n  | Box m0 -> (match x0 with\n               | Box m1 -> eq_dec_form m0 m1\n               | _ -> false)\n\ntype nobox_gen_ext = (coq_MPropF, __) univ_gen_ext\n\n(** val unBox_formula : coq_MPropF -> coq_MPropF **)\n\nlet unBox_formula = function\n| Box a0 -> a0\n| x -> x\n\n(** val unboxed_list : coq_MPropF list -> coq_MPropF list **)\n\nlet rec unboxed_list = function\n| [] -> []\n| h :: t -> (unBox_formula h) :: (unboxed_list t)\n\n(** val top_boxes : coq_MPropF list -> coq_MPropF list **)\n\nlet rec top_boxes = function\n| [] -> []\n| h :: t ->\n  (match h with\n   | Box a -> (Box a) :: (top_boxes t)\n   | _ -> top_boxes t)\n","\ntype nat =\n| O\n| S of nat\n\ntype ('a, 'b) sum =\n| Coq_inl of 'a\n| Coq_inr of 'b\n\n(** val fst : ('a1 * 'a2) -> 'a1 **)\n\nlet fst = function\n| (x, _) -> x\n\n(** val snd : ('a1 * 'a2) -> 'a2 **)\n\nlet snd = function\n| (_, y) -> y\n\n(** val length : 'a1 list -> nat **)\n\nlet rec length = function\n| [] -> O\n| _ :: l' -> S (length l')\n\n(** val app : 'a1 list -> 'a1 list -> 'a1 list **)\n\nlet rec app l m =\n  match l with\n  | [] -> m\n  | a :: l1 -> a :: (app l1 m)\n\ntype comparison =\n| Eq\n| Lt\n| Gt\n","open Datatypes\n\n(** val le_lt_dec : nat -> nat -> bool **)\n\nlet rec le_lt_dec n m =\n  match n with\n  | O -> true\n  | S n0 -> (match m with\n             | O -> false\n             | S n1 -> le_lt_dec n0 n1)\n\n(** val le_gt_dec : nat -> nat -> bool **)\n\nlet le_gt_dec =\n  le_lt_dec\n\n(** val le_dec : nat -> nat -> bool **)\n\nlet le_dec =\n  le_gt_dec\n\n(** val lt_dec : nat -> nat -> bool **)\n\nlet lt_dec n m =\n  le_dec (S n) m\n","open Datatypes\n\n(** val add : nat -> nat -> nat **)\n\nlet rec add n m =\n  match n with\n  | O -> m\n  | S p -> S (add p m)\n","\n(** val string_dec : char list -> char list -> bool **)\n\nlet rec string_dec s x =\n  match s with\n  | [] -> (match x with\n           | [] -> true\n           | _::_ -> false)\n  | a::s0 ->\n    (match x with\n     | [] -> false\n     | a0::s1 -> if (=) a a0 then string_dec s0 s1 else false)\n","open Datatypes\nopen Nat\nopen String\nopen Base\n\ntype variable = char list\n\ntype form =\n| Var of variable\n| Bot\n| And of form * form\n| Or of form * form\n| Implies of form * form\n| Box of form\n\n(** val fomula_bottom : form coq_Bottom **)\n\nlet fomula_bottom =\n  Bot\n\n(** val form_top : form coq_Top **)\n\nlet form_top =\n  Implies (Bot, Bot)\n\n(** val string_dec : (char list, char list) coq_RelDecision **)\n\nlet string_dec =\n  string_dec\n\n(** val form_eq_dec : (form, form) coq_RelDecision **)\n\nlet rec form_eq_dec f x0 =\n  match f with\n  | Var v -> (match x0 with\n              | Var v0 -> decide_rel string_dec v v0\n              | _ -> false)\n  | Bot -> (match x0 with\n            | Bot -> true\n            | _ -> false)\n  | And (f0, f1) ->\n    (match x0 with\n     | And (f2, f3) -> if form_eq_dec f0 f2 then form_eq_dec f1 f3 else false\n     | _ -> false)\n  | Or (f0, f1) ->\n    (match x0 with\n     | Or (f2, f3) -> if form_eq_dec f0 f2 then form_eq_dec f1 f3 else false\n     | _ -> false)\n  | Implies (f0, f1) ->\n    (match x0 with\n     | Implies (f2, f3) ->\n       if form_eq_dec f0 f2 then form_eq_dec f1 f3 else false\n     | _ -> false)\n  | Box f0 -> (match x0 with\n               | Box f1 -> form_eq_dec f0 f1\n               | _ -> false)\n\n(** val weight : form -> nat **)\n\nlet rec weight = function\n| And (_UU03c6_0, _UU03c8_) ->\n  add (add (S (S O)) (weight _UU03c6_0)) (weight _UU03c8_)\n| Or (_UU03c6_0, _UU03c8_) ->\n  add (add (S (S (S O))) (weight _UU03c6_0)) (weight _UU03c8_)\n| Implies (_UU03c6_0, _UU03c8_) ->\n  add (add (S O) (weight _UU03c6_0)) (weight _UU03c8_)\n| Box _UU03c6_0 -> add (S O) (weight _UU03c6_0)\n| _ -> S O\n","\n(** val in_dec : ('a1 -> 'a1 -> bool) -> 'a1 -> 'a1 list -> bool **)\n\nlet rec in_dec h a = function\n| [] -> false\n| y :: l0 -> let s = h y a in if s then true else in_dec h a l0\n\n(** val remove : ('a1 -> 'a1 -> bool) -> 'a1 -> 'a1 list -> 'a1 list **)\n\nlet rec remove eq_dec x = function\n| [] -> []\n| y :: tl ->\n  if eq_dec x y then remove eq_dec x tl else y :: (remove eq_dec x tl)\n\n(** val list_eq_dec : ('a1 -> 'a1 -> bool) -> 'a1 list -> 'a1 list -> bool **)\n\nlet rec list_eq_dec eq_dec l l' =\n  match l with\n  | [] -> (match l' with\n           | [] -> true\n           | _ :: _ -> false)\n  | y :: l0 ->\n    (match l' with\n     | [] -> false\n     | a :: l1 -> if eq_dec y a then list_eq_dec eq_dec l0 l1 else false)\n\n(** val map : ('a1 -> 'a2) -> 'a1 list -> 'a2 list **)\n\nlet rec map f = function\n| [] -> []\n| a :: t -> (f a) :: (map f t)\n\n(** val nodup : ('a1 -> 'a1 -> bool) -> 'a1 list -> 'a1 list **)\n\nlet rec nodup decA = function\n| [] -> []\n| x :: xs -> if in_dec decA x xs then nodup decA xs else x :: (nodup decA xs)\n","open Base\n\n(** val foldl : ('a1 -> 'a2 -> 'a1) -> 'a1 -> 'a2 list -> 'a1 **)\n\nlet rec foldl f a = function\n| [] -> a\n| x :: l0 -> foldl f (f a x) l0\n\n(** val elem_of_list_dec :\n    ('a1, 'a1) coq_RelDecision -> ('a1, 'a1 list) coq_RelDecision **)\n\nlet rec elem_of_list_dec dec x = function\n| [] -> false\n| y :: l0 ->\n  if decide (decide_rel dec x y) then true else elem_of_list_dec dec x l0\n","open Datatypes\nopen Base\n\n(** val comparison_eq_dec : (comparison, comparison) coq_RelDecision **)\n\nlet comparison_eq_dec x y =\n  match x with\n  | Eq -> (match y with\n           | Eq -> true\n           | _ -> false)\n  | Lt -> (match y with\n           | Lt -> true\n           | _ -> false)\n  | Gt -> (match y with\n           | Gt -> true\n           | _ -> false)\n","open Datatypes\nopen Formulas\nopen List\nopen Base\nopen List0\nopen Numbers\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val decidable_is_implication : form -> form -> coq_Decision **)\n\nlet decidable_is_implication _UU03c6_ _UU03c8_ =\n  match _UU03c6_ with\n  | Implies (_, f) -> decide (decide_rel form_eq_dec f _UU03c8_)\n  | _ -> false\n\n(** val decidable_is_negation : form -> form -> coq_Decision **)\n\nlet decidable_is_negation _UU03c6_ _UU03c8_ =\n  decide (decide_rel form_eq_dec _UU03c6_ (Implies (_UU03c8_, Bot)))\n\n(** val obviously_smaller : form -> form -> comparison **)\n\nlet rec obviously_smaller _UU03c6_ _UU03c8_ =\n  match _UU03c6_ with\n  | Var _ ->\n    (match _UU03c8_ with\n     | Bot -> Gt\n     | Implies (f, _) ->\n       (match f with\n        | Bot -> Lt\n        | _ ->\n          if decide (decide_rel form_eq_dec _UU03c6_ _UU03c8_)\n          then Lt\n          else if decide\n                    (decidable_is_negation _UU03c6_ (Implies (_UU03c8_, Bot)))\n               then Gt\n               else if decide\n                         (decidable_is_negation _UU03c8_ (Implies (_UU03c6_,\n                           Bot)))\n                    then Lt\n                    else if decide\n                              (decidable_is_implication _UU03c6_ _UU03c8_)\n                         then Gt\n                         else if decide\n                                   (decidable_is_implication _UU03c8_\n                                     _UU03c6_)\n                              then Lt\n                              else Eq)\n     | _ ->\n       if decide (decide_rel form_eq_dec _UU03c6_ _UU03c8_)\n       then Lt\n       else if decide\n                 (decidable_is_negation _UU03c6_ (Implies (_UU03c8_, Bot)))\n            then Gt\n            else if decide\n                      (decidable_is_negation _UU03c8_ (Implies (_UU03c6_,\n                        Bot)))\n                 then Lt\n                 else if decide (decidable_is_implication _UU03c6_ _UU03c8_)\n                      then Gt\n                      else if decide\n                                (decidable_is_implication _UU03c8_ _UU03c6_)\n                           then Lt\n                           else Eq)\n  | Bot -> Lt\n  | And (_UU03c6_0, _UU03c8_0) ->\n    (match _UU03c8_ with\n     | Bot -> Gt\n     | Implies (f, _) ->\n       (match f with\n        | Bot -> Lt\n        | _ ->\n          let c = obviously_smaller _UU03c6_0 _UU03c8_ in\n          let c0 = obviously_smaller _UU03c8_0 _UU03c8_ in\n          (match c with\n           | Eq -> (match c0 with\n                    | Lt -> Lt\n                    | _ -> Eq)\n           | Lt -> Lt\n           | Gt -> c0))\n     | _ ->\n       let c = obviously_smaller _UU03c6_0 _UU03c8_ in\n       let c0 = obviously_smaller _UU03c8_0 _UU03c8_ in\n       (match c with\n        | Eq -> (match c0 with\n                 | Lt -> Lt\n                 | _ -> Eq)\n        | Lt -> Lt\n        | Gt -> c0))\n  | Or (_UU03c6_0, _UU03c8_0) ->\n    (match _UU03c8_ with\n     | Bot -> Gt\n     | Implies (f, _) ->\n       (match f with\n        | Bot -> Lt\n        | _ ->\n          let c = obviously_smaller _UU03c6_0 _UU03c8_ in\n          let c0 = obviously_smaller _UU03c8_0 _UU03c8_ in\n          (match c with\n           | Eq -> (match c0 with\n                    | Gt -> Gt\n                    | _ -> Eq)\n           | Lt -> c0\n           | Gt -> Gt))\n     | _ ->\n       let c = obviously_smaller _UU03c6_0 _UU03c8_ in\n       let c0 = obviously_smaller _UU03c8_0 _UU03c8_ in\n       (match c with\n        | Eq -> (match c0 with\n                 | Gt -> Gt\n                 | _ -> Eq)\n        | Lt -> c0\n        | Gt -> Gt))\n  | Implies (f, _) ->\n    (match f with\n     | Var _ ->\n       (match _UU03c8_ with\n        | Bot -> Gt\n        | Implies (f1, _) ->\n          (match f1 with\n           | Bot -> Lt\n           | _ ->\n             if decide (decide_rel form_eq_dec _UU03c6_ _UU03c8_)\n             then Lt\n             else if decide\n                       (decidable_is_negation _UU03c6_ (Implies (_UU03c8_,\n                         Bot)))\n                  then Gt\n                  else if decide\n                            (decidable_is_negation _UU03c8_ (Implies\n                              (_UU03c6_, Bot)))\n                       then Lt\n                       else if decide\n                                 (decidable_is_implication _UU03c6_ _UU03c8_)\n                            then Gt\n                            else if decide\n                                      (decidable_is_implication _UU03c8_\n                                        _UU03c6_)\n                                 then Lt\n                                 else Eq)\n        | _ ->\n          if decide (decide_rel form_eq_dec _UU03c6_ _UU03c8_)\n          then Lt\n          else if decide\n                    (decidable_is_negation _UU03c6_ (Implies (_UU03c8_, Bot)))\n               then Gt\n               else if decide\n                         (decidable_is_negation _UU03c8_ (Implies (_UU03c6_,\n                           Bot)))\n                    then Lt\n                    else if decide\n                              (decidable_is_implication _UU03c6_ _UU03c8_)\n                         then Gt\n                         else if decide\n                                   (decidable_is_implication _UU03c8_\n                                     _UU03c6_)\n                              then Lt\n                              else Eq)\n     | Bot -> Gt\n     | Box _ ->\n       (match _UU03c8_ with\n        | Bot -> Gt\n        | Implies (f2, _) ->\n          (match f2 with\n           | Bot -> Lt\n           | _ ->\n             if decide (decide_rel form_eq_dec _UU03c6_ _UU03c8_)\n             then Lt\n             else if decide\n                       (decidable_is_negation _UU03c6_ (Implies (_UU03c8_,\n                         Bot)))\n                  then Gt\n                  else if decide\n                            (decidable_is_negation _UU03c8_ (Implies\n                              (_UU03c6_, Bot)))\n                       then Lt\n                       else if decide\n                                 (decidable_is_implication _UU03c6_ _UU03c8_)\n                            then Gt\n                            else if decide\n                                      (decidable_is_implication _UU03c8_\n                                        _UU03c6_)\n                                 then Lt\n                                 else Eq)\n        | _ ->\n          if decide (decide_rel form_eq_dec _UU03c6_ _UU03c8_)\n          then Lt\n          else if decide\n                    (decidable_is_negation _UU03c6_ (Implies (_UU03c8_, Bot)))\n               then Gt\n               else if decide\n                         (decidable_is_negation _UU03c8_ (Implies (_UU03c6_,\n                           Bot)))\n                    then Lt\n                    else if decide\n                              (decidable_is_implication _UU03c6_ _UU03c8_)\n                         then Gt\n                         else if decide\n                                   (decidable_is_implication _UU03c8_\n                                     _UU03c6_)\n                              then Lt\n                              else Eq)\n     | _ ->\n       (match _UU03c8_ with\n        | Bot -> Gt\n        | Implies (f3, _) ->\n          (match f3 with\n           | Bot -> Lt\n           | _ ->\n             if decide (decide_rel form_eq_dec _UU03c6_ _UU03c8_)\n             then Lt\n             else if decide\n                       (decidable_is_negation _UU03c6_ (Implies (_UU03c8_,\n                         Bot)))\n                  then Gt\n                  else if decide\n                            (decidable_is_negation _UU03c8_ (Implies\n                              (_UU03c6_, Bot)))\n                       then Lt\n                       else if decide\n                                 (decidable_is_implication _UU03c6_ _UU03c8_)\n                            then Gt\n                            else if decide\n                                      (decidable_is_implication _UU03c8_\n                                        _UU03c6_)\n                                 then Lt\n                                 else Eq)\n        | _ ->\n          if decide (decide_rel form_eq_dec _UU03c6_ _UU03c8_)\n          then Lt\n          else if decide\n                    (decidable_is_negation _UU03c6_ (Implies (_UU03c8_, Bot)))\n               then Gt\n               else if decide\n                         (decidable_is_negation _UU03c8_ (Implies (_UU03c6_,\n                           Bot)))\n                    then Lt\n                    else if decide\n                              (decidable_is_implication _UU03c6_ _UU03c8_)\n                         then Gt\n                         else if decide\n                                   (decidable_is_implication _UU03c8_\n                                     _UU03c6_)\n                              then Lt\n                              else Eq))\n  | Box _ ->\n    (match _UU03c8_ with\n     | Bot -> Gt\n     | Implies (f0, _) ->\n       (match f0 with\n        | Bot -> Lt\n        | _ ->\n          if decide (decide_rel form_eq_dec _UU03c6_ _UU03c8_)\n          then Lt\n          else if decide\n                    (decidable_is_negation _UU03c6_ (Implies (_UU03c8_, Bot)))\n               then Gt\n               else if decide\n                         (decidable_is_negation _UU03c8_ (Implies (_UU03c6_,\n                           Bot)))\n                    then Lt\n                    else if decide\n                              (decidable_is_implication _UU03c6_ _UU03c8_)\n                         then Gt\n                         else if decide\n                                   (decidable_is_implication _UU03c8_\n                                     _UU03c6_)\n                              then Lt\n                              else Eq)\n     | _ ->\n       if decide (decide_rel form_eq_dec _UU03c6_ _UU03c8_)\n       then Lt\n       else if decide\n                 (decidable_is_negation _UU03c6_ (Implies (_UU03c8_, Bot)))\n            then Gt\n            else if decide\n                      (decidable_is_negation _UU03c8_ (Implies (_UU03c6_,\n                        Bot)))\n                 then Lt\n                 else if decide (decidable_is_implication _UU03c6_ _UU03c8_)\n                      then Gt\n                      else if decide\n                                (decidable_is_implication _UU03c8_ _UU03c6_)\n                           then Lt\n                           else Eq)\n\n(** val choose_conj : form -> form -> form **)\n\nlet choose_conj _UU03c6_ _UU03c8_ =\n  match obviously_smaller _UU03c6_ _UU03c8_ with\n  | Eq -> And (_UU03c6_, _UU03c8_)\n  | Lt -> _UU03c6_\n  | Gt -> _UU03c8_\n\n(** val make_conj : form -> form -> form **)\n\nlet make_conj _UU03c6_ _UU03c8_ = match _UU03c8_ with\n| And (_UU03c8_1, _UU03c8_2) ->\n  (match obviously_smaller _UU03c6_ _UU03c8_1 with\n   | Eq -> And (_UU03c6_, (And (_UU03c8_1, _UU03c8_2)))\n   | Lt -> And (_UU03c6_, _UU03c8_2)\n   | Gt -> And (_UU03c8_1, _UU03c8_2))\n| Or (_UU03c8_1, _UU03c8_2) ->\n  if decide\n       (decide_rel comparison_eq_dec (obviously_smaller _UU03c6_ _UU03c8_1)\n         Lt)\n  then _UU03c6_\n  else if decide\n            (decide_rel comparison_eq_dec\n              (obviously_smaller _UU03c6_ _UU03c8_2) Lt)\n       then _UU03c6_\n       else choose_conj _UU03c6_ (Or (_UU03c8_1, _UU03c8_2))\n| Implies (_UU03c8_1, _UU03c8_2) ->\n  if decide\n       (decide_rel comparison_eq_dec (obviously_smaller _UU03c6_ _UU03c8_1)\n         Lt)\n  then choose_conj _UU03c6_ _UU03c8_2\n  else choose_conj _UU03c6_ _UU03c8_\n| _ ->\n  (match _UU03c6_ with\n   | Implies (_UU03c6_1, _UU03c6_2) ->\n     if decide\n          (decide_rel comparison_eq_dec\n            (obviously_smaller _UU03c8_ _UU03c6_1) Lt)\n     then choose_conj _UU03c6_2 _UU03c8_\n     else choose_conj _UU03c6_ _UU03c8_\n   | _ -> choose_conj _UU03c6_ _UU03c8_)\n\n(** val choose_disj : form -> form -> form **)\n\nlet choose_disj _UU03c6_ _UU03c8_ =\n  match obviously_smaller _UU03c6_ _UU03c8_ with\n  | Eq ->\n    (match obviously_smaller _UU03c8_ _UU03c6_ with\n     | Eq -> Or (_UU03c6_, _UU03c8_)\n     | Lt -> _UU03c6_\n     | Gt -> _UU03c8_)\n  | Lt -> _UU03c8_\n  | Gt -> _UU03c6_\n\n(** val make_disj : form -> form -> form **)\n\nlet make_disj _UU03c6_ _UU03c8_ = match _UU03c8_ with\n| And (_UU03c8_1, _UU03c8_2) ->\n  if decide\n       (decide_rel comparison_eq_dec (obviously_smaller _UU03c6_ _UU03c8_1)\n         Gt)\n  then _UU03c6_\n  else if decide\n            (decide_rel comparison_eq_dec\n              (obviously_smaller _UU03c6_ _UU03c8_2) Gt)\n       then _UU03c6_\n       else choose_disj _UU03c6_ (And (_UU03c8_1, _UU03c8_2))\n| Or (_UU03c8_1, _UU03c8_2) ->\n  (match obviously_smaller _UU03c6_ _UU03c8_1 with\n   | Eq -> Or (_UU03c6_, (Or (_UU03c8_1, _UU03c8_2)))\n   | Lt -> Or (_UU03c8_1, _UU03c8_2)\n   | Gt -> Or (_UU03c6_, _UU03c8_2))\n| _ -> choose_disj _UU03c6_ _UU03c8_\n\n(** val make_impl : form -> form -> form **)\n\nlet rec make_impl _UU03c6_ _UU03c8_ = match _UU03c8_ with\n| Implies (_UU03c8_1, _UU03c8_2) ->\n  make_impl (make_conj _UU03c6_ _UU03c8_1) _UU03c8_2\n| _ ->\n  if decide\n       (decide_rel comparison_eq_dec (obviously_smaller _UU03c6_ _UU03c8_) Lt)\n  then Implies (Bot, Bot)\n  else if decide\n            (decide_rel comparison_eq_dec (obviously_smaller _UU03c6_ Bot) Lt)\n       then Implies (Bot, Bot)\n       else if decide\n                 (decide_rel comparison_eq_dec\n                   (obviously_smaller _UU03c8_ (Implies (Bot, Bot))) Gt)\n            then Implies (Bot, Bot)\n            else if decide\n                      (decide_rel comparison_eq_dec\n                        (obviously_smaller _UU03c6_ (Implies (Bot, Bot))) Gt)\n                 then _UU03c8_\n                 else if decide\n                           (decide_rel comparison_eq_dec\n                             (obviously_smaller _UU03c8_ Bot) Lt)\n                      then Implies (_UU03c6_, Bot)\n                      else if decide (decidable_is_negation _UU03c6_ _UU03c8_)\n                           then Implies (_UU03c6_, Bot)\n                           else if decide\n                                     (decidable_is_negation _UU03c8_ _UU03c6_)\n                                then _UU03c8_\n                                else Implies (_UU03c6_, _UU03c8_)\n\n(** val conjunction : form list -> form **)\n\nlet conjunction l =\n  foldl make_conj (Implies (Bot, Bot)) (nodup form_eq_dec l)\n\n(** val disjunction : form list -> form **)\n\nlet disjunction l =\n  foldl make_disj Bot (nodup form_eq_dec l)\n\n(** val in_map_aux :\n    form list -> (form -> __ -> 'a1) -> form list -> 'a1 list **)\n\nlet rec in_map_aux _UU0393_ f = function\n| [] -> []\n| a :: _UU0393_'0 -> (f a __) :: (in_map_aux _UU0393_ f _UU0393_'0)\n\n(** val in_map : form list -> (form -> __ -> 'a1) -> 'a1 list **)\n\nlet in_map _UU0393_ f =\n  in_map_aux _UU0393_ f _UU0393_\n\n(** val rm : form -> form list -> form list **)\n\nlet rec rm x = function\n| [] -> []\n| h :: t -> if form_eq_dec x h then t else h :: (rm x t)\n\n(** val open_box : form -> form **)\n\nlet open_box _UU03c6_ = match _UU03c6_ with\n| Box _UU03c6_0 -> _UU03c6_0\n| _ -> _UU03c6_\n","open CML_Syntax\n\n(** val coq_XBoxed_list : coq_MPropF list -> coq_MPropF list **)\n\nlet rec coq_XBoxed_list = function\n| [] -> []\n| h :: t -> (unBox_formula h) :: (h :: (coq_XBoxed_list t))\n\ntype coq_Seq = coq_MPropF list * coq_MPropF list\n\ntype coq_IdPRule =\n| IdPRule_I of char list * coq_MPropF list * coq_MPropF list\n   * coq_MPropF list * coq_MPropF list\n\ntype coq_IdBRule =\n| IdBRule_I of coq_MPropF * coq_MPropF list * coq_MPropF list\n   * coq_MPropF list * coq_MPropF list\n\ntype coq_BotLRule =\n| BotLRule_I of coq_MPropF list * coq_MPropF list * coq_MPropF list\n\ntype coq_ImpRRule =\n| ImpRRule_I of coq_MPropF * coq_MPropF * coq_MPropF list * coq_MPropF list\n   * coq_MPropF list * coq_MPropF list\n\ntype coq_ImpLRule =\n| ImpLRule_I of coq_MPropF * coq_MPropF * coq_MPropF list * coq_MPropF list\n   * coq_MPropF list * coq_MPropF list\n\ntype coq_GLRRule =\n| GLRRule_I of coq_MPropF * coq_MPropF list * coq_MPropF list\n   * coq_MPropF list * coq_MPropF list * nobox_gen_ext\n","\ntype 'a coq_InT =\n| InT_eq' of 'a * 'a list\n| InT_cons of 'a * 'a list * 'a coq_InT\n\n(** val coq_InT_eq : 'a1 -> 'a1 list -> 'a1 coq_InT **)\n\nlet coq_InT_eq a l =\n  InT_eq' (a, l)\n","open Datatypes\nopen GenT\n\n(** val coq_InT_app_or :\n    'a1 list -> 'a1 list -> 'a1 -> 'a1 coq_InT -> ('a1 coq_InT, 'a1 coq_InT)\n    sum **)\n\nlet rec coq_InT_app_or l l2 a x =\n  match l with\n  | [] -> Coq_inr x\n  | y :: l0 ->\n    (match x with\n     | InT_eq' (_, _) -> Coq_inl (coq_InT_eq y l0)\n     | InT_cons (_, _, i) ->\n       let x0 = coq_InT_app_or l0 l2 a i in\n       (match x0 with\n        | Coq_inl i0 -> Coq_inl (InT_cons (y, l0, i0))\n        | Coq_inr i0 -> Coq_inr i0))\n\n(** val coq_InT_or_app :\n    'a1 list -> 'a1 list -> 'a1 -> ('a1 coq_InT, 'a1 coq_InT) sum -> 'a1\n    coq_InT **)\n\nlet rec coq_InT_or_app l l2 a x =\n  match l with\n  | [] ->\n    (match x with\n     | Coq_inl _ -> assert false (* absurd case *)\n     | Coq_inr i -> i)\n  | y :: l0 ->\n    (match x with\n     | Coq_inl i ->\n       (match i with\n        | InT_eq' (_, _) ->\n          coq_InT_eq y\n            (let rec app0 l1 m =\n               match l1 with\n               | [] -> m\n               | a0 :: l3 -> a0 :: (app0 l3 m)\n             in app0 l0 l2)\n        | InT_cons (_, _, i0) ->\n          InT_cons (y, (app l0 l2), (coq_InT_or_app l0 l2 a (Coq_inl i0))))\n     | Coq_inr i ->\n       InT_cons (y, (app l0 l2), (coq_InT_or_app l0 l2 a (Coq_inr i))))\n","open CML_Syntax\nopen Datatypes\nopen List\nopen List_lemmasT\nopen Specif\nopen GenT\nopen Gen_tacs\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val in_splitT :\n    coq_MPropF -> coq_MPropF list -> (coq_MPropF list, (coq_MPropF list, __)\n    sigT) sigT **)\n\nlet rec in_splitT x = function\n| [] -> assert false (* absurd case *)\n| y :: l0 ->\n  let s = eq_dec_form x y in\n  if s\n  then Coq_existT ([], (Coq_existT (l0, __)))\n  else let h0 = in_splitT x l0 in\n       let Coq_existT (x0, s0) = h0 in\n       let Coq_existT (x1, _) = s0 in\n       Coq_existT ((app (y :: []) x0), (Coq_existT (x1, __)))\n\n(** val eq_dec_listsF : coq_MPropF list -> coq_MPropF list -> bool **)\n\nlet eq_dec_listsF =\n  list_eq_dec eq_dec_form\n\n(** val eq_dec_seqs : coq_MPropF list rel -> coq_MPropF list rel -> bool **)\n\nlet eq_dec_seqs s0 s1 =\n  let (l, l0) = s0 in\n  let (l1, l2) = s1 in\n  let s = eq_dec_listsF l l1 in if s then eq_dec_listsF l0 l2 else false\n\n(** val seqs_in_splitT :\n    coq_MPropF list rel -> coq_MPropF list rel list -> (coq_MPropF list rel\n    list, (coq_MPropF list rel list, __) sigT) sigT **)\n\nlet rec seqs_in_splitT x = function\n| [] -> assert false (* absurd case *)\n| y :: l0 ->\n  let s = eq_dec_seqs x y in\n  if s\n  then Coq_existT ([], (Coq_existT (l0, __)))\n  else let h0 = seqs_in_splitT x l0 in\n       let Coq_existT (x0, s0) = h0 in\n       let Coq_existT (x1, _) = s0 in\n       Coq_existT ((app (y :: []) x0), (Coq_existT (x1, __)))\n\n(** val coq_In_InT_seqs :\n    coq_MPropF list rel -> coq_MPropF list rel list -> coq_MPropF list rel\n    coq_InT **)\n\nlet coq_In_InT_seqs seq = function\n| [] -> assert false (* absurd case *)\n| y :: l ->\n  let h = seqs_in_splitT seq (y :: l) in\n  let Coq_existT (x, s) = h in\n  let Coq_existT (x0, _) = s in\n  coq_InT_or_app x (seq :: x0) seq (Coq_inr (coq_InT_eq seq x0))\n","open CML_Syntax\nopen List\n\n(** val coq_In_dec : coq_MPropF list -> coq_MPropF -> bool **)\n\nlet coq_In_dec l a =\n  in_dec eq_dec_form a l\n\n(** val remove_list :\n    coq_MPropF list -> coq_MPropF list -> coq_MPropF list **)\n\nlet rec remove_list l1 l2 =\n  match l1 with\n  | [] -> l2\n  | h1 :: t1 -> remove eq_dec_form h1 (remove_list t1 l2)\n","open CML_Syntax\nopen Datatypes\nopen GLS_calcs\nopen Specif\nopen List_lems\nopen Remove_list_lems\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val dec_prop_var_in :\n    (coq_MPropF list * coq_MPropF list) -> ((char list, __) sigT, __) sum **)\n\nlet dec_prop_var_in = function\n| (l, l0) ->\n  let rec f = function\n  | [] -> Coq_inr __\n  | y :: l2 ->\n    (match f l2 with\n     | Coq_inl s0 ->\n       let Coq_existT (x, _) = s0 in Coq_inl (Coq_existT (x, __))\n     | Coq_inr _ ->\n       (match y with\n        | Var s0 ->\n          let s1 = coq_In_dec l0 (Var s0) in\n          if s1 then Coq_inl (Coq_existT (s0, __)) else Coq_inr __\n        | _ -> Coq_inr __))\n  in f l\n\n(** val dec_is_box : coq_MPropF -> ((coq_MPropF, __) sigT, __) sum **)\n\nlet dec_is_box = function\n| Box m -> Coq_inl (Coq_existT (m, __))\n| _ -> Coq_inr __\n\n(** val dec_box_in :\n    (coq_MPropF list * coq_MPropF list) -> ((coq_MPropF, __) sigT, __) sum **)\n\nlet dec_box_in = function\n| (l, l0) ->\n  let rec f = function\n  | [] -> Coq_inr __\n  | y :: l2 ->\n    (match f l2 with\n     | Coq_inl s0 ->\n       let Coq_existT (x, _) = s0 in Coq_inl (Coq_existT (x, __))\n     | Coq_inr _ ->\n       let s0 = dec_is_box y in\n       (match s0 with\n        | Coq_inl s1 ->\n          let s2 = coq_In_dec l0 y in\n          if s2\n          then Coq_inl (let Coq_existT (x, _) = s1 in Coq_existT (x, __))\n          else Coq_inr __\n        | Coq_inr _ -> Coq_inr __))\n  in f l\n\n(** val dec_init_rules :\n    coq_Seq -> (((coq_IdPRule, coq_IdBRule) sum, coq_BotLRule) sum, __) sum **)\n\nlet dec_init_rules = function\n| (l, l0) ->\n  let s0 = dec_prop_var_in (l, l0) in\n  (match s0 with\n   | Coq_inl s1 ->\n     let Coq_existT (x, _) = s1 in\n     Coq_inl (Coq_inl (Coq_inl\n     (let h = in_splitT (Var x) l in\n      let Coq_existT (x0, s2) = h in\n      let Coq_existT (x1, _) = s2 in\n      let h0 = in_splitT (Var x) l0 in\n      let Coq_existT (x2, s3) = h0 in\n      let Coq_existT (x3, _) = s3 in IdPRule_I (x, x0, x1, x2, x3))))\n   | Coq_inr _ ->\n     let s1 = coq_In_dec l Bot in\n     if s1\n     then Coq_inl (Coq_inr\n            (let i = in_splitT Bot l in\n             let Coq_existT (x, s2) = i in\n             let Coq_existT (x0, _) = s2 in BotLRule_I (x, x0, l0)))\n     else let s2 = dec_box_in (l, l0) in\n          (match s2 with\n           | Coq_inl s3 ->\n             Coq_inl (Coq_inl (Coq_inr\n               (let Coq_existT (x, _) = s3 in\n                let h = in_splitT (Box x) (fst (l, l0)) in\n                let Coq_existT (x0, s4) = h in\n                let Coq_existT (x1, _) = s4 in\n                let h0 = in_splitT (Box x) (snd (l, l0)) in\n                let Coq_existT (x2, s5) = h0 in\n                let Coq_existT (x3, _) = s5 in IdBRule_I (x, x0, x1, x2, x3))))\n           | Coq_inr _ -> Coq_inr __))\n","open Datatypes\n\nmodule Nat =\n struct\n  (** val eq_dec : nat -> nat -> bool **)\n\n  let rec eq_dec n m =\n    match n with\n    | O -> (match m with\n            | O -> true\n            | S _ -> false)\n    | S n0 -> (match m with\n               | O -> false\n               | S n1 -> eq_dec n0 n1)\n end\n","open CML_Syntax\nopen Datatypes\nopen GLS_calcs\nopen List\nopen List_lemmasT\nopen PeanoNat\nopen Specif\nopen GenT\nopen List_lems\nopen Univ_gen_ext\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val proj1_sigT2 : ('a1, 'a2) sigT -> 'a1 **)\n\nlet proj1_sigT2 = function\n| Coq_existT (a, _) -> a\n\n(** val proj2_sigT2 : ('a1, 'a2) sigT -> 'a2 **)\n\nlet proj2_sigT2 = function\n| Coq_existT (_, b) -> b\n\n(** val coq_In_InT_pair :\n    coq_MPropF -> nat -> (coq_MPropF * nat) list -> (coq_MPropF * nat) coq_InT **)\n\nlet rec coq_In_InT_pair a n = function\n| [] -> assert false (* absurd case *)\n| y :: l0 ->\n  let h0 =\n    let (m, n0) = y in\n    let s = eq_dec_form a m in if s then Nat.eq_dec n n0 else false\n  in\n  if h0\n  then coq_InT_eq (a, n) l0\n  else InT_cons (y, l0, (coq_In_InT_pair a n l0))\n\n(** val coq_InT_map_iff :\n    ('a1 -> 'a2) -> 'a1 list -> 'a2 -> ('a2 coq_InT -> ('a1, __ * 'a1\n    coq_InT) sigT) * (('a1, __ * 'a1 coq_InT) sigT -> 'a2 coq_InT) **)\n\nlet rec coq_InT_map_iff f = function\n| [] ->\n  (fun _ -> ((fun _ -> assert false (* absurd case *)), (fun _ ->\n    assert false (* absurd case *))))\n| y :: l0 ->\n  let iHl = coq_InT_map_iff f l0 in\n  (fun y0 -> ((fun x ->\n  match x with\n  | InT_eq' (_, _) -> Coq_existT (y, (__, (coq_InT_eq y l0)))\n  | InT_cons (_, _, x0) ->\n    let p = iHl y0 in\n    let (s, _) = p in\n    let x1 = s x0 in\n    let Coq_existT (x2, p0) = x1 in\n    let (_, i) = p0 in Coq_existT (x2, (__, (InT_cons (y, l0, i))))),\n  (fun x ->\n  let p = iHl y0 in\n  let (_, i) = p in\n  let p0 = proj2_sigT2 x in\n  let (_, i0) = p0 in\n  (match i0 with\n   | InT_eq' (_, _) -> coq_InT_eq (f y) (map f l0)\n   | InT_cons (_, _, x0) ->\n     let x1 = Coq_existT ((proj1_sigT2 x), (__, x0)) in\n     let x2 = i x1 in InT_cons ((f y), (map f l0), x2)))))\n\n(** val pos_top_imps : coq_MPropF list -> (coq_MPropF * nat) list **)\n\nlet rec pos_top_imps = function\n| [] -> []\n| h :: t ->\n  (match h with\n   | Imp (a, b) ->\n     ((Imp (a, b)), (S\n       O)) :: (map (fun y -> ((fst y), (S (snd y)))) (pos_top_imps t))\n   | _ -> map (fun y -> ((fst y), (S (snd y)))) (pos_top_imps t))\n\n(** val top_boxes_nobox_gen_ext : coq_MPropF list -> nobox_gen_ext **)\n\nlet rec top_boxes_nobox_gen_ext = function\n| [] -> Coq_univ_gen_ext_nil\n| y :: l0 ->\n  (match y with\n   | Box m ->\n     Coq_univ_gen_ext_cons ((Box m), (top_boxes l0), l0,\n       (top_boxes_nobox_gen_ext l0))\n   | x ->\n     Coq_univ_gen_ext_extra (x, (top_boxes l0), l0, __,\n       (top_boxes_nobox_gen_ext l0)))\n\n(** val flatten_list : 'a1 list list -> 'a1 list **)\n\nlet rec flatten_list = function\n| [] -> []\n| h :: t -> app h (flatten_list t)\n\n(** val coq_InT_flatten_list_InT_elem :\n    'a1 list list -> 'a1 -> 'a1 coq_InT -> ('a1 list, 'a1 coq_InT * 'a1 list\n    coq_InT) sigT **)\n\nlet rec coq_InT_flatten_list_InT_elem l b x =\n  match l with\n  | [] -> assert false (* absurd case *)\n  | y :: l0 ->\n    let x0 = coq_InT_app_or y (flatten_list l0) b x in\n    (match x0 with\n     | Coq_inl i -> Coq_existT (y, (i, (coq_InT_eq y l0)))\n     | Coq_inr i ->\n       let s = coq_InT_flatten_list_InT_elem l0 b in\n       let i0 = s i in\n       let Coq_existT (x1, p) = i0 in\n       let (i1, i2) = p in Coq_existT (x1, (i1, (InT_cons (y, l0, i2)))))\n\n(** val coq_InT_trans_flatten_list :\n    'a1 list list -> 'a1 list -> 'a1 -> 'a1 coq_InT -> 'a1 list coq_InT ->\n    'a1 coq_InT **)\n\nlet rec coq_InT_trans_flatten_list l bs b x x0 =\n  match l with\n  | [] -> assert false (* absurd case *)\n  | y :: l0 ->\n    (match x0 with\n     | InT_eq' (_, _) -> coq_InT_or_app bs (flatten_list l0) b (Coq_inl x)\n     | InT_cons (_, _, x1) ->\n       coq_InT_or_app y (flatten_list l0) b (Coq_inr\n         (coq_InT_trans_flatten_list l0 bs b x x1)))\n\n(** val list_of_splits :\n    coq_MPropF list -> ((coq_MPropF list * coq_MPropF list) list, __) sigT **)\n\nlet rec list_of_splits = function\n| [] -> Coq_existT ((([], []) :: []), __)\n| y :: l0 ->\n  let Coq_existT (x, _) = list_of_splits l0 in\n  Coq_existT\n  ((app (([], (y :: l0)) :: [])\n     (map (fun y0 -> ((y :: (fst y0)), (snd y0))) x)), __)\n\n(** val listInserts :\n    coq_MPropF list -> coq_MPropF -> coq_MPropF list list **)\n\nlet listInserts l a =\n  map (fun y -> app (fst y) (a :: (snd y))) (proj1_sigT2 (list_of_splits l))\n\n(** val listInsertsR_Seqs :\n    coq_MPropF list -> coq_MPropF list -> coq_MPropF -> (coq_MPropF\n    list * coq_MPropF list) list **)\n\nlet listInsertsR_Seqs _UU0393_ _UU0394_ a =\n  map (fun y -> (y, _UU0394_)) (listInserts _UU0393_ a)\n\n(** val listInsertsL_Seqs :\n    coq_MPropF list -> coq_MPropF list -> coq_MPropF -> (coq_MPropF\n    list * coq_MPropF list) list **)\n\nlet listInsertsL_Seqs _UU0393_ _UU0394_ a =\n  map (fun y -> (_UU0393_, y)) (listInserts _UU0394_ a)\n\n(** val remove_nth :\n    nat -> coq_MPropF -> coq_MPropF list -> coq_MPropF list **)\n\nlet rec remove_nth n a l =\n  match n with\n  | O -> l\n  | S m ->\n    (match m with\n     | O ->\n       (match l with\n        | [] -> []\n        | b :: tl -> if eq_dec_form a b then tl else b :: tl)\n     | S _ -> (match l with\n               | [] -> []\n               | b :: tl -> b :: (remove_nth m a tl)))\n\n(** val nth_split :\n    nat -> coq_MPropF list -> coq_MPropF list * coq_MPropF list **)\n\nlet rec nth_split n l =\n  match n with\n  | O -> ([], l)\n  | S m ->\n    (match m with\n     | O -> (match l with\n             | [] -> ([], [])\n             | b :: tl -> ((b :: []), tl))\n     | S _ ->\n       (match l with\n        | [] -> ([], [])\n        | b :: tl -> ((b :: (fst (nth_split m tl))), (snd (nth_split m tl)))))\n\n(** val prems_Imp_R : (coq_MPropF * nat) list -> coq_Seq -> coq_Seq list **)\n\nlet rec prems_Imp_R l s =\n  match l with\n  | [] -> []\n  | p :: t ->\n    let (c, n) = p in\n    (match n with\n     | O -> prems_Imp_R t s\n     | S m ->\n       (match c with\n        | Imp (a, b) ->\n          app\n            (listInsertsR_Seqs (fst s)\n              (app (fst (nth_split m (remove_nth (S m) c (snd s))))\n                (b :: (snd (nth_split m (remove_nth (S m) c (snd s)))))) a)\n            (prems_Imp_R t s)\n        | _ -> prems_Imp_R t s))\n\n(** val coq_In_pos_top_imps_split_l :\n    coq_MPropF list -> coq_MPropF -> nat -> (coq_MPropF list, (coq_MPropF\n    list, __) sigT) sigT **)\n\nlet rec coq_In_pos_top_imps_split_l l a n =\n  match l with\n  | [] -> assert false (* absurd case *)\n  | y :: l0 ->\n    (match y with\n     | Imp (m, m0) ->\n       let h =\n         coq_In_InT_pair a (S n) (((Imp (m, m0)), (S\n           O)) :: (map (fun y0 -> ((fst y0), (S (snd y0)))) (pos_top_imps l0)))\n       in\n       (match h with\n        | InT_eq' (_, _) -> Coq_existT ([], (Coq_existT (l0, __)))\n        | InT_cons (_, _, _) ->\n          (match n with\n           | O -> assert false (* absurd case *)\n           | S n0 ->\n             let s = coq_In_pos_top_imps_split_l l0 a n0 in\n             let Coq_existT (x, s0) = s in\n             let Coq_existT (x0, _) = s0 in\n             Coq_existT (((Imp (m, m0)) :: x), (Coq_existT (x0, __)))))\n     | x ->\n       (match n with\n        | O -> assert false (* absurd case *)\n        | S n0 ->\n          let s = coq_In_pos_top_imps_split_l l0 a n0 in\n          let Coq_existT (x0, s0) = s in\n          let Coq_existT (x1, _) = s0 in\n          Coq_existT ((x :: x0), (Coq_existT (x1, __)))))\n\n(** val coq_ImpR_help01 :\n    coq_Seq -> coq_Seq -> (coq_MPropF * nat) list -> coq_Seq coq_InT -> (nat,\n    (coq_MPropF, (coq_MPropF, (coq_MPropF list, (coq_MPropF list, (coq_MPropF\n    list, (coq_MPropF list, __) sigT) sigT) sigT) sigT) sigT) sigT) sigT **)\n\nlet coq_ImpR_help01 prem s l3 =\n  let (l, l0) = s in\n  let rec f l1 x =\n    match l1 with\n    | [] -> assert false (* absurd case *)\n    | y :: l2 ->\n      let (m, n) = y in\n      (match m with\n       | Imp (m0, m1) ->\n         (match n with\n          | O ->\n            let s0 = f l2 x in\n            let Coq_existT (x0, s1) = s0 in\n            let Coq_existT (x1, s2) = s1 in\n            let Coq_existT (x2, s3) = s2 in\n            let Coq_existT (x3, s4) = s3 in\n            let Coq_existT (x4, s5) = s4 in\n            let Coq_existT (x5, s6) = s5 in\n            let Coq_existT (x6, _) = s6 in\n            Coq_existT (x0, (Coq_existT (x1, (Coq_existT (x2, (Coq_existT\n            (x3, (Coq_existT (x4, (Coq_existT (x5, (Coq_existT (x6,\n            __)))))))))))))\n          | S n0 ->\n            let x0 =\n              coq_InT_app_or\n                (listInsertsR_Seqs (fst (l, l0))\n                  (app\n                    (fst\n                      (nth_split n0\n                        (remove_nth (S n0) (Imp (m0, m1)) (snd (l, l0)))))\n                    (m1 :: (snd\n                             (nth_split n0\n                               (remove_nth (S n0) (Imp (m0, m1))\n                                 (snd (l, l0))))))) m0)\n                (let rec prems_Imp_R0 l4 s0 =\n                   match l4 with\n                   | [] -> []\n                   | p :: t ->\n                     let (c, n1) = p in\n                     (match n1 with\n                      | O -> prems_Imp_R0 t s0\n                      | S m2 ->\n                        (match c with\n                         | Imp (a, b) ->\n                           app\n                             (listInsertsR_Seqs (fst s0)\n                               (app\n                                 (fst\n                                   (nth_split m2\n                                     (remove_nth (S m2) c (snd s0))))\n                                 (b :: (snd\n                                         (nth_split m2\n                                           (remove_nth (S m2) c (snd s0))))))\n                               a) (prems_Imp_R0 t s0)\n                         | _ -> prems_Imp_R0 t s0))\n                 in prems_Imp_R0 l2 (l, l0)) prem x\n            in\n            (match x0 with\n             | Coq_inl i ->\n               let x1 = fun f0 l4 y0 ->\n                 let (x1, _) = coq_InT_map_iff f0 l4 y0 in x1\n               in\n               let i0 =\n                 x1 (fun y0 -> (y0,\n                   (app\n                     (fst\n                       (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l0)))\n                     (m1 :: (snd\n                              (nth_split n0\n                                (remove_nth (S n0) (Imp (m0, m1)) l0)))))))\n                   (listInserts l m0) prem i\n               in\n               let Coq_existT (x2, p) = i0 in\n               let (_, i1) = p in\n               let x3 = fun f0 l4 y0 ->\n                 let (x3, _) = coq_InT_map_iff f0 l4 y0 in x3\n               in\n               let i2 =\n                 x3 (fun y0 -> app (fst y0) (m0 :: (snd y0)))\n                   (proj1_sigT2 (list_of_splits l)) x2 i1\n               in\n               let Coq_existT (x4, _) = i2 in\n               let (l4, l5) = x4 in\n               Coq_existT (n0, (Coq_existT (m0, (Coq_existT (m1, (Coq_existT\n               (l4, (Coq_existT (l5, (Coq_existT\n               ((fst (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l0))),\n               (Coq_existT\n               ((snd (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l0))),\n               __)))))))))))))\n             | Coq_inr i ->\n               let s0 = f l2 i in\n               let Coq_existT (x1, s1) = s0 in\n               let Coq_existT (x2, s2) = s1 in\n               let Coq_existT (x3, s3) = s2 in\n               let Coq_existT (x4, s4) = s3 in\n               let Coq_existT (x5, s5) = s4 in\n               let Coq_existT (x6, s6) = s5 in\n               let Coq_existT (x7, _) = s6 in\n               Coq_existT (x1, (Coq_existT (x2, (Coq_existT (x3, (Coq_existT\n               (x4, (Coq_existT (x5, (Coq_existT (x6, (Coq_existT (x7,\n               __)))))))))))))))\n       | _ ->\n         let s0 = f l2 x in\n         let Coq_existT (x0, s1) = s0 in\n         let Coq_existT (x1, s2) = s1 in\n         let Coq_existT (x2, s3) = s2 in\n         let Coq_existT (x3, s4) = s3 in\n         let Coq_existT (x4, s5) = s4 in\n         let Coq_existT (x5, s6) = s5 in\n         let Coq_existT (x6, _) = s6 in\n         Coq_existT (x0, (Coq_existT (x1, (Coq_existT (x2, (Coq_existT (x3,\n         (Coq_existT (x4, (Coq_existT (x5, (Coq_existT (x6, __))))))))))))))\n  in f l3\n\n(** val coq_ImpR_help1 :\n    coq_Seq -> (coq_MPropF list * coq_MPropF list) -> coq_Seq coq_InT ->\n    coq_ImpRRule **)\n\nlet coq_ImpR_help1 prem s x =\n  let s0 = coq_ImpR_help01 prem s (pos_top_imps (snd s)) x in\n  let Coq_existT (x0, s1) = s0 in\n  let (_, l) = s in\n  let Coq_existT (x1, s2) = s1 in\n  let Coq_existT (x2, s3) = s2 in\n  let Coq_existT (x3, s4) = s3 in\n  let Coq_existT (x4, _) = s4 in\n  let i = coq_In_pos_top_imps_split_l l (Imp (x1, x2)) x0 in\n  let Coq_existT (x5, s5) = i in\n  let Coq_existT (x6, _) = s5 in ImpRRule_I (x1, x2, x3, x4, x5, x6)\n\n(** val coq_ImpR_help002 :\n    coq_MPropF list -> coq_MPropF list -> coq_MPropF list -> coq_MPropF list\n    -> coq_MPropF -> coq_MPropF -> (coq_MPropF list * coq_MPropF list) coq_InT **)\n\nlet coq_ImpR_help002 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b =\n  let f = fun y -> (y, (app _UU0394_0 (b :: _UU0394_1))) in\n  let l = listInserts (app _UU0393_0 _UU0393_1) a in\n  let y = ((app _UU0393_0 (a :: _UU0393_1)), (app _UU0394_0 (b :: _UU0394_1)))\n  in\n  let (_, x) = coq_InT_map_iff f l y in\n  x (Coq_existT ((app _UU0393_0 (a :: _UU0393_1)), (__,\n    (let f0 = fun y0 -> app (fst y0) (a :: (snd y0)) in\n     let l0 = proj1_sigT2 (list_of_splits (app _UU0393_0 _UU0393_1)) in\n     let y0 = app _UU0393_0 (a :: _UU0393_1) in\n     let (_, x0) = coq_InT_map_iff f0 l0 y0 in\n     x0 (Coq_existT ((_UU0393_0, _UU0393_1), (__,\n       (let s = list_of_splits (app _UU0393_0 _UU0393_1) in\n        let Coq_existT (x1, _) = s in\n        coq_In_InT_seqs (_UU0393_0, _UU0393_1) x1))))))))\n\n(** val coq_ImpR_help02 :\n    coq_MPropF list -> coq_MPropF list -> coq_MPropF list -> coq_MPropF list\n    -> coq_MPropF -> coq_MPropF -> (coq_MPropF * nat) list -> nat ->\n    coq_ImpRRule -> (coq_MPropF list * coq_MPropF list) coq_InT **)\n\nlet rec coq_ImpR_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b l n x =\n  match l with\n  | [] -> assert false (* absurd case *)\n  | y :: l0 ->\n    let (m, n0) = y in\n    (match m with\n     | Imp (m0, m1) ->\n       let h1 =\n         coq_In_InT_pair (Imp (a, b)) (S n) (((Imp (m0, m1)), n0) :: l0)\n       in\n       (match h1 with\n        | InT_eq' (_, _) ->\n          (match _UU0394_0 with\n           | [] ->\n             let i = coq_ImpR_help002 _UU0393_0 _UU0393_1 [] _UU0394_1 a b in\n             let s = eq_dec_form (Imp (a, b)) (Imp (a, b)) in\n             if s\n             then coq_InT_or_app\n                    (listInsertsR_Seqs (app _UU0393_0 _UU0393_1)\n                      (b :: _UU0394_1) a)\n                    (prems_Imp_R l0 ((app _UU0393_0 _UU0393_1), ((Imp (a,\n                      b)) :: _UU0394_1))) ((app _UU0393_0 (a :: _UU0393_1)),\n                    (b :: _UU0394_1)) (Coq_inl i)\n             else assert false (* absurd case *)\n           | m2 :: l1 ->\n             coq_InT_or_app\n               (listInsertsR_Seqs\n                 (fst ((app _UU0393_0 _UU0393_1),\n                   (app (m2 :: l1) ((Imp (a, b)) :: _UU0394_1))))\n                 (app\n                   (fst\n                     (nth_split (length (m2 :: l1))\n                       (remove_nth (S (length (m2 :: l1))) (Imp (a, b))\n                         (snd ((app _UU0393_0 _UU0393_1),\n                           (app (m2 :: l1) ((Imp (a, b)) :: _UU0394_1)))))))\n                   (b :: (snd\n                           (nth_split (length (m2 :: l1))\n                             (remove_nth (S (length (m2 :: l1))) (Imp (a, b))\n                               (snd ((app _UU0393_0 _UU0393_1),\n                                 (app (m2 :: l1) ((Imp (a, b)) :: _UU0394_1)))))))))\n                 a)\n               (let rec prems_Imp_R0 l2 s =\n                  match l2 with\n                  | [] -> []\n                  | p :: t ->\n                    let (c, n1) = p in\n                    (match n1 with\n                     | O -> prems_Imp_R0 t s\n                     | S m3 ->\n                       (match c with\n                        | Imp (a0, b0) ->\n                          app\n                            (listInsertsR_Seqs (fst s)\n                              (app\n                                (fst\n                                  (nth_split m3 (remove_nth (S m3) c (snd s))))\n                                (b0 :: (snd\n                                         (nth_split m3\n                                           (remove_nth (S m3) c (snd s))))))\n                              a0) (prems_Imp_R0 t s)\n                        | _ -> prems_Imp_R0 t s))\n                in prems_Imp_R0 l0 ((app _UU0393_0 _UU0393_1),\n                     (app (m2 :: l1) ((Imp (a, b)) :: _UU0394_1))))\n               ((app _UU0393_0 (a :: _UU0393_1)),\n               (app (m2 :: l1) (b :: _UU0394_1))) (Coq_inl\n               (coq_ImpR_help002 _UU0393_0 _UU0393_1 (m2 :: l1) _UU0394_1 a b)))\n        | InT_cons (_, _, _) ->\n          let i =\n            coq_ImpR_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b l0\n              (length _UU0394_0) x\n          in\n          (match n0 with\n           | O -> i\n           | S n1 ->\n             coq_InT_or_app\n               (listInsertsR_Seqs (app _UU0393_0 _UU0393_1)\n                 (app\n                   (fst\n                     (nth_split n1\n                       (match n1 with\n                        | O ->\n                          (match app _UU0394_0 ((Imp (a, b)) :: _UU0394_1) with\n                           | [] -> []\n                           | b0 :: tl ->\n                             if eq_dec_form (Imp (m0, m1)) b0\n                             then tl\n                             else b0 :: tl)\n                        | S _ ->\n                          (match app _UU0394_0 ((Imp (a, b)) :: _UU0394_1) with\n                           | [] -> []\n                           | b0 :: tl ->\n                             b0 :: (remove_nth n1 (Imp (m0, m1)) tl)))))\n                   (m1 :: (snd\n                            (nth_split n1\n                              (match n1 with\n                               | O ->\n                                 (match app _UU0394_0 ((Imp (a,\n                                          b)) :: _UU0394_1) with\n                                  | [] -> []\n                                  | b0 :: tl ->\n                                    if eq_dec_form (Imp (m0, m1)) b0\n                                    then tl\n                                    else b0 :: tl)\n                               | S _ ->\n                                 (match app _UU0394_0 ((Imp (a,\n                                          b)) :: _UU0394_1) with\n                                  | [] -> []\n                                  | b0 :: tl ->\n                                    b0 :: (remove_nth n1 (Imp (m0, m1)) tl)))))))\n                 m0)\n               (prems_Imp_R l0 ((app _UU0393_0 _UU0393_1),\n                 (app _UU0394_0 ((Imp (a, b)) :: _UU0394_1))))\n               ((app _UU0393_0 (a :: _UU0393_1)),\n               (app _UU0394_0 (b :: _UU0394_1))) (Coq_inr i)))\n     | x0 ->\n       let h1 = coq_In_InT_pair (Imp (a, b)) (S n) ((x0, n0) :: l0) in\n       (match h1 with\n        | InT_eq' (_, _) -> assert false (* absurd case *)\n        | InT_cons (_, _, _) ->\n          coq_ImpR_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b l0\n            (length _UU0394_0) x))\n\n(** val coq_ImpR_help2 :\n    coq_Seq -> coq_Seq -> coq_ImpRRule -> coq_Seq coq_InT **)\n\nlet coq_ImpR_help2 _ _ x = match x with\n| ImpRRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1) ->\n  coq_ImpR_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b\n    (pos_top_imps (app _UU0394_0 ((Imp (a, b)) :: _UU0394_1)))\n    (length _UU0394_0) x\n\n(** val finite_ImpR_premises_of_S :\n    coq_Seq -> (coq_Seq list list, coq_Seq list -> (coq_ImpRRule -> coq_Seq\n    list coq_InT) * (coq_Seq list coq_InT -> coq_ImpRRule)) sigT **)\n\nlet finite_ImpR_premises_of_S = function\n| (l, l0) ->\n  Coq_existT\n    ((map (fun y -> y :: []) (prems_Imp_R (pos_top_imps l0) (l, l0))),\n    (fun prems -> ((fun h ->\n    let ImpRRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1) = h in\n    let f = fun y -> y :: [] in\n    let l1 =\n      prems_Imp_R (pos_top_imps (app _UU0394_0 ((Imp (a, b)) :: _UU0394_1)))\n        ((app _UU0393_0 _UU0393_1),\n        (app _UU0394_0 ((Imp (a, b)) :: _UU0394_1)))\n    in\n    let y = ((app _UU0393_0 (a :: _UU0393_1)),\n      (app _UU0394_0 (b :: _UU0394_1))) :: []\n    in\n    let (_, x) = coq_InT_map_iff f l1 y in\n    x (Coq_existT (((app _UU0393_0 (a :: _UU0393_1)),\n      (app _UU0394_0 (b :: _UU0394_1))), (__,\n      (coq_ImpR_help2 ((app _UU0393_0 (a :: _UU0393_1)),\n        (app _UU0394_0 (b :: _UU0394_1))) ((app _UU0393_0 _UU0393_1),\n        (app _UU0394_0 ((Imp (a, b)) :: _UU0394_1))) h))))), (fun h ->\n    let x = fun f l1 y -> let (x, _) = coq_InT_map_iff f l1 y in x in\n    let h0 =\n      x (fun y -> y :: []) (prems_Imp_R (pos_top_imps l0) (l, l0)) prems h\n    in\n    let Coq_existT (x0, p) = h0 in\n    let (_, i) = p in coq_ImpR_help1 x0 (l, l0) i))))\n\n(** val prems_Imp_L :\n    (coq_MPropF * nat) list -> coq_Seq -> coq_Seq list list **)\n\nlet rec prems_Imp_L l s =\n  match l with\n  | [] -> []\n  | p :: t ->\n    let (c, n) = p in\n    (match n with\n     | O -> prems_Imp_L t s\n     | S m ->\n       (match c with\n        | Imp (a, b) ->\n          app\n            (flatten_list\n              (map (fun y ->\n                map (fun z -> z :: (y :: []))\n                  (listInsertsL_Seqs\n                    (app (fst (nth_split m (remove_nth (S m) c (fst s))))\n                      (snd (nth_split m (remove_nth (S m) c (fst s)))))\n                    (snd s) a))\n                (((app (fst (nth_split m (remove_nth (S m) c (fst s))))\n                    (b :: (snd (nth_split m (remove_nth (S m) c (fst s)))))),\n                (snd s)) :: []))) (prems_Imp_L t s)\n        | _ -> prems_Imp_L t s))\n\n(** val coq_ImpL_help002 :\n    coq_MPropF list -> coq_MPropF list -> coq_MPropF list -> coq_MPropF list\n    -> coq_MPropF -> coq_MPropF -> (coq_MPropF list * coq_MPropF list) list\n    coq_InT **)\n\nlet coq_ImpL_help002 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b =\n  coq_InT_trans_flatten_list\n    (map (fun y ->\n      map (fun z -> y :: (z :: [])) (((app _UU0393_0 (b :: _UU0393_1)),\n        (app _UU0394_0 _UU0394_1)) :: []))\n      (listInsertsL_Seqs (app _UU0393_0 _UU0393_1) (app _UU0394_0 _UU0394_1)\n        a))\n    (map (fun z -> ((app _UU0393_0 _UU0393_1),\n      (app _UU0394_0 (a :: _UU0394_1))) :: (z :: []))\n      (((app _UU0393_0 (b :: _UU0393_1)), (app _UU0394_0 _UU0394_1)) :: []))\n    (((app _UU0393_0 _UU0393_1),\n    (app _UU0394_0 (a :: _UU0394_1))) :: (((app _UU0393_0 (b :: _UU0393_1)),\n    (app _UU0394_0 _UU0394_1)) :: []))\n    (let p =\n       coq_InT_map_iff (fun z -> ((app _UU0393_0 _UU0393_1),\n         (app _UU0394_0 (a :: _UU0394_1))) :: (z :: []))\n         (((app _UU0393_0 (b :: _UU0393_1)),\n         (app _UU0394_0 _UU0394_1)) :: []) (((app _UU0393_0 _UU0393_1),\n         (app _UU0394_0 (a :: _UU0394_1))) :: (((app _UU0393_0\n                                                  (b :: _UU0393_1)),\n         (app _UU0394_0 _UU0394_1)) :: []))\n     in\n     let (_, i) = p in\n     i (Coq_existT (((app _UU0393_0 (b :: _UU0393_1)),\n       (app _UU0394_0 _UU0394_1)), (__,\n       (coq_InT_eq ((app _UU0393_0 (b :: _UU0393_1)),\n         (app _UU0394_0 _UU0394_1)) [])))))\n    (let p =\n       coq_InT_map_iff (fun y ->\n         map (fun z -> y :: (z :: [])) (((app _UU0393_0 (b :: _UU0393_1)),\n           (app _UU0394_0 _UU0394_1)) :: []))\n         (listInsertsL_Seqs (app _UU0393_0 _UU0393_1)\n           (app _UU0394_0 _UU0394_1) a)\n         (map (fun z -> ((app _UU0393_0 _UU0393_1),\n           (app _UU0394_0 (a :: _UU0394_1))) :: (z :: []))\n           (((app _UU0393_0 (b :: _UU0393_1)),\n           (app _UU0394_0 _UU0394_1)) :: []))\n     in\n     let (_, i) = p in\n     i (Coq_existT (((app _UU0393_0 _UU0393_1),\n       (app _UU0394_0 (a :: _UU0394_1))), (__,\n       (let p0 =\n          coq_InT_map_iff (fun y -> ((app _UU0393_0 _UU0393_1), y))\n            (listInserts (app _UU0394_0 _UU0394_1) a)\n            ((app _UU0393_0 _UU0393_1), (app _UU0394_0 (a :: _UU0394_1)))\n        in\n        let (_, i0) = p0 in\n        i0 (Coq_existT ((app _UU0394_0 (a :: _UU0394_1)), (__,\n          (let p1 =\n             coq_InT_map_iff (fun y -> app (fst y) (a :: (snd y)))\n               (proj1_sigT2 (list_of_splits (app _UU0394_0 _UU0394_1)))\n               (app _UU0394_0 (a :: _UU0394_1))\n           in\n           let (_, i1) = p1 in\n           i1 (Coq_existT ((_UU0394_0, _UU0394_1), (__,\n             (let s = list_of_splits (app _UU0394_0 _UU0394_1) in\n              let Coq_existT (x, _) = s in\n              coq_In_InT_seqs (_UU0394_0, _UU0394_1) x)))))))))))))\n\n(** val coq_ImpL_help02 :\n    coq_MPropF list -> coq_MPropF list -> coq_MPropF list -> coq_MPropF list\n    -> coq_MPropF -> coq_MPropF -> (coq_MPropF * nat) list -> nat ->\n    coq_ImpLRule -> (coq_MPropF list * coq_MPropF list) list coq_InT **)\n\nlet rec coq_ImpL_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b l n x =\n  match l with\n  | [] -> assert false (* absurd case *)\n  | y :: l0 ->\n    let (m, n0) = y in\n    (match m with\n     | Imp (m0, m1) ->\n       let h1 =\n         coq_In_InT_pair (Imp (a, b)) (S n) (((Imp (m0, m1)), n0) :: l0)\n       in\n       (match h1 with\n        | InT_eq' (_, _) ->\n          let i = coq_ImpL_help002 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b\n          in\n          coq_InT_or_app\n            (flatten_list\n              (map (fun y0 ->\n                map (fun z -> z :: (y0 :: []))\n                  (listInsertsL_Seqs\n                    (app\n                      (fst\n                        (nth_split (length _UU0393_0)\n                          (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                            (fst\n                              ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                              (app _UU0394_0 _UU0394_1))))))\n                      (snd\n                        (nth_split (length _UU0393_0)\n                          (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                            (fst\n                              ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                              (app _UU0394_0 _UU0394_1)))))))\n                    (snd ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                      (app _UU0394_0 _UU0394_1))) a))\n                (((app\n                    (fst\n                      (nth_split (length _UU0393_0)\n                        (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                          (fst ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                            (app _UU0394_0 _UU0394_1))))))\n                    (b :: (snd\n                            (nth_split (length _UU0393_0)\n                              (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                                (fst\n                                  ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                                  (app _UU0394_0 _UU0394_1)))))))),\n                (snd ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                  (app _UU0394_0 _UU0394_1)))) :: [])))\n            (let rec prems_Imp_L0 l1 s =\n               match l1 with\n               | [] -> []\n               | p :: t ->\n                 let (c, n1) = p in\n                 (match n1 with\n                  | O -> prems_Imp_L0 t s\n                  | S m2 ->\n                    (match c with\n                     | Imp (a0, b0) ->\n                       app\n                         (flatten_list\n                           (map (fun y0 ->\n                             map (fun z -> z :: (y0 :: []))\n                               (listInsertsL_Seqs\n                                 (app\n                                   (fst\n                                     (nth_split m2\n                                       (remove_nth (S m2) c (fst s))))\n                                   (snd\n                                     (nth_split m2\n                                       (remove_nth (S m2) c (fst s)))))\n                                 (snd s) a0))\n                             (((app\n                                 (fst\n                                   (nth_split m2\n                                     (remove_nth (S m2) c (fst s))))\n                                 (b0 :: (snd\n                                          (nth_split m2\n                                            (remove_nth (S m2) c (fst s)))))),\n                             (snd s)) :: []))) (prems_Imp_L0 t s)\n                     | _ -> prems_Imp_L0 t s))\n             in prems_Imp_L0 l0 ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                  (app _UU0394_0 _UU0394_1))) (((app _UU0393_0 _UU0393_1),\n            (app _UU0394_0 (a :: _UU0394_1))) :: (((app _UU0393_0\n                                                     (b :: _UU0393_1)),\n            (app _UU0394_0 _UU0394_1)) :: [])) (Coq_inl\n            (coq_InT_trans_flatten_list\n              (map (fun y0 ->\n                map (fun z -> z :: (y0 :: []))\n                  (listInsertsL_Seqs\n                    (app\n                      (fst\n                        (nth_split (length _UU0393_0)\n                          (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                            (fst\n                              ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                              (app _UU0394_0 _UU0394_1))))))\n                      (snd\n                        (nth_split (length _UU0393_0)\n                          (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                            (fst\n                              ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                              (app _UU0394_0 _UU0394_1)))))))\n                    (snd ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                      (app _UU0394_0 _UU0394_1))) a))\n                (((app\n                    (fst\n                      (nth_split (length _UU0393_0)\n                        (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                          (fst ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                            (app _UU0394_0 _UU0394_1))))))\n                    (b :: (snd\n                            (nth_split (length _UU0393_0)\n                              (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                                (fst\n                                  ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                                  (app _UU0394_0 _UU0394_1)))))))),\n                (snd ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                  (app _UU0394_0 _UU0394_1)))) :: []))\n              (flatten_list\n                (map (fun y0 -> (y0 :: (((app _UU0393_0 (b :: _UU0393_1)),\n                  (app _UU0394_0 _UU0394_1)) :: [])) :: [])\n                  (listInsertsL_Seqs (app _UU0393_0 _UU0393_1)\n                    (app _UU0394_0 _UU0394_1) a)))\n              (((app _UU0393_0 _UU0393_1),\n              (app _UU0394_0 (a :: _UU0394_1))) :: (((app _UU0393_0\n                                                       (b :: _UU0393_1)),\n              (app _UU0394_0 _UU0394_1)) :: [])) i\n              (let f = fun y0 ->\n                 map (fun z -> z :: (y0 :: []))\n                   (listInsertsL_Seqs\n                     (app\n                       (fst\n                         (nth_split (length _UU0393_0)\n                           (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                             (fst\n                               ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                               (app _UU0394_0 _UU0394_1))))))\n                       (snd\n                         (nth_split (length _UU0393_0)\n                           (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                             (fst\n                               ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                               (app _UU0394_0 _UU0394_1)))))))\n                     (snd ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                       (app _UU0394_0 _UU0394_1))) a)\n               in\n               let l1 =\n                 ((app\n                    (fst\n                      (nth_split (length _UU0393_0)\n                        (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                          (fst ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                            (app _UU0394_0 _UU0394_1))))))\n                    (b :: (snd\n                            (nth_split (length _UU0393_0)\n                              (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                                (fst\n                                  ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                                  (app _UU0394_0 _UU0394_1)))))))),\n                 (snd ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                   (app _UU0394_0 _UU0394_1)))) :: []\n               in\n               let y0 =\n                 flatten_list\n                   (map (fun y0 -> (y0 :: (((app _UU0393_0 (b :: _UU0393_1)),\n                     (app _UU0394_0 _UU0394_1)) :: [])) :: [])\n                     (listInsertsL_Seqs (app _UU0393_0 _UU0393_1)\n                       (app _UU0394_0 _UU0394_1) a))\n               in\n               let (_, x0) = coq_InT_map_iff f l1 y0 in\n               x0 (Coq_existT (((app _UU0393_0 (b :: _UU0393_1)),\n                 (app _UU0394_0 _UU0394_1)), (__,\n                 (let s = eq_dec_form (Imp (a, b)) (Imp (a, b)) in\n                  if s\n                  then coq_InT_eq ((app _UU0393_0 (b :: _UU0393_1)),\n                         (app _UU0394_0 _UU0394_1)) []\n                  else assert false (* absurd case *))))))))\n        | InT_cons (_, _, _) ->\n          let i =\n            coq_ImpL_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b l0\n              (length _UU0393_0) x\n          in\n          (match n0 with\n           | O -> i\n           | S n1 ->\n             coq_InT_or_app\n               (app\n                 (map (fun z ->\n                   z :: (((app\n                            (fst\n                              (nth_split n1\n                                (match n1 with\n                                 | O ->\n                                   (match app _UU0393_0 ((Imp (a,\n                                            b)) :: _UU0393_1) with\n                                    | [] -> []\n                                    | b0 :: tl ->\n                                      if eq_dec_form (Imp (m0, m1)) b0\n                                      then tl\n                                      else b0 :: tl)\n                                 | S _ ->\n                                   (match app _UU0393_0 ((Imp (a,\n                                            b)) :: _UU0393_1) with\n                                    | [] -> []\n                                    | b0 :: tl ->\n                                      b0 :: (remove_nth n1 (Imp (m0, m1)) tl)))))\n                            (m1 :: (snd\n                                     (nth_split n1\n                                       (match n1 with\n                                        | O ->\n                                          (match app _UU0393_0 ((Imp (a,\n                                                   b)) :: _UU0393_1) with\n                                           | [] -> []\n                                           | b0 :: tl ->\n                                             if eq_dec_form (Imp (m0, m1)) b0\n                                             then tl\n                                             else b0 :: tl)\n                                        | S _ ->\n                                          (match app _UU0393_0 ((Imp (a,\n                                                   b)) :: _UU0393_1) with\n                                           | [] -> []\n                                           | b0 :: tl ->\n                                             b0 :: (remove_nth n1 (Imp (m0,\n                                                     m1)) tl))))))),\n                   (app _UU0394_0 _UU0394_1)) :: []))\n                   (listInsertsL_Seqs\n                     (app\n                       (fst\n                         (nth_split n1\n                           (match n1 with\n                            | O ->\n                              (match app _UU0393_0 ((Imp (a, b)) :: _UU0393_1) with\n                               | [] -> []\n                               | b0 :: tl ->\n                                 if eq_dec_form (Imp (m0, m1)) b0\n                                 then tl\n                                 else b0 :: tl)\n                            | S _ ->\n                              (match app _UU0393_0 ((Imp (a, b)) :: _UU0393_1) with\n                               | [] -> []\n                               | b0 :: tl ->\n                                 b0 :: (remove_nth n1 (Imp (m0, m1)) tl)))))\n                       (snd\n                         (nth_split n1\n                           (match n1 with\n                            | O ->\n                              (match app _UU0393_0 ((Imp (a, b)) :: _UU0393_1) with\n                               | [] -> []\n                               | b0 :: tl ->\n                                 if eq_dec_form (Imp (m0, m1)) b0\n                                 then tl\n                                 else b0 :: tl)\n                            | S _ ->\n                              (match app _UU0393_0 ((Imp (a, b)) :: _UU0393_1) with\n                               | [] -> []\n                               | b0 :: tl ->\n                                 b0 :: (remove_nth n1 (Imp (m0, m1)) tl))))))\n                     (app _UU0394_0 _UU0394_1) m0)) [])\n               (prems_Imp_L l0 ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                 (app _UU0394_0 _UU0394_1))) (((app _UU0393_0 _UU0393_1),\n               (app _UU0394_0 (a :: _UU0394_1))) :: (((app _UU0393_0\n                                                        (b :: _UU0393_1)),\n               (app _UU0394_0 _UU0394_1)) :: [])) (Coq_inr i)))\n     | x0 ->\n       let h1 =\n         coq_In_InT_pair (Imp (a, b)) (S (length _UU0393_0)) ((x0, n0) :: l0)\n       in\n       (match h1 with\n        | InT_eq' (_, _) -> assert false (* absurd case *)\n        | InT_cons (_, _, _) ->\n          coq_ImpL_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b l0\n            (length _UU0393_0) x))\n\n(** val coq_ImpL_help2 :\n    coq_Seq -> coq_Seq -> coq_Seq -> coq_ImpLRule -> coq_Seq list coq_InT **)\n\nlet coq_ImpL_help2 _ _ _ x = match x with\n| ImpLRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1) ->\n  coq_ImpL_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b\n    (pos_top_imps (app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)))\n    (length _UU0393_0) x\n\n(** val coq_ImpL_help01 :\n    coq_Seq list -> coq_Seq -> (coq_MPropF * nat) list -> coq_Seq list\n    coq_InT -> (nat, (coq_Seq, (coq_Seq, (coq_MPropF, (coq_MPropF,\n    (coq_MPropF list, (coq_MPropF list, (coq_MPropF list, (coq_MPropF list,\n    __) sigT) sigT) sigT) sigT) sigT) sigT) sigT) sigT) sigT **)\n\nlet coq_ImpL_help01 prems s l1 =\n  let (l, l0) = s in\n  let rec f l2 x =\n    match l2 with\n    | [] -> assert false (* absurd case *)\n    | y :: l3 ->\n      let (m, n) = y in\n      (match m with\n       | Imp (m0, m1) ->\n         (match n with\n          | O ->\n            let s0 = f l3 x in\n            let Coq_existT (x0, s1) = s0 in\n            let Coq_existT (x1, s2) = s1 in\n            let Coq_existT (x2, s3) = s2 in\n            let Coq_existT (x3, s4) = s3 in\n            let Coq_existT (x4, s5) = s4 in\n            let Coq_existT (x5, s6) = s5 in\n            let Coq_existT (x6, s7) = s6 in\n            let Coq_existT (x7, s8) = s7 in\n            let Coq_existT (x8, _) = s8 in\n            Coq_existT (x0, (Coq_existT (x1, (Coq_existT (x2, (Coq_existT\n            (x3, (Coq_existT (x4, (Coq_existT (x5, (Coq_existT (x6,\n            (Coq_existT (x7, (Coq_existT (x8, __)))))))))))))))))\n          | S n0 ->\n            let x0 =\n              coq_InT_app_or\n                (flatten_list\n                  (map (fun y0 ->\n                    map (fun z -> z :: (y0 :: []))\n                      (listInsertsL_Seqs\n                        (app\n                          (fst\n                            (nth_split n0\n                              (remove_nth (S n0) (Imp (m0, m1)) (fst (l, l0)))))\n                          (snd\n                            (nth_split n0\n                              (remove_nth (S n0) (Imp (m0, m1)) (fst (l, l0))))))\n                        (snd (l, l0)) m0))\n                    (((app\n                        (fst\n                          (nth_split n0\n                            (remove_nth (S n0) (Imp (m0, m1)) (fst (l, l0)))))\n                        (m1 :: (snd\n                                 (nth_split n0\n                                   (remove_nth (S n0) (Imp (m0, m1))\n                                     (fst (l, l0))))))),\n                    (snd (l, l0))) :: [])))\n                (let rec prems_Imp_L0 l4 s0 =\n                   match l4 with\n                   | [] -> []\n                   | p :: t ->\n                     let (c, n1) = p in\n                     (match n1 with\n                      | O -> prems_Imp_L0 t s0\n                      | S m2 ->\n                        (match c with\n                         | Imp (a, b) ->\n                           app\n                             (flatten_list\n                               (map (fun y0 ->\n                                 map (fun z -> z :: (y0 :: []))\n                                   (listInsertsL_Seqs\n                                     (app\n                                       (fst\n                                         (nth_split m2\n                                           (remove_nth (S m2) c (fst s0))))\n                                       (snd\n                                         (nth_split m2\n                                           (remove_nth (S m2) c (fst s0)))))\n                                     (snd s0) a))\n                                 (((app\n                                     (fst\n                                       (nth_split m2\n                                         (remove_nth (S m2) c (fst s0))))\n                                     (b :: (snd\n                                             (nth_split m2\n                                               (remove_nth (S m2) c (fst s0)))))),\n                                 (snd s0)) :: []))) (prems_Imp_L0 t s0)\n                         | _ -> prems_Imp_L0 t s0))\n                 in prems_Imp_L0 l3 (l, l0)) prems x\n            in\n            (match x0 with\n             | Coq_inl i ->\n               let i0 =\n                 coq_InT_flatten_list_InT_elem\n                   (map (fun y0 ->\n                     map (fun z -> z :: (y0 :: []))\n                       (listInsertsL_Seqs\n                         (app\n                           (fst\n                             (nth_split n0\n                               (remove_nth (S n0) (Imp (m0, m1)) l)))\n                           (snd\n                             (nth_split n0\n                               (remove_nth (S n0) (Imp (m0, m1)) l)))) l0 m0))\n                     (((app\n                         (fst\n                           (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l)))\n                         (m1 :: (snd\n                                  (nth_split n0\n                                    (remove_nth (S n0) (Imp (m0, m1)) l))))),\n                     l0) :: [])) prems i\n               in\n               let Coq_existT (x1, p) = i0 in\n               let (i1, i2) = p in\n               let x2 = fun f0 l4 y0 ->\n                 let (x2, _) = coq_InT_map_iff f0 l4 y0 in x2\n               in\n               let i3 =\n                 x2 (fun y0 ->\n                   map (fun z -> z :: (y0 :: []))\n                     (listInsertsL_Seqs\n                       (app\n                         (fst\n                           (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l)))\n                         (snd\n                           (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l))))\n                       l0 m0))\n                   (((app\n                       (fst\n                         (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l)))\n                       (m1 :: (snd\n                                (nth_split n0\n                                  (remove_nth (S n0) (Imp (m0, m1)) l))))),\n                   l0) :: []) x1 i2\n               in\n               let Coq_existT (_, p0) = i3 in\n               let (_, i4) = p0 in\n               (match i4 with\n                | InT_eq' (_, _) ->\n                  let x3 = fun f0 l4 y0 ->\n                    let (x3, _) = coq_InT_map_iff f0 l4 y0 in x3\n                  in\n                  let i5 =\n                    x3 (fun z ->\n                      z :: (((app\n                               (fst\n                                 (nth_split n0\n                                   (match n0 with\n                                    | O ->\n                                      (match l with\n                                       | [] -> []\n                                       | b :: tl ->\n                                         if eq_dec_form (Imp (m0, m1)) b\n                                         then tl\n                                         else b :: tl)\n                                    | S _ ->\n                                      (match l with\n                                       | [] -> []\n                                       | b :: tl ->\n                                         b :: (remove_nth n0 (Imp (m0, m1))\n                                                tl)))))\n                               (m1 :: (snd\n                                        (nth_split n0\n                                          (match n0 with\n                                           | O ->\n                                             (match l with\n                                              | [] -> []\n                                              | b :: tl ->\n                                                if eq_dec_form (Imp (m0, m1))\n                                                     b\n                                                then tl\n                                                else b :: tl)\n                                           | S _ ->\n                                             (match l with\n                                              | [] -> []\n                                              | b :: tl ->\n                                                b :: (remove_nth n0 (Imp (m0,\n                                                       m1)) tl))))))),\n                      l0) :: []))\n                      (listInsertsL_Seqs\n                        (app\n                          (fst\n                            (nth_split n0\n                              (remove_nth (S n0) (Imp (m0, m1)) l)))\n                          (snd\n                            (nth_split n0\n                              (remove_nth (S n0) (Imp (m0, m1)) l)))) l0 m0)\n                      prems i1\n                  in\n                  let Coq_existT (x4, p1) = i5 in\n                  let (_, i6) = p1 in\n                  let x5 = fun f0 l4 y0 ->\n                    let (x5, _) = coq_InT_map_iff f0 l4 y0 in x5\n                  in\n                  let i7 =\n                    x5 (fun y0 ->\n                      ((app\n                         (fst\n                           (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l)))\n                         (snd\n                           (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l)))),\n                      y0)) (listInserts l0 m0) x4 i6\n                  in\n                  let Coq_existT (x6, p2) = i7 in\n                  let (_, i8) = p2 in\n                  let x7 = fun f0 l4 y0 ->\n                    let (x7, _) = coq_InT_map_iff f0 l4 y0 in x7\n                  in\n                  let i9 =\n                    x7 (fun y0 -> app (fst y0) (m0 :: (snd y0)))\n                      (proj1_sigT2 (list_of_splits l0)) x6 i8\n                  in\n                  let Coq_existT (x8, _) = i9 in\n                  let (l4, l5) = x8 in\n                  Coq_existT (n0, (Coq_existT\n                  (((app\n                      (fst\n                        (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l)))\n                      (snd\n                        (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l)))),\n                  (app l4 (m0 :: l5))), (Coq_existT\n                  (((app\n                      (fst\n                        (nth_split n0\n                          (match n0 with\n                           | O ->\n                             (match l with\n                              | [] -> []\n                              | b0 :: tl ->\n                                if eq_dec_form (Imp (m0, m1)) b0\n                                then tl\n                                else b0 :: tl)\n                           | S _ ->\n                             (match l with\n                              | [] -> []\n                              | b0 :: tl ->\n                                b0 :: (remove_nth n0 (Imp (m0, m1)) tl)))))\n                      (m1 :: (snd\n                               (nth_split n0\n                                 (match n0 with\n                                  | O ->\n                                    (match l with\n                                     | [] -> []\n                                     | b0 :: tl ->\n                                       if eq_dec_form (Imp (m0, m1)) b0\n                                       then tl\n                                       else b0 :: tl)\n                                  | S _ ->\n                                    (match l with\n                                     | [] -> []\n                                     | b0 :: tl ->\n                                       b0 :: (remove_nth n0 (Imp (m0, m1)) tl))))))),\n                  l0), (Coq_existT (m0, (Coq_existT (m1, (Coq_existT\n                  ((fst (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l))),\n                  (Coq_existT\n                  ((snd (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l))),\n                  (Coq_existT (l4, (Coq_existT (l5, __)))))))))))))))))\n                | InT_cons (_, _, _) -> assert false (* absurd case *))\n             | Coq_inr i ->\n               let s0 = f l3 i in\n               let Coq_existT (x1, s1) = s0 in\n               let Coq_existT (x2, s2) = s1 in\n               let Coq_existT (x3, s3) = s2 in\n               let Coq_existT (x4, s4) = s3 in\n               let Coq_existT (x5, s5) = s4 in\n               let Coq_existT (x6, s6) = s5 in\n               let Coq_existT (x7, s7) = s6 in\n               let Coq_existT (x8, s8) = s7 in\n               let Coq_existT (x9, _) = s8 in\n               Coq_existT (x1, (Coq_existT (x2, (Coq_existT (x3, (Coq_existT\n               (x4, (Coq_existT (x5, (Coq_existT (x6, (Coq_existT (x7,\n               (Coq_existT (x8, (Coq_existT (x9, __)))))))))))))))))))\n       | _ ->\n         let s0 = f l3 x in\n         let Coq_existT (x0, s1) = s0 in\n         let Coq_existT (x1, s2) = s1 in\n         let Coq_existT (x2, s3) = s2 in\n         let Coq_existT (x3, s4) = s3 in\n         let Coq_existT (x4, s5) = s4 in\n         let Coq_existT (x5, s6) = s5 in\n         let Coq_existT (x6, s7) = s6 in\n         let Coq_existT (x7, s8) = s7 in\n         let Coq_existT (x8, _) = s8 in\n         Coq_existT (x0, (Coq_existT (x1, (Coq_existT (x2, (Coq_existT (x3,\n         (Coq_existT (x4, (Coq_existT (x5, (Coq_existT (x6, (Coq_existT (x7,\n         (Coq_existT (x8, __))))))))))))))))))\n  in f l1\n\n(** val coq_ImpL_help1 :\n    coq_Seq list -> (coq_MPropF list * coq_MPropF list) -> coq_Seq list\n    coq_InT -> coq_ImpLRule **)\n\nlet coq_ImpL_help1 prem s x =\n  let s0 = coq_ImpL_help01 prem s (pos_top_imps (fst s)) x in\n  let Coq_existT (x0, s1) = s0 in\n  let Coq_existT (_, s2) = s1 in\n  let Coq_existT (_, s3) = s2 in\n  let Coq_existT (x1, s4) = s3 in\n  let Coq_existT (x2, s5) = s4 in\n  let Coq_existT (_, s6) = s5 in\n  let Coq_existT (_, s7) = s6 in\n  let Coq_existT (x3, s8) = s7 in\n  let Coq_existT (x4, _) = s8 in\n  let (l, l0) = s in\n  let i = coq_In_pos_top_imps_split_l (fst (l, l0)) (Imp (x1, x2)) x0 in\n  let Coq_existT (x5, _) = i in\n  let _UU0393_0' =\n    fst (nth_split (length x5) (remove_nth (S (length x5)) (Imp (x1, x2)) l))\n  in\n  let _UU0393_1' =\n    snd (nth_split (length x5) (remove_nth (S (length x5)) (Imp (x1, x2)) l))\n  in\n  ImpLRule_I (x1, x2, _UU0393_0', _UU0393_1', x3, x4)\n\n(** val finite_ImpL_premises_of_S :\n    coq_Seq -> (coq_Seq list list, coq_Seq list -> (coq_ImpLRule -> coq_Seq\n    list coq_InT) * (coq_Seq list coq_InT -> coq_ImpLRule)) sigT **)\n\nlet finite_ImpL_premises_of_S = function\n| (l, l0) ->\n  Coq_existT ((prems_Imp_L (pos_top_imps l) (l, l0)), (fun prems ->\n    ((fun h ->\n    let ImpLRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1) = h in\n    coq_ImpL_help2 ((app _UU0393_0 _UU0393_1),\n      (app _UU0394_0 (a :: _UU0394_1))) ((app _UU0393_0 (b :: _UU0393_1)),\n      (app _UU0394_0 _UU0394_1))\n      ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n      (app _UU0394_0 _UU0394_1)) h), (fun h ->\n    coq_ImpL_help1 prems (l, l0) h))))\n\n(** val prems_Box_R : coq_MPropF list -> coq_Seq -> coq_Seq list list **)\n\nlet rec prems_Box_R l s =\n  match l with\n  | [] -> []\n  | h :: t ->\n    (match h with\n     | Box a ->\n       (((app (coq_XBoxed_list (top_boxes (fst s))) ((Box a) :: [])),\n         (a :: [])) :: []) :: (prems_Box_R t s)\n     | _ -> prems_Box_R t s)\n\n(** val coq_GLR_help01 :\n    coq_Seq list -> coq_Seq -> coq_MPropF list -> coq_Seq list coq_InT ->\n    (coq_MPropF, __) sigT **)\n\nlet rec coq_GLR_help01 prems s l1 x =\n  match l1 with\n  | [] -> assert false (* absurd case *)\n  | y :: l ->\n    (match y with\n     | Box m ->\n       (match x with\n        | InT_eq' (_, _) -> Coq_existT (m, __)\n        | InT_cons (_, _, x0) ->\n          let h0 = coq_GLR_help01 prems s l x0 in\n          let Coq_existT (x1, _) = h0 in Coq_existT (x1, __))\n     | _ ->\n       let x0 = coq_GLR_help01 prems s l x in\n       let Coq_existT (x1, _) = x0 in Coq_existT (x1, __))\n\n(** val coq_GLR_help1 :\n    coq_Seq list -> (coq_MPropF list * coq_MPropF list) -> coq_Seq list\n    coq_InT -> coq_GLRRule **)\n\nlet coq_GLR_help1 prems s x =\n  let s0 = coq_GLR_help01 prems s (top_boxes (snd s)) x in\n  let Coq_existT (x0, _) = s0 in\n  let (l, l0) = s in\n  let h = in_splitT (Box x0) l0 in\n  let Coq_existT (x1, s1) = h in\n  let Coq_existT (x2, _) = s1 in\n  GLRRule_I (x0, (top_boxes (fst (l, (app x1 ((Box x0) :: x2))))), l, x1, x2,\n  (top_boxes_nobox_gen_ext l))\n\n(** val coq_GLR_help02 :\n    coq_MPropF list -> coq_MPropF list -> coq_MPropF list -> coq_MPropF list\n    -> coq_MPropF -> coq_MPropF list -> coq_GLRRule -> nobox_gen_ext ->\n    (coq_MPropF list * coq_MPropF list) list coq_InT **)\n\nlet rec coq_GLR_help02 _UU0393_ _UU0394_0 _UU0394_1 b_UU0393_ a l x x0 =\n  match l with\n  | [] -> assert false (* absurd case *)\n  | y :: l0 ->\n    (match y with\n     | Box m ->\n       let h1 =\n         let h0 = in_splitT (Box a) ((Box m) :: l0) in\n         let Coq_existT (x1, s) = h0 in\n         let Coq_existT (x2, _) = s in\n         coq_InT_or_app x1 ((Box a) :: x2) (Box a) (Coq_inr\n           (coq_InT_eq (Box a) x2))\n       in\n       (match h1 with\n        | InT_eq' (_, _) ->\n          coq_InT_eq\n            (((app (coq_XBoxed_list (top_boxes _UU0393_)) ((Box a) :: [])),\n            (a :: [])) :: [])\n            (prems_Box_R l0 (_UU0393_,\n              (app _UU0394_0 ((Box a) :: _UU0394_1))))\n        | InT_cons (_, _, _) ->\n          let i =\n            coq_GLR_help02 _UU0393_ _UU0394_0 _UU0394_1 b_UU0393_ a l0 x x0\n          in\n          InT_cons\n          ((((app (coq_XBoxed_list (top_boxes _UU0393_)) ((Box m) :: [])),\n          (m :: [])) :: []),\n          (prems_Box_R l0 (_UU0393_, (app _UU0394_0 ((Box a) :: _UU0394_1)))),\n          i))\n     | x1 ->\n       let h1 =\n         let h0 = in_splitT (Box a) (x1 :: l0) in\n         let Coq_existT (x2, s) = h0 in\n         let Coq_existT (x3, _) = s in\n         coq_InT_or_app x2 ((Box a) :: x3) (Box a) (Coq_inr\n           (coq_InT_eq (Box a) x3))\n       in\n       (match h1 with\n        | InT_eq' (_, _) -> assert false (* absurd case *)\n        | InT_cons (_, _, _) ->\n          coq_GLR_help02 _UU0393_ _UU0394_0 _UU0394_1 b_UU0393_ a l0 x x0))\n\n(** val coq_GLR_help2 :\n    coq_Seq -> coq_Seq -> coq_GLRRule -> coq_Seq list coq_InT **)\n\nlet coq_GLR_help2 _ _ x = match x with\n| GLRRule_I (a, b_UU0393_, _UU0393_0, _UU0394_0, _UU0394_1, x0) ->\n  coq_GLR_help02 _UU0393_0 _UU0394_0 _UU0394_1 b_UU0393_ a\n    (top_boxes (app _UU0394_0 ((Box a) :: _UU0394_1))) x x0\n\n(** val finite_GLR_premises_of_S :\n    coq_Seq -> (coq_Seq list list, coq_Seq list -> (coq_GLRRule -> coq_Seq\n    list coq_InT) * (coq_Seq list coq_InT -> coq_GLRRule)) sigT **)\n\nlet finite_GLR_premises_of_S = function\n| (l, l0) ->\n  Coq_existT ((prems_Box_R (top_boxes l0) (l, l0)), (fun prems -> ((fun x ->\n    let GLRRule_I (a, b_UU0393_, _, _UU0394_0, _UU0394_1, _) = x in\n    coq_GLR_help2 ((app (coq_XBoxed_list b_UU0393_) ((Box a) :: [])),\n      (a :: [])) (l, (app _UU0394_0 ((Box a) :: _UU0394_1))) x), (fun h ->\n    coq_GLR_help1 prems (l, l0) h))))\n","open CML_Syntax\nopen Datatypes\nopen GLS_calcs\nopen Remove_list_lems\n\n(** val subform_boxesF : coq_MPropF -> coq_MPropF list **)\n\nlet rec subform_boxesF = function\n| Imp (b, c) ->\n  app (subform_boxesF b) (remove_list (subform_boxesF b) (subform_boxesF c))\n| Box b -> (Box b) :: (subform_boxesF b)\n| _ -> []\n\n(** val subform_boxesLF : coq_MPropF list -> coq_MPropF list **)\n\nlet rec subform_boxesLF = function\n| [] -> []\n| h :: t ->\n  app (subform_boxesF h) (remove_list (subform_boxesF h) (subform_boxesLF t))\n\n(** val subform_boxesS : coq_Seq -> coq_MPropF list **)\n\nlet subform_boxesS s =\n  app (subform_boxesLF (fst s))\n    (remove_list (subform_boxesLF (fst s)) (subform_boxesLF (snd s)))\n\n(** val usable_boxes : coq_Seq -> coq_MPropF list **)\n\nlet usable_boxes s =\n  remove_list (top_boxes (fst s)) (subform_boxesS s)\n","open CML_Syntax\nopen Datatypes\nopen KS_calc\nopen Specif\nopen List_lems\nopen Remove_list_lems\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val dec_is_PropVar : coq_MPropF -> ((char list, __) sigT, __) sum **)\n\nlet dec_is_PropVar = function\n| Var s -> Coq_inl (Coq_existT (s, __))\n| _ -> Coq_inr __\n\n(** val dec_prop_var_in :\n    (coq_MPropF list * coq_MPropF list) -> ((char list, __) sigT, __) sum **)\n\nlet dec_prop_var_in = function\n| (l, l0) ->\n  let rec f = function\n  | [] -> Coq_inr __\n  | y :: l2 ->\n    (match f l2 with\n     | Coq_inl s0 ->\n       let Coq_existT (x, _) = s0 in Coq_inl (Coq_existT (x, __))\n     | Coq_inr _ ->\n       let s0 = dec_is_PropVar y in\n       (match s0 with\n        | Coq_inl s1 ->\n          let s2 = coq_In_dec l0 y in\n          if s2\n          then Coq_inl (let Coq_existT (x, _) = s1 in Coq_existT (x, __))\n          else Coq_inr __\n        | Coq_inr _ -> Coq_inr __))\n  in f l\n\n(** val dec_KS_init_rules :\n    coq_Seq -> ((coq_IdPRule, coq_BotLRule) sum, __) sum **)\n\nlet dec_KS_init_rules = function\n| (l, l0) ->\n  let s0 = dec_prop_var_in (l, l0) in\n  (match s0 with\n   | Coq_inl s1 ->\n     let Coq_existT (x, _) = s1 in\n     Coq_inl (Coq_inl\n     (let h = in_splitT (Var x) l in\n      let Coq_existT (x0, s2) = h in\n      let Coq_existT (x1, _) = s2 in\n      let h0 = in_splitT (Var x) l0 in\n      let Coq_existT (x2, s3) = h0 in\n      let Coq_existT (x3, _) = s3 in IdPRule_I (x, x0, x1, x2, x3)))\n   | Coq_inr _ ->\n     let s1 = coq_In_dec l Bot in\n     if s1\n     then Coq_inl\n            (let i = in_splitT Bot l in\n             let Coq_existT (x, s2) = i in\n             let Coq_existT (x0, _) = s2 in Coq_inr (BotLRule_I (x, x0, l0)))\n     else Coq_inr __)\n","open CML_Syntax\nopen Datatypes\nopen List\nopen List_lemmasT\nopen PeanoNat\nopen Specif\nopen GenT\nopen Univ_gen_ext\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val proj1_sigT2 : ('a1, 'a2) sigT -> 'a1 **)\n\nlet proj1_sigT2 = function\n| Coq_existT (a, _) -> a\n\n(** val proj2_sigT2 : ('a1, 'a2) sigT -> 'a2 **)\n\nlet proj2_sigT2 = function\n| Coq_existT (_, b) -> b\n\n(** val coq_In_InT_pair :\n    coq_MPropF -> nat -> (coq_MPropF * nat) list -> (coq_MPropF * nat) coq_InT **)\n\nlet rec coq_In_InT_pair a n = function\n| [] -> assert false (* absurd case *)\n| y :: l0 ->\n  let h0 =\n    let (m, n0) = y in\n    let s = eq_dec_form a m in if s then Nat.eq_dec n n0 else false\n  in\n  if h0\n  then coq_InT_eq (a, n) l0\n  else InT_cons (y, l0, (coq_In_InT_pair a n l0))\n\n(** val coq_InT_map_iff :\n    ('a1 -> 'a2) -> 'a1 list -> 'a2 -> ('a2 coq_InT -> ('a1, __ * 'a1\n    coq_InT) sigT) * (('a1, __ * 'a1 coq_InT) sigT -> 'a2 coq_InT) **)\n\nlet rec coq_InT_map_iff f = function\n| [] ->\n  (fun _ -> ((fun _ -> assert false (* absurd case *)), (fun _ ->\n    assert false (* absurd case *))))\n| y :: l0 ->\n  let iHl = coq_InT_map_iff f l0 in\n  (fun y0 -> ((fun x ->\n  match x with\n  | InT_eq' (_, _) -> Coq_existT (y, (__, (coq_InT_eq y l0)))\n  | InT_cons (_, _, x0) ->\n    let p = iHl y0 in\n    let (s, _) = p in\n    let x1 = s x0 in\n    let Coq_existT (x2, p0) = x1 in\n    let (_, i) = p0 in Coq_existT (x2, (__, (InT_cons (y, l0, i))))),\n  (fun x ->\n  let p = iHl y0 in\n  let (_, i) = p in\n  let p0 = proj2_sigT2 x in\n  let (_, i0) = p0 in\n  (match i0 with\n   | InT_eq' (_, _) -> coq_InT_eq (f y) (map f l0)\n   | InT_cons (_, _, x0) ->\n     let x1 = Coq_existT ((proj1_sigT2 x), (__, x0)) in\n     let x2 = i x1 in InT_cons ((f y), (map f l0), x2)))))\n\n(** val pos_top_imps : coq_MPropF list -> (coq_MPropF * nat) list **)\n\nlet rec pos_top_imps = function\n| [] -> []\n| h :: t ->\n  (match h with\n   | Imp (a, b) ->\n     ((Imp (a, b)), (S\n       O)) :: (map (fun y -> ((fst y), (S (snd y)))) (pos_top_imps t))\n   | _ -> map (fun y -> ((fst y), (S (snd y)))) (pos_top_imps t))\n\n(** val top_boxes_nobox_gen_ext : coq_MPropF list -> nobox_gen_ext **)\n\nlet rec top_boxes_nobox_gen_ext = function\n| [] -> Coq_univ_gen_ext_nil\n| y :: l0 ->\n  (match y with\n   | Box m ->\n     Coq_univ_gen_ext_cons ((Box m), (top_boxes l0), l0,\n       (top_boxes_nobox_gen_ext l0))\n   | x ->\n     Coq_univ_gen_ext_extra (x, (top_boxes l0), l0, __,\n       (top_boxes_nobox_gen_ext l0)))\n\n(** val flatten_list : 'a1 list list -> 'a1 list **)\n\nlet rec flatten_list = function\n| [] -> []\n| h :: t -> app h (flatten_list t)\n\n(** val coq_InT_flatten_list_InT_elem :\n    'a1 list list -> 'a1 -> 'a1 coq_InT -> ('a1 list, 'a1 coq_InT * 'a1 list\n    coq_InT) sigT **)\n\nlet rec coq_InT_flatten_list_InT_elem l b x =\n  match l with\n  | [] -> assert false (* absurd case *)\n  | y :: l0 ->\n    let x0 = coq_InT_app_or y (flatten_list l0) b x in\n    (match x0 with\n     | Coq_inl i -> Coq_existT (y, (i, (coq_InT_eq y l0)))\n     | Coq_inr i ->\n       let s = coq_InT_flatten_list_InT_elem l0 b in\n       let i0 = s i in\n       let Coq_existT (x1, p) = i0 in\n       let (i1, i2) = p in Coq_existT (x1, (i1, (InT_cons (y, l0, i2)))))\n\n(** val coq_InT_trans_flatten_list :\n    'a1 list list -> 'a1 list -> 'a1 -> 'a1 coq_InT -> 'a1 list coq_InT ->\n    'a1 coq_InT **)\n\nlet rec coq_InT_trans_flatten_list l bs b x x0 =\n  match l with\n  | [] -> assert false (* absurd case *)\n  | y :: l0 ->\n    (match x0 with\n     | InT_eq' (_, _) -> coq_InT_or_app bs (flatten_list l0) b (Coq_inl x)\n     | InT_cons (_, _, x1) ->\n       coq_InT_or_app y (flatten_list l0) b (Coq_inr\n         (coq_InT_trans_flatten_list l0 bs b x x1)))\n\n(** val list_of_splits :\n    coq_MPropF list -> ((coq_MPropF list * coq_MPropF list) list, __) sigT **)\n\nlet rec list_of_splits = function\n| [] -> Coq_existT ((([], []) :: []), __)\n| y :: l0 ->\n  let Coq_existT (x, _) = list_of_splits l0 in\n  Coq_existT\n  ((app (([], (y :: l0)) :: [])\n     (map (fun y0 -> ((y :: (fst y0)), (snd y0))) x)), __)\n\n(** val listInserts :\n    coq_MPropF list -> coq_MPropF -> coq_MPropF list list **)\n\nlet listInserts l a =\n  map (fun y -> app (fst y) (a :: (snd y))) (proj1_sigT2 (list_of_splits l))\n\n(** val listInsertsR_Seqs :\n    coq_MPropF list -> coq_MPropF list -> coq_MPropF -> (coq_MPropF\n    list * coq_MPropF list) list **)\n\nlet listInsertsR_Seqs _UU0393_ _UU0394_ a =\n  map (fun y -> (y, _UU0394_)) (listInserts _UU0393_ a)\n\n(** val listInsertsL_Seqs :\n    coq_MPropF list -> coq_MPropF list -> coq_MPropF -> (coq_MPropF\n    list * coq_MPropF list) list **)\n\nlet listInsertsL_Seqs _UU0393_ _UU0394_ a =\n  map (fun y -> (_UU0393_, y)) (listInserts _UU0394_ a)\n\n(** val remove_nth :\n    nat -> coq_MPropF -> coq_MPropF list -> coq_MPropF list **)\n\nlet rec remove_nth n a l =\n  match n with\n  | O -> l\n  | S m ->\n    (match m with\n     | O ->\n       (match l with\n        | [] -> []\n        | b :: tl -> if eq_dec_form a b then tl else b :: tl)\n     | S _ -> (match l with\n               | [] -> []\n               | b :: tl -> b :: (remove_nth m a tl)))\n\n(** val nth_split :\n    nat -> coq_MPropF list -> coq_MPropF list * coq_MPropF list **)\n\nlet rec nth_split n l =\n  match n with\n  | O -> ([], l)\n  | S m ->\n    (match m with\n     | O -> (match l with\n             | [] -> ([], [])\n             | b :: tl -> ((b :: []), tl))\n     | S _ ->\n       (match l with\n        | [] -> ([], [])\n        | b :: tl -> ((b :: (fst (nth_split m tl))), (snd (nth_split m tl)))))\n","open CML_Syntax\nopen Datatypes\nopen KS_calc\nopen KS_termination_prelims\nopen List\nopen List_lemmasT\nopen Specif\nopen GenT\nopen List_lems\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val prems_Imp_R : (coq_MPropF * nat) list -> coq_Seq -> coq_Seq list **)\n\nlet rec prems_Imp_R l s =\n  match l with\n  | [] -> []\n  | p :: t ->\n    let (c, n) = p in\n    (match n with\n     | O -> prems_Imp_R t s\n     | S m ->\n       (match c with\n        | Imp (a, b) ->\n          app\n            (listInsertsR_Seqs (fst s)\n              (app (fst (nth_split m (remove_nth (S m) c (snd s))))\n                (b :: (snd (nth_split m (remove_nth (S m) c (snd s)))))) a)\n            (prems_Imp_R t s)\n        | _ -> prems_Imp_R t s))\n\n(** val coq_In_pos_top_imps_split_l :\n    coq_MPropF list -> coq_MPropF -> nat -> (coq_MPropF list, (coq_MPropF\n    list, __) sigT) sigT **)\n\nlet rec coq_In_pos_top_imps_split_l l a n =\n  match l with\n  | [] -> assert false (* absurd case *)\n  | y :: l0 ->\n    (match y with\n     | Imp (m, m0) ->\n       let h =\n         coq_In_InT_pair a (S n) (((Imp (m, m0)), (S\n           O)) :: (map (fun y0 -> ((fst y0), (S (snd y0)))) (pos_top_imps l0)))\n       in\n       (match h with\n        | InT_eq' (_, _) -> Coq_existT ([], (Coq_existT (l0, __)))\n        | InT_cons (_, _, _) ->\n          (match n with\n           | O -> assert false (* absurd case *)\n           | S n0 ->\n             let s = coq_In_pos_top_imps_split_l l0 a n0 in\n             let Coq_existT (x, s0) = s in\n             let Coq_existT (x0, _) = s0 in\n             Coq_existT (((Imp (m, m0)) :: x), (Coq_existT (x0, __)))))\n     | x ->\n       (match n with\n        | O -> assert false (* absurd case *)\n        | S n0 ->\n          let s = coq_In_pos_top_imps_split_l l0 a n0 in\n          let Coq_existT (x0, s0) = s in\n          let Coq_existT (x1, _) = s0 in\n          Coq_existT ((x :: x0), (Coq_existT (x1, __)))))\n\n(** val coq_ImpR_help01 :\n    coq_Seq -> coq_Seq -> (coq_MPropF * nat) list -> coq_Seq coq_InT -> (nat,\n    (coq_MPropF, (coq_MPropF, (coq_MPropF list, (coq_MPropF list, (coq_MPropF\n    list, (coq_MPropF list, __) sigT) sigT) sigT) sigT) sigT) sigT) sigT **)\n\nlet coq_ImpR_help01 prem s l3 =\n  let (l, l0) = s in\n  let rec f l1 x =\n    match l1 with\n    | [] -> assert false (* absurd case *)\n    | y :: l2 ->\n      let (m, n) = y in\n      (match m with\n       | Imp (m0, m1) ->\n         (match n with\n          | O ->\n            let s0 = f l2 x in\n            let Coq_existT (x0, s1) = s0 in\n            let Coq_existT (x1, s2) = s1 in\n            let Coq_existT (x2, s3) = s2 in\n            let Coq_existT (x3, s4) = s3 in\n            let Coq_existT (x4, s5) = s4 in\n            let Coq_existT (x5, s6) = s5 in\n            let Coq_existT (x6, _) = s6 in\n            Coq_existT (x0, (Coq_existT (x1, (Coq_existT (x2, (Coq_existT\n            (x3, (Coq_existT (x4, (Coq_existT (x5, (Coq_existT (x6,\n            __)))))))))))))\n          | S n0 ->\n            let x0 =\n              coq_InT_app_or\n                (listInsertsR_Seqs (fst (l, l0))\n                  (app\n                    (fst\n                      (nth_split n0\n                        (remove_nth (S n0) (Imp (m0, m1)) (snd (l, l0)))))\n                    (m1 :: (snd\n                             (nth_split n0\n                               (remove_nth (S n0) (Imp (m0, m1))\n                                 (snd (l, l0))))))) m0)\n                (let rec prems_Imp_R0 l4 s0 =\n                   match l4 with\n                   | [] -> []\n                   | p :: t ->\n                     let (c, n1) = p in\n                     (match n1 with\n                      | O -> prems_Imp_R0 t s0\n                      | S m2 ->\n                        (match c with\n                         | Imp (a, b) ->\n                           app\n                             (listInsertsR_Seqs (fst s0)\n                               (app\n                                 (fst\n                                   (nth_split m2\n                                     (remove_nth (S m2) c (snd s0))))\n                                 (b :: (snd\n                                         (nth_split m2\n                                           (remove_nth (S m2) c (snd s0))))))\n                               a) (prems_Imp_R0 t s0)\n                         | _ -> prems_Imp_R0 t s0))\n                 in prems_Imp_R0 l2 (l, l0)) prem x\n            in\n            (match x0 with\n             | Coq_inl i ->\n               let x1 = fun f0 l4 y0 ->\n                 let (x1, _) = coq_InT_map_iff f0 l4 y0 in x1\n               in\n               let i0 =\n                 x1 (fun y0 -> (y0,\n                   (app\n                     (fst\n                       (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l0)))\n                     (m1 :: (snd\n                              (nth_split n0\n                                (remove_nth (S n0) (Imp (m0, m1)) l0)))))))\n                   (listInserts l m0) prem i\n               in\n               let Coq_existT (x2, p) = i0 in\n               let (_, i1) = p in\n               let x3 = fun f0 l4 y0 ->\n                 let (x3, _) = coq_InT_map_iff f0 l4 y0 in x3\n               in\n               let i2 =\n                 x3 (fun y0 -> app (fst y0) (m0 :: (snd y0)))\n                   (proj1_sigT2 (list_of_splits l)) x2 i1\n               in\n               let Coq_existT (x4, _) = i2 in\n               let (l4, l5) = x4 in\n               Coq_existT (n0, (Coq_existT (m0, (Coq_existT (m1, (Coq_existT\n               (l4, (Coq_existT (l5, (Coq_existT\n               ((fst (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l0))),\n               (Coq_existT\n               ((snd (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l0))),\n               __)))))))))))))\n             | Coq_inr i ->\n               let s0 = f l2 i in\n               let Coq_existT (x1, s1) = s0 in\n               let Coq_existT (x2, s2) = s1 in\n               let Coq_existT (x3, s3) = s2 in\n               let Coq_existT (x4, s4) = s3 in\n               let Coq_existT (x5, s5) = s4 in\n               let Coq_existT (x6, s6) = s5 in\n               let Coq_existT (x7, _) = s6 in\n               Coq_existT (x1, (Coq_existT (x2, (Coq_existT (x3, (Coq_existT\n               (x4, (Coq_existT (x5, (Coq_existT (x6, (Coq_existT (x7,\n               __)))))))))))))))\n       | _ ->\n         let s0 = f l2 x in\n         let Coq_existT (x0, s1) = s0 in\n         let Coq_existT (x1, s2) = s1 in\n         let Coq_existT (x2, s3) = s2 in\n         let Coq_existT (x3, s4) = s3 in\n         let Coq_existT (x4, s5) = s4 in\n         let Coq_existT (x5, s6) = s5 in\n         let Coq_existT (x6, _) = s6 in\n         Coq_existT (x0, (Coq_existT (x1, (Coq_existT (x2, (Coq_existT (x3,\n         (Coq_existT (x4, (Coq_existT (x5, (Coq_existT (x6, __))))))))))))))\n  in f l3\n\n(** val coq_ImpR_help1 :\n    coq_Seq -> (coq_MPropF list * coq_MPropF list) -> coq_Seq coq_InT ->\n    coq_ImpRRule **)\n\nlet coq_ImpR_help1 prem s x =\n  let s0 = coq_ImpR_help01 prem s (pos_top_imps (snd s)) x in\n  let Coq_existT (x0, s1) = s0 in\n  let (_, l) = s in\n  let Coq_existT (x1, s2) = s1 in\n  let Coq_existT (x2, s3) = s2 in\n  let Coq_existT (x3, s4) = s3 in\n  let Coq_existT (x4, _) = s4 in\n  let i = coq_In_pos_top_imps_split_l l (Imp (x1, x2)) x0 in\n  let Coq_existT (x5, s5) = i in\n  let Coq_existT (x6, _) = s5 in ImpRRule_I (x1, x2, x3, x4, x5, x6)\n\n(** val coq_ImpR_help002 :\n    coq_MPropF list -> coq_MPropF list -> coq_MPropF list -> coq_MPropF list\n    -> coq_MPropF -> coq_MPropF -> (coq_MPropF list * coq_MPropF list) coq_InT **)\n\nlet coq_ImpR_help002 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b =\n  let f = fun y -> (y, (app _UU0394_0 (b :: _UU0394_1))) in\n  let l = listInserts (app _UU0393_0 _UU0393_1) a in\n  let y = ((app _UU0393_0 (a :: _UU0393_1)), (app _UU0394_0 (b :: _UU0394_1)))\n  in\n  let (_, x) = coq_InT_map_iff f l y in\n  x (Coq_existT ((app _UU0393_0 (a :: _UU0393_1)), (__,\n    (let f0 = fun y0 -> app (fst y0) (a :: (snd y0)) in\n     let l0 = proj1_sigT2 (list_of_splits (app _UU0393_0 _UU0393_1)) in\n     let y0 = app _UU0393_0 (a :: _UU0393_1) in\n     let (_, x0) = coq_InT_map_iff f0 l0 y0 in\n     x0 (Coq_existT ((_UU0393_0, _UU0393_1), (__,\n       (let s = list_of_splits (app _UU0393_0 _UU0393_1) in\n        let Coq_existT (x1, _) = s in\n        coq_In_InT_seqs (_UU0393_0, _UU0393_1) x1))))))))\n\n(** val coq_ImpR_help02 :\n    coq_MPropF list -> coq_MPropF list -> coq_MPropF list -> coq_MPropF list\n    -> coq_MPropF -> coq_MPropF -> (coq_MPropF * nat) list -> nat ->\n    coq_ImpRRule -> (coq_MPropF list * coq_MPropF list) coq_InT **)\n\nlet rec coq_ImpR_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b l n x =\n  match l with\n  | [] -> assert false (* absurd case *)\n  | y :: l0 ->\n    let (m, n0) = y in\n    (match m with\n     | Imp (m0, m1) ->\n       let h1 =\n         coq_In_InT_pair (Imp (a, b)) (S n) (((Imp (m0, m1)), n0) :: l0)\n       in\n       (match h1 with\n        | InT_eq' (_, _) ->\n          (match _UU0394_0 with\n           | [] ->\n             let i = coq_ImpR_help002 _UU0393_0 _UU0393_1 [] _UU0394_1 a b in\n             let s = eq_dec_form (Imp (a, b)) (Imp (a, b)) in\n             if s\n             then coq_InT_or_app\n                    (listInsertsR_Seqs (app _UU0393_0 _UU0393_1)\n                      (b :: _UU0394_1) a)\n                    (prems_Imp_R l0 ((app _UU0393_0 _UU0393_1), ((Imp (a,\n                      b)) :: _UU0394_1))) ((app _UU0393_0 (a :: _UU0393_1)),\n                    (b :: _UU0394_1)) (Coq_inl i)\n             else assert false (* absurd case *)\n           | m2 :: l1 ->\n             coq_InT_or_app\n               (listInsertsR_Seqs\n                 (fst ((app _UU0393_0 _UU0393_1),\n                   (app (m2 :: l1) ((Imp (a, b)) :: _UU0394_1))))\n                 (app\n                   (fst\n                     (nth_split (length (m2 :: l1))\n                       (remove_nth (S (length (m2 :: l1))) (Imp (a, b))\n                         (snd ((app _UU0393_0 _UU0393_1),\n                           (app (m2 :: l1) ((Imp (a, b)) :: _UU0394_1)))))))\n                   (b :: (snd\n                           (nth_split (length (m2 :: l1))\n                             (remove_nth (S (length (m2 :: l1))) (Imp (a, b))\n                               (snd ((app _UU0393_0 _UU0393_1),\n                                 (app (m2 :: l1) ((Imp (a, b)) :: _UU0394_1)))))))))\n                 a)\n               (let rec prems_Imp_R0 l2 s =\n                  match l2 with\n                  | [] -> []\n                  | p :: t ->\n                    let (c, n1) = p in\n                    (match n1 with\n                     | O -> prems_Imp_R0 t s\n                     | S m3 ->\n                       (match c with\n                        | Imp (a0, b0) ->\n                          app\n                            (listInsertsR_Seqs (fst s)\n                              (app\n                                (fst\n                                  (nth_split m3 (remove_nth (S m3) c (snd s))))\n                                (b0 :: (snd\n                                         (nth_split m3\n                                           (remove_nth (S m3) c (snd s))))))\n                              a0) (prems_Imp_R0 t s)\n                        | _ -> prems_Imp_R0 t s))\n                in prems_Imp_R0 l0 ((app _UU0393_0 _UU0393_1),\n                     (app (m2 :: l1) ((Imp (a, b)) :: _UU0394_1))))\n               ((app _UU0393_0 (a :: _UU0393_1)),\n               (app (m2 :: l1) (b :: _UU0394_1))) (Coq_inl\n               (coq_ImpR_help002 _UU0393_0 _UU0393_1 (m2 :: l1) _UU0394_1 a b)))\n        | InT_cons (_, _, _) ->\n          let i =\n            coq_ImpR_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b l0\n              (length _UU0394_0) x\n          in\n          (match n0 with\n           | O -> i\n           | S n1 ->\n             coq_InT_or_app\n               (listInsertsR_Seqs (app _UU0393_0 _UU0393_1)\n                 (app\n                   (fst\n                     (nth_split n1\n                       (match n1 with\n                        | O ->\n                          (match app _UU0394_0 ((Imp (a, b)) :: _UU0394_1) with\n                           | [] -> []\n                           | b0 :: tl ->\n                             if eq_dec_form (Imp (m0, m1)) b0\n                             then tl\n                             else b0 :: tl)\n                        | S _ ->\n                          (match app _UU0394_0 ((Imp (a, b)) :: _UU0394_1) with\n                           | [] -> []\n                           | b0 :: tl ->\n                             b0 :: (remove_nth n1 (Imp (m0, m1)) tl)))))\n                   (m1 :: (snd\n                            (nth_split n1\n                              (match n1 with\n                               | O ->\n                                 (match app _UU0394_0 ((Imp (a,\n                                          b)) :: _UU0394_1) with\n                                  | [] -> []\n                                  | b0 :: tl ->\n                                    if eq_dec_form (Imp (m0, m1)) b0\n                                    then tl\n                                    else b0 :: tl)\n                               | S _ ->\n                                 (match app _UU0394_0 ((Imp (a,\n                                          b)) :: _UU0394_1) with\n                                  | [] -> []\n                                  | b0 :: tl ->\n                                    b0 :: (remove_nth n1 (Imp (m0, m1)) tl)))))))\n                 m0)\n               (prems_Imp_R l0 ((app _UU0393_0 _UU0393_1),\n                 (app _UU0394_0 ((Imp (a, b)) :: _UU0394_1))))\n               ((app _UU0393_0 (a :: _UU0393_1)),\n               (app _UU0394_0 (b :: _UU0394_1))) (Coq_inr i)))\n     | x0 ->\n       let h1 = coq_In_InT_pair (Imp (a, b)) (S n) ((x0, n0) :: l0) in\n       (match h1 with\n        | InT_eq' (_, _) -> assert false (* absurd case *)\n        | InT_cons (_, _, _) ->\n          coq_ImpR_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b l0\n            (length _UU0394_0) x))\n\n(** val coq_ImpR_help2 :\n    coq_Seq -> coq_Seq -> coq_ImpRRule -> coq_Seq coq_InT **)\n\nlet coq_ImpR_help2 _ _ x = match x with\n| ImpRRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1) ->\n  coq_ImpR_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b\n    (pos_top_imps (app _UU0394_0 ((Imp (a, b)) :: _UU0394_1)))\n    (length _UU0394_0) x\n\n(** val finite_ImpR_premises_of_S :\n    coq_Seq -> (coq_Seq list list, coq_Seq list -> (coq_ImpRRule -> coq_Seq\n    list coq_InT) * (coq_Seq list coq_InT -> coq_ImpRRule)) sigT **)\n\nlet finite_ImpR_premises_of_S = function\n| (l, l0) ->\n  Coq_existT\n    ((map (fun y -> y :: []) (prems_Imp_R (pos_top_imps l0) (l, l0))),\n    (fun prems -> ((fun h ->\n    let ImpRRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1) = h in\n    let f = fun y -> y :: [] in\n    let l1 =\n      prems_Imp_R (pos_top_imps (app _UU0394_0 ((Imp (a, b)) :: _UU0394_1)))\n        ((app _UU0393_0 _UU0393_1),\n        (app _UU0394_0 ((Imp (a, b)) :: _UU0394_1)))\n    in\n    let y = ((app _UU0393_0 (a :: _UU0393_1)),\n      (app _UU0394_0 (b :: _UU0394_1))) :: []\n    in\n    let (_, x) = coq_InT_map_iff f l1 y in\n    x (Coq_existT (((app _UU0393_0 (a :: _UU0393_1)),\n      (app _UU0394_0 (b :: _UU0394_1))), (__,\n      (coq_ImpR_help2 ((app _UU0393_0 (a :: _UU0393_1)),\n        (app _UU0394_0 (b :: _UU0394_1))) ((app _UU0393_0 _UU0393_1),\n        (app _UU0394_0 ((Imp (a, b)) :: _UU0394_1))) h))))), (fun h ->\n    let x = fun f l1 y -> let (x, _) = coq_InT_map_iff f l1 y in x in\n    let h0 =\n      x (fun y -> y :: []) (prems_Imp_R (pos_top_imps l0) (l, l0)) prems h\n    in\n    let Coq_existT (x0, p) = h0 in\n    let (_, i) = p in coq_ImpR_help1 x0 (l, l0) i))))\n","open CML_Syntax\nopen Datatypes\nopen KS_calc\nopen KS_termination_ImpR\nopen KS_termination_prelims\nopen List\nopen List_lemmasT\nopen Specif\nopen GenT\nopen List_lems\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val prems_Imp_L :\n    (coq_MPropF * nat) list -> coq_Seq -> coq_Seq list list **)\n\nlet rec prems_Imp_L l s =\n  match l with\n  | [] -> []\n  | p :: t ->\n    let (c, n) = p in\n    (match n with\n     | O -> prems_Imp_L t s\n     | S m ->\n       (match c with\n        | Imp (a, b) ->\n          app\n            (flatten_list\n              (map (fun y ->\n                map (fun z -> z :: (y :: []))\n                  (listInsertsL_Seqs\n                    (app (fst (nth_split m (remove_nth (S m) c (fst s))))\n                      (snd (nth_split m (remove_nth (S m) c (fst s)))))\n                    (snd s) a))\n                (((app (fst (nth_split m (remove_nth (S m) c (fst s))))\n                    (b :: (snd (nth_split m (remove_nth (S m) c (fst s)))))),\n                (snd s)) :: []))) (prems_Imp_L t s)\n        | _ -> prems_Imp_L t s))\n\n(** val coq_ImpL_help002 :\n    coq_MPropF list -> coq_MPropF list -> coq_MPropF list -> coq_MPropF list\n    -> coq_MPropF -> coq_MPropF -> (coq_MPropF list * coq_MPropF list) list\n    coq_InT **)\n\nlet coq_ImpL_help002 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b =\n  coq_InT_trans_flatten_list\n    (map (fun y ->\n      map (fun z -> y :: (z :: [])) (((app _UU0393_0 (b :: _UU0393_1)),\n        (app _UU0394_0 _UU0394_1)) :: []))\n      (listInsertsL_Seqs (app _UU0393_0 _UU0393_1) (app _UU0394_0 _UU0394_1)\n        a))\n    (map (fun z -> ((app _UU0393_0 _UU0393_1),\n      (app _UU0394_0 (a :: _UU0394_1))) :: (z :: []))\n      (((app _UU0393_0 (b :: _UU0393_1)), (app _UU0394_0 _UU0394_1)) :: []))\n    (((app _UU0393_0 _UU0393_1),\n    (app _UU0394_0 (a :: _UU0394_1))) :: (((app _UU0393_0 (b :: _UU0393_1)),\n    (app _UU0394_0 _UU0394_1)) :: []))\n    (let p =\n       coq_InT_map_iff (fun z -> ((app _UU0393_0 _UU0393_1),\n         (app _UU0394_0 (a :: _UU0394_1))) :: (z :: []))\n         (((app _UU0393_0 (b :: _UU0393_1)),\n         (app _UU0394_0 _UU0394_1)) :: []) (((app _UU0393_0 _UU0393_1),\n         (app _UU0394_0 (a :: _UU0394_1))) :: (((app _UU0393_0\n                                                  (b :: _UU0393_1)),\n         (app _UU0394_0 _UU0394_1)) :: []))\n     in\n     let (_, i) = p in\n     i (Coq_existT (((app _UU0393_0 (b :: _UU0393_1)),\n       (app _UU0394_0 _UU0394_1)), (__,\n       (coq_InT_eq ((app _UU0393_0 (b :: _UU0393_1)),\n         (app _UU0394_0 _UU0394_1)) [])))))\n    (let p =\n       coq_InT_map_iff (fun y ->\n         map (fun z -> y :: (z :: [])) (((app _UU0393_0 (b :: _UU0393_1)),\n           (app _UU0394_0 _UU0394_1)) :: []))\n         (listInsertsL_Seqs (app _UU0393_0 _UU0393_1)\n           (app _UU0394_0 _UU0394_1) a)\n         (map (fun z -> ((app _UU0393_0 _UU0393_1),\n           (app _UU0394_0 (a :: _UU0394_1))) :: (z :: []))\n           (((app _UU0393_0 (b :: _UU0393_1)),\n           (app _UU0394_0 _UU0394_1)) :: []))\n     in\n     let (_, i) = p in\n     i (Coq_existT (((app _UU0393_0 _UU0393_1),\n       (app _UU0394_0 (a :: _UU0394_1))), (__,\n       (let p0 =\n          coq_InT_map_iff (fun y -> ((app _UU0393_0 _UU0393_1), y))\n            (listInserts (app _UU0394_0 _UU0394_1) a)\n            ((app _UU0393_0 _UU0393_1), (app _UU0394_0 (a :: _UU0394_1)))\n        in\n        let (_, i0) = p0 in\n        i0 (Coq_existT ((app _UU0394_0 (a :: _UU0394_1)), (__,\n          (let p1 =\n             coq_InT_map_iff (fun y -> app (fst y) (a :: (snd y)))\n               (proj1_sigT2 (list_of_splits (app _UU0394_0 _UU0394_1)))\n               (app _UU0394_0 (a :: _UU0394_1))\n           in\n           let (_, i1) = p1 in\n           i1 (Coq_existT ((_UU0394_0, _UU0394_1), (__,\n             (let s = list_of_splits (app _UU0394_0 _UU0394_1) in\n              let Coq_existT (x, _) = s in\n              coq_In_InT_seqs (_UU0394_0, _UU0394_1) x)))))))))))))\n\n(** val coq_ImpL_help02 :\n    coq_MPropF list -> coq_MPropF list -> coq_MPropF list -> coq_MPropF list\n    -> coq_MPropF -> coq_MPropF -> (coq_MPropF * nat) list -> nat ->\n    coq_ImpLRule -> (coq_MPropF list * coq_MPropF list) list coq_InT **)\n\nlet rec coq_ImpL_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b l n x =\n  match l with\n  | [] -> assert false (* absurd case *)\n  | y :: l0 ->\n    let (m, n0) = y in\n    (match m with\n     | Imp (m0, m1) ->\n       let h1 =\n         coq_In_InT_pair (Imp (a, b)) (S n) (((Imp (m0, m1)), n0) :: l0)\n       in\n       (match h1 with\n        | InT_eq' (_, _) ->\n          let i = coq_ImpL_help002 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b\n          in\n          coq_InT_or_app\n            (flatten_list\n              (map (fun y0 ->\n                map (fun z -> z :: (y0 :: []))\n                  (listInsertsL_Seqs\n                    (app\n                      (fst\n                        (nth_split (length _UU0393_0)\n                          (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                            (fst\n                              ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                              (app _UU0394_0 _UU0394_1))))))\n                      (snd\n                        (nth_split (length _UU0393_0)\n                          (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                            (fst\n                              ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                              (app _UU0394_0 _UU0394_1)))))))\n                    (snd ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                      (app _UU0394_0 _UU0394_1))) a))\n                (((app\n                    (fst\n                      (nth_split (length _UU0393_0)\n                        (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                          (fst ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                            (app _UU0394_0 _UU0394_1))))))\n                    (b :: (snd\n                            (nth_split (length _UU0393_0)\n                              (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                                (fst\n                                  ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                                  (app _UU0394_0 _UU0394_1)))))))),\n                (snd ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                  (app _UU0394_0 _UU0394_1)))) :: [])))\n            (let rec prems_Imp_L0 l1 s =\n               match l1 with\n               | [] -> []\n               | p :: t ->\n                 let (c, n1) = p in\n                 (match n1 with\n                  | O -> prems_Imp_L0 t s\n                  | S m2 ->\n                    (match c with\n                     | Imp (a0, b0) ->\n                       app\n                         (flatten_list\n                           (map (fun y0 ->\n                             map (fun z -> z :: (y0 :: []))\n                               (listInsertsL_Seqs\n                                 (app\n                                   (fst\n                                     (nth_split m2\n                                       (remove_nth (S m2) c (fst s))))\n                                   (snd\n                                     (nth_split m2\n                                       (remove_nth (S m2) c (fst s)))))\n                                 (snd s) a0))\n                             (((app\n                                 (fst\n                                   (nth_split m2\n                                     (remove_nth (S m2) c (fst s))))\n                                 (b0 :: (snd\n                                          (nth_split m2\n                                            (remove_nth (S m2) c (fst s)))))),\n                             (snd s)) :: []))) (prems_Imp_L0 t s)\n                     | _ -> prems_Imp_L0 t s))\n             in prems_Imp_L0 l0 ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                  (app _UU0394_0 _UU0394_1))) (((app _UU0393_0 _UU0393_1),\n            (app _UU0394_0 (a :: _UU0394_1))) :: (((app _UU0393_0\n                                                     (b :: _UU0393_1)),\n            (app _UU0394_0 _UU0394_1)) :: [])) (Coq_inl\n            (coq_InT_trans_flatten_list\n              (map (fun y0 ->\n                map (fun z -> z :: (y0 :: []))\n                  (listInsertsL_Seqs\n                    (app\n                      (fst\n                        (nth_split (length _UU0393_0)\n                          (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                            (fst\n                              ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                              (app _UU0394_0 _UU0394_1))))))\n                      (snd\n                        (nth_split (length _UU0393_0)\n                          (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                            (fst\n                              ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                              (app _UU0394_0 _UU0394_1)))))))\n                    (snd ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                      (app _UU0394_0 _UU0394_1))) a))\n                (((app\n                    (fst\n                      (nth_split (length _UU0393_0)\n                        (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                          (fst ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                            (app _UU0394_0 _UU0394_1))))))\n                    (b :: (snd\n                            (nth_split (length _UU0393_0)\n                              (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                                (fst\n                                  ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                                  (app _UU0394_0 _UU0394_1)))))))),\n                (snd ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                  (app _UU0394_0 _UU0394_1)))) :: []))\n              (flatten_list\n                (map (fun y0 -> (y0 :: (((app _UU0393_0 (b :: _UU0393_1)),\n                  (app _UU0394_0 _UU0394_1)) :: [])) :: [])\n                  (listInsertsL_Seqs (app _UU0393_0 _UU0393_1)\n                    (app _UU0394_0 _UU0394_1) a)))\n              (((app _UU0393_0 _UU0393_1),\n              (app _UU0394_0 (a :: _UU0394_1))) :: (((app _UU0393_0\n                                                       (b :: _UU0393_1)),\n              (app _UU0394_0 _UU0394_1)) :: [])) i\n              (let f = fun y0 ->\n                 map (fun z -> z :: (y0 :: []))\n                   (listInsertsL_Seqs\n                     (app\n                       (fst\n                         (nth_split (length _UU0393_0)\n                           (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                             (fst\n                               ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                               (app _UU0394_0 _UU0394_1))))))\n                       (snd\n                         (nth_split (length _UU0393_0)\n                           (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                             (fst\n                               ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                               (app _UU0394_0 _UU0394_1)))))))\n                     (snd ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                       (app _UU0394_0 _UU0394_1))) a)\n               in\n               let l1 =\n                 ((app\n                    (fst\n                      (nth_split (length _UU0393_0)\n                        (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                          (fst ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                            (app _UU0394_0 _UU0394_1))))))\n                    (b :: (snd\n                            (nth_split (length _UU0393_0)\n                              (remove_nth (S (length _UU0393_0)) (Imp (a, b))\n                                (fst\n                                  ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                                  (app _UU0394_0 _UU0394_1)))))))),\n                 (snd ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                   (app _UU0394_0 _UU0394_1)))) :: []\n               in\n               let y0 =\n                 flatten_list\n                   (map (fun y0 -> (y0 :: (((app _UU0393_0 (b :: _UU0393_1)),\n                     (app _UU0394_0 _UU0394_1)) :: [])) :: [])\n                     (listInsertsL_Seqs (app _UU0393_0 _UU0393_1)\n                       (app _UU0394_0 _UU0394_1) a))\n               in\n               let (_, x0) = coq_InT_map_iff f l1 y0 in\n               x0 (Coq_existT (((app _UU0393_0 (b :: _UU0393_1)),\n                 (app _UU0394_0 _UU0394_1)), (__,\n                 (let s = eq_dec_form (Imp (a, b)) (Imp (a, b)) in\n                  if s\n                  then coq_InT_eq ((app _UU0393_0 (b :: _UU0393_1)),\n                         (app _UU0394_0 _UU0394_1)) []\n                  else assert false (* absurd case *))))))))\n        | InT_cons (_, _, _) ->\n          let i =\n            coq_ImpL_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b l0\n              (length _UU0393_0) x\n          in\n          (match n0 with\n           | O -> i\n           | S n1 ->\n             coq_InT_or_app\n               (app\n                 (map (fun z ->\n                   z :: (((app\n                            (fst\n                              (nth_split n1\n                                (match n1 with\n                                 | O ->\n                                   (match app _UU0393_0 ((Imp (a,\n                                            b)) :: _UU0393_1) with\n                                    | [] -> []\n                                    | b0 :: tl ->\n                                      if eq_dec_form (Imp (m0, m1)) b0\n                                      then tl\n                                      else b0 :: tl)\n                                 | S _ ->\n                                   (match app _UU0393_0 ((Imp (a,\n                                            b)) :: _UU0393_1) with\n                                    | [] -> []\n                                    | b0 :: tl ->\n                                      b0 :: (remove_nth n1 (Imp (m0, m1)) tl)))))\n                            (m1 :: (snd\n                                     (nth_split n1\n                                       (match n1 with\n                                        | O ->\n                                          (match app _UU0393_0 ((Imp (a,\n                                                   b)) :: _UU0393_1) with\n                                           | [] -> []\n                                           | b0 :: tl ->\n                                             if eq_dec_form (Imp (m0, m1)) b0\n                                             then tl\n                                             else b0 :: tl)\n                                        | S _ ->\n                                          (match app _UU0393_0 ((Imp (a,\n                                                   b)) :: _UU0393_1) with\n                                           | [] -> []\n                                           | b0 :: tl ->\n                                             b0 :: (remove_nth n1 (Imp (m0,\n                                                     m1)) tl))))))),\n                   (app _UU0394_0 _UU0394_1)) :: []))\n                   (listInsertsL_Seqs\n                     (app\n                       (fst\n                         (nth_split n1\n                           (match n1 with\n                            | O ->\n                              (match app _UU0393_0 ((Imp (a, b)) :: _UU0393_1) with\n                               | [] -> []\n                               | b0 :: tl ->\n                                 if eq_dec_form (Imp (m0, m1)) b0\n                                 then tl\n                                 else b0 :: tl)\n                            | S _ ->\n                              (match app _UU0393_0 ((Imp (a, b)) :: _UU0393_1) with\n                               | [] -> []\n                               | b0 :: tl ->\n                                 b0 :: (remove_nth n1 (Imp (m0, m1)) tl)))))\n                       (snd\n                         (nth_split n1\n                           (match n1 with\n                            | O ->\n                              (match app _UU0393_0 ((Imp (a, b)) :: _UU0393_1) with\n                               | [] -> []\n                               | b0 :: tl ->\n                                 if eq_dec_form (Imp (m0, m1)) b0\n                                 then tl\n                                 else b0 :: tl)\n                            | S _ ->\n                              (match app _UU0393_0 ((Imp (a, b)) :: _UU0393_1) with\n                               | [] -> []\n                               | b0 :: tl ->\n                                 b0 :: (remove_nth n1 (Imp (m0, m1)) tl))))))\n                     (app _UU0394_0 _UU0394_1) m0)) [])\n               (prems_Imp_L l0 ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n                 (app _UU0394_0 _UU0394_1))) (((app _UU0393_0 _UU0393_1),\n               (app _UU0394_0 (a :: _UU0394_1))) :: (((app _UU0393_0\n                                                        (b :: _UU0393_1)),\n               (app _UU0394_0 _UU0394_1)) :: [])) (Coq_inr i)))\n     | x0 ->\n       let h1 =\n         coq_In_InT_pair (Imp (a, b)) (S (length _UU0393_0)) ((x0, n0) :: l0)\n       in\n       (match h1 with\n        | InT_eq' (_, _) -> assert false (* absurd case *)\n        | InT_cons (_, _, _) ->\n          coq_ImpL_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b l0\n            (length _UU0393_0) x))\n\n(** val coq_ImpL_help2 :\n    coq_Seq -> coq_Seq -> coq_Seq -> coq_ImpLRule -> coq_Seq list coq_InT **)\n\nlet coq_ImpL_help2 _ _ _ x = match x with\n| ImpLRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1) ->\n  coq_ImpL_help02 _UU0393_0 _UU0393_1 _UU0394_0 _UU0394_1 a b\n    (pos_top_imps (app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)))\n    (length _UU0393_0) x\n\n(** val coq_ImpL_help01 :\n    coq_Seq list -> coq_Seq -> (coq_MPropF * nat) list -> coq_Seq list\n    coq_InT -> (nat, (coq_Seq, (coq_Seq, (coq_MPropF, (coq_MPropF,\n    (coq_MPropF list, (coq_MPropF list, (coq_MPropF list, (coq_MPropF list,\n    __) sigT) sigT) sigT) sigT) sigT) sigT) sigT) sigT) sigT **)\n\nlet coq_ImpL_help01 prems s l1 =\n  let (l, l0) = s in\n  let rec f l2 x =\n    match l2 with\n    | [] -> assert false (* absurd case *)\n    | y :: l3 ->\n      let (m, n) = y in\n      (match m with\n       | Imp (m0, m1) ->\n         (match n with\n          | O ->\n            let s0 = f l3 x in\n            let Coq_existT (x0, s1) = s0 in\n            let Coq_existT (x1, s2) = s1 in\n            let Coq_existT (x2, s3) = s2 in\n            let Coq_existT (x3, s4) = s3 in\n            let Coq_existT (x4, s5) = s4 in\n            let Coq_existT (x5, s6) = s5 in\n            let Coq_existT (x6, s7) = s6 in\n            let Coq_existT (x7, s8) = s7 in\n            let Coq_existT (x8, _) = s8 in\n            Coq_existT (x0, (Coq_existT (x1, (Coq_existT (x2, (Coq_existT\n            (x3, (Coq_existT (x4, (Coq_existT (x5, (Coq_existT (x6,\n            (Coq_existT (x7, (Coq_existT (x8, __)))))))))))))))))\n          | S n0 ->\n            let x0 =\n              coq_InT_app_or\n                (flatten_list\n                  (map (fun y0 ->\n                    map (fun z -> z :: (y0 :: []))\n                      (listInsertsL_Seqs\n                        (app\n                          (fst\n                            (nth_split n0\n                              (remove_nth (S n0) (Imp (m0, m1)) (fst (l, l0)))))\n                          (snd\n                            (nth_split n0\n                              (remove_nth (S n0) (Imp (m0, m1)) (fst (l, l0))))))\n                        (snd (l, l0)) m0))\n                    (((app\n                        (fst\n                          (nth_split n0\n                            (remove_nth (S n0) (Imp (m0, m1)) (fst (l, l0)))))\n                        (m1 :: (snd\n                                 (nth_split n0\n                                   (remove_nth (S n0) (Imp (m0, m1))\n                                     (fst (l, l0))))))),\n                    (snd (l, l0))) :: [])))\n                (let rec prems_Imp_L0 l4 s0 =\n                   match l4 with\n                   | [] -> []\n                   | p :: t ->\n                     let (c, n1) = p in\n                     (match n1 with\n                      | O -> prems_Imp_L0 t s0\n                      | S m2 ->\n                        (match c with\n                         | Imp (a, b) ->\n                           app\n                             (flatten_list\n                               (map (fun y0 ->\n                                 map (fun z -> z :: (y0 :: []))\n                                   (listInsertsL_Seqs\n                                     (app\n                                       (fst\n                                         (nth_split m2\n                                           (remove_nth (S m2) c (fst s0))))\n                                       (snd\n                                         (nth_split m2\n                                           (remove_nth (S m2) c (fst s0)))))\n                                     (snd s0) a))\n                                 (((app\n                                     (fst\n                                       (nth_split m2\n                                         (remove_nth (S m2) c (fst s0))))\n                                     (b :: (snd\n                                             (nth_split m2\n                                               (remove_nth (S m2) c (fst s0)))))),\n                                 (snd s0)) :: []))) (prems_Imp_L0 t s0)\n                         | _ -> prems_Imp_L0 t s0))\n                 in prems_Imp_L0 l3 (l, l0)) prems x\n            in\n            (match x0 with\n             | Coq_inl i ->\n               let i0 =\n                 coq_InT_flatten_list_InT_elem\n                   (map (fun y0 ->\n                     map (fun z -> z :: (y0 :: []))\n                       (listInsertsL_Seqs\n                         (app\n                           (fst\n                             (nth_split n0\n                               (remove_nth (S n0) (Imp (m0, m1)) l)))\n                           (snd\n                             (nth_split n0\n                               (remove_nth (S n0) (Imp (m0, m1)) l)))) l0 m0))\n                     (((app\n                         (fst\n                           (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l)))\n                         (m1 :: (snd\n                                  (nth_split n0\n                                    (remove_nth (S n0) (Imp (m0, m1)) l))))),\n                     l0) :: [])) prems i\n               in\n               let Coq_existT (x1, p) = i0 in\n               let (i1, i2) = p in\n               let x2 = fun f0 l4 y0 ->\n                 let (x2, _) = coq_InT_map_iff f0 l4 y0 in x2\n               in\n               let i3 =\n                 x2 (fun y0 ->\n                   map (fun z -> z :: (y0 :: []))\n                     (listInsertsL_Seqs\n                       (app\n                         (fst\n                           (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l)))\n                         (snd\n                           (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l))))\n                       l0 m0))\n                   (((app\n                       (fst\n                         (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l)))\n                       (m1 :: (snd\n                                (nth_split n0\n                                  (remove_nth (S n0) (Imp (m0, m1)) l))))),\n                   l0) :: []) x1 i2\n               in\n               let Coq_existT (_, p0) = i3 in\n               let (_, i4) = p0 in\n               (match i4 with\n                | InT_eq' (_, _) ->\n                  let x3 = fun f0 l4 y0 ->\n                    let (x3, _) = coq_InT_map_iff f0 l4 y0 in x3\n                  in\n                  let i5 =\n                    x3 (fun z ->\n                      z :: (((app\n                               (fst\n                                 (nth_split n0\n                                   (match n0 with\n                                    | O ->\n                                      (match l with\n                                       | [] -> []\n                                       | b :: tl ->\n                                         if eq_dec_form (Imp (m0, m1)) b\n                                         then tl\n                                         else b :: tl)\n                                    | S _ ->\n                                      (match l with\n                                       | [] -> []\n                                       | b :: tl ->\n                                         b :: (remove_nth n0 (Imp (m0, m1))\n                                                tl)))))\n                               (m1 :: (snd\n                                        (nth_split n0\n                                          (match n0 with\n                                           | O ->\n                                             (match l with\n                                              | [] -> []\n                                              | b :: tl ->\n                                                if eq_dec_form (Imp (m0, m1))\n                                                     b\n                                                then tl\n                                                else b :: tl)\n                                           | S _ ->\n                                             (match l with\n                                              | [] -> []\n                                              | b :: tl ->\n                                                b :: (remove_nth n0 (Imp (m0,\n                                                       m1)) tl))))))),\n                      l0) :: []))\n                      (listInsertsL_Seqs\n                        (app\n                          (fst\n                            (nth_split n0\n                              (remove_nth (S n0) (Imp (m0, m1)) l)))\n                          (snd\n                            (nth_split n0\n                              (remove_nth (S n0) (Imp (m0, m1)) l)))) l0 m0)\n                      prems i1\n                  in\n                  let Coq_existT (x4, p1) = i5 in\n                  let (_, i6) = p1 in\n                  let x5 = fun f0 l4 y0 ->\n                    let (x5, _) = coq_InT_map_iff f0 l4 y0 in x5\n                  in\n                  let i7 =\n                    x5 (fun y0 ->\n                      ((app\n                         (fst\n                           (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l)))\n                         (snd\n                           (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l)))),\n                      y0)) (listInserts l0 m0) x4 i6\n                  in\n                  let Coq_existT (x6, p2) = i7 in\n                  let (_, i8) = p2 in\n                  let x7 = fun f0 l4 y0 ->\n                    let (x7, _) = coq_InT_map_iff f0 l4 y0 in x7\n                  in\n                  let i9 =\n                    x7 (fun y0 -> app (fst y0) (m0 :: (snd y0)))\n                      (proj1_sigT2 (list_of_splits l0)) x6 i8\n                  in\n                  let Coq_existT (x8, _) = i9 in\n                  let (l4, l5) = x8 in\n                  Coq_existT (n0, (Coq_existT\n                  (((app\n                      (fst\n                        (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l)))\n                      (snd\n                        (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l)))),\n                  (app l4 (m0 :: l5))), (Coq_existT\n                  (((app\n                      (fst\n                        (nth_split n0\n                          (match n0 with\n                           | O ->\n                             (match l with\n                              | [] -> []\n                              | b0 :: tl ->\n                                if eq_dec_form (Imp (m0, m1)) b0\n                                then tl\n                                else b0 :: tl)\n                           | S _ ->\n                             (match l with\n                              | [] -> []\n                              | b0 :: tl ->\n                                b0 :: (remove_nth n0 (Imp (m0, m1)) tl)))))\n                      (m1 :: (snd\n                               (nth_split n0\n                                 (match n0 with\n                                  | O ->\n                                    (match l with\n                                     | [] -> []\n                                     | b0 :: tl ->\n                                       if eq_dec_form (Imp (m0, m1)) b0\n                                       then tl\n                                       else b0 :: tl)\n                                  | S _ ->\n                                    (match l with\n                                     | [] -> []\n                                     | b0 :: tl ->\n                                       b0 :: (remove_nth n0 (Imp (m0, m1)) tl))))))),\n                  l0), (Coq_existT (m0, (Coq_existT (m1, (Coq_existT\n                  ((fst (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l))),\n                  (Coq_existT\n                  ((snd (nth_split n0 (remove_nth (S n0) (Imp (m0, m1)) l))),\n                  (Coq_existT (l4, (Coq_existT (l5, __)))))))))))))))))\n                | InT_cons (_, _, _) -> assert false (* absurd case *))\n             | Coq_inr i ->\n               let s0 = f l3 i in\n               let Coq_existT (x1, s1) = s0 in\n               let Coq_existT (x2, s2) = s1 in\n               let Coq_existT (x3, s3) = s2 in\n               let Coq_existT (x4, s4) = s3 in\n               let Coq_existT (x5, s5) = s4 in\n               let Coq_existT (x6, s6) = s5 in\n               let Coq_existT (x7, s7) = s6 in\n               let Coq_existT (x8, s8) = s7 in\n               let Coq_existT (x9, _) = s8 in\n               Coq_existT (x1, (Coq_existT (x2, (Coq_existT (x3, (Coq_existT\n               (x4, (Coq_existT (x5, (Coq_existT (x6, (Coq_existT (x7,\n               (Coq_existT (x8, (Coq_existT (x9, __)))))))))))))))))))\n       | _ ->\n         let s0 = f l3 x in\n         let Coq_existT (x0, s1) = s0 in\n         let Coq_existT (x1, s2) = s1 in\n         let Coq_existT (x2, s3) = s2 in\n         let Coq_existT (x3, s4) = s3 in\n         let Coq_existT (x4, s5) = s4 in\n         let Coq_existT (x5, s6) = s5 in\n         let Coq_existT (x6, s7) = s6 in\n         let Coq_existT (x7, s8) = s7 in\n         let Coq_existT (x8, _) = s8 in\n         Coq_existT (x0, (Coq_existT (x1, (Coq_existT (x2, (Coq_existT (x3,\n         (Coq_existT (x4, (Coq_existT (x5, (Coq_existT (x6, (Coq_existT (x7,\n         (Coq_existT (x8, __))))))))))))))))))\n  in f l1\n\n(** val coq_ImpL_help1 :\n    coq_Seq list -> (coq_MPropF list * coq_MPropF list) -> coq_Seq list\n    coq_InT -> coq_ImpLRule **)\n\nlet coq_ImpL_help1 prem s x =\n  let s0 = coq_ImpL_help01 prem s (pos_top_imps (fst s)) x in\n  let Coq_existT (x0, s1) = s0 in\n  let Coq_existT (_, s2) = s1 in\n  let Coq_existT (_, s3) = s2 in\n  let Coq_existT (x1, s4) = s3 in\n  let Coq_existT (x2, s5) = s4 in\n  let Coq_existT (_, s6) = s5 in\n  let Coq_existT (_, s7) = s6 in\n  let Coq_existT (x3, s8) = s7 in\n  let Coq_existT (x4, _) = s8 in\n  let (l, l0) = s in\n  let i = coq_In_pos_top_imps_split_l (fst (l, l0)) (Imp (x1, x2)) x0 in\n  let Coq_existT (x5, _) = i in\n  let _UU0393_0' =\n    fst (nth_split (length x5) (remove_nth (S (length x5)) (Imp (x1, x2)) l))\n  in\n  let _UU0393_1' =\n    snd (nth_split (length x5) (remove_nth (S (length x5)) (Imp (x1, x2)) l))\n  in\n  ImpLRule_I (x1, x2, _UU0393_0', _UU0393_1', x3, x4)\n\n(** val finite_ImpL_premises_of_S :\n    coq_Seq -> (coq_Seq list list, coq_Seq list -> (coq_ImpLRule -> coq_Seq\n    list coq_InT) * (coq_Seq list coq_InT -> coq_ImpLRule)) sigT **)\n\nlet finite_ImpL_premises_of_S = function\n| (l, l0) ->\n  Coq_existT ((prems_Imp_L (pos_top_imps l) (l, l0)), (fun prems ->\n    ((fun h ->\n    let ImpLRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1) = h in\n    coq_ImpL_help2 ((app _UU0393_0 _UU0393_1),\n      (app _UU0394_0 (a :: _UU0394_1))) ((app _UU0393_0 (b :: _UU0393_1)),\n      (app _UU0394_0 _UU0394_1))\n      ((app _UU0393_0 ((Imp (a, b)) :: _UU0393_1)),\n      (app _UU0394_0 _UU0394_1)) h), (fun h ->\n    coq_ImpL_help1 prems (l, l0) h))))\n","open CML_Syntax\nopen Datatypes\nopen KS_calc\nopen KS_termination_prelims\nopen List_lemmasT\nopen Specif\nopen GenT\nopen List_lems\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val prems_Box_R : coq_MPropF list -> coq_Seq -> coq_Seq list list **)\n\nlet rec prems_Box_R l s =\n  match l with\n  | [] -> []\n  | h :: t ->\n    (match h with\n     | Box a ->\n       (((unboxed_list (top_boxes (fst s))),\n         (a :: [])) :: []) :: (prems_Box_R t s)\n     | _ -> prems_Box_R t s)\n\n(** val coq_KR_help01 :\n    coq_Seq list -> coq_Seq -> coq_MPropF list -> coq_Seq list coq_InT ->\n    (coq_MPropF, __) sigT **)\n\nlet rec coq_KR_help01 prems s l1 x =\n  match l1 with\n  | [] -> assert false (* absurd case *)\n  | y :: l ->\n    (match y with\n     | Box m ->\n       (match x with\n        | InT_eq' (_, _) -> Coq_existT (m, __)\n        | InT_cons (_, _, x0) ->\n          let h0 = coq_KR_help01 prems s l x0 in\n          let Coq_existT (x1, _) = h0 in Coq_existT (x1, __))\n     | _ ->\n       let x0 = coq_KR_help01 prems s l x in\n       let Coq_existT (x1, _) = x0 in Coq_existT (x1, __))\n\n(** val coq_KR_help1 :\n    coq_Seq list -> (coq_MPropF list * coq_MPropF list) -> coq_Seq list\n    coq_InT -> coq_KRRule **)\n\nlet coq_KR_help1 prems s x =\n  let s0 = coq_KR_help01 prems s (top_boxes (snd s)) x in\n  let Coq_existT (x0, _) = s0 in\n  let (l, l0) = s in\n  let h = in_splitT (Box x0) l0 in\n  let Coq_existT (x1, s1) = h in\n  let Coq_existT (x2, _) = s1 in\n  KRRule_I (x0, (top_boxes l), l, x1, x2, (top_boxes_nobox_gen_ext l))\n\n(** val coq_KR_help02 :\n    coq_MPropF list -> coq_MPropF list -> coq_MPropF list -> coq_MPropF list\n    -> coq_MPropF -> coq_MPropF list -> coq_KRRule -> nobox_gen_ext ->\n    (coq_MPropF list * coq_MPropF list) list coq_InT **)\n\nlet rec coq_KR_help02 _UU0393_ _UU0394_0 _UU0394_1 b_UU0393_ a l x x0 =\n  match l with\n  | [] -> assert false (* absurd case *)\n  | y :: l0 ->\n    (match y with\n     | Box m ->\n       let h1 =\n         let h0 = in_splitT (Box a) ((Box m) :: l0) in\n         let Coq_existT (x1, s) = h0 in\n         let Coq_existT (x2, _) = s in\n         coq_InT_or_app x1 ((Box a) :: x2) (Box a) (Coq_inr\n           (coq_InT_eq (Box a) x2))\n       in\n       (match h1 with\n        | InT_eq' (_, _) ->\n          coq_InT_eq (((unboxed_list (top_boxes _UU0393_)), (a :: [])) :: [])\n            (prems_Box_R l0 (_UU0393_,\n              (app _UU0394_0 ((Box a) :: _UU0394_1))))\n        | InT_cons (_, _, _) ->\n          let i =\n            coq_KR_help02 _UU0393_ _UU0394_0 _UU0394_1 b_UU0393_ a l0 x x0\n          in\n          InT_cons ((((unboxed_list (top_boxes _UU0393_)), (m :: [])) :: []),\n          (prems_Box_R l0 (_UU0393_, (app _UU0394_0 ((Box a) :: _UU0394_1)))),\n          i))\n     | x1 ->\n       let h1 =\n         let h0 = in_splitT (Box a) (x1 :: l0) in\n         let Coq_existT (x2, s) = h0 in\n         let Coq_existT (x3, _) = s in\n         coq_InT_or_app x2 ((Box a) :: x3) (Box a) (Coq_inr\n           (coq_InT_eq (Box a) x3))\n       in\n       (match h1 with\n        | InT_eq' (_, _) -> assert false (* absurd case *)\n        | InT_cons (_, _, _) ->\n          coq_KR_help02 _UU0393_ _UU0394_0 _UU0394_1 b_UU0393_ a l0 x x0))\n\n(** val coq_KR_help2 :\n    coq_Seq -> coq_Seq -> coq_KRRule -> coq_Seq list coq_InT **)\n\nlet coq_KR_help2 _ _ x = match x with\n| KRRule_I (a, b_UU0393_, _UU0393_0, _UU0394_0, _UU0394_1, x0) ->\n  coq_KR_help02 _UU0393_0 _UU0394_0 _UU0394_1 b_UU0393_ a\n    (top_boxes (app _UU0394_0 ((Box a) :: _UU0394_1))) x x0\n\n(** val finite_KR_premises_of_S :\n    coq_Seq -> (coq_Seq list list, coq_Seq list -> (coq_KRRule -> coq_Seq\n    list coq_InT) * (coq_Seq list coq_InT -> coq_KRRule)) sigT **)\n\nlet finite_KR_premises_of_S = function\n| (l, l0) ->\n  Coq_existT ((prems_Box_R (top_boxes l0) (l, l0)), (fun prems -> ((fun x ->\n    let KRRule_I (a, b_UU0393_, _, _UU0394_0, _UU0394_1, _) = x in\n    coq_KR_help2 ((unboxed_list b_UU0393_), (a :: [])) (l,\n      (app _UU0394_0 ((Box a) :: _UU0394_1))) x), (fun h ->\n    coq_KR_help1 prems (l, l0) h))))\n","open Datatypes\nopen Environments\nopen Formulas\nopen List\nopen Order\nopen Base\nopen List0\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val e_rule :\n    variable -> form list -> form -> (pointed_env -> __ -> form * form) ->\n    form -> form **)\n\nlet e_rule p _UU0394_ _UU03d5_ eA0 _UU03b8_ =\n  let e = fun _UU0394_0 -> fst (eA0 (_UU0394_0, _UU03d5_) __) in\n  let a = fun pe0 -> snd (eA0 pe0 __) in\n  let _UU0394_' = rm _UU03b8_ _UU0394_ in\n  (match _UU03b8_ with\n   | Var q ->\n     if decide (decide_rel string_dec p q) then Implies (Bot, Bot) else Var q\n   | Bot -> Bot\n   | And (_UU03b4__UU2081_, _UU03b4__UU2082_) ->\n     e (_UU03b4__UU2082_ :: (_UU03b4__UU2081_ :: _UU0394_'))\n   | Or (_UU03b4__UU2081_, _UU03b4__UU2082_) ->\n     make_disj (e (_UU03b4__UU2081_ :: _UU0394_'))\n       (e (_UU03b4__UU2082_ :: _UU0394_'))\n   | Implies (f, _UU03b4_2) ->\n     (match f with\n      | Var q ->\n        if decide (decide_rel (elem_of_list_dec form_eq_dec) (Var q) _UU0394_)\n        then e (_UU03b4_2 :: _UU0394_')\n        else if decide (decide_rel string_dec p q)\n             then Implies (Bot, Bot)\n             else make_impl (Var q) (e (_UU03b4_2 :: _UU0394_'))\n      | Bot -> Implies (Bot, Bot)\n      | And (_UU03b4__UU2081_, _UU03b4__UU2082_) ->\n        e ((Implies (_UU03b4__UU2081_, (Implies (_UU03b4__UU2082_,\n          _UU03b4_2)))) :: _UU0394_')\n      | Or (_UU03b4__UU2081_, _UU03b4__UU2082_) ->\n        e ((Implies (_UU03b4__UU2082_, _UU03b4_2)) :: ((Implies\n          (_UU03b4__UU2081_, _UU03b4_2)) :: _UU0394_'))\n      | Implies (_UU03b4__UU2081_, _UU03b4__UU2082_) ->\n        make_impl\n          (make_impl\n            (e (_UU03b4__UU2081_ :: ((Implies (_UU03b4__UU2082_,\n              _UU03b4_2)) :: _UU0394_')))\n            (a ((_UU03b4__UU2081_ :: ((Implies (_UU03b4__UU2082_,\n              _UU03b4_2)) :: _UU0394_')), _UU03b4__UU2082_)))\n          (e (_UU03b4_2 :: _UU0394_'))\n      | Box _UU03b4_1 ->\n        make_impl (Box\n          (make_impl\n            (e ((Box _UU03b4_1) :: (_UU03b4_2 :: (map open_box _UU0394_'))))\n            (a (((Box _UU03b4_1) :: (_UU03b4_2 :: (map open_box _UU0394_'))),\n              _UU03b4_1)))) (e (_UU03b4_2 :: _UU0394_')))\n   | Box _UU03c6_ -> Box (e (_UU03c6_ :: (map open_box _UU0394_'))))\n\n(** val a_rule_env :\n    variable -> form list -> form -> (pointed_env -> __ -> form * form) ->\n    form -> form **)\n\nlet a_rule_env p _UU0394_ _UU03d5_ eA0 _UU03b8_ =\n  let e = fun _UU0394_0 -> fst (eA0 (_UU0394_0, _UU03d5_) __) in\n  let a = fun pe0 -> snd (eA0 pe0 __) in\n  let _UU0394_' = rm _UU03b8_ _UU0394_ in\n  (match _UU03b8_ with\n   | Var q ->\n     if decide (decide_rel string_dec p q)\n     then if decide (decide_rel form_eq_dec (Var p) _UU03d5_)\n          then Implies (Bot, Bot)\n          else Bot\n     else Bot\n   | And (_UU03b4__UU2081_, _UU03b4__UU2082_) ->\n     a ((_UU03b4__UU2082_ :: (_UU03b4__UU2081_ :: _UU0394_')), _UU03d5_)\n   | Or (_UU03b4__UU2081_, _UU03b4__UU2082_) ->\n     make_conj\n       (make_impl (e (_UU03b4__UU2081_ :: _UU0394_'))\n         (a ((_UU03b4__UU2081_ :: _UU0394_'), _UU03d5_)))\n       (make_impl (e (_UU03b4__UU2082_ :: _UU0394_'))\n         (a ((_UU03b4__UU2082_ :: _UU0394_'), _UU03d5_)))\n   | Implies (f, _UU03b4_2) ->\n     (match f with\n      | Var q ->\n        if decide (decide_rel (elem_of_list_dec form_eq_dec) (Var q) _UU0394_)\n        then a ((_UU03b4_2 :: _UU0394_'), _UU03d5_)\n        else if decide (decide_rel string_dec p q)\n             then Bot\n             else make_conj (Var q) (a ((_UU03b4_2 :: _UU0394_'), _UU03d5_))\n      | Bot -> Bot\n      | And (_UU03b4__UU2081_, _UU03b4__UU2082_) ->\n        a (((Implies (_UU03b4__UU2081_, (Implies (_UU03b4__UU2082_,\n          _UU03b4_2)))) :: _UU0394_'), _UU03d5_)\n      | Or (_UU03b4__UU2081_, _UU03b4__UU2082_) ->\n        a (((Implies (_UU03b4__UU2082_, _UU03b4_2)) :: ((Implies\n          (_UU03b4__UU2081_, _UU03b4_2)) :: _UU0394_')), _UU03d5_)\n      | Implies (_UU03b4__UU2081_, _UU03b4__UU2082_) ->\n        make_conj\n          (make_impl\n            (e (_UU03b4__UU2081_ :: ((Implies (_UU03b4__UU2082_,\n              _UU03b4_2)) :: _UU0394_')))\n            (a ((_UU03b4__UU2081_ :: ((Implies (_UU03b4__UU2082_,\n              _UU03b4_2)) :: _UU0394_')), _UU03b4__UU2082_)))\n          (a ((_UU03b4_2 :: _UU0394_'), _UU03d5_))\n      | Box _UU03b4_1 ->\n        And ((Box\n          (make_impl\n            (e ((Box _UU03b4_1) :: (_UU03b4_2 :: (map open_box _UU0394_'))))\n            (a (((Box _UU03b4_1) :: (_UU03b4_2 :: (map open_box _UU0394_'))),\n              _UU03b4_1)))), (a ((_UU03b4_2 :: _UU0394_'), _UU03d5_))))\n   | _ -> Bot)\n\n(** val a_rule_form :\n    variable -> form list -> form -> (pointed_env -> __ -> form * form) ->\n    form **)\n\nlet a_rule_form p _UU0394_ _UU03d5_ eA0 =\n  let e = fun pe0 -> fst (eA0 pe0 __) in\n  let a = fun pe0 -> snd (eA0 pe0 __) in\n  (match _UU03d5_ with\n   | Var q -> if decide (decide_rel string_dec p q) then Bot else Var q\n   | Bot -> Bot\n   | And (_UU03d5__UU2081_, _UU03d5__UU2082_) ->\n     make_conj (a (_UU0394_, _UU03d5__UU2081_))\n       (a (_UU0394_, _UU03d5__UU2082_))\n   | Or (_UU03d5__UU2081_, _UU03d5__UU2082_) ->\n     make_disj (a (_UU0394_, _UU03d5__UU2081_))\n       (a (_UU0394_, _UU03d5__UU2082_))\n   | Implies (_UU03d5__UU2081_, _UU03d5__UU2082_) ->\n     make_impl (e ((_UU03d5__UU2081_ :: _UU0394_), _UU03d5__UU2082_))\n       (a ((_UU03d5__UU2081_ :: _UU0394_), _UU03d5__UU2082_))\n   | Box _UU03b4_ ->\n     Box\n       (make_impl (e (((Box _UU03b4_) :: (map open_box _UU0394_)), _UU03b4_))\n         (a (((Box _UU03b4_) :: (map open_box _UU0394_)), _UU03b4_))))\n\n(** val coq_EA : variable -> (form list * form) -> form * form **)\n\nlet rec coq_EA p x =\n  let _UU0394_ = fst x in\n  ((conjunction\n     (in_map _UU0394_ (fun x0 _ ->\n       e_rule p (fst x) (snd x) (fun pe _ -> coq_EA p pe) x0))),\n  (make_disj\n    (disjunction\n      (in_map _UU0394_ (fun x0 _ ->\n        a_rule_env p (fst x) (snd x) (fun pe _ -> coq_EA p pe) x0)))\n    (a_rule_form p (fst x) (snd x) (fun pe _ -> coq_EA p pe))))\n\n(** val coq_E : variable -> (form list * form) -> form **)\n\nlet coq_E p pe =\n  fst (coq_EA p pe)\n\n(** val coq_A : variable -> (form list * form) -> form **)\n\nlet coq_A p pe =\n  snd (coq_EA p pe)\n\n(** val coq_Ef : variable -> form -> form **)\n\nlet coq_Ef p _UU03c8_ =\n  coq_E p ((_UU03c8_ :: []), Bot)\n\n(** val coq_Af : variable -> form -> form **)\n\nlet coq_Af p _UU03c8_ =\n  coq_A p ([], _UU03c8_)\n","open Datatypes\nopen Environments\nopen Formulas\nopen PropQuantifiers\nopen Base\nopen Numbers\n\n(** val simp_ors : form -> form -> form **)\n\nlet rec simp_ors _UU03c6_ _UU03c8_ =\n  match _UU03c6_ with\n  | Or (_UU03c6_1, _UU03c6_2) ->\n    (match _UU03c8_ with\n     | Or (_UU03c8_1, _UU03c8_2) ->\n       make_disj _UU03c6_1\n         (make_disj _UU03c8_1 (simp_ors _UU03c6_2 _UU03c8_2))\n     | _ -> make_disj _UU03c8_ (Or (_UU03c6_1, _UU03c6_2)))\n  | _ ->\n    (match _UU03c8_ with\n     | Or (_UU03c8_1, _UU03c8_2) ->\n       make_disj _UU03c6_ (Or (_UU03c8_1, _UU03c8_2))\n     | _ -> make_disj _UU03c6_ _UU03c8_)\n\n(** val simp_ands : form -> form -> form **)\n\nlet rec simp_ands _UU03c6_ _UU03c8_ =\n  match _UU03c6_ with\n  | And (_UU03c6_1, _UU03c6_2) ->\n    (match _UU03c8_ with\n     | And (_UU03c8_1, _UU03c8_2) ->\n       make_conj _UU03c6_1\n         (make_conj _UU03c8_1 (simp_ands _UU03c6_2 _UU03c8_2))\n     | _ -> make_conj _UU03c8_ (And (_UU03c6_1, _UU03c6_2)))\n  | _ ->\n    (match _UU03c8_ with\n     | And (_UU03c8_1, _UU03c8_2) ->\n       make_conj _UU03c6_ (And (_UU03c8_1, _UU03c8_2))\n     | _ -> make_conj _UU03c6_ _UU03c8_)\n\n(** val simp_imp : form -> form -> form **)\n\nlet simp_imp _UU03c6_ _UU03c8_ =\n  if decide\n       (decide_rel comparison_eq_dec (obviously_smaller _UU03c6_ _UU03c8_) Lt)\n  then top form_top\n  else if decide\n            (decide_rel comparison_eq_dec\n              (obviously_smaller _UU03c6_ (bottom fomula_bottom)) Lt)\n       then top form_top\n       else if decide\n                 (decide_rel comparison_eq_dec\n                   (obviously_smaller _UU03c8_ (top form_top)) Gt)\n            then top form_top\n            else if decide\n                      (decide_rel comparison_eq_dec\n                        (obviously_smaller _UU03c6_ (top form_top)) Gt)\n                 then _UU03c8_\n                 else if decide\n                           (decide_rel comparison_eq_dec\n                             (obviously_smaller _UU03c8_\n                               (bottom fomula_bottom)) Lt)\n                      then Implies (_UU03c6_, Bot)\n                      else Implies (_UU03c6_, _UU03c8_)\n\n(** val simp_imps : form -> form -> form **)\n\nlet rec simp_imps _UU03c6_ _UU03c8_ = match _UU03c8_ with\n| Implies (_UU03c8_1, _UU03c8_2) ->\n  simp_imps (simp_ands _UU03c6_ _UU03c8_1) _UU03c8_2\n| _ -> simp_imp _UU03c6_ _UU03c8_\n\n(** val simp : form -> form **)\n\nlet rec simp _UU03c6_ = match _UU03c6_ with\n| And (_UU03c6_0, _UU03c8_) -> simp_ands (simp _UU03c6_0) (simp _UU03c8_)\n| Or (_UU03c6_0, _UU03c8_) -> simp_ors (simp _UU03c6_0) (simp _UU03c8_)\n| Implies (_UU03c6_0, _UU03c8_) -> simp_imps (simp _UU03c6_0) (simp _UU03c8_)\n| Box _UU03c6_0 -> Box (simp _UU03c6_0)\n| _ -> _UU03c6_\n\n(** val coq_E_simplified : variable -> form -> form **)\n\nlet coq_E_simplified p _UU03c8_ =\n  simp (coq_E p ((_UU03c8_ :: []), (bottom fomula_bottom)))\n\n(** val coq_A_simplified : variable -> form -> form **)\n\nlet coq_A_simplified p _UU03c8_ =\n  simp (coq_Af p _UU03c8_)\n","open Datatypes\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val list_is_nil : 'a1 list -> bool **)\n\nlet list_is_nil = function\n| [] -> true\n| _ :: _ -> false\n\n(** val flatmap : ('a1 -> __ -> 'a1 list) -> 'a1 list -> 'a1 list **)\n\nlet rec flatmap f = function\n| [] -> []\n| x :: l0 -> app (f x __) (flatmap f l0)\n\n(** val irred : ('a1 -> 'a1 list) -> 'a1 -> 'a1 list **)\n\nlet rec irred f x =\n  if list_is_nil (f x) then x :: [] else flatmap (fun y _ -> irred f y) (f x)\n","open CML_Syntax\nopen Datatypes\nopen GLS_calcs\nopen GLS_der_dec\nopen List_lemmasT\nopen Specif\nopen UIGL_irred_short\nopen GenT\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val finite_ImpRules_premises_of_S :\n    coq_Seq -> (coq_Seq list list, coq_Seq list -> ((coq_ImpRRule,\n    coq_ImpLRule) sum -> coq_Seq list coq_InT) * (coq_Seq list coq_InT ->\n    (coq_ImpRRule, coq_ImpLRule) sum)) sigT **)\n\nlet finite_ImpRules_premises_of_S s =\n  let s0 = finite_ImpR_premises_of_S s in\n  let Coq_existT (x, p) = s0 in\n  let s1 = finite_ImpL_premises_of_S s in\n  let Coq_existT (x0, p0) = s1 in\n  Coq_existT ((app x x0), (fun prems -> ((fun h ->\n  match h with\n  | Coq_inl i ->\n    let ImpRRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1) = i in\n    coq_InT_or_app x x0 (((app _UU0393_0 (a :: _UU0393_1)),\n      (app _UU0394_0 (b :: _UU0394_1))) :: []) (Coq_inl\n      (let prems0 = ((app _UU0393_0 (a :: _UU0393_1)),\n         (app _UU0394_0 (b :: _UU0394_1))) :: []\n       in\n       let (x1, _) = p prems0 in\n       x1 (ImpRRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1))))\n  | Coq_inr i ->\n    let ImpLRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1) = i in\n    coq_InT_or_app x x0 (((app _UU0393_0 _UU0393_1),\n      (app _UU0394_0 (a :: _UU0394_1))) :: (((app _UU0393_0 (b :: _UU0393_1)),\n      (app _UU0394_0 _UU0394_1)) :: [])) (Coq_inr\n      (let prems0 = ((app _UU0393_0 _UU0393_1),\n         (app _UU0394_0 (a :: _UU0394_1))) :: (((app _UU0393_0\n                                                  (b :: _UU0393_1)),\n         (app _UU0394_0 _UU0394_1)) :: [])\n       in\n       let (x1, _) = p0 prems0 in\n       x1 (ImpLRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1))))),\n  (fun h ->\n  let h0 = coq_InT_app_or x x0 prems h in\n  (match h0 with\n   | Coq_inl i -> Coq_inl (let (_, x1) = p prems in x1 i)\n   | Coq_inr i -> Coq_inr (let (_, x1) = p0 prems in x1 i))))))\n\n(** val inv_prems : coq_Seq -> coq_Seq list **)\n\nlet inv_prems s =\n  flatten_list (proj1_sigT2 (finite_ImpRules_premises_of_S s))\n\n(** val coq_Canopy : coq_Seq -> coq_Seq list **)\n\nlet coq_Canopy =\n  irred inv_prems\n\n(** val is_Prime_dec : coq_MPropF list -> (__, __) sum **)\n\nlet rec is_Prime_dec = function\n| [] -> Coq_inl __\n| y :: l0 ->\n  (match is_Prime_dec l0 with\n   | Coq_inl _ -> (match y with\n                   | Imp (_, _) -> Coq_inr __\n                   | _ -> Coq_inl __)\n   | Coq_inr _ -> Coq_inr __)\n\n(** val critical_Seq_dec : coq_Seq -> (__, __) sum **)\n\nlet critical_Seq_dec = function\n| (l, l0) -> is_Prime_dec (app l l0)\n","open Datatypes\nopen GLS_calcs\nopen GLS_der_dec\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val coq_GLR_prems : coq_Seq -> coq_Seq list **)\n\nlet coq_GLR_prems s =\n  flatten_list (proj1_sigT2 (finite_GLR_premises_of_S s))\n\n(** val coq_LexSeq_ind :\n    (coq_Seq -> (coq_Seq -> __ -> 'a1) -> 'a1) -> coq_Seq -> 'a1 **)\n\nlet rec coq_LexSeq_ind x s =\n  x s (fun s1 _ -> coq_LexSeq_ind x s1)\n\n(** val empty_seq_dec : coq_Seq -> (__, __) sum **)\n\nlet empty_seq_dec = function\n| (l, l0) ->\n  (match l with\n   | [] -> (match l0 with\n            | [] -> Coq_inl __\n            | _ :: _ -> Coq_inr __)\n   | _ :: _ -> Coq_inr __)\n","open CML_Syntax\nopen Datatypes\nopen List\n\n(** val list_conj : coq_MPropF list -> coq_MPropF **)\n\nlet rec list_conj = function\n| [] -> coq_Top\n| h :: t -> coq_And h (list_conj t)\n\n(** val list_disj : coq_MPropF list -> coq_MPropF **)\n\nlet rec list_disj = function\n| [] -> Bot\n| h :: t -> coq_Or h (list_disj t)\n\n(** val list_prop_F : coq_MPropF -> coq_MPropF list **)\n\nlet list_prop_F = function\n| Var p -> (Var p) :: []\n| _ -> []\n\n(** val list_prop_LF : coq_MPropF list -> coq_MPropF list **)\n\nlet rec list_prop_LF = function\n| [] -> []\n| h :: t -> app (list_prop_F h) (list_prop_LF t)\n\n(** val restr_list_prop : char list -> coq_MPropF list -> coq_MPropF list **)\n\nlet restr_list_prop p l =\n  remove eq_dec_form (Var p) (list_prop_LF l)\n","open CML_Syntax\nopen Datatypes\nopen GLS_calcs\nopen List\n\n(** val nodupseq : coq_Seq -> coq_MPropF list * coq_MPropF list **)\n\nlet nodupseq s =\n  ((nodup eq_dec_form (fst s)), (nodup eq_dec_form (snd s)))\n","open CML_Syntax\nopen Compare_dec\nopen Datatypes\nopen GLS_calcs\nopen GLS_dec\nopen GLS_termination_measure\nopen List\nopen UIGL_Canopy\nopen UIGL_LexSeq\nopen UIGL_basics\nopen UIGL_nodupseq\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val imap : ('a1 -> __ -> 'a2) -> 'a1 list -> 'a2 list **)\n\nlet rec imap f = function\n| [] -> []\n| x :: l0 -> (f x __) :: (imap f l0)\n\n(** val coq_GUI_tot : char list -> coq_Seq -> coq_MPropF **)\n\nlet coq_GUI_tot p =\n  coq_LexSeq_ind (fun s iH ->\n    let s0 = empty_seq_dec s in\n    (match s0 with\n     | Coq_inl _ -> Bot\n     | Coq_inr _ ->\n       let s1 = critical_Seq_dec s in\n       (match s1 with\n        | Coq_inl _ ->\n          let s2 = dec_init_rules s in\n          (match s2 with\n           | Coq_inl _ -> coq_Top\n           | Coq_inr _ ->\n             let h0 = fun x -> iH x __ in\n             let s3 = fun _ ->\n               imap (fun x _ -> h0 x) (coq_GLR_prems (nodupseq s))\n             in\n             let s4 = s3 __ in\n             let j10 = fun z ->\n               let s5 = dec_init_rules z in\n               (match s5 with\n                | Coq_inl _ -> coq_Top\n                | Coq_inr _ ->\n                  let s6 =\n                    lt_dec (length (usable_boxes z)) (length (usable_boxes s))\n                  in\n                  if s6\n                  then iH z __\n                  else let j100 = fun x0 -> iH x0 __ in\n                       let s7 = fun _ ->\n                         imap (fun x0 _ -> j100 x0)\n                           (coq_GLR_prems (nodupseq z))\n                       in\n                       let s8 = s7 __ in\n                       coq_Or (list_disj (restr_list_prop p (snd z)))\n                         (coq_Or\n                           (list_disj\n                             (map coq_Neg (restr_list_prop p (fst z))))\n                           (list_disj (map (fun x -> Box x) s8))))\n             in\n             let s5 = fun _ ->\n               imap (fun z _ -> j10 z)\n                 (coq_Canopy\n                   (nodupseq ((coq_XBoxed_list (top_boxes (fst s))), [])))\n             in\n             let s6 = s5 __ in\n             coq_Or (list_disj (restr_list_prop p (snd s)))\n               (coq_Or (list_disj (map coq_Neg (restr_list_prop p (fst s))))\n                 (coq_Or (list_disj (map (fun x -> Box x) s4))\n                   (coq_Diam (list_conj s6)))))\n        | Coq_inr _ ->\n          let h = fun x -> iH x __ in\n          let s2 = fun _ -> imap (fun x _ -> h x) (coq_Canopy (nodupseq s)) in\n          let s3 = s2 __ in list_conj s3)))\n","open Datatypes\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val list_is_nil : 'a1 list -> bool **)\n\nlet list_is_nil = function\n| [] -> true\n| _ :: _ -> false\n\n(** val flatmap : ('a1 -> __ -> 'a1 list) -> 'a1 list -> 'a1 list **)\n\nlet rec flatmap f = function\n| [] -> []\n| x :: l0 -> app (f x __) (flatmap f l0)\n\n(** val irred : ('a1 -> 'a1 list) -> 'a1 -> 'a1 list **)\n\nlet rec irred f x =\n  if list_is_nil (f x) then x :: [] else flatmap (fun y _ -> irred f y) (f x)\n","open CML_Syntax\nopen Datatypes\nopen KS_calc\nopen KS_termination_ImpL\nopen KS_termination_ImpR\nopen KS_termination_prelims\nopen List_lemmasT\nopen Specif\nopen UIK_irred_short\nopen GenT\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val finite_ImpRules_premises_of_S :\n    coq_Seq -> (coq_Seq list list, coq_Seq list -> ((coq_ImpRRule,\n    coq_ImpLRule) sum -> coq_Seq list coq_InT) * (coq_Seq list coq_InT ->\n    (coq_ImpRRule, coq_ImpLRule) sum)) sigT **)\n\nlet finite_ImpRules_premises_of_S s =\n  let s0 = finite_ImpR_premises_of_S s in\n  let Coq_existT (x, p) = s0 in\n  let s1 = finite_ImpL_premises_of_S s in\n  let Coq_existT (x0, p0) = s1 in\n  Coq_existT ((app x x0), (fun prems -> ((fun h ->\n  match h with\n  | Coq_inl i ->\n    let ImpRRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1) = i in\n    coq_InT_or_app x x0 (((app _UU0393_0 (a :: _UU0393_1)),\n      (app _UU0394_0 (b :: _UU0394_1))) :: []) (Coq_inl\n      (let prems0 = ((app _UU0393_0 (a :: _UU0393_1)),\n         (app _UU0394_0 (b :: _UU0394_1))) :: []\n       in\n       let (x1, _) = p prems0 in\n       x1 (ImpRRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1))))\n  | Coq_inr i ->\n    let ImpLRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1) = i in\n    coq_InT_or_app x x0 (((app _UU0393_0 _UU0393_1),\n      (app _UU0394_0 (a :: _UU0394_1))) :: (((app _UU0393_0 (b :: _UU0393_1)),\n      (app _UU0394_0 _UU0394_1)) :: [])) (Coq_inr\n      (let prems0 = ((app _UU0393_0 _UU0393_1),\n         (app _UU0394_0 (a :: _UU0394_1))) :: (((app _UU0393_0\n                                                  (b :: _UU0393_1)),\n         (app _UU0394_0 _UU0394_1)) :: [])\n       in\n       let (x1, _) = p0 prems0 in\n       x1 (ImpLRule_I (a, b, _UU0393_0, _UU0393_1, _UU0394_0, _UU0394_1))))),\n  (fun h ->\n  let h0 = coq_InT_app_or x x0 prems h in\n  (match h0 with\n   | Coq_inl i -> Coq_inl (let (_, x1) = p prems in x1 i)\n   | Coq_inr i -> Coq_inr (let (_, x1) = p0 prems in x1 i))))))\n\n(** val inv_prems : coq_Seq -> coq_Seq list **)\n\nlet inv_prems s =\n  flatten_list (proj1_sigT2 (finite_ImpRules_premises_of_S s))\n\n(** val coq_Canopy : coq_Seq -> coq_Seq list **)\n\nlet coq_Canopy =\n  irred inv_prems\n\n(** val is_Prime_dec : coq_MPropF list -> (__, __) sum **)\n\nlet rec is_Prime_dec = function\n| [] -> Coq_inl __\n| y :: l0 ->\n  (match is_Prime_dec l0 with\n   | Coq_inl _ -> (match y with\n                   | Imp (_, _) -> Coq_inr __\n                   | _ -> Coq_inl __)\n   | Coq_inr _ -> Coq_inr __)\n\n(** val critical_Seq_dec : coq_Seq -> (__, __) sum **)\n\nlet critical_Seq_dec = function\n| (l, l0) -> is_Prime_dec (app l l0)\n","open CML_Syntax\nopen Datatypes\nopen KS_calc\nopen KS_termination_KR\nopen KS_termination_prelims\nopen List\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val list_conj : coq_MPropF list -> coq_MPropF **)\n\nlet rec list_conj = function\n| [] -> coq_Top\n| h :: t -> coq_And h (list_conj t)\n\n(** val list_disj : coq_MPropF list -> coq_MPropF **)\n\nlet rec list_disj = function\n| [] -> Bot\n| h :: t -> coq_Or h (list_disj t)\n\n(** val list_prop_F : coq_MPropF -> coq_MPropF list **)\n\nlet list_prop_F = function\n| Var p -> (Var p) :: []\n| _ -> []\n\n(** val list_prop_LF : coq_MPropF list -> coq_MPropF list **)\n\nlet rec list_prop_LF = function\n| [] -> []\n| h :: t -> app (list_prop_F h) (list_prop_LF t)\n\n(** val restr_list_prop : char list -> coq_MPropF list -> coq_MPropF list **)\n\nlet restr_list_prop p l =\n  remove eq_dec_form (Var p) (list_prop_LF l)\n\n(** val coq_KR_prems : coq_Seq -> coq_Seq list **)\n\nlet coq_KR_prems s =\n  flatten_list (proj1_sigT2 (finite_KR_premises_of_S s))\n\n(** val coq_LtSeq_ind :\n    (coq_Seq -> (coq_Seq -> __ -> 'a1) -> 'a1) -> coq_Seq -> 'a1 **)\n\nlet rec coq_LtSeq_ind x s =\n  x s (fun s1 _ -> coq_LtSeq_ind x s1)\n\n(** val empty_seq_dec : coq_Seq -> (__, __) sum **)\n\nlet empty_seq_dec = function\n| (l, l0) ->\n  (match l with\n   | [] -> (match l0 with\n            | [] -> Coq_inl __\n            | _ :: _ -> Coq_inr __)\n   | _ :: _ -> Coq_inr __)\n","open CML_Syntax\nopen Datatypes\nopen KS_calc\nopen KS_dec\nopen List\nopen UIK_Canopy\nopen UIK_basics\nopen List_lems\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val imap : ('a1 -> __ -> 'a2) -> 'a1 list -> 'a2 list **)\n\nlet rec imap f = function\n| [] -> []\n| x :: l0 -> (f x __) :: (imap f l0)\n\n(** val coq_GUI_tot : char list -> coq_Seq -> coq_MPropF **)\n\nlet coq_GUI_tot p =\n  coq_LtSeq_ind (fun s iH ->\n    let s0 = empty_seq_dec s in\n    (match s0 with\n     | Coq_inl _ -> Bot\n     | Coq_inr _ ->\n       let s1 = critical_Seq_dec s in\n       (match s1 with\n        | Coq_inl _ ->\n          let s2 = dec_KS_init_rules s in\n          (match s2 with\n           | Coq_inl _ -> coq_Top\n           | Coq_inr _ ->\n             let h0 = fun x -> iH x __ in\n             let s3 = fun _ -> imap (fun x _ -> h0 x) (coq_KR_prems s) in\n             let s4 = s3 __ in\n             let s5 = eq_dec_listsF (fst s) [] in\n             if s5\n             then coq_Or (list_disj (restr_list_prop p (snd s)))\n                    (coq_Or\n                      (list_disj (map coq_Neg (restr_list_prop p (fst s))))\n                      (coq_Or (list_disj (map (fun x -> Box x) s4))\n                        (coq_Diam Bot)))\n             else let j10 = iH ((unboxed_list (top_boxes (fst s))), []) __ in\n                  coq_Or (list_disj (restr_list_prop p (snd s)))\n                    (coq_Or\n                      (list_disj (map coq_Neg (restr_list_prop p (fst s))))\n                      (coq_Or (list_disj (map (fun x -> Box x) s4))\n                        (coq_Diam j10))))\n        | Coq_inr _ ->\n          let h = fun x -> iH x __ in\n          let s2 = fun _ -> imap (fun x _ -> h x) (coq_Canopy s) in\n          let s3 = s2 __ in list_conj s3)))\n","open CML_Syntax\nopen Formulas\nopen PropQuantifiers\nopen Simp\nopen UIGL_braga\nopen UIK_braga\n\n(** val coq_MPropF_of_form : form -> coq_MPropF **)\n\nlet rec coq_MPropF_of_form = function\n| Var n -> CML_Syntax.Var n\n| Bot -> CML_Syntax.Bot\n| And (f1, f2) ->\n  Imp ((Imp ((coq_MPropF_of_form f1), (Imp ((coq_MPropF_of_form f2),\n    CML_Syntax.Bot)))), CML_Syntax.Bot)\n| Or (f1, f2) ->\n  Imp ((Imp ((coq_MPropF_of_form f1), CML_Syntax.Bot)),\n    (coq_MPropF_of_form f2))\n| Implies (f1, f2) -> Imp ((coq_MPropF_of_form f1), (coq_MPropF_of_form f2))\n| Box f0 -> CML_Syntax.Box (coq_MPropF_of_form f0)\n\n(** val form_of_MPropF : coq_MPropF -> form **)\n\nlet rec form_of_MPropF = function\n| CML_Syntax.Var n -> Var n\n| CML_Syntax.Bot -> Bot\n| Imp (f1, f2) -> Implies ((form_of_MPropF f1), (form_of_MPropF f2))\n| CML_Syntax.Box f0 -> Box (form_of_MPropF f0)\n\n(** val gl_UI : char list -> form -> form **)\n\nlet gl_UI p s =\n  form_of_MPropF\n    (UIGL_braga.coq_GUI_tot p ([], ((coq_MPropF_of_form s) :: [])))\n\n(** val k_UI : char list -> form -> form **)\n\nlet k_UI p s =\n  form_of_MPropF (coq_GUI_tot p ([], ((coq_MPropF_of_form s) :: [])))\n\n(** val isl_E : variable -> form -> form **)\n\nlet isl_E =\n  coq_Ef\n\n(** val isl_A : variable -> form -> form **)\n\nlet isl_A =\n  coq_Af\n\n(** val isl_simp : form -> form **)\n\nlet isl_simp =\n  simp\n\n(** val isl_simplified_E : variable -> form -> form **)\n\nlet isl_simplified_E =\n  coq_E_simplified\n\n(** val isl_simplified_A : variable -> form -> form **)\n\nlet isl_simplified_A =\n  coq_A_simplified\n","open Datatypes\nopen Environments\nopen Formulas\nopen List\nopen Specif\nopen Base\nopen List0\n\ntype __ = Obj.t\nlet __ = let rec f _ = Obj.repr f in Obj.repr f\n\n(** val exists_dec : ('a1 -> bool) -> 'a1 list -> ('a1, __) sigT option **)\n\nlet rec exists_dec p = function\n| [] -> None\n| y :: l0 ->\n  if p y\n  then Some (Coq_existT (y, __))\n  else (match exists_dec p l0 with\n        | Some s -> let Coq_existT (x, _) = s in Some (Coq_existT (x, __))\n        | None -> None)\n\n(** val coq_Provable_dec : form list -> form -> (__, __) sum **)\n\nlet coq_Provable_dec _UU0393_ _UU03c6_ =\n  let pe = (_UU0393_, _UU03c6_) in\n  let rec f = function\n  | (l, f0) ->\n    let hind' = fun _UU0393_' _UU03c6_' -> f (_UU0393_', _UU03c6_') in\n    if decide (decide_rel (elem_of_list_dec form_eq_dec) Bot l)\n    then Coq_inl __\n    else let hAndR =\n           match f0 with\n           | Var _ -> None\n           | Bot -> None\n           | And (f1, f2) -> Some (Coq_existT (f1, (Coq_existT (f2, __))))\n           | _ -> None\n         in\n         (match hAndR with\n          | Some s ->\n            let Coq_existT (x0, s0) = s in\n            let Coq_existT (x1, _) = s0 in\n            let s1 = hind' l x0 in\n            (match s1 with\n             | Coq_inl _ ->\n               let s2 = hind' l x1 in\n               (match s2 with\n                | Coq_inl _ -> Coq_inl __\n                | Coq_inr _ -> Coq_inr __)\n             | Coq_inr _ -> Coq_inr __)\n          | None ->\n            let hvar =\n              match f0 with\n              | Var v ->\n                if decide\n                     (decide_rel (elem_of_list_dec form_eq_dec) (Var v) l)\n                then Some (Coq_existT2 (v, __, __))\n                else None\n              | _ -> None\n            in\n            (match hvar with\n             | Some _ -> Coq_inl __\n             | None ->\n               let hAndL =\n                 let fA = fun _UU03b8_ ->\n                   match _UU03b8_ with\n                   | And (_, _) -> true\n                   | _ -> false\n                 in\n                 let s = exists_dec fA l in\n                 (match s with\n                  | Some s0 ->\n                    let Coq_existT (x0, _) = s0 in\n                    Some\n                    (match x0 with\n                     | And (f1, f2) -> Coq_existT (f1, (Coq_existT (f2, __)))\n                     | _ -> assert false (* absurd case *))\n                  | None -> None)\n               in\n               (match hAndL with\n                | Some s ->\n                  let Coq_existT (x0, s0) = s in\n                  let Coq_existT (x1, _) = s0 in\n                  let s1 = hind' (x0 :: (x1 :: (rm (And (x0, x1)) l))) f0 in\n                  (match s1 with\n                   | Coq_inl _ -> Coq_inl __\n                   | Coq_inr _ -> Coq_inr __)\n                | None ->\n                  let hImpR =\n                    match f0 with\n                    | Var _ -> None\n                    | Bot -> None\n                    | And (_, _) -> None\n                    | Or (_, _) -> None\n                    | Implies (f1, f2) ->\n                      Some (Coq_existT (f1, (Coq_existT (f2, __))))\n                    | Box _ -> None\n                  in\n                  (match hImpR with\n                   | Some s ->\n                     let Coq_existT (x0, s0) = s in\n                     let Coq_existT (x1, _) = s0 in\n                     let s1 = hind' (x0 :: l) x1 in\n                     (match s1 with\n                      | Coq_inl _ -> Coq_inl __\n                      | Coq_inr _ -> Coq_inr __)\n                   | None ->\n                     let hOrL =\n                       let fA = fun _UU03b8_ ->\n                         match _UU03b8_ with\n                         | Or (_, _) -> true\n                         | _ -> false\n                       in\n                       let s = exists_dec fA l in\n                       (match s with\n                        | Some s0 ->\n                          let Coq_existT (x0, _) = s0 in\n                          Some\n                          (match x0 with\n                           | Or (f1, f2) ->\n                             Coq_existT (f1, (Coq_existT (f2, __)))\n                           | _ -> assert false (* absurd case *))\n                        | None -> None)\n                     in\n                     (match hOrL with\n                      | Some s ->\n                        let Coq_existT (x0, s0) = s in\n                        let Coq_existT (x1, _) = s0 in\n                        let s1 = hind' (x0 :: (rm (Or (x0, x1)) l)) f0 in\n                        (match s1 with\n                         | Coq_inl _ ->\n                           let s2 = hind' (x1 :: (rm (Or (x0, x1)) l)) f0 in\n                           (match s2 with\n                            | Coq_inl _ -> Coq_inl __\n                            | Coq_inr _ -> Coq_inr __)\n                         | Coq_inr _ -> Coq_inr __)\n                      | None ->\n                        let hImpLVar =\n                          let fIp = fun p _UU03b8_ ->\n                            match _UU03b8_ with\n                            | Implies (f1, _) ->\n                              (match f1 with\n                               | Var q ->\n                                 if decide (decide_rel string_dec p q)\n                                 then true\n                                 else false\n                               | _ -> false)\n                            | _ -> false\n                          in\n                          let fp = fun _UU03b8_ ->\n                            match _UU03b8_ with\n                            | Var p ->\n                              (match exists_dec (fIp p) l with\n                               | Some _ -> true\n                               | None -> false)\n                            | _ -> false\n                          in\n                          let s = exists_dec fp l in\n                          (match s with\n                           | Some s0 ->\n                             let Coq_existT (x0, _) = s0 in\n                             Some\n                             (match x0 with\n                              | Var v ->\n                                let s1 = exists_dec (fIp v) l in\n                                (match s1 with\n                                 | Some s2 ->\n                                   let Coq_existT (x1, _) = s2 in\n                                   (match x1 with\n                                    | Implies (f1, f2) ->\n                                      (match f1 with\n                                       | Var v0 ->\n                                         let s3 =\n                                           decide (decide_rel string_dec v v0)\n                                         in\n                                         if s3\n                                         then Coq_existT (v0, (Coq_existT\n                                                (f2, __)))\n                                         else assert false (* absurd case *)\n                                       | _ -> assert false (* absurd case *))\n                                    | _ -> assert false (* absurd case *))\n                                 | None -> assert false (* absurd case *))\n                              | _ -> assert false (* absurd case *))\n                           | None -> None)\n                        in\n                        (match hImpLVar with\n                         | Some s ->\n                           let Coq_existT (x0, s0) = s in\n                           let Coq_existT (x1, _) = s0 in\n                           let s1 =\n                             hind' (x1 :: (rm (Implies ((Var x0), x1)) l)) f0\n                           in\n                           (match s1 with\n                            | Coq_inl _ -> Coq_inl __\n                            | Coq_inr _ -> Coq_inr __)\n                         | None ->\n                           let hImpLAnd =\n                             let fII = fun _UU03b8_ ->\n                               match _UU03b8_ with\n                               | Implies (f1, _) ->\n                                 (match f1 with\n                                  | And (_, _) -> true\n                                  | _ -> false)\n                               | _ -> false\n                             in\n                             let s = exists_dec fII l in\n                             (match s with\n                              | Some s0 ->\n                                let Coq_existT (x0, _) = s0 in\n                                Some\n                                (match x0 with\n                                 | Implies (f1, f2) ->\n                                   (match f1 with\n                                    | And (f3, f4) ->\n                                      Coq_existT (f3, (Coq_existT (f4,\n                                        (Coq_existT (f2, __)))))\n                                    | _ -> assert false (* absurd case *))\n                                 | _ -> assert false (* absurd case *))\n                              | None -> None)\n                           in\n                           (match hImpLAnd with\n                            | Some s ->\n                              let Coq_existT (x0, s0) = s in\n                              let Coq_existT (x1, s1) = s0 in\n                              let Coq_existT (x2, _) = s1 in\n                              let s2 =\n                                hind' ((Implies (x0, (Implies (x1,\n                                  x2)))) :: (rm (Implies ((And (x0, x1)),\n                                              x2)) l)) f0\n                              in\n                              (match s2 with\n                               | Coq_inl _ -> Coq_inl __\n                               | Coq_inr _ -> Coq_inr __)\n                            | None ->\n                              let hImpLOr =\n                                let fII = fun _UU03b8_ ->\n                                  match _UU03b8_ with\n                                  | Implies (f1, _) ->\n                                    (match f1 with\n                                     | Or (_, _) -> true\n                                     | _ -> false)\n                                  | _ -> false\n                                in\n                                let s = exists_dec fII l in\n                                (match s with\n                                 | Some s0 ->\n                                   let Coq_existT (x0, _) = s0 in\n                                   Some\n                                   (match x0 with\n                                    | Implies (f1, f2) ->\n                                      (match f1 with\n                                       | Or (f3, f4) ->\n                                         Coq_existT (f3, (Coq_existT (f4,\n                                           (Coq_existT (f2, __)))))\n                                       | _ -> assert false (* absurd case *))\n                                    | _ -> assert false (* absurd case *))\n                                 | None -> None)\n                              in\n                              (match hImpLOr with\n                               | Some s ->\n                                 let Coq_existT (x0, s0) = s in\n                                 let Coq_existT (x1, s1) = s0 in\n                                 let Coq_existT (x2, _) = s1 in\n                                 let s2 =\n                                   hind' ((Implies (x1, x2)) :: ((Implies\n                                     (x0,\n                                     x2)) :: (rm (Implies ((Or (x0, x1)),\n                                               x2)) l))) f0\n                                 in\n                                 (match s2 with\n                                  | Coq_inl _ -> Coq_inl __\n                                  | Coq_inr _ -> Coq_inr __)\n                               | None ->\n                                 let hOrR1 =\n                                   match f0 with\n                                   | Var _ -> None\n                                   | Bot -> None\n                                   | And (_, _) -> None\n                                   | Or (f1, f2) ->\n                                     let s = hind' l f1 in\n                                     (match s with\n                                      | Coq_inl _ ->\n                                        Some (Coq_existT (f1, (Coq_existT\n                                          (f2, __))))\n                                      | Coq_inr _ -> None)\n                                   | _ -> None\n                                 in\n                                 (match hOrR1 with\n                                  | Some _ -> Coq_inl __\n                                  | None ->\n                                    let hOrR2 =\n                                      match f0 with\n                                      | Var _ -> None\n                                      | Bot -> None\n                                      | And (_, _) -> None\n                                      | Or (f1, f2) ->\n                                        let s = hind' l f2 in\n                                        (match s with\n                                         | Coq_inl _ ->\n                                           Some (Coq_existT (f1, (Coq_existT\n                                             (f2, __))))\n                                         | Coq_inr _ -> None)\n                                      | _ -> None\n                                    in\n                                    (match hOrR2 with\n                                     | Some _ -> Coq_inl __\n                                     | None ->\n                                       let hBoxR =\n                                         match f0 with\n                                         | Var _ -> None\n                                         | Bot -> None\n                                         | And (_, _) -> None\n                                         | Or (_, _) -> None\n                                         | Implies (_, _) -> None\n                                         | Box f1 ->\n                                           let s =\n                                             hind' ((Box\n                                               f1) :: (map open_box l)) f1\n                                           in\n                                           (match s with\n                                            | Coq_inl _ ->\n                                              Some (Coq_existT (f1, __))\n                                            | Coq_inr _ -> None)\n                                       in\n                                       (match hBoxR with\n                                        | Some _ -> Coq_inl __\n                                        | None ->\n                                          let hImpLImp =\n                                            fun _UU0393_2 _UU0393_1 ->\n                                            let rec f1 l0 _UU0393_3 =\n                                              match l0 with\n                                              | [] -> None\n                                              | y :: l1 ->\n                                                let s =\n                                                  f1 l1\n                                                    (app _UU0393_3 (y :: []))\n                                                in\n                                                (match s with\n                                                 | Some s0 ->\n                                                   let Coq_existT (x0, s1) =\n                                                     s0\n                                                   in\n                                                   let Coq_existT (x1, s2) =\n                                                     s1\n                                                   in\n                                                   let Coq_existT (x2, _) = s2\n                                                   in\n                                                   Some (Coq_existT (x0,\n                                                   (Coq_existT (x1,\n                                                   (Coq_existT (x2, __))))))\n                                                 | None ->\n                                                   (match y with\n                                                    | Implies (f2, f3) ->\n                                                      (match f2 with\n                                                       | Implies (f4, f5) ->\n                                                         let s0 =\n                                                           hind' ((Implies\n                                                             (f5,\n                                                             f3)) :: \n                                                             (rm (Implies\n                                                               ((Implies (f4,\n                                                               f5)), f3)) l))\n                                                             (Implies (f4,\n                                                             f5))\n                                                         in\n                                                         (match s0 with\n                                                          | Coq_inl _ ->\n                                                            let s1 =\n                                                              hind'\n                                                                (f3 :: \n                                                                (rm (Implies\n                                                                  ((Implies\n                                                                  (f4, f5)),\n                                                                  f3)) l)) f0\n                                                            in\n                                                            (match s1 with\n                                                             | Coq_inl _ ->\n                                                               Some\n                                                                 (Coq_existT\n                                                                 (f4,\n                                                                 (Coq_existT\n                                                                 (f5,\n                                                                 (Coq_existT\n                                                                 (f3, __))))))\n                                                             | Coq_inr _ ->\n                                                               None)\n                                                          | Coq_inr _ -> None)\n                                                       | Box _ -> None\n                                                       | _ -> None)\n                                                    | Box _ -> None\n                                                    | _ -> None))\n                                            in f1 _UU0393_2 _UU0393_1\n                                          in\n                                          let s = hImpLImp l [] in\n                                          (match s with\n                                           | Some _ -> Coq_inl __\n                                           | None ->\n                                             let hImpLBox =\n                                               fun _UU0393_2 _UU0393_1 ->\n                                               let rec f1 l0 _UU0393_3 =\n                                                 match l0 with\n                                                 | [] -> None\n                                                 | y :: l1 ->\n                                                   let s0 =\n                                                     f1 l1\n                                                       (app _UU0393_3\n                                                         (y :: []))\n                                                   in\n                                                   (match s0 with\n                                                    | Some s1 ->\n                                                      let Coq_existT (\n                                                        x0, s2) = s1\n                                                      in\n                                                      let Coq_existT (\n                                                        x1, _) = s2\n                                                      in\n                                                      Some (Coq_existT (x0,\n                                                      (Coq_existT (x1, __))))\n                                                    | None ->\n                                                      (match y with\n                                                       | Implies (f2, f3) ->\n                                                         (match f2 with\n                                                          | Box f4 ->\n                                                            let s1 =\n                                                              hind'\n                                                                (f3 :: ((Box\n                                                                f4) :: \n                                                                (map open_box\n                                                                  (rm\n                                                                    (Implies\n                                                                    ((Box\n                                                                    f4), f3))\n                                                                    l)))) f4\n                                                            in\n                                                            (match s1 with\n                                                             | Coq_inl _ ->\n                                                               let s2 =\n                                                                 hind'\n                                                                   (f3 :: \n                                                                   (rm\n                                                                    (Implies\n                                                                    ((Box\n                                                                    f4), f3))\n                                                                    l)) f0\n                                                               in\n                                                               (match s2 with\n                                                                | Coq_inl _ ->\n                                                                  Some\n                                                                    (Coq_existT\n                                                                    (f4,\n                                                                    (Coq_existT\n                                                                    (f3,\n                                                                    __))))\n                                                                | Coq_inr _ ->\n                                                                  None)\n                                                             | Coq_inr _ ->\n                                                               None)\n                                                          | _ -> None)\n                                                       | Box _ -> None\n                                                       | _ -> None))\n                                               in f1 _UU0393_2 _UU0393_1\n                                             in\n                                             let s0 = hImpLBox l [] in\n                                             (match s0 with\n                                              | Some _ -> Coq_inl __\n                                              | None -> Coq_inr __)))))))))))))\n  in f pe\n","type bigstring =\n  (char, Bigarray.int8_unsigned_elt, Bigarray.c_layout) Bigarray.Array1.t\n\ntype t = bigstring\n\nlet create size = Bigarray.(Array1.create char c_layout size)\nlet empty       = create 0\n\nmodule BA1 = Bigarray.Array1\n\nlet length t = BA1.dim t\n\nexternal get : t -> int -> char = \"%caml_ba_ref_1\"\nexternal set : t -> int -> char -> unit = \"%caml_ba_set_1\"\n\nexternal unsafe_get : t -> int -> char         = \"%caml_ba_unsafe_ref_1\"\nexternal unsafe_set : t -> int -> char -> unit = \"%caml_ba_unsafe_set_1\"\n\nexternal unsafe_blit            : t       -> src_off:int -> t       -> dst_off:int -> len:int -> unit =\n  \"bigstringaf_blit_to_bigstring\" [@@noalloc]\n\nexternal unsafe_blit_to_bytes   : t       -> src_off:int -> Bytes.t -> dst_off:int -> len:int -> unit =\n  \"bigstringaf_blit_to_bytes\"     [@@noalloc]\n\nexternal unsafe_blit_from_bytes : Bytes.t -> src_off:int -> t       -> dst_off:int -> len:int -> unit =\n  \"bigstringaf_blit_from_bytes\"   [@@noalloc]\n\nexternal unsafe_blit_from_string : string -> src_off:int -> t       -> dst_off:int -> len:int -> unit =\n  \"bigstringaf_blit_from_bytes\"   [@@noalloc]\n\nexternal unsafe_memcmp : t -> int -> t -> int -> int -> int =\n  \"bigstringaf_memcmp_bigstring\" [@@noalloc]\n\nexternal unsafe_memcmp_string : t -> int -> string -> int -> int -> int =\n  \"bigstringaf_memcmp_string\" [@@noalloc]\n\nexternal unsafe_memchr : t -> int -> char -> int -> int =\n  \"bigstringaf_memchr\" [@@noalloc]\n\nlet sub t ~off ~len =\n  BA1.sub t off len\n\nlet[@inline never] invalid_bounds op buffer_len off len =\n  let message =\n    Printf.sprintf \"Bigstringaf.%s invalid range: { buffer_len: %d, off: %d, len: %d }\"\n    op buffer_len off len\n  in\n  raise (Invalid_argument message)\n;;\n\nlet[@inline never] invalid_bounds_blit op src_len src_off dst_len dst_off len =\n  let message =\n    Printf.sprintf \"Bigstringaf.%s invalid range: { src_len: %d, src_off: %d, dst_len: %d, dst_off: %d, len: %d }\"\n    op src_len src_off dst_len dst_off len\n  in\n  raise (Invalid_argument message)\n;;\n\nlet[@inline never] invalid_bounds_memcmp op buf1_len buf1_off buf2_len buf2_off len =\n  let message =\n    Printf.sprintf \"Bigstringaf.%s invalid range: { buf1_len: %d, buf1_off: %d, buf2_len: %d, buf2_off: %d, len: %d }\"\n    op buf1_len buf1_off buf2_len buf2_off len\n  in\n  raise (Invalid_argument message)\n;;\n\n(* A note on bounds checking.\n *\n * The code should perform the following check to ensure that the blit doesn't\n * run off the end of the input buffer:\n *\n *   {[off + len <= buffer_len]}\n *\n * However, this may lead to an integer overflow for large values of [off],\n * e.g., [max_int], which will cause the comparison to return [true] when it\n * should really return [false].\n *\n * An equivalent comparison that does not run into this integer overflow\n * problem is:\n *\n *   {[buffer_len - off => len]}\n *\n * This is checking that the input buffer, less the offset, is sufficiently\n * long to perform the blit. Since the expression is subtracting [off] rather\n * than adding it, it doesn't suffer from the overflow that the previous\n * inequality did. As long as there is a check to ensure that [off] is not\n * negative, it won't underflow either. *)\n\nlet copy t ~off ~len =\n  let buffer_len = length t in\n  if len < 0 || off < 0 || buffer_len - off < len\n  then invalid_bounds \"copy\" buffer_len off len;\n  let dst = create len in\n  unsafe_blit t ~src_off:off dst ~dst_off:0 ~len;\n  dst\n;;\n\nlet substring t ~off ~len =\n  let buffer_len = length t in\n  if len < 0 || off < 0 || buffer_len - off < len\n  then invalid_bounds \"substring\" buffer_len off len;\n  let b = Bytes.create len in\n  unsafe_blit_to_bytes t ~src_off:off b ~dst_off:0 ~len;\n  Bytes.unsafe_to_string b\n;;\n\nlet to_string t =\n  let len = length t in\n  let b = Bytes.create len in\n  unsafe_blit_to_bytes t ~src_off:0 b ~dst_off:0 ~len;\n  Bytes.unsafe_to_string b\n;;\n\nlet of_string ~off ~len s =\n  let buffer_len = String.length s in\n  if len < 0 || off < 0 || buffer_len - off < len\n  then invalid_bounds \"of_string\" buffer_len off len;\n  let b = create len in\n  unsafe_blit_from_string s ~src_off:off b ~dst_off:0 ~len;\n  b\n;;\n\nlet blit src ~src_off dst ~dst_off ~len =\n  let src_len = length src in\n  let dst_len = length dst in\n  if len < 0\n  then invalid_bounds_blit \"blit\" src_len src_off dst_len dst_off len;\n  if src_off < 0 || src_len - src_off < len\n  then invalid_bounds_blit \"blit\" src_len src_off dst_len dst_off len;\n  if dst_off < 0 || dst_len - dst_off < len\n  then invalid_bounds_blit \"blit\" src_len src_off dst_len dst_off len;\n  unsafe_blit src ~src_off dst ~dst_off ~len\n;;\n\nlet blit_from_string src ~src_off dst ~dst_off ~len =\n  let src_len = String.length src in\n  let dst_len = length dst in\n  if len < 0\n  then invalid_bounds_blit \"blit_from_string\" src_len src_off dst_len dst_off len;\n  if src_off < 0 || src_len - src_off < len\n  then invalid_bounds_blit \"blit_from_string\" src_len src_off dst_len dst_off len;\n  if dst_off < 0 || dst_len - dst_off < len\n  then invalid_bounds_blit \"blit_from_string\" src_len src_off dst_len dst_off len;\n  unsafe_blit_from_string src ~src_off dst ~dst_off ~len\n;;\n\nlet blit_from_bytes src ~src_off dst ~dst_off ~len =\n  let src_len = Bytes.length src in\n  let dst_len = length dst in\n  if len < 0\n  then invalid_bounds_blit \"blit_from_bytes\" src_len src_off dst_len dst_off len;\n  if src_off < 0 || src_len - src_off < len\n  then invalid_bounds_blit \"blit_from_bytes\" src_len src_off dst_len dst_off len;\n  if dst_off < 0 || dst_len - dst_off < len\n  then invalid_bounds_blit \"blit_from_bytes\" src_len src_off dst_len dst_off len;\n  unsafe_blit_from_bytes src ~src_off dst ~dst_off ~len\n;;\n\nlet blit_to_bytes src ~src_off dst ~dst_off ~len =\n  let src_len = length src in\n  let dst_len = Bytes.length dst in\n  if len < 0\n  then invalid_bounds_blit \"blit_to_bytes\" src_len src_off dst_len dst_off len;\n  if src_off < 0 || src_len - src_off < len\n  then invalid_bounds_blit \"blit_to_bytes\" src_len src_off dst_len dst_off len;\n  if dst_off < 0 || dst_len - dst_off < len\n  then invalid_bounds_blit \"blit_to_bytes\" src_len src_off dst_len dst_off len;\n  unsafe_blit_to_bytes src ~src_off dst ~dst_off ~len\n;;\n\nlet memcmp buf1 buf1_off buf2 buf2_off len =\n  let buf1_len = length buf1 in\n  let buf2_len = length buf2 in\n  if len < 0\n  then invalid_bounds_memcmp \"memcmp\" buf1_len buf1_off buf2_len buf2_off len;\n  if buf1_off < 0 || buf1_len - buf1_off < len\n  then invalid_bounds_memcmp \"memcmp\" buf1_len buf1_off buf2_len buf2_off len;\n  if buf2_off < 0 || buf2_len - buf2_off < len\n  then invalid_bounds_memcmp \"memcmp\" buf1_len buf1_off buf2_len buf2_off len;\n  unsafe_memcmp buf1 buf1_off buf2 buf2_off len\n;;\n\nlet memcmp_string buf1 buf1_off buf2 buf2_off len =\n  let buf1_len = length buf1 in\n  let buf2_len = String.length buf2 in\n  if len < 0\n  then invalid_bounds_memcmp \"memcmp_string\" buf1_len buf1_off buf2_len buf2_off len;\n  if buf1_off < 0 || buf1_len - buf1_off < len\n  then invalid_bounds_memcmp \"memcmp_string\" buf1_len buf1_off buf2_len buf2_off len;\n  if buf2_off < 0 || buf2_len - buf2_off < len\n  then invalid_bounds_memcmp \"memcmp_string\" buf1_len buf1_off buf2_len buf2_off len;\n  unsafe_memcmp_string buf1 buf1_off buf2 buf2_off len\n;;\n\nlet memchr buf buf_off chr len =\n  let buf_len = length buf in\n  if len < 0\n  then invalid_bounds \"memchr\" buf_len buf_off len;\n  if buf_off < 0 || buf_len - buf_off < len\n  then invalid_bounds \"memchr\" buf_len buf_off len;\n  unsafe_memchr buf buf_off chr len\n\n(* Safe operations *)\n\nexternal caml_bigstring_set_16 : bigstring -> int -> int   -> unit = \"%caml_bigstring_set16\"\nexternal caml_bigstring_set_32 : bigstring -> int -> int32 -> unit = \"%caml_bigstring_set32\"\nexternal caml_bigstring_set_64 : bigstring -> int -> int64 -> unit = \"%caml_bigstring_set64\"\n\nexternal caml_bigstring_get_16 : bigstring -> int -> int   = \"%caml_bigstring_get16\"\nexternal caml_bigstring_get_32 : bigstring -> int -> int32 = \"%caml_bigstring_get32\"\nexternal caml_bigstring_get_64 : bigstring -> int -> int64 = \"%caml_bigstring_get64\"\n\nmodule Swap = struct\n  external bswap16 : int -> int = \"%bswap16\"\n  external bswap_int32 : int32 -> int32 = \"%bswap_int32\"\n  external bswap_int64 : int64 -> int64 = \"%bswap_int64\"\n\n  let caml_bigstring_set_16 bs off i =\n    caml_bigstring_set_16 bs off (bswap16 i)\n\n  let caml_bigstring_set_32 bs off i =\n    caml_bigstring_set_32 bs off (bswap_int32 i)\n\n  let caml_bigstring_set_64 bs off i =\n    caml_bigstring_set_64 bs off (bswap_int64 i)\n\n  let caml_bigstring_get_16 bs off =\n    bswap16 (caml_bigstring_get_16 bs off)\n\n  let caml_bigstring_get_32 bs off =\n    bswap_int32 (caml_bigstring_get_32 bs off)\n\n  let caml_bigstring_get_64 bs off =\n    bswap_int64 (caml_bigstring_get_64 bs off)\n\n  let get_int16_sign_extended x off =\n    ((caml_bigstring_get_16 x off) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\nend\n\nlet set_int16_le, set_int16_be =\n  if Sys.big_endian\n  then Swap.caml_bigstring_set_16, caml_bigstring_set_16\n  else caml_bigstring_set_16     , Swap.caml_bigstring_set_16\n\nlet set_int32_le, set_int32_be =\n  if Sys.big_endian\n  then Swap.caml_bigstring_set_32, caml_bigstring_set_32\n  else caml_bigstring_set_32     , Swap.caml_bigstring_set_32\n\nlet set_int64_le, set_int64_be =\n  if Sys.big_endian\n  then Swap.caml_bigstring_set_64, caml_bigstring_set_64\n  else caml_bigstring_set_64     , Swap.caml_bigstring_set_64\n\nlet get_int16_le, get_int16_be =\n  if Sys.big_endian\n  then Swap.caml_bigstring_get_16, caml_bigstring_get_16\n  else caml_bigstring_get_16     , Swap.caml_bigstring_get_16\n\nlet get_int16_sign_extended_noswap x off =\n  ((caml_bigstring_get_16      x off) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet get_int16_sign_extended_le, get_int16_sign_extended_be  =\n  if Sys.big_endian\n  then Swap.get_int16_sign_extended  , get_int16_sign_extended_noswap\n  else get_int16_sign_extended_noswap, Swap.get_int16_sign_extended\n\nlet get_int32_le, get_int32_be =\n  if Sys.big_endian\n  then Swap.caml_bigstring_get_32, caml_bigstring_get_32\n  else caml_bigstring_get_32     , Swap.caml_bigstring_get_32\n\nlet get_int64_le, get_int64_be =\n  if Sys.big_endian\n  then Swap.caml_bigstring_get_64, caml_bigstring_get_64\n  else caml_bigstring_get_64     , Swap.caml_bigstring_get_64\n\n(* Unsafe operations *)\n\nexternal caml_bigstring_unsafe_set_16 : bigstring -> int -> int   -> unit = \"%caml_bigstring_set16u\"\nexternal caml_bigstring_unsafe_set_32 : bigstring -> int -> int32 -> unit = \"%caml_bigstring_set32u\"\nexternal caml_bigstring_unsafe_set_64 : bigstring -> int -> int64 -> unit = \"%caml_bigstring_set64u\"\n\nexternal caml_bigstring_unsafe_get_16 : bigstring -> int -> int   = \"%caml_bigstring_get16u\"\nexternal caml_bigstring_unsafe_get_32 : bigstring -> int -> int32 = \"%caml_bigstring_get32u\"\nexternal caml_bigstring_unsafe_get_64 : bigstring -> int -> int64 = \"%caml_bigstring_get64u\"\n\nmodule USwap = struct\n  external bswap16 : int -> int = \"%bswap16\"\n  external bswap_int32 : int32 -> int32 = \"%bswap_int32\"\n  external bswap_int64 : int64 -> int64 = \"%bswap_int64\"\n\n  let caml_bigstring_unsafe_set_16 bs off i =\n    caml_bigstring_unsafe_set_16 bs off (bswap16 i)\n\n  let caml_bigstring_unsafe_set_32 bs off i =\n    caml_bigstring_unsafe_set_32 bs off (bswap_int32 i)\n\n  let caml_bigstring_unsafe_set_64 bs off i =\n    caml_bigstring_unsafe_set_64 bs off (bswap_int64 i)\n\n  let caml_bigstring_unsafe_get_16 bs off =\n    bswap16 (caml_bigstring_unsafe_get_16 bs off)\n\n  let caml_bigstring_unsafe_get_32 bs off =\n    bswap_int32 (caml_bigstring_unsafe_get_32 bs off)\n\n  let caml_bigstring_unsafe_get_64 bs off =\n    bswap_int64 (caml_bigstring_unsafe_get_64 bs off)\nend\n\nlet unsafe_set_int16_le, unsafe_set_int16_be =\n  if Sys.big_endian\n  then USwap.caml_bigstring_unsafe_set_16, caml_bigstring_unsafe_set_16\n  else caml_bigstring_unsafe_set_16      , USwap.caml_bigstring_unsafe_set_16\n\nlet unsafe_set_int32_le, unsafe_set_int32_be =\n  if Sys.big_endian\n  then USwap.caml_bigstring_unsafe_set_32, caml_bigstring_unsafe_set_32\n  else caml_bigstring_unsafe_set_32      , USwap.caml_bigstring_unsafe_set_32\n\nlet unsafe_set_int64_le, unsafe_set_int64_be =\n  if Sys.big_endian\n  then USwap.caml_bigstring_unsafe_set_64, caml_bigstring_unsafe_set_64\n  else caml_bigstring_unsafe_set_64      , USwap.caml_bigstring_unsafe_set_64\n\nlet unsafe_get_int16_le, unsafe_get_int16_be =\n  if Sys.big_endian\n  then USwap.caml_bigstring_unsafe_get_16, caml_bigstring_unsafe_get_16\n  else caml_bigstring_unsafe_get_16      , USwap.caml_bigstring_unsafe_get_16\n\nlet unsafe_get_int16_sign_extended_le x off =\n  ((unsafe_get_int16_le x off) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet unsafe_get_int16_sign_extended_be x off =\n  ((unsafe_get_int16_be x off ) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet unsafe_get_int32_le, unsafe_get_int32_be =\n  if Sys.big_endian\n  then USwap.caml_bigstring_unsafe_get_32, caml_bigstring_unsafe_get_32\n  else caml_bigstring_unsafe_get_32      , USwap.caml_bigstring_unsafe_get_32\n\nlet unsafe_get_int64_le, unsafe_get_int64_be =\n  if Sys.big_endian\n  then USwap.caml_bigstring_unsafe_get_64, caml_bigstring_unsafe_get_64\n  else caml_bigstring_unsafe_get_64      , USwap.caml_bigstring_unsafe_get_64\n","type 'a state =\n  | Partial of 'a partial\n  | Done    of int * 'a\n  | Fail    of int * string list * string\n\nand 'a partial =\n  { committed : int\n  ; continue  : Bigstringaf.t -> off:int -> len:int -> More.t -> 'a state }\n\n\nlet state_to_option x = match x with\n  | Done(_, v) -> Some v\n  | Fail _     -> None\n  | Partial _  -> None\n\nlet fail_to_string marks err =\n  String.concat \" > \" marks ^ \": \" ^ err\n\nlet state_to_result x = match x with\n  | Done(_, v)          -> Ok v\n  | Partial _           -> Error \"incomplete input\"\n  | Fail(_, marks, err) -> Error (fail_to_string marks err)\n","(*----------------------------------------------------------------------------\n    Copyright (c) 2017 Inhabited Type LLC.\n\n    All rights reserved.\n\n    Redistribution and use in source and binary forms, with or without\n    modification, are permitted provided that the following conditions\n    are met:\n\n    1. Redistributions of source code must retain the above copyright\n       notice, this list of conditions and the following disclaimer.\n\n    2. Redistributions in binary form must reproduce the above copyright\n       notice, this list of conditions and the following disclaimer in the\n       documentation and/or other materials provided with the distribution.\n\n    3. Neither the name of the author nor the names of his contributors\n       may be used to endorse or promote products derived from this software\n       without specific prior written permission.\n\n    THIS SOFTWARE IS PROVIDED BY THE CONTRIBUTORS ``AS IS'' AND ANY EXPRESS\n    OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n    WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n    DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR\n    ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n    DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\n    OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\n    HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,\n    STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN\n    ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE\n    POSSIBILITY OF SUCH DAMAGE.\n  ----------------------------------------------------------------------------*)\n\ntype t =\n  { mutable parser_committed_bytes : int\n  ; client_committed_bytes         : int\n  ; off                            : int\n  ; len                            : int\n  ; buffer                         : Bigstringaf.t\n  }\n\nlet create buffer ~off ~len ~committed_bytes =\n  { parser_committed_bytes = committed_bytes\n  ; client_committed_bytes = committed_bytes\n  ; off\n  ; len\n  ; buffer }\n\nlet length                 t = t.client_committed_bytes + t.len\nlet client_committed_bytes t = t.client_committed_bytes\nlet parser_committed_bytes t = t.parser_committed_bytes\n\nlet committed_bytes_discrepancy t = t.parser_committed_bytes - t.client_committed_bytes\nlet bytes_for_client_to_commit  t = committed_bytes_discrepancy t\n\nlet parser_uncommitted_bytes t = t.len - bytes_for_client_to_commit t\n\nlet invariant t =\n  assert (parser_committed_bytes t + parser_uncommitted_bytes t = length t);\n  assert (parser_committed_bytes t - client_committed_bytes   t = bytes_for_client_to_commit t);\n;;\n\nlet offset_in_buffer t pos =\n  t.off + pos - t.client_committed_bytes\n\nlet apply t pos len ~f =\n  let off = offset_in_buffer t pos in\n  f t.buffer ~off ~len\n\nlet unsafe_get_char t pos =\n  let off = offset_in_buffer t pos in\n  Bigstringaf.unsafe_get t.buffer off\n\nlet unsafe_get_int16_le t pos =\n  let off = offset_in_buffer t pos in\n  Bigstringaf.unsafe_get_int16_le t.buffer off\n\nlet unsafe_get_int32_le t pos =\n  let off = offset_in_buffer t pos in\n  Bigstringaf.unsafe_get_int32_le t.buffer off\n\nlet unsafe_get_int64_le t pos =\n  let off = offset_in_buffer t pos in\n  Bigstringaf.unsafe_get_int64_le t.buffer off\n\nlet unsafe_get_int16_be t pos =\n  let off = offset_in_buffer t pos in\n  Bigstringaf.unsafe_get_int16_be t.buffer off\n\nlet unsafe_get_int32_be t pos =\n  let off = offset_in_buffer t pos in\n  Bigstringaf.unsafe_get_int32_be t.buffer off\n\nlet unsafe_get_int64_be t pos =\n  let off = offset_in_buffer t pos in\n  Bigstringaf.unsafe_get_int64_be t.buffer off\n\nlet count_while t pos ~f =\n  let buffer = t.buffer in\n  let off    = offset_in_buffer t pos in\n  let i      = ref off in\n  let limit  = t.off + t.len in\n  while !i < limit && f (Bigstringaf.unsafe_get buffer !i) do\n    incr i\n  done;\n  !i - off\n;;\n\nlet commit t pos =\n  t.parser_committed_bytes <- pos\n;;\n","module State = struct\n  type 'a t =\n    | Partial of 'a partial\n    | Lazy    of 'a t Lazy.t\n    | Done    of int * 'a\n    | Fail    of int * string list * string\n\n  and 'a partial =\n    { committed : int\n    ; continue  : Bigstringaf.t -> off:int -> len:int -> More.t -> 'a t }\n\nend\ntype 'a with_state = Input.t ->  int -> More.t -> 'a\n\ntype 'a failure = (string list -> string -> 'a State.t) with_state\ntype ('a, 'r) success = ('a -> 'r State.t) with_state\n\ntype 'a t =\n  { run : 'r. ('r failure -> ('a, 'r) success -> 'r State.t) with_state }\n\nlet fail_k    input pos _ marks msg =\n  State.Fail(pos - Input.client_committed_bytes input, marks, msg)\nlet succeed_k input pos _       v   =\n  State.Done(pos - Input.client_committed_bytes input, v)\n\nlet rec to_exported_state = function\n  | State.Partial {committed;continue} ->\n     Exported_state.Partial\n       { committed\n       ; continue =\n           fun bs ~off ~len more ->\n           to_exported_state (continue bs ~off ~len more)}\n  | State.Done (i,x) -> Exported_state.Done (i,x)\n  | State.Fail (i, sl, s) -> Exported_state.Fail (i, sl, s)\n  | State.Lazy x -> to_exported_state (Lazy.force x)\n\nlet parse p =\n  let input = Input.create Bigstringaf.empty ~committed_bytes:0 ~off:0 ~len:0 in\n  to_exported_state (p.run input 0 Incomplete fail_k succeed_k)\n\nlet parse_bigstring p input =\n  let input = Input.create input ~committed_bytes:0 ~off:0 ~len:(Bigstringaf.length input) in\n  Exported_state.state_to_result (to_exported_state (p.run input 0 Complete fail_k succeed_k))\n\nmodule Monad = struct\n  let return v =\n    { run = fun input pos more _fail succ ->\n      succ input pos more v\n    }\n\n  let fail msg =\n    { run = fun input pos more fail _succ ->\n      fail input pos more [] msg\n    }\n\n  let (>>=) p f =\n    { run = fun input pos more fail succ ->\n      let succ' input' pos' more' v = (f v).run input' pos' more' fail succ in\n      p.run input pos more fail succ'\n    }\n\n  let (>>|) p f =\n    { run = fun input pos more fail succ ->\n      let succ' input' pos' more' v = succ input' pos' more' (f v) in\n      p.run input pos more fail succ'\n    }\n\n  let (<$>) f m =\n    m >>| f\n\n  let (<*>) f m =\n    (* f >>= fun f -> m >>| f *)\n    { run = fun input pos more fail succ ->\n      let succ0 input0 pos0 more0 f =\n        let succ1 input1 pos1 more1 m = succ input1 pos1 more1 (f m) in\n        m.run input0 pos0 more0 fail succ1\n      in\n      f.run input pos more fail succ0 }\n\n  let lift f m =\n    f <$> m\n\n  let lift2 f m1 m2 =\n    { run = fun input pos more fail succ ->\n      let succ1 input1 pos1 more1 m1 =\n        let succ2 input2 pos2 more2 m2 = succ input2 pos2 more2 (f m1 m2) in\n        m2.run input1 pos1 more1 fail succ2\n      in\n      m1.run input pos more fail succ1 }\n\n  let lift3 f m1 m2 m3 =\n    { run = fun input pos more fail succ ->\n      let succ1 input1 pos1 more1 m1 =\n        let succ2 input2 pos2 more2 m2 =\n          let succ3 input3 pos3 more3 m3 =\n            succ input3 pos3 more3 (f m1 m2 m3) in\n          m3.run input2 pos2 more2 fail succ3 in\n        m2.run input1 pos1 more1 fail succ2\n      in\n      m1.run input pos more fail succ1 }\n\n  let lift4 f m1 m2 m3 m4 =\n    { run = fun input pos more fail succ ->\n      let succ1 input1 pos1 more1 m1 =\n        let succ2 input2 pos2 more2 m2 =\n          let succ3 input3 pos3 more3 m3 =\n            let succ4 input4 pos4 more4 m4 =\n              succ input4 pos4 more4 (f m1 m2 m3 m4) in\n            m4.run input3 pos3 more3 fail succ4 in\n          m3.run input2 pos2 more2 fail succ3 in\n        m2.run input1 pos1 more1 fail succ2\n      in\n      m1.run input pos more fail succ1 }\n\n  let ( *>) a b =\n    (* a >>= fun _ -> b *)\n    { run = fun input pos more fail succ ->\n      let succ' input' pos' more' _ = b.run input' pos' more' fail succ in\n      a.run input pos more fail succ'\n    }\n\n  let (<* ) a b =\n    (* a >>= fun x -> b >>| fun _ -> x *)\n    { run = fun input pos more fail succ ->\n      let succ0 input0 pos0 more0 x =\n        let succ1 input1 pos1 more1 _ = succ input1 pos1 more1 x in\n        b.run input0 pos0 more0 fail succ1\n      in\n      a.run input pos more fail succ0 }\nend\n\nmodule Choice = struct\n  let (<?>) p mark =\n    { run = fun input pos more fail succ ->\n      let fail' input' pos' more' marks msg =\n        fail input' pos' more' (mark::marks) msg in\n      p.run input pos more fail' succ\n    }\n\n  let (<|>) p q =\n    { run = fun input pos more fail succ ->\n      let fail' input' pos' more' marks msg =\n        (* The only two constructors that introduce new failure continuations are\n         * [<?>] and [<|>]. If the initial input position is less than the length\n         * of the committed input, then calling the failure continuation will\n         * have the effect of unwinding all choices and collecting marks along\n         * the way. *)\n        if pos < Input.parser_committed_bytes input' then\n          fail input' pos' more marks msg\n        else\n          q.run input' pos more' fail succ in\n      p.run input pos more fail' succ\n    }\nend\n\nmodule Monad_use_for_debugging = struct\n  let return = Monad.return\n  let fail   = Monad.fail\n  let (>>=)  = Monad.(>>=)\n\n  let (>>|) m f = m >>= fun x -> return (f x)\n\n  let (<$>) f m = m >>| f\n  let (<*>) f m = f >>= fun f -> m >>| f\n\n  let lift  = (>>|)\n  let lift2 f m1 m2       = f <$> m1 <*> m2\n  let lift3 f m1 m2 m3    = f <$> m1 <*> m2 <*> m3\n  let lift4 f m1 m2 m3 m4 = f <$> m1 <*> m2 <*> m3 <*> m4\n\n  let ( *>) a b = a >>= fun _ -> b\n  let (<* ) a b = a >>= fun x -> b >>| fun _ -> x\nend\n","type t =\n  { mutable buf : Bigstringaf.t\n  ; mutable off : int\n  ; mutable len : int }\n\nlet of_bigstring ~off ~len buf =\n  assert (off >= 0);\n  assert (Bigstringaf.length buf >= len - off);\n  { buf; off; len }\n\nlet create len =\n  of_bigstring ~off:0 ~len:0 (Bigstringaf.create len)\n\nlet writable_space t =\n  Bigstringaf.length t.buf - t.len\n\nlet trailing_space t =\n  Bigstringaf.length t.buf - (t.off + t.len)\n\nlet compress t =\n  Bigstringaf.unsafe_blit t.buf ~src_off:t.off t.buf ~dst_off:0 ~len:t.len;\n  t.off <- 0\n\nlet grow t to_copy =\n  let old_len = Bigstringaf.length t.buf in\n  let new_len = ref old_len in\n  let space = writable_space t in\n  while space + !new_len - old_len < to_copy do\n    new_len := (3 * !new_len) / 2\n  done;\n  let new_buf = Bigstringaf.create !new_len in\n  Bigstringaf.unsafe_blit t.buf ~src_off:t.off new_buf ~dst_off:0 ~len:t.len;\n  t.buf <- new_buf;\n  t.off <- 0\n\nlet ensure t to_copy =\n  if trailing_space t < to_copy then\n    if writable_space t >= to_copy\n    then compress t\n    else grow t to_copy\n\nlet write_pos t =\n  t.off + t.len\n\nlet feed_string t ~off ~len str =\n  assert (off >= 0);\n  assert (String.length str >= len - off);\n  ensure t len;\n  Bigstringaf.unsafe_blit_from_string str ~src_off:off t.buf ~dst_off:(write_pos t) ~len;\n  t.len <- t.len + len\n\nlet feed_bigstring t ~off ~len b =\n  assert (off >= 0);\n  assert (Bigstringaf.length b >= len - off);\n  ensure t len;\n  Bigstringaf.unsafe_blit b ~src_off:off t.buf ~dst_off:(write_pos t) ~len;\n  t.len <- t.len + len\n\nlet feed_input t = function\n  | `String    s -> feed_string    t ~off:0 ~len:(String     .length s) s\n  | `Bigstring b -> feed_bigstring t ~off:0 ~len:(Bigstringaf.length b) b\n\nlet shift t n =\n  assert (t.len >= n);\n  t.off <- t.off + n;\n  t.len <- t.len - n\n\nlet for_reading { buf; off; len } =\n  Bigstringaf.sub ~off ~len buf\n\nmodule Unconsumed = struct\n  type t =\n    { buf : Bigstringaf.t\n    ; off : int\n    ; len : int }\nend\n\nlet unconsumed ?(shift=0) { buf; off; len } =\n  assert (len >= shift);\n  { Unconsumed.buf; off = off + shift; len = len - shift }\n\nlet of_unconsumed { Unconsumed.buf; off; len } =\n  { buf; off; len }\n\ntype unconsumed = Unconsumed.t =\n  { buf : Bigstringaf.t\n  ; off : int\n  ; len : int }\n","(*----------------------------------------------------------------------------\n    Copyright (c) 2016 Inhabited Type LLC.\n\n    All rights reserved.\n\n    Redistribution and use in source and binary forms, with or without\n    modification, are permitted provided that the following conditions\n    are met:\n\n    1. Redistributions of source code must retain the above copyright\n       notice, this list of conditions and the following disclaimer.\n\n    2. Redistributions in binary form must reproduce the above copyright\n       notice, this list of conditions and the following disclaimer in the\n       documentation and/or other materials provided with the distribution.\n\n    3. Neither the name of the author nor the names of his contributors\n       may be used to endorse or promote products derived from this software\n       without specific prior written permission.\n\n    THIS SOFTWARE IS PROVIDED BY THE CONTRIBUTORS ``AS IS'' AND ANY EXPRESS\n    OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n    WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n    DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR\n    ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n    DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\n    OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\n    HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,\n    STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN\n    ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE\n    POSSIBILITY OF SUCH DAMAGE.\n  ----------------------------------------------------------------------------*)\n\nmodule Bigarray = struct\n  (* Do not access Bigarray operations directly. If anything's needed, refer to\n   * the internal Bigstring module. *)\nend\n\ntype bigstring = Bigstringaf.t\n\n\nmodule Unbuffered = struct\n  include Parser\n\n  include Exported_state\n\n  type more = More.t =\n    | Complete\n    | Incomplete\nend\n\ninclude Unbuffered\ninclude Parser.Monad\ninclude Parser.Choice\n\nmodule Buffered = struct\n  type unconsumed = Buffering.unconsumed =\n    { buf : bigstring\n    ; off : int\n    ; len : int }\n\n  type input =\n    [ `Bigstring of bigstring\n    | `String    of string ]\n\n  type 'a state =\n    | Partial of ([ input | `Eof ] -> 'a state)\n    | Done    of unconsumed * 'a\n    | Fail    of unconsumed * string list * string\n\n  let from_unbuffered_state ~f buffering = function\n    | Unbuffered.Partial p         -> Partial (f p)\n    | Unbuffered.Done(consumed, v) ->\n      let unconsumed = Buffering.unconsumed ~shift:consumed buffering in\n      Done(unconsumed, v)\n    | Unbuffered.Fail(consumed, marks, msg) ->\n      let unconsumed = Buffering.unconsumed ~shift:consumed buffering in\n      Fail(unconsumed, marks, msg)\n\n  let parse ?(initial_buffer_size=0x1000) p =\n    if initial_buffer_size < 1 then\n      failwith \"parse: invalid argument, initial_buffer_size < 1\";\n    let buffering = Buffering.create initial_buffer_size in\n    let rec f p input =\n      Buffering.shift buffering p.committed;\n      let more : More.t =\n        match input with\n        | `Eof            -> Complete\n        | #input as input ->\n          Buffering.feed_input buffering input;\n          Incomplete\n      in\n      let for_reading = Buffering.for_reading buffering in\n      p.continue for_reading ~off:0 ~len:(Bigstringaf.length for_reading) more\n      |> from_unbuffered_state buffering ~f\n    in\n    Unbuffered.parse p\n    |> from_unbuffered_state buffering ~f\n\n  let feed state input =\n    match state with\n    | Partial k -> k input\n    | Fail(unconsumed, marks, msg) ->\n      begin match input with\n      | `Eof   -> state\n      | #input as input ->\n        let buffering = Buffering.of_unconsumed unconsumed in\n        Buffering.feed_input buffering input;\n        Fail(Buffering.unconsumed buffering, marks, msg)\n      end\n    | Done(unconsumed, v) ->\n      begin match input with\n      | `Eof   -> state\n      | #input as input ->\n        let buffering = Buffering.of_unconsumed unconsumed in\n        Buffering.feed_input buffering input;\n        Done(Buffering.unconsumed buffering, v)\n      end\n\n  let state_to_option = function\n    | Done(_, v) -> Some v\n    | Partial _  -> None\n    | Fail _     -> None\n\n  let state_to_result = function\n    | Partial _           -> Error \"incomplete input\"\n    | Done(_, v)          -> Ok v\n    | Fail(_, marks, msg) -> Error (Unbuffered.fail_to_string marks msg)\n\n  let state_to_unconsumed = function\n    | Done(unconsumed, _)\n    | Fail(unconsumed, _, _) -> Some unconsumed\n    | Partial _              -> None\n\nend\n\n(** BEGIN: getting input *)\n\nlet rec prompt input pos fail succ =\n  (* [prompt] should only call [succ] if it has received more input. If there\n   * is no chance that the input will grow, i.e., [more = Complete], then\n   * [prompt] should call [fail]. Otherwise (in the case where the input\n   * hasn't grown but [more = Incomplete] just prompt again. *)\n  let parser_uncommitted_bytes = Input.parser_uncommitted_bytes input in\n  let parser_committed_bytes   = Input.parser_committed_bytes   input in\n  (* The continuation should not hold any references to input above. *)\n  let continue input ~off ~len more =\n    if len < parser_uncommitted_bytes then\n      failwith \"prompt: input shrunk!\";\n    let input = Input.create input ~off ~len ~committed_bytes:parser_committed_bytes in\n    if len = parser_uncommitted_bytes then\n      match (more : More.t) with\n      | Complete   -> fail input pos More.Complete\n      | Incomplete -> prompt input pos fail succ\n    else\n      succ input pos more\n  in\n  State.Partial { committed = Input.bytes_for_client_to_commit input; continue }\n\nlet demand_input =\n  { run = fun input pos more fail succ ->\n    match (more : More.t) with\n    | Complete   -> fail input pos more [] \"not enough input\"\n    | Incomplete ->\n      let succ' input' pos' more' = succ input' pos' more' ()\n      and fail' input' pos' more' = fail input' pos' more' [] \"not enough input\" in\n      prompt input pos fail' succ'\n  }\n\nlet ensure_suspended n input pos more fail succ =\n  let rec go =\n    { run = fun input' pos' more' fail' succ' ->\n      if pos' + n <= Input.length input' then\n        succ' input' pos' more' ()\n      else\n        (demand_input *> go).run input' pos' more' fail' succ'\n    }\n  in\n  (demand_input *> go).run input pos more fail succ\n\nlet unsafe_apply len ~f =\n  { run = fun input pos more _fail succ ->\n    succ input (pos + len) more (Input.apply input pos len ~f)\n  }\n\nlet unsafe_apply_opt len ~f =\n  { run = fun input pos more fail succ ->\n    match Input.apply input pos len ~f with\n    | Error e -> fail input pos more [] e\n    | Ok    x -> succ input (pos + len) more x\n  }\n\nlet ensure n p =\n  { run = fun input pos more fail succ ->\n    if pos + n <= Input.length input\n    then p.run input pos more fail succ\n    else\n      let succ' input' pos' more' () = p.run input' pos' more' fail succ in\n      ensure_suspended n input pos more fail succ' }\n\n(** END: getting input *)\n\nlet at_end_of_input =\n  { run = fun input pos more _ succ ->\n    if pos < Input.length input then\n      succ input pos more false\n    else match more with\n    | Complete -> succ input pos more true\n    | Incomplete ->\n      let succ' input' pos' more' = succ input' pos' more' false\n      and fail' input' pos' more' = succ input' pos' more' true in\n      prompt input pos fail' succ'\n  }\n\nlet end_of_input =\n  at_end_of_input\n  >>= function\n    | true  -> return ()\n    | false -> fail \"end_of_input\"\n\nlet advance n =\n  if n < 0\n  then fail \"advance\"\n  else\n    let p =\n      { run = fun input pos more _fail succ -> succ input (pos + n) more () }\n    in\n    ensure n p\n\nlet pos =\n  { run = fun input pos more _fail succ -> succ input pos more pos }\n\nlet available =\n  { run = fun input pos more _fail succ ->\n    succ input pos more (Input.length input - pos)\n  }\n\nlet commit =\n  { run = fun input pos more _fail succ ->\n    Input.commit input pos;\n    succ input pos more () }\n\n(* Do not use this if [p] contains a [commit]. *)\nlet unsafe_lookahead p =\n  { run = fun input pos more fail succ ->\n    let succ' input' _ more' v = succ input' pos more' v in\n    p.run input pos more fail succ' }\n\nlet peek_char =\n  { run = fun input pos more _fail succ ->\n    if pos < Input.length input then\n      succ input pos more (Some (Input.unsafe_get_char input pos))\n    else if more = Complete then\n      succ input pos more None\n    else\n      let succ' input' pos' more' =\n        succ input' pos' more' (Some (Input.unsafe_get_char input' pos'))\n      and fail' input' pos' more' =\n        succ input' pos' more' None in\n      prompt input pos fail' succ'\n  }\n\n(* This parser is too important to not be optimized. Do a custom job. *)\nlet rec peek_char_fail =\n  { run = fun input pos more fail succ ->\n    if pos < Input.length input\n    then succ input pos more (Input.unsafe_get_char input pos)\n    else\n      let succ' input' pos' more' () =\n        peek_char_fail.run input' pos' more' fail succ in\n      ensure_suspended 1 input pos more fail succ' }\n\nlet satisfy f =\n  { run = fun input pos more fail succ ->\n    if pos < Input.length input then\n      let c = Input.unsafe_get_char input pos in\n      if f c\n      then succ input (pos + 1) more c\n      else Printf.ksprintf (fail input pos more []) \"satisfy: %C\" c\n    else\n      let succ' input' pos' more' () =\n        let c = Input.unsafe_get_char input' pos' in\n        if f c\n        then succ input' (pos' + 1) more' c\n        else Printf.ksprintf (fail input' pos' more' []) \"satisfy: %C\" c\n      in\n      ensure_suspended 1 input pos more fail succ' }\n\nlet char c =\n  let p =\n    { run = fun input pos more fail succ ->\n      if Input.unsafe_get_char input pos = c\n      then succ input (pos + 1) more c\n      else fail input pos more [] (Printf.sprintf \"char %C\" c) }\n  in\n  ensure 1 p\n\nlet not_char c =\n  let p =\n    { run = fun input pos more fail succ ->\n      let c' = Input.unsafe_get_char input pos in\n      if c <> c'\n      then succ input (pos + 1) more c'\n      else fail input pos more [] (Printf.sprintf \"not char %C\" c) }\n  in\n  ensure 1 p\n\nlet any_char =\n  let p =\n    { run = fun input pos more _fail succ ->\n      succ input (pos + 1) more (Input.unsafe_get_char input pos)  }\n  in\n  ensure 1 p\n\nlet int8 i =\n  let p =\n    { run = fun input pos more fail succ ->\n      let c = Char.code (Input.unsafe_get_char input pos) in\n      if c = i land 0xff\n      then succ input (pos + 1) more c\n      else fail input pos more [] (Printf.sprintf \"int8 %d\" i) }\n  in\n  ensure 1 p\n\nlet any_uint8 =\n  let p =\n    { run = fun input pos more _fail succ ->\n      let c = Input.unsafe_get_char input pos in\n      succ input (pos + 1) more (Char.code c) }\n  in\n  ensure 1 p\n\nlet any_int8 =\n  (* https://graphics.stanford.edu/~seander/bithacks.html#VariableSignExtendRisky *)\n  let s = Sys.int_size - 8 in\n  let p =\n    { run = fun input pos more _fail succ ->\n      let c = Input.unsafe_get_char input pos in\n      succ input (pos + 1) more ((Char.code c lsl s) asr s) }\n  in\n  ensure 1 p\n\nlet skip f =\n  let p =\n    { run = fun input pos more fail succ ->\n      if f (Input.unsafe_get_char input pos)\n      then succ input (pos + 1) more ()\n      else fail input pos more [] \"skip\" }\n  in\n  ensure 1 p\n\nlet rec count_while ~init ~f ~with_buffer =\n  { run = fun input pos more fail succ ->\n    let len         = Input.count_while input (pos + init) ~f in\n    let input_len   = Input.length input in\n    let init'       = init + len in\n    (* Check if the loop terminated because it reached the end of the input\n     * buffer. If so, then prompt for additional input and continue. *)\n    if pos + init' < input_len || more = Complete\n    then succ input (pos + init') more (Input.apply input pos init' ~f:with_buffer)\n    else\n      let succ' input' pos' more' =\n        (count_while ~init:init' ~f ~with_buffer).run input' pos' more' fail succ\n      and fail' input' pos' more' =\n        succ input' (pos' + init') more' (Input.apply input' pos' init' ~f:with_buffer)\n      in\n      prompt input pos fail' succ'\n  }\n\nlet rec count_while1 ~f ~with_buffer =\n  { run = fun input pos more fail succ ->\n    let len         = Input.count_while input pos ~f in\n    let input_len   = Input.length input in\n    (* Check if the loop terminated because it reached the end of the input\n     * buffer. If so, then prompt for additional input and continue. *)\n    if len < 1\n    then\n      if pos < input_len || more = Complete\n      then fail input pos more [] \"count_while1\"\n      else\n        let succ' input' pos' more' =\n          (count_while1 ~f ~with_buffer).run input' pos' more' fail succ\n        and fail' input' pos' more' =\n          fail input' pos' more' [] \"count_while1\"\n        in\n        prompt input pos fail' succ'\n    else if pos + len < input_len || more = Complete\n    then succ input (pos + len) more (Input.apply input pos len ~f:with_buffer)\n    else\n      let succ' input' pos' more' =\n        (count_while ~init:len ~f ~with_buffer).run input' pos' more' fail succ\n      and fail' input' pos' more' =\n        succ input' (pos' + len) more' (Input.apply input' pos' len ~f:with_buffer)\n      in\n      prompt input pos fail' succ'\n  }\n\nlet string_ f s =\n  (* XXX(seliopou): Inefficient. Could check prefix equality to short-circuit\n   * the io. *)\n  let len = String.length s in\n  ensure  len (unsafe_apply_opt len ~f:(fun buffer ~off ~len ->\n    let i = ref 0 in\n    while !i < len && Char.equal (f (Bigstringaf.unsafe_get buffer (off + !i)))\n                                 (f (String.unsafe_get s !i))\n    do\n      incr i\n    done;\n    if len = !i\n    then Ok (Bigstringaf.substring buffer ~off ~len)\n    else Error \"string\"))\n\nlet string s    = string_ (fun x -> x) s\nlet string_ci s = string_ Char.lowercase_ascii s\n\nlet skip_while f =\n  count_while ~init:0 ~f ~with_buffer:(fun _ ~off:_ ~len:_ -> ())\n\nlet take n =\n  if n < 0\n  then fail \"take: n < 0\"\n  else\n    let n = max n 0 in\n    ensure n (unsafe_apply n ~f:Bigstringaf.substring)\n\nlet take_bigstring n =\n  if n < 0\n  then fail \"take_bigstring: n < 0\"\n  else\n    let n = max n 0 in\n    ensure n (unsafe_apply n ~f:Bigstringaf.copy)\n\nlet take_bigstring_while f =\n  count_while ~init:0 ~f ~with_buffer:Bigstringaf.copy\n\nlet take_bigstring_while1 f =\n  count_while1 ~f ~with_buffer:Bigstringaf.copy\n\nlet take_bigstring_till f =\n  take_bigstring_while (fun c -> not (f c))\n\nlet peek_string n =\n  unsafe_lookahead (take n)\n\nlet take_while f =\n  count_while ~init:0 ~f ~with_buffer:Bigstringaf.substring\n\nlet take_while1 f =\n  count_while1 ~f ~with_buffer:Bigstringaf.substring\n\nlet take_till f =\n  take_while (fun c -> not (f c))\n\nlet choice ?(failure_msg=\"no more choices\") ps =\n  List.fold_right (<|>) ps (fail failure_msg)\n\nlet fix_direct f =\n  let rec p = lazy (f r)\n  and r = { run = fun buf pos more fail succ ->\n    (Lazy.force p).run buf pos more fail succ }\n  in\n  r\n\nlet fix_lazy ~max_steps f =\n  let steps = ref max_steps in\n  let rec p = lazy (f r)\n  and r = { run = fun buf pos more fail succ ->\n    decr steps;\n    if !steps < 0\n    then (\n      steps := max_steps;\n      State.Lazy (lazy ((Lazy.force p).run buf pos more fail succ)))\n    else\n      (Lazy.force p).run buf pos more fail succ\n          }\n  in\n  r\n\nlet fix = match Sys.backend_type with\n  | Native -> fix_direct\n  | Bytecode -> fix_direct\n  | Other _ -> fun f -> fix_lazy ~max_steps:20 f\n\nlet option x p =\n  p <|> return x\n\nlet cons x xs = x :: xs\n\nlet rec list ps =\n  match ps with\n  | []    -> return []\n  | p::ps -> lift2 cons p (list ps)\n\nlet count n p =\n  if n < 0\n  then fail \"count: n < 0\"\n  else\n    let rec loop = function\n      | 0 -> return []\n      | n -> lift2 cons p (loop (n - 1))\n    in\n    loop n\n\nlet many p =\n  fix (fun m ->\n    (lift2 cons p m) <|> return [])\n\nlet many1 p =\n  lift2 cons p (many p)\n\nlet many_till p t =\n  fix (fun m ->\n    (t *> return []) <|> (lift2 cons p m))\n\nlet sep_by1 s p =\n  fix (fun m ->\n    lift2 cons p ((s *> m) <|> return []))\n\nlet sep_by s p =\n  (lift2 cons p ((s *> sep_by1 s p) <|> return [])) <|> return []\n\nlet skip_many p =\n  fix (fun m ->\n      ((p >>| fun _ -> true) <|> return false) >>= function\n      | true -> m\n      | false -> return ()\n    )\n\nlet skip_many1 p =\n  p *> skip_many p\n\nlet end_of_line =\n  (char '\\n' *> return ()) <|> (string \"\\r\\n\" *> return ()) <?> \"end_of_line\"\n\nlet scan_ state f ~with_buffer =\n  { run = fun input pos more fail succ ->\n    let state = ref state in\n    let parser =\n      count_while ~init:0 ~f:(fun c ->\n        match f !state c with\n        | None -> false\n        | Some state' -> state := state'; true)\n      ~with_buffer\n      >>| fun x -> x, !state\n    in\n    parser.run input pos more fail succ }\n\nlet scan state f =\n  scan_ state f ~with_buffer:Bigstringaf.substring\n\nlet scan_state state f =\n  scan_ state f ~with_buffer:(fun _ ~off:_ ~len:_ -> ())\n  >>| fun ((), state) -> state\n\nlet scan_string state f =\n  scan state f >>| fst\n\nlet consume_with p f =\n  { run = fun input pos more fail succ ->\n    let start = pos in\n    let parser_committed_bytes = Input.parser_committed_bytes input  in\n    let succ' input' pos' more' _ =\n      if parser_committed_bytes <> Input.parser_committed_bytes input'\n      then fail input' pos' more' [] \"consumed: parser committed\"\n      else (\n        let len = pos' - start in\n        let consumed = Input.apply input' start len ~f in\n        succ input' pos' more' consumed)\n    in\n    p.run input pos more fail succ'\n  }\n\nlet consumed           p = consume_with p Bigstringaf.substring\nlet consumed_bigstring p = consume_with p Bigstringaf.copy\n\nlet both a b = lift2 (fun a b -> a, b) a b\nlet map t ~f = t >>| f\nlet bind t ~f = t >>= f\nlet map2 a b ~f = lift2 f a b\nlet map3 a b c ~f = lift3 f a b c\nlet map4 a b c d ~f = lift4 f a b c d\n\nmodule Let_syntax = struct\n  let return = return\n  let ( >>| ) = ( >>| )\n  let ( >>= ) = ( >>= )\n\n  module Let_syntax = struct\n    let return = return\n    let map = map\n    let bind = bind\n    let both = both\n    let map2 = map2\n    let map3 = map3\n    let map4 = map4\n  end\nend\n\nlet ( let+ ) = ( >>| )\nlet ( let* ) = ( >>= )\nlet ( and+ ) = both\n\nmodule BE = struct\n  (* XXX(seliopou): The pattern in both this module and [LE] are a compromise\n   * between efficiency and code reuse. By inlining [ensure] you can recover\n   * about 2 nanoseconds on average. That may add up in certain applications.\n   *\n   * This pattern does not allocate in the fast (success) path.\n   * *)\n  let int16 n =\n    let bytes = 2 in\n    let p =\n      { run = fun input pos more fail succ ->\n        if Input.unsafe_get_int16_be input pos = (n land 0xffff)\n        then succ input (pos + bytes) more ()\n        else fail input pos more [] \"BE.int16\" }\n    in\n    ensure bytes p\n\n  let int32 n =\n    let bytes = 4 in\n    let p =\n      { run = fun input pos more fail succ ->\n        if Int32.equal (Input.unsafe_get_int32_be input pos) n\n        then succ input (pos + bytes) more ()\n        else fail input pos more [] \"BE.int32\" }\n    in\n    ensure bytes p\n\n  let int64 n =\n    let bytes = 8 in\n    let p =\n      { run = fun input pos more fail succ ->\n        if Int64.equal (Input.unsafe_get_int64_be input pos) n\n        then succ input (pos + bytes) more ()\n        else fail input pos more [] \"BE.int64\" }\n    in\n    ensure bytes p\n\n  let any_uint16 =\n    ensure 2 (unsafe_apply 2 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int16_be bs off))\n\n  let any_int16  =\n    ensure 2 (unsafe_apply 2 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int16_sign_extended_be  bs off))\n\n  let any_int32  =\n    ensure 4 (unsafe_apply 4 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int32_be bs off))\n\n  let any_int64 =\n    ensure 8 (unsafe_apply 8 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int64_be bs off))\n\n  let any_float =\n    ensure 4 (unsafe_apply 4 ~f:(fun bs ~off ~len:_ -> Int32.float_of_bits (Bigstringaf.unsafe_get_int32_be bs off)))\n\n  let any_double =\n    ensure 8 (unsafe_apply 8 ~f:(fun bs ~off ~len:_ -> Int64.float_of_bits (Bigstringaf.unsafe_get_int64_be bs off)))\nend\n\nmodule LE = struct\n  let int16 n =\n    let bytes = 2 in\n    let p =\n      { run = fun input pos more fail succ ->\n        if Input.unsafe_get_int16_le input pos = (n land 0xffff)\n        then succ input (pos + bytes) more ()\n        else fail input pos more [] \"LE.int16\" }\n    in\n    ensure bytes p\n\n  let int32 n =\n    let bytes = 4 in\n    let p =\n      { run = fun input pos more fail succ ->\n        if Int32.equal (Input.unsafe_get_int32_le input pos) n\n        then succ input (pos + bytes) more ()\n        else fail input pos more [] \"LE.int32\" }\n    in\n    ensure bytes p\n\n  let int64 n =\n    let bytes = 8 in\n    let p =\n      { run = fun input pos more fail succ ->\n        if Int64.equal (Input.unsafe_get_int64_le input pos) n\n        then succ input (pos + bytes) more ()\n        else fail input pos more [] \"LE.int64\" }\n    in\n    ensure bytes p\n\n\n  let any_uint16 =\n    ensure 2 (unsafe_apply 2 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int16_le bs off))\n\n  let any_int16  =\n    ensure 2 (unsafe_apply 2 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int16_sign_extended_le  bs off))\n\n  let any_int32  =\n    ensure 4 (unsafe_apply 4 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int32_le bs off))\n\n  let any_int64 =\n    ensure 8 (unsafe_apply 8 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int64_le bs off))\n\n  let any_float =\n    ensure 4 (unsafe_apply 4 ~f:(fun bs ~off ~len:_ -> Int32.float_of_bits (Bigstringaf.unsafe_get_int32_le bs off)))\n\n  let any_double =\n    ensure 8 (unsafe_apply 8 ~f:(fun bs ~off ~len:_ -> Int64.float_of_bits (Bigstringaf.unsafe_get_int64_le bs off)))\nend\n\nmodule Unsafe = struct\n  let take n f =\n    let n = max n 0 in\n    ensure n (unsafe_apply n ~f)\n\n  let peek n f =\n    unsafe_lookahead (take n f)\n\n  let take_while check f =\n    count_while ~init:0 ~f:check ~with_buffer:f\n\n  let take_while1 check f =\n    count_while1 ~f:check ~with_buffer:f\n\n  let take_till check f =\n    take_while (fun c -> not (check c)) f\nend\n\nmodule Consume = struct\n  type t =\n    | Prefix\n    | All\nend\n\nlet parse_bigstring ~consume p bs =\n  let p =\n    match (consume : Consume.t) with\n    | Prefix -> p\n    | All -> p <* end_of_input\n  in\n  Unbuffered.parse_bigstring p bs\n\nlet parse_string ~consume p s =\n  let len = String.length s in\n  let bs  = Bigstringaf.create len in\n  Bigstringaf.unsafe_blit_from_string s ~src_off:0 bs ~dst_off:0 ~len;\n  parse_bigstring ~consume p bs\n","\n(*******************  Convenience functions  **********************)\nlet myfold l a f = List.fold_left f a l\nlet myrevmap l f   = List.rev_map f l\nlet myrevmap2 l1 l2 f  = List.rev_map2 f l1 l2\n\n(* Builds a string from a list of items *)\nlet sep map sp l = List.fold_left (fun acu x -> if acu = \"\" then map x else acu ^ sp ^ (map x)) \"\" l\n\n\n\n(*******************  Shortcuts to Zarith  ***********************)\n\nlet (++) = Z.add\nlet (+++) b i = b ++ (Z.of_int i)\nlet succ = Z.succ\n\nlet (--) = Z.sub\nlet minus = Z.neg\n\nlet ( *^ ) i j = let open Z in (Z.of_int i) ** j\n\nlet ( ** ) = Z.mul\nlet ( **. ) i b = (Z.of_int i) ** b\n\nlet quomod = Z.div_rem\nlet bigmod a b = Z.rem a b\n\nlet sign = Z.sign\nlet big_compare = Z.compare\n\nlet bigzero = Z.zero\nlet bigone  = Z.one\n\nlet is_bigone x = Z.compare x bigone = 0\n\nlet sob = Z.to_string\nlet bos = Z.of_string\n\nlet boi = Z.of_int\nlet iob = Z.to_int\n\n","\ntype 'a t =\n    { default_value : 'a ;\n      mutable realsize : int ;\n      mutable tab : 'a array }\n      \nlet create n v =\n  { default_value = v ;\n    realsize = 0 ;\n    tab = Array.make n v }\n\nlet copy t = \n  { default_value = t.default_value ;\n    realsize = t.realsize ;\n    tab = Array.copy t.tab }\n\nlet get t index = \n  if index < 0 then failwith \"extArray.get, negative index.\"\n  else if index >= t.realsize then t.default_value\n  else t.tab.(index)\n\nlet set t index v =\n\n  let len = Array.length t.tab in\n  if index >= len then\n    begin\n      (* Resize *)\n      let newarray = Array.make (max (index+1) (2 * len)) t.default_value in\n      Array.blit t.tab 0 newarray 0 len ;\n      t.tab <- newarray ;\n    end ;\n\n  t.tab.(index) <- v ;\n  t.realsize <- max t.realsize (index+1) ;\n  ()\n\nlet size t = t.realsize\n\nlet fold t acu f =\n  let akk = ref acu in\n  for i = 0 to t.realsize - 1 do\n    akk := f i t.tab.(i) !akk ;\n  done ;\n  !akk\n\nlet iter t f =\n  for i = 0 to t.realsize - 1 do\n    f i t.tab.(i) ;\n  done\n  \n\n","open Convenience\n\n(*** Shuffle, deterministically, the values inside parts. ***)\n\n(* Starting from x, find a number prime with y. *)\nlet rec find_prime x y =\n  let gcd = Z.gcd x y in\n  if is_bigone gcd then x\n  else find_prime (Z.succ x) y\n\nlet compute_shuffle card compute =\n\n  (* Z doc says bigints can be compared using >  *)\n  if card = Z.zero then\n    (* The part is empty. *)\n    (fun _ -> assert false) (* Should not be invoked. *)\n      \n  else\n  \n  (* Find a number within the order of magnitude of sqrt(card) \n   * and that is prime with card. *)\n  let prime = find_prime (Z.sqrt card) card in\n\n  fun index -> \n    let new_index = bigmod (index ** prime) card in\n    compute new_index\n\n\n","open Convenience\n\n(******************************************************************)\n(*                        PARTS                                   *)\n(******************************************************************)\n\n(* A part is a _finite_ sub-enumeration corresponding to a given depth.\n * The depth is roughly the number of constructors. *)\ntype 'a part = {\n    (* Cardinal of this part. *)\n    p_cardinal : Z.t ;\n    \n    (* Compute the element corresponding to the given index. *)\n    compute : (Z.t -> 'a) ;\n  }\n\nlet get_cardinal p = p.p_cardinal\n\n(* Debug: we try two modes. Standard and Shuffled. \n * In shuffled mode, values in parts are (deterministically) shuffled. *)\ntype mode = Standard | Shuffled\nlet mode = Shuffled\n\n(* Suppress warning. *)\nlet _ = Standard\n\nlet shuffle part =\n  match mode with\n  | Standard -> part\n  | Shuffled -> \n      { p_cardinal = part.p_cardinal ;\n\tcompute    = Shuffle.compute_shuffle part.p_cardinal part.compute }\n\n(* The EMPTY part *)\nlet empty_part = {\n  p_cardinal = bigzero ;\n  compute = (fun _ -> assert false) ;\n}\n\n(* A DUMMY part, for cells that remain to be initialized. *)\nlet uninitialized_part = {\n  p_cardinal = bigzero ;\n  compute = (fun _ -> assert false) ;\n}\n\n(* Maps a part through a presumably bijective function f. *)\nlet map_part f part =\n  { p_cardinal = part.p_cardinal ;\n    compute    = (fun index -> f (part.compute index)) }\n\n(* Builds a part from a finite list of values. *)\nlet part_from_list values =\n  let avalues = Array.of_list values in\n  { p_cardinal = boi (Array.length avalues) ;\n    compute = (fun n -> avalues.(iob n)) }\n\n(*** Union ***)\n\n(* Finds in which part (of the given list) is the given index. *)\nlet rec standard_compute_union_aux partlist index =\n  match partlist with\n  | [] ->\n      (* Index is out of part list. Cannot happen. *)\n      assert false\n  | p :: ps ->\n      if p.p_cardinal <= index then standard_compute_union_aux ps (index -- p.p_cardinal)\n      else (p, index)\n\n(* Disjoint union of these parts. *)\nlet union_parts parts =\n\n  let whichpart = standard_compute_union_aux parts in\n\n  let compute index = \n    let (p, index) = whichpart index in\n    p.compute index\n  in\n\n  (* The cardinal of the disjoint union is the sum of cardinals. *)\n  let pre_result =\n    { p_cardinal = myfold parts bigzero (fun acu p -> acu ++ p.p_cardinal) ;\n      compute }\n  in\n  shuffle pre_result\n\n\n(*** Product ***)\n\n(* Split the index into coordinates in the different parts.\n * We use div & mod. *)\nlet rec compute_product_vector index part_revvector acu =\n  match part_revvector with\n  | [] -> acu\n  | pcard :: others ->\n      assert (sign pcard = 1) ;\n      let (index', mod') = quomod index pcard in\n      compute_product_vector index' others (mod' :: acu)\n\nlet standard_compute_product_aux parts =\n  let part_revvector = myrevmap parts get_cardinal in\n  fun index -> compute_product_vector index part_revvector []\n\n(* Cartesian product of these parts. \n * Caution! compute returns a (product) value in the reversed order of the part list. *)\nlet product_parts parts =\n\n  assert (parts <> []) ;\n  let whichindexes = standard_compute_product_aux parts in\n\n  let compute index =\n    let vector = whichindexes index in\n    (* Result is reversed. *)\n    myrevmap2 vector parts (fun index p -> p.compute index)    \n  in\n\n  let p_cardinal = myfold parts bigone (fun acu p -> acu ** p.p_cardinal) in\n  (* Note: p_cardinal can be = 0, if one part has size 0 (this can happen if one enumeration is finite). *)\n  \n  (* The cardinal of the product it the product of cardinals. *)\n  let pre_result = \n    { p_cardinal ;\n      compute }\n  in\n  shuffle pre_result\n\n\n","open Parts\nopen Convenience\n\n(******************************************************************)\n(*                  ENUMERATIONS                                  *)\n(******************************************************************)\n\n(* An enumeration *)\ntype 'a t = {\n    (* Number of elements. None means infinity. *)\n    cardinal : Z.t option ;\n    \n    (* Number of parts. None means infinity. *)\n    n_parts  : int option ;\n\n    (* An extensible array of parts, in order to compute parts lazily. *)\n    parts : ('a part) ExtArray.t ;\n    \n    (* Function used to create a new part when necessary. *)\n    new_part : (int -> 'a part) ;\n\n    (* A title, mostly for debugging. *)\n    title : string Lazy.t ;\n  }\n\nlet cardinal exen = exen.cardinal\n\n(******************************************************************)\n(*             ACCESSING ENUMERATIONS                             *)\n(******************************************************************)\n\n(* Check that the required part index exists in the given enumeration. *)\nlet check_array_index index exen =\n  match exen.n_parts with\n  | None -> true\n  | Some n -> index < n\n\n(* Get (possibly by forcing evaluation) the part corresponding to the given index. *)\nlet get_part exen array_index =\n\n  if check_array_index array_index exen then\n    let part = ExtArray.get exen.parts array_index in\n\n    let part =\n      if part == uninitialized_part then\n\tbegin\n\t  (* This cell is uninitialized. Set it first. *)\n\t  let newcell = exen.new_part array_index in\n\t  ExtArray.set exen.parts array_index newcell ;\n\t  newcell\n\tend  \n      else\n\tpart\n    in\n\n    part\n\n  else\n      empty_part\n\n(* Find in which part of an enumearation an index holds. *)\nlet rec get_in_parts exen value_index array_index =\n\n  let part = get_part exen array_index in\n\n  (* Is the index in range of this part ? *)\n  if part.p_cardinal <= value_index then\n    (* No. Go to next part. *)\n    get_in_parts exen (value_index -- part.p_cardinal) (array_index + 1)\n  else\n    (* OK. Get the value in this part. *)\n    part.compute value_index\n\n(* Gets a value, given an absolute index. *)\nlet get exen index =\n  begin match exen.cardinal with\n  | None -> ()\n  | Some max -> \n      if max <= index then \n\tfailwith (Printf.sprintf \"Exenum.get: index is out of bounds : %s / %s\" (sob index) (sob (max -- bigone)))\n  end ;\n  \n  get_in_parts exen index 0\n\n(******************************************************************)\n(*              BUILDING SIMPLE ENUMERATIONS                      *)\n(******************************************************************)\n\n(* An enumeration from a single part. *)\nlet from_single_part title a_part =\n  let parts = ExtArray.create 1 empty_part in\n  ExtArray.set parts 0 a_part ;  \n\n  { cardinal = Some (a_part.p_cardinal) ;\n    n_parts  = Some 1 ;\n    parts ;\n    (* This enumeration is finite. We should never need to create a new cell. *)\n    new_part = (fun _ -> assert false) ;\n    title }\n\n(* An enumeration from a list of values. *)\nlet from_list ?(name=\"unnamed\") values = from_single_part (lazy name) (part_from_list values)\n\n\n(******************************************************************)\n(*           ALGEBRAIC OPERATIONS ON ENUMERATIONS                 *)\n(******************************************************************)\n\n(* Pay *)\nlet pay l_exen =\n\n  let parts = ExtArray.create 1 uninitialized_part in\n  ExtArray.set parts 0 empty_part ;\n\n  (* On the first call to new_part, we will check that the argument function is indeed infinite. *)\n  let is_infinite = lazy\n      ((Lazy.force l_exen).cardinal = None)\n  in\n\n  let new_part array_index =\n    assert (array_index > 0) ;\n    assert (Lazy.force is_infinite) ;\n    get_part (Lazy.force l_exen) (array_index - 1)\n  in\n\n  { cardinal = None ;\n    n_parts = None ;\n    parts ;\n    new_part ;\n    title = lazy (\"pay (...)\") }\n\n(* Maps an enumeration *)\nlet map exen f = \n\n  let parts = ExtArray.create 1 uninitialized_part in\n\n  let new_part array_index =\n    let part = get_part exen array_index in\n    map_part f part\n  in\n\n  { cardinal = exen.cardinal ;\n    n_parts = exen.n_parts ;\n    parts ;\n    new_part ;\n    title = lazy (\"map (\" ^ Lazy.force exen.title ^ \")\") }\n\n\n(* Finite sub-enumeration *)\nlet sub ~max exen =\n\n  let newcardinal =\n    match exen.cardinal with\n    | None -> Some max\n    | Some bound -> \n\tif max <= bound then Some max\n\telse Some bound\n  in\n\n  { exen with cardinal = newcardinal }\n\n(*** DISJOINT UNION ***)\n\n(* Compute the possibly infinite sum of cardinals. *)\nlet rec sum_cardinals acu = function\n  | [] -> Some acu\n  | exen :: exens ->\n      begin match exen.cardinal with\n      | None -> None (* Infinite *)\n      | Some n -> sum_cardinals (acu ++ n) exens\n      end\n\n(* max, taking account of infinity (None) *)\nlet infmax a b =\n  match (a,b) with\n  | (None, _) | (_, None) -> None\n  | (Some x, Some y) -> Some (max x y)\n\n(* Returns the maximal number of parts of these enumerations. *)\nlet max_parts exens = myfold exens (Some 0) (fun acu exen -> infmax acu exen.n_parts)\n\n(* Disjoint union of enumerations. *)\nlet union exens =\n  let cardinal = sum_cardinals bigzero exens in  \n  let parts = ExtArray.create 1 uninitialized_part in\n  let new_part array_index = union_parts (List.map (fun ex -> get_part ex array_index) exens) in\n\n  { cardinal ;\n    n_parts = max_parts exens ;\n    parts ;\n    new_part ;\n    title = lazy (\"union (\" ^ (sep (fun e -> Lazy.force e.title) \", \" exens) ^ \")\") }\n\n\n(*** CARTESIAN PRODUCT ***)\n\n(* Compute the possibly infinite product of cardinals. \n * If one of them is empty, the result is empty. *)\nlet rec prod_cardinals acu = function\n  | [] -> acu\n  | exen :: exens ->\n      begin match (exen.cardinal, acu) with\n      | None, _ -> prod_cardinals None exens\n      | (Some z,_) when z = bigzero -> Some bigzero\n      | Some _, None -> prod_cardinals None exens\n      | Some n, Some k -> prod_cardinals (Some (n ** k)) exens\n      end\n\n(* Find all vectors that reach the given max depth. \n * Input: the expected (max) depth. \n *        the vector of maximal indexes reachable by each coordinate.\n *          (these maximal indexes are guaranteed to be <= max depth). *)\n\n(* Algorithm: brut force enumeration of all tuples.\n * An optimization, though: we know if the max depth has been reached in the current temporary vector,\n * and we know at which position is the 'last chance' of reaching the max depth. *)\n\n(* For efficiency, rev_max is the reversed list of max_indexes. \n * flag indicates if max depth has been reached in the current temporary vector. \n * acu is the list of all vectors. \n * pos is the current position in the reversed max_indexes list. *)\nlet rec find_vectors_aux last_chance depth flag acu temp_vect pos rev_max = \n\n  match rev_max with\n  (* This vector is finished. Add it to the accumulator. *)\n  | [] ->\n      assert flag ; (* The maximal depth must have been reached. *)\n      temp_vect :: acu\n\n  | current_vup :: others ->\n\n      let (vlow, vup) =\n\t(* Particular case: if this is the last chance and flag is false. *)\n\tif (not flag) && pos = last_chance then\n\t  begin\n\t    assert (current_vup = depth) ;\n\t    (depth, depth)\n\t  end\n\n\telse (0, current_vup)\n      in\n\n      (* Iterate over all these values. *)\n      let racu = ref acu in\n      \n      for current_index = vlow to vup do\n\tracu := find_vectors_aux last_chance depth (flag || current_index = depth) !racu (current_index :: temp_vect) (pos+1) others ;\n      done ;\n\n      (* Finished. *)\n      !racu\n\n      \nlet find_vectors depth rev_max_indexes = \n \n  (* Find the position of the last chance. *)\n  let (_, last_chance) = myfold rev_max_indexes (0, (-1)) \n      begin fun (current_pos, last) v -> if v = depth then (current_pos+1, current_pos) else (current_pos+1, last) end\n  in\n  assert (last_chance >= 0) ; (* The maximal depth must be reachable. We never try to build a part that cannot be built. *)\n\n  find_vectors_aux last_chance depth false [] [] 0 rev_max_indexes\n\n(* Maps a vector to a rev_list of parts. *)\nlet vector_to_part_list exens vector = \n  (try myrevmap2 exens vector get_part with _ -> assert false)\n\n(* Creates a new part with depth array_index corresponding to the cartesian product of the given enumerations. *)\nlet prod_parts array_index exens =\n  (* This part is the union of cartesian products of PARTS, at least one of them being at the given depth. *)\n\n  (* Def: a 'vector' is a vector of indexes. Each index corresponds to an enumeration. \n   * The length of the vector = the length of the list 'exens'. *)\n\n  assert (exens <> []) ;\n\n  (* Get the rev_vectors of maximal part indexes, but never further than array_index. *)\n  let max_revindexes = myrevmap exens\n      begin fun ex ->\n\tmatch ex.n_parts with\n\t| None -> array_index (* Infinite *)\n\t| Some n -> min (n-1) array_index\n      end\n  in\n\n  (* List all vectors that satisfy the current depth (i.e. at least one index is the expected array_index). *)\n  let all_vectors = find_vectors array_index max_revindexes in\n\n  assert (all_vectors <> []) ;\n  \n  (* Map these vectors to part lists. *)\n  let all_rev_parts = List.rev_map (vector_to_part_list exens) all_vectors in\n\n  (* Map each part list to a product part. \n   * product_parts reverses the tuples. *)\n  let all_prod_parts = List.rev_map product_parts all_rev_parts in\n\n  (* Get the union *)\n  union_parts all_prod_parts\n\n(* Cartesian product. *)\nlet product exens =\n  \n  let cardinal = prod_cardinals (Some bigone) exens in\n  let parts = ExtArray.create 1 uninitialized_part in\n\n  { cardinal ;\n    n_parts = max_parts exens ;\n    parts ;\n    new_part = (fun array_index -> prod_parts array_index exens) ;\n    title = lazy (\"product (\" ^ (sep (fun e -> Lazy.force e.title) \", \" exens) ^ \")\") }\n\n","open Exen\nopen Convenience\n\n(* Generic version that can be instantiated to a Lwt version and a non-lwt version. *)\t\t\t\t\t\nlet gen_tester print ?tos bind unit exen ?(from=bigzero) ?upto ?(verbose_period=10000) ~len f =\n  \n  assert (len > 0) ;\n  assert (verbose_period > 0) ;\n\n  let bigverbose_period = boi verbose_period in\n\n  let test_current count index =\n    let verbose = verbose_period > 0 && Z.equal bigzero (bigmod count bigverbose_period) in\n    let test_value = get exen index in\n    \n    bind (if verbose then print (Printf.sprintf \"Test number %s, index #%s ... %s\" (sob count) (sob index)\n                                   (match tos with None -> \"\" | Some tos -> \"with \" ^ tos test_value ^ \" ... \"))\n          else unit)\n      \n\t (fun () ->\n\t  bind (f test_value)\n\t       (fun () -> if verbose then print \"done\\n\" else unit))\n  in\n  \n  (* for loop, in which we double the current index every len iterations. *)\n  let rec iterate count current remaining =\n    (* End of this part? If yes, current := current * 2. *)\n    if remaining = 0 then\n      iterate count (2 **. current) len\n\n    else\n      (* Have we reached the upper bound? *)\n      let continue =\n\tmatch upto with\n\t| None -> true\n\t| Some upper_bound -> big_compare current upper_bound < 0\n      in\n\n      if continue then\n\tbegin\n\t  bind (test_current count current)\n\t       (fun () -> iterate (succ count) (succ current) (remaining - 1))\n\tend\n      else\n\t(* We're done. *)\n\tunit\n  in\n\n  iterate bigzero from len\n","open Exenum_internals\n\nopen Parts\nopen Exen\nopen Convenience\n\ntype 'a enum = 'a Exen.t\ntype 'a t = 'a enum\n\nlet get_exen x = x\n\nlet product   = Exen.product\nlet union     = Exen.union\nlet from_list = Exen.from_list\nlet single ?name x  = from_list ?name [x]\nlet map       = Exen.map\nlet get       = Exen.get\nlet cardinal  = Exen.cardinal\nlet pay       = Exen.pay\nlet sub       = Exen.sub\n\n(* Boilerplate code. *)\ntype ('a,'b) tuple2 = C1_2 of 'a | C2_2 of 'b\n\nlet c1_2 x = C1_2 x\nlet c2_2 x = C2_2 x\n\nlet proj2 = function\n  | [C1_2 a ; C2_2 b] -> (a,b)\n  | _ -> assert false\n\nlet pair ex1 ex2 = \n  let mex1 = map ex1 c1_2\n  and mex2 = map ex2 c2_2 in\n  map (product [mex1 ; mex2]) proj2\n\ntype ('a,'b,'c) tuple3 = C1_3 of 'a | C2_3 of 'b | C3_3 of 'c\n\nlet c1_3 x = C1_3 x\nlet c2_3 x = C2_3 x\nlet c3_3 x = C3_3 x\n\nlet proj3 = function\n  | [C1_3 a ; C2_3 b ; C3_3 c] -> (a,b,c)\n  | _ -> assert false\n\nlet triple ex1 ex2 ex3 =\n  let mex1 = map ex1 c1_3\n  and mex2 = map ex2 c2_3 \n  and mex3 = map ex3 c3_3 in\n  map (product [mex1 ; mex2 ; mex3]) proj3\n\nlet tuple2 = pair\nlet tuple3 = triple\nlet tuple4 e1 e2 e3 e4 = map (pair (triple e1 e2 e3) e4) (fun ((a,b,c), d) -> (a,b,c,d))\n\nlet tuple5 e1 e2 e3 e4 e5 = map (pair (triple e1 e2 e3) (pair e4 e5)) (fun ((a,b,c), (d,e)) -> (a,b,c,d,e))\nlet tuple6 e1 e2 e3 e4 e5 e6 = map (pair (triple e1 e2 e3) (triple e4 e5 e6)) (fun ((a,b,c),(d,e,f)) -> (a,b,c,d,e,f))\n\n(******************************************************************)\n(*                     BUILTINS                                   *)\n(******************************************************************)\n\nlet char_part =\n  { p_cardinal = boi 256 ;\n    compute = (fun n -> Char.chr (iob n)) }\n\n(* Usual chars: from 32 to 125. *)\nlet usual_char_part =\n  { p_cardinal = boi (125 - 32 + 1) ;\n    compute = (fun n -> Char.chr (32 + iob n)) }\n\nlet e_unit  = from_list ~name:\"Unit\" [ () ]\nlet e_bool  = from_list ~name:\"Bool\" [true ; false]\nlet e_char  = from_single_part (lazy \"Char\") char_part\nlet e_pchar = from_single_part (lazy \"Printable-Char\") usual_char_part\n\n(* Big ints & ints *)\nlet e_zero = from_list ~name:\"Zero\" [bigzero]\nlet e_one = from_list ~name:\"One\" [bigone]\n\nlet e_bigpos =\n\n  let big2n n = n ++ n in\n  let big2np1 n = succ (big2n n) in\n  \n  let rec e_bigpos = lazy (union [e_one ; map (pay e_bigpos) big2n ; map (pay e_bigpos) big2np1 ]) in\n  Lazy.force e_bigpos\n\n\n\nlet e_bignat = union [e_zero ; e_bigpos]\n\nlet e_bigneg = map e_bigpos minus\n\nlet e_bigint = union [e_zero ; e_bigneg ; e_bigpos]\n\nlet biginterval_part a b =\n  { p_cardinal = succ (b -- a) ;\n    compute = (fun n -> a ++ n) }\n\nlet e_biginterval a b = from_single_part (lazy (Printf.sprintf \"[%s-%s]\" (sob a) (sob b))) (biginterval_part a b)\n\nlet interval_part a b =\n  { p_cardinal = boi (b - a + 1) ;\n    compute = (fun n -> a + iob n) }\n\nlet e_interval a b = from_single_part (lazy (Printf.sprintf \"[%d-%d]\" a b)) (interval_part a b)\n\nlet bmax_int = boi max_int\n\nlet toint b = try iob (bigmod b bmax_int) with _ -> 0\n\nlet e_nat = map e_bignat toint \nlet e_pos = map e_bigpos toint\nlet e_neg = map e_bigpos (fun b -> - (toint b))\nlet e_int = union [single 0 ; e_pos ; e_neg]\n    \n(* Strings *)\nlet e_string_from_echar enum_chars =\n  let rec enum = lazy ( union [ map e_unit (fun () -> \"\") ; \n\t\t\t\tmap (pair (map enum_chars (String.make 1)) (pay enum))\n\t\t\t\t  (fun (a,b) -> a ^ b) \n\t\t\t      ] )\n  in\n  Lazy.force enum\n\nlet e_string = e_string_from_echar e_pchar\nlet e_rstring charlist = e_string_from_echar (from_list ~name:\"The given chars\" charlist)\n\nlet e_emptylist () = from_list ~name:\"Emptylist\" [ [] ]\n\n(* Enumerations of lists. *)\nlet e_list exen =\n  let rec enum = lazy (union [ e_emptylist () ;\n\t\t\t       map (pair exen (pay enum))\n\t\t\t\t (fun (a,b) -> a :: b)\n\t\t\t     ] )\n  in\n  Lazy.force enum\n\nlet e_ne_list exen = map (pair exen (e_list exen)) (fun (a,b) -> a :: b)\n  \n(* Enumerations of arrays. *)\nlet e_array exen = map (e_list exen) Array.of_list\n\nlet e_option exen = union [single None ; map exen (fun x -> Some x)]\n\nlet bigshow exen to_string n1 n2 =\n  for i = 0 to n2 - 1 do\n    let index = n1 +++ i in\n    Printf.printf \"Value #%d is %s\\n\" i (to_string (get exen index)) ;\n  done ;\n  ()\n\nlet show exen to_string n1 n2 = bigshow exen to_string (boi n1) n2\n\nlet tester exen ?from ?upto ?verbose_period ?tos ~len f =\n  Tester.gen_tester (Printf.printf \"%s%!\") ?tos (fun a b -> ignore(a) ; b ()) () exen ?from ?upto ?verbose_period ~len f\n\n\n","(* *********************************************************************)\n(*                                                                     *)\n(*              The Compcert verified compiler                         *)\n(*                                                                     *)\n(*          Xavier Leroy, INRIA Paris-Rocquencourt                     *)\n(*                                                                     *)\n(*  Copyright Institut National de Recherche en Informatique et en     *)\n(*  Automatique.  All rights reserved.  This file is distributed       *)\n(*  under the terms of the GNU Lesser General Public License as        *)\n(*  published by the Free Software Foundation, either version 2.1 of   *)\n(*  the License, or  (at your option) any later version.               *)\n(*  This file is also distributed under the terms of the               *)\n(*  INRIA Non-Commercial License Agreement.                            *)\n(*                                                                     *)\n(* *********************************************************************)\n\nlet camlstring_of_coqstring (s: char list) =\n  let r = Bytes.create (List.length s) in\n  let rec fill pos = function\n  | [] -> r\n  | c :: s -> Bytes.set r pos c; fill (pos + 1) s\n  in Bytes.to_string (fill 0 s)\n\n\nlet coqstring_of_camlstring s =\n  let rec cstring accu pos =\n    if pos < 0 then accu else cstring (s.[pos] :: accu) (pos - 1)\n  in cstring [] (String.length s - 1)\n  ","open Angstrom\nopen UIML.Formulas\nopen UIML.Datatypes\nopen Stringconversion\n\nlet is_space =\n  function | ' ' | '\\t' | '\\n' -> true | _ -> false\n\nlet spaces = skip_while is_space\n\nlet parens p = char '(' *> p <* char ')'\n\nlet box p = ((char '[' *> char ']') <|> (char '\\xE2' *> char '\\x96' *> char '\\xA1')) *> spaces *> p\n  >>| fun x -> Box x\nlet diamond p = ((char '<' *> char '>') <|> (char '\\xE2' *> char '\\x8B' *> char '\\x84')) *> spaces *> p\n  >>| fun x -> Implies (Box (Implies(x, Bot)), Bot)\n\nlet neg p = ((char '~') <|> (char '\\xC2' *> char '\\xAC')) *> spaces *> p\n  >>| fun x -> Implies(x, Bot)\n\nlet disj = spaces *> ((char '\\xE2' *> char '\\x88' *> char '\\xA8') <|> char '|') *> spaces *>  return (fun x y -> Or(x, y))\nlet conj = spaces *> ((char '\\xE2' *> char '\\x88' *> char '\\xA7') <|> char '&') *> spaces *> return (fun x y -> And (x, y))\n\nlet modal (p : form t) : form t = box p <|> neg p <|> diamond p\nlet impl = spaces *> ((char '\\xE2' *> char '\\x86' *> char '\\x92') <|> (char '-' *> char '>')) *> spaces *> return (fun x y -> Implies(x, y))\n\n(* this is ⊥ *)\nlet bot = spaces *> ((char '\\xE2' *> char '\\x8A' *> char '\\xA5') <|> char '#'\n                     <|> char 'F') *> spaces *> return (Bot)\nlet top = spaces *> ((char '\\xE2' *> char '\\x8A' *> char '\\xA4') <|> char 'T') *> spaces *> return (Implies(Bot,Bot))\n\n\nlet letter = function | 'a' .. 'z' -> true | _ -> false\nlet letter_or_digit = function | 'a' .. 'z' | 'A' .. 'Z' | '0' .. '9' -> true | _ -> false\n\nlet identifier = lift2 (^) (take_while1 letter) (take_while letter_or_digit) >>| fun x -> Var (coqstring_of_camlstring x)\n\n(* chain of left-associative operations *)\nlet chainl1 e op =\n  let rec go acc =\n    (lift2 (fun f x -> f acc x) op e >>= go) <|> return acc in\n  e >>= fun init -> go init\n\n  let chainr1 e op =\n    let rec go acc =\n      (lift2 (fun f x -> f acc x) op (e >>= go)) <|> return acc in\n    e >>= go\n\nlet chainmod (e : 'a t) (op : 'a t -> 'a t) : 'a t =\n  fix (fun x -> op x <|> e)\n\n  (*\n  let rec go (acc : 'a) = lift (fun f -> f acc) op  *> (e >>= go) <|> return acc in e >>= go\n  *)\n    (*\n  p ‘chainr1‘ op =\n  p ‘bind‘ \\x ->\n  [f x y | f <- op, y <- p ‘chainr1‘ op] ++ [x]\n*)\nlet expr : form t =\n  fix (fun expr ->\n    let factor = parens expr <|> identifier <|> bot <|> top in\n    let modality = chainmod factor modal  in\n    let term   = chainl1 modality conj in\n    let disjunctions = spaces *> chainl1 term disj <* spaces in\n    spaces *> chainr1 disjunctions impl <* spaces\n    )\n\nexception ParseError\nlet eval (str:string) : form =\n  match parse_string ~consume:All expr str with\n  | Ok v      -> v\n  | Error _ -> raise ParseError;;\n","open UIML.Formulas\nopen Stringconversion\nopen UIML.Datatypes\n\nlet rec int_of_nat = function\n| O -> 0\n| S n -> 1 + int_of_nat n\n\n\nlet string_of_formula ?(classical = false) =\n  let rec string_of_formula =\n  function\n| Var v -> camlstring_of_coqstring v\n| Bot -> \"⊥\"\n| Implies(Bot, Bot) -> \"⊤\"\n(* diamond *)\n| Implies(Box(Implies(f, Bot)),Bot) when classical -> \"⋄ \" ^ bracket f\n(* double negation *)\n| Implies(Implies(f, Bot), Bot) when classical -> string_of_formula f\n| Box f -> \"□ \" ^ bracket f\n| And (f, g) -> bracket f ^ \" ∧ \" ^ bracket g\n| Or (f, g) -> bracket f ^ \" ∨ \" ^ bracket g\n| Implies (f, Bot) -> \"¬ \" ^ bracket f (* pretty print ¬ *)\n| Implies (f, g) -> bracket f ^ \" → \" ^ bracket g\nand bracket e = match e with\n| Implies(Implies(f, Bot), Bot) when classical -> bracket f\n| Implies(Box(Implies(f, Bot)),Bot) when classical -> \"⋄ \" ^ bracket f\n| Var _ | Bot | Implies(_, Bot) | Box _ -> string_of_formula e\n| e -> \"(\" ^ string_of_formula e ^ \")\"\n  in string_of_formula","open UIML.UIML_extraction\nopen UIML.Formulas\nopen Js_of_ocaml\nopen Modal_expressions_parser\nopen Stringconversion\nopen Printer\n\nlet catch_e f = try f() with\n  ParseError -> \"Parse Error\"\n| Failure s -> \"Error: \" ^ s\n| e -> \"Error: \" ^ Printexc.to_string e\n\nlet fail_on_modality (f : form) : form =\n  let rec aux = function\n  | Box _ -> failwith \"The provided formula contains modalities\"\n  | Or(x, y) | Implies(x, y) | And(x, y) -> aux x ; aux y\n  | _ -> ()\n  in (aux f; f)\n\n(* export functions to js *)\n\nlet v : variable = coqstring_of_camlstring \"p\"\nlet _ =\n  Js.export \"UIML\"\n    (object%js\n(* TODO: iE and iA are just an alias for isl_E and isl_A,\nthere should really at least be a function that checks that\niE and iA are given box-free formulas as input.*)\n       method iA s =  catch_e (fun () -> s |> eval |> fail_on_modality |> isl_A v |> string_of_formula)\n       method iE s =  catch_e (fun () -> s |> eval |> fail_on_modality |> isl_E v |> string_of_formula)\n       method islA s = catch_e (fun () -> s |> eval |> isl_simplified_A v |> string_of_formula)\n       method islE s = catch_e (fun () -> s |> eval |> isl_simplified_E v |> string_of_formula)\n       method k s = catch_e (fun () -> s |> eval |> gl_UI v |> string_of_formula ~classical: true)\n       method gl s = catch_e (fun () -> s |> eval |> k_UI v |> string_of_formula ~classical: true)\n       method parse s = catch_e (fun () -> s |> eval |> string_of_formula)\n     end);;\n\n","(**************************************************************************)\n(*                                                                        *)\n(*                                 OCaml                                  *)\n(*                                                                        *)\n(*             Xavier Leroy, projet Cristal, INRIA Rocquencourt           *)\n(*                                                                        *)\n(*   Copyright 1996 Institut National de Recherche en Informatique et     *)\n(*     en Automatique.                                                    *)\n(*                                                                        *)\n(*   All rights reserved.  This file is distributed under the terms of    *)\n(*   the GNU Lesser General Public License version 2.1, with the          *)\n(*   special exception on linking described in the file LICENSE.          *)\n(*                                                                        *)\n(**************************************************************************)\n\n(* Ensure that [at_exit] functions are called at the end of every program *)\n\nlet _ = do_at_exit()\n"]}