[
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 31,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\n⊢ ∫ (x : Ω), |f a (X x)| ∂μ ≤ ∫ (x : Ω), b ∂μ",
        "tactic": "apply integral_mono",
        "tactic_state_after": "[case hf\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n a : ι\n ⊢ Integrable (fun a_1 => |f a (X a_1)|) μ,\n case hg\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n a : ι\n ⊢ Integrable (fun a => b) μ,\n case h\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n a : ι\n ⊢ (fun a_1 => |f a (X a_1)|) ≤ fun a => b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\nh_original_goal : ∫ (x : Ω), |f a (X x)| ∂μ ≤ ∫ (x : Ω), b ∂μ\n⊢ Integrable (fun a_1 => |f a (X a_1)|) μ",
        "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} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (a : ι)\n  (h_original_goal : ∫ (x : Ω), |f a (X x)| ∂μ ≤ ∫ (x : Ω), b ∂μ) : Integrable (fun a_1 => |f a (X a_1)|) μ := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_0.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (a : ι)\n  (h_original_goal :\n    @LE.le.{0} Real Real.instLE\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 : Ω) => @abs.{0} Real Real.lattice Real.instAddGroup (f a (X x)))\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 : Ω) => b)) :\n  @MeasureTheory.Integrable.{0, u} Real\n    (@ContinuousENorm.toENorm.{0} Real\n      (@UniformSpace.toTopologicalSpace.{0} Real\n        (@PseudoMetricSpace.toUniformSpace.{0} Real\n          (@SeminormedAddGroup.toPseudoMetricSpace.{0} Real\n            (@SeminormedAddCommGroup.toSeminormedAddGroup.{0} Real\n              (@NonUnitalSeminormedRing.toSeminormedAddCommGroup.{0} Real\n                (@NonUnitalSeminormedCommRing.toNonUnitalSeminormedRing.{0} Real\n                  (@SeminormedCommRing.toNonUnitalSeminormedCommRing.{0} Real\n                    (@NormedCommRing.toSeminormedCommRing.{0} Real Real.normedCommRing))))))))\n      (@SeminormedAddGroup.toContinuousENorm.{0} Real\n        (@SeminormedAddCommGroup.toSeminormedAddGroup.{0} Real\n          (@NonUnitalSeminormedRing.toSeminormedAddCommGroup.{0} Real\n            (@NonUnitalSeminormedCommRing.toNonUnitalSeminormedRing.{0} Real\n              (@SeminormedCommRing.toNonUnitalSeminormedCommRing.{0} Real\n                (@NormedCommRing.toSeminormedCommRing.{0} Real Real.normedCommRing)))))))\n    (@UniformSpace.toTopologicalSpace.{0} Real (@PseudoMetricSpace.toUniformSpace.{0} Real Real.pseudoMetricSpace)) Ω\n    inst (fun (a_1 : Ω) => @abs.{0} Real Real.lattice Real.instAddGroup (f a (X a_1))) μ := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem integral_mono {f g : α → ℝ} (hf : Integrable f μ) (hg : Integrable g μ) (h : f ≤ g) :\n    ∫ a, f a ∂μ ≤ ∫ a, g a ∂μ"
            },
            {
                "library": "Mathlib",
                "definition": "theorem integral_mono (h : f ≤ g) : (∫ u in a..b, f u ∂μ) ≤ ∫ u in a..b, g u ∂μ"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 31,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\n⊢ ∫ (x : Ω), |f a (X x)| ∂μ ≤ ∫ (x : Ω), b ∂μ",
        "tactic": "apply integral_mono",
        "tactic_state_after": "[case hf\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n a : ι\n ⊢ Integrable (fun a_1 => |f a (X a_1)|) μ,\n case hg\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n a : ι\n ⊢ Integrable (fun a => b) μ,\n case h\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n a : ι\n ⊢ (fun a_1 => |f a (X a_1)|) ≤ fun a => b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\nh_original_goal : ∫ (x : Ω), |f a (X x)| ∂μ ≤ ∫ (x : Ω), b ∂μ\n⊢ Integrable (fun a => b) μ",
        "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} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (a : ι)\n  (h_original_goal : ∫ (x : Ω), |f a (X x)| ∂μ ≤ ∫ (x : Ω), b ∂μ) : Integrable (fun a => b) μ := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_1.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (a : ι)\n  (h_original_goal :\n    @LE.le.{0} Real Real.instLE\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 : Ω) => @abs.{0} Real Real.lattice Real.instAddGroup (f a (X x)))\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 : Ω) => b)) :\n  @MeasureTheory.Integrable.{0, u} Real\n    (@ContinuousENorm.toENorm.{0} Real\n      (@UniformSpace.toTopologicalSpace.{0} Real\n        (@PseudoMetricSpace.toUniformSpace.{0} Real\n          (@SeminormedAddGroup.toPseudoMetricSpace.{0} Real\n            (@SeminormedAddCommGroup.toSeminormedAddGroup.{0} Real\n              (@NonUnitalSeminormedRing.toSeminormedAddCommGroup.{0} Real\n                (@NonUnitalSeminormedCommRing.toNonUnitalSeminormedRing.{0} Real\n                  (@SeminormedCommRing.toNonUnitalSeminormedCommRing.{0} Real\n                    (@NormedCommRing.toSeminormedCommRing.{0} Real Real.normedCommRing))))))))\n      (@SeminormedAddGroup.toContinuousENorm.{0} Real\n        (@SeminormedAddCommGroup.toSeminormedAddGroup.{0} Real\n          (@NonUnitalSeminormedRing.toSeminormedAddCommGroup.{0} Real\n            (@NonUnitalSeminormedCommRing.toNonUnitalSeminormedRing.{0} Real\n              (@SeminormedCommRing.toNonUnitalSeminormedCommRing.{0} Real\n                (@NormedCommRing.toSeminormedCommRing.{0} Real Real.normedCommRing)))))))\n    (@UniformSpace.toTopologicalSpace.{0} Real (@PseudoMetricSpace.toUniformSpace.{0} Real Real.pseudoMetricSpace)) Ω\n    inst (fun (a : Ω) => b) μ := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem integral_mono {f g : α → ℝ} (hf : Integrable f μ) (hg : Integrable g μ) (h : f ≤ g) :\n    ∫ a, f a ∂μ ≤ ∫ a, g a ∂μ"
            },
            {
                "library": "Mathlib",
                "definition": "theorem integral_mono (h : f ≤ g) : (∫ u in a..b, f u ∂μ) ≤ ∫ u in a..b, g u ∂μ"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 31,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\n⊢ ∫ (x : Ω), |f a (X x)| ∂μ ≤ ∫ (x : Ω), b ∂μ",
        "tactic": "apply integral_mono",
        "tactic_state_after": "[case hf\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n a : ι\n ⊢ Integrable (fun a_1 => |f a (X a_1)|) μ,\n case hg\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n a : ι\n ⊢ Integrable (fun a => b) μ,\n case h\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n a : ι\n ⊢ (fun a_1 => |f a (X a_1)|) ≤ fun a => b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\nh_original_goal : ∫ (x : Ω), |f a (X x)| ∂μ ≤ ∫ (x : Ω), b ∂μ\n⊢ (fun a_1 => |f a (X a_1)|) ≤ fun a => b",
        "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} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (a : ι)\n  (h_original_goal : ∫ (x : Ω), |f a (X x)| ∂μ ≤ ∫ (x : Ω), b ∂μ) : (fun a_1 => |f a (X a_1)|) ≤ fun a => b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_2.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (a : ι)\n  (h_original_goal :\n    @LE.le.{0} Real Real.instLE\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 : Ω) => @abs.{0} Real Real.lattice Real.instAddGroup (f a (X x)))\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 : Ω) => b)) :\n  @LE.le.{u} (Ω → Real) (@Pi.hasLe.{u, 0} Ω (fun (a : Ω) => Real) fun (i : Ω) => Real.instLE)\n    (fun (a_1 : Ω) => @abs.{0} Real Real.lattice Real.instAddGroup (f a (X a_1))) fun (a : Ω) => b := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem integral_mono {f g : α → ℝ} (hf : Integrable f μ) (hg : Integrable g μ) (h : f ≤ g) :\n    ∫ a, f a ∂μ ≤ ∫ a, g a ∂μ"
            },
            {
                "library": "Mathlib",
                "definition": "theorem integral_mono (h : f ≤ g) : (∫ u in a..b, f u ∂μ) ≤ ∫ u in a..b, g u ∂μ"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 38,
        "tactic_state_before": "case hf.right.h.h.left\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\na_1 : Ω\n⊢ ?hf.right.a ≤ |f a (X a_1)|",
        "tactic": "exact abs_nonneg (f a (X a_1))",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\na_1 : Ω\n⊢ 0 ≤ |f a (X a_1)|",
        "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} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (a : ι) (a_1 : Ω) :\n  0 ≤ |f a (X a_1)| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_3.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (a : ι) (a_1 : Ω) :\n  @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n    (@OfNat.ofNat.{0} Real 0\n      (@Zero.toOfNat0.{0} Real\n        (@NegZeroClass.toZero.{0} Real\n          (@SubNegZeroMonoid.toNegZeroClass.{0} Real\n            (@SubtractionMonoid.toSubNegZeroMonoid.{0} Real\n              (@AddGroup.toSubtractionMonoid.{0} Real Real.instAddGroup))))))\n    (@abs.{0} Real Real.lattice Real.instAddGroup (f a (X a_1))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 39,
        "tactic_state_before": "case hf.right.h.h.right\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\na_1 : Ω\n⊢ |f a (X a_1)| ≤ ?hf.right.b",
        "tactic": "apply hf'",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\na_1 : Ω\n⊢ |f a (X a_1)| ≤ b",
        "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} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (a : ι) (a_1 : Ω) :\n  |f a (X a_1)| ≤ b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_4.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (a : ι) (a_1 : Ω) :\n  @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n    (@abs.{0} Real Real.lattice Real.instAddGroup (f a (X a_1))) b := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 40,
        "tactic_state_before": "case hg\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\n⊢ Integrable (fun a => b) μ",
        "tactic": "exact integrable_const b",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\n⊢ Integrable (fun a => b) μ",
        "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} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) :\n  Integrable (fun a => b) μ := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_5.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b) :\n  @MeasureTheory.Integrable.{0, u} Real\n    (@ContinuousENorm.toENorm.{0} Real\n      (@UniformSpace.toTopologicalSpace.{0} Real\n        (@PseudoMetricSpace.toUniformSpace.{0} Real\n          (@SeminormedAddGroup.toPseudoMetricSpace.{0} Real\n            (@SeminormedAddCommGroup.toSeminormedAddGroup.{0} Real\n              (@NonUnitalSeminormedRing.toSeminormedAddCommGroup.{0} Real\n                (@NonUnitalSeminormedCommRing.toNonUnitalSeminormedRing.{0} Real\n                  (@SeminormedCommRing.toNonUnitalSeminormedCommRing.{0} Real\n                    (@NormedCommRing.toSeminormedCommRing.{0} Real Real.normedCommRing))))))))\n      (@SeminormedAddGroup.toContinuousENorm.{0} Real\n        (@SeminormedAddCommGroup.toSeminormedAddGroup.{0} Real\n          (@NonUnitalSeminormedRing.toSeminormedAddCommGroup.{0} Real\n            (@NonUnitalSeminormedCommRing.toNonUnitalSeminormedRing.{0} Real\n              (@SeminormedCommRing.toNonUnitalSeminormedCommRing.{0} Real\n                (@NormedCommRing.toSeminormedCommRing.{0} Real Real.normedCommRing)))))))\n    (@UniformSpace.toTopologicalSpace.{0} Real (@PseudoMetricSpace.toUniformSpace.{0} Real Real.pseudoMetricSpace)) Ω\n    inst (fun (a : Ω) => b) μ := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem integrable_const [IsFiniteMeasure μ] (c : β) : Integrable (fun _ : α => c) μ"
            },
            {
                "library": "Mathlib",
                "definition": "theorem integrable_const (c : E) : Integrable I l (fun _ => c) vol"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 41,
        "tactic_state_before": "case h\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\n⊢ (fun a_1 => |f a (X a_1)|) ≤ fun a => b",
        "tactic": "exact fun i ↦ hf' a (X i)",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\n⊢ (fun a_1 => |f a (X a_1)|) ≤ fun a => b",
        "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} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (a : ι) :\n  (fun a_1 => |f a (X a_1)|) ≤ fun a => b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_6.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (a : ι) :\n  @LE.le.{u} (Ω → Real) (@Pi.hasLe.{u, 0} Ω (fun (a : Ω) => Real) fun (i : Ω) => Real.instLE)\n    (fun (a_1 : Ω) => @abs.{0} Real Real.lattice Real.instAddGroup (f a (X a_1))) fun (a : Ω) => b := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 42,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\n⊢ ∫ (x : Ω), b ∂μ = b",
        "tactic": "simp",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\na : ι\n⊢ ∫ (x : Ω), b ∂μ = b",
        "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} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) :\n  ∫ (x : Ω), b ∂μ = b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_7.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b) :\n  @Eq.{1} Real\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 : Ω) => b)\n    b := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 48,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\n⊢ |(↑n)⁻¹ * ∑ k, f j (x k) - ∫ (x : Ω), f j (X x) ∂μ -\n        ((↑n)⁻¹ * ∑ k, f j (Function.update x i x' k) - ∫ (x : Ω), f j (X x) ∂μ)| =\n    |(↑n)⁻¹ * ∑ k, f j (x k) - (↑n)⁻¹ * ∑ k, f j (Function.update x i x' k)|",
        "tactic": "rw [sub_sub_sub_cancel_right]",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\n⊢ |(↑n)⁻¹ * ∑ k, f j (x k) - ∫ (x : Ω), f j (X x) ∂μ -\n        ((↑n)⁻¹ * ∑ k, f j (Function.update x i x' k) - ∫ (x : Ω), f j (X x) ∂μ)| =\n    |(↑n)⁻¹ * ∑ k, f j (x k) - (↑n)⁻¹ * ∑ k, f j (Function.update x i x' k)|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_8.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) :\n  |(↑n)⁻¹ * ∑ k, f j (x k) - ∫ (x : Ω), f j (X x) ∂μ -\n        ((↑n)⁻¹ * ∑ k, f j (Function.update x i x' k) - ∫ (x : Ω), f j (X x) ∂μ)| =\n    |(↑n)⁻¹ * ∑ k, f j (x k) - (↑n)⁻¹ * ∑ k, f j (Function.update x i x' k)| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_8.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι) :\n  @Eq.{1} Real\n    (@abs.{0} Real Real.lattice Real.instAddGroup\n      (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\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 j (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 : Ω) => f j (X x)))\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) =>\n              f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f j (X x)))))\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 j (x k)))\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) =>\n            f j\n              (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 50,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\n⊢ |(↑n)⁻¹ * ∑ k, f j (x k) - (↑n)⁻¹ * ∑ k, f j (Function.update x i x' k)| =\n    |(↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k))|",
        "tactic": "apply congrArg",
        "tactic_state_after": "[case h\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n j : ι\n ⊢ (↑n)⁻¹ * ∑ k, f j (x k) - (↑n)⁻¹ * ∑ k, f j (Function.update x i x' k) =\n     (↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k))]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\nh_original_goal :\n  |(↑n)⁻¹ * ∑ k, f j (x k) - (↑n)⁻¹ * ∑ k, f j (Function.update x i x' k)| =\n    |(↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k))|\n⊢ (↑n)⁻¹ * ∑ k, f j (x k) - (↑n)⁻¹ * ∑ k, f j (Function.update x i x' k) =\n    (↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k))",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_9.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι)\n  (h_original_goal :\n    |(↑n)⁻¹ * ∑ k, f j (x k) - (↑n)⁻¹ * ∑ k, f j (Function.update x i x' k)| =\n      |(↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k))|) :\n  (↑n)⁻¹ * ∑ k, f j (x k) - (↑n)⁻¹ * ∑ k, f j (Function.update x i x' k) =\n    (↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k)) := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_9.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (h_original_goal :\n    @Eq.{1} Real\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 j (x k)))\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) =>\n              f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k)))))\n      (@abs.{0} Real Real.lattice Real.instAddGroup\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          (@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 j (x k))\n            (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n              fun (k : Fin n) =>\n              f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k)))))) :\n  @Eq.{1} Real\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 j (x k)))\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) =>\n          f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\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      (@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 j (x k))\n        (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n          fun (k : Fin n) =>\n          f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 51,
        "tactic_state_before": "case h\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\n⊢ (↑n)⁻¹ * ∑ k, f j (x k) - (↑n)⁻¹ * ∑ k, f j (Function.update x i x' k) =\n    (↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k))",
        "tactic": "exact\n  Eq.symm (mul_sub_left_distrib (↑n)⁻¹ (∑ k : Fin n, f j (x k)) (∑ k : Fin n, f j (Function.update x i x' k)))",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\n⊢ (↑n)⁻¹ * ∑ k, f j (x k) - (↑n)⁻¹ * ∑ k, f j (Function.update x i x' k) =\n    (↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k))",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_10.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) :\n  (↑n)⁻¹ * ∑ k, f j (x k) - (↑n)⁻¹ * ∑ k, f j (Function.update x i x' k) =\n    (↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k)) := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_10.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι) :\n  @Eq.{1} Real\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 j (x k)))\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) =>\n          f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\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      (@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 j (x k))\n        (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n          fun (k : Fin n) =>\n          f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 56,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\n⊢ |(↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k))| =\n    |(↑n)⁻¹ * ∑ k, (f j (x k) - f j (Function.update x i x' k))|",
        "tactic": "apply congrArg",
        "tactic_state_after": "[case h\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n j : ι\n ⊢ (↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k)) =\n     (↑n)⁻¹ * ∑ k, (f j (x k) - f j (Function.update x i x' k))]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\nh_original_goal :\n  |(↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k))| =\n    |(↑n)⁻¹ * ∑ k, (f j (x k) - f j (Function.update x i x' k))|\n⊢ (↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k)) =\n    (↑n)⁻¹ * ∑ k, (f j (x k) - f j (Function.update x i x' k))",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_11.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι)\n  (h_original_goal :\n    |(↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k))| =\n      |(↑n)⁻¹ * ∑ k, (f j (x k) - f j (Function.update x i x' k))|) :\n  (↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k)) =\n    (↑n)⁻¹ * ∑ k, (f j (x k) - f j (Function.update x i x' k)) := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_11.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (h_original_goal :\n    @Eq.{1} Real\n      (@abs.{0} Real Real.lattice Real.instAddGroup\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          (@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 j (x k))\n            (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n              fun (k : Fin n) =>\n              f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k)))))\n      (@abs.{0} Real Real.lattice Real.instAddGroup\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) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n              (f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k)))))) :\n  @Eq.{1} Real\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      (@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 j (x k))\n        (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n          fun (k : Fin n) =>\n          f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\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) =>\n        @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n          (f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 57,
        "tactic_state_before": "case h\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\n⊢ (↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k)) =\n    (↑n)⁻¹ * ∑ k, (f j (x k) - f j (Function.update x i x' k))",
        "tactic": "rw [Finset.sum_sub_distrib]",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\n⊢ (↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k)) =\n    (↑n)⁻¹ * ∑ k, (f j (x k) - f j (Function.update x i x' k))",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_12.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) :\n  (↑n)⁻¹ * (∑ k, f j (x k) - ∑ k, f j (Function.update x i x' k)) =\n    (↑n)⁻¹ * ∑ k, (f j (x k) - f j (Function.update x i x' k)) := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_12.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι) :\n  @Eq.{1} Real\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      (@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 j (x k))\n        (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n          fun (k : Fin n) =>\n          f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\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) =>\n        @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n          (f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 59,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\n⊢ |(↑n)⁻¹ * ∑ k, (f j (x k) - f j (Function.update x i x' k))| =\n    (↑n)⁻¹ * |∑ k, (f j (x k) - f j (Function.update x i x' k))|",
        "tactic": "rw [abs_mul]",
        "tactic_state_after": "[Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n j : ι\n ⊢ |(↑n)⁻¹| * |∑ k, (f j (x k) - f j (Function.update x i x' k))| =\n     (↑n)⁻¹ * |∑ k, (f j (x k) - f j (Function.update x i x' k))|]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\nh_original_goal :\n  |(↑n)⁻¹ * ∑ k, (f j (x k) - f j (Function.update x i x' k))| =\n    (↑n)⁻¹ * |∑ k, (f j (x k) - f j (Function.update x i x' k))|\n⊢ |(↑n)⁻¹| * |∑ k, (f j (x k) - f j (Function.update x i x' k))| =\n    (↑n)⁻¹ * |∑ k, (f j (x k) - f j (Function.update x i x' k))|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_13.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι)\n  (h_original_goal :\n    |(↑n)⁻¹ * ∑ k, (f j (x k) - f j (Function.update x i x' k))| =\n      (↑n)⁻¹ * |∑ k, (f j (x k) - f j (Function.update x i x' k))|) :\n  |(↑n)⁻¹| * |∑ k, (f j (x k) - f j (Function.update x i x' k))| =\n    (↑n)⁻¹ * |∑ k, (f j (x k) - f j (Function.update x i x' k))| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_13.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (h_original_goal :\n    @Eq.{1} Real\n      (@abs.{0} Real Real.lattice Real.instAddGroup\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) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n              (f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k)))))\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        (@abs.{0} Real Real.lattice Real.instAddGroup\n          (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n            fun (k : Fin n) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n              (f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k)))))) :\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            (@NonUnitalNonAssocRing.toNonUnitalNonAssocSemiring.{0} Real\n              (@NonAssocRing.toNonUnitalNonAssocRing.{0} Real\n                (@Ring.toNonAssocRing.{0} Real\n                  (@StrictOrderedRing.toRing.{0} Real\n                    (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))))))\n      (@abs.{0} Real\n        (@DistribLattice.toLattice.{0} Real\n          (@instDistribLatticeOfLinearOrder.{0} Real\n            (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n        (@AddGroupWithOne.toAddGroup.{0} Real\n          (@Ring.toAddGroupWithOne.{0} Real\n            (@StrictOrderedRing.toRing.{0} Real\n              (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n        (@Inv.inv.{0} Real Real.instInv (@Nat.cast.{0} Real Real.instNatCast n)))\n      (@abs.{0} Real\n        (@DistribLattice.toLattice.{0} Real\n          (@instDistribLatticeOfLinearOrder.{0} Real\n            (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n        (@AddGroupWithOne.toAddGroup.{0} Real\n          (@Ring.toAddGroupWithOne.{0} Real\n            (@StrictOrderedRing.toRing.{0} Real\n              (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n        (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n          fun (k : Fin n) =>\n          @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n            (f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k)))))\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      (@abs.{0} Real Real.lattice Real.instAddGroup\n        (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n          fun (k : Fin n) =>\n          @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n            (f j\n              (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "lemma abs_mul (a b : α) : |a * b| = |a| * |b|"
            },
            {
                "library": "Mathlib",
                "definition": "theorem abs_mul (x y : EReal) : (x * y).abs = x.abs * y.abs"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 60,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\n⊢ |(↑n)⁻¹| * |∑ k, (f j (x k) - f j (Function.update x i x' k))| =\n    (↑n)⁻¹ * |∑ k, (f j (x k) - f j (Function.update x i x' k))|",
        "tactic": "simp",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\n⊢ |(↑n)⁻¹| * |∑ k, (f j (x k) - f j (Function.update x i x' k))| =\n    (↑n)⁻¹ * |∑ k, (f j (x k) - f j (Function.update x i x' k))|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_14.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) :\n  |(↑n)⁻¹| * |∑ k, (f j (x k) - f j (Function.update x i x' k))| =\n    (↑n)⁻¹ * |∑ k, (f j (x k) - f j (Function.update x i x' k))| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_14.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι) :\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            (@NonUnitalNonAssocRing.toNonUnitalNonAssocSemiring.{0} Real\n              (@NonAssocRing.toNonUnitalNonAssocRing.{0} Real\n                (@Ring.toNonAssocRing.{0} Real\n                  (@StrictOrderedRing.toRing.{0} Real\n                    (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))))))\n      (@abs.{0} Real\n        (@DistribLattice.toLattice.{0} Real\n          (@instDistribLatticeOfLinearOrder.{0} Real\n            (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n        (@AddGroupWithOne.toAddGroup.{0} Real\n          (@Ring.toAddGroupWithOne.{0} Real\n            (@StrictOrderedRing.toRing.{0} Real\n              (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n        (@Inv.inv.{0} Real Real.instInv (@Nat.cast.{0} Real Real.instNatCast n)))\n      (@abs.{0} Real\n        (@DistribLattice.toLattice.{0} Real\n          (@instDistribLatticeOfLinearOrder.{0} Real\n            (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n        (@AddGroupWithOne.toAddGroup.{0} Real\n          (@Ring.toAddGroupWithOne.{0} Real\n            (@StrictOrderedRing.toRing.{0} Real\n              (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n        (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n          fun (k : Fin n) =>\n          @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n            (f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k)))))\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      (@abs.{0} Real Real.lattice Real.instAddGroup\n        (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n          fun (k : Fin n) =>\n          @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n            (f j\n              (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 66,
        "tactic_state_before": "case refine_2\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\n⊢ |∑ k, (f j (x k) - f j (Function.update x i x' k))| ≤ (↑n)⁻¹ * 2 * b * ↑n",
        "tactic": "rw [pe]",
        "tactic_state_after": "[case refine_2\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n j : ι\n pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\n ⊢ |∑ k, (f j (x k) - f j (Function.update x i x' k))| ≤ 2 * b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nh_original_goal : |∑ k, (f j (x k) - f j (Function.update x i x' k))| ≤ (↑n)⁻¹ * 2 * b * ↑n\n⊢ |∑ k, (f j (x k) - f j (Function.update x i x' k))| ≤ 2 * b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_15.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) (pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b)\n  (h_original_goal : |∑ k, (f j (x k) - f j (Function.update x i x' k))| ≤ (↑n)⁻¹ * 2 * b * ↑n) :\n  |∑ k, (f j (x k) - f j (Function.update x i x' k))| ≤ 2 * b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_15.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (pe :\n    @Eq.{1} Real\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          (@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        (@Nat.cast.{0} Real Real.instNatCast n))\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\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  (h_original_goal :\n    @LE.le.{0} Real (@Preorder.toLE.{0} Real (@PartialOrder.toPreorder.{0} Real Real.partialOrder))\n      (@abs.{0} Real Real.lattice Real.instAddGroup\n        (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n          fun (k : Fin n) =>\n          @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n            (f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\n      (@HMul.hMul.{0, 0, 0} Real Real Real\n        (@instHMul.{0} Real\n          (@MulZeroClass.toMul.{0} Real\n            (@MulZeroOneClass.toMulZeroClass.{0} Real\n              (@MonoidWithZero.toMulZeroOneClass.{0} Real\n                (@GroupWithZero.toMonoidWithZero.{0} Real\n                  (@CommGroupWithZero.toGroupWithZero.{0} Real\n                    (@Semifield.toCommGroupWithZero.{0} Real\n                      (@LinearOrderedSemifield.toSemifield.{0} Real\n                        (@LinearOrderedField.toLinearOrderedSemifield.{0} Real Real.instLinearOrderedField)))))))))\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        (@Nat.cast.{0} Real Real.instNatCast n))) :\n  @LE.le.{0} Real (@Preorder.toLE.{0} Real (@PartialOrder.toPreorder.{0} Real Real.partialOrder))\n    (@abs.{0} Real Real.lattice Real.instAddGroup\n      (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n        fun (k : Fin n) =>\n        @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n          (f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\n    (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\n      (@OfNat.ofNat.{0} Real 2\n        (@instOfNatAtLeastTwo.{0} Real 2 Real.instNatCast\n          (@instNatAtLeastTwo (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)))))\n      b) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 68,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\n⊢ |∑ k, (f j (x k) - f j (Function.update x i x' k))| ≤ ∑ k, |f j (x k) - f j (Function.update x i x' k)|",
        "tactic": "exact Finset.abs_sum_le_sum_abs (fun i_1 ↦ f j (x i_1) - f j (Function.update x i x' i_1)) Finset.univ",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\n⊢ |∑ k, (f j (x k) - f j (Function.update x i x' k))| ≤ ∑ k, |f j (x k) - f j (Function.update x i x' k)|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_16.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) (pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b) :\n  |∑ k, (f j (x k) - f j (Function.update x i x' k))| ≤ ∑ k, |f j (x k) - f j (Function.update x i x' k)| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_16.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (pe :\n    @Eq.{1} Real\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          (@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        (@Nat.cast.{0} Real Real.instNatCast n))\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\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  @LE.le.{0} Real Real.instLE\n    (@abs.{0} Real Real.lattice Real.instAddGroup\n      (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n        fun (k : Fin n) =>\n        @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n          (f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\n    (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n      fun (k : Fin n) =>\n      @abs.{0} Real Real.lattice Real.instAddGroup\n        (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n          (f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 73,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\n⊢ ∑ k, |f j (x k) - f j (Function.update x i x' k)| = ∑ k, |if i = k then f j (x k) - f j x' else 0|",
        "tactic": "apply congrArg",
        "tactic_state_after": "[case h\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n j : ι\n pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\n ⊢ (fun k => |f j (x k) - f j (Function.update x i x' k)|) = fun k => |if i = k then f j (x k) - f j x' else 0|]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nh_original_goal : ∑ k, |f j (x k) - f j (Function.update x i x' k)| = ∑ k, |if i = k then f j (x k) - f j x' else 0|\n⊢ (fun k => |f j (x k) - f j (Function.update x i x' k)|) = fun k => |if i = k then f j (x k) - f j x' else 0|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_17.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) (pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b)\n  (h_original_goal :\n    ∑ k, |f j (x k) - f j (Function.update x i x' k)| = ∑ k, |if i = k then f j (x k) - f j x' else 0|) :\n  (fun k => |f j (x k) - f j (Function.update x i x' k)|) = fun k => |if i = k then f j (x k) - f j x' else 0| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_17.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (pe :\n    @Eq.{1} Real\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          (@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        (@Nat.cast.{0} Real Real.instNatCast n))\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\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  (h_original_goal :\n    @Eq.{1} Real\n      (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n        fun (k : Fin n) =>\n        @abs.{0} Real Real.lattice Real.instAddGroup\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n            (f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\n      (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n        fun (k : Fin n) =>\n        @abs.{0} Real Real.lattice Real.instAddGroup\n          (@ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n            (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))))) :\n  @Eq.{1} (Fin n → Real)\n    (fun (k : Fin n) =>\n      @abs.{0} Real Real.lattice Real.instAddGroup\n        (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n          (f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\n    fun (k : Fin n) =>\n    @abs.{0} Real Real.lattice Real.instAddGroup\n      (@ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n        (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n        (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 75,
        "tactic_state_before": "case h.h\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\n⊢ |f j (x k) - f j (Function.update x i x' k)| = |if i = k then f j (x k) - f j x' else 0|",
        "tactic": "apply congrArg",
        "tactic_state_after": "[case h.h.h\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n j : ι\n pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\n k : Fin n\n ⊢ f j (x k) - f j (Function.update x i x' k) = if i = k then f j (x k) - f j x' else 0]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\nh_original_goal : |f j (x k) - f j (Function.update x i x' k)| = |if i = k then f j (x k) - f j x' else 0|\n⊢ f j (x k) - f j (Function.update x i x' k) = if i = k then f j (x k) - f j x' else 0",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_18.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) (pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b)\n  (k : Fin n)\n  (h_original_goal : |f j (x k) - f j (Function.update x i x' k)| = |if i = k then f j (x k) - f j x' else 0|) :\n  f j (x k) - f j (Function.update x i x' k) = if i = k then f j (x k) - f j x' else 0 := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_18.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (pe :\n    @Eq.{1} Real\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          (@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        (@Nat.cast.{0} Real Real.instNatCast n))\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\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  (k : Fin n)\n  (h_original_goal :\n    @Eq.{1} Real\n      (@abs.{0} Real Real.lattice Real.instAddGroup\n        (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n          (f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\n      (@abs.{0} Real Real.lattice Real.instAddGroup\n        (@ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n          (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))))) :\n  @Eq.{1} Real\n    (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n      (f j (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k)))\n    (@ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n      (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n      (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 77,
        "tactic_state_before": "case h.h.h\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\n⊢ f j (x k) - f j (if h : k = i then ⋯ ▸ x' else x k) = if i = k then f j (x k) - f j x' else 0",
        "tactic": "simp only [eq_rec_constant, dite_eq_ite, h, g]",
        "tactic_state_after": "[case h.h.h\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n j : ι\n pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\n k : Fin n\n ⊢ f j (x k) - f j (if k = i then x' else x k) = if i = k then f j (x k) - f j x' else 0]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\nh_original_goal : f j (x k) - f j (if h : k = i then ⋯ ▸ x' else x k) = if i = k then f j (x k) - f j x' else 0\n⊢ f j (x k) - f j (if k = i then x' else x k) = if i = k then f j (x k) - f j x' else 0",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_19.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) (pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b)\n  (k : Fin n)\n  (h_original_goal :\n    f j (x k) - f j (if h : k = i then Eq.symm h ▸ x' else x k) = if i = k then f j (x k) - f j x' else 0) :\n  f j (x k) - f j (if k = i then x' else x k) = if i = k then f j (x k) - f j x' else 0 := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_19.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (pe :\n    @Eq.{1} Real\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          (@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        (@Nat.cast.{0} Real Real.instNatCast n))\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\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  (k : Fin n)\n  (h_original_goal :\n    @Eq.{1} Real\n      (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n        (f j\n          (@dite.{w + 1} Z (@Eq.{1} (Fin n) k i) (instDecidableEqFin n k i)\n            (fun (h : @Eq.{1} (Fin n) k i) =>\n              @Eq.rec.{w + 1, 1} (Fin n) i (fun (x : Fin n) (x : @Eq.{1} (Fin n) i x) => Z) x' k\n                (@Eq.symm.{1} (Fin n) k i h))\n            fun (h : Not (@Eq.{1} (Fin n) k i)) => x k)))\n      (@ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n        (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n        (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)))) :\n  @Eq.{1} Real\n    (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n      (f j (@ite.{w + 1} Z (@Eq.{1} (Fin n) k i) (instDecidableEqFin n k i) x' (x k))))\n    (@ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n      (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n      (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 81,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\n⊢ f j (x k) - f j (if k = i then x' else x k) = f j (x k) - if k = i then f j x' else f j (x k)",
        "tactic": "simp only [sub_right_inj, h, g]",
        "tactic_state_after": "[Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n j : ι\n pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\n k : Fin n\n ⊢ f j (if k = i then x' else x k) = if k = i then f j x' else f j (x k)]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\nh_original_goal : f j (x k) - f j (if k = i then x' else x k) = f j (x k) - if k = i then f j x' else f j (x k)\n⊢ f j (if k = i then x' else x k) = if k = i then f j x' else f j (x k)",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_20.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) (pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b)\n  (k : Fin n)\n  (h_original_goal : f j (x k) - f j (if k = i then x' else x k) = f j (x k) - if k = i then f j x' else f j (x k)) :\n  f j (if k = i then x' else x k) = if k = i then f j x' else f j (x k) := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_20.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (pe :\n    @Eq.{1} Real\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          (@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        (@Nat.cast.{0} Real Real.instNatCast n))\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\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  (k : Fin n)\n  (h_original_goal :\n    @Eq.{1} Real\n      (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n        (f j (@ite.{w + 1} Z (@Eq.{1} (Fin n) k i) (instDecidableEqFin n k i) x' (x k))))\n      (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n        (@ite.{1} Real (@Eq.{1} (Fin n) k i) (instDecidableEqFin n k i) (f j x') (f j (x k))))) :\n  @Eq.{1} Real (f j (@ite.{w + 1} Z (@Eq.{1} (Fin n) k i) (instDecidableEqFin n k i) x' (x k)))\n    (@ite.{1} Real (@Eq.{1} (Fin n) k i) (instDecidableEqFin n k i) (f j x') (f j (x k))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 82,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\n⊢ f j (if k = i then x' else x k) = if k = i then f j x' else f j (x k)",
        "tactic": "exact apply_ite (f j) (k = i) x' (x k)",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\n⊢ f j (if k = i then x' else x k) = if k = i then f j x' else f j (x k)",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_21.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) (pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b)\n  (k : Fin n) : f j (if k = i then x' else x k) = if k = i then f j x' else f j (x k) := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_21.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (pe :\n    @Eq.{1} Real\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          (@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        (@Nat.cast.{0} Real Real.instNatCast n))\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\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  (k : Fin n) :\n  @Eq.{1} Real (f j (@ite.{w + 1} Z (@Eq.{1} (Fin n) k i) (instDecidableEqFin n k i) x' (x k)))\n    (@ite.{1} Real (@Eq.{1} (Fin n) k i) (instDecidableEqFin n k i) (f j x') (f j (x k))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 84,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\n⊢ (f j (x k) - if k = i then f j x' else f j (x k)) = if k = i then f j (x k) - f j x' else f j (x k) - f j (x k)",
        "tactic": "exact sub_ite (k = i) (f j (x k)) (f j x') (f j (x k))",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\n⊢ (f j (x k) - if k = i then f j x' else f j (x k)) = if k = i then f j (x k) - f j x' else f j (x k) - f j (x k)",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_22.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) (pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b)\n  (k : Fin n) :\n  (f j (x k) - if k = i then f j x' else f j (x k)) =\n    if k = i then f j (x k) - f j x' else f j (x k) - f j (x k) := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_22.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (pe :\n    @Eq.{1} Real\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          (@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        (@Nat.cast.{0} Real Real.instNatCast n))\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\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  (k : Fin n) :\n  @Eq.{1} Real\n    (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n      (@ite.{1} Real (@Eq.{1} (Fin n) k i) (instDecidableEqFin n k i) (f j x') (f j (x k))))\n    (@ite.{1} Real (@Eq.{1} (Fin n) k i) (instDecidableEqFin n k i)\n      (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n      (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j (x k)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 86,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\n⊢ (if k = i then f j (x k) - f j x' else f j (x k) - f j (x k)) = if i = k then f j (x k) - f j x' else 0",
        "tactic": "simp only [sub_self, h, g]",
        "tactic_state_after": "[Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n j : ι\n pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\n k : Fin n\n ⊢ (if k = i then f j (x k) - f j x' else 0) = if i = k then f j (x k) - f j x' else 0]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\nh_original_goal :\n  (if k = i then f j (x k) - f j x' else f j (x k) - f j (x k)) = if i = k then f j (x k) - f j x' else 0\n⊢ (if k = i then f j (x k) - f j x' else 0) = if i = k then f j (x k) - f j x' else 0",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_23.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) (pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b)\n  (k : Fin n)\n  (h_original_goal :\n    (if k = i then f j (x k) - f j x' else f j (x k) - f j (x k)) = if i = k then f j (x k) - f j x' else 0) :\n  (if k = i then f j (x k) - f j x' else 0) = if i = k then f j (x k) - f j x' else 0 := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_23.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (pe :\n    @Eq.{1} Real\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          (@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        (@Nat.cast.{0} Real Real.instNatCast n))\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\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  (k : Fin n)\n  (h_original_goal :\n    @Eq.{1} Real\n      (@ite.{1} Real (@Eq.{1} (Fin n) k i) (instDecidableEqFin n k i)\n        (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n        (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j (x k))))\n      (@ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n        (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n        (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)))) :\n  @Eq.{1} Real\n    (@ite.{1} Real (@Eq.{1} (Fin n) k i) (instDecidableEqFin n k i)\n      (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n      (@OfNat.ofNat.{0} Real 0\n        (@Zero.toOfNat0.{0} Real\n          (@AddZeroClass.toZero.{0} Real\n            (@AddMonoid.toAddZeroClass.{0} Real\n              (@SubNegMonoid.toAddMonoid.{0} Real (@AddGroup.toSubNegMonoid.{0} Real Real.instAddGroup)))))))\n    (@ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n      (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n      (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 88,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\n⊢ i = k ↔ k = i",
        "tactic": "exact eq_comm",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\n⊢ i = k ↔ k = i",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_24.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b) (k : Fin n) :\n  i = k ↔ k = i := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_24.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (pe :\n    @Eq.{1} Real\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          (@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        (@Nat.cast.{0} Real Real.instNatCast n))\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\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  (k : Fin n) : Iff (@Eq.{1} (Fin n) i k) (@Eq.{1} (Fin n) k i) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 89,
        "tactic_state_before": "case h.h.h\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\nt : f j (x k) - f j (if k = i then x' else x k) = if i = k then f j (x k) - f j x' else 0\n⊢ f j (x k) - f j (if k = i then x' else x k) = if i = k then f j (x k) - f j x' else 0",
        "tactic": "exact t",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\nt : f j (x k) - f j (if k = i then x' else x k) = if i = k then f j (x k) - f j x' else 0\n⊢ f j (x k) - f j (if k = i then x' else x k) = if i = k then f j (x k) - f j x' else 0",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_25.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) (pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b)\n  (k : Fin n) (t : f j (x k) - f j (if k = i then x' else x k) = if i = k then f j (x k) - f j x' else 0) :\n  f j (x k) - f j (if k = i then x' else x k) = if i = k then f j (x k) - f j x' else 0 := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_25.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (pe :\n    @Eq.{1} Real\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          (@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        (@Nat.cast.{0} Real Real.instNatCast n))\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\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  (k : Fin n)\n  (t :\n    @Eq.{1} Real\n      (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n        (f j (@ite.{w + 1} Z (@Eq.{1} (Fin n) k i) (instDecidableEqFin n k i) x' (x k))))\n      (@ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n        (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n        (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)))) :\n  @Eq.{1} Real\n    (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k))\n      (f j (@ite.{w + 1} Z (@Eq.{1} (Fin n) k i) (instDecidableEqFin n k i) x' (x k))))\n    (@ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n      (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n      (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 91,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\n⊢ ∑ k, |if i = k then f j (x k) - f j x' else 0| = ∑ k, if i = k then |f j (x k) - f j x'| else |0|",
        "tactic": "apply congrArg",
        "tactic_state_after": "[case h\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n j : ι\n pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\n ⊢ (fun k => |if i = k then f j (x k) - f j x' else 0|) = fun k => if i = k then |f j (x k) - f j x'| else |0|]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nh_original_goal : ∑ k, |if i = k then f j (x k) - f j x' else 0| = ∑ k, if i = k then |f j (x k) - f j x'| else |0|\n⊢ (fun k => |if i = k then f j (x k) - f j x' else 0|) = fun k => if i = k then |f j (x k) - f j x'| else |0|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_26.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) (pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b)\n  (h_original_goal :\n    ∑ k, |if i = k then f j (x k) - f j x' else 0| = ∑ k, if i = k then |f j (x k) - f j x'| else |0|) :\n  (fun k => |if i = k then f j (x k) - f j x' else 0|) = fun k => if i = k then |f j (x k) - f j x'| else |0| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_26.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (pe :\n    @Eq.{1} Real\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          (@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        (@Nat.cast.{0} Real Real.instNatCast n))\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\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  (h_original_goal :\n    @Eq.{1} Real\n      (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n        fun (k : Fin n) =>\n        @abs.{0} Real Real.lattice Real.instAddGroup\n          (@ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n            (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))))\n      (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n        fun (k : Fin n) =>\n        @ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x')))\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))))) :\n  @Eq.{1} (Fin n → Real)\n    (fun (k : Fin n) =>\n      @abs.{0} Real Real.lattice Real.instAddGroup\n        (@ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n          (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))))\n    fun (k : Fin n) =>\n    @ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n      (@abs.{0} Real Real.lattice Real.instAddGroup\n        (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x')))\n      (@abs.{0} Real Real.lattice Real.instAddGroup\n        (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 93,
        "tactic_state_before": "case h.h\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\n⊢ |if i = k then f j (x k) - f j x' else 0| = if i = k then |f j (x k) - f j x'| else |0|",
        "tactic": "exact apply_ite abs (i = k) (f j (x k) - f j x') 0",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\nk : Fin n\n⊢ |if i = k then f j (x k) - f j x' else 0| = if i = k then |f j (x k) - f j x'| else |0|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_27.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) (pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b)\n  (k : Fin n) : |if i = k then f j (x k) - f j x' else 0| = if i = k then |f j (x k) - f j x'| else |0| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_27.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (pe :\n    @Eq.{1} Real\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          (@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        (@Nat.cast.{0} Real Real.instNatCast n))\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\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  (k : Fin n) :\n  @Eq.{1} Real\n    (@abs.{0} Real Real.lattice Real.instAddGroup\n      (@ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n        (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x'))\n        (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))))\n    (@ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n      (@abs.{0} Real Real.lattice Real.instAddGroup\n        (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x')))\n      (@abs.{0} Real Real.lattice Real.instAddGroup\n        (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 94,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\n⊢ (∑ k, if i = k then |f j (x k) - f j x'| else |0|) = |f j (x i) - f j x'|",
        "tactic": "simp",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\nj : ι\npe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b\n⊢ (∑ k, if i = k then |f j (x k) - f j x'| else |0|) = |f j (x i) - f j x'|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_28.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) (s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) (j : ι) (pe : (↑n)⁻¹ * 2 * b * ↑n = 2 * b) :\n  (∑ k, if i = k then |f j (x k) - f j x'| else |0|) = |f j (x i) - f j x'| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_28.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z)\n  (s' :\n    ∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b)\n  (j : ι)\n  (pe :\n    @Eq.{1} Real\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          (@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        (@Nat.cast.{0} Real Real.instNatCast n))\n      (@HMul.hMul.{0, 0, 0} Real Real Real (@instHMul.{0} Real Real.instMul)\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  @Eq.{1} Real\n    (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n      fun (k : Fin n) =>\n      @ite.{1} Real (@Eq.{1} (Fin n) i k) (instDecidableEqFin n i k)\n        (@abs.{0} Real Real.lattice Real.instAddGroup\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x k)) (f j x')))\n        (@abs.{0} Real Real.lattice Real.instAddGroup\n          (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))))\n    (@abs.{0} Real Real.lattice Real.instAddGroup\n      (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (f j (x i)) (f j x'))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 99,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\nthis : |(⨆ i, |g i|) - ⨆ i_1, |h i_1|| ≤ (↑n)⁻¹ * 2 * b\n⊢ |(⨆ i, |(↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ|) -\n        ⨆ i_1, |(↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ|| ≤\n    (↑n)⁻¹ * 2 * b",
        "tactic": "exact this",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\nthis : |(⨆ i, |g i|) - ⨆ i_1, |h i_1|| ≤ (↑n)⁻¹ * 2 * b\n⊢ |(⨆ i, |(↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ|) -\n        ⨆ i_1, |(↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ|| ≤\n    (↑n)⁻¹ * 2 * b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_29.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      |(⨆ i, |g i|) - ⨆ i_1, |h i_1|| ≤ (↑n)⁻¹ * 2 * b →\n        |(⨆ i, |(↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ|) -\n              ⨆ i_1, |(↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ|| ≤\n          (↑n)⁻¹ * 2 * b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_29.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))))\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        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\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                    (@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 (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 : Ω) => f i (X x))))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\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) =>\n                        f i_1\n                          (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x))))))\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) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 102,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n⊢ (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|",
        "tactic": "apply ciSup_sub",
        "tactic_state_after": "[case hf\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n ⊢ BddAbove (Set.range fun i => |g i|)]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\nh_original_goal : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\n⊢ BddAbove (Set.range fun i => |g i|)",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_30.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| → BddAbove (Set.range fun i => |g i|) := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_30.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        @BddAbove.{0} Real\n          (@Preorder.toLE.{0} Real\n            (@PartialOrder.toPreorder.{0} Real\n              (@SemilatticeInf.toPartialOrder.{0} Real\n                (@Lattice.toSemilatticeInf.{0} Real\n                  (@ConditionallyCompleteLattice.toLattice.{0} Real\n                    (@ConditionallyCompleteLinearOrder.toConditionallyCompleteLattice.{0} Real\n                      Real.instConditionallyCompleteLinearOrder))))))\n          (@Set.range.{0, v + 1} Real ι fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i)) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 103,
        "tactic_state_before": "case hf\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n⊢ BddAbove (Set.range fun i => |g i|)",
        "tactic": "rw [bddAbove_def]",
        "tactic_state_after": "[case hf\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n ⊢ ∃ x, ∀ y ∈ Set.range fun i => |g i|, y ≤ x]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\nh_original_goal : BddAbove (Set.range fun i => |g i|)\n⊢ ∃ x, ∀ y ∈ Set.range fun i => |g i|, y ≤ x",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_31.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      BddAbove (Set.range fun i => |g i|) → ∃ x, ∀ y ∈ Set.range fun i => |g i|, y ≤ x := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_31.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @BddAbove.{0} Real\n          (@Preorder.toLE.{0} Real\n            (@PartialOrder.toPreorder.{0} Real\n              (@SemilatticeInf.toPartialOrder.{0} Real\n                (@Lattice.toSemilatticeInf.{0} Real\n                  (@ConditionallyCompleteLattice.toLattice.{0} Real\n                    (@ConditionallyCompleteLinearOrder.toConditionallyCompleteLattice.{0} Real\n                      Real.instConditionallyCompleteLinearOrder))))))\n          (@Set.range.{0, v + 1} Real ι fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i)) →\n        @Exists.{1} Real fun (x : Real) =>\n          ∀ (y : Real),\n            @Membership.mem.{0, 0} Real (Set.{0} Real) (@Set.instMembership.{0} Real)\n                (@Set.range.{0, v + 1} Real ι fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i)) y →\n              @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder) y x := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem bddAbove_def : BddAbove s ↔ ∃ x, ∀ y ∈ s, y ≤ x"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 105,
        "tactic_state_before": "case h\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n⊢ ∀ y ∈ Set.range fun i => |g i|, y ≤ b + b",
        "tactic": "simp only [Set.mem_range, forall_exists_index, forall_apply_eq_imp_iff, h, g]",
        "tactic_state_after": "[case h\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n ⊢ ∀ (a : ι), |(↑n)⁻¹ * ∑ k, f a (x k) - ∫ (x : Ω), f a (X x) ∂μ| ≤ b + b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\nh_original_goal : ∀ y ∈ Set.range fun i => |g i|, y ≤ b + b\n⊢ ∀ (a : ι), |(↑n)⁻¹ * ∑ k, f a (x k) - ∫ (x : Ω), f a (X x) ∂μ| ≤ b + b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_32.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (∀ y ∈ Set.range fun i => |g i|, y ≤ b + b) →\n        ∀ (a : ι), |(↑n)⁻¹ * ∑ k, f a (x k) - ∫ (x : Ω), f a (X x) ∂μ| ≤ b + b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_32.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      (∀ (y : Real),\n          @Membership.mem.{0, 0} Real (Set.{0} Real) (@Set.instMembership.{0} Real)\n              (@Set.range.{0, v + 1} Real ι fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i)) y →\n            @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder) y\n              (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b)) →\n        ∀ (a : ι),\n          @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\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 a (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 : Ω) => f a (X x))))\n            (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 110,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\na : ι\n⊢ |(↑n)⁻¹ * ∑ k, f a (x k)| = (↑n)⁻¹ * |∑ k, f a (x k)|",
        "tactic": "rw [abs_mul]",
        "tactic_state_after": "[Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n a : ι\n ⊢ |(↑n)⁻¹| * |∑ k, f a (x k)| = (↑n)⁻¹ * |∑ k, f a (x k)|]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\na : ι\nh_original_goal : |(↑n)⁻¹ * ∑ k, f a (x k)| = (↑n)⁻¹ * |∑ k, f a (x k)|\n⊢ |(↑n)⁻¹| * |∑ k, f a (x k)| = (↑n)⁻¹ * |∑ k, f a (x k)|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_33.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      ∀ (a : ι),\n        |(↑n)⁻¹ * ∑ k, f a (x k)| = (↑n)⁻¹ * |∑ k, f a (x k)| →\n          |(↑n)⁻¹| * |∑ k, f a (x k)| = (↑n)⁻¹ * |∑ k, f a (x k)| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_33.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      ∀ (a : ι),\n        @Eq.{1} Real\n            (@abs.{0} Real Real.lattice Real.instAddGroup\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 a (x k))))\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              (@abs.{0} Real Real.lattice Real.instAddGroup\n                (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                  fun (k : Fin n) => f a (x k)))) →\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                    (@NonUnitalNonAssocRing.toNonUnitalNonAssocSemiring.{0} Real\n                      (@NonAssocRing.toNonUnitalNonAssocRing.{0} Real\n                        (@Ring.toNonAssocRing.{0} Real\n                          (@StrictOrderedRing.toRing.{0} Real\n                            (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))))))\n              (@abs.{0} Real\n                (@DistribLattice.toLattice.{0} Real\n                  (@instDistribLatticeOfLinearOrder.{0} Real\n                    (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n                (@AddGroupWithOne.toAddGroup.{0} Real\n                  (@Ring.toAddGroupWithOne.{0} Real\n                    (@StrictOrderedRing.toRing.{0} Real\n                      (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n                (@Inv.inv.{0} Real Real.instInv (@Nat.cast.{0} Real Real.instNatCast n)))\n              (@abs.{0} Real\n                (@DistribLattice.toLattice.{0} Real\n                  (@instDistribLatticeOfLinearOrder.{0} Real\n                    (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n                (@AddGroupWithOne.toAddGroup.{0} Real\n                  (@Ring.toAddGroupWithOne.{0} Real\n                    (@StrictOrderedRing.toRing.{0} Real\n                      (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n                (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                  fun (k : Fin n) => f a (x k))))\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              (@abs.{0} Real Real.lattice Real.instAddGroup\n                (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                  fun (k : Fin n) => f a (x k)))) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "lemma abs_mul (a b : α) : |a * b| = |a| * |b|"
            },
            {
                "library": "Mathlib",
                "definition": "theorem abs_mul (x y : EReal) : (x * y).abs = x.abs * y.abs"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 111,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\na : ι\n⊢ |(↑n)⁻¹| * |∑ k, f a (x k)| = (↑n)⁻¹ * |∑ k, f a (x k)|",
        "tactic": "simp",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\na : ι\n⊢ |(↑n)⁻¹| * |∑ k, f a (x k)| = (↑n)⁻¹ * |∑ k, f a (x k)|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_34.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      ∀ (a : ι), |(↑n)⁻¹| * |∑ k, f a (x k)| = (↑n)⁻¹ * |∑ k, f a (x k)| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_34.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      ∀ (a : ι),\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                  (@NonUnitalNonAssocRing.toNonUnitalNonAssocSemiring.{0} Real\n                    (@NonAssocRing.toNonUnitalNonAssocRing.{0} Real\n                      (@Ring.toNonAssocRing.{0} Real\n                        (@StrictOrderedRing.toRing.{0} Real\n                          (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))))))\n            (@abs.{0} Real\n              (@DistribLattice.toLattice.{0} Real\n                (@instDistribLatticeOfLinearOrder.{0} Real\n                  (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n              (@AddGroupWithOne.toAddGroup.{0} Real\n                (@Ring.toAddGroupWithOne.{0} Real\n                  (@StrictOrderedRing.toRing.{0} Real\n                    (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n              (@Inv.inv.{0} Real Real.instInv (@Nat.cast.{0} Real Real.instNatCast n)))\n            (@abs.{0} Real\n              (@DistribLattice.toLattice.{0} Real\n                (@instDistribLatticeOfLinearOrder.{0} Real\n                  (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n              (@AddGroupWithOne.toAddGroup.{0} Real\n                (@Ring.toAddGroupWithOne.{0} Real\n                  (@StrictOrderedRing.toRing.{0} Real\n                    (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n              (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                fun (k : Fin n) => f a (x k))))\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            (@abs.{0} Real Real.lattice Real.instAddGroup\n              (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                fun (k : Fin n) => f a (x k)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 120,
        "tactic_state_before": "case refine_4\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni✝ : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i✝ x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\na : ι\ni : Fin n\n⊢ 0 i ≤ |f a (x i)|",
        "tactic": "simp",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni✝ : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i✝ x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\na : ι\ni : Fin n\n⊢ 0 i ≤ |f a (x i)|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_35.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i_1 : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1_1 => (↑n)⁻¹ * ∑ k, f i_1_1 (Function.update x i_1 x' k) - ∫ (x : Ω), f i_1_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) → ∀ (a : ι) (i : Fin n), 0 i ≤ |f a (x i)| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_35.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i_1 : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1_1 : ι) =>\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) =>\n          f i_1_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i_1 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 : Ω) => f i_1_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      ∀ (a : ι) (i : Fin n),\n        @LE.le.{0} Real\n          (@Preorder.toLE.{0} Real\n            (@PartialOrder.toPreorder.{0} Real\n              (@OrderedAddCommMonoid.toPartialOrder.{0} Real Real.orderedAddCommMonoid)))\n          (@OfNat.ofNat.{0} (Fin n → Real) 0\n            (@Zero.toOfNat0.{0} (Fin n → Real)\n              (@Pi.instZero.{0, 0} (Fin n) (fun (a : Fin n) => Real) fun (i : Fin n) =>\n                @AddZeroClass.toZero.{0} Real\n                  (@AddMonoid.toAddZeroClass.{0} Real\n                    (@AddCommMonoid.toAddMonoid.{0} Real\n                      (@OrderedAddCommMonoid.toAddCommMonoid.{0} Real Real.orderedAddCommMonoid)))))\n            i)\n          (@abs.{0} Real Real.lattice Real.instAddGroup (f a (x i))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 126,
        "tactic_state_before": "case refine_4\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\na : ι\n⊢ 0 ≤ ∑ k, b",
        "tactic": "simp only [Finset.sum_const, Finset.card_univ, Fintype.card_fin, nsmul_eq_mul, h, g]",
        "tactic_state_after": "[case refine_4\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n a : ι\n ⊢ 0 ≤ ↑n * b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\na : ι\nh_original_goal : 0 ≤ ∑ k, b\n⊢ 0 ≤ ↑n * b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_36.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) → 0 ≤ ∑ k, b → 0 ≤ ↑n * b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_36.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n          (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))\n          (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n            fun (k : Fin n) => b) →\n        @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n          (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))\n          (@HMul.hMul.{0, 0, 0} Real Real Real\n            (@instHMul.{0} Real\n              (@Distrib.toMul.{0} Real\n                (@NonUnitalNonAssocSemiring.toDistrib.{0} Real\n                  (@NonAssocSemiring.toNonUnitalNonAssocSemiring.{0} Real\n                    (@Semiring.toNonAssocSemiring.{0} Real Real.semiring)))))\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 Real.semiring))))\n              n)\n            b) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 128,
        "tactic_state_before": "case refine_4\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\na : ι\n⊢ 0 ≤ b",
        "tactic": "exact hb",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\na : ι\n⊢ 0 ≤ b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_37.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) → (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) → 0 ≤ b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_37.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real\n        (@Preorder.toLE.{0} Real\n          (@PartialOrder.toPreorder.{0} Real\n            (@SemilatticeInf.toPartialOrder.{0} Real\n              (@Lattice.toSemilatticeInf.{0} Real\n                (@DistribLattice.toLattice.{0} Real (@instDistribLatticeOfLinearOrder.{0} Real Real.linearOrder))))))\n        (@OfNat.ofNat.{0} Real 0\n          (@Zero.toOfNat0.{0} Real\n            (@MulZeroClass.toZero.{0} Real\n              (@NonUnitalNonAssocSemiring.toMulZeroClass.{0} Real\n                (@NonAssocSemiring.toNonUnitalNonAssocSemiring.{0} Real\n                  (@Semiring.toNonAssocSemiring.{0} Real Real.semiring))))))\n        b := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 131,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\na : ι\ns : |(↑n)⁻¹ * ∑ k, f a (x k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f a (x k) - ∫ (x : Ω), f a (X x) ∂μ| ≤ |(↑n)⁻¹ * ∑ k, f a (x k)| + |∫ (x : Ω), f a (X x) ∂μ|",
        "tactic": "exact abs_sub ((↑n)⁻¹ * ∑ k : Fin n, f a (x k)) (∫ (x : Ω), f a (X x) ∂μ)",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\na : ι\ns : |(↑n)⁻¹ * ∑ k, f a (x k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f a (x k) - ∫ (x : Ω), f a (X x) ∂μ| ≤ |(↑n)⁻¹ * ∑ k, f a (x k)| + |∫ (x : Ω), f a (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_38.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      ∀ (a : ι),\n        |(↑n)⁻¹ * ∑ k, f a (x k)| ≤ b →\n          |(↑n)⁻¹ * ∑ k, f a (x k) - ∫ (x : Ω), f a (X x) ∂μ| ≤\n            |(↑n)⁻¹ * ∑ k, f a (x k)| + |∫ (x : Ω), f a (X x) ∂μ| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_38.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      ∀ (a : ι),\n        @LE.le.{0} Real Real.instLE\n            (@abs.{0} Real Real.lattice Real.instAddGroup\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 a (x k))))\n            b →\n          @LE.le.{0} Real Real.instLE\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 a (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 : Ω) => f a (X x))))\n            (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd)\n              (@abs.{0} Real Real.lattice Real.instAddGroup\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 a (x k))))\n              (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 132,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\na : ι\ns : |(↑n)⁻¹ * ∑ k, f a (x k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f a (x k)| + |∫ (x : Ω), f a (X x) ∂μ| ≤ b + b",
        "tactic": "exact add_le_add s (s' a)",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\na : ι\ns : |(↑n)⁻¹ * ∑ k, f a (x k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f a (x k)| + |∫ (x : Ω), f a (X x) ∂μ| ≤ b + b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_39.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      ∀ (a : ι), |(↑n)⁻¹ * ∑ k, f a (x k)| ≤ b → |(↑n)⁻¹ * ∑ k, f a (x k)| + |∫ (x : Ω), f a (X x) ∂μ| ≤ b + b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_39.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      ∀ (a : ι),\n        @LE.le.{0} Real Real.instLE\n            (@abs.{0} Real Real.lattice Real.instAddGroup\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 a (x k))))\n            b →\n          @LE.le.{0} Real Real.instLE\n            (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd)\n              (@abs.{0} Real Real.lattice Real.instAddGroup\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 a (x k))))\n              (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x))))\n            (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 133,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\n⊢ (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b",
        "tactic": "rw [p0]",
        "tactic_state_after": "[Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\n ⊢ ⨆ i, |g i| - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nh_original_goal : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n⊢ ⨆ i, |g i| - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_40.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| →\n        (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b → ⨆ i, |g i| - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_40.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        @LE.le.{0} Real Real.instLE\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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          @LE.le.{0} Real Real.instLE\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 139,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\nthis : (abs ∘ h) j ≤ ⨆ i_1, (abs ∘ h) i_1\n⊢ |h j| ≤ ⨆ i_1, |h i_1|",
        "tactic": "exact this",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\nthis : (abs ∘ h) j ≤ ⨆ i_1, (abs ∘ h) i_1\n⊢ |h j| ≤ ⨆ i_1, |h i_1|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_41.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| →\n        ∀ (j : ι), (abs ∘ h) j ≤ ⨆ i_1, (abs ∘ h) i_1 → |h j| ≤ ⨆ i_1, |h i_1| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_41.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        ∀ (j : ι),\n          @LE.le.{0} Real Real.instLE\n              (@Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) h j)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) h i_1) →\n            @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (h j))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 140,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\n⊢ (abs ∘ h) j ≤ ⨆ i_1, (abs ∘ h) i_1",
        "tactic": "apply le_ciSup",
        "tactic_state_after": "[case H\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\n j : ι\n ⊢ BddAbove (Set.range (abs ∘ h))]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\nh_original_goal : (abs ∘ h) j ≤ ⨆ i_1, (abs ∘ h) i_1\n⊢ BddAbove (Set.range (abs ∘ h))",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_42.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| →\n        ∀ (j : ι), (abs ∘ h) j ≤ ⨆ i_1, (abs ∘ h) i_1 → BddAbove (Set.range (abs ∘ h)) := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_42.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        ∀ (j : ι),\n          @LE.le.{0} Real Real.instLE\n              (@Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) h j)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) h i_1) →\n            @BddAbove.{0} Real\n              (@Preorder.toLE.{0} Real\n                (@PartialOrder.toPreorder.{0} Real\n                  (@SemilatticeInf.toPartialOrder.{0} Real\n                    (@Lattice.toSemilatticeInf.{0} Real\n                      (@ConditionallyCompleteLattice.toLattice.{0} Real\n                        (@ConditionallyCompleteLinearOrder.toConditionallyCompleteLattice.{0} Real\n                          Real.instConditionallyCompleteLinearOrder))))))\n              (@Set.range.{0, v + 1} Real ι\n                (@Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) h)) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem le_ciSup {f : ι → α} (H : BddAbove (range f)) (c : ι) : f c ≤ iSup f"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 141,
        "tactic_state_before": "case H\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\n⊢ BddAbove (Set.range (abs ∘ h))",
        "tactic": "rw [bddAbove_def]",
        "tactic_state_after": "[case H\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\n j : ι\n ⊢ ∃ x, ∀ y ∈ Set.range (abs ∘ h), y ≤ x]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\nh_original_goal : BddAbove (Set.range (abs ∘ h))\n⊢ ∃ x, ∀ y ∈ Set.range (abs ∘ h), y ≤ x",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_43.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| →\n        BddAbove (Set.range (abs ∘ h)) → ∃ x, ∀ y ∈ Set.range (abs ∘ h), y ≤ x := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_43.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        @BddAbove.{0} Real\n            (@Preorder.toLE.{0} Real\n              (@PartialOrder.toPreorder.{0} Real\n                (@SemilatticeInf.toPartialOrder.{0} Real\n                  (@Lattice.toSemilatticeInf.{0} Real\n                    (@ConditionallyCompleteLattice.toLattice.{0} Real\n                      (@ConditionallyCompleteLinearOrder.toConditionallyCompleteLattice.{0} Real\n                        Real.instConditionallyCompleteLinearOrder))))))\n            (@Set.range.{0, v + 1} Real ι\n              (@Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) h)) →\n          @Exists.{1} Real fun (x : Real) =>\n            ∀ (y : Real),\n              @Membership.mem.{0, 0} Real (Set.{0} Real) (@Set.instMembership.{0} Real)\n                  (@Set.range.{0, v + 1} Real ι\n                    (@Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) h))\n                  y →\n                @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder) y x := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem bddAbove_def : BddAbove s ↔ ∃ x, ∀ y ∈ s, y ≤ x"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 144,
        "tactic_state_before": "case h\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\n⊢ y ∈ Set.range (abs ∘ h) → y ≤ b + b",
        "tactic": "simp only [Set.mem_range, Function.comp_apply, forall_exists_index, h, g]",
        "tactic_state_after": "[case h\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\n j : ι\n y : ℝ\n ⊢ ∀ (x_1 : ι), |(↑n)⁻¹ * ∑ k, f x_1 (Function.update x i x' k) - ∫ (x : Ω), f x_1 (X x) ∂μ| = y → y ≤ b + b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nh_original_goal : y ∈ Set.range (abs ∘ h) → y ≤ b + b\n⊢ ∀ (x_1 : ι), |(↑n)⁻¹ * ∑ k, f x_1 (Function.update x i x' k) - ∫ (x : Ω), f x_1 (X x) ∂μ| = y → y ≤ b + b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_44.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| →\n        ∀ (y : ℝ),\n          (y ∈ Set.range (abs ∘ h) → y ≤ b + b) →\n            ∀ (x_1 : ι),\n              |(↑n)⁻¹ * ∑ k, f x_1 (Function.update x i x' k) - ∫ (x : Ω), f x_1 (X x) ∂μ| = y → y ≤ b + b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_44.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        ∀ (y : Real),\n          (@Membership.mem.{0, 0} Real (Set.{0} Real) (@Set.instMembership.{0} Real)\n                (@Set.range.{0, v + 1} Real ι\n                  (@Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) h))\n                y →\n              @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder) y\n                (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b)) →\n            ∀ (x_1 : ι),\n              @Eq.{1} Real\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\n                          (@Finset.univ.{0} (Fin n) (Fin.fintype n)) fun (k : Fin n) =>\n                          f x_1\n                            (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x'\n                              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 : Ω) => f x_1 (X x))))\n                  y →\n                @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder) y\n                  (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 146,
        "tactic_state_before": "case h\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n⊢ y ≤ b + b",
        "tactic": "rw [<- hx]",
        "tactic_state_after": "[case h\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\n j : ι\n y : ℝ\n z : ι\n hx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n ⊢ |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| ≤ b + b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\nh_original_goal : y ≤ b + b\n⊢ |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| ≤ b + b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_45.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| →\n        ∀ (y : ℝ) (z : ι),\n          |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y →\n            y ≤ b + b → |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| ≤ b + b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_45.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        ∀ (y : Real) (z : ι),\n          @Eq.{1} Real\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) =>\n                      f z (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f z (X x))))\n              y →\n            @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder) y\n                (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b) →\n              @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\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) =>\n                        f z\n                          (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f z (X x))))\n                (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 150,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n⊢ |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)|",
        "tactic": "rw [abs_mul]",
        "tactic_state_after": "[Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\n j : ι\n y : ℝ\n z : ι\n hx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n ⊢ |(↑n)⁻¹| * |∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)|]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\nh_original_goal : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)|\n⊢ |(↑n)⁻¹| * |∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_46.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| →\n        ∀ (y : ℝ) (z : ι),\n          |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y →\n            |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)| →\n              |(↑n)⁻¹| * |∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_46.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        ∀ (y : Real) (z : ι),\n          @Eq.{1} Real\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) =>\n                      f z (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f z (X x))))\n              y →\n            @Eq.{1} Real\n                (@abs.{0} Real Real.lattice Real.instAddGroup\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) =>\n                      f z\n                        (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\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                  (@abs.{0} Real Real.lattice Real.instAddGroup\n                    (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                      fun (k : Fin n) =>\n                      f z\n                        (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x'\n                          k)))) →\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                        (@NonUnitalNonAssocRing.toNonUnitalNonAssocSemiring.{0} Real\n                          (@NonAssocRing.toNonUnitalNonAssocRing.{0} Real\n                            (@Ring.toNonAssocRing.{0} Real\n                              (@StrictOrderedRing.toRing.{0} Real\n                                (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))))))\n                  (@abs.{0} Real\n                    (@DistribLattice.toLattice.{0} Real\n                      (@instDistribLatticeOfLinearOrder.{0} Real\n                        (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n                    (@AddGroupWithOne.toAddGroup.{0} Real\n                      (@Ring.toAddGroupWithOne.{0} Real\n                        (@StrictOrderedRing.toRing.{0} Real\n                          (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n                    (@Inv.inv.{0} Real Real.instInv (@Nat.cast.{0} Real Real.instNatCast n)))\n                  (@abs.{0} Real\n                    (@DistribLattice.toLattice.{0} Real\n                      (@instDistribLatticeOfLinearOrder.{0} Real\n                        (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n                    (@AddGroupWithOne.toAddGroup.{0} Real\n                      (@Ring.toAddGroupWithOne.{0} Real\n                        (@StrictOrderedRing.toRing.{0} Real\n                          (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n                    (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                      fun (k : Fin n) =>\n                      f z\n                        (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\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                  (@abs.{0} Real Real.lattice Real.instAddGroup\n                    (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                      fun (k : Fin n) =>\n                      f z\n                        (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x'\n                          k)))) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "lemma abs_mul (a b : α) : |a * b| = |a| * |b|"
            },
            {
                "library": "Mathlib",
                "definition": "theorem abs_mul (x y : EReal) : (x * y).abs = x.abs * y.abs"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 151,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n⊢ |(↑n)⁻¹| * |∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)|",
        "tactic": "simp",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n⊢ |(↑n)⁻¹| * |∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_47.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| →\n        ∀ (y : ℝ) (z : ι),\n          |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y →\n            |(↑n)⁻¹| * |∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_47.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        ∀ (y : Real) (z : ι),\n          @Eq.{1} Real\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) =>\n                      f z (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f z (X x))))\n              y →\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                      (@NonUnitalNonAssocRing.toNonUnitalNonAssocSemiring.{0} Real\n                        (@NonAssocRing.toNonUnitalNonAssocRing.{0} Real\n                          (@Ring.toNonAssocRing.{0} Real\n                            (@StrictOrderedRing.toRing.{0} Real\n                              (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))))))\n                (@abs.{0} Real\n                  (@DistribLattice.toLattice.{0} Real\n                    (@instDistribLatticeOfLinearOrder.{0} Real\n                      (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n                  (@AddGroupWithOne.toAddGroup.{0} Real\n                    (@Ring.toAddGroupWithOne.{0} Real\n                      (@StrictOrderedRing.toRing.{0} Real\n                        (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n                  (@Inv.inv.{0} Real Real.instInv (@Nat.cast.{0} Real Real.instNatCast n)))\n                (@abs.{0} Real\n                  (@DistribLattice.toLattice.{0} Real\n                    (@instDistribLatticeOfLinearOrder.{0} Real\n                      (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n                  (@AddGroupWithOne.toAddGroup.{0} Real\n                    (@Ring.toAddGroupWithOne.{0} Real\n                      (@StrictOrderedRing.toRing.{0} Real\n                        (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n                  (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                    fun (k : Fin n) =>\n                    f z (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\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                (@abs.{0} Real Real.lattice Real.instAddGroup\n                  (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                    fun (k : Fin n) =>\n                    f z\n                      (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x'\n                        k)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 160,
        "tactic_state_before": "case refine_4\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni✝ : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i✝ x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i✝ x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\ni : Fin n\n⊢ 0 i ≤ |f z (Function.update x i✝ x' i)|",
        "tactic": "simp",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni✝ : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i✝ x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i✝ x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\ni : Fin n\n⊢ 0 i ≤ |f z (Function.update x i✝ x' i)|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_48.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i_1 : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1_1 => (↑n)⁻¹ * ∑ k, f i_1_1 (Function.update x i_1 x' k) - ∫ (x : Ω), f i_1_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| →\n        ∀ (y : ℝ) (z : ι),\n          |(↑n)⁻¹ * ∑ k, f z (Function.update x i_1 x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y →\n            ∀ (i : Fin n), 0 i ≤ |f z (Function.update x i_1 x' i)| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_48.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i_1 : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1_1 : ι) =>\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) =>\n          f i_1_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i_1 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 : Ω) => f i_1_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        ∀ (y : Real) (z : ι),\n          @Eq.{1} Real\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) =>\n                      f z\n                        (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i_1 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 : Ω) => f z (X x))))\n              y →\n            ∀ (i : Fin n),\n              @LE.le.{0} Real\n                (@Preorder.toLE.{0} Real\n                  (@PartialOrder.toPreorder.{0} Real\n                    (@OrderedAddCommMonoid.toPartialOrder.{0} Real Real.orderedAddCommMonoid)))\n                (@OfNat.ofNat.{0} (Fin n → Real) 0\n                  (@Zero.toOfNat0.{0} (Fin n → Real)\n                    (@Pi.instZero.{0, 0} (Fin n) (fun (a : Fin n) => Real) fun (i : Fin n) =>\n                      @AddZeroClass.toZero.{0} Real\n                        (@AddMonoid.toAddZeroClass.{0} Real\n                          (@AddCommMonoid.toAddMonoid.{0} Real\n                            (@OrderedAddCommMonoid.toAddCommMonoid.{0} Real Real.orderedAddCommMonoid)))))\n                  i)\n                (@abs.{0} Real Real.lattice Real.instAddGroup\n                  (f z\n                    (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i_1 x'\n                      i))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 166,
        "tactic_state_before": "case refine_4\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n⊢ 0 ≤ ∑ k, b",
        "tactic": "simp only [Finset.sum_const, Finset.card_univ, Fintype.card_fin, nsmul_eq_mul, h, g]",
        "tactic_state_after": "[case refine_4\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\n j : ι\n y : ℝ\n z : ι\n hx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n ⊢ 0 ≤ ↑n * b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\nh_original_goal : 0 ≤ ∑ k, b\n⊢ 0 ≤ ↑n * b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_49.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| →\n        ∀ (y : ℝ) (z : ι),\n          |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y →\n            0 ≤ ∑ k, b → 0 ≤ ↑n * b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_49.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        ∀ (y : Real) (z : ι),\n          @Eq.{1} Real\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) =>\n                      f z (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f z (X x))))\n              y →\n            @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n                (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))\n                (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                  fun (k : Fin n) => b) →\n              @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n                (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))\n                (@HMul.hMul.{0, 0, 0} Real Real Real\n                  (@instHMul.{0} Real\n                    (@Distrib.toMul.{0} Real\n                      (@NonUnitalNonAssocSemiring.toDistrib.{0} Real\n                        (@NonAssocSemiring.toNonUnitalNonAssocSemiring.{0} Real\n                          (@Semiring.toNonAssocSemiring.{0} Real Real.semiring)))))\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 Real.semiring))))\n                    n)\n                  b) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 168,
        "tactic_state_before": "case refine_4\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n⊢ 0 ≤ b",
        "tactic": "exact hb",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n⊢ 0 ≤ b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_50.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| →\n        ∀ (y : ℝ) (z : ι), |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y → 0 ≤ b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_50.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        ∀ (y : Real) (z : ι),\n          @Eq.{1} Real\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) =>\n                      f z (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f z (X x))))\n              y →\n            @LE.le.{0} Real\n              (@Preorder.toLE.{0} Real\n                (@PartialOrder.toPreorder.{0} Real\n                  (@SemilatticeInf.toPartialOrder.{0} Real\n                    (@Lattice.toSemilatticeInf.{0} Real\n                      (@DistribLattice.toLattice.{0} Real\n                        (@instDistribLatticeOfLinearOrder.{0} Real Real.linearOrder))))))\n              (@OfNat.ofNat.{0} Real 0\n                (@Zero.toOfNat0.{0} Real\n                  (@MulZeroClass.toZero.{0} Real\n                    (@NonUnitalNonAssocSemiring.toMulZeroClass.{0} Real\n                      (@NonAssocSemiring.toNonUnitalNonAssocSemiring.{0} Real\n                        (@Semiring.toNonAssocSemiring.{0} Real Real.semiring))))))\n              b := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 171,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\ns0 : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| ≤\n    |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| + |∫ (x : Ω), f z (X x) ∂μ|",
        "tactic": "exact abs_sub ((↑n)⁻¹ * ∑ k : Fin n, f z (Function.update x i x' k)) (∫ (x : Ω), f z (X x) ∂μ)",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\ns0 : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| ≤\n    |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| + |∫ (x : Ω), f z (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_51.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| →\n        ∀ (y : ℝ) (z : ι),\n          |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y →\n            |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| ≤ b →\n              |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| ≤\n                |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| + |∫ (x : Ω), f z (X x) ∂μ| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_51.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        ∀ (y : Real) (z : ι),\n          @Eq.{1} Real\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) =>\n                      f z (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f z (X x))))\n              y →\n            @LE.le.{0} Real Real.instLE\n                (@abs.{0} Real Real.lattice Real.instAddGroup\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) =>\n                      f z\n                        (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\n                b →\n              @LE.le.{0} Real Real.instLE\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) =>\n                        f z\n                          (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f z (X x))))\n                (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd)\n                  (@abs.{0} Real Real.lattice Real.instAddGroup\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) =>\n                        f z\n                          (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x'\n                            k))))\n                  (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f z (X x)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 173,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\ns0 : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| + |∫ (x : Ω), f z (X x) ∂μ| ≤ b + b",
        "tactic": "exact add_le_add s0 (s' z)",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y\ns0 : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| + |∫ (x : Ω), f z (X x) ∂μ| ≤ b + b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_52.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| →\n        ∀ (y : ℝ) (z : ι),\n          |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| = y →\n            |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| ≤ b →\n              |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| + |∫ (x : Ω), f z (X x) ∂μ| ≤ b + b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_52.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        ∀ (y : Real) (z : ι),\n          @Eq.{1} Real\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) =>\n                      f z (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f z (X x))))\n              y →\n            @LE.le.{0} Real Real.instLE\n                (@abs.{0} Real Real.lattice Real.instAddGroup\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) =>\n                      f z\n                        (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\n                b →\n              @LE.le.{0} Real Real.instLE\n                (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd)\n                  (@abs.{0} Real Real.lattice Real.instAddGroup\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) =>\n                        f z\n                          (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x'\n                            k))))\n                  (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f z (X x))))\n                (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 177,
        "tactic_state_before": "case refine_2\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\n⊢ 0 ≤ (↑n)⁻¹ * 2 * b",
        "tactic": "apply (mul_nonneg_iff_of_pos_left _).mpr hb",
        "tactic_state_after": "[Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\n ⊢ 0 < (↑n)⁻¹ * 2]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\nh_original_goal : 0 ≤ (↑n)⁻¹ * 2 * b\n⊢ 0 < (↑n)⁻¹ * 2",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_53.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| → 0 ≤ (↑n)⁻¹ * 2 * b → 0 < (↑n)⁻¹ * 2 := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_53.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))\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          @LT.lt.{0} Real\n            (@Preorder.toLT.{0} Real\n              (@PartialOrder.toPreorder.{0} Real\n                (@SemilatticeInf.toPartialOrder.{0} Real\n                  (@Lattice.toSemilatticeInf.{0} Real\n                    (@DistribLattice.toLattice.{0} Real\n                      (@instDistribLatticeOfLinearOrder.{0} Real Real.linearOrder))))))\n            (@OfNat.ofNat.{0} Real 0\n              (@Zero.toOfNat0.{0} Real\n                (@MulZeroClass.toZero.{0} Real\n                  (@NonUnitalNonAssocSemiring.toMulZeroClass.{0} Real\n                    (@NonAssocSemiring.toNonUnitalNonAssocSemiring.{0} Real\n                      (@Semiring.toNonAssocSemiring.{0} Real Real.semiring))))))\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)))))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 178,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\n⊢ 0 < (↑n)⁻¹ * 2",
        "tactic": "apply Left.mul_pos (inv_pos_of_pos (Nat.cast_pos.mpr hn)) (by linarith)",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1|\n⊢ 0 < (↑n)⁻¹ * 2",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_54.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| = ⨆ i, |g i| - ⨆ i_1, |h i_1| → 0 < (↑n)⁻¹ * 2 := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_54.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @Eq.{1} Real\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\n          (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n            @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@abs.{0} Real Real.lattice Real.instAddGroup (g i))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))) →\n        @LT.lt.{0} Real\n          (@Preorder.toLT.{0} Real\n            (@PartialOrder.toPreorder.{0} Real\n              (@SemilatticeInf.toPartialOrder.{0} Real\n                (@Lattice.toSemilatticeInf.{0} Real\n                  (@DistribLattice.toLattice.{0} Real (@instDistribLatticeOfLinearOrder.{0} Real Real.linearOrder))))))\n          (@OfNat.ofNat.{0} Real 0\n            (@Zero.toOfNat0.{0} Real\n              (@MulZeroClass.toZero.{0} Real\n                (@NonUnitalNonAssocSemiring.toMulZeroClass.{0} Real\n                  (@NonAssocSemiring.toNonUnitalNonAssocSemiring.{0} Real\n                    (@Semiring.toNonAssocSemiring.{0} Real Real.semiring))))))\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)))))) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem Left.mul_pos [PosMulStrictMono α] (ha : 0 < a) (hb : 0 < b) : 0 < a * b"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 181,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n⊢ (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|",
        "tactic": "apply ciSup_sub",
        "tactic_state_after": "[case hf\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n ⊢ BddAbove (Set.range fun i => |h i|)]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nh_original_goal : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\n⊢ BddAbove (Set.range fun i => |h i|)",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_55.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| → BddAbove (Set.range fun i => |h i|) := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_55.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          @BddAbove.{0} Real\n            (@Preorder.toLE.{0} Real\n              (@PartialOrder.toPreorder.{0} Real\n                (@SemilatticeInf.toPartialOrder.{0} Real\n                  (@Lattice.toSemilatticeInf.{0} Real\n                    (@ConditionallyCompleteLattice.toLattice.{0} Real\n                      (@ConditionallyCompleteLinearOrder.toConditionallyCompleteLattice.{0} Real\n                        Real.instConditionallyCompleteLinearOrder))))))\n            (@Set.range.{0, v + 1} Real ι fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (h i)) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 182,
        "tactic_state_before": "case hf\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n⊢ BddAbove (Set.range fun i => |h i|)",
        "tactic": "rw [bddAbove_def]",
        "tactic_state_after": "[case hf\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n ⊢ ∃ x, ∀ y ∈ Set.range fun i => |h i|, y ≤ x]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nh_original_goal : BddAbove (Set.range fun i => |h i|)\n⊢ ∃ x, ∀ y ∈ Set.range fun i => |h i|, y ≤ x",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_56.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        BddAbove (Set.range fun i => |h i|) → ∃ x, ∀ y ∈ Set.range fun i => |h i|, y ≤ x := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_56.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @BddAbove.{0} Real\n            (@Preorder.toLE.{0} Real\n              (@PartialOrder.toPreorder.{0} Real\n                (@SemilatticeInf.toPartialOrder.{0} Real\n                  (@Lattice.toSemilatticeInf.{0} Real\n                    (@ConditionallyCompleteLattice.toLattice.{0} Real\n                      (@ConditionallyCompleteLinearOrder.toConditionallyCompleteLattice.{0} Real\n                        Real.instConditionallyCompleteLinearOrder))))))\n            (@Set.range.{0, v + 1} Real ι fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (h i)) →\n          @Exists.{1} Real fun (x : Real) =>\n            ∀ (y : Real),\n              @Membership.mem.{0, 0} Real (Set.{0} Real) (@Set.instMembership.{0} Real)\n                  (@Set.range.{0, v + 1} Real ι fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (h i)) y →\n                @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder) y x := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem bddAbove_def : BddAbove s ↔ ∃ x, ∀ y ∈ s, y ≤ x"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 184,
        "tactic_state_before": "case h\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n⊢ ∀ y ∈ Set.range fun i => |h i|, y ≤ b + b",
        "tactic": "simp only [Set.mem_range, forall_exists_index, forall_apply_eq_imp_iff, h, g]",
        "tactic_state_after": "[case h\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n ⊢ ∀ (a : ι), |(↑n)⁻¹ * ∑ k, f a (Function.update x i x' k) - ∫ (x : Ω), f a (X x) ∂μ| ≤ b + b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nh_original_goal : ∀ y ∈ Set.range fun i => |h i|, y ≤ b + b\n⊢ ∀ (a : ι), |(↑n)⁻¹ * ∑ k, f a (Function.update x i x' k) - ∫ (x : Ω), f a (X x) ∂μ| ≤ b + b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_57.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (∀ y ∈ Set.range fun i => |h i|, y ≤ b + b) →\n          ∀ (a : ι), |(↑n)⁻¹ * ∑ k, f a (Function.update x i x' k) - ∫ (x : Ω), f a (X x) ∂μ| ≤ b + b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_57.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        (∀ (y : Real),\n            @Membership.mem.{0, 0} Real (Set.{0} Real) (@Set.instMembership.{0} Real)\n                (@Set.range.{0, v + 1} Real ι fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (h i)) y →\n              @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder) y\n                (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b)) →\n          ∀ (a : ι),\n            @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\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) =>\n                      f a (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f a (X x))))\n              (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 189,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nz : ι\n⊢ |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)|",
        "tactic": "rw [abs_mul]",
        "tactic_state_after": "[Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n z : ι\n ⊢ |(↑n)⁻¹| * |∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)|]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nz : ι\nh_original_goal : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)|\n⊢ |(↑n)⁻¹| * |∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_58.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        ∀ (z : ι),\n          |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)| →\n            |(↑n)⁻¹| * |∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_58.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        ∀ (z : ι),\n          @Eq.{1} Real\n              (@abs.{0} Real Real.lattice Real.instAddGroup\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) =>\n                    f z (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\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                (@abs.{0} Real Real.lattice Real.instAddGroup\n                  (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                    fun (k : Fin n) =>\n                    f z\n                      (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k)))) →\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                      (@NonUnitalNonAssocRing.toNonUnitalNonAssocSemiring.{0} Real\n                        (@NonAssocRing.toNonUnitalNonAssocRing.{0} Real\n                          (@Ring.toNonAssocRing.{0} Real\n                            (@StrictOrderedRing.toRing.{0} Real\n                              (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))))))\n                (@abs.{0} Real\n                  (@DistribLattice.toLattice.{0} Real\n                    (@instDistribLatticeOfLinearOrder.{0} Real\n                      (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n                  (@AddGroupWithOne.toAddGroup.{0} Real\n                    (@Ring.toAddGroupWithOne.{0} Real\n                      (@StrictOrderedRing.toRing.{0} Real\n                        (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n                  (@Inv.inv.{0} Real Real.instInv (@Nat.cast.{0} Real Real.instNatCast n)))\n                (@abs.{0} Real\n                  (@DistribLattice.toLattice.{0} Real\n                    (@instDistribLatticeOfLinearOrder.{0} Real\n                      (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n                  (@AddGroupWithOne.toAddGroup.{0} Real\n                    (@Ring.toAddGroupWithOne.{0} Real\n                      (@StrictOrderedRing.toRing.{0} Real\n                        (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n                  (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                    fun (k : Fin n) =>\n                    f z (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\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                (@abs.{0} Real Real.lattice Real.instAddGroup\n                  (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                    fun (k : Fin n) =>\n                    f z\n                      (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x'\n                        k)))) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "lemma abs_mul (a b : α) : |a * b| = |a| * |b|"
            },
            {
                "library": "Mathlib",
                "definition": "theorem abs_mul (x y : EReal) : (x * y).abs = x.abs * y.abs"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 190,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nz : ι\n⊢ |(↑n)⁻¹| * |∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)|",
        "tactic": "simp",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nz : ι\n⊢ |(↑n)⁻¹| * |∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_59.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        ∀ (z : ι),\n          |(↑n)⁻¹| * |∑ k, f z (Function.update x i x' k)| = (↑n)⁻¹ * |∑ k, f z (Function.update x i x' k)| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_59.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        ∀ (z : ι),\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                    (@NonUnitalNonAssocRing.toNonUnitalNonAssocSemiring.{0} Real\n                      (@NonAssocRing.toNonUnitalNonAssocRing.{0} Real\n                        (@Ring.toNonAssocRing.{0} Real\n                          (@StrictOrderedRing.toRing.{0} Real\n                            (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))))))\n              (@abs.{0} Real\n                (@DistribLattice.toLattice.{0} Real\n                  (@instDistribLatticeOfLinearOrder.{0} Real\n                    (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n                (@AddGroupWithOne.toAddGroup.{0} Real\n                  (@Ring.toAddGroupWithOne.{0} Real\n                    (@StrictOrderedRing.toRing.{0} Real\n                      (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n                (@Inv.inv.{0} Real Real.instInv (@Nat.cast.{0} Real Real.instNatCast n)))\n              (@abs.{0} Real\n                (@DistribLattice.toLattice.{0} Real\n                  (@instDistribLatticeOfLinearOrder.{0} Real\n                    (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n                (@AddGroupWithOne.toAddGroup.{0} Real\n                  (@Ring.toAddGroupWithOne.{0} Real\n                    (@StrictOrderedRing.toRing.{0} Real\n                      (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n                (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                  fun (k : Fin n) =>\n                  f z (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\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              (@abs.{0} Real Real.lattice Real.instAddGroup\n                (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                  fun (k : Fin n) =>\n                  f z\n                    (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x'\n                      k)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 199,
        "tactic_state_before": "case refine_4\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni✝ : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i✝ x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nz : ι\ni : Fin n\n⊢ 0 i ≤ |f z (Function.update x i✝ x' i)|",
        "tactic": "simp",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni✝ : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i✝ x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nz : ι\ni : Fin n\n⊢ 0 i ≤ |f z (Function.update x i✝ x' i)|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_60.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i_1 : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1_1 => (↑n)⁻¹ * ∑ k, f i_1_1 (Function.update x i_1 x' k) - ∫ (x : Ω), f i_1_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        ∀ (z : ι) (i : Fin n), 0 i ≤ |f z (Function.update x i_1 x' i)| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_60.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i_1 : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1_1 : ι) =>\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) =>\n          f i_1_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i_1 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 : Ω) => f i_1_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        ∀ (z : ι) (i : Fin n),\n          @LE.le.{0} Real\n            (@Preorder.toLE.{0} Real\n              (@PartialOrder.toPreorder.{0} Real\n                (@OrderedAddCommMonoid.toPartialOrder.{0} Real Real.orderedAddCommMonoid)))\n            (@OfNat.ofNat.{0} (Fin n → Real) 0\n              (@Zero.toOfNat0.{0} (Fin n → Real)\n                (@Pi.instZero.{0, 0} (Fin n) (fun (a : Fin n) => Real) fun (i : Fin n) =>\n                  @AddZeroClass.toZero.{0} Real\n                    (@AddMonoid.toAddZeroClass.{0} Real\n                      (@AddCommMonoid.toAddMonoid.{0} Real\n                        (@OrderedAddCommMonoid.toAddCommMonoid.{0} Real Real.orderedAddCommMonoid)))))\n              i)\n            (@abs.{0} Real Real.lattice Real.instAddGroup\n              (f z\n                (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i_1 x'\n                  i))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 205,
        "tactic_state_before": "case refine_4\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nz : ι\n⊢ 0 ≤ ∑ k, b",
        "tactic": "simp only [Finset.sum_const, Finset.card_univ, Fintype.card_fin, nsmul_eq_mul, h, g]",
        "tactic_state_after": "[case refine_4\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n z : ι\n ⊢ 0 ≤ ↑n * b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nz : ι\nh_original_goal : 0 ≤ ∑ k, b\n⊢ 0 ≤ ↑n * b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_61.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b → 0 ≤ ∑ k, b → 0 ≤ ↑n * b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_61.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n            (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))\n            (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n              fun (k : Fin n) => b) →\n          @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n            (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))\n            (@HMul.hMul.{0, 0, 0} Real Real Real\n              (@instHMul.{0} Real\n                (@Distrib.toMul.{0} Real\n                  (@NonUnitalNonAssocSemiring.toDistrib.{0} Real\n                    (@NonAssocSemiring.toNonUnitalNonAssocSemiring.{0} Real\n                      (@Semiring.toNonAssocSemiring.{0} Real Real.semiring)))))\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 Real.semiring))))\n                n)\n              b) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 207,
        "tactic_state_before": "case refine_4\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nz : ι\n⊢ 0 ≤ b",
        "tactic": "exact hb",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nz : ι\n⊢ 0 ≤ b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_62.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) → (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b → 0 ≤ b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_62.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @LE.le.{0} Real\n          (@Preorder.toLE.{0} Real\n            (@PartialOrder.toPreorder.{0} Real\n              (@SemilatticeInf.toPartialOrder.{0} Real\n                (@Lattice.toSemilatticeInf.{0} Real\n                  (@DistribLattice.toLattice.{0} Real (@instDistribLatticeOfLinearOrder.{0} Real Real.linearOrder))))))\n          (@OfNat.ofNat.{0} Real 0\n            (@Zero.toOfNat0.{0} Real\n              (@MulZeroClass.toZero.{0} Real\n                (@NonUnitalNonAssocSemiring.toMulZeroClass.{0} Real\n                  (@NonAssocSemiring.toNonUnitalNonAssocSemiring.{0} Real\n                    (@Semiring.toNonAssocSemiring.{0} Real Real.semiring))))))\n          b := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 210,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nz : ι\ns0 : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| ≤\n    |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| + |∫ (x : Ω), f z (X x) ∂μ|",
        "tactic": "exact abs_sub ((↑n)⁻¹ * ∑ k : Fin n, f z (Function.update x i x' k)) (∫ (x : Ω), f z (X x) ∂μ)",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nz : ι\ns0 : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| ≤\n    |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| + |∫ (x : Ω), f z (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_63.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        ∀ (z : ι),\n          |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| ≤ b →\n            |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k) - ∫ (x : Ω), f z (X x) ∂μ| ≤\n              |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| + |∫ (x : Ω), f z (X x) ∂μ| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_63.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        ∀ (z : ι),\n          @LE.le.{0} Real Real.instLE\n              (@abs.{0} Real Real.lattice Real.instAddGroup\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) =>\n                    f z (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\n              b →\n            @LE.le.{0} Real Real.instLE\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) =>\n                      f z (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f z (X x))))\n              (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd)\n                (@abs.{0} Real Real.lattice Real.instAddGroup\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) =>\n                      f z\n                        (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\n                (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f z (X x)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 211,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nz : ι\ns0 : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| + |∫ (x : Ω), f z (X x) ∂μ| ≤ b + b",
        "tactic": "exact add_le_add s0 (s' z)",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\nz : ι\ns0 : |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| + |∫ (x : Ω), f z (X x) ∂μ| ≤ b + b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_64.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        ∀ (z : ι),\n          |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| ≤ b →\n            |(↑n)⁻¹ * ∑ k, f z (Function.update x i x' k)| + |∫ (x : Ω), f z (X x) ∂μ| ≤ b + b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_64.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        ∀ (z : ι),\n          @LE.le.{0} Real Real.instLE\n              (@abs.{0} Real Real.lattice Real.instAddGroup\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) =>\n                    f z (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\n              b →\n            @LE.le.{0} Real Real.instLE\n              (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd)\n                (@abs.{0} Real Real.lattice Real.instAddGroup\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) =>\n                      f z\n                        (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i x' k))))\n                (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f z (X x))))\n              (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 212,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\n⊢ (⨆ i_1, |h i_1|) - ⨆ i, |g i| ≤ (↑n)⁻¹ * 2 * b",
        "tactic": "rw [p0]",
        "tactic_state_after": "[Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\n ⊢ ⨆ i_1, |h i_1| - ⨆ i, |g i| ≤ (↑n)⁻¹ * 2 * b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nh_original_goal : (⨆ i_1, |h i_1|) - ⨆ i, |g i| ≤ (↑n)⁻¹ * 2 * b\n⊢ ⨆ i_1, |h i_1| - ⨆ i, |g i| ≤ (↑n)⁻¹ * 2 * b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_65.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| →\n          (⨆ i_1, |h i_1|) - ⨆ i, |g i| ≤ (↑n)⁻¹ * 2 * b → ⨆ i_1, |h i_1| - ⨆ i, |g i| ≤ (↑n)⁻¹ * 2 * b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_65.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          @LE.le.{0} Real Real.instLE\n              (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\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            @LE.le.{0} Real Real.instLE\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                  (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                  (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                    @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\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) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 218,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\nthis : (abs ∘ g) j ≤ ⨆ i_1, (abs ∘ g) i_1\n⊢ |g j| ≤ ⨆ i_1, |g i_1|",
        "tactic": "exact this",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\nthis : (abs ∘ g) j ≤ ⨆ i_1, (abs ∘ g) i_1\n⊢ |g j| ≤ ⨆ i_1, |g i_1|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_66.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| →\n          ∀ (j : ι), (abs ∘ g) j ≤ ⨆ i_1, (abs ∘ g) i_1 → |g j| ≤ ⨆ i_1, |g i_1| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_66.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          ∀ (j : ι),\n            @LE.le.{0} Real Real.instLE\n                (@Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) g j)\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                  @Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) g i_1) →\n              @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (g j))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i_1)) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 219,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\n⊢ (abs ∘ g) j ≤ ⨆ i_1, (abs ∘ g) i_1",
        "tactic": "apply le_ciSup",
        "tactic_state_after": "[case H\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\n j : ι\n ⊢ BddAbove (Set.range (abs ∘ g))]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\nh_original_goal : (abs ∘ g) j ≤ ⨆ i_1, (abs ∘ g) i_1\n⊢ BddAbove (Set.range (abs ∘ g))",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_67.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| →\n          ∀ (j : ι), (abs ∘ g) j ≤ ⨆ i_1, (abs ∘ g) i_1 → BddAbove (Set.range (abs ∘ g)) := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_67.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          ∀ (j : ι),\n            @LE.le.{0} Real Real.instLE\n                (@Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) g j)\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                  @Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) g i_1) →\n              @BddAbove.{0} Real\n                (@Preorder.toLE.{0} Real\n                  (@PartialOrder.toPreorder.{0} Real\n                    (@SemilatticeInf.toPartialOrder.{0} Real\n                      (@Lattice.toSemilatticeInf.{0} Real\n                        (@ConditionallyCompleteLattice.toLattice.{0} Real\n                          (@ConditionallyCompleteLinearOrder.toConditionallyCompleteLattice.{0} Real\n                            Real.instConditionallyCompleteLinearOrder))))))\n                (@Set.range.{0, v + 1} Real ι\n                  (@Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) g)) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem le_ciSup {f : ι → α} (H : BddAbove (range f)) (c : ι) : f c ≤ iSup f"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 220,
        "tactic_state_before": "case H\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\n⊢ BddAbove (Set.range (abs ∘ g))",
        "tactic": "rw [bddAbove_def]",
        "tactic_state_after": "[case H\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\n j : ι\n ⊢ ∃ x, ∀ y ∈ Set.range (abs ∘ g), y ≤ x]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\nh_original_goal : BddAbove (Set.range (abs ∘ g))\n⊢ ∃ x, ∀ y ∈ Set.range (abs ∘ g), y ≤ x",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_68.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| →\n          BddAbove (Set.range (abs ∘ g)) → ∃ x, ∀ y ∈ Set.range (abs ∘ g), y ≤ x := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_68.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          @BddAbove.{0} Real\n              (@Preorder.toLE.{0} Real\n                (@PartialOrder.toPreorder.{0} Real\n                  (@SemilatticeInf.toPartialOrder.{0} Real\n                    (@Lattice.toSemilatticeInf.{0} Real\n                      (@ConditionallyCompleteLattice.toLattice.{0} Real\n                        (@ConditionallyCompleteLinearOrder.toConditionallyCompleteLattice.{0} Real\n                          Real.instConditionallyCompleteLinearOrder))))))\n              (@Set.range.{0, v + 1} Real ι\n                (@Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) g)) →\n            @Exists.{1} Real fun (x : Real) =>\n              ∀ (y : Real),\n                @Membership.mem.{0, 0} Real (Set.{0} Real) (@Set.instMembership.{0} Real)\n                    (@Set.range.{0, v + 1} Real ι\n                      (@Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) g))\n                    y →\n                  @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder) y x := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem bddAbove_def : BddAbove s ↔ ∃ x, ∀ y ∈ s, y ≤ x"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 223,
        "tactic_state_before": "case h\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\n⊢ y ∈ Set.range (abs ∘ g) → y ≤ b + b",
        "tactic": "simp only [Set.mem_range, Function.comp_apply, forall_exists_index, h, g]",
        "tactic_state_after": "[case h\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\n j : ι\n y : ℝ\n ⊢ ∀ (x_1 : ι), |(↑n)⁻¹ * ∑ k, f x_1 (x k) - ∫ (x : Ω), f x_1 (X x) ∂μ| = y → y ≤ b + b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nh_original_goal : y ∈ Set.range (abs ∘ g) → y ≤ b + b\n⊢ ∀ (x_1 : ι), |(↑n)⁻¹ * ∑ k, f x_1 (x k) - ∫ (x : Ω), f x_1 (X x) ∂μ| = y → y ≤ b + b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_69.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| →\n          ∀ (y : ℝ),\n            (y ∈ Set.range (abs ∘ g) → y ≤ b + b) →\n              ∀ (x_1 : ι), |(↑n)⁻¹ * ∑ k, f x_1 (x k) - ∫ (x : Ω), f x_1 (X x) ∂μ| = y → y ≤ b + b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_69.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          ∀ (y : Real),\n            (@Membership.mem.{0, 0} Real (Set.{0} Real) (@Set.instMembership.{0} Real)\n                  (@Set.range.{0, v + 1} Real ι\n                    (@Function.comp.{v + 1, 1, 1} ι Real Real (@abs.{0} Real Real.lattice Real.instAddGroup) g))\n                  y →\n                @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder) y\n                  (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b)) →\n              ∀ (x_1 : ι),\n                @Eq.{1} Real\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\n                            (@Finset.univ.{0} (Fin n) (Fin.fintype n)) fun (k : Fin n) => f x_1 (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 : Ω) => f x_1 (X x))))\n                    y →\n                  @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder) y\n                    (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 225,
        "tactic_state_before": "case h\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n⊢ y ≤ b + b",
        "tactic": "rw [<- hx]",
        "tactic_state_after": "[case h\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\n j : ι\n y : ℝ\n z : ι\n hx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n ⊢ |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| ≤ b + b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\nh_original_goal : y ≤ b + b\n⊢ |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| ≤ b + b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_70.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| →\n          ∀ (y : ℝ) (z : ι),\n            |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y →\n              y ≤ b + b → |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| ≤ b + b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_70.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          ∀ (y : Real) (z : ι),\n            @Eq.{1} Real\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 z (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 : Ω) => f z (X x))))\n                y →\n              @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder) y\n                  (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b) →\n                @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\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\n                          (@Finset.univ.{0} (Fin n) (Fin.fintype n)) fun (k : Fin n) => f z (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 : Ω) => f z (X x))))\n                  (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 229,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n⊢ |(↑n)⁻¹ * ∑ k, f z (x k)| = (↑n)⁻¹ * |∑ k, f z (x k)|",
        "tactic": "rw [abs_mul]",
        "tactic_state_after": "[Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\n j : ι\n y : ℝ\n z : ι\n hx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n ⊢ |(↑n)⁻¹| * |∑ k, f z (x k)| = (↑n)⁻¹ * |∑ k, f z (x k)|]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\nh_original_goal : |(↑n)⁻¹ * ∑ k, f z (x k)| = (↑n)⁻¹ * |∑ k, f z (x k)|\n⊢ |(↑n)⁻¹| * |∑ k, f z (x k)| = (↑n)⁻¹ * |∑ k, f z (x k)|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_71.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| →\n          ∀ (y : ℝ) (z : ι),\n            |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y →\n              |(↑n)⁻¹ * ∑ k, f z (x k)| = (↑n)⁻¹ * |∑ k, f z (x k)| →\n                |(↑n)⁻¹| * |∑ k, f z (x k)| = (↑n)⁻¹ * |∑ k, f z (x k)| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_71.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          ∀ (y : Real) (z : ι),\n            @Eq.{1} Real\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 z (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 : Ω) => f z (X x))))\n                y →\n              @Eq.{1} Real\n                  (@abs.{0} Real Real.lattice Real.instAddGroup\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 z (x k))))\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                    (@abs.{0} Real Real.lattice Real.instAddGroup\n                      (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                        fun (k : Fin n) => f z (x k)))) →\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                          (@NonUnitalNonAssocRing.toNonUnitalNonAssocSemiring.{0} Real\n                            (@NonAssocRing.toNonUnitalNonAssocRing.{0} Real\n                              (@Ring.toNonAssocRing.{0} Real\n                                (@StrictOrderedRing.toRing.{0} Real\n                                  (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))))))\n                    (@abs.{0} Real\n                      (@DistribLattice.toLattice.{0} Real\n                        (@instDistribLatticeOfLinearOrder.{0} Real\n                          (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n                      (@AddGroupWithOne.toAddGroup.{0} Real\n                        (@Ring.toAddGroupWithOne.{0} Real\n                          (@StrictOrderedRing.toRing.{0} Real\n                            (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n                      (@Inv.inv.{0} Real Real.instInv (@Nat.cast.{0} Real Real.instNatCast n)))\n                    (@abs.{0} Real\n                      (@DistribLattice.toLattice.{0} Real\n                        (@instDistribLatticeOfLinearOrder.{0} Real\n                          (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n                      (@AddGroupWithOne.toAddGroup.{0} Real\n                        (@Ring.toAddGroupWithOne.{0} Real\n                          (@StrictOrderedRing.toRing.{0} Real\n                            (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n                      (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                        fun (k : Fin n) => f z (x k))))\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                    (@abs.{0} Real Real.lattice Real.instAddGroup\n                      (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                        fun (k : Fin n) => f z (x k)))) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "lemma abs_mul (a b : α) : |a * b| = |a| * |b|"
            },
            {
                "library": "Mathlib",
                "definition": "theorem abs_mul (x y : EReal) : (x * y).abs = x.abs * y.abs"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 230,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n⊢ |(↑n)⁻¹| * |∑ k, f z (x k)| = (↑n)⁻¹ * |∑ k, f z (x k)|",
        "tactic": "simp",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n⊢ |(↑n)⁻¹| * |∑ k, f z (x k)| = (↑n)⁻¹ * |∑ k, f z (x k)|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_72.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| →\n          ∀ (y : ℝ) (z : ι),\n            |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y →\n              |(↑n)⁻¹| * |∑ k, f z (x k)| = (↑n)⁻¹ * |∑ k, f z (x k)| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_72.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          ∀ (y : Real) (z : ι),\n            @Eq.{1} Real\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 z (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 : Ω) => f z (X x))))\n                y →\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                        (@NonUnitalNonAssocRing.toNonUnitalNonAssocSemiring.{0} Real\n                          (@NonAssocRing.toNonUnitalNonAssocRing.{0} Real\n                            (@Ring.toNonAssocRing.{0} Real\n                              (@StrictOrderedRing.toRing.{0} Real\n                                (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))))))\n                  (@abs.{0} Real\n                    (@DistribLattice.toLattice.{0} Real\n                      (@instDistribLatticeOfLinearOrder.{0} Real\n                        (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n                    (@AddGroupWithOne.toAddGroup.{0} Real\n                      (@Ring.toAddGroupWithOne.{0} Real\n                        (@StrictOrderedRing.toRing.{0} Real\n                          (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n                    (@Inv.inv.{0} Real Real.instInv (@Nat.cast.{0} Real Real.instNatCast n)))\n                  (@abs.{0} Real\n                    (@DistribLattice.toLattice.{0} Real\n                      (@instDistribLatticeOfLinearOrder.{0} Real\n                        (@LinearOrderedRing.toLinearOrder.{0} Real Real.instLinearOrderedRing)))\n                    (@AddGroupWithOne.toAddGroup.{0} Real\n                      (@Ring.toAddGroupWithOne.{0} Real\n                        (@StrictOrderedRing.toRing.{0} Real\n                          (@LinearOrderedRing.toStrictOrderedRing.{0} Real Real.instLinearOrderedRing))))\n                    (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                      fun (k : Fin n) => f z (x k))))\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                  (@abs.{0} Real Real.lattice Real.instAddGroup\n                    (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                      fun (k : Fin n) => f z (x k)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 239,
        "tactic_state_before": "case refine_4\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni✝ : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i✝ x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\ni : Fin n\n⊢ 0 i ≤ |f z (x i)|",
        "tactic": "simp",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni✝ : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i✝ x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\ni : Fin n\n⊢ 0 i ≤ |f z (x i)|",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_73.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i_1 : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1_1 => (↑n)⁻¹ * ∑ k, f i_1_1 (Function.update x i_1 x' k) - ∫ (x : Ω), f i_1_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| →\n          ∀ (y : ℝ) (z : ι),\n            |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y → ∀ (i : Fin n), 0 i ≤ |f z (x i)| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_73.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i_1 : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1_1 : ι) =>\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) =>\n          f i_1_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i_1 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 : Ω) => f i_1_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          ∀ (y : Real) (z : ι),\n            @Eq.{1} Real\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 z (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 : Ω) => f z (X x))))\n                y →\n              ∀ (i : Fin n),\n                @LE.le.{0} Real\n                  (@Preorder.toLE.{0} Real\n                    (@PartialOrder.toPreorder.{0} Real\n                      (@OrderedAddCommMonoid.toPartialOrder.{0} Real Real.orderedAddCommMonoid)))\n                  (@OfNat.ofNat.{0} (Fin n → Real) 0\n                    (@Zero.toOfNat0.{0} (Fin n → Real)\n                      (@Pi.instZero.{0, 0} (Fin n) (fun (a : Fin n) => Real) fun (i : Fin n) =>\n                        @AddZeroClass.toZero.{0} Real\n                          (@AddMonoid.toAddZeroClass.{0} Real\n                            (@AddCommMonoid.toAddMonoid.{0} Real\n                              (@OrderedAddCommMonoid.toAddCommMonoid.{0} Real Real.orderedAddCommMonoid)))))\n                    i)\n                  (@abs.{0} Real Real.lattice Real.instAddGroup (f z (x i))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 245,
        "tactic_state_before": "case refine_4\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n⊢ 0 ≤ ∑ k, b",
        "tactic": "simp only [Finset.sum_const, Finset.card_univ, Fintype.card_fin, nsmul_eq_mul, h, g]",
        "tactic_state_after": "[case refine_4\n Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\n j : ι\n y : ℝ\n z : ι\n hx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n ⊢ 0 ≤ ↑n * b]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\nh_original_goal : 0 ≤ ∑ k, b\n⊢ 0 ≤ ↑n * b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_74.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| →\n          ∀ (y : ℝ) (z : ι), |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y → 0 ≤ ∑ k, b → 0 ≤ ↑n * b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_74.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          ∀ (y : Real) (z : ι),\n            @Eq.{1} Real\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 z (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 : Ω) => f z (X x))))\n                y →\n              @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n                  (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))\n                  (@Finset.sum.{0, 0} (Fin n) Real Real.instAddCommMonoid (@Finset.univ.{0} (Fin n) (Fin.fintype n))\n                    fun (k : Fin n) => b) →\n                @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n                  (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))\n                  (@HMul.hMul.{0, 0, 0} Real Real Real\n                    (@instHMul.{0} Real\n                      (@Distrib.toMul.{0} Real\n                        (@NonUnitalNonAssocSemiring.toDistrib.{0} Real\n                          (@NonAssocSemiring.toNonUnitalNonAssocSemiring.{0} Real\n                            (@Semiring.toNonAssocSemiring.{0} Real Real.semiring)))))\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 Real.semiring))))\n                      n)\n                    b) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 247,
        "tactic_state_before": "case refine_4\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n⊢ 0 ≤ b",
        "tactic": "exact hb",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\n⊢ 0 ≤ b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_75.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| →\n          ∀ (y : ℝ) (z : ι), |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y → 0 ≤ b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_75.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          ∀ (y : Real) (z : ι),\n            @Eq.{1} Real\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 z (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 : Ω) => f z (X x))))\n                y →\n              @LE.le.{0} Real\n                (@Preorder.toLE.{0} Real\n                  (@PartialOrder.toPreorder.{0} Real\n                    (@SemilatticeInf.toPartialOrder.{0} Real\n                      (@Lattice.toSemilatticeInf.{0} Real\n                        (@DistribLattice.toLattice.{0} Real\n                          (@instDistribLatticeOfLinearOrder.{0} Real Real.linearOrder))))))\n                (@OfNat.ofNat.{0} Real 0\n                  (@Zero.toOfNat0.{0} Real\n                    (@MulZeroClass.toZero.{0} Real\n                      (@NonUnitalNonAssocSemiring.toMulZeroClass.{0} Real\n                        (@NonAssocSemiring.toNonUnitalNonAssocSemiring.{0} Real\n                          (@Semiring.toNonAssocSemiring.{0} Real Real.semiring))))))\n                b := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 250,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\ns : |(↑n)⁻¹ * ∑ k, f z (x k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| ≤ |(↑n)⁻¹ * ∑ k, f z (x k)| + |∫ (x : Ω), f z (X x) ∂μ|",
        "tactic": "exact abs_sub ((↑n)⁻¹ * ∑ k : Fin n, f z (x k)) (∫ (x : Ω), f z (X x) ∂μ)",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\ns : |(↑n)⁻¹ * ∑ k, f z (x k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| ≤ |(↑n)⁻¹ * ∑ k, f z (x k)| + |∫ (x : Ω), f z (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_76.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| →\n          ∀ (y : ℝ) (z : ι),\n            |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y →\n              |(↑n)⁻¹ * ∑ k, f z (x k)| ≤ b →\n                |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| ≤\n                  |(↑n)⁻¹ * ∑ k, f z (x k)| + |∫ (x : Ω), f z (X x) ∂μ| := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_76.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          ∀ (y : Real) (z : ι),\n            @Eq.{1} Real\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 z (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 : Ω) => f z (X x))))\n                y →\n              @LE.le.{0} Real Real.instLE\n                  (@abs.{0} Real Real.lattice Real.instAddGroup\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 z (x k))))\n                  b →\n                @LE.le.{0} Real Real.instLE\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\n                          (@Finset.univ.{0} (Fin n) (Fin.fintype n)) fun (k : Fin n) => f z (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 : Ω) => f z (X x))))\n                  (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd)\n                    (@abs.{0} Real Real.lattice Real.instAddGroup\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\n                          (@Finset.univ.{0} (Fin n) (Fin.fintype n)) fun (k : Fin n) => f z (x k))))\n                    (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f z (X x)))) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 251,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\ns : |(↑n)⁻¹ * ∑ k, f z (x k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f z (x k)| + |∫ (x : Ω), f z (X x) ∂μ| ≤ b + b",
        "tactic": "apply add_le_add s (s' z)",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nj : ι\ny : ℝ\nz : ι\nhx : |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y\ns : |(↑n)⁻¹ * ∑ k, f z (x k)| ≤ b\n⊢ |(↑n)⁻¹ * ∑ k, f z (x k)| + |∫ (x : Ω), f z (X x) ∂μ| ≤ b + b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_77.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| →\n          ∀ (y : ℝ) (z : ι),\n            |(↑n)⁻¹ * ∑ k, f z (x k) - ∫ (x : Ω), f z (X x) ∂μ| = y →\n              |(↑n)⁻¹ * ∑ k, f z (x k)| ≤ b → |(↑n)⁻¹ * ∑ k, f z (x k)| + |∫ (x : Ω), f z (X x) ∂μ| ≤ b + b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_77.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          ∀ (y : Real) (z : ι),\n            @Eq.{1} Real\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 z (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 : Ω) => f z (X x))))\n                y →\n              @LE.le.{0} Real Real.instLE\n                  (@abs.{0} Real Real.lattice Real.instAddGroup\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 z (x k))))\n                  b →\n                @LE.le.{0} Real Real.instLE\n                  (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd)\n                    (@abs.{0} Real Real.lattice Real.instAddGroup\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\n                          (@Finset.univ.{0} (Fin n) (Fin.fintype n)) fun (k : Fin n) => f z (x k))))\n                    (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f z (X x))))\n                  (@HAdd.hAdd.{0, 0, 0} Real Real Real (@instHAdd.{0} Real Real.instAdd) b b) := sorry",
        "retrieval": []
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 258,
        "tactic_state_before": "case refine_2\nΩ : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\n⊢ 0 ≤ (↑n)⁻¹ * 2 * b",
        "tactic": "apply Left.mul_nonneg _ hb",
        "tactic_state_after": "[Ω : Type u\n inst✝² : MeasurableSpace Ω\n Z : Type w\n n : ℕ\n ι : Type v\n f : ι → Z → ℝ\n μ : Measure Ω\n inst✝¹ : Nonempty ι\n inst✝ : IsProbabilityMeasure μ\n hn : 0 < n\n X : Ω → Z\n hf : ∀ (i : ι), Measurable (f i ∘ X)\n b : ℝ\n hb : 0 ≤ b\n hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\n i : Fin n\n x : Fin n → Z\n x' : Z\n g : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\n h : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\n s' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\n p''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\n p : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\n p0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\n ⊢ 0 ≤ (↑n)⁻¹ * 2]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\nh_original_goal : 0 ≤ (↑n)⁻¹ * 2 * b\n⊢ 0 ≤ (↑n)⁻¹ * 2",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_78.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| → 0 ≤ (↑n)⁻¹ * 2 * b → 0 ≤ (↑n)⁻¹ * 2 := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_78.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          @LE.le.{0} Real Real.instLE (@OfNat.ofNat.{0} Real 0 (@Zero.toOfNat0.{0} Real Real.instZero))\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            @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n              (@OfNat.ofNat.{0} Real 0\n                (@Zero.toOfNat0.{0} Real\n                  (@MulZeroClass.toZero.{0} Real\n                    (@NonUnitalNonAssocSemiring.toMulZeroClass.{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 Real.normedCommRing)))))))))\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)))))) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem Left.mul_nonneg [PosMulMono α] (ha : 0 ≤ a) (hb : 0 ≤ b) : 0 ≤ a * b"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 259,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\n⊢ 0 ≤ (↑n)⁻¹ * 2",
        "tactic": "apply Left.mul_nonneg (inv_nonneg_of_nonneg (Nat.cast_nonneg n)) (by linarith)",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np0 : (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i|\n⊢ 0 ≤ (↑n)⁻¹ * 2",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_79.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| = ⨆ i_1, |h i_1| - ⨆ i, |g i| → 0 ≤ (↑n)⁻¹ * 2 := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_79.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @Eq.{1} Real\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))) →\n          @LE.le.{0} Real (@Preorder.toLE.{0} Real Real.instPreorder)\n            (@OfNat.ofNat.{0} Real 0\n              (@Zero.toOfNat0.{0} Real\n                (@MulZeroClass.toZero.{0} Real\n                  (@NonUnitalNonAssocSemiring.toMulZeroClass.{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 Real.normedCommRing)))))))))\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)))))) := sorry",
        "retrieval": [
            {
                "library": "Mathlib",
                "definition": "theorem Left.mul_nonneg [PosMulMono α] (ha : 0 ≤ a) (hb : 0 ≤ b) : 0 ≤ a * b"
            }
        ]
    },
    {
        "filename": "FoML/FoML/BoundedDifference.lean",
        "line": 260,
        "tactic_state_before": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np' : (⨆ i_1, |h i_1|) - ⨆ i, |g i| ≤ (↑n)⁻¹ * 2 * b\n⊢ |(⨆ i, |g i|) - ⨆ i_1, |h i_1|| ≤ (↑n)⁻¹ * 2 * b",
        "tactic": "apply abs_sub_le_iff.mpr ⟨p, p'⟩",
        "tactic_state_after": "[]",
        "goal": "Ω : Type u\ninst✝² : MeasurableSpace Ω\nZ : Type w\nn : ℕ\nι : Type v\nf : ι → Z → ℝ\nμ : Measure Ω\ninst✝¹ : Nonempty ι\ninst✝ : IsProbabilityMeasure μ\nhn : 0 < n\nX : Ω → Z\nhf : ∀ (i : ι), Measurable (f i ∘ X)\nb : ℝ\nhb : 0 ≤ b\nhf' : ∀ (i : ι) (z : Z), |f i z| ≤ b\ni : Fin n\nx : Fin n → Z\nx' : Z\ng : ι → ℝ := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ\nh : ι → ℝ := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ\ns' : ∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b\np''' : ∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b\np : (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b\np' : (⨆ i_1, |h i_1|) - ⨆ i, |g i| ≤ (↑n)⁻¹ * 2 * b\n⊢ |(⨆ i, |g i|) - ⨆ i_1, |h i_1|| ≤ (↑n)⁻¹ * 2 * b",
        "theorem_header": "import Mathlib\nimport FoML\n\n\nopen MeasureTheory ProbabilityTheory Real\n\nopen scoped ENNReal\n",
        "formal_statement": "theorem extracted_formal_statement_80.{w, v, u} {Ω : Type u} [inst : MeasurableSpace Ω] {Z : Type w} {n : ℕ} {ι : Type v}\n  {f : ι → Z → ℝ} {μ : Measure Ω} [inst_1 : Nonempty ι] [inst_2 : IsProbabilityMeasure μ] (hn : 0 < n) (X : Ω → Z)\n  (hf : ∀ (i : ι), Measurable (f i ∘ X)) {b : ℝ} (hb : 0 ≤ b) (hf' : ∀ (i : ι) (z : Z), |f i z| ≤ b) (i : Fin n)\n  (x : Fin n → Z) (x' : Z) :\n  let g := fun i => (↑n)⁻¹ * ∑ k, f i (x k) - ∫ (x : Ω), f i (X x) ∂μ;\n  let h := fun i_1 => (↑n)⁻¹ * ∑ k, f i_1 (Function.update x i x' k) - ∫ (x : Ω), f i_1 (X x) ∂μ;\n  (∀ (a : ι), |∫ (x : Ω), f a (X x) ∂μ| ≤ b) →\n    (∀ (j : ι), |g j - h j| ≤ (↑n)⁻¹ * 2 * b) →\n      (⨆ i, |g i|) - ⨆ i_1, |h i_1| ≤ (↑n)⁻¹ * 2 * b →\n        (⨆ i_1, |h i_1|) - ⨆ i, |g i| ≤ (↑n)⁻¹ * 2 * b → |(⨆ i, |g i|) - ⨆ i_1, |h i_1|| ≤ (↑n)⁻¹ * 2 * b := sorry",
        "full_formal_statement": "theorem extracted_full_formal_statement_80.{w, v, u} {Ω : Type u} [inst : MeasurableSpace.{u} Ω] {Z : Type w} {n : Nat}\n  {ι : Type v} {f : ι → Z → Real} {μ : @MeasureTheory.Measure.{u} Ω inst} [inst_1 : Nonempty.{v + 1} ι]\n  [inst_2 : @MeasureTheory.IsProbabilityMeasure.{u} Ω inst μ]\n  (hn : @LT.lt.{0} Nat instLTNat (@OfNat.ofNat.{0} Nat 0 (instOfNatNat 0)) n) (X : Ω → Z)\n  (hf :\n    ∀ (i : ι), @Measurable.{u, 0} Ω Real inst Real.measurableSpace (@Function.comp.{u + 1, w + 1, 1} Ω Z 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 : ι) (z : Z), @LE.le.{0} Real Real.instLE (@abs.{0} Real Real.lattice Real.instAddGroup (f i z)) b)\n  (i : Fin n) (x : Fin n → Z) (x' : Z) :\n  let g : ι → Real := fun (i : ι) =>\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 (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 : Ω) => f i (X x));\n  let h : ι → Real := fun (i_1 : ι) =>\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) =>\n          f i_1 (@Function.update.{1, w + 1} (Fin n) (fun (a : Fin n) => Z) (instDecidableEqFin n) x i 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 : Ω) => f i_1 (X x));\n  (∀ (a : ι),\n      @LE.le.{0} Real Real.instLE\n        (@abs.{0} Real Real.lattice Real.instAddGroup\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 : Ω) => f a (X x)))\n        b) →\n    (∀ (j : ι),\n        @LE.le.{0} Real Real.instLE\n          (@abs.{0} Real Real.lattice Real.instAddGroup\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub) (g j) (h j)))\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      @LE.le.{0} Real Real.instLE\n          (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) => @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n            (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n              @abs.{0} Real Real.lattice Real.instAddGroup (h i_1)))\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        @LE.le.{0} Real Real.instLE\n            (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))\n              (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                @abs.{0} Real Real.lattice Real.instAddGroup (g i)))\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          @LE.le.{0} Real Real.instLE\n            (@abs.{0} Real Real.lattice Real.instAddGroup\n              (@HSub.hSub.{0, 0, 0} Real Real Real (@instHSub.{0} Real Real.instSub)\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (g i))\n                (@iSup.{0, v + 1} Real ι Real.instSupSet fun (i_1 : ι) =>\n                  @abs.{0} Real Real.lattice Real.instAddGroup (h i_1))))\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) := sorry",
        "retrieval": []
    }
]