Documentation

Mathlib.AlgebraicGeometry.Restrict

Restriction of Schemes and Morphisms #

Main definition #

Open subset of a scheme as a scheme.

Equations
  • U = X.restrict
Instances For
    def AlgebraicGeometry.Scheme.Opens.ι {X : Scheme} (U : X.Opens) :
    U X

    The restriction of a scheme to an open subset.

    Equations
    • U = X.ofRestrict
    Instances For
      @[simp]
      theorem AlgebraicGeometry.Scheme.Opens.ι_base_apply {X : Scheme} (U : X.Opens) (x : U) :
      U.base x = x
      @[simp]
      theorem AlgebraicGeometry.Scheme.Opens.instCanonicallyOver_over {X : Scheme} (U : X.Opens) :
      U X = U
      theorem AlgebraicGeometry.Scheme.Opens.toScheme_carrier {X : Scheme} (U : X.Opens) :
      (↑U).toPresheafedSpace = U
      theorem AlgebraicGeometry.Scheme.Opens.toScheme_presheaf_obj {X : Scheme} (U : X.Opens) (V : (↑U).Opens) :
      (↑U).presheaf.obj (Opposite.op V) = X.presheaf.obj (Opposite.op ((Hom.opensFunctor U).obj V))
      @[simp]
      theorem AlgebraicGeometry.Scheme.Opens.toScheme_presheaf_map {X : Scheme} (U : X.Opens) {V W : (TopologicalSpace.Opens (↑U).toPresheafedSpace)ᵒᵖ} (i : V W) :
      (↑U).presheaf.map i = X.presheaf.map ((Hom.opensFunctor U).map i.unop).op
      @[simp]
      theorem AlgebraicGeometry.Scheme.Opens.ι_app {X : Scheme} (U V : X.Opens) :
      Hom.app U V = X.presheaf.map (CategoryTheory.homOfLE ).op
      @[simp]
      theorem AlgebraicGeometry.Scheme.Opens.ι_appTop {X : Scheme} (U : X.Opens) :
      Hom.appTop U = X.presheaf.map (CategoryTheory.homOfLE ).op
      @[simp]
      theorem AlgebraicGeometry.Scheme.Opens.ι_appLE {X : Scheme} (U V : X.Opens) (W : (↑U).Opens) (e : W (TopologicalSpace.Opens.map U.base).obj V) :
      Hom.appLE U V W e = X.presheaf.map (CategoryTheory.homOfLE ).op
      @[simp]
      theorem AlgebraicGeometry.Scheme.Opens.ι_appIso {X : Scheme} (U : X.Opens) (V : (↑U).Opens) :
      Hom.appIso U V = CategoryTheory.Iso.refl (X.presheaf.obj (Opposite.op ((Hom.opensFunctor U).obj V)))
      @[simp]
      theorem AlgebraicGeometry.Scheme.Opens.range_ι {X : Scheme} (U : X.Opens) :
      Set.range U.base = U
      theorem AlgebraicGeometry.Scheme.Opens.ι_image_le {X : Scheme} (U : X.Opens) (W : (↑U).Opens) :
      (Hom.opensFunctor U).obj W U
      theorem AlgebraicGeometry.Scheme.Opens.ι_app_self {X : Scheme} (U : X.Opens) :
      Hom.app U U = X.presheaf.map (CategoryTheory.eqToHom ).op
      theorem AlgebraicGeometry.Scheme.Opens.eq_presheaf_map_eqToHom {X : Scheme} (U : X.Opens) {V W : (↑U).Opens} (e : (Hom.opensFunctor U).obj V = (Hom.opensFunctor U).obj W) :
      X.presheaf.map (CategoryTheory.eqToHom e).op = (↑U).presheaf.map (CategoryTheory.eqToHom ).op
      @[simp]
      theorem AlgebraicGeometry.Scheme.Opens.nonempty_iff {X : Scheme} (U : X.Opens) :
      Nonempty (↑U).toPresheafedSpace (↑U).Nonempty
      def AlgebraicGeometry.Scheme.Opens.topIso {X : Scheme} (U : X.Opens) :
      (↑U).presheaf.obj (Opposite.op ) X.presheaf.obj (Opposite.op U)

      The global sections of the restriction is isomorphic to the sections on the open set.

      Equations
      Instances For
        @[simp]
        theorem AlgebraicGeometry.Scheme.Opens.topIso_hom {X : Scheme} (U : X.Opens) :
        U.topIso.hom = X.presheaf.map (CategoryTheory.eqToHom ).op
        @[simp]
        theorem AlgebraicGeometry.Scheme.Opens.topIso_inv {X : Scheme} (U : X.Opens) :
        U.topIso.inv = X.presheaf.map (CategoryTheory.eqToHom ).op
        def AlgebraicGeometry.Scheme.Opens.stalkIso {X : Scheme} (U : X.Opens) (x : U) :
        (↑U).presheaf.stalk x X.presheaf.stalk x

        The stalks of an open subscheme are isomorphic to the stalks of the original scheme.

        Equations
        • U.stalkIso x = X.restrictStalkIso x
        Instances For
          @[simp]
          theorem AlgebraicGeometry.Scheme.Opens.germ_stalkIso_hom {X : Scheme} (U : X.Opens) {V : (↑U).Opens} (x : U) (hx : x V) :
          CategoryTheory.CategoryStruct.comp ((↑U).presheaf.germ V x hx) (U.stalkIso x).hom = X.presheaf.germ ((Hom.opensFunctor U).obj V) x
          @[simp]
          theorem AlgebraicGeometry.Scheme.Opens.germ_stalkIso_hom_assoc {X : Scheme} (U : X.Opens) {V : (↑U).Opens} (x : U) (hx : x V) {Z : CommRingCat} (h : X.presheaf.stalk x Z) :
          CategoryTheory.CategoryStruct.comp ((↑U).presheaf.germ V x hx) (CategoryTheory.CategoryStruct.comp (U.stalkIso x).hom h) = CategoryTheory.CategoryStruct.comp (X.presheaf.germ ((Hom.opensFunctor U).obj V) x ) h
          theorem AlgebraicGeometry.Scheme.Opens.germ_stalkIso_inv {X : Scheme} (U : X.Opens) (V : (↑U).Opens) (x : U) (hx : x V) :
          CategoryTheory.CategoryStruct.comp (X.presheaf.germ ((Hom.opensFunctor U).obj V) x ) (U.stalkIso x).inv = (↑U).presheaf.germ V x hx
          theorem AlgebraicGeometry.Scheme.Opens.germ_stalkIso_inv_assoc {X : Scheme} (U : X.Opens) (V : (↑U).Opens) (x : U) (hx : x V) {Z : CommRingCat} (h : (↑U).presheaf.stalk x Z) :
          CategoryTheory.CategoryStruct.comp (X.presheaf.germ ((Hom.opensFunctor U).obj V) x ) (CategoryTheory.CategoryStruct.comp (U.stalkIso x).inv h) = CategoryTheory.CategoryStruct.comp ((↑U).presheaf.germ V x hx) h
          theorem AlgebraicGeometry.Scheme.Opens.stalkIso_inv {X : Scheme} (U : X.Opens) (x : U) :
          (U.stalkIso x).inv = Hom.stalkMap U x
          def AlgebraicGeometry.Scheme.openCoverOfISupEqTop {s : Type u_1} (X : Scheme) (U : sX.Opens) (hU : ⨆ (i : s), U i = ) :
          X.OpenCover

          If U is a family of open sets that covers X, then X.restrict U forms an X.open_cover.

          Equations
          • X.openCoverOfISupEqTop U hU = { J := s, obj := fun (i : s) => (U i), map := fun (i : s) => (U i), f := fun (x : X.toPresheafedSpace) => .choose, covers := , map_prop := }
          Instances For
            @[simp]
            theorem AlgebraicGeometry.Scheme.openCoverOfISupEqTop_map {s : Type u_1} (X : Scheme) (U : sX.Opens) (hU : ⨆ (i : s), U i = ) (i : s) :
            (X.openCoverOfISupEqTop U hU).map i = (U i)
            @[simp]
            theorem AlgebraicGeometry.Scheme.openCoverOfISupEqTop_J {s : Type u_1} (X : Scheme) (U : sX.Opens) (hU : ⨆ (i : s), U i = ) :
            (X.openCoverOfISupEqTop U hU).J = s
            @[simp]
            theorem AlgebraicGeometry.Scheme.openCoverOfISupEqTop_obj {s : Type u_1} (X : Scheme) (U : sX.Opens) (hU : ⨆ (i : s), U i = ) (i : s) :
            (X.openCoverOfISupEqTop U hU).obj i = (U i)
            @[deprecated AlgebraicGeometry.Scheme.openCoverOfISupEqTop (since := "2024-07-24")]
            def AlgebraicGeometry.Scheme.openCoverOfSuprEqTop {s : Type u_1} (X : Scheme) (U : sX.Opens) (hU : ⨆ (i : s), U i = ) :
            X.OpenCover

            Alias of AlgebraicGeometry.Scheme.openCoverOfISupEqTop.


            If U is a family of open sets that covers X, then X.restrict U forms an X.open_cover.

            Equations
            Instances For
              def AlgebraicGeometry.opensRestrict {X : Scheme} (U : X.Opens) :
              (↑U).Opens { V : X.Opens // V U }

              The open sets of an open subscheme corresponds to the open sets containing in the subset.

              Equations
              Instances For
                @[simp]
                theorem AlgebraicGeometry.coe_opensRestrict_symm_apply {X : Scheme} (U : X.Opens) (a✝ : { V : X.Opens // V U }) :
                ((opensRestrict U).symm a✝) = U.base ⁻¹' ((Equiv.subtypeEquivProp ).symm a✝)
                @[simp]
                theorem AlgebraicGeometry.coe_opensRestrict_apply_coe {X : Scheme} (U : X.Opens) (a✝ : (↑U).Opens) :
                ((opensRestrict U) a✝) = (fun (a : (↑U).toPresheafedSpace) => a) '' a✝
                instance AlgebraicGeometry.ΓRestrictAlgebra {X : Scheme} (U : X.Opens) :
                Algebra (X.presheaf.obj (Opposite.op )) ((↑U).presheaf.obj (Opposite.op ))
                Equations
                theorem AlgebraicGeometry.Scheme.map_basicOpen {X : Scheme} (U : X.Opens) (r : ((↑U).presheaf.obj (Opposite.op ))) :
                (Hom.opensFunctor U).obj ((↑U).basicOpen r) = X.basicOpen ((X.presheaf.map (CategoryTheory.eqToHom ).op).hom r)
                @[deprecated AlgebraicGeometry.Scheme.map_basicOpen (since := "2024-10-23")]
                theorem AlgebraicGeometry.Scheme.map_basicOpen' {X : Scheme} (U : X.Opens) (r : ((↑U).presheaf.obj (Opposite.op ))) :
                (Hom.opensFunctor U).obj ((↑U).basicOpen r) = X.basicOpen ((X.presheaf.map (CategoryTheory.eqToHom ).op).hom r)

                Alias of AlgebraicGeometry.Scheme.map_basicOpen.

                theorem AlgebraicGeometry.Scheme.Opens.ι_image_basicOpen {X : Scheme} (U : X.Opens) (r : ((↑U).presheaf.obj (Opposite.op ))) :
                (Hom.opensFunctor U).obj ((↑U).basicOpen r) = X.basicOpen r
                theorem AlgebraicGeometry.Scheme.map_basicOpen_map {X : Scheme} (U : X.Opens) (r : (X.presheaf.obj (Opposite.op U))) :
                (Hom.opensFunctor U).obj ((↑U).basicOpen (U.topIso.inv.hom r)) = X.basicOpen r
                noncomputable def AlgebraicGeometry.Scheme.homOfLE (X : Scheme) {U V : X.Opens} (e : U V) :
                U V

                If U ≤ V, then U is also a subscheme of V.

                Equations
                Instances For
                  @[simp]
                  theorem AlgebraicGeometry.Scheme.homOfLE_ι (X : Scheme) {U V : X.Opens} (e : U V) :
                  CategoryTheory.CategoryStruct.comp (X.homOfLE e) V = U
                  instance AlgebraicGeometry.instIsOverHomOfLE {X : Scheme} {U V : X.Opens} (h : U V) :
                  Scheme.Hom.IsOver (X.homOfLE h) X
                  @[simp]
                  theorem AlgebraicGeometry.Scheme.homOfLE_rfl (X : Scheme) (U : X.Opens) :
                  @[simp]
                  theorem AlgebraicGeometry.Scheme.homOfLE_homOfLE (X : Scheme) {U V W : X.Opens} (e₁ : U V) (e₂ : V W) :
                  CategoryTheory.CategoryStruct.comp (X.homOfLE e₁) (X.homOfLE e₂) = X.homOfLE
                  @[simp]
                  theorem AlgebraicGeometry.Scheme.homOfLE_homOfLE_assoc (X : Scheme) {U V W : X.Opens} (e₁ : U V) (e₂ : V W) {Z : Scheme} (h : W Z) :
                  theorem AlgebraicGeometry.Scheme.homOfLE_base {X : Scheme} {U V : X.Opens} (e : U V) :
                  (X.homOfLE e).base = (TopologicalSpace.Opens.toTopCat X.toPresheafedSpace).map (CategoryTheory.homOfLE e)
                  @[simp]
                  theorem AlgebraicGeometry.Scheme.homOfLE_apply {X : Scheme} {U V : X.Opens} (e : U V) (x : U) :
                  ((X.homOfLE e).base x) = x
                  theorem AlgebraicGeometry.Scheme.ι_image_homOfLE_le_ι_image {X : Scheme} {U V : X.Opens} (e : U V) (W : (↑V).Opens) :
                  (Hom.opensFunctor U).obj ((TopologicalSpace.Opens.map (X.homOfLE e).base).obj W) (Hom.opensFunctor V).obj W
                  @[simp]
                  theorem AlgebraicGeometry.Scheme.homOfLE_app {X : Scheme} {U V : X.Opens} (e : U V) (W : (↑V).Opens) :
                  Hom.app (X.homOfLE e) W = X.presheaf.map (CategoryTheory.homOfLE ).op
                  theorem AlgebraicGeometry.Scheme.homOfLE_appTop {X : Scheme} {U V : X.Opens} (e : U V) :
                  Hom.appTop (X.homOfLE e) = X.presheaf.map (CategoryTheory.homOfLE ).op
                  instance AlgebraicGeometry.instIsOpenImmersionHomOfLE (X : Scheme) {U V : X.Opens} (e : U V) :
                  IsOpenImmersion (X.homOfLE e)

                  The functor taking open subsets of X to open subschemes of X.

                  Equations
                  Instances For
                    @[simp]
                    theorem AlgebraicGeometry.Scheme.restrictFunctor_obj_left (X : Scheme) (U : X.Opens) :
                    (X.restrictFunctor.obj U).left = U
                    @[simp]
                    theorem AlgebraicGeometry.Scheme.restrictFunctor_map_left (X : Scheme) {U V : X.Opens} (i : U V) :
                    (X.restrictFunctor.map i).left = X.homOfLE
                    @[simp]
                    theorem AlgebraicGeometry.Scheme.restrictFunctor_obj_hom (X : Scheme) (U : X.Opens) :
                    (X.restrictFunctor.obj U).hom = U
                    @[deprecated AlgebraicGeometry.Scheme.homOfLE_ι (since := "2024-10-20")]
                    theorem AlgebraicGeometry.Scheme.restrictFunctor_map_ofRestrict (X : Scheme) {U V : X.Opens} (e : U V) :
                    CategoryTheory.CategoryStruct.comp (X.homOfLE e) V = U

                    Alias of AlgebraicGeometry.Scheme.homOfLE_ι.

                    @[deprecated AlgebraicGeometry.Scheme.homOfLE_ι_assoc (since := "2024-10-20")]

                    Alias of AlgebraicGeometry.Scheme.homOfLE_ι_assoc.

                    @[deprecated AlgebraicGeometry.Scheme.homOfLE_base (since := "2024-10-20")]
                    theorem AlgebraicGeometry.Scheme.restrictFunctor_map_base {X : Scheme} {U V : X.Opens} (e : U V) :
                    (X.homOfLE e).base = (TopologicalSpace.Opens.toTopCat X.toPresheafedSpace).map (CategoryTheory.homOfLE e)

                    Alias of AlgebraicGeometry.Scheme.homOfLE_base.

                    @[deprecated AlgebraicGeometry.Scheme.ι_image_homOfLE_le_ι_image (since := "2024-10-20")]
                    theorem AlgebraicGeometry.Scheme.restrictFunctor_map_app_aux {X : Scheme} {U V : X.Opens} (e : U V) (W : (↑V).Opens) :
                    (Hom.opensFunctor U).obj ((TopologicalSpace.Opens.map (X.homOfLE e).base).obj W) (Hom.opensFunctor V).obj W

                    Alias of AlgebraicGeometry.Scheme.ι_image_homOfLE_le_ι_image.

                    @[deprecated AlgebraicGeometry.Scheme.homOfLE_app (since := "2024-10-20")]
                    theorem AlgebraicGeometry.Scheme.restrictFunctor_map_app {X : Scheme} {U V : X.Opens} (e : U V) (W : (↑V).Opens) :
                    Hom.app (X.homOfLE e) W = X.presheaf.map (CategoryTheory.homOfLE ).op

                    Alias of AlgebraicGeometry.Scheme.homOfLE_app.

                    def AlgebraicGeometry.Scheme.restrictFunctorΓ {X : Scheme} :
                    X.restrictFunctor.op.comp ((CategoryTheory.Over.forget X).op.comp Γ) X.presheaf

                    The functor that restricts to open subschemes and then takes global section is isomorphic to the structure sheaf.

                    Equations
                    Instances For
                      @[simp]
                      theorem AlgebraicGeometry.Scheme.restrictFunctorΓ_inv_app {X : Scheme} (X✝ : X.Opensᵒᵖ) :
                      restrictFunctorΓ.inv.app X✝ = X.presheaf.map (CategoryTheory.eqToHom )
                      @[simp]
                      theorem AlgebraicGeometry.Scheme.restrictFunctorΓ_hom_app {X : Scheme} (X✝ : X.Opensᵒᵖ) :
                      restrictFunctorΓ.hom.app X✝ = X.presheaf.map (CategoryTheory.eqToHom )
                      noncomputable def AlgebraicGeometry.Scheme.restrictRestrictComm (X : Scheme) (U V : X.Opens) :
                      ((TopologicalSpace.Opens.map U.base).obj V) ((TopologicalSpace.Opens.map V.base).obj U)

                      X ∣_ U ∣_ V is isomorphic to X ∣_ V ∣_ U

                      Equations
                      • One or more equations did not get rendered due to their size.
                      Instances For
                        noncomputable def AlgebraicGeometry.Scheme.Hom.isoImage {X Y : Scheme} (f : X.Hom Y) [IsOpenImmersion f] (U : X.Opens) :
                        U (f.opensFunctor.obj U)

                        If f : X ⟶ Y is an open immersion, then for any U : X.Opens, we have the isomorphism U ≅ f ''ᵁ U.

                        Equations
                        Instances For
                          @[deprecated AlgebraicGeometry.Scheme.Hom.isoImage (since := "2024-10-20")]
                          def AlgebraicGeometry.Scheme.restrictRestrict {X Y : Scheme} (f : X.Hom Y) [IsOpenImmersion f] (U : X.Opens) :
                          U (f.opensFunctor.obj U)

                          Alias of AlgebraicGeometry.Scheme.Hom.isoImage.


                          If f : X ⟶ Y is an open immersion, then for any U : X.Opens, we have the isomorphism U ≅ f ''ᵁ U.

                          Equations
                          Instances For
                            @[deprecated AlgebraicGeometry.Scheme.Hom.isoImage_hom_ι (since := "2024-10-20")]

                            Alias of AlgebraicGeometry.Scheme.Hom.isoImage_hom_ι.

                            @[deprecated AlgebraicGeometry.Scheme.Hom.isoImage_inv_ι (since := "2024-10-20")]

                            Alias of AlgebraicGeometry.Scheme.Hom.isoImage_inv_ι.

                            @[deprecated AlgebraicGeometry.Scheme.Hom.isoImage_hom_ι_assoc (since := "2024-10-20")]

                            Alias of AlgebraicGeometry.Scheme.Hom.isoImage_hom_ι_assoc.

                            (⊤ : X.Opens) as a scheme is isomorphic to X.

                            Equations
                            • X.topIso = { hom := , inv := { toHom_1 := X.restrictTopIso.inv }, hom_inv_id := , inv_hom_id := }
                            Instances For
                              @[simp]
                              theorem AlgebraicGeometry.Scheme.topIso_hom (X : Scheme) :
                              X.topIso.hom =
                              noncomputable def AlgebraicGeometry.Scheme.isoOfEq (X : Scheme) {U V : X.Opens} (e : U = V) :
                              U V

                              If U = V, then X ∣_ U is isomorphic to X ∣_ V.

                              Equations
                              Instances For
                                @[simp]
                                theorem AlgebraicGeometry.Scheme.isoOfEq_hom_ι (X : Scheme) {U V : X.Opens} (e : U = V) :
                                CategoryTheory.CategoryStruct.comp (X.isoOfEq e).hom V = U
                                @[simp]
                                theorem AlgebraicGeometry.Scheme.isoOfEq_inv_ι (X : Scheme) {U V : X.Opens} (e : U = V) :
                                CategoryTheory.CategoryStruct.comp (X.isoOfEq e).inv U = V
                                @[simp]
                                theorem AlgebraicGeometry.Scheme.isoOfEq_rfl (X : Scheme) (U : X.Opens) :
                                X.isoOfEq = CategoryTheory.Iso.refl U
                                @[deprecated AlgebraicGeometry.Scheme.isoOfEq (since := "2024-10-20")]
                                def AlgebraicGeometry.Scheme.restrictIsoOfEq (X : Scheme) {U V : X.Opens} (e : U = V) :
                                U V

                                Alias of AlgebraicGeometry.Scheme.isoOfEq.


                                If U = V, then X ∣_ U is isomorphic to X ∣_ V.

                                Equations
                                Instances For
                                  noncomputable def AlgebraicGeometry.Scheme.Hom.preimageIso {X Y : Scheme} (f : X.Hom Y) [CategoryTheory.IsIso f] (U : Y.Opens) :
                                  ((TopologicalSpace.Opens.map f.base).obj U) U

                                  The restriction of an isomorphism onto an open set.

                                  Equations
                                  Instances For
                                    @[deprecated AlgebraicGeometry.Scheme.Hom.preimageIso (since := "2024-10-20")]
                                    def AlgebraicGeometry.Scheme.restrictMapIso {X Y : Scheme} (f : X.Hom Y) [CategoryTheory.IsIso f] (U : Y.Opens) :
                                    ((TopologicalSpace.Opens.map f.base).obj U) U

                                    Alias of AlgebraicGeometry.Scheme.Hom.preimageIso.


                                    The restriction of an isomorphism onto an open set.

                                    Equations
                                    Instances For

                                      Given a morphism f : X ⟶ Y and an open set U ⊆ Y, we have X ×[Y] U ≅ X |_{f ⁻¹ U}

                                      Equations
                                      Instances For
                                        @[deprecated AlgebraicGeometry.pullbackRestrictIsoRestrict_hom_ι (since := "2024-10-20")]

                                        Alias of AlgebraicGeometry.pullbackRestrictIsoRestrict_hom_ι.

                                        def AlgebraicGeometry.morphismRestrict {X Y : Scheme} (f : X Y) (U : Y.Opens) :
                                        ((TopologicalSpace.Opens.map f.base).obj U) U

                                        The restriction of a morphism X ⟶ Y onto X |_{f ⁻¹ U} ⟶ Y |_ U.

                                        Equations
                                        Instances For

                                          the notation for restricting a morphism of scheme to an open subset of the target scheme

                                          Equations
                                          • One or more equations did not get rendered due to their size.
                                          Instances For
                                            theorem AlgebraicGeometry.isPullback_morphismRestrict {X Y : Scheme} (f : X Y) (U : Y.Opens) :
                                            theorem AlgebraicGeometry.isPullback_opens_inf_le {X : Scheme} {U V W : X.Opens} (hU : U W) (hV : V W) :
                                            CategoryTheory.IsPullback (X.homOfLE ) (X.homOfLE ) (X.homOfLE hU) (X.homOfLE hV)
                                            theorem AlgebraicGeometry.isPullback_opens_inf {X : Scheme} (U V : X.Opens) :
                                            CategoryTheory.IsPullback (X.homOfLE ) (X.homOfLE ) U V
                                            theorem AlgebraicGeometry.morphismRestrict_base_coe {X Y : Scheme} (f : X Y) (U : Y.Opens) (x : (↑((TopologicalSpace.Opens.map f.base).obj U)).toPresheafedSpace) :
                                            Coe.coe ((f ∣_ U).base x) = f.base x
                                            theorem AlgebraicGeometry.morphismRestrict_base {X Y : Scheme} (f : X Y) (U : Y.Opens) :
                                            (f ∣_ U).base = U.carrier.restrictPreimage f.base
                                            theorem AlgebraicGeometry.image_morphismRestrict_preimage {X Y : Scheme} (f : X Y) (U : Y.Opens) (V : TopologicalSpace.Opens (↑U).toPresheafedSpace) :
                                            theorem AlgebraicGeometry.morphismRestrict_app {X Y : Scheme} (f : X Y) (U : Y.Opens) (V : (↑U).Opens) :
                                            @[simp]
                                            theorem AlgebraicGeometry.morphismRestrict_app' {X Y : Scheme} (f : X Y) (U : Y.Opens) (V : TopologicalSpace.Opens (↑U).toPresheafedSpace) :
                                            @[simp]
                                            theorem AlgebraicGeometry.morphismRestrict_appLE {X Y : Scheme} (f : X Y) (U : Y.Opens) (V : (↑U).Opens) (W : (↑((TopologicalSpace.Opens.map f.base).obj U)).Opens) (e : W (TopologicalSpace.Opens.map (f ∣_ U).base).obj V) :

                                            Restricting a morphism onto the image of an open immersion is isomorphic to the base change along the immersion.

                                            Equations
                                            • One or more equations did not get rendered due to their size.
                                            Instances For
                                              def AlgebraicGeometry.morphismRestrictEq {X Y : Scheme} (f : X Y) {U V : Y.Opens} (e : U = V) :

                                              The restrictions onto two equal open sets are isomorphic. This currently has bad defeqs when unfolded, but it should not matter for now. Replace this definition if better defeqs are needed.

                                              Equations
                                              Instances For
                                                def AlgebraicGeometry.morphismRestrictRestrict {X Y : Scheme} (f : X Y) (U : Y.Opens) (V : (↑U).Opens) :

                                                Restricting a morphism twice is isomorphic to one restriction.

                                                Equations
                                                • One or more equations did not get rendered due to their size.
                                                Instances For
                                                  def AlgebraicGeometry.morphismRestrictRestrictBasicOpen {X Y : Scheme} (f : X Y) (U : Y.Opens) (r : (Y.presheaf.obj (Opposite.op U))) :
                                                  CategoryTheory.Arrow.mk (f ∣_ U ∣_ (↑U).basicOpen ((Y.presheaf.map (CategoryTheory.eqToHom ).op).hom r)) CategoryTheory.Arrow.mk (f ∣_ Y.basicOpen r)

                                                  Restricting a morphism twice onto a basic open set is isomorphic to one restriction.

                                                  Equations
                                                  • One or more equations did not get rendered due to their size.
                                                  Instances For
                                                    def AlgebraicGeometry.morphismRestrictStalkMap {X Y : Scheme} (f : X Y) (U : Y.Opens) (x : (↑((TopologicalSpace.Opens.map f.base).obj U)).toPresheafedSpace) :

                                                    The stalk map of a restriction of a morphism is isomorphic to the stalk map of the original map.

                                                    Equations
                                                    • One or more equations did not get rendered due to their size.
                                                    Instances For
                                                      def AlgebraicGeometry.Scheme.Hom.resLE {X Y : Scheme} (f : X.Hom Y) (U : Y.Opens) (V : X.Opens) (e : V (TopologicalSpace.Opens.map f.base).obj U) :
                                                      V U

                                                      The restriction of a morphism f : X ⟶ Y to open sets on the source and target.

                                                      Equations
                                                      Instances For
                                                        theorem AlgebraicGeometry.Scheme.Hom.resLE_eq_morphismRestrict {X Y : Scheme} (f : X Y) {U : Y.Opens} :
                                                        resLE f U ((TopologicalSpace.Opens.map f.base).obj U) = f ∣_ U
                                                        theorem AlgebraicGeometry.Scheme.Hom.resLE_id {X : Scheme} {V V' : X.Opens} (i : V V') :
                                                        @[simp]
                                                        theorem AlgebraicGeometry.Scheme.Hom.resLE_comp_ι {X Y : Scheme} (f : X Y) {U : Y.Opens} {V : X.Opens} (e : V (TopologicalSpace.Opens.map f.base).obj U) :
                                                        theorem AlgebraicGeometry.Scheme.Hom.resLE_comp_resLE {X Y : Scheme} (f : X Y) {U : Y.Opens} {V : X.Opens} (e : V (TopologicalSpace.Opens.map f.base).obj U) {Z : Scheme} (g : Y Z) {W : Z.Opens} (e' : U (TopologicalSpace.Opens.map g.base).obj W) :
                                                        theorem AlgebraicGeometry.Scheme.Hom.resLE_comp_resLE_assoc {X Y : Scheme} (f : X Y) {U : Y.Opens} {V : X.Opens} (e : V (TopologicalSpace.Opens.map f.base).obj U) {Z : Scheme} (g : Y Z) {W : Z.Opens} (e' : U (TopologicalSpace.Opens.map g.base).obj W) {Z✝ : Scheme} (h : W Z✝) :
                                                        @[simp]
                                                        theorem AlgebraicGeometry.Scheme.Hom.map_resLE {X Y : Scheme} (f : X Y) {U : Y.Opens} {V V' : X.Opens} (e : V (TopologicalSpace.Opens.map f.base).obj U) (i : V' V) :
                                                        CategoryTheory.CategoryStruct.comp (X.homOfLE i) (resLE f U V e) = resLE f U V'
                                                        @[simp]
                                                        theorem AlgebraicGeometry.Scheme.Hom.map_resLE_assoc {X Y : Scheme} (f : X Y) {U : Y.Opens} {V V' : X.Opens} (e : V (TopologicalSpace.Opens.map f.base).obj U) (i : V' V) {Z : Scheme} (h : U Z) :
                                                        @[simp]
                                                        theorem AlgebraicGeometry.Scheme.Hom.resLE_map {X Y : Scheme} (f : X Y) {U U' : Y.Opens} {V : X.Opens} (e : V (TopologicalSpace.Opens.map f.base).obj U) (i : U U') :
                                                        CategoryTheory.CategoryStruct.comp (resLE f U V e) (Y.homOfLE i) = resLE f U' V
                                                        @[simp]
                                                        theorem AlgebraicGeometry.Scheme.Hom.resLE_map_assoc {X Y : Scheme} (f : X Y) {U U' : Y.Opens} {V : X.Opens} (e : V (TopologicalSpace.Opens.map f.base).obj U) (i : U U') {Z : Scheme} (h : U' Z) :
                                                        theorem AlgebraicGeometry.Scheme.Hom.resLE_congr {X Y : Scheme} (f : X Y) {U U' : Y.Opens} {V V' : X.Opens} (e : V (TopologicalSpace.Opens.map f.base).obj U) (e₁ : U = U') (e₂ : V = V') (P : CategoryTheory.MorphismProperty Scheme) :
                                                        P (resLE f U V e) P (resLE f U' V' )
                                                        theorem AlgebraicGeometry.Scheme.Hom.resLE_preimage {X Y : Scheme} (f : X Y) {U : Y.Opens} {V : X.Opens} (e : V (TopologicalSpace.Opens.map f.base).obj U) (O : (↑U).Opens) :
                                                        (TopologicalSpace.Opens.map (resLE f U V e).base).obj O = (TopologicalSpace.Opens.map V.base).obj ((TopologicalSpace.Opens.map f.base).obj ((opensFunctor U).obj O))
                                                        theorem AlgebraicGeometry.Scheme.Hom.le_preimage_resLE_iff {X Y : Scheme} (f : X Y) {U : Y.Opens} {V : X.Opens} (e : V (TopologicalSpace.Opens.map f.base).obj U) (O : (↑U).Opens) (W : (↑V).Opens) :
                                                        W (TopologicalSpace.Opens.map (resLE f U V e).base).obj O (opensFunctor V).obj W (TopologicalSpace.Opens.map f.base).obj ((opensFunctor U).obj O)
                                                        theorem AlgebraicGeometry.Scheme.Hom.resLE_appLE {X Y : Scheme} (f : X Y) {U : Y.Opens} {V : X.Opens} (e : V (TopologicalSpace.Opens.map f.base).obj U) (O : (↑U).Opens) (W : (↑V).Opens) (e' : W (TopologicalSpace.Opens.map (resLE f U V e).base).obj O) :
                                                        appLE (resLE f U V e) O W e' = appLE f ((opensFunctor U).obj O) ((opensFunctor V).obj W)
                                                        @[simp]
                                                        theorem AlgebraicGeometry.Scheme.Hom.coe_resLE_base {X Y : Scheme} (f : X Y) {U : Y.Opens} {V : X.Opens} (e : V (TopologicalSpace.Opens.map f.base).obj U) (x : V) :
                                                        ((resLE f U V e).base x) = f.base x
                                                        def AlgebraicGeometry.Scheme.Hom.resLEStalkMap {X Y : Scheme} (f : X Y) {U : Y.Opens} {V : X.Opens} (e : V (TopologicalSpace.Opens.map f.base).obj U) (x : V) :

                                                        The stalk map of f.resLE U V at x : V is is the stalk map of f at x.

                                                        Equations
                                                        Instances For
                                                          noncomputable def AlgebraicGeometry.arrowResLEAppIso {X Y : Scheme} (f : X Y) (U : Y.Opens) (V : X.Opens) (e : V (TopologicalSpace.Opens.map f.base).obj U) :

                                                          f.resLE U V induces f.appLE U V on global sections.

                                                          Equations
                                                          Instances For
                                                            noncomputable def AlgebraicGeometry.Scheme.OpenCover.restrict {X : Scheme} (𝒰 : X.OpenCover) (U : X.Opens) :
                                                            (↑U).OpenCover

                                                            The restriction of an open cover to an open subset.

                                                            Equations
                                                            • One or more equations did not get rendered due to their size.
                                                            Instances For
                                                              @[simp]
                                                              theorem AlgebraicGeometry.Scheme.OpenCover.restrict_map {X : Scheme} (𝒰 : X.OpenCover) (U : X.Opens) (x✝ : 𝒰.J) :
                                                              (𝒰.restrict U).map x✝ = 𝒰.map x✝ ∣_ U
                                                              @[simp]
                                                              theorem AlgebraicGeometry.Scheme.OpenCover.restrict_J {X : Scheme} (𝒰 : X.OpenCover) (U : X.Opens) :
                                                              (𝒰.restrict U).J = 𝒰.J
                                                              @[simp]
                                                              theorem AlgebraicGeometry.Scheme.OpenCover.restrict_obj {X : Scheme} (𝒰 : X.OpenCover) (U : X.Opens) (x✝ : 𝒰.J) :
                                                              (𝒰.restrict U).obj x✝ = ((TopologicalSpace.Opens.map (𝒰.map x✝).base).obj U)