Nontrivial types #
A type is nontrivial if it contains at least two elements. This is useful in particular for rings (where it is equivalent to the fact that zero is different from one) and for vector spaces (where it is equivalent to the fact that the dimension is positive).
We introduce a typeclass nontrivial
formalizing this property.
- exists_pair_ne : ∃ (x y : α), x ≠ y
Predicate typeclass for expressing that a type is not reduced to a single element. In rings,
this is equivalent to 0 ≠ 1
. In vector spaces, this is equivalent to positive dimension.
Instances
- group_with_zero.to_nontrivial
- is_domain.to_nontrivial
- linear_ordered_add_comm_group_with_top.to_nontrivial
- linear_ordered_semiring.to_nontrivial
- linear_ordered_ring.to_nontrivial
- division_ring.to_nontrivial
- field.to_nontrivial
- infinite.nontrivial
- euclidean_domain.to_nontrivial
- is_simple_order.to_nontrivial
- is_simple_group.to_nontrivial
- is_simple_add_group.to_nontrivial
- sort.nontrivial
- option.nontrivial
- nontrivial_prod_right
- nontrivial_prod_left
- pi.nontrivial
- function.nontrivial
- bool.nontrivial
- order_dual.nontrivial
- with_one.nontrivial
- with_zero.nontrivial
- additive.nontrivial
- multiplicative.nontrivial
- mul_opposite.nontrivial
- with_top.nontrivial
- with_bot.nontrivial
- nat.nontrivial
- int.nontrivial
- fin.nontrivial
- rat.nontrivial
- submonoid.nontrivial
- add_submonoid.nontrivial
- real.nontrivial
- subgroup.nontrivial
- add_subgroup.nontrivial
- subsemiring.nontrivial
- subring.nontrivial
- associates.nontrivial
- finsupp.nontrivial
- linear_map.module.End.nontrivial
- submodule.nontrivial
- nonneg.nontrivial
- ennreal.nontrivial
See Note [lower instance priority]
Note that since this and nonempty_of_inhabited
are the most "obvious" way to find a nonempty
instance if no direct instance can be found, we give this a higher priority than the usual 100
.
An inhabited type is either nontrivial, or has a unique element.
Equations
- nontrivial_psum_unique α = dite (nontrivial α) (λ (h : nontrivial α), psum.inl h) (λ (h : ¬nontrivial α), psum.inr {to_inhabited := {default := default α _inst_1}, uniq := _})
A type is either a subsingleton or nontrivial.
Pushforward a nontrivial
instance along an injective function.
Pullback a nontrivial
instance along a surjective function.
An injective function from a nontrivial type has an argument at which it does not take a given value.
A pi type is nontrivial if it's nonempty everywhere and nontrivial somewhere.
As a convenience, provide an instance automatically if (f (default I))
is nontrivial.
If a different index has the non-trivial type, then use haveI := nontrivial_at that_index
.