[
    {
        "filename": "FoML/FoML/Main.lean",
        "line": 22,
        "tactic_state_before": "n : ℕ\nΩ : Type u\ninst✝³ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\nf : ι → 𝒳 → ℝ\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → 𝒳\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\n⊢ (∫ (x : Fin n → Ω), (fun ω => uniformDeviation n f μ X (X ∘ ω)) x ∂Measure.pi fun x => μ) ≤\n    2 • rademacherComplexity n f μ X",
        "tactic": "apply le_of_mul_le_mul_left _ (Nat.cast_pos.mpr hn)",
        "tactic_state_after": "[n : ℕ\n Ω : Type u\n inst✝³ : MeasurableSpace Ω\n ι : Type v\n 𝒳 : Type w\n μ : Measure Ω\n f : ι → 𝒳 → ℝ\n inst✝² : Nonempty ι\n inst✝¹ : Countable ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → 𝒳\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\n ⊢ (↑n * ∫ (x : Fin n → Ω), (fun ω => uniformDeviation n f μ X (X ∘ ω)) x ∂Measure.pi fun x => μ) ≤\n     ↑n * 2 • rademacherComplexity n f μ X]",
        "goal": "n : ℕ\nΩ : Type u\ninst✝³ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\nf : ι → 𝒳 → ℝ\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → 𝒳\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\nh_original_goal :\n  (∫ (x : Fin n → Ω), (fun ω => uniformDeviation n f μ X (X ∘ ω)) x ∂Measure.pi fun x => μ) ≤\n    2 • rademacherComplexity n f μ X\n⊢ (↑n * ∫ (x : Fin n → Ω), (fun ω => uniformDeviation n f μ X (X ∘ ω)) x ∂Measure.pi fun x => μ) ≤\n    ↑n * 2 • rademacherComplexity n f μ X",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_0.{w, v, u} {n : ℕ} {Ω : Type u} [inst : MeasurableSpace Ω] {ι : Type v} {𝒳 : Type w}\n  {μ : Measure Ω} {f : ι → 𝒳 → ℝ} [inst_1 : Nonempty ι] [inst_2 : Countable ι] [inst_3 : IsProbabilityMeasure μ]\n  (hn : 0 < n) (X : Ω → 𝒳) (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b)\n  (hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b)\n  (h_original_goal :\n    (∫ (x : Fin n → Ω), (fun ω => uniformDeviation n f μ X (X ∘ ω)) x ∂Measure.pi fun x => μ) ≤\n      2 • rademacherComplexity n f μ X) :\n  (↑n * ∫ (x : Fin n → Ω), (fun ω => uniformDeviation n f μ X (X ∘ ω)) x ∂Measure.pi fun x => μ) ≤\n    ↑n * 2 • rademacherComplexity n f μ X := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_0.{w, v, u} {n : Nat} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {ι : Type v}\n  {𝒳 : Type w} {μ : @MeasureTheory.Measure.{u} Ω inst} {f : ι → 𝒳 → Real} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : Countable.{v + 1} ι] [inst_3 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → 𝒳)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω 𝒳 Real (f i) X))\n  {b : Real} (hb : @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) b)\n  (hf' : ∀ (i : ι) (x : 𝒳), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i x)) b)\n  (h_original_goal :\n    @LE.le.{0} Real Real.instLE\n      (@MeasureTheory.integral.{u, 0} (Fin n → Ω) Real Real.normedAddCommGroup\n        (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n          (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n          (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n        (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst)\n        (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n          fun (x : Fin n) => μ)\n        fun (x : Fin n → Ω) =>\n        (fun (ω : Fin n → Ω) =>\n            @uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω))\n          x)\n      (@HSMul.hSMul.{0, 0, 0} Nat Real Real\n        (@instHSMul.{0, 0} Nat Real (@AddMonoid.toNatSMul.{0} Real Real.instAddMonoid))\n        (@OfNat.ofNat.{0} Nat 2 (instOfNatNat 2)) (@rademacherComplexity.{u, v, w} Ω inst ι 𝒳 n f μ X))) :\n  @LE.le.{0} Real\n    (@Preorder.toLE.{0} Real\n      (@PartialOrder.toPreorder.{0} Real\n        (@OrderedAddCommMonoid.toPartialOrder.{0} Real\n          (@OrderedSemiring.toOrderedAddCommMonoid.{0} Real Real.orderedSemiring))))\n    (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n      (@Nat.cast.{0} Real\n        (@AddMonoidWithOne.toNatCast.{0} Real\n          (@AddCommMonoidWithOne.toAddMonoidWithOne.{0} Real\n            (@NonAssocSemiring.toAddCommMonoidWithOne.{0} Real\n              (@Semiring.toNonAssocSemiring.{0} Real (@OrderedSemiring.toSemiring.{0} Real Real.orderedSemiring)))))\n        n)\n      (@MeasureTheory.integral.{u, 0} (Fin n → Ω) Real Real.normedAddCommGroup\n        (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n          (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n          (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n        (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst)\n        (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n          fun (x : Fin n) => μ)\n        fun (x : Fin n → Ω) =>\n        (fun (ω : Fin n → Ω) =>\n            @uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω))\n          x))\n    (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n      (@Nat.cast.{0} Real\n        (@AddMonoidWithOne.toNatCast.{0} Real\n          (@AddCommMonoidWithOne.toAddMonoidWithOne.{0} Real\n            (@NonAssocSemiring.toAddCommMonoidWithOne.{0} Real\n              (@Semiring.toNonAssocSemiring.{0} Real (@OrderedSemiring.toSemiring.{0} Real Real.orderedSemiring)))))\n        n)\n      (@HSMul.hSMul.{0, 0, 0} Nat Real Real\n        (@instHSMul.{0, 0} Nat Real (@AddMonoid.toNatSMul.{0} Real Real.instAddMonoid))\n        (@OfNat.ofNat.{0} Nat 2 (instOfNatNat 2)) (@rademacherComplexity.{u, v, w} Ω inst ι 𝒳 n f μ X))) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem le_of_mul_le_mul_left (a b c : Associates M) (ha : a ≠ 0) : a * b ≤ a * c → b ≤ c\n  | ⟨d, hd⟩ => ⟨d, mul_left_cancel₀ ha <| by rwa [← mul_assoc]⟩\n\ntheorem one_or_eq_of_le_of_prime {p m : Associates M} (hp : Prime p) (hle : m ≤ p) :\n    m = 1 ∨ m = p"
            },
            {
                "library": "Mathlib",
                "definition": "theorem le_of_mul_le_mul_left [PosMulReflectLE α] (bc : a * b ≤ a * c) (a0 : 0 < a) : b ≤ c"
            },
            {
                "library": "Mathlib",
                "definition": "theorem le_of_mul_le_mul_left {a b c : Ordinal} (h : c * a ≤ c * b) (h0 : 0 < c) : a ≤ b"
            }
        ]
    },
    {
        "filename": "FoML/FoML/Main.lean",
        "line": 24,
        "tactic_state_before": "case h.e'_3\nn : ℕ\nΩ : Type u\ninst✝³ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\nf : ι → 𝒳 → ℝ\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → 𝒳\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\n⊢ (↑n * ∫ (x : Fin n → Ω), (fun ω => uniformDeviation n f μ X (X ∘ ω)) x ∂Measure.pi fun x => μ) =\n    ∫ (x : Fin n → Ω),\n      (fun ω => ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|) x ∂Measure.pi fun x => μ",
        "tactic": "rw [← integral_mul_left]",
        "tactic_state_after": "[case h.e'_3\n n : ℕ\n Ω : Type u\n inst✝³ : MeasurableSpace Ω\n ι : Type v\n 𝒳 : Type w\n μ : Measure Ω\n f : ι → 𝒳 → ℝ\n inst✝² : Nonempty ι\n inst✝¹ : Countable ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → 𝒳\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\n ⊢ (∫ (a : Fin n → Ω), ↑n * uniformDeviation n f μ X (X ∘ a) ∂Measure.pi fun x => μ) =\n     ∫ (x : Fin n → Ω),\n       (fun ω => ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|) x ∂Measure.pi fun x => μ]",
        "goal": "n : ℕ\nΩ : Type u\ninst✝³ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\nf : ι → 𝒳 → ℝ\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → 𝒳\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\nh_original_goal :\n  (↑n * ∫ (x : Fin n → Ω), (fun ω => uniformDeviation n f μ X (X ∘ ω)) x ∂Measure.pi fun x => μ) =\n    ∫ (x : Fin n → Ω),\n      (fun ω => ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|) x ∂Measure.pi fun x => μ\n⊢ (∫ (a : Fin n → Ω), ↑n * uniformDeviation n f μ X (X ∘ a) ∂Measure.pi fun x => μ) =\n    ∫ (x : Fin n → Ω),\n      (fun ω => ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|) x ∂Measure.pi fun x => μ",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_1.{w, v, u} {n : ℕ} {Ω : Type u} [inst : MeasurableSpace Ω] {ι : Type v} {𝒳 : Type w}\n  {μ : Measure Ω} {f : ι → 𝒳 → ℝ} [inst_1 : Nonempty ι] [inst_2 : Countable ι] [inst_3 : IsProbabilityMeasure μ]\n  (hn : 0 < n) (X : Ω → 𝒳) (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b)\n  (hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b)\n  (h_original_goal :\n    (↑n * ∫ (x : Fin n → Ω), (fun ω => uniformDeviation n f μ X (X ∘ ω)) x ∂Measure.pi fun x => μ) =\n      ∫ (x : Fin n → Ω),\n        (fun ω => ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|) x ∂Measure.pi fun x => μ) :\n  (∫ (a : Fin n → Ω), ↑n * uniformDeviation n f μ X (X ∘ a) ∂Measure.pi fun x => μ) =\n    ∫ (x : Fin n → Ω),\n      (fun ω => ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|)\n        x ∂Measure.pi fun x => μ := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_1.{w, v, u} {n : Nat} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {ι : Type v}\n  {𝒳 : Type w} {μ : @MeasureTheory.Measure.{u} Ω inst} {f : ι → 𝒳 → Real} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : Countable.{v + 1} ι] [inst_3 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → 𝒳)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω 𝒳 Real (f i) X))\n  {b : Real} (hb : @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) b)\n  (hf' : ∀ (i : ι) (x : 𝒳), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i x)) b)\n  (h_original_goal :\n    @Eq.{1} Real\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n        (@Nat.cast.{0} Real\n          (@AddMonoidWithOne.toNatCast.{0} Real\n            (@AddCommMonoidWithOne.toAddMonoidWithOne.{0} Real\n              (@NonAssocSemiring.toAddCommMonoidWithOne.{0} Real\n                (@Semiring.toNonAssocSemiring.{0} Real (@OrderedSemiring.toSemiring.{0} Real Real.orderedSemiring)))))\n          n)\n        (@MeasureTheory.integral.{u, 0} (Fin n → Ω) Real Real.normedAddCommGroup\n          (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n            (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n            (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n          (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst)\n          (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n            fun (x : Fin n) => μ)\n          fun (x : Fin n → Ω) =>\n          (fun (ω : Fin n → Ω) =>\n              @uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω))\n            x))\n      (@MeasureTheory.integral.{u, 0} (Fin n → Ω) Real Real.normedAddCommGroup\n        (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n          (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n          (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n        (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst)\n        (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n          fun (x : Fin n) => μ)\n        fun (x : Fin n → Ω) =>\n        (fun (ω : Fin n → Ω) =>\n            @iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup\n                (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                  (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                    fun (k : Fin n) => f i (X (ω k)))\n                  (@HSMul.hSMul.{0, 0, 0} Nat Real Real\n                    (@instHSMul.{0, 0} Nat Real (@AddMonoid.toNatSMul.{0} Real Real.instAddMonoid)) n\n                    (@MeasureTheory.integral.{u, 0} Ω Real Real.normedAddCommGroup\n                      (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n                        (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n                        (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n                      inst μ fun (x : Ω) => (fun (ω' : Ω) => f i (X ω')) x))))\n          x)) :\n  @Eq.{1} Real\n    (@MeasureTheory.integral.{u, 0} (Fin n → Ω) Real\n      (@NonUnitalNormedRing.toNormedAddCommGroup.{0} Real\n        (@NonUnitalNormedCommRing.toNonUnitalNormedRing.{0} Real\n          (@NormedCommRing.toNonUnitalNormedCommRing.{0} Real\n            (@NormedField.toNormedCommRing.{0} Real\n              (@DenselyNormedField.toNormedField.{0} Real (@RCLike.toDenselyNormedField.{0} Real Real.instRCLike))))))\n      (@NormedAlgebra.toNormedSpace.{0, 0} Real Real Real.normedField\n        (@SeminormedCommRing.toSeminormedRing.{0} Real\n          (@NormedCommRing.toSeminormedCommRing.{0} Real\n            (@NormedField.toNormedCommRing.{0} Real\n              (@DenselyNormedField.toNormedField.{0} Real (@RCLike.toDenselyNormedField.{0} Real Real.instRCLike)))))\n        (@RCLike.toNormedAlgebra.{0} Real Real.instRCLike))\n      (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst)\n      (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n        fun (x : Fin n) => μ)\n      fun (a : Fin n → Ω) =>\n      @HMul.hMul.{0, 0, 0} Real Real Real\n        (@instHMul.{0} Real\n          (@Distrib.toMul.{0} Real\n            (@NonUnitalNonAssocSemiring.toDistrib.{0} Real\n              (@NonUnitalNonAssocCommSemiring.toNonUnitalNonAssocSemiring.{0} Real\n                (@NonUnitalNonAssocCommRing.toNonUnitalNonAssocCommSemiring.{0} Real\n                  (@NonUnitalCommRing.toNonUnitalNonAssocCommRing.{0} Real\n                    (@NonUnitalNormedCommRing.toNonUnitalCommRing.{0} Real\n                      (@NormedCommRing.toNonUnitalNormedCommRing.{0} Real\n                        (@NormedField.toNormedCommRing.{0} Real\n                          (@DenselyNormedField.toNormedField.{0} Real\n                            (@RCLike.toDenselyNormedField.{0} Real Real.instRCLike)))))))))))\n        (@Nat.cast.{0} Real\n          (@AddMonoidWithOne.toNatCast.{0} Real\n            (@AddCommMonoidWithOne.toAddMonoidWithOne.{0} Real\n              (@NonAssocSemiring.toAddCommMonoidWithOne.{0} Real\n                (@Semiring.toNonAssocSemiring.{0} Real (@OrderedSemiring.toSemiring.{0} Real Real.orderedSemiring)))))\n          n)\n        (@uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X a)))\n    (@MeasureTheory.integral.{u, 0} (Fin n → Ω) Real Real.normedAddCommGroup\n      (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n        (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n        (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n      (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst)\n      (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n        fun (x : Fin n) => μ)\n      fun (x : Fin n → Ω) =>\n      (fun (ω : Fin n → Ω) =>\n          @iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @abs.{0} Real Real.lattice Real.instAddGroup\n              (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                  fun (k : Fin n) => f i (X (ω k)))\n                (@HSMul.hSMul.{0, 0, 0} Nat Real Real\n                  (@instHSMul.{0, 0} Nat Real (@AddMonoid.toNatSMul.{0} Real Real.instAddMonoid)) n\n                  (@MeasureTheory.integral.{u, 0} Ω Real Real.normedAddCommGroup\n                    (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n                      (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n                      (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n                    inst μ fun (x : Ω) => (fun (ω' : Ω) => f i (X ω')) x))))\n        x) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem integral_mul_left {L : Type*} [RCLike L] (r : L) (f : α → L) :\n    ∫ a, r * f a ∂μ = r * ∫ a, f a ∂μ"
            }
        ]
    },
    {
        "filename": "FoML/FoML/Main.lean",
        "line": 25,
        "tactic_state_before": "case h.e'_3\nn : ℕ\nΩ : Type u\ninst✝³ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\nf : ι → 𝒳 → ℝ\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → 𝒳\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\n⊢ (∫ (a : Fin n → Ω), ↑n * uniformDeviation n f μ X (X ∘ a) ∂Measure.pi fun x => μ) =\n    ∫ (x : Fin n → Ω),\n      (fun ω => ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|) x ∂Measure.pi fun x => μ",
        "tactic": "apply integral_congr_ae (Filter.EventuallyEq.of_eq _)",
        "tactic_state_after": "[n : ℕ\n Ω : Type u\n inst✝³ : MeasurableSpace Ω\n ι : Type v\n 𝒳 : Type w\n μ : Measure Ω\n f : ι → 𝒳 → ℝ\n inst✝² : Nonempty ι\n inst✝¹ : Countable ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → 𝒳\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\n ⊢ (fun a => ↑n * uniformDeviation n f μ X (X ∘ a)) = fun ω =>\n     ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|]",
        "goal": "n : ℕ\nΩ : Type u\ninst✝³ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\nf : ι → 𝒳 → ℝ\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → 𝒳\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\nh_original_goal :\n  (∫ (a : Fin n → Ω), ↑n * uniformDeviation n f μ X (X ∘ a) ∂Measure.pi fun x => μ) =\n    ∫ (x : Fin n → Ω),\n      (fun ω => ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|) x ∂Measure.pi fun x => μ\n⊢ (fun a => ↑n * uniformDeviation n f μ X (X ∘ a)) = fun ω =>\n    ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_2.{w, v, u} {n : ℕ} {Ω : Type u} [inst : MeasurableSpace Ω] {ι : Type v} {𝒳 : Type w}\n  {μ : Measure Ω} {f : ι → 𝒳 → ℝ} [inst_1 : Nonempty ι] [inst_2 : Countable ι] [inst_3 : IsProbabilityMeasure μ]\n  (hn : 0 < n) (X : Ω → 𝒳) (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b)\n  (hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b)\n  (h_original_goal :\n    (∫ (a : Fin n → Ω), ↑n * uniformDeviation n f μ X (X ∘ a) ∂Measure.pi fun x => μ) =\n      ∫ (x : Fin n → Ω),\n        (fun ω => ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|) x ∂Measure.pi fun x => μ) :\n  (fun a => ↑n * uniformDeviation n f μ X (X ∘ a)) = fun ω =>\n    ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_2.{w, v, u} {n : Nat} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {ι : Type v}\n  {𝒳 : Type w} {μ : @MeasureTheory.Measure.{u} Ω inst} {f : ι → 𝒳 → Real} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : Countable.{v + 1} ι] [inst_3 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → 𝒳)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω 𝒳 Real (f i) X))\n  {b : Real} (hb : @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) b)\n  (hf' : ∀ (i : ι) (x : 𝒳), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i x)) b)\n  (h_original_goal :\n    @Eq.{1} Real\n      (@MeasureTheory.integral.{u, 0} (Fin n → Ω) Real\n        (@NonUnitalNormedRing.toNormedAddCommGroup.{0} Real\n          (@NonUnitalNormedCommRing.toNonUnitalNormedRing.{0} Real\n            (@NormedCommRing.toNonUnitalNormedCommRing.{0} Real\n              (@NormedField.toNormedCommRing.{0} Real\n                (@DenselyNormedField.toNormedField.{0} Real (@RCLike.toDenselyNormedField.{0} Real Real.instRCLike))))))\n        (@NormedAlgebra.toNormedSpace.{0, 0} Real Real Real.normedField\n          (@SeminormedCommRing.toSeminormedRing.{0} Real\n            (@NormedCommRing.toSeminormedCommRing.{0} Real\n              (@NormedField.toNormedCommRing.{0} Real\n                (@DenselyNormedField.toNormedField.{0} Real (@RCLike.toDenselyNormedField.{0} Real Real.instRCLike)))))\n          (@RCLike.toNormedAlgebra.{0} Real Real.instRCLike))\n        (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst)\n        (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n          fun (x : Fin n) => μ)\n        fun (a : Fin n → Ω) =>\n        @HMul.hMul.{0, 0, 0} Real Real Real\n          (@instHMul.{0} Real\n            (@Distrib.toMul.{0} Real\n              (@NonUnitalNonAssocSemiring.toDistrib.{0} Real\n                (@NonUnitalNonAssocCommSemiring.toNonUnitalNonAssocSemiring.{0} Real\n                  (@NonUnitalNonAssocCommRing.toNonUnitalNonAssocCommSemiring.{0} Real\n                    (@NonUnitalCommRing.toNonUnitalNonAssocCommRing.{0} Real\n                      (@NonUnitalNormedCommRing.toNonUnitalCommRing.{0} Real\n                        (@NormedCommRing.toNonUnitalNormedCommRing.{0} Real\n                          (@NormedField.toNormedCommRing.{0} Real\n                            (@DenselyNormedField.toNormedField.{0} Real\n                              (@RCLike.toDenselyNormedField.{0} Real Real.instRCLike)))))))))))\n          (@Nat.cast.{0} Real\n            (@AddMonoidWithOne.toNatCast.{0} Real\n              (@AddCommMonoidWithOne.toAddMonoidWithOne.{0} Real\n                (@NonAssocSemiring.toAddCommMonoidWithOne.{0} Real\n                  (@Semiring.toNonAssocSemiring.{0} Real (@OrderedSemiring.toSemiring.{0} Real Real.orderedSemiring)))))\n            n)\n          (@uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X a)))\n      (@MeasureTheory.integral.{u, 0} (Fin n → Ω) Real Real.normedAddCommGroup\n        (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n          (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n          (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n        (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst)\n        (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n          fun (x : Fin n) => μ)\n        fun (x : Fin n → Ω) =>\n        (fun (ω : Fin n → Ω) =>\n            @iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup\n                (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                  (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                    fun (k : Fin n) => f i (X (ω k)))\n                  (@HSMul.hSMul.{0, 0, 0} Nat Real Real\n                    (@instHSMul.{0, 0} Nat Real (@AddMonoid.toNatSMul.{0} Real Real.instAddMonoid)) n\n                    (@MeasureTheory.integral.{u, 0} Ω Real Real.normedAddCommGroup\n                      (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n                        (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n                        (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n                      inst μ fun (x : Ω) => (fun (ω' : Ω) => f i (X ω')) x))))\n          x)) :\n  @Eq.{u + 1} ((Fin n → Ω) → Real)\n    (fun (a : Fin n → Ω) =>\n      @HMul.hMul.{0, 0, 0} Real Real Real\n        (@instHMul.{0} Real\n          (@Distrib.toMul.{0} Real\n            (@NonUnitalNonAssocSemiring.toDistrib.{0} Real\n              (@NonUnitalNonAssocCommSemiring.toNonUnitalNonAssocSemiring.{0} Real\n                (@NonUnitalNonAssocCommRing.toNonUnitalNonAssocCommSemiring.{0} Real\n                  (@NonUnitalCommRing.toNonUnitalNonAssocCommRing.{0} Real\n                    (@NonUnitalNormedCommRing.toNonUnitalCommRing.{0} Real\n                      (@NormedCommRing.toNonUnitalNormedCommRing.{0} Real\n                        (@NormedField.toNormedCommRing.{0} Real\n                          (@DenselyNormedField.toNormedField.{0} Real\n                            (@RCLike.toDenselyNormedField.{0} Real Real.instRCLike)))))))))))\n        (@Nat.cast.{0} Real\n          (@AddMonoidWithOne.toNatCast.{0} Real\n            (@AddCommMonoidWithOne.toAddMonoidWithOne.{0} Real\n              (@NonAssocSemiring.toAddCommMonoidWithOne.{0} Real\n                (@Semiring.toNonAssocSemiring.{0} Real (@OrderedSemiring.toSemiring.{0} Real Real.orderedSemiring)))))\n          n)\n        (@uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X a)))\n    fun (ω : Fin n → Ω) =>\n    @iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n      @abs.{0} Real Real.lattice Real.instAddGroup\n        (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n          (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n            fun (k : Fin n) => f i (X (ω k)))\n          (@HSMul.hSMul.{0, 0, 0} Nat Real Real\n            (@instHSMul.{0, 0} Nat Real (@AddMonoid.toNatSMul.{0} Real Real.instAddMonoid)) n\n            (@MeasureTheory.integral.{u, 0} Ω Real Real.normedAddCommGroup\n              (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n                (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n                (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n              inst μ fun (x : Ω) => (fun (ω' : Ω) => f i (X ω')) x))) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem integral_congr_ae {f g : α → G} (h : f =ᵐ[μ] g) : ∫ a, f a ∂μ = ∫ a, g a ∂μ"
            },
            {
                "library": "Mathlib",
                "definition": "theorem integral_congr_ae (h : ∀ᵐ x ∂μ, x ∈ Ι a b → f x = g x) :\n    ∫ x in a..b, f x ∂μ = ∫ x in a..b, g x ∂μ"
            }
        ]
    },
    {
        "filename": "FoML/FoML/Main.lean",
        "line": 27,
        "tactic_state_before": "case h\nn : ℕ\nΩ : Type u\ninst✝³ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\nf : ι → 𝒳 → ℝ\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → 𝒳\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\nω : Fin n → Ω\n⊢ ↑n * uniformDeviation n f μ X (X ∘ ω) = ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|",
        "tactic": "rw [uniformDeviation, Real.mul_iSup_of_nonneg (by norm_num)]",
        "tactic_state_after": "[case h\n n : ℕ\n Ω : Type u\n inst✝³ : MeasurableSpace Ω\n ι : Type v\n 𝒳 : Type w\n μ : Measure Ω\n f : ι → 𝒳 → ℝ\n inst✝² : Nonempty ι\n inst✝¹ : Countable ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → 𝒳\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\n ω : Fin n → Ω\n ⊢ ⨆ i, ↑n * |(↑n)⁻¹ * ∑ k, f i ((X ∘ ω) k) - ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ| =\n     ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|]",
        "goal": "n : ℕ\nΩ : Type u\ninst✝³ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\nf : ι → 𝒳 → ℝ\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → 𝒳\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\nω : Fin n → Ω\nh_original_goal :\n  ↑n * uniformDeviation n f μ X (X ∘ ω) = ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|\n⊢ ⨆ i, ↑n * |(↑n)⁻¹ * ∑ k, f i ((X ∘ ω) k) - ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ| =\n    ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_3.{w, v, u} {n : ℕ} {Ω : Type u} [inst : MeasurableSpace Ω] {ι : Type v} {𝒳 : Type w}\n  {μ : Measure Ω} {f : ι → 𝒳 → ℝ} [inst_1 : Nonempty ι] [inst_2 : Countable ι] [inst_3 : IsProbabilityMeasure μ]\n  (hn : 0 < n) (X : Ω → 𝒳) (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b)\n  (hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b) (ω : Fin n → Ω)\n  (h_original_goal :\n    ↑n * uniformDeviation n f μ X (X ∘ ω) = ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ|) :\n  ⨆ i, ↑n * |(↑n)⁻¹ * ∑ k, f i ((X ∘ ω) k) - ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ| =\n    ⨆ i, |∑ k, f i (X (ω k)) - n • ∫ (x : Ω), (fun ω' => f i (X ω')) x ∂μ| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_3.{w, v, u} {n : Nat} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {ι : Type v}\n  {𝒳 : Type w} {μ : @MeasureTheory.Measure.{u} Ω inst} {f : ι → 𝒳 → Real} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : Countable.{v + 1} ι] [inst_3 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → 𝒳)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω 𝒳 Real (f i) X))\n  {b : Real} (hb : @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) b)\n  (hf' : ∀ (i : ι) (x : 𝒳), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i x)) b)\n  (ω : Fin n → Ω)\n  (h_original_goal :\n    @Eq.{1} Real\n      (@HMul.hMul.{0, 0, 0} Real Real Real\n        (@instHMul.{0} Real\n          (@Distrib.toMul.{0} Real\n            (@NonUnitalNonAssocSemiring.toDistrib.{0} Real\n              (@NonUnitalNonAssocCommSemiring.toNonUnitalNonAssocSemiring.{0} Real\n                (@NonUnitalNonAssocCommRing.toNonUnitalNonAssocCommSemiring.{0} Real\n                  (@NonUnitalCommRing.toNonUnitalNonAssocCommRing.{0} Real\n                    (@NonUnitalNormedCommRing.toNonUnitalCommRing.{0} Real\n                      (@NormedCommRing.toNonUnitalNormedCommRing.{0} Real\n                        (@NormedField.toNormedCommRing.{0} Real\n                          (@DenselyNormedField.toNormedField.{0} Real\n                            (@RCLike.toDenselyNormedField.{0} Real Real.instRCLike)))))))))))\n        (@Nat.cast.{0} Real\n          (@AddMonoidWithOne.toNatCast.{0} Real\n            (@AddCommMonoidWithOne.toAddMonoidWithOne.{0} Real\n              (@NonAssocSemiring.toAddCommMonoidWithOne.{0} Real\n                (@Semiring.toNonAssocSemiring.{0} Real (@OrderedSemiring.toSemiring.{0} Real Real.orderedSemiring)))))\n          n)\n        (@uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω)))\n      (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n        @abs.{0} Real Real.lattice Real.instAddGroup\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n              fun (k : Fin n) => f i (X (ω k)))\n            (@HSMul.hSMul.{0, 0, 0} Nat Real Real\n              (@instHSMul.{0, 0} Nat Real (@AddMonoid.toNatSMul.{0} Real Real.instAddMonoid)) n\n              (@MeasureTheory.integral.{u, 0} Ω Real Real.normedAddCommGroup\n                (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n                  (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n                  (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n                inst μ fun (x : Ω) => (fun (ω' : Ω) => f i (X ω')) x))))) :\n  @Eq.{1} Real\n    (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n      @HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n        (@Nat.cast.{0} Real\n          (@AddMonoidWithOne.toNatCast.{0} Real\n            (@AddCommMonoidWithOne.toAddMonoidWithOne.{0} Real\n              (@NonAssocSemiring.toAddCommMonoidWithOne.{0} Real\n                (@Semiring.toNonAssocSemiring.{0} Real (@OrderedSemiring.toSemiring.{0} Real Real.orderedSemiring)))))\n          n)\n        (@abs.{0} Real Real.lattice Real.instAddGroup\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n              (@Inv.inv.{0} Real Real.instInv (@Nat.cast.{0} Real Real.instNatCast n))\n              (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                fun (k : Fin n) => f i (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω k)))\n            (@MeasureTheory.integral.{u, 0} Ω Real Real.normedAddCommGroup\n              (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n                (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n                (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n              inst μ fun (x : Ω) => (fun (ω' : Ω) => f i (X ω')) x))))\n    (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n      @abs.{0} Real Real.lattice Real.instAddGroup\n        (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n          (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n            fun (k : Fin n) => f i (X (ω k)))\n          (@HSMul.hSMul.{0, 0, 0} Nat Real Real\n            (@instHSMul.{0, 0} Nat Real (@AddMonoid.toNatSMul.{0} Real Real.instAddMonoid)) n\n            (@MeasureTheory.integral.{u, 0} Ω Real Real.normedAddCommGroup\n              (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n                (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n                (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n              inst μ fun (x : Ω) => (fun (ω' : Ω) => f i (X ω')) x)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/Main.lean",
        "line": 53,
        "tactic_state_before": "n : ℕ\nΩ : Type u\ninst✝⁵ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\nf : ι → 𝒳 → ℝ\ninst✝⁴ : MeasurableSpace 𝒳\ninst✝³ : Nonempty 𝒳\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nX : Ω → 𝒳\nhX : Measurable X\nhf : ∀ (i : ι), Measurable (f i)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\nt : ℝ\nht✝ : 0 ≤ t\nht' : t * b ^ 2 ≤ 1 / 2\nε : ℝ\nhε : 0 ≤ ε\nhn✝ : ¬n = 0\nhn : 0 < n\nhn' : 0 < ↑n\nc : Fin n → ℝ := fun i => (↑n)⁻¹ * 2 * b\nht : ↑n * t / 2 ≥ 0\n⊢ ↑n * t / 2 * ∑ i, c i ^ 2 ≤ 1",
        "tactic": "apply le_of_mul_le_mul_left _ (show (0 : ℝ) < 1 / 2 from by linarith)",
        "tactic_state_after": "[n : ℕ\n Ω : Type u\n inst✝⁵ : MeasurableSpace Ω\n ι : Type v\n 𝒳 : Type w\n μ : Measure Ω\n f : ι → 𝒳 → ℝ\n inst✝⁴ : MeasurableSpace 𝒳\n inst✝³ : Nonempty 𝒳\n inst✝² : Nonempty ι\n inst✝¹ : Countable ι\n inst✝ : IsProbabilityMeasure μ\n X : Ω → 𝒳\n hX : Measurable X\n hf : ∀ (i : ι), Measurable (f i)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\n t : ℝ\n ht✝ : 0 ≤ t\n ht' : t * b ^ 2 ≤ 1 / 2\n ε : ℝ\n hε : 0 ≤ ε\n hn✝ : ¬n = 0\n hn : 0 < n\n hn' : 0 < ↑n\n c : Fin n → ℝ := fun i => (↑n)⁻¹ * 2 * b\n ht : ↑n * t / 2 ≥ 0\n ⊢ 1 / 2 * (↑n * t / 2 * ∑ i, c i ^ 2) ≤ 1 / 2 * 1]",
        "goal": "n : ℕ\nΩ : Type u\ninst✝⁵ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\nf : ι → 𝒳 → ℝ\ninst✝⁴ : MeasurableSpace 𝒳\ninst✝³ : Nonempty 𝒳\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nX : Ω → 𝒳\nhX : Measurable X\nhf : ∀ (i : ι), Measurable (f i)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\nt : ℝ\nht✝ : 0 ≤ t\nht' : t * b ^ 2 ≤ 1 / 2\nε : ℝ\nhε : 0 ≤ ε\nhn✝ : ¬n = 0\nhn : 0 < n\nhn' : 0 < ↑n\nc : Fin n → ℝ := fun i => (↑n)⁻¹ * 2 * b\nht : ↑n * t / 2 ≥ 0\nh_original_goal : ↑n * t / 2 * ∑ i, c i ^ 2 ≤ 1\n⊢ 1 / 2 * (↑n * t / 2 * ∑ i, c i ^ 2) ≤ 1 / 2 * 1",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_4.{w, v, u} {n : ℕ} {Ω : Type u} [inst : MeasurableSpace Ω] {ι : Type v} {𝒳 : Type w}\n  {μ : Measure Ω} {f : ι → 𝒳 → ℝ} [inst_1 : MeasurableSpace 𝒳] [inst_2 : Nonempty 𝒳] [inst_3 : Nonempty ι]\n  [inst_4 : Countable ι] [inst_5 : IsProbabilityMeasure μ] {X : Ω → 𝒳} (hX : Measurable X)\n  (hf : ∀ (i : ι), Measurable (f i)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b) {t : ℝ} (ht_1 : 0 ≤ t)\n  (ht' : t * b ^ 2 ≤ 1 / 2) (hn_1 : ¬n = 0) (hn : 0 < n) (hn' : 0 < ↑n) :\n  let c := fun i => (↑n)⁻¹ * 2 * b;\n  ↑n * t / 2 ≥ 0 → ↑n * t / 2 * ∑ i, c i ^ 2 ≤ 1 → 1 / 2 * (↑n * t / 2 * ∑ i, c i ^ 2) ≤ 1 / 2 * 1 := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_4.{w, v, u} {n : Nat} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {ι : Type v}\n  {𝒳 : Type w} {μ : @MeasureTheory.Measure.{u} Ω inst} {f : ι → 𝒳 → Real} [inst_1 : MeasurableSpace.{w} 𝒳]\n  [inst_2 : Nonempty.{w + 1} 𝒳] [inst_3 : Nonempty.{v + 1} ι] [inst_4 : Countable.{v + 1} ι]\n  [inst_5 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ] {X : Ω → 𝒳} (hX : @Measurable.{u, w} Ω 𝒳 inst inst_1 X)\n  (hf : ∀ (i : ι), @Measurable.{w, 0} 𝒳 Real inst_1 Real.measurableSpace (f i)) {b : Real}\n  (hb : @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) b)\n  (hf' : ∀ (i : ι) (x : 𝒳), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i x)) b)\n  {t : Real} (ht_1 : @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) t)\n  (ht' :\n    @LE.le.{0} Real Real.instLE\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul) t\n        (@HPow.hPow.{0, 0, 0} Real Nat Real (@instHPow.{0, 0} Real Nat (@Monoid.toNatPow.{0} Real Real.instMonoid)) b\n          (@OfNat.ofNat.{0} Nat 2 (instOfNatNat 2))))\n      (@HDiv.hDiv.{0, 0, 0} Real Real Real (@instHDiv.{0} Real (@DivInvMonoid.toDiv.{0} Real Real.instDivInvMonoid))\n        (@OfNat.ofNat.{0} Real 1 (@One.toOfNat1.{0} Real Real.instOne))\n        (@OfNat.ofNat.{0} Real 2\n          (@instOfNatAtLeastTwo.{0} Real 2 Real.instNatCast\n            (@instNatAtLeastTwo (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)))))))\n  (hn_1 : Not (@Eq.{1} Nat n (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0))))\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n)\n  (hn' :\n    @LT.lt.{0} Real Real.instLT (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))\n      (@Nat.cast.{0} Real Real.instNatCast n)) :\n  let c : Fin n → Real := fun (i : Fin n) =>\n    @HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n        (@Inv.inv.{0} Real Real.instInv (@Nat.cast.{0} Real Real.instNatCast n))\n        (@OfNat.ofNat.{0} Real 2\n          (@instOfNatAtLeastTwo.{0} Real 2 Real.instNatCast\n            (@instNatAtLeastTwo (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0))))))\n      b;\n  @GE.ge.{0} Real Real.instLE\n      (@HDiv.hDiv.{0, 0, 0} Real Real Real (@instHDiv.{0} Real (@DivInvMonoid.toDiv.{0} Real Real.instDivInvMonoid))\n        (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul) (@Nat.cast.{0} Real Real.instNatCast n)\n          t)\n        (@OfNat.ofNat.{0} Real 2\n          (@instOfNatAtLeastTwo.{0} Real 2 Real.instNatCast\n            (@instNatAtLeastTwo (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0))))))\n      (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) →\n    @LE.le.{0} Real Real.instLE\n        (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n          (@HDiv.hDiv.{0, 0, 0} Real Real Real (@instHDiv.{0} Real (@DivInvMonoid.toDiv.{0} Real Real.instDivInvMonoid))\n            (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n              (@Nat.cast.{0} Real Real.instNatCast n) t)\n            (@OfNat.ofNat.{0} Real 2\n              (@instOfNatAtLeastTwo.{0} Real 2 Real.instNatCast\n                (@instNatAtLeastTwo (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0))))))\n          (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n            fun (i : Fin n) =>\n            @HPow.hPow.{0, 0, 0} Real Nat Real (@instHPow.{0, 0} Real Nat (@Monoid.toNatPow.{0} Real Real.instMonoid))\n              (c i) (@OfNat.ofNat.{0} Nat 2 (instOfNatNat 2))))\n        (@OfNat.ofNat.{0} Real 1 (@One.toOfNat1.{0} Real Real.instOne)) →\n      @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n        (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n          (@HDiv.hDiv.{0, 0, 0} Real Real Real (@instHDiv.{0} Real (@DivInvMonoid.toDiv.{0} Real Real.instDivInvMonoid))\n            (@OfNat.ofNat.{0} Real 1 (@One.toOfNat1.{0} Real Real.instOne))\n            (@OfNat.ofNat.{0} Real 2\n              (@instOfNatAtLeastTwo.{0} Real 2 Real.instNatCast\n                (@instNatAtLeastTwo (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0))))))\n          (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n            (@HDiv.hDiv.{0, 0, 0} Real Real Real\n              (@instHDiv.{0} Real (@DivInvMonoid.toDiv.{0} Real Real.instDivInvMonoid))\n              (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n                (@Nat.cast.{0} Real Real.instNatCast n) t)\n              (@OfNat.ofNat.{0} Real 2\n                (@instOfNatAtLeastTwo.{0} Real 2 Real.instNatCast\n                  (@instNatAtLeastTwo (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0))))))\n            (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n              fun (i : Fin n) =>\n              @HPow.hPow.{0, 0, 0} Real Nat Real (@instHPow.{0, 0} Real Nat (@Monoid.toNatPow.{0} Real Real.instMonoid))\n                (c i) (@OfNat.ofNat.{0} Nat 2 (instOfNatNat 2)))))\n        (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n          (@HDiv.hDiv.{0, 0, 0} Real Real Real (@instHDiv.{0} Real (@DivInvMonoid.toDiv.{0} Real Real.instDivInvMonoid))\n            (@OfNat.ofNat.{0} Real 1 (@One.toOfNat1.{0} Real Real.instOne))\n            (@OfNat.ofNat.{0} Real 2\n              (@instOfNatAtLeastTwo.{0} Real 2 Real.instNatCast\n                (@instNatAtLeastTwo (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0))))))\n          (@OfNat.ofNat.{0} Real 1 (@One.toOfNat1.{0} Real Real.instOne))) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem le_of_mul_le_mul_left (a b c : Associates M) (ha : a ≠ 0) : a * b ≤ a * c → b ≤ c\n  | ⟨d, hd⟩ => ⟨d, mul_left_cancel₀ ha <| by rwa [← mul_assoc]⟩\n\ntheorem one_or_eq_of_le_of_prime {p m : Associates M} (hp : Prime p) (hle : m ≤ p) :\n    m = 1 ∨ m = p"
            },
            {
                "library": "Mathlib",
                "definition": "theorem le_of_mul_le_mul_left [PosMulReflectLE α] (bc : a * b ≤ a * c) (a0 : 0 < a) : b ≤ c"
            },
            {
                "library": "Mathlib",
                "definition": "theorem le_of_mul_le_mul_left {a b c : Ordinal} (h : c * a ≤ c * b) (h0 : 0 < c) : a ≤ b"
            }
        ]
    },
    {
        "filename": "FoML/FoML/Main.lean",
        "line": 75,
        "tactic_state_before": "case neg\nn : ℕ\nΩ : Type u\ninst✝⁵ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\ninst✝⁴ : MeasurableSpace 𝒳\ninst✝³ : Nonempty 𝒳\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nf : ι → 𝒳 → ℝ\nhf : ∀ (i : ι), Measurable (f i)\nX : Ω → 𝒳\nhX : Measurable X\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\nt : ℝ\nht : 0 ≤ t\nht' : t * b ^ 2 ≤ 1 / 2\nε : ℝ\nhε : 0 ≤ ε\nhn✝ : ¬n = 0\nhn : 0 < n\n⊢ ((Measure.pi fun x => μ) fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)).toReal ≤\n    rexp (-ε ^ 2 * t * ↑n)",
        "tactic": "apply le_trans _ (uniformDeviation_mcdiarmid (μ := μ) hX hf hb hf' ht ht' hε)",
        "tactic_state_after": "[n : ℕ\n Ω : Type u\n inst✝⁵ : MeasurableSpace Ω\n ι : Type v\n 𝒳 : Type w\n μ : Measure Ω\n inst✝⁴ : MeasurableSpace 𝒳\n inst✝³ : Nonempty 𝒳\n inst✝² : Nonempty ι\n inst✝¹ : Countable ι\n inst✝ : IsProbabilityMeasure μ\n f : ι → 𝒳 → ℝ\n hf : ∀ (i : ι), Measurable (f i)\n X : Ω → 𝒳\n hX : Measurable X\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\n t : ℝ\n ht : 0 ≤ t\n ht' : t * b ^ 2 ≤ 1 / 2\n ε : ℝ\n hε : 0 ≤ ε\n hn✝ : ¬n = 0\n hn : 0 < n\n ⊢ ((Measure.pi fun x => μ) fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)).toReal ≤\n     ((Measure.pi fun x => μ) fun ω =>\n         (uniformDeviation n f μ X (X ∘ ω) -\n             ∫ (x : Fin n → Ω), (fun ω => uniformDeviation n f μ X (X ∘ ω)) x ∂Measure.pi fun x => μ) ≥\n           ε).toReal]",
        "goal": "n : ℕ\nΩ : Type u\ninst✝⁵ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\ninst✝⁴ : MeasurableSpace 𝒳\ninst✝³ : Nonempty 𝒳\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nf : ι → 𝒳 → ℝ\nhf : ∀ (i : ι), Measurable (f i)\nX : Ω → 𝒳\nhX : Measurable X\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\nt : ℝ\nht : 0 ≤ t\nht' : t * b ^ 2 ≤ 1 / 2\nε : ℝ\nhε : 0 ≤ ε\nhn✝ : ¬n = 0\nhn : 0 < n\nh_original_goal :\n  ((Measure.pi fun x => μ) fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)).toReal ≤\n    rexp (-ε ^ 2 * t * ↑n)\n⊢ ((Measure.pi fun x => μ) fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)).toReal ≤\n    ((Measure.pi fun x => μ) fun ω =>\n        (uniformDeviation n f μ X (X ∘ ω) -\n            ∫ (x : Fin n → Ω), (fun ω => uniformDeviation n f μ X (X ∘ ω)) x ∂Measure.pi fun x => μ) ≥\n          ε).toReal",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_5.{w, v, u} {n : ℕ} {Ω : Type u} [inst : MeasurableSpace Ω] {ι : Type v} {𝒳 : Type w}\n  {μ : Measure Ω} [inst_1 : MeasurableSpace 𝒳] [inst_2 : Nonempty 𝒳] [inst_3 : Nonempty ι] [inst_4 : Countable ι]\n  [inst_5 : IsProbabilityMeasure μ] (f : ι → 𝒳 → ℝ) (hf : ∀ (i : ι), Measurable (f i)) (X : Ω → 𝒳) (hX : Measurable X)\n  {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b) {t : ℝ} (ht : 0 ≤ t) (ht' : t * b ^ 2 ≤ 1 / 2) {ε : ℝ}\n  (hε : 0 ≤ ε) (hn_1 : ¬n = 0) (hn : 0 < n)\n  (h_original_goal :\n    ((Measure.pi fun x => μ) fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)).toReal ≤\n      rexp (-ε ^ 2 * t * ↑n)) :\n  ((Measure.pi fun x => μ) fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)).toReal ≤\n    ((Measure.pi fun x => μ) fun ω =>\n        (uniformDeviation n f μ X (X ∘ ω) -\n            ∫ (x : Fin n → Ω), (fun ω => uniformDeviation n f μ X (X ∘ ω)) x ∂Measure.pi fun x => μ) ≥\n          ε).toReal := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_5.{w, v, u} {n : Nat} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {ι : Type v}\n  {𝒳 : Type w} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : MeasurableSpace.{w} 𝒳] [inst_2 : Nonempty.{w + 1} 𝒳]\n  [inst_3 : Nonempty.{v + 1} ι] [inst_4 : Countable.{v + 1} ι]\n  [inst_5 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ] (f : ι → 𝒳 → Real)\n  (hf : ∀ (i : ι), @Measurable.{w, 0} 𝒳 Real inst_1 Real.measurableSpace (f i)) (X : Ω → 𝒳)\n  (hX : @Measurable.{u, w} Ω 𝒳 inst inst_1 X) {b : Real}\n  (hb : @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) b)\n  (hf' : ∀ (i : ι) (x : 𝒳), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i x)) b)\n  {t : Real} (ht : @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) t)\n  (ht' :\n    @LE.le.{0} Real Real.instLE\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul) t\n        (@HPow.hPow.{0, 0, 0} Real Nat Real (@instHPow.{0, 0} Real Nat (@Monoid.toNatPow.{0} Real Real.instMonoid)) b\n          (@OfNat.ofNat.{0} Nat 2 (instOfNatNat 2))))\n      (@HDiv.hDiv.{0, 0, 0} Real Real Real (@instHDiv.{0} Real (@DivInvMonoid.toDiv.{0} Real Real.instDivInvMonoid))\n        (@OfNat.ofNat.{0} Real 1 (@One.toOfNat1.{0} Real Real.instOne))\n        (@OfNat.ofNat.{0} Real 2\n          (@instOfNatAtLeastTwo.{0} Real 2 Real.instNatCast\n            (@instNatAtLeastTwo (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)))))))\n  {ε : Real} (hε : @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) ε)\n  (hn_1 : Not (@Eq.{1} Nat n (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0))))\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n)\n  (h_original_goal :\n    @LE.le.{0} Real Real.instLE\n      (ENNReal.toReal\n        (@DFunLike.coe.{u + 1, u + 1, 1}\n          (@MeasureTheory.Measure.{u} (Fin n → Ω)\n            (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n          (Set.{u} (Fin n → Ω)) (fun (x : Set.{u} (Fin n → Ω)) => ENNReal)\n          (@MeasureTheory.Measure.instFunLike.{u} (Fin n → Ω)\n            (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n          (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n            fun (x : Fin n) => μ)\n          fun (ω : Fin n → Ω) =>\n          @LE.le.{0} Real Real.instLE\n            (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd)\n              (@HSMul.hSMul.{0, 0, 0} Nat Real Real\n                (@instHSMul.{0, 0} Nat Real (@AddMonoid.toNatSMul.{0} Real Real.instAddMonoid))\n                (@OfNat.ofNat.{0} Nat 2 (instOfNatNat 2)) (@rademacherComplexity.{u, v, w} Ω inst ι 𝒳 n f μ X))\n              ε)\n            (@uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω))))\n      (Real.exp\n        (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n          (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n            (@Neg.neg.{0} Real Real.instNeg\n              (@HPow.hPow.{0, 0, 0} Real Nat Real\n                (@instHPow.{0, 0} Real Nat (@Monoid.toNatPow.{0} Real Real.instMonoid)) ε\n                (@OfNat.ofNat.{0} Nat 2 (instOfNatNat 2))))\n            t)\n          (@Nat.cast.{0} Real Real.instNatCast n)))) :\n  @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n    (ENNReal.toReal\n      (@DFunLike.coe.{u + 1, u + 1, 1}\n        (@MeasureTheory.Measure.{u} (Fin n → Ω)\n          (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n        (Set.{u} (Fin n → Ω)) (fun (x : Set.{u} (Fin n → Ω)) => ENNReal)\n        (@MeasureTheory.Measure.instFunLike.{u} (Fin n → Ω)\n          (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n        (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n          fun (x : Fin n) => μ)\n        fun (ω : Fin n → Ω) =>\n        @LE.le.{0} Real Real.instLE\n          (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd)\n            (@HSMul.hSMul.{0, 0, 0} Nat Real Real\n              (@instHSMul.{0, 0} Nat Real (@AddMonoid.toNatSMul.{0} Real Real.instAddMonoid))\n              (@OfNat.ofNat.{0} Nat 2 (instOfNatNat 2)) (@rademacherComplexity.{u, v, w} Ω inst ι 𝒳 n f μ X))\n            ε)\n          (@uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω))))\n    (ENNReal.toReal\n      (@DFunLike.coe.{u + 1, u + 1, 1}\n        (@MeasureTheory.Measure.{u} (Fin n → Ω)\n          (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n        (Set.{u} (Fin n → Ω)) (fun (x : Set.{u} (Fin n → Ω)) => ENNReal)\n        (@MeasureTheory.Measure.instFunLike.{u} (Fin n → Ω)\n          (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n        (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n          fun (x : Fin n) => μ)\n        fun (ω : Fin n → Ω) =>\n        @GE.ge.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω))\n            (@MeasureTheory.integral.{u, 0} (Fin n → Ω) Real Real.normedAddCommGroup\n              (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n                (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n                (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n              (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst)\n              (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n                fun (x : Fin n) => μ)\n              fun (x : Fin n → Ω) =>\n              (fun (ω : Fin n → Ω) =>\n                  @uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω))\n                x))\n          ε)) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem le_trans (f g h : M ≃ₚ[L] N) : f ≤ g → g ≤ h → f ≤ h"
            },
            {
                "library": "Mathlib",
                "definition": "lemma le_trans : a ≤ b → b ≤ c → a ≤ c"
            }
        ]
    },
    {
        "filename": "FoML/FoML/Main.lean",
        "line": 76,
        "tactic_state_before": "n : ℕ\nΩ : Type u\ninst✝⁵ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\ninst✝⁴ : MeasurableSpace 𝒳\ninst✝³ : Nonempty 𝒳\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nf : ι → 𝒳 → ℝ\nhf : ∀ (i : ι), Measurable (f i)\nX : Ω → 𝒳\nhX : Measurable X\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\nt : ℝ\nht : 0 ≤ t\nht' : t * b ^ 2 ≤ 1 / 2\nε : ℝ\nhε : 0 ≤ ε\nhn✝ : ¬n = 0\nhn : 0 < n\n⊢ ((Measure.pi fun x => μ) fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)).toReal ≤\n    ((Measure.pi fun x => μ) fun ω =>\n        (uniformDeviation n f μ X (X ∘ ω) -\n            ∫ (x : Fin n → Ω), (fun ω => uniformDeviation n f μ X (X ∘ ω)) x ∂Measure.pi fun x => μ) ≥\n          ε).toReal",
        "tactic": "simp only [ge_iff_le, ne_eq, measure_ne_top, not_false_eq_true, ENNReal.toReal_le_toReal]",
        "tactic_state_after": "[n : ℕ\n Ω : Type u\n inst✝⁵ : MeasurableSpace Ω\n ι : Type v\n 𝒳 : Type w\n μ : Measure Ω\n inst✝⁴ : MeasurableSpace 𝒳\n inst✝³ : Nonempty 𝒳\n inst✝² : Nonempty ι\n inst✝¹ : Countable ι\n inst✝ : IsProbabilityMeasure μ\n f : ι → 𝒳 → ℝ\n hf : ∀ (i : ι), Measurable (f i)\n X : Ω → 𝒳\n hX : Measurable X\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\n t : ℝ\n ht : 0 ≤ t\n ht' : t * b ^ 2 ≤ 1 / 2\n ε : ℝ\n hε : 0 ≤ ε\n hn✝ : ¬n = 0\n hn : 0 < n\n ⊢ ((Measure.pi fun x => μ) fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)) ≤\n     (Measure.pi fun x => μ) fun ω =>\n       ε ≤\n         uniformDeviation n f μ X (X ∘ ω) - ∫ (x : Fin n → Ω), uniformDeviation n f μ X (X ∘ x) ∂Measure.pi fun x => μ]",
        "goal": "n : ℕ\nΩ : Type u\ninst✝⁵ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\ninst✝⁴ : MeasurableSpace 𝒳\ninst✝³ : Nonempty 𝒳\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nf : ι → 𝒳 → ℝ\nhf : ∀ (i : ι), Measurable (f i)\nX : Ω → 𝒳\nhX : Measurable X\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\nt : ℝ\nht : 0 ≤ t\nht' : t * b ^ 2 ≤ 1 / 2\nε : ℝ\nhε : 0 ≤ ε\nhn✝ : ¬n = 0\nhn : 0 < n\nh_original_goal :\n  ((Measure.pi fun x => μ) fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)).toReal ≤\n    ((Measure.pi fun x => μ) fun ω =>\n        (uniformDeviation n f μ X (X ∘ ω) -\n            ∫ (x : Fin n → Ω), (fun ω => uniformDeviation n f μ X (X ∘ ω)) x ∂Measure.pi fun x => μ) ≥\n          ε).toReal\n⊢ ((Measure.pi fun x => μ) fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)) ≤\n    (Measure.pi fun x => μ) fun ω =>\n      ε ≤ uniformDeviation n f μ X (X ∘ ω) - ∫ (x : Fin n → Ω), uniformDeviation n f μ X (X ∘ x) ∂Measure.pi fun x => μ",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_6.{w, v, u} {n : ℕ} {Ω : Type u} [inst : MeasurableSpace Ω] {ι : Type v} {𝒳 : Type w}\n  {μ : Measure Ω} [inst_1 : MeasurableSpace 𝒳] [inst_2 : Nonempty 𝒳] [inst_3 : Nonempty ι] [inst_4 : Countable ι]\n  [inst_5 : IsProbabilityMeasure μ] (f : ι → 𝒳 → ℝ) (hf : ∀ (i : ι), Measurable (f i)) (X : Ω → 𝒳) (hX : Measurable X)\n  {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b) {t : ℝ} (ht : 0 ≤ t) (ht' : t * b ^ 2 ≤ 1 / 2) {ε : ℝ}\n  (hε : 0 ≤ ε) (hn_1 : ¬n = 0) (hn : 0 < n)\n  (h_original_goal :\n    ((Measure.pi fun x => μ) fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)).toReal ≤\n      ((Measure.pi fun x => μ) fun ω =>\n          (uniformDeviation n f μ X (X ∘ ω) -\n              ∫ (x : Fin n → Ω), (fun ω => uniformDeviation n f μ X (X ∘ ω)) x ∂Measure.pi fun x => μ) ≥\n            ε).toReal) :\n  ((Measure.pi fun x => μ) fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)) ≤\n    (Measure.pi fun x => μ) fun ω =>\n      ε ≤\n        uniformDeviation n f μ X (X ∘ ω) -\n          ∫ (x : Fin n → Ω), uniformDeviation n f μ X (X ∘ x) ∂Measure.pi fun x => μ := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_6.{w, v, u} {n : Nat} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {ι : Type v}\n  {𝒳 : Type w} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : MeasurableSpace.{w} 𝒳] [inst_2 : Nonempty.{w + 1} 𝒳]\n  [inst_3 : Nonempty.{v + 1} ι] [inst_4 : Countable.{v + 1} ι]\n  [inst_5 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ] (f : ι → 𝒳 → Real)\n  (hf : ∀ (i : ι), @Measurable.{w, 0} 𝒳 Real inst_1 Real.measurableSpace (f i)) (X : Ω → 𝒳)\n  (hX : @Measurable.{u, w} Ω 𝒳 inst inst_1 X) {b : Real}\n  (hb : @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) b)\n  (hf' : ∀ (i : ι) (x : 𝒳), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i x)) b)\n  {t : Real} (ht : @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) t)\n  (ht' :\n    @LE.le.{0} Real Real.instLE\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul) t\n        (@HPow.hPow.{0, 0, 0} Real Nat Real (@instHPow.{0, 0} Real Nat (@Monoid.toNatPow.{0} Real Real.instMonoid)) b\n          (@OfNat.ofNat.{0} Nat 2 (instOfNatNat 2))))\n      (@HDiv.hDiv.{0, 0, 0} Real Real Real (@instHDiv.{0} Real (@DivInvMonoid.toDiv.{0} Real Real.instDivInvMonoid))\n        (@OfNat.ofNat.{0} Real 1 (@One.toOfNat1.{0} Real Real.instOne))\n        (@OfNat.ofNat.{0} Real 2\n          (@instOfNatAtLeastTwo.{0} Real 2 Real.instNatCast\n            (@instNatAtLeastTwo (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)))))))\n  {ε : Real} (hε : @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) ε)\n  (hn_1 : Not (@Eq.{1} Nat n (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0))))\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n)\n  (h_original_goal :\n    @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n      (ENNReal.toReal\n        (@DFunLike.coe.{u + 1, u + 1, 1}\n          (@MeasureTheory.Measure.{u} (Fin n → Ω)\n            (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n          (Set.{u} (Fin n → Ω)) (fun (x : Set.{u} (Fin n → Ω)) => ENNReal)\n          (@MeasureTheory.Measure.instFunLike.{u} (Fin n → Ω)\n            (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n          (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n            fun (x : Fin n) => μ)\n          fun (ω : Fin n → Ω) =>\n          @LE.le.{0} Real Real.instLE\n            (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd)\n              (@HSMul.hSMul.{0, 0, 0} Nat Real Real\n                (@instHSMul.{0, 0} Nat Real (@AddMonoid.toNatSMul.{0} Real Real.instAddMonoid))\n                (@OfNat.ofNat.{0} Nat 2 (instOfNatNat 2)) (@rademacherComplexity.{u, v, w} Ω inst ι 𝒳 n f μ X))\n              ε)\n            (@uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω))))\n      (ENNReal.toReal\n        (@DFunLike.coe.{u + 1, u + 1, 1}\n          (@MeasureTheory.Measure.{u} (Fin n → Ω)\n            (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n          (Set.{u} (Fin n → Ω)) (fun (x : Set.{u} (Fin n → Ω)) => ENNReal)\n          (@MeasureTheory.Measure.instFunLike.{u} (Fin n → Ω)\n            (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n          (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n            fun (x : Fin n) => μ)\n          fun (ω : Fin n → Ω) =>\n          @GE.ge.{0} Real Real.instLE\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω))\n              (@MeasureTheory.integral.{u, 0} (Fin n → Ω) Real Real.normedAddCommGroup\n                (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n                  (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n                  (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n                (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst)\n                (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n)\n                  (fun (i : Fin n) => inst) fun (x : Fin n) => μ)\n                fun (x : Fin n → Ω) =>\n                (fun (ω : Fin n → Ω) =>\n                    @uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω))\n                  x))\n            ε))) :\n  @LE.le.{0} ENNReal\n    (@Preorder.toLE.{0} ENNReal\n      (@PartialOrder.toPreorder.{0} ENNReal\n        (@CompleteSemilatticeInf.toPartialOrder.{0} ENNReal\n          (@CompleteLattice.toCompleteSemilatticeInf.{0} ENNReal\n            (@CompletelyDistribLattice.toCompleteLattice.{0} ENNReal\n              (@CompleteLinearOrder.toCompletelyDistribLattice.{0} ENNReal ENNReal.instCompleteLinearOrder))))))\n    (@DFunLike.coe.{u + 1, u + 1, 1}\n      (@MeasureTheory.Measure.{u} (Fin n → Ω)\n        (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n      (Set.{u} (Fin n → Ω)) (fun (x : Set.{u} (Fin n → Ω)) => ENNReal)\n      (@MeasureTheory.Measure.instFunLike.{u} (Fin n → Ω)\n        (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n      (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n        fun (x : Fin n) => μ)\n      fun (ω : Fin n → Ω) =>\n      @LE.le.{0} Real Real.instLE\n        (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd)\n          (@HSMul.hSMul.{0, 0, 0} Nat Real Real\n            (@instHSMul.{0, 0} Nat Real (@AddMonoid.toNatSMul.{0} Real Real.instAddMonoid))\n            (@OfNat.ofNat.{0} Nat 2 (instOfNatNat 2)) (@rademacherComplexity.{u, v, w} Ω inst ι 𝒳 n f μ X))\n          ε)\n        (@uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω)))\n    (@DFunLike.coe.{u + 1, u + 1, 1}\n      (@MeasureTheory.Measure.{u} (Fin n → Ω)\n        (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n      (Set.{u} (Fin n → Ω)) (fun (x : Set.{u} (Fin n → Ω)) => ENNReal)\n      (@MeasureTheory.Measure.instFunLike.{u} (Fin n → Ω)\n        (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n      (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n        fun (x : Fin n) => μ)\n      fun (ω : Fin n → Ω) =>\n      @LE.le.{0} Real Real.instLE ε\n        (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n          (@uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω))\n          (@MeasureTheory.integral.{u, 0} (Fin n → Ω) Real Real.normedAddCommGroup\n            (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n              (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n              (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n            (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst)\n            (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n              fun (x : Fin n) => μ)\n            fun (x : Fin n → Ω) =>\n            @uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X\n              (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X x)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/Main.lean",
        "line": 77,
        "tactic_state_before": "n : ℕ\nΩ : Type u\ninst✝⁵ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\ninst✝⁴ : MeasurableSpace 𝒳\ninst✝³ : Nonempty 𝒳\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nf : ι → 𝒳 → ℝ\nhf : ∀ (i : ι), Measurable (f i)\nX : Ω → 𝒳\nhX : Measurable X\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\nt : ℝ\nht : 0 ≤ t\nht' : t * b ^ 2 ≤ 1 / 2\nε : ℝ\nhε : 0 ≤ ε\nhn✝ : ¬n = 0\nhn : 0 < n\n⊢ ((Measure.pi fun x => μ) fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)) ≤\n    (Measure.pi fun x => μ) fun ω =>\n      ε ≤ uniformDeviation n f μ X (X ∘ ω) - ∫ (x : Fin n → Ω), uniformDeviation n f μ X (X ∘ x) ∂Measure.pi fun x => μ",
        "tactic": "apply measure_mono",
        "tactic_state_after": "[case h\n n : ℕ\n Ω : Type u\n inst✝⁵ : MeasurableSpace Ω\n ι : Type v\n 𝒳 : Type w\n μ : Measure Ω\n inst✝⁴ : MeasurableSpace 𝒳\n inst✝³ : Nonempty 𝒳\n inst✝² : Nonempty ι\n inst✝¹ : Countable ι\n inst✝ : IsProbabilityMeasure μ\n f : ι → 𝒳 → ℝ\n hf : ∀ (i : ι), Measurable (f i)\n X : Ω → 𝒳\n hX : Measurable X\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\n t : ℝ\n ht : 0 ≤ t\n ht' : t * b ^ 2 ≤ 1 / 2\n ε : ℝ\n hε : 0 ≤ ε\n hn✝ : ¬n = 0\n hn : 0 < n\n ⊢ (fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)) ⊆ fun ω =>\n     ε ≤ uniformDeviation n f μ X (X ∘ ω) - ∫ (x : Fin n → Ω), uniformDeviation n f μ X (X ∘ x) ∂Measure.pi fun x => μ]",
        "goal": "n : ℕ\nΩ : Type u\ninst✝⁵ : MeasurableSpace Ω\nι : Type v\n𝒳 : Type w\nμ : Measure Ω\ninst✝⁴ : MeasurableSpace 𝒳\ninst✝³ : Nonempty 𝒳\ninst✝² : Nonempty ι\ninst✝¹ : Countable ι\ninst✝ : IsProbabilityMeasure μ\nf : ι → 𝒳 → ℝ\nhf : ∀ (i : ι), Measurable (f i)\nX : Ω → 𝒳\nhX : Measurable X\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b\nt : ℝ\nht : 0 ≤ t\nht' : t * b ^ 2 ≤ 1 / 2\nε : ℝ\nhε : 0 ≤ ε\nhn✝ : ¬n = 0\nhn : 0 < n\nh_original_goal :\n  ((Measure.pi fun x => μ) fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)) ≤\n    (Measure.pi fun x => μ) fun ω =>\n      ε ≤ uniformDeviation n f μ X (X ∘ ω) - ∫ (x : Fin n → Ω), uniformDeviation n f μ X (X ∘ x) ∂Measure.pi fun x => μ\n⊢ (fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)) ⊆ fun ω =>\n    ε ≤ uniformDeviation n f μ X (X ∘ ω) - ∫ (x : Fin n → Ω), uniformDeviation n f μ X (X ∘ x) ∂Measure.pi fun x => μ",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_7.{w, v, u} {n : ℕ} {Ω : Type u} [inst : MeasurableSpace Ω] {ι : Type v} {𝒳 : Type w}\n  {μ : Measure Ω} [inst_1 : MeasurableSpace 𝒳] [inst_2 : Nonempty 𝒳] [inst_3 : Nonempty ι] [inst_4 : Countable ι]\n  [inst_5 : IsProbabilityMeasure μ] (f : ι → 𝒳 → ℝ) (hf : ∀ (i : ι), Measurable (f i)) (X : Ω → 𝒳) (hX : Measurable X)\n  {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (x : 𝒳), |f i x| ≤ b) {t : ℝ} (ht : 0 ≤ t) (ht' : t * b ^ 2 ≤ 1 / 2) {ε : ℝ}\n  (hε : 0 ≤ ε) (hn_1 : ¬n = 0) (hn : 0 < n)\n  (h_original_goal :\n    ((Measure.pi fun x => μ) fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)) ≤\n      (Measure.pi fun x => μ) fun ω =>\n        ε ≤\n          uniformDeviation n f μ X (X ∘ ω) -\n            ∫ (x : Fin n → Ω), uniformDeviation n f μ X (X ∘ x) ∂Measure.pi fun x => μ) :\n  (fun ω => 2 • rademacherComplexity n f μ X + ε ≤ uniformDeviation n f μ X (X ∘ ω)) ⊆ fun ω =>\n    ε ≤\n      uniformDeviation n f μ X (X ∘ ω) -\n        ∫ (x : Fin n → Ω), uniformDeviation n f μ X (X ∘ x) ∂Measure.pi fun x => μ := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_7.{w, v, u} {n : Nat} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {ι : Type v}\n  {𝒳 : Type w} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : MeasurableSpace.{w} 𝒳] [inst_2 : Nonempty.{w + 1} 𝒳]\n  [inst_3 : Nonempty.{v + 1} ι] [inst_4 : Countable.{v + 1} ι]\n  [inst_5 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ] (f : ι → 𝒳 → Real)\n  (hf : ∀ (i : ι), @Measurable.{w, 0} 𝒳 Real inst_1 Real.measurableSpace (f i)) (X : Ω → 𝒳)\n  (hX : @Measurable.{u, w} Ω 𝒳 inst inst_1 X) {b : Real}\n  (hb : @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) b)\n  (hf' : ∀ (i : ι) (x : 𝒳), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i x)) b)\n  {t : Real} (ht : @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) t)\n  (ht' :\n    @LE.le.{0} Real Real.instLE\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul) t\n        (@HPow.hPow.{0, 0, 0} Real Nat Real (@instHPow.{0, 0} Real Nat (@Monoid.toNatPow.{0} Real Real.instMonoid)) b\n          (@OfNat.ofNat.{0} Nat 2 (instOfNatNat 2))))\n      (@HDiv.hDiv.{0, 0, 0} Real Real Real (@instHDiv.{0} Real (@DivInvMonoid.toDiv.{0} Real Real.instDivInvMonoid))\n        (@OfNat.ofNat.{0} Real 1 (@One.toOfNat1.{0} Real Real.instOne))\n        (@OfNat.ofNat.{0} Real 2\n          (@instOfNatAtLeastTwo.{0} Real 2 Real.instNatCast\n            (@instNatAtLeastTwo (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)))))))\n  {ε : Real} (hε : @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)) ε)\n  (hn_1 : Not (@Eq.{1} Nat n (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0))))\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n)\n  (h_original_goal :\n    @LE.le.{0} ENNReal\n      (@Preorder.toLE.{0} ENNReal\n        (@PartialOrder.toPreorder.{0} ENNReal\n          (@CompleteSemilatticeInf.toPartialOrder.{0} ENNReal\n            (@CompleteLattice.toCompleteSemilatticeInf.{0} ENNReal\n              (@CompletelyDistribLattice.toCompleteLattice.{0} ENNReal\n                (@CompleteLinearOrder.toCompletelyDistribLattice.{0} ENNReal ENNReal.instCompleteLinearOrder))))))\n      (@DFunLike.coe.{u + 1, u + 1, 1}\n        (@MeasureTheory.Measure.{u} (Fin n → Ω)\n          (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n        (Set.{u} (Fin n → Ω)) (fun (x : Set.{u} (Fin n → Ω)) => ENNReal)\n        (@MeasureTheory.Measure.instFunLike.{u} (Fin n → Ω)\n          (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n        (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n          fun (x : Fin n) => μ)\n        fun (ω : Fin n → Ω) =>\n        @LE.le.{0} Real Real.instLE\n          (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd)\n            (@HSMul.hSMul.{0, 0, 0} Nat Real Real\n              (@instHSMul.{0, 0} Nat Real (@AddMonoid.toNatSMul.{0} Real Real.instAddMonoid))\n              (@OfNat.ofNat.{0} Nat 2 (instOfNatNat 2)) (@rademacherComplexity.{u, v, w} Ω inst ι 𝒳 n f μ X))\n            ε)\n          (@uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω)))\n      (@DFunLike.coe.{u + 1, u + 1, 1}\n        (@MeasureTheory.Measure.{u} (Fin n → Ω)\n          (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n        (Set.{u} (Fin n → Ω)) (fun (x : Set.{u} (Fin n → Ω)) => ENNReal)\n        (@MeasureTheory.Measure.instFunLike.{u} (Fin n → Ω)\n          (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst))\n        (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n          fun (x : Fin n) => μ)\n        fun (ω : Fin n → Ω) =>\n        @LE.le.{0} Real Real.instLE ε\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω))\n            (@MeasureTheory.integral.{u, 0} (Fin n → Ω) Real Real.normedAddCommGroup\n              (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n                (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n                (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n              (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst)\n              (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n                fun (x : Fin n) => μ)\n              fun (x : Fin n → Ω) =>\n              @uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X x))))) :\n  @HasSubset.Subset.{u} (Set.{u} (Fin n → Ω)) (@Set.instHasSubset.{u} (Fin n → Ω))\n    (fun (ω : Fin n → Ω) =>\n      @LE.le.{0} Real Real.instLE\n        (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd)\n          (@HSMul.hSMul.{0, 0, 0} Nat Real Real\n            (@instHSMul.{0, 0} Nat Real (@AddMonoid.toNatSMul.{0} Real Real.instAddMonoid))\n            (@OfNat.ofNat.{0} Nat 2 (instOfNatNat 2)) (@rademacherComplexity.{u, v, w} Ω inst ι 𝒳 n f μ X))\n          ε)\n        (@uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω)))\n    fun (ω : Fin n → Ω) =>\n    @LE.le.{0} Real Real.instLE ε\n      (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n        (@uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X ω))\n        (@MeasureTheory.integral.{u, 0} (Fin n → Ω) Real Real.normedAddCommGroup\n          (@InnerProductSpace.toNormedSpace.{0, 0} Real Real Real.instRCLike\n            (@NormedAddCommGroup.toSeminormedAddCommGroup.{0} Real Real.normedAddCommGroup)\n            (@RCLike.toInnerProductSpaceReal.{0} Real Real.instRCLike))\n          (@MeasurableSpace.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) fun (i : Fin n) => inst)\n          (@MeasureTheory.Measure.pi.{0, u} (Fin n) (fun (x : Fin n) => Ω) (Fin.fintype n) (fun (i : Fin n) => inst)\n            fun (x : Fin n) => μ)\n          fun (x : Fin n → Ω) =>\n          @uniformDeviation.{u, v, w} Ω inst ι 𝒳 n f μ X (@Function.comp.{1, u + 1, w + 1} (Fin n) Ω 𝒳 X x))) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem measure_mono (h : s ⊆ t) : μ s ≤ μ t"
            }
        ]
    }
]