# `OS4_Clustering.lean` — Informal Summary

> **Source**: [`OSforGFF/OS/OS4_Clustering.lean`](../../OSforGFF/OS/OS4_Clustering.lean)
> **Generated**: 2026-03-03 00:00
> **Note**: Auto-generated by `/lean-summarize`. Re-run to refresh.

## Overview

Proves OS4 (Osterwalder–Schrader axiom 4) clustering for the Gaussian free field
in two forms: qualitative (the generating functional difference tends to zero as the
spatial separation grows) and polynomial (the difference decays like $(1+s)^{-\alpha}$
for any $\alpha > 0$, reflecting the mass gap).  The proof chain is: (1) time-translation
duality $\langle T_s \omega, g \rangle = \langle \omega, T_{-s} g \rangle$; (2) Gaussian
factorization $\mathbb{E}[e^{\langle\omega, f+T_{-s}g\rangle}]
= \mathbb{E}[e^{\langle\omega,f\rangle}]\cdot\mathbb{E}[e^{\langle\omega,g\rangle}]
\cdot e^{S_2(f, T_{-s}g)}$; (3) quantitative decay of
$S_2(f, T_{-s}g)$ via the exponentially decaying free covariance kernel.

## Status

**Main result**: Fully proven (0 sorries)

None — file is sorry-free.

**Length**: 771 lines, 2 definitions + 14 theorems/lemmas

---

## Gaussian Generating Functional Factorization

### [`schwinger2_sum_expansion`](../../OSforGFF/OS/OS4_Clustering.lean#L58) — Lemma

**Statement**: The GFF two-point Schwinger function satisfies the bilinearity identity
$$S_2(f+g, f+g) = S_2(f,f) + 2 S_2(f,g) + S_2(g,g).$$

