Documentation

Mathlib.AlgebraicGeometry.Limits

(Co)Limits of Schemes #

We construct various limits and colimits in the category of schemes.

TODO #

Spec ℤ is the terminal object in the category of schemes.

Instances For

    Spec ℤ is the terminal object in the category of schemes.

    Instances For
      @[implicit_reducible]
      noncomputable def AlgebraicGeometry.Scheme.emptyTo (X : Scheme) :
      X

      The map from the empty scheme.

      Instances For
        @[simp]
        theorem AlgebraicGeometry.Scheme.emptyTo_base (X : Scheme) :
        X.emptyTo.base = TopCat.ofHom { toFun := fun (x : PEmpty.{u + 1}) => x.elim, continuous_toFun := }
        theorem AlgebraicGeometry.Scheme.empty_ext {X : Scheme} (f g : X) :
        f = g
        theorem AlgebraicGeometry.Scheme.empty_ext_iff {X : Scheme} {f g : X} :
        f = g True
        @[implicit_reducible]

        The empty scheme is the initial object in the category of schemes.

        Instances For

          A scheme is initial if its underlying space is empty .

          Instances For

            Spec 0 is the initial object in the category of schemes.

            Instances For
              @[deprecated AlgebraicGeometry.specPUnitIsInitial (since := "2026-02-08")]

              Alias of AlgebraicGeometry.specPUnitIsInitial.


              Spec 0 is the initial object in the category of schemes.

              Instances For
                @[instance 100]

                This is true in general for finite discrete schemes. See below.

                theorem AlgebraicGeometry.sigmaι_eq_iff {σ : Type v} (g : σScheme) [Small.{u, v} σ] (i j : σ) (x : (g i)) (y : (g j)) :
                (CategoryTheory.Limits.Sigma.ι g i) x = (CategoryTheory.Limits.Sigma.ι g j) y i, x = j, y

                The images of each component in the coproduct is disjoint.

                theorem AlgebraicGeometry.isEmpty_of_commSq_sigmaι_of_ne {σ : Type v} {g : σScheme} [Small.{u, v} σ] {i j : σ} {Z : Scheme} {a : Z g i} {b : Z g j} (h : CategoryTheory.CommSq a b (CategoryTheory.Limits.Sigma.ι g i) (CategoryTheory.Limits.Sigma.ι g j)) (hij : i j) :
                IsEmpty Z
                noncomputable def AlgebraicGeometry.sigmaOpenCover {σ : Type v} (g : σScheme) [Small.{u, v} σ] :

                The cover of ∐ X by the Xᵢ.

                Instances For
                  @[simp]
                  theorem AlgebraicGeometry.sigmaOpenCover_X {σ : Type v} (g : σScheme) [Small.{u, v} σ] (a✝ : σ) :
                  (sigmaOpenCover g).X a✝ = g a✝
                  noncomputable def AlgebraicGeometry.sigmaMk {ι : Type u} (f : ιScheme) :
                  (i : ι) × (f i) ≃ₜ ↥( f)

                  The underlying topological space of the coproduct is homeomorphic to the disjoint union.

                  Instances For
                    @[simp]
                    theorem AlgebraicGeometry.sigmaMk_mk {ι : Type u} (f : ιScheme) (i : ι) (x : (f i)) :
                    (sigmaMk f) i, x = (CategoryTheory.Limits.Sigma.ι f i) x
                    theorem AlgebraicGeometry.isOpenImmersion_sigmaDesc {σ : Type v} (g : σScheme) [Small.{u, v} σ] {X : Scheme} (α : (i : σ) → g i X) [∀ (i : σ), IsOpenImmersion (α i)] ( : Pairwise (Function.onFun Disjoint fun (x : σ) => Set.range (α x))) :
                    theorem AlgebraicGeometry.nonempty_isColimit_cofanMk_of {σ : Type v} [Small.{u, v} σ] {X : σScheme} {S : Scheme} (f : (i : σ) → X i S) [∀ (i : σ), IsOpenImmersion (f i)] (hcov : ⨆ (i : σ), Scheme.Hom.opensRange (f i) = ) (hdisj : Pairwise (Function.onFun Disjoint fun (x : σ) => Scheme.Hom.opensRange (f x))) :

                    S is the disjoint union of Xᵢ if the Xᵢ are covering, pairwise disjoint open subschemes of S.

                    (Implementation Detail) The coproduct of the two schemes is given by indexed coproducts over WalkingPair.

                    Instances For
                      noncomputable def AlgebraicGeometry.coprodMk (X Y : Scheme) :
                      X Y ≃ₜ ↥(X ⨿ Y)

                      The underlying topological space of the coproduct is homeomorphic to the disjoint union

                      Instances For
                        noncomputable def AlgebraicGeometry.coprodOpenCover (X Y : Scheme) :

                        The open cover of the coproduct of two schemes.

                        Instances For

                          If X and Y are open disjoint and covering open subschemes of S, S is the disjoint union of X and Y.

                          The sections on coproducts of schemes are the (categorical) product of the sections on the components

                          Instances For

                            The map Spec R ⨿ Spec S ⟶ Spec (R × S). This is an isomorphism as witnessed by an IsIso instance provided below.

                            Instances For
                              noncomputable def AlgebraicGeometry.sigmaSpec {ι : Type u} (R : ιCommRingCat) :
                              ( fun (i : ι) => Spec (R i)) Spec (CommRingCat.of ((i : ι) → (R i)))

                              The canonical map ∐ Spec Rᵢ ⟶ Spec (Π Rᵢ). This is an isomorphism when the product is finite.

                              Instances For
                                @[simp]
                                theorem AlgebraicGeometry.ι_sigmaSpec {ι : Type u} (R : ιCommRingCat) (i : ι) :
                                instance AlgebraicGeometry.instIsOpenImmersionMapOfHomForallEvalRingHom {ι : Type u} (i : ι) (R : ιType (max u_1 u)) [(i : ι) → CommRing (R i)] :
                                instance AlgebraicGeometry.instIsAffineSigmaObjScheme {σ : Type v} (g : σScheme) [Finite σ] [∀ (i : σ), IsAffine (g i)] :
                                theorem AlgebraicGeometry.IsAffineOpen.iSup_of_disjoint {σ : Type v} {X : Scheme} [Finite σ] {U : σX.Opens} (hU : ∀ (i : σ), IsAffineOpen (U i)) (hU' : Pairwise (Function.onFun Disjoint U)) :
                                theorem AlgebraicGeometry.IsAffineOpen.biSup_of_disjoint {σ : Type v} {X : Scheme} {s : Set σ} (hs : s.Finite) {U : σX.Opens} (hU : is, IsAffineOpen (U i)) (hU' : s.Pairwise (Function.onFun Disjoint U)) :
                                IsAffineOpen (⨆ is, U i)