Documentation

Mathlib.Analysis.NormedSpace.FiniteDimension

Finite dimensional normed spaces over complete fields #

Over a complete nontrivially normed field, in finite dimension, all norms are equivalent and all linear maps are continuous. Moreover, a finite-dimensional subspace is always complete and closed.

Main results: #

Implementation notes #

The fact that all norms are equivalent is not written explicitly, as it would mean having two norms on a single space, which is not the way type classes work. However, if one has a finite-dimensional vector space E with a norm, and a copy E' of this type with another norm, then the identities from E to E' and from E'to E are continuous thanks to LinearMap.continuous_of_finiteDimensional. This gives the desired norm equivalence.

def LinearIsometry.toLinearIsometryEquiv {F : Type u_2} {E₁ : Type u_3} [SeminormedAddCommGroup F] [NormedAddCommGroup E₁] {R₁ : Type u_4} [Field R₁] [Module R₁ E₁] [Module R₁ F] [FiniteDimensional R₁ E₁] [FiniteDimensional R₁ F] (li : E₁ β†’β‚—α΅’[R₁] F) (h : FiniteDimensional.finrank R₁ E₁ = FiniteDimensional.finrank R₁ F) :
E₁ ≃ₗᡒ[R₁] F

A linear isometry between finite dimensional spaces of equal dimension can be upgraded to a linear isometry equivalence.

Equations
  • One or more equations did not get rendered due to their size.