**Proof uses**: [`covariance_bilinear_from_general`](../../OSforGFF/Schwinger/GaussianMoments.lean#L241),
[`gff_two_point_equals_covarianceℂ_free`](../../OSforGFF/Measure/IsGaussian.lean#L463),
[`freeCovarianceℂ_bilinear_symm`](../../OSforGFF/Covariance/Position.lean#L528)

---

### [`gff_generating_sum_factorization`](../../OSforGFF/OS/OS4_Clustering.lean#L91) — Lemma

**Statement**: The GFF complex generating functional factorizes on a sum:
$$Z[f + g] = Z[f] \cdot Z[g] \cdot e^{-S_2(f,g)}.$$

**Proof uses**: [`gff_complex_generating`](../../OSforGFF/Measure/IsGaussian.lean#L523),
[`schwinger2_sum_expansion`](../../OSforGFF/OS/OS4_Clustering.lean#L58)

---

## Translation as Euclidean Action

### [`LinearIsometry_inv_one`](../../OSforGFF/OS/OS4_Clustering.lean#L116) — Lemma

**Statement**: The inverse of the identity linear isometry $1 \in O(4)$ is itself.

**Proof uses**: `LinearIsometry.comp_inv`

---

### [`generating_euclidean_invariant`](../../OSforGFF/OS/OS4_Clustering.lean#L126) — Lemma

**Statement**: For a Euclidean-invariant measure, $Z[g \cdot f] = Z[f]$ for any
Euclidean group element $g \in E$.

**Proof uses**: *(direct tactic proof)*

---

## GFF Generating Functional Norm Bound

### [`gff_generating_norm_le_one_real`](../../OSforGFF/OS/OS4_Clustering.lean#L148) — Lemma

**Statement**: For real test functions $f$, the GFF generating functional satisfies
$\lVert Z[\hat f] \rVert \leq 1$, because the covariance is positive definite on
real functions.

**Proof uses**: [`gff_complex_generating`](../../OSforGFF/Measure/IsGaussian.lean#L523),
[`gff_two_point_equals_covarianceℂ_free`](../../OSforGFF/Measure/IsGaussian.lean#L463),
[`freeCovarianceℂ_positive`](../../OSforGFF/Covariance/Position.lean#L495)

---

## Technical Lemma for OS4 (Real Test Functions)

### [`GFF_OS4_from_small_decay_real`](../../OSforGFF/OS/OS4_Clustering.lean#L184) — Lemma

**Statement**: If $\lvert S_2(f, T_a g) \rvert < \delta \leq 1$ for real test functions
$f, g$, then
$$\lVert Z[f + T_a g] - Z[f] \cdot Z[g] \rVert < 2\delta.$$

**Proof uses**: [`gff_generating_sum_factorization`](../../OSforGFF/OS/OS4_Clustering.lean#L91),
[`gff_generating_norm_le_one_real`](../../OSforGFF/OS/OS4_Clustering.lean#L148),
[`generating_euclidean_invariant`](../../OSforGFF/OS/OS4_Clustering.lean#L126),
[`CovarianceEuclideanInvariantℂ_μ_GFF`](../../OSforGFF/OS/OS2_Invariance.lean#L146),
[`isGaussianGJ_gaussianFreeField_free`](../../OSforGFF/Measure/IsGaussian.lean#L539),
[`gaussian_satisfies_OS2`](../../OSforGFF/Measure/GaussianFreeField.lean#L212),
[`GFFIsGaussian.schwinger_eq_covariance_real`](../../OSforGFF/Measure/IsGaussian.lean#L372),
[`schwinger_eq_covariance`](../../OSforGFF/Schwinger/Defs.lean#L82),
[`gaussianFreeField_pairing_memLp`](../../OSforGFF/Measure/Construct.lean#L247),
[`integral_ofReal_eq`](../../OSforGFF/Covariance/Momentum.lean#L63),
[`distributionPairingℂ_real_toComplex`](../../OSforGFF/Spacetime/ComplexTestFunction.lean#L284),
`Complex.norm_exp_sub_one_le`

---

## Main Theorem: OS4 for Gaussian Free Field

### [`schwartz_cross_covariance_decay_real`](../../OSforGFF/OS/OS4_Clustering.lean#L323) — Theorem

**Statement**: For real Schwartz test functions $f, g$ and any $\varepsilon > 0$,
there exists $R > 0$ such that for all $a \in \mathbb{R}^4$ with $\lVert a \rVert > R$:
$$\lVert S_2(f, T_a g) \rVert < \varepsilon.$$

**Proof uses**: [`freeCovarianceKernel_decay_bound`](../../OSforGFF/Covariance/Momentum.lean#L1723),
[`freeCovarianceKernel_continuousOn`](../../OSforGFF/Covariance/Momentum.lean#L1963),
[`freeCovarianceKernel_integrable`](../../OSforGFF/Covariance/Momentum.lean#L1690),
[`schwartz_bilinear_translation_decay_proof`](../../OSforGFF/General/SchwartzTranslationDecay.lean#L558)

---

### [`gaussianFreeField_satisfies_OS4`](../../OSforGFF/OS/OS4_Clustering.lean#L462) — Theorem

**Statement**: The Gaussian free field measure $\mu_{\text{GFF}}(m)$ satisfies the OS4
clustering axiom:
$$\mathrm{OS4\_Clustering}(\mu_{\text{GFF}}(m)).$$

**Proof uses**: [`schwartz_cross_covariance_decay_real`](../../OSforGFF/OS/OS4_Clustering.lean#L323),
[`GFF_OS4_from_small_decay_real`](../../OSforGFF/OS/OS4_Clustering.lean#L184)

---

## Alternative: Direct (ε-δ) Formulation

### `CovarianceClustering_real` — Definition

**Lean signature**
```lean
def CovarianceClustering_real (dμ_config : ProbabilityMeasure FieldConfiguration) : Prop
```
**Informal**: The proposition that the two-point Schwinger function $S_2(f, T_a g)$
tends to zero as $\lVert a \rVert \to \infty$, for all real Schwartz test functions $f, g$.

---

### [`freeCovarianceClustering_real`](../../OSforGFF/OS/OS4_Clustering.lean#L511) — Theorem

**Statement**: The Gaussian free field covariance has the real clustering property:
`CovarianceClustering_real (gaussianFreeField_free m)`.

**Proof uses**: [`schwartz_cross_covariance_decay_real`](../../OSforGFF/OS/OS4_Clustering.lean#L323)

---

## OS4 Polynomial Clustering for GFF

### `timeVector` — Definition

**Lean signature**
```lean
def timeVector (s : ℝ) : SpaceTime
```
**Informal**: The pure time-direction vector $(s, 0, 0, 0) \in \mathbb{R}^4$.

---

### [`time_translation_pairing_duality`](../../OSforGFF/OS/OS4_Clustering.lean#L551) — Lemma

**Statement**: Time translation on distributions is dual to time translation on test
functions:
$$\langle T_s \omega, g \rangle_{\mathbb{C}} = \langle \omega, T_{-s} g \rangle_{\mathbb{C}}.$$

**Proof uses**: [`OS4infra.timeTranslationDistribution_pairingℂ`](../../OSforGFF/OS/OS4_MGF.lean#L94)

---

### [`timeShiftConst_norm`](../../OSforGFF/OS/OS4_Clustering.lean#L560) — Lemma

**Statement**: The norm of the time shift constant vector satisfies
$\lVert (s,0,0,0) \rVert = \lvert s \rvert$.

**Proof uses**: *(direct tactic proof)*

---

### [`timeTranslationSchwartzℂ_at_point`](../../OSforGFF/OS/OS4_Clustering.lean#L567) — Lemma

**Statement**: Time translation of a Schwartz function evaluates as
$(T_s g)(y) = g(\mathrm{timeShift}(s, y))$.

**Proof uses**: *(direct tactic proof)*

---

### [`timeShift_eq_add`](../../OSforGFF/OS/OS4_Clustering.lean#L572) — Lemma

**Statement**: Time shift satisfies $\mathrm{timeShift}(s, y) = y + (s,0,0,0)$.

**Proof uses**: `TimeTranslation.timeShift_eq_add_const`

---

### [`timeTranslationSchwartzℂ_neg_eq_sub`](../../OSforGFF/OS/OS4_Clustering.lean#L577) — Lemma

**Statement**: Time translation by $-s$ evaluates as
$(T_{-s} g)(y) = g(y - (s,0,0,0))$.

**Proof uses**: [`timeTranslationSchwartzℂ_at_point`](../../OSforGFF/OS/OS4_Clustering.lean#L567),
[`timeShift_eq_add`](../../OSforGFF/OS/OS4_Clustering.lean#L572)

---

### [`freeCovariance_eq_kernel`](../../OSforGFF/OS/OS4_Clustering.lean#L588) — Lemma

**Statement**: The free covariance kernel is translation-invariant:
$C(x, y) = K(x - y)$ where $K = \mathrm{freeCovarianceKernel}$.

**Proof uses**: *(direct tactic proof)*

---

### [`schwinger2_time_translated_eq_bilinear`](../../OSforGFF/OS/OS4_Clustering.lean#L600) — Lemma

**Statement**: The GFF two-point Schwinger function with a time-translated second
argument equals the bilinear kernel integral:
$$S_2(f, T_{-s} g) = \int_x \int_y f(x)\, K(x-y)\, g(y - (s,0,0,0))\, dy\, dx.$$

**Proof uses**: [`gff_two_point_equals_covarianceℂ_free`](../../OSforGFF/Measure/IsGaussian.lean#L463),
[`timeTranslationSchwartzℂ_neg_eq_sub`](../../OSforGFF/OS/OS4_Clustering.lean#L577),
[`freeCovariance_eq_kernel`](../../OSforGFF/OS/OS4_Clustering.lean#L588)

---

### [`gaussianFreeField_satisfies_OS4_PolynomialClustering`](../../OSforGFF/OS/OS4_Clustering.lean#L623) — Theorem

**Statement**: For any $\alpha > 0$, the GFF satisfies polynomial OS4 clustering with
exponent $\alpha$: there exists $c \geq 0$ such that for all $s \geq 0$,
$$\Bigl\lVert \mathbb{E}\bigl[e^{\langle\omega,f\rangle + \langle T_s\omega, g\rangle}\bigr]
  - \mathbb{E}\bigl[e^{\langle\omega,f\rangle}\bigr]
    \mathbb{E}\bigl[e^{\langle\omega,g\rangle}\bigr] \Bigr\rVert
  \leq c\,(1+s)^{-\alpha}.$$

**Proof uses**: [`time_translation_pairing_duality`](../../OSforGFF/OS/OS4_Clustering.lean#L551),
[`OS4infra.gff_joint_mgf_factorization`](../../OSforGFF/OS/OS4_MGF.lean#L216),
[`OS4infra.gff_generating_time_invariant`](../../OSforGFF/OS/OS4_MGF.lean#L203),
[`schwinger2_time_translated_eq_bilinear`](../../OSforGFF/OS/OS4_Clustering.lean#L600),
[`OS4infra.exp_sub_one_bound_general`](../../OSforGFF/OS/OS4_MGF.lean#L248),
[`freeCovariance_exponential_bound`](../../OSforGFF/Covariance/Momentum.lean#L1884),
[`freeCovarianceKernel_integrable`](../../OSforGFF/Covariance/Momentum.lean#L1690),
[`freeCovarianceKernel_continuousOn`](../../OSforGFF/Covariance/Momentum.lean#L1963),
[`schwartz_bilinear_translation_decay_polynomial_proof`](../../OSforGFF/General/QuantitativeDecay.lean#L758),
[`timeShiftConst_norm`](../../OSforGFF/OS/OS4_Clustering.lean#L560)

---

*This file has **2** definitions and **14** theorems/lemmas (0 with sorry).*
