p-adic integers #
This file defines the p
-adic integers ℤ_[p]
as the subtype of ℚ_[p]
with norm ≤ 1
.
We show that ℤ_[p]
- is complete,
- is nonarchimedean,
- is a normed ring,
- is a local ring, and
- is a discrete valuation ring.
The relation between ℤ_[p]
and ZMod p
is established in another file.
Important definitions #
PadicInt
: the type ofp
-adic integers
Notation #
We introduce the notation ℤ_[p]
for the p
-adic integers.
Implementation notes #
Much, but not all, of this file assumes that p
is prime. This assumption is inferred automatically
by taking [Fact p.Prime]
as a type class argument.
Coercions into ℤ_[p]
are set up to work with the norm_cast
tactic.
References #
- [F. Q. Gouvêa, p-adic numbers][gouvea1997]
- [R. Y. Lewis, A formal proof of Hensel's lemma over the p-adic integers][lewis2019]
Tags #
p-adic, p adic, padic, p-adic integer
The ring of p
-adic integers.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Ring structure and coercion to ℚ_[p]
#
Equations
- PadicInt.instAddCommGroupPadicInt = inferInstance
The coercion from ℤ_[p]
to ℚ_[p]
as a ring homomorphism.
Equations
- PadicInt.Coe.ringHom = Subring.subtype (PadicInt.subring p)
Instances For
The inverse of a p
-adic integer with norm equal to 1
is also a p
-adic integer.
Otherwise, the inverse is defined to be 0
.
Equations
Instances For
A sequence of integers that is Cauchy with respect to the p
-adic norm converges to a p
-adic
integer.
Equations
- PadicInt.ofIntSeq seq h = { val := ⟦{ val := fun (n : ℕ) => ↑(seq n), property := h }⟧, property := ⋯ }
Instances For
Equations
- PadicInt.instMetricSpacePadicInt p = Subtype.metricSpace
Equations
- ⋯ = ⋯
Equations
- PadicInt.instNormedCommRingPadicInt p = let __src := PadicInt.instCommRing; NormedCommRing.mk ⋯
Equations
- ⋯ = ⋯
Norm #
Equations
- ⋯ = ⋯
Valuation on ℤ_[p]
#
Units of ℤ_[p]
#
unitCoeff hx
is the unit u
in the unique representation x = u * p ^ n
.
See unitCoeff_spec
.
Equations
- PadicInt.unitCoeff hx = let u := ↑x * ↑p ^ (-PadicInt.valuation x); let_fun hu := ⋯; PadicInt.mkUnits hu
Instances For
Various characterizations of open unit balls #
Discrete valuation ring #
Equations
- ⋯ = ⋯
Equations
- PadicInt.algebra = Algebra.ofSubring (PadicInt.subring p)