From 6e8d2a2b9d658a6b3839d979513ce8e2fd23f4f1 Mon Sep 17 00:00:00 2001 From: Antoine Chambert-Loir Date: Wed, 5 Jun 2024 18:04:13 +0200 Subject: [PATCH 1/3] some attempt on PolynomialMap --- DividedPowers/DPAlgebra/PolynomialMap.lean | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/DividedPowers/DPAlgebra/PolynomialMap.lean b/DividedPowers/DPAlgebra/PolynomialMap.lean index 1ea429a..f73c9be 100644 --- a/DividedPowers/DPAlgebra/PolynomialMap.lean +++ b/DividedPowers/DPAlgebra/PolynomialMap.lean @@ -82,8 +82,25 @@ theorem gamma_mem_grade (n : ℕ) (S : Type*) [CommRing S] [Algebra R S] (m : S obtain ⟨y', hy'⟩ := hy simp only [LinearMap.mem_range] -- we need the graded structure on the base change of a graded algebra + rw [← hx', ← hy'] + /- more precisely, we have multiplication + grade R M k × grade R M l → grade R M (k + l) + induced by multiplication of DividedPowerAlgebra R M + thanks to `SetLike.GradedMul.mul_mem` + and we want to base change this bilinear map to + S ⊗[R] grade R M k × S ⊗[R] grade R M l → S⊗[R] grade R M (k + l) + -/ sorry +example (A : Type*) [CommRing A] (M N P : Type*) [AddCommGroup M] [Module A M] + [AddCommGroup N] [Module A N] [AddCommGroup P] [Module A P] + (Φ : M →ₗ[A] N →ₗ[A] P) + (R : Type*) [CommRing R] [Algebra A R] : + R ⊗[A] M →ₗ[R] R ⊗[A] N →ₗ[R] R ⊗[A] P := by + have := LinearMap.baseChange R Φ + apply LinearMap.comp ?_ this + have := LinearMap.tensorProduct A R N P + /- to do this, it seems that we have to understand polynomial maps valued into a submodule (in this case, it is a direct factor, so it will exactly correspond to polynomial maps all of which evaluations From 1fc3af2cc728a86c67604456e1b619dc657cdd36 Mon Sep 17 00:00:00 2001 From: Antoine Chambert-Loir Date: Wed, 5 Jun 2024 18:09:56 +0200 Subject: [PATCH 2/3] small attempts on PolynomialMap --- DividedPowers/DPAlgebra/PolynomialMap.lean | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/DividedPowers/DPAlgebra/PolynomialMap.lean b/DividedPowers/DPAlgebra/PolynomialMap.lean index f73c9be..c3e55c1 100644 --- a/DividedPowers/DPAlgebra/PolynomialMap.lean +++ b/DividedPowers/DPAlgebra/PolynomialMap.lean @@ -1,6 +1,7 @@ import DividedPowers.PolynomialMap.Homogeneous import DividedPowers.DPAlgebra.Graded.Basic import DividedPowers.DPAlgebra.BaseChange +import Mathlib.RingTheory.TensorProduct.Basic /- @@ -92,6 +93,8 @@ theorem gamma_mem_grade (n : ℕ) (S : Type*) [CommRing S] [Algebra R S] (m : S -/ sorry +#check LinearMap.tensorProduct + example (A : Type*) [CommRing A] (M N P : Type*) [AddCommGroup M] [Module A M] [AddCommGroup N] [Module A N] [AddCommGroup P] [Module A P] (Φ : M →ₗ[A] N →ₗ[A] P) @@ -100,6 +103,7 @@ example (A : Type*) [CommRing A] (M N P : Type*) [AddCommGroup M] [Module A M] have := LinearMap.baseChange R Φ apply LinearMap.comp ?_ this have := LinearMap.tensorProduct A R N P + exact this /- to do this, it seems that we have to understand polynomial maps valued into a submodule (in this case, it is a direct factor, From 5ddbe9eaa62d1c7fac63337ce2b5d7539f03d332 Mon Sep 17 00:00:00 2001 From: Antoine Chambert-Loir Date: Wed, 5 Jun 2024 18:15:32 +0200 Subject: [PATCH 3/3] correct Ne_def to ne_eq --- DividedPowers/BasicLemmas.lean | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/DividedPowers/BasicLemmas.lean b/DividedPowers/BasicLemmas.lean index a82daee..99f379b 100644 --- a/DividedPowers/BasicLemmas.lean +++ b/DividedPowers/BasicLemmas.lean @@ -77,7 +77,7 @@ theorem rewriting_4_fold_sums {α : Type _} [CommSemiring α] {m n u v : ℕ} if_true] · rintro ⟨⟨x, y⟩, ⟨z, t⟩⟩ hb hb'; rw [if_neg]; intro hb'' simp only [Finset.mem_product, Finset.mem_antidiagonal] at hb - simp only [Ne.def, Prod.mk.inj_iff, not_and, and_imp] at hb' + simp only [ne_eq, Prod.mk.injEq, not_and, and_imp] at hb' simp only [Prod.mk.inj_iff] at hb'' specialize hb' hb''.2.1 hb''.2.2 rw [hb''.2.1, hb''.2.2] at hb