Instances For
    @[simp]
    theorem LinearIsometry.coe_toLinearIsometryEquiv {F : Type u_2} {E₁ : Type u_3} [SeminormedAddCommGroup F] [NormedAddCommGroup E₁] {R₁ : Type u_4} [Field R₁] [Module R₁ E₁] [Module R₁ F] [FiniteDimensional R₁ E₁] [FiniteDimensional R₁ F] (li : E₁ β†’β‚—α΅’[R₁] F) (h : FiniteDimensional.finrank R₁ E₁ = FiniteDimensional.finrank R₁ F) :
    @[simp]
    theorem LinearIsometry.toLinearIsometryEquiv_apply {F : Type u_2} {E₁ : Type u_3} [SeminormedAddCommGroup F] [NormedAddCommGroup E₁] {R₁ : Type u_4} [Field R₁] [Module R₁ E₁] [Module R₁ F] [FiniteDimensional R₁ E₁] [FiniteDimensional R₁ F] (li : E₁ β†’β‚—α΅’[R₁] F) (h : FiniteDimensional.finrank R₁ E₁ = FiniteDimensional.finrank R₁ F) (x : E₁) :
    ↑(LinearIsometry.toLinearIsometryEquiv li h) x = ↑li x
    def AffineIsometry.toAffineIsometryEquiv {π•œ : Type u_1} {V₁ : Type u_2} {Vβ‚‚ : Type u_3} {P₁ : Type u_4} {Pβ‚‚ : Type u_5} [NormedField π•œ] [NormedAddCommGroup V₁] [SeminormedAddCommGroup Vβ‚‚] [NormedSpace π•œ V₁] [NormedSpace π•œ Vβ‚‚] [MetricSpace P₁] [PseudoMetricSpace Pβ‚‚] [NormedAddTorsor V₁ P₁] [NormedAddTorsor Vβ‚‚ Pβ‚‚] [FiniteDimensional π•œ V₁] [FiniteDimensional π•œ Vβ‚‚] [Inhabited P₁] (li : P₁ →ᡃⁱ[π•œ] Pβ‚‚) (h : FiniteDimensional.finrank π•œ V₁ = FiniteDimensional.finrank π•œ Vβ‚‚) :
    P₁ ≃ᡃⁱ[π•œ] Pβ‚‚

    An affine isometry between finite dimensional spaces of equal dimension can be upgraded to an affine isometry equivalence.

    Equations
    • One or more equations did not get rendered due to their size.
    Instances For
      @[simp]
      theorem AffineIsometry.coe_toAffineIsometryEquiv {π•œ : Type u_1} {V₁ : Type u_2} {Vβ‚‚ : Type u_3} {P₁ : Type u_4} {Pβ‚‚ : Type u_5} [NormedField π•œ] [NormedAddCommGroup V₁] [SeminormedAddCommGroup Vβ‚‚] [NormedSpace π•œ V₁] [NormedSpace π•œ Vβ‚‚] [MetricSpace P₁] [PseudoMetricSpace Pβ‚‚] [NormedAddTorsor V₁ P₁] [NormedAddTorsor Vβ‚‚ Pβ‚‚] [FiniteDimensional π•œ V₁] [FiniteDimensional π•œ Vβ‚‚] [Inhabited P₁] (li : P₁ →ᡃⁱ[π•œ] Pβ‚‚) (h : FiniteDimensional.finrank π•œ V₁ = FiniteDimensional.finrank π•œ Vβ‚‚) :
      @[simp]
      theorem AffineIsometry.toAffineIsometryEquiv_apply {π•œ : Type u_1} {V₁ : Type u_2} {Vβ‚‚ : Type u_3} {P₁ : Type u_4} {Pβ‚‚ : Type u_5} [NormedField π•œ] [NormedAddCommGroup V₁] [SeminormedAddCommGroup Vβ‚‚] [NormedSpace π•œ V₁] [NormedSpace π•œ Vβ‚‚] [MetricSpace P₁] [PseudoMetricSpace Pβ‚‚] [NormedAddTorsor V₁ P₁] [NormedAddTorsor Vβ‚‚ Pβ‚‚] [FiniteDimensional π•œ V₁] [FiniteDimensional π•œ Vβ‚‚] [Inhabited P₁] (li : P₁ →ᡃⁱ[π•œ] Pβ‚‚) (h : FiniteDimensional.finrank π•œ V₁ = FiniteDimensional.finrank π•œ Vβ‚‚) (x : P₁) :
      ↑(AffineIsometry.toAffineIsometryEquiv li h) x = ↑li x
      theorem AffineMap.continuous_of_finiteDimensional {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] {F : Type w} [NormedAddCommGroup F] [NormedSpace π•œ F] [CompleteSpace π•œ] {PE : Type u_1} {PF : Type u_2} [MetricSpace PE] [NormedAddTorsor E PE] [MetricSpace PF] [NormedAddTorsor F PF] [FiniteDimensional π•œ E] (f : PE →ᡃ[π•œ] PF) :
      Continuous ↑f
      theorem AffineEquiv.continuous_of_finiteDimensional {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] {F : Type w} [NormedAddCommGroup F] [NormedSpace π•œ F] [CompleteSpace π•œ] {PE : Type u_1} {PF : Type u_2} [MetricSpace PE] [NormedAddTorsor E PE] [MetricSpace PF] [NormedAddTorsor F PF] [FiniteDimensional π•œ E] (f : PE ≃ᡃ[π•œ] PF) :
      Continuous ↑f
      def AffineEquiv.toHomeomorphOfFiniteDimensional {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] {F : Type w} [NormedAddCommGroup F] [NormedSpace π•œ F] [CompleteSpace π•œ] {PE : Type u_1} {PF : Type u_2} [MetricSpace PE] [NormedAddTorsor E PE] [MetricSpace PF] [NormedAddTorsor F PF] [FiniteDimensional π•œ E] (f : PE ≃ᡃ[π•œ] PF) :

      Reinterpret an affine equivalence as a homeomorphism.

      Equations
      Instances For
        @[simp]
        theorem AffineEquiv.coe_toHomeomorphOfFiniteDimensional {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] {F : Type w} [NormedAddCommGroup F] [NormedSpace π•œ F] [CompleteSpace π•œ] {PE : Type u_1} {PF : Type u_2} [MetricSpace PE] [NormedAddTorsor E PE] [MetricSpace PF] [NormedAddTorsor F PF] [FiniteDimensional π•œ E] (f : PE ≃ᡃ[π•œ] PF) :
        @[simp]
        theorem AffineEquiv.coe_toHomeomorphOfFiniteDimensional_symm {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] {F : Type w} [NormedAddCommGroup F] [NormedSpace π•œ F] [CompleteSpace π•œ] {PE : Type u_1} {PF : Type u_2} [MetricSpace PE] [NormedAddTorsor E PE] [MetricSpace PF] [NormedAddTorsor F PF] [FiniteDimensional π•œ E] (f : PE ≃ᡃ[π•œ] PF) :
        @[irreducible]

        Any K-Lipschitz map from a subset s of a metric space Ξ± to a finite-dimensional real vector space E' can be extended to a Lipschitz map on the whole space Ξ±, with a slightly worse constant C * K where C only depends on E'. We record a working value for this constant C as lipschitzExtensionConstant E'.

        Equations
        Instances For
          theorem LipschitzOnWith.extend_finite_dimension {Ξ± : Type u_1} [PseudoMetricSpace Ξ±] {E' : Type u_2} [NormedAddCommGroup E'] [NormedSpace ℝ E'] [FiniteDimensional ℝ E'] {s : Set Ξ±} {f : Ξ± β†’ E'} {K : NNReal} (hf : LipschitzOnWith K f s) :

          Any K-Lipschitz map from a subset s of a metric space Ξ± to a finite-dimensional real vector space E' can be extended to a Lipschitz map on the whole space Ξ±, with a slightly worse constant lipschitzExtensionConstant E' * K.

          theorem LinearMap.exists_antilipschitzWith {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] {F : Type w} [NormedAddCommGroup F] [NormedSpace π•œ F] [CompleteSpace π•œ] [FiniteDimensional π•œ E] (f : E β†’β‚—[π•œ] F) (hf : LinearMap.ker f = βŠ₯) :
          βˆƒ K, K > 0 ∧ AntilipschitzWith K ↑f
          theorem LinearIndependent.eventually {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] [CompleteSpace π•œ] {ΞΉ : Type u_1} [Finite ΞΉ] {f : ΞΉ β†’ E} (hf : LinearIndependent π•œ f) :
          βˆ€αΆ  (g : ΞΉ β†’ E) in nhds f, LinearIndependent π•œ g
          theorem isOpen_setOf_linearIndependent {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] [CompleteSpace π•œ] {ΞΉ : Type u_1} [Finite ΞΉ] :
          IsOpen {f | LinearIndependent π•œ f}
          theorem isOpen_setOf_nat_le_rank {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] {F : Type w} [NormedAddCommGroup F] [NormedSpace π•œ F] [CompleteSpace π•œ] (n : β„•) :
          IsOpen {f | ↑n ≀ LinearMap.rank ↑f}
          theorem Basis.op_nnnorm_le {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] {F : Type w} [NormedAddCommGroup F] [NormedSpace π•œ F] [CompleteSpace π•œ] {ΞΉ : Type u_1} [Fintype ΞΉ] (v : Basis ΞΉ π•œ E) {u : E β†’L[π•œ] F} (M : NNReal) (hu : βˆ€ (i : ΞΉ), ‖↑u (↑v i)β€–β‚Š ≀ M) :
          theorem Basis.op_norm_le {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] {F : Type w} [NormedAddCommGroup F] [NormedSpace π•œ F] [CompleteSpace π•œ] {ΞΉ : Type u_1} [Fintype ΞΉ] (v : Basis ΞΉ π•œ E) {u : E β†’L[π•œ] F} {M : ℝ} (hM : 0 ≀ M) (hu : βˆ€ (i : ΞΉ), ‖↑u (↑v i)β€– ≀ M) :
          theorem Basis.exists_op_nnnorm_le {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] {F : Type w} [NormedAddCommGroup F] [NormedSpace π•œ F] [CompleteSpace π•œ] {ΞΉ : Type u_1} [Finite ΞΉ] (v : Basis ΞΉ π•œ E) :
          βˆƒ C, C > 0 ∧ βˆ€ {u : E β†’L[π•œ] F} (M : NNReal), (βˆ€ (i : ΞΉ), ‖↑u (↑v i)β€–β‚Š ≀ M) β†’ β€–uβ€–β‚Š ≀ C * M

          A weaker version of Basis.op_nnnorm_le that abstracts away the value of C.

          theorem Basis.exists_op_norm_le {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] {F : Type w} [NormedAddCommGroup F] [NormedSpace π•œ F] [CompleteSpace π•œ] {ΞΉ : Type u_1} [Finite ΞΉ] (v : Basis ΞΉ π•œ E) :
          βˆƒ C, C > 0 ∧ βˆ€ {u : E β†’L[π•œ] F} {M : ℝ}, 0 ≀ M β†’ (βˆ€ (i : ΞΉ), ‖↑u (↑v i)β€– ≀ M) β†’ β€–uβ€– ≀ C * M

          A weaker version of Basis.op_norm_le that abstracts away the value of C.

          theorem AffineSubspace.closed_of_finiteDimensional {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] [CompleteSpace π•œ] {P : Type u_1} [MetricSpace P] [NormedAddTorsor E P] (s : AffineSubspace π•œ P) [FiniteDimensional π•œ { x // x ∈ AffineSubspace.direction s }] :
          IsClosed ↑s
          theorem exists_norm_le_le_norm_sub_of_finset {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] [CompleteSpace π•œ] {c : π•œ} (hc : 1 < β€–cβ€–) {R : ℝ} (hR : β€–cβ€– < R) (h : Β¬FiniteDimensional π•œ E) (s : Finset E) :
          βˆƒ x, β€–xβ€– ≀ R ∧ βˆ€ (y : E), y ∈ s β†’ 1 ≀ β€–y - xβ€–

          In an infinite dimensional space, given a finite number of points, one may find a point with norm at most R which is at distance at least 1 of all these points.

          theorem exists_seq_norm_le_one_le_norm_sub' {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] [CompleteSpace π•œ] {c : π•œ} (hc : 1 < β€–cβ€–) {R : ℝ} (hR : β€–cβ€– < R) (h : Β¬FiniteDimensional π•œ E) :
          βˆƒ f, (βˆ€ (n : β„•), β€–f nβ€– ≀ R) ∧ βˆ€ (m n : β„•), m β‰  n β†’ 1 ≀ β€–f m - f nβ€–

          In an infinite-dimensional normed space, there exists a sequence of points which are all bounded by R and at distance at least 1. For a version not assuming c and R, see exists_seq_norm_le_one_le_norm_sub.

          theorem exists_seq_norm_le_one_le_norm_sub {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] [CompleteSpace π•œ] (h : Β¬FiniteDimensional π•œ E) :
          βˆƒ R f, 1 < R ∧ (βˆ€ (n : β„•), β€–f nβ€– ≀ R) ∧ βˆ€ (m n : β„•), m β‰  n β†’ 1 ≀ β€–f m - f nβ€–
          theorem finiteDimensional_of_isCompact_closedBallβ‚€ (π•œ : Type u) [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] [CompleteSpace π•œ] {r : ℝ} (rpos : 0 < r) (h : IsCompact (Metric.closedBall 0 r)) :

          Riesz's theorem: if a closed ball with center zero of positive radius is compact in a vector space, then the space is finite-dimensional.

          theorem finiteDimensional_of_isCompact_closedBall (π•œ : Type u) [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] [CompleteSpace π•œ] {r : ℝ} (rpos : 0 < r) {c : E} (h : IsCompact (Metric.closedBall c r)) :

          Riesz's theorem: if a closed ball of positive radius is compact in a vector space, then the space is finite-dimensional.

          Riesz's theorem: a locally compact normed vector space is finite-dimensional.

          theorem HasCompactSupport.eq_zero_or_finiteDimensional (π•œ : Type u) [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] [CompleteSpace π•œ] {X : Type u_1} [TopologicalSpace X] [Zero X] [T2Space X] {f : E β†’ X} (hf : HasCompactSupport f) (h'f : Continuous f) :
          f = 0 ∨ FiniteDimensional π•œ E

          If a function has compact support, then either the function is trivial or the space is finite-dimensional.

          theorem HasCompactMulSupport.eq_one_or_finiteDimensional (π•œ : Type u) [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] [CompleteSpace π•œ] {X : Type u_1} [TopologicalSpace X] [One X] [T2Space X] {f : E β†’ X} (hf : HasCompactMulSupport f) (h'f : Continuous f) :
          f = 1 ∨ FiniteDimensional π•œ E

          If a function has compact multiplicative support, then either the function is trivial or the space is finite-dimensional.

          A locally compact normed vector space is proper.

          def ContinuousLinearEquiv.piRing {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] [CompleteSpace π•œ] (ΞΉ : Type u_1) [Fintype ΞΉ] [DecidableEq ΞΉ] :
          ((ΞΉ β†’ π•œ) β†’L[π•œ] E) ≃L[π•œ] ΞΉ β†’ E

          Continuous linear equivalence between continuous linear functions π•œβΏ β†’ E and Eⁿ. The spaces π•œβΏ and Eⁿ are represented as ΞΉ β†’ π•œ and ΞΉ β†’ E, respectively, where ΞΉ is a finite type.

          Equations
          • One or more equations did not get rendered due to their size.
          Instances For
            theorem continuousOn_clm_apply {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] {F : Type w} [NormedAddCommGroup F] [NormedSpace π•œ F] [CompleteSpace π•œ] {X : Type u_1} [TopologicalSpace X] [FiniteDimensional π•œ E] {f : X β†’ E β†’L[π•œ] F} {s : Set X} :
            ContinuousOn f s ↔ βˆ€ (y : E), ContinuousOn (fun x => ↑(f x) y) s

            A family of continuous linear maps is continuous on s if all its applications are.

            theorem continuous_clm_apply {π•œ : Type u} [NontriviallyNormedField π•œ] {E : Type v} [NormedAddCommGroup E] [NormedSpace π•œ E] {F : Type w} [NormedAddCommGroup F] [NormedSpace π•œ F] [CompleteSpace π•œ] {X : Type u_1} [TopologicalSpace X] [FiniteDimensional π•œ E] {f : X β†’ E β†’L[π•œ] F} :
            Continuous f ↔ βˆ€ (y : E), Continuous fun x => ↑(f x) y
            theorem FiniteDimensional.proper (π•œ : Type u) [NontriviallyNormedField π•œ] (E : Type v) [NormedAddCommGroup E] [NormedSpace π•œ E] [LocallyCompactSpace π•œ] [FiniteDimensional π•œ E] :

            Any finite-dimensional vector space over a locally compact field is proper. We do not register this as an instance to avoid an instance loop when trying to prove the properness of π•œ, and the search for π•œ as an unknown metavariable. Declare the instance explicitly when needed.

            A submodule of a locally compact space over a complete field is also locally compact (and even proper).

            Equations
            • One or more equations did not get rendered due to their size.
            theorem exists_mem_frontier_infDist_compl_eq_dist {E : Type u_1} [NormedAddCommGroup E] [NormedSpace ℝ E] [FiniteDimensional ℝ E] {x : E} {s : Set E} (hx : x ∈ s) (hs : s β‰  Set.univ) :

            If E is a finite dimensional normed real vector space, x : E, and s is a neighborhood of x that is not equal to the whole space, then there exists a point y ∈ frontier s at distance Metric.infDist x sᢜ from x. See also IsCompact.exists_mem_frontier_infDist_compl_eq_dist.

            If K is a compact set in a nontrivial real normed space and x ∈ K, then there exists a point y of the boundary of K at distance Metric.infDist x Kᢜ from x. See also exists_mem_frontier_infDist_compl_eq_dist.

            theorem summable_norm_iff {Ξ± : Type u_1} {E : Type u_2} [NormedAddCommGroup E] [NormedSpace ℝ E] [FiniteDimensional ℝ E] {f : Ξ± β†’ E} :

            In a finite dimensional vector space over ℝ, the series βˆ‘ x, β€–f xβ€– is unconditionally summable if and only if the series βˆ‘ x, f x is unconditionally summable. One implication holds in any complete normed space, while the other holds only in finite dimensional spaces.

            theorem summable_of_isBigO' {ΞΉ : Type u_1} {E : Type u_2} {F : Type u_3} [NormedAddCommGroup E] [CompleteSpace E] [NormedAddCommGroup F] [NormedSpace ℝ F] [FiniteDimensional ℝ F] {f : ΞΉ β†’ E} {g : ΞΉ β†’ F} (hg : Summable g) (h : f =O[Filter.cofinite] g) :
            theorem summable_of_isBigO_nat' {E : Type u_1} {F : Type u_2} [NormedAddCommGroup E] [CompleteSpace E] [NormedAddCommGroup F] [NormedSpace ℝ F] [FiniteDimensional ℝ F] {f : β„• β†’ E} {g : β„• β†’ F} (hg : Summable g) (h : f =O[Filter.atTop] g) :
            theorem summable_of_isEquivalent {ΞΉ : Type u_1} {E : Type u_2} [NormedAddCommGroup E] [NormedSpace ℝ E] [FiniteDimensional ℝ E] {f : ΞΉ β†’ E} {g : ΞΉ β†’ E} (hg : Summable g) (h : Asymptotics.IsEquivalent Filter.cofinite f g) :
            theorem summable_of_isEquivalent_nat {E : Type u_1} [NormedAddCommGroup E] [NormedSpace ℝ E] [FiniteDimensional ℝ E] {f : β„• β†’ E} {g : β„• β†’ E} (hg : Summable g) (h : Asymptotics.IsEquivalent Filter.atTop f g) :
            theorem IsEquivalent.summable_iff {ΞΉ : Type u_1} {E : Type u_2} [NormedAddCommGroup E] [NormedSpace ℝ E] [FiniteDimensional ℝ E] {f : ΞΉ β†’ E} {g : ΞΉ β†’ E} (h : Asymptotics.IsEquivalent Filter.cofinite f g) :