First Order Language of Rings #
This file defines the first order language of rings, as well as defining instance of Add, Mul,
etc. on terms in the language.
Main Definitions #
FirstOrder.Language.ring: the language of rings, with function symbols+,*,-,0,1FirstOrder.Ring.CompatibleRing: A class stating that a type is aLanguage.ring.Structure, and that this structure is the same as the structure given by the classesAdd,Mul, etc. already onR.FirstOrder.Ring.compatibleRingOfRing: Given a typeRwith instances for each of theRingoperations, make acompatibleRinginstance.
Implementation Notes #
There are implementation difficulties with the model theory of rings caused by the fact that there
are two different ways to say that R is a Ring. We can say Ring R or
Language.ring.Structure R and Theory.ring.Model R (The theory of rings is not implemented yet).
The recommended way to use this library is to use the hypotheses CompatibleRing R and Ring R
on any theorem that requires both a Ring instance and a Language.ring.Structure instance
in order to state the theorem. To apply such a theorem to a ring R with a Ring instance,
use the tactic let _ := compatibleRingOfRing R. To apply the theorem to K
a Language.ring.Structure K instance and for example an instance of Theory.field.Model K,
you must add local instances with definitions like ModelTheory.Field.fieldOfModelField K and
FirstOrder.Ring.compatibleRingOfModelField K.
(in Mathlib/ModelTheory/Algebra/Field/Basic.lean), depending on the Theory.
The language of rings contains the operations (+,*,-,0,1)
Equations
- FirstOrder.Language.ring = { Functions := FirstOrder.ringFunc, Relations := fun (x : ℕ) => Empty }
Instances For
Equations
RingFunc.add, but with the defeq type Language.ring.Functions 2 instead
of RingFunc 2
Instances For
RingFunc.mul, but with the defeq type Language.ring.Functions 2 instead
of RingFunc 2
Instances For
RingFunc.neg, but with the defeq type Language.ring.Functions 1 instead
of RingFunc 1
Instances For
RingFunc.zero, but with the defeq type Language.ring.Functions 0 instead
of RingFunc 0
Instances For
RingFunc.one, but with the defeq type Language.ring.Functions 0 instead
of RingFunc 0
Instances For
Equations
Equations
Equations
Equations
Equations
Equations
- One or more equations did not get rendered due to their size.
A Type R is a CompatibleRing if it is a structure for the language of rings and this
structure is the same as the structure already given on R by the classes Add, Mul etc.
It is recommended to use this type class as a hypothesis to any theorem whose statement
requires a type to have be both a Ring (or Field etc.) and a
Language.ring.Structure
Addition in the
Language.ring.Structureis the same as the addition given by theAddinstanceMultiplication in the
Language.ring.Structureis the same as the multiplication given by theMulinstanceNegation in the
Language.ring.Structureis the same as the negation given by theNeginstanceThe constant
0in theLanguage.ring.Structureis the same as the constant given by theZeroinstanceThe constant
1in theLanguage.ring.Structureis the same as the constant given by theOneinstance
Instances
Given a Type R with instances for each of the Ring operations, make a
Language.ring.Structure R instance, along with a proof that the operations given
by the Language.ring.Structure are the same as those given by the Add or Mul etc.
instances.
This definition can be used when applying a theorem about the model theory of rings
to a literal ring R, by writing let _ := compatibleRingOfRing R. After this, if,
for example, R is a field, then Lean will be able to find the instance for
Theory.field.Model R, and it will be possible to apply theorems about the model theory
of fields.
This is a def and not an instance, because the path
Ring => Language.ring.Structure => Ring cannot be made to
commute by definition
Equations
- One or more equations did not get rendered due to their size.
Instances For
An isomorphism in the language of rings is a ring isomorphism
Equations
- One or more equations did not get rendered due to their size.
Instances For
A def to put an Add instance on a type with a Language.ring.Structure instance.
To be used sparingly, usually only when defining a more useful definition like,
[Language.ring.Structure K] -> [Theory.field.Model K] -> Field K
Equations
- FirstOrder.Ring.addOfRingStructure R = { add := fun (x y : R) => FirstOrder.Language.Structure.funMap FirstOrder.Ring.addFunc ![x, y] }
Instances For
A def to put an Mul instance on a type with a Language.ring.Structure instance.
To be used sparingly, usually only when defining a more useful definition like,
[Language.ring.Structure K] -> [Theory.field.Model K] -> Field K
Equations
- FirstOrder.Ring.mulOfRingStructure R = { mul := fun (x y : R) => FirstOrder.Language.Structure.funMap FirstOrder.Ring.mulFunc ![x, y] }
Instances For
A def to put an Neg instance on a type with a Language.ring.Structure instance.
To be used sparingly, usually only when defining a more useful definition like,
[Language.ring.Structure K] -> [Theory.field.Model K] -> Field K
Equations
- FirstOrder.Ring.negOfRingStructure R = { neg := fun (x : R) => FirstOrder.Language.Structure.funMap FirstOrder.Ring.negFunc ![x] }
Instances For
A def to put an Zero instance on a type with a Language.ring.Structure instance.
To be used sparingly, usually only when defining a more useful definition like,
[Language.ring.Structure K] -> [Theory.field.Model K] -> Field K
Equations
Instances For
A def to put an One instance on a type with a Language.ring.Structure instance.
To be used sparingly, usually only when defining a more useful definition like,
[Language.ring.Structure K] -> [Theory.field.Model K] -> Field K
Equations
Instances For
Given a Type R with a Language.ring.Structure R, the instance given by
addOfRingStructure etc are compatible with the Language.ring.Structure instance on R.
This definition is only to be used when addOfRingStructure, mulOfRingStructure etc
are local instances.
Equations
- FirstOrder.Ring.compatibleRingOfRingStructure R = { toStructure := inst✝, funMap_add := ⋯, funMap_mul := ⋯, funMap_neg := ⋯, funMap_zero := ⋯, funMap_one := ⋯ }