Documentation

Mathlib.Combinatorics.SimpleGraph.Triangle.Removal

Triangle removal lemma #

In this file, we prove the triangle removal lemma.

References #

Yaël Dillies, Bhavik Mehta, Formalising Szemerédi’s Regularity Lemma in Lean

noncomputable def SimpleGraph.triangleRemovalBound (ε : ) :

An explicit form for the constant in the triangle removal lemma.

Note that this depends on SzemerediRegularity.bound, which is a tower-type exponential. This means triangleRemovalBound is in practice absolutely tiny.

Equations
Instances For
    theorem SimpleGraph.triangleRemovalBound_pos {ε : } (hε : 0 < ε) (hε₁ : ε 1) :
    theorem SimpleGraph.regularityReduced_edges_card_aux {α : Type u_1} [DecidableEq α] [Fintype α] {G : SimpleGraph α} [DecidableRel G.Adj] {P : Finpartition Finset.univ} {ε : } [Nonempty α] (hε : 0 < ε) (hP : P.IsEquipartition) (hPε : P.IsUniform G (ε / 8)) (hP' : 4 / ε P.parts.card) :
    2 * (G.edgeFinset.card - (regularityReduced P G (ε / 8) (ε / 4)).edgeFinset.card) < 2 * ε * (Fintype.card α ^ 2)
    theorem SimpleGraph.FarFromTriangleFree.le_card_cliqueFinset {α : Type u_1} [DecidableEq α] [Fintype α] {G : SimpleGraph α} [DecidableRel G.Adj] {ε : } (hG : G.FarFromTriangleFree ε) :
    triangleRemovalBound ε * (Fintype.card α) ^ 3 (G.cliqueFinset 3).card

    Triangle Removal Lemma. If not all triangles can be removed by removing few edges (on the order of (card α)^2), then there were many triangles to start with (on the order of (card α)^3).

    theorem SimpleGraph.triangle_removal {α : Type u_1} [DecidableEq α] [Fintype α] {G : SimpleGraph α} [DecidableRel G.Adj] {ε : } (hG : (G.cliqueFinset 3).card < triangleRemovalBound ε * (Fintype.card α) ^ 3) :
    G'G, ∃ (x : DecidableRel G'.Adj), G.edgeFinset.card - G'.edgeFinset.card < ε * (Fintype.card α ^ 2) G'.CliqueFree 3

    Triangle Removal Lemma. If there are not too many triangles (on the order of (card α)^3) then they can all be removed by removing a few edges (on the order of (card α)^2).

    Extension for the positivity tactic: SimpleGraph.triangleRemovalBound ε is positive if 0 < ε ≤ 1.

    Note this looks for ε ≤ 1 in the context.

    Instances For