Documentation

Mathlib.Analysis.Convex.Cone.Basic

Convex cones #

In a π•œ-module E, we define a convex cone as a set s such that a β€’ x + b β€’ y ∈ s whenever x, y ∈ s and a, b > 0. We prove that convex cones form a CompleteLattice, and define their images (ConvexCone.map) and preimages (ConvexCone.comap) under linear maps.

We define pointed, blunt, flat and salient cones, and prove the correspondence between convex cones and ordered modules.

We define Convex.toCone to be the minimal cone that includes a given convex set.

Main statements #

We prove two extension theorems:

In Mathlib/Analysis/Convex/Cone/Dual.lean, we prove the following theorems:

Implementation notes #

While Convex π•œ is a predicate on sets, ConvexCone π•œ E is a bundled convex cone.

References #

Definition of ConvexCone and basic properties #

structure ConvexCone (π•œ : Type u_1) (E : Type u_2) [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] :
Type u_2
  • carrier : Set E
  • smul_mem' : βˆ€ ⦃c : π•œβ¦„, 0 < c β†’ βˆ€ ⦃x : E⦄, x ∈ s.carrier β†’ c β€’ x ∈ s.carrier
  • add_mem' : βˆ€ ⦃x : E⦄, x ∈ s.carrier β†’ βˆ€ ⦃y : E⦄, y ∈ s.carrier β†’ x + y ∈ s.carrier

A convex cone is a subset s of a π•œ-module such that a β€’ x + b β€’ y ∈ s whenever a, b > 0 and x, y ∈ s.

Instances For
    instance ConvexCone.instSetLikeConvexCone {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] :
    SetLike (ConvexCone π•œ E) E
    Equations
    • ConvexCone.instSetLikeConvexCone = { coe := ConvexCone.carrier, coe_injective' := (_ : βˆ€ (S T : ConvexCone π•œ E), S.carrier = T.carrier β†’ S = T) }
    @[simp]
    theorem ConvexCone.coe_mk {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] {s : Set E} {h₁ : βˆ€ ⦃c : π•œβ¦„, 0 < c β†’ βˆ€ ⦃x : E⦄, x ∈ s β†’ c β€’ x ∈ s} {hβ‚‚ : βˆ€ ⦃x : E⦄, x ∈ s β†’ βˆ€ ⦃y : E⦄, y ∈ s β†’ x + y ∈ s} :
    ↑{ carrier := s, smul_mem' := h₁, add_mem' := hβ‚‚ } = s
    @[simp]
    theorem ConvexCone.mem_mk {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] {s : Set E} {h₁ : βˆ€ ⦃c : π•œβ¦„, 0 < c β†’ βˆ€ ⦃x : E⦄, x ∈ s β†’ c β€’ x ∈ s} {hβ‚‚ : βˆ€ ⦃x : E⦄, x ∈ s β†’ βˆ€ ⦃y : E⦄, y ∈ s β†’ x + y ∈ s} {x : E} :
    x ∈ { carrier := s, smul_mem' := h₁, add_mem' := hβ‚‚ } ↔ x ∈ s
    theorem ConvexCone.ext {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] {S : ConvexCone π•œ E} {T : ConvexCone π•œ E} (h : βˆ€ (x : E), x ∈ S ↔ x ∈ T) :
    S = T

    Two ConvexCones are equal if they have the same elements.

    theorem ConvexCone.smul_mem {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] (S : ConvexCone π•œ E) {c : π•œ} {x : E} (hc : 0 < c) (hx : x ∈ S) :
    theorem ConvexCone.add_mem {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] (S : ConvexCone π•œ E) ⦃x : E⦄ (hx : x ∈ S) ⦃y : E⦄ (hy : y ∈ S) :
    x + y ∈ S
    instance ConvexCone.instInfConvexCone {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] :
    Inf (ConvexCone π•œ E)
    Equations
    • One or more equations did not get rendered due to their size.
    @[simp]
    theorem ConvexCone.coe_inf {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] (S : ConvexCone π•œ E) (T : ConvexCone π•œ E) :
    ↑(S βŠ“ T) = ↑S ∩ ↑T
    theorem ConvexCone.mem_inf {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] (S : ConvexCone π•œ E) (T : ConvexCone π•œ E) {x : E} :
    instance ConvexCone.instInfSetConvexCone {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] :
    InfSet (ConvexCone π•œ E)
    Equations
    • One or more equations did not get rendered due to their size.
    @[simp]
    theorem ConvexCone.coe_sInf {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] (S : Set (ConvexCone π•œ E)) :
    ↑(sInf S) = β‹‚ (s : ConvexCone π•œ E) (_ : s ∈ S), ↑s
    theorem ConvexCone.mem_sInf {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] {x : E} {S : Set (ConvexCone π•œ E)} :
    x ∈ sInf S ↔ βˆ€ (s : ConvexCone π•œ E), s ∈ S β†’ x ∈ s
    @[simp]
    theorem ConvexCone.coe_iInf {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] {ΞΉ : Sort u_5} (f : ΞΉ β†’ ConvexCone π•œ E) :
    ↑(iInf f) = β‹‚ (i : ΞΉ), ↑(f i)
    theorem ConvexCone.mem_iInf {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] {ΞΉ : Sort u_5} {x : E} {f : ΞΉ β†’ ConvexCone π•œ E} :
    x ∈ iInf f ↔ βˆ€ (i : ΞΉ), x ∈ f i
    instance ConvexCone.instBotConvexCone (π•œ : Type u_1) {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] :
    Bot (ConvexCone π•œ E)
    Equations
    • One or more equations did not get rendered due to their size.
    theorem ConvexCone.mem_bot (π•œ : Type u_1) {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] (x : E) :
    @[simp]
    theorem ConvexCone.coe_bot (π•œ : Type u_1) {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] :
    instance ConvexCone.instTopConvexCone (π•œ : Type u_1) {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] :
    Top (ConvexCone π•œ E)
    Equations
    • One or more equations did not get rendered due to their size.
    theorem ConvexCone.mem_top (π•œ : Type u_1) {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] (x : E) :
    @[simp]
    theorem ConvexCone.coe_top (π•œ : Type u_1) {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] :
    β†‘βŠ€ = Set.univ
    instance ConvexCone.instCompleteLatticeConvexCone (π•œ : Type u_1) {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] :
    Equations
    • One or more equations did not get rendered due to their size.
    instance ConvexCone.instInhabitedConvexCone (π•œ : Type u_1) {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] :
    Inhabited (ConvexCone π•œ E)
    Equations
    theorem ConvexCone.convex {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] (S : ConvexCone π•œ E) :
    Convex π•œ ↑S
    def ConvexCone.map {π•œ : Type u_1} {E : Type u_2} {F : Type u_3} [OrderedSemiring π•œ] [AddCommMonoid E] [AddCommMonoid F] [Module π•œ E] [Module π•œ F] (f : E β†’β‚—[π•œ] F) (S : ConvexCone π•œ E) :
    ConvexCone π•œ F

    The image of a convex cone under a π•œ-linear map is a convex cone.

    Equations
    • One or more equations did not get rendered due to their size.
    Instances For
      @[simp]
      theorem ConvexCone.coe_map {π•œ : Type u_1} {E : Type u_2} {F : Type u_3} [OrderedSemiring π•œ] [AddCommMonoid E] [AddCommMonoid F] [Module π•œ E] [Module π•œ F] (S : ConvexCone π•œ E) (f : E β†’β‚—[π•œ] F) :
      ↑(ConvexCone.map f S) = ↑f '' ↑S
      @[simp]
      theorem ConvexCone.mem_map {π•œ : Type u_1} {E : Type u_2} {F : Type u_3} [OrderedSemiring π•œ] [AddCommMonoid E] [AddCommMonoid F] [Module π•œ E] [Module π•œ F] {f : E β†’β‚—[π•œ] F} {S : ConvexCone π•œ E} {y : F} :
      y ∈ ConvexCone.map f S ↔ βˆƒ x, x ∈ S ∧ ↑f x = y
      theorem ConvexCone.map_map {π•œ : Type u_1} {E : Type u_2} {F : Type u_3} {G : Type u_4} [OrderedSemiring π•œ] [AddCommMonoid E] [AddCommMonoid F] [AddCommMonoid G] [Module π•œ E] [Module π•œ F] [Module π•œ G] (g : F β†’β‚—[π•œ] G) (f : E β†’β‚—[π•œ] F) (S : ConvexCone π•œ E) :
      @[simp]
      theorem ConvexCone.map_id {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] (S : ConvexCone π•œ E) :
      ConvexCone.map LinearMap.id S = S
      def ConvexCone.comap {π•œ : Type u_1} {E : Type u_2} {F : Type u_3} [OrderedSemiring π•œ] [AddCommMonoid E] [AddCommMonoid F] [Module π•œ E] [Module π•œ F] (f : E β†’β‚—[π•œ] F) (S : ConvexCone π•œ F) :
      ConvexCone π•œ E

      The preimage of a convex cone under a π•œ-linear map is a convex cone.

      Equations
      • One or more equations did not get rendered due to their size.
      Instances For
        @[simp]
        theorem ConvexCone.coe_comap {π•œ : Type u_1} {E : Type u_2} {F : Type u_3} [OrderedSemiring π•œ] [AddCommMonoid E] [AddCommMonoid F] [Module π•œ E] [Module π•œ F] (f : E β†’β‚—[π•œ] F) (S : ConvexCone π•œ F) :
        ↑(ConvexCone.comap f S) = ↑f ⁻¹' ↑S
        @[simp]
        theorem ConvexCone.comap_id {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] (S : ConvexCone π•œ E) :
        ConvexCone.comap LinearMap.id S = S
        theorem ConvexCone.comap_comap {π•œ : Type u_1} {E : Type u_2} {F : Type u_3} {G : Type u_4} [OrderedSemiring π•œ] [AddCommMonoid E] [AddCommMonoid F] [AddCommMonoid G] [Module π•œ E] [Module π•œ F] [Module π•œ G] (g : F β†’β‚—[π•œ] G) (f : E β†’β‚—[π•œ] F) (S : ConvexCone π•œ G) :
        @[simp]
        theorem ConvexCone.mem_comap {π•œ : Type u_1} {E : Type u_2} {F : Type u_3} [OrderedSemiring π•œ] [AddCommMonoid E] [AddCommMonoid F] [Module π•œ E] [Module π•œ F] {f : E β†’β‚—[π•œ] F} {S : ConvexCone π•œ F} {x : E} :
        theorem ConvexCone.smul_mem_iff {π•œ : Type u_1} {E : Type u_2} [LinearOrderedField π•œ] [AddCommMonoid E] [MulAction π•œ E] (S : ConvexCone π•œ E) {c : π•œ} (hc : 0 < c) {x : E} :
        theorem ConvexCone.to_orderedSMul {π•œ : Type u_1} {E : Type u_2} [LinearOrderedField π•œ] [OrderedAddCommGroup E] [Module π•œ E] (S : ConvexCone π•œ E) (h : βˆ€ (x y : E), x ≀ y ↔ y - x ∈ S) :
        OrderedSMul π•œ E

        Constructs an ordered module given an OrderedAddCommGroup, a cone, and a proof that the order relation is the one defined by the cone.

        Convex cones with extra properties #

        def ConvexCone.Pointed {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] (S : ConvexCone π•œ E) :

        A convex cone is pointed if it includes 0.

        Equations
        Instances For
          def ConvexCone.Blunt {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] (S : ConvexCone π•œ E) :

          A convex cone is blunt if it doesn't include 0.

          Equations
          Instances For
            theorem ConvexCone.pointed_iff_not_blunt {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] (S : ConvexCone π•œ E) :
            theorem ConvexCone.blunt_iff_not_pointed {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] (S : ConvexCone π•œ E) :
            theorem ConvexCone.Pointed.mono {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] {S : ConvexCone π•œ E} {T : ConvexCone π•œ E} (h : S ≀ T) :
            theorem ConvexCone.Blunt.anti {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [SMul π•œ E] {S : ConvexCone π•œ E} {T : ConvexCone π•œ E} (h : T ≀ S) :
            def ConvexCone.Flat {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommGroup E] [SMul π•œ E] (S : ConvexCone π•œ E) :

            A convex cone is flat if it contains some nonzero vector x and its opposite -x.

            Equations
            Instances For
              def ConvexCone.Salient {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommGroup E] [SMul π•œ E] (S : ConvexCone π•œ E) :

              A convex cone is salient if it doesn't include x and -x for any nonzero x.

              Equations
              Instances For
                theorem ConvexCone.salient_iff_not_flat {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommGroup E] [SMul π•œ E] (S : ConvexCone π•œ E) :
                theorem ConvexCone.Flat.mono {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommGroup E] [SMul π•œ E] {S : ConvexCone π•œ E} {T : ConvexCone π•œ E} (h : S ≀ T) :
                theorem ConvexCone.Salient.anti {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommGroup E] [SMul π•œ E] {S : ConvexCone π•œ E} {T : ConvexCone π•œ E} (h : T ≀ S) :
                theorem ConvexCone.Flat.pointed {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommGroup E] [SMul π•œ E] {S : ConvexCone π•œ E} (hS : ConvexCone.Flat S) :

                A flat cone is always pointed (contains 0).

                theorem ConvexCone.Blunt.salient {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommGroup E] [SMul π•œ E] {S : ConvexCone π•œ E} :

                A blunt cone (one not containing 0) is always salient.

                def ConvexCone.toPreorder {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommGroup E] [SMul π•œ E] (S : ConvexCone π•œ E) (h₁ : ConvexCone.Pointed S) :

                A pointed convex cone defines a preorder.

                Equations
                Instances For
                  def ConvexCone.toPartialOrder {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommGroup E] [SMul π•œ E] (S : ConvexCone π•œ E) (h₁ : ConvexCone.Pointed S) (hβ‚‚ : ConvexCone.Salient S) :

                  A pointed and salient cone defines a partial order.

                  Equations
                  Instances For
                    def ConvexCone.toOrderedAddCommGroup {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommGroup E] [SMul π•œ E] (S : ConvexCone π•œ E) (h₁ : ConvexCone.Pointed S) (hβ‚‚ : ConvexCone.Salient S) :

                    A pointed and salient cone defines an OrderedAddCommGroup.

                    Equations
                    • One or more equations did not get rendered due to their size.
                    Instances For
                      Equations
                      • One or more equations did not get rendered due to their size.
                      @[simp]
                      theorem ConvexCone.mem_zero {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] (x : E) :
                      x ∈ 0 ↔ x = 0
                      @[simp]
                      theorem ConvexCone.coe_zero {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] :
                      ↑0 = 0
                      theorem ConvexCone.pointed_zero {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] :
                      instance ConvexCone.instAdd {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] :
                      Add (ConvexCone π•œ E)
                      Equations
                      • One or more equations did not get rendered due to their size.
                      @[simp]
                      theorem ConvexCone.mem_add {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] {K₁ : ConvexCone π•œ E} {Kβ‚‚ : ConvexCone π•œ E} {a : E} :
                      a ∈ K₁ + Kβ‚‚ ↔ βˆƒ x y, x ∈ K₁ ∧ y ∈ Kβ‚‚ ∧ x + y = a
                      instance ConvexCone.instAddZeroClass {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] :
                      Equations
                      instance ConvexCone.instAddCommSemigroup {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] :
                      Equations

                      Submodules are cones #

                      def Submodule.toConvexCone {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] (S : Submodule π•œ E) :
                      ConvexCone π•œ E

                      Every submodule is trivially a convex cone.

                      Equations
                      Instances For
                        @[simp]
                        theorem Submodule.coe_toConvexCone {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] (S : Submodule π•œ E) :
                        ↑(Submodule.toConvexCone S) = ↑S
                        @[simp]
                        theorem Submodule.mem_toConvexCone {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] {x : E} {S : Submodule π•œ E} :
                        @[simp]
                        theorem Submodule.toConvexCone_le_iff {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] {S : Submodule π•œ E} {T : Submodule π•œ E} :
                        @[simp]
                        theorem Submodule.toConvexCone_bot {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] :
                        @[simp]
                        theorem Submodule.toConvexCone_top {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] :
                        @[simp]
                        theorem Submodule.toConvexCone_inf {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] (S : Submodule π•œ E) (T : Submodule π•œ E) :
                        @[simp]
                        theorem Submodule.pointed_toConvexCone {π•œ : Type u_1} {E : Type u_2} [OrderedSemiring π•œ] [AddCommMonoid E] [Module π•œ E] (S : Submodule π•œ E) :

                        Positive cone of an ordered module #

                        def ConvexCone.positive (π•œ : Type u_1) (E : Type u_2) [OrderedSemiring π•œ] [OrderedAddCommGroup E] [Module π•œ E] [OrderedSMul π•œ E] :
                        ConvexCone π•œ E

                        The positive cone is the convex cone formed by the set of nonnegative elements in an ordered module.

                        Equations
                        • One or more equations did not get rendered due to their size.
                        Instances For
                          @[simp]
                          theorem ConvexCone.mem_positive (π•œ : Type u_1) (E : Type u_2) [OrderedSemiring π•œ] [OrderedAddCommGroup E] [Module π•œ E] [OrderedSMul π•œ E] {x : E} :
                          @[simp]
                          theorem ConvexCone.coe_positive (π•œ : Type u_1) (E : Type u_2) [OrderedSemiring π•œ] [OrderedAddCommGroup E] [Module π•œ E] [OrderedSMul π•œ E] :
                          ↑(ConvexCone.positive π•œ E) = Set.Ici 0
                          theorem ConvexCone.salient_positive (π•œ : Type u_1) (E : Type u_2) [OrderedSemiring π•œ] [OrderedAddCommGroup E] [Module π•œ E] [OrderedSMul π•œ E] :

                          The positive cone of an ordered module is always salient.

                          theorem ConvexCone.pointed_positive (π•œ : Type u_1) (E : Type u_2) [OrderedSemiring π•œ] [OrderedAddCommGroup E] [Module π•œ E] [OrderedSMul π•œ E] :

                          The positive cone of an ordered module is always pointed.

                          def ConvexCone.strictlyPositive (π•œ : Type u_1) (E : Type u_2) [OrderedSemiring π•œ] [OrderedAddCommGroup E] [Module π•œ E] [OrderedSMul π•œ E] :
                          ConvexCone π•œ E

                          The cone of strictly positive elements.

                          Note that this naming diverges from the mathlib convention of pos and nonneg due to "positive cone" (ConvexCone.positive) being established terminology for the non-negative elements.

                          Equations
                          • One or more equations did not get rendered due to their size.
                          Instances For
                            @[simp]
                            theorem ConvexCone.mem_strictlyPositive (π•œ : Type u_1) (E : Type u_2) [OrderedSemiring π•œ] [OrderedAddCommGroup E] [Module π•œ E] [OrderedSMul π•œ E] {x : E} :
                            @[simp]
                            theorem ConvexCone.coe_strictlyPositive (π•œ : Type u_1) (E : Type u_2) [OrderedSemiring π•œ] [OrderedAddCommGroup E] [Module π•œ E] [OrderedSMul π•œ E] :
                            theorem ConvexCone.positive_le_strictlyPositive (π•œ : Type u_1) (E : Type u_2) [OrderedSemiring π•œ] [OrderedAddCommGroup E] [Module π•œ E] [OrderedSMul π•œ E] :
                            theorem ConvexCone.salient_strictlyPositive (π•œ : Type u_1) (E : Type u_2) [OrderedSemiring π•œ] [OrderedAddCommGroup E] [Module π•œ E] [OrderedSMul π•œ E] :

                            The strictly positive cone of an ordered module is always salient.

                            theorem ConvexCone.blunt_strictlyPositive (π•œ : Type u_1) (E : Type u_2) [OrderedSemiring π•œ] [OrderedAddCommGroup E] [Module π•œ E] [OrderedSMul π•œ E] :

                            The strictly positive cone of an ordered module is always blunt.

                            Cone over a convex set #

                            def Convex.toCone {π•œ : Type u_1} {E : Type u_2} [LinearOrderedField π•œ] [AddCommGroup E] [Module π•œ E] (s : Set E) (hs : Convex π•œ s) :
                            ConvexCone π•œ E

                            The set of vectors proportional to those in a convex set forms a convex cone.

                            Equations
                            • One or more equations did not get rendered due to their size.
                            Instances For
                              theorem Convex.mem_toCone {π•œ : Type u_1} {E : Type u_2} [LinearOrderedField π•œ] [AddCommGroup E] [Module π•œ E] {s : Set E} (hs : Convex π•œ s) {x : E} :
                              x ∈ Convex.toCone s hs ↔ βˆƒ c, 0 < c ∧ βˆƒ y, y ∈ s ∧ c β€’ y = x
                              theorem Convex.mem_toCone' {π•œ : Type u_1} {E : Type u_2} [LinearOrderedField π•œ] [AddCommGroup E] [Module π•œ E] {s : Set E} (hs : Convex π•œ s) {x : E} :
                              x ∈ Convex.toCone s hs ↔ βˆƒ c, 0 < c ∧ c β€’ x ∈ s
                              theorem Convex.subset_toCone {π•œ : Type u_1} {E : Type u_2} [LinearOrderedField π•œ] [AddCommGroup E] [Module π•œ E] {s : Set E} (hs : Convex π•œ s) :
                              s βŠ† ↑(Convex.toCone s hs)
                              theorem Convex.toCone_isLeast {π•œ : Type u_1} {E : Type u_2} [LinearOrderedField π•œ] [AddCommGroup E] [Module π•œ E] {s : Set E} (hs : Convex π•œ s) :
                              IsLeast {t | s βŠ† ↑t} (Convex.toCone s hs)

                              hs.toCone s is the least cone that includes s.

                              theorem Convex.toCone_eq_sInf {π•œ : Type u_1} {E : Type u_2} [LinearOrderedField π•œ] [AddCommGroup E] [Module π•œ E] {s : Set E} (hs : Convex π•œ s) :
                              Convex.toCone s hs = sInf {t | s βŠ† ↑t}
                              theorem convexHull_toCone_isLeast {π•œ : Type u_1} {E : Type u_2} [LinearOrderedField π•œ] [AddCommGroup E] [Module π•œ E] (s : Set E) :
                              IsLeast {t | s βŠ† ↑t} (Convex.toCone (↑(convexHull π•œ) s) (_ : Convex π•œ (↑(convexHull π•œ) s)))
                              theorem convexHull_toCone_eq_sInf {π•œ : Type u_1} {E : Type u_2} [LinearOrderedField π•œ] [AddCommGroup E] [Module π•œ E] (s : Set E) :
                              Convex.toCone (↑(convexHull π•œ) s) (_ : Convex π•œ (↑(convexHull π•œ) s)) = sInf {t | s βŠ† ↑t}

                              M. Riesz extension theorem #

                              Given a convex cone s in a vector space E, a submodule p, and a linear f : p β†’ ℝ, assume that f is nonnegative on p ∩ s and p + s = E. Then there exists a globally defined linear function g : E β†’ ℝ that agrees with f on p, and is nonnegative on s.

                              We prove this theorem using Zorn's lemma. RieszExtension.step is the main part of the proof. It says that if the domain p of f is not the whole space, then f can be extended to a larger subspace p βŠ” span ℝ {y} without breaking the non-negativity condition.

                              In RieszExtension.exists_top we use Zorn's lemma to prove that we can extend f to a linear map g on ⊀ : Submodule E. Mathematically this is the same as a linear map on E but in Lean ⊀ : Submodule E is isomorphic but is not equal to E. In riesz_extension we use this isomorphism to prove the theorem.

                              theorem RieszExtension.step {E : Type u_2} [AddCommGroup E] [Module ℝ E] (s : ConvexCone ℝ E) (f : E β†’β‚—.[ℝ] ℝ) (nonneg : βˆ€ (x : { x // x ∈ f.domain }), ↑x ∈ s β†’ 0 ≀ ↑f x) (dense : βˆ€ (y : E), βˆƒ x, ↑x + y ∈ s) (hdom : f.domain β‰  ⊀) :
                              βˆƒ g, f < g ∧ βˆ€ (x : { x // x ∈ g.domain }), ↑x ∈ s β†’ 0 ≀ ↑g x

                              Induction step in M. Riesz extension theorem. Given a convex cone s in a vector space E, a partially defined linear map f : f.domain β†’ ℝ, assume that f is nonnegative on f.domain ∩ p and p + s = E. If f is not defined on the whole E, then we can extend it to a larger submodule without breaking the non-negativity condition.

                              theorem RieszExtension.exists_top {E : Type u_2} [AddCommGroup E] [Module ℝ E] (s : ConvexCone ℝ E) (p : E β†’β‚—.[ℝ] ℝ) (hp_nonneg : βˆ€ (x : { x // x ∈ p.domain }), ↑x ∈ s β†’ 0 ≀ ↑p x) (hp_dense : βˆ€ (y : E), βˆƒ x, ↑x + y ∈ s) :
                              βˆƒ q, q β‰₯ p ∧ q.domain = ⊀ ∧ βˆ€ (x : { x // x ∈ q.domain }), ↑x ∈ s β†’ 0 ≀ ↑q x
                              theorem riesz_extension {E : Type u_2} [AddCommGroup E] [Module ℝ E] (s : ConvexCone ℝ E) (f : E β†’β‚—.[ℝ] ℝ) (nonneg : βˆ€ (x : { x // x ∈ f.domain }), ↑x ∈ s β†’ 0 ≀ ↑f x) (dense : βˆ€ (y : E), βˆƒ x, ↑x + y ∈ s) :
                              βˆƒ g, (βˆ€ (x : { x // x ∈ f.domain }), ↑g ↑x = ↑f x) ∧ βˆ€ (x : E), x ∈ s β†’ 0 ≀ ↑g x

                              M. Riesz extension theorem: given a convex cone s in a vector space E, a submodule p, and a linear f : p β†’ ℝ, assume that f is nonnegative on p ∩ s and p + s = E. Then there exists a globally defined linear function g : E β†’ ℝ that agrees with f on p, and is nonnegative on s.

                              theorem exists_extension_of_le_sublinear {E : Type u_2} [AddCommGroup E] [Module ℝ E] (f : E β†’β‚—.[ℝ] ℝ) (N : E β†’ ℝ) (N_hom : βˆ€ (c : ℝ), 0 < c β†’ βˆ€ (x : E), N (c β€’ x) = c * N x) (N_add : βˆ€ (x y : E), N (x + y) ≀ N x + N y) (hf : βˆ€ (x : { x // x ∈ f.domain }), ↑f x ≀ N ↑x) :
                              βˆƒ g, (βˆ€ (x : { x // x ∈ f.domain }), ↑g ↑x = ↑f x) ∧ βˆ€ (x : E), ↑g x ≀ N x

                              Hahn-Banach theorem: if N : E β†’ ℝ is a sublinear map, f is a linear map defined on a subspace of E, and f x ≀ N x for all x in the domain of f, then f can be extended to the whole space to a linear map g such that g x ≀ N x for all x.