HomeHome Intuitionistic Logic Explorer
Theorem List (p. 132 of 135)
< Previous  Next >
Browser slow? Try the
Unicode version.

Mirrors  >  Metamath Home Page  >  ILE Home Page  >  Theorem List Contents  >  Recent Proofs       This page: Page List

Theorem List for Intuitionistic Logic Explorer - 13101-13200   *Has distinct variable group(s)
TypeLabelDescription
Statement
 
Theorem2irrexpq 13101* There exist real numbers  a and  b which are not rational such that  ( a ^
b ) is rational. Statement in the Metamath book, section 1.1.5, footnote 27 on page 17, and the "constructive proof" for theorem 1.2 of [Bauer], p. 483. This is a constructive proof because it is based on two explicitly named non-rational numbers  ( sqr `  2 ) and  ( 2 logb  9 ), see sqrt2irr0 11878, 2logb9irr 13096 and sqrt2cxp2logb9e3 13100. Therefore, this proof is acceptable/usable in intuitionistic logic.

For a theorem which is the same but proves that  a and  b are irrational (in the sense of being apart from any rational number), see 2irrexpqap 13103. (Contributed by AV, 23-Dec-2022.)

 |- 
 E. a  e.  ( RR  \  QQ ) E. b  e.  ( RR  \  QQ ) ( a 
 ^c  b )  e.  QQ
 
Theorem2logb9irrap 13102 Example for logbgcd1irrap 13095. The logarithm of nine to base two is irrational (in the sense of being apart from any rational number). (Contributed by Jim Kingdon, 12-Jul-2024.)
 |-  ( Q  e.  QQ  ->  ( 2 logb  9 ) #  Q )
 
Theorem2irrexpqap 13103* There exist real numbers  a and  b which are irrational (in the sense of being apart from any rational number) such that  ( a ^ b ) is rational. Statement in the Metamath book, section 1.1.5, footnote 27 on page 17, and the "constructive proof" for theorem 1.2 of [Bauer], p. 483. This is a constructive proof because it is based on two explicitly named irrational numbers  ( sqr `  2 ) and  ( 2 logb  9 ), see sqrt2irrap 11894, 2logb9irrap 13102 and sqrt2cxp2logb9e3 13100. Therefore, this proof is acceptable/usable in intuitionistic logic. (Contributed by Jim Kingdon, 12-Jul-2024.)
 |- 
 E. a  e.  RR  E. b  e.  RR  ( A. p  e.  QQ  a #  p  /\  A. q  e.  QQ  b #  q  /\  ( a  ^c  b )  e.  QQ )
 
PART 10  GUIDES AND MISCELLANEA
 
10.1  Guides (conventions, explanations, and examples)
 
10.1.1  Conventions

This section describes the conventions we use. These conventions often refer to existing mathematical practices, which are discussed in more detail in other references. The following sources lay out how mathematics is developed without the law of the excluded middle. Of course, there are a greater number of sources which assume excluded middle and most of what is in them applies here too (especially in a treatment such as ours which is built on first-order logic and set theory, rather than, say, type theory). Studying how a topic is treated in the Metamath Proof Explorer and the references therein is often a good place to start (and is easy to compare with the Intuitionistic Logic Explorer). The textbooks provide a motivation for what we are doing, whereas Metamath lets you see in detail all hidden and implicit steps. Most standard theorems are accompanied by citations. Some closely followed texts include the following:

  • Axioms of propositional calculus - Stanford Encyclopedia of Philosophy or [Heyting].
  • Axioms of predicate calculus - our axioms are adapted from the ones in the Metamath Proof Explorer.
  • Theorems of propositional calculus - [Heyting].
  • Theorems of pure predicate calculus - Metamath Proof Explorer.
  • Theorems of equality and substitution - Metamath Proof Explorer.
  • Axioms of set theory - [Crosilla].
  • Development of set theory - Chapter 10 of [HoTT].
  • Construction of real and complex numbers - Chapter 11 of [HoTT]; [BauerTaylor].
  • Theorems about real numbers - [Geuvers].
 
Theoremconventions 13104 Unless there is a reason to diverge, we follow the conventions of the Metamath Proof Explorer (MPE, set.mm). This list of conventions is intended to be read in conjunction with the corresponding conventions in the Metamath Proof Explorer, and only the differences are described below.
  • Minimizing axioms and the axiom of choice. We prefer proofs that depend on fewer and/or weaker axioms, even if the proofs are longer. In particular, our choice of IZF (Intuitionistic Zermelo-Fraenkel) over CZF (Constructive Zermelo-Fraenkel, a weaker system) was just an expedient choice because IZF is easier to formalize in Metamath. You can find some development using CZF in BJ's mathbox starting at wbd 13181 (and the section header just above it). As for the axiom of choice, the full axiom of choice implies excluded middle as seen at acexmid 5781, although some authors will use countable choice or dependent choice. For example, countable choice or excluded middle is needed to show that the Cauchy reals coincide with the Dedekind reals - Corollary 11.4.3 of [HoTT], p. (varies).
  • Junk/undefined results. Much of the discussion of this topic in the Metamath Proof Explorer applies except that certain techniques are not available to us. For example, the Metamath Proof Explorer will often say "if a function is evaluated within its domain, a certain result follows; if the function is evaluated outside its domain, the same result follows. Since the function must be evaluated within its domain or outside it, the result follows unconditionally" (the use of excluded middle in this argument is perhaps obvious when stated this way). Often, the easiest fix will be to prove we are evaluating functions within their domains, other times it will be possible to use a theorem like relelfvdm 5461 which says that if a function value produces an inhabited set, then the function is being evaluated within its domain.
  • Bibliography references. The bibliography for the Intuitionistic Logic Explorer is separate from the one for the Metamath Proof Explorer but feel free to copy-paste a citation in either direction in order to cite it.

Label naming conventions

Here are a few of the label naming conventions:

  • Suffixes. We follow the conventions of the Metamath Proof Explorer with a few additions. A biconditional in set.mm which is an implication in iset.mm should have a "r" (for the reverse direction), or "i"/"im" (for the forward direction) appended. A theorem in set.mm which has a decidability condition added should add "dc" to the theorem name. A theorem in set.mm where "nonempty class" is changed to "inhabited class" should add "m" (for member) to the theorem name.
  • iset.mm versus set.mm names

    Theorems which are the same as in set.mm should be named the same (that is, where the statement of the theorem is the same; the proof can differ without a new name being called for). Theorems which are different should be named differently (we do have a small number of intentional exceptions to this rule but on the whole it serves us well).

    As for how to choose names so they are different between iset.mm and set.mm, when possible choose a name which reflect the difference in the theorems. For example, if a theorem in set.mm is an equality and the iset.mm analogue is a subset, add "ss" to the iset.mm name. If need be, add "i" to the iset.mm name (usually as a prefix to some portion of the name).

    As with set.mm, we welcome suggestions for better names (such as names which are more consistent with naming conventions).

    We do try to keep set.mm and iset.mm similar where we can. For example, if a theorem exists in both places but the name in set.mm isn't great, we tend to keep that name for iset.mm, or change it in both files together. This is mainly to make it easier to copy theorems, but also to generally help people browse proofs, find theorems, write proofs, etc.

The following table shows some commonly-used abbreviations in labels which are not found in the Metamath Proof Explorer, in alphabetical order. For each abbreviation we provide a mnenomic to help you remember it, the source theorem/assumption defining it, an expression showing what it looks like, whether or not it is a "syntax fragment" (an abbreviation that indicates a particular kind of syntax), and hyperlinks to label examples that use the abbreviation. The abbreviation is bolded if there is a df-NAME definition but the label fragment is not NAME.

For the "g" abbreviation, this is related to the set.mm usage, in which "is a set" conditions are converted from hypotheses to antecedents, but is also used where "is a set" conditions are added relative to similar set.mm theorems.

AbbreviationMnenomic/MeaningSource ExpressionSyntax?Example(s)
apapart df-ap 8368 Yes apadd1 8394, apne 8409
gwith "is a set" condition No 1stvalg 6048, brtposg 6159, setsmsbasg 12687
seq3, sum3recursive sequence df-seqfrec 10250 Yes seq3-1 10264, fsum3 11188

(Contributed by Jim Kingdon, 24-Feb-2020.) (New usage is discouraged.)

 |-  ph   =>    |-  ph
 
10.1.2  Definitional examples
 
Theoremex-or 13105 Example for ax-io 699. Example by David A. Wheeler. (Contributed by Mario Carneiro, 9-May-2015.)
 |-  ( 2  =  3  \/  4  =  4 )
 
Theoremex-an 13106 Example for ax-ia1 105. Example by David A. Wheeler. (Contributed by Mario Carneiro, 9-May-2015.)
 |-  ( 2  =  2 
 /\  3  =  3 )
 
Theorem1kp2ke3k 13107 Example for df-dec 9207, 1000 + 2000 = 3000.

This proof disproves (by counterexample) the assertion of Hao Wang, who stated, "There is a theorem in the primitive notation of set theory that corresponds to the arithmetic theorem 1000 + 2000 = 3000. The formula would be forbiddingly long... even if (one) knows the definitions and is asked to simplify the long formula according to them, chances are he will make errors and arrive at some incorrect result." (Hao Wang, "Theory and practice in mathematics" , In Thomas Tymoczko, editor, New Directions in the Philosophy of Mathematics, pp 129-152, Birkauser Boston, Inc., Boston, 1986. (QA8.6.N48). The quote itself is on page 140.)

This is noted in Metamath: A Computer Language for Pure Mathematics by Norman Megill (2007) section 1.1.3. Megill then states, "A number of writers have conveyed the impression that the kind of absolute rigor provided by Metamath is an impossible dream, suggesting that a complete, formal verification of a typical theorem would take millions of steps in untold volumes of books... These writers assume, however, that in order to achieve the kind of complete formal verification they desire one must break down a proof into individual primitive steps that make direct reference to the axioms. This is not necessary. There is no reason not to make use of previously proved theorems rather than proving them over and over... A hierarchy of theorems and definitions permits an exponential growth in the formula sizes and primitive proof steps to be described with only a linear growth in the number of symbols used. Of course, this is how ordinary informal mathematics is normally done anyway, but with Metamath it can be done with absolute rigor and precision."

The proof here starts with  ( 2  +  1 )  =  3, commutes it, and repeatedly multiplies both sides by ten. This is certainly longer than traditional mathematical proofs, e.g., there are a number of steps explicitly shown here to show that we're allowed to do operations such as multiplication. However, while longer, the proof is clearly a manageable size - even though every step is rigorously derived all the way back to the primitive notions of set theory and logic. And while there's a risk of making errors, the many independent verifiers make it much less likely that an incorrect result will be accepted.

This proof heavily relies on the decimal constructor df-dec 9207 developed by Mario Carneiro in 2015. The underlying Metamath language has an intentionally very small set of primitives; it doesn't even have a built-in construct for numbers. Instead, the digits are defined using these primitives, and the decimal constructor is used to make it easy to express larger numbers as combinations of digits.

(Contributed by David A. Wheeler, 29-Jun-2016.) (Shortened by Mario Carneiro using the arithmetic algorithm in mmj2, 30-Jun-2016.)

 |-  (;;; 1 0 0 0  + ;;; 2 0 0 0 )  = ;;; 3 0 0 0
 
Theoremex-fl 13108 Example for df-fl 10074. Example by David A. Wheeler. (Contributed by Mario Carneiro, 18-Jun-2015.)
 |-  ( ( |_ `  (
 3  /  2 )
 )  =  1  /\  ( |_ `  -u (
 3  /  2 )
 )  =  -u 2
 )
 
Theoremex-ceil 13109 Example for df-ceil 10075. (Contributed by AV, 4-Sep-2021.)
 |-  ( ( `  (
 3  /  2 )
 )  =  2  /\  ( `  -u ( 3  / 
 2 ) )  =  -u 1 )
 
Theoremex-exp 13110 Example for df-exp 10324. (Contributed by AV, 4-Sep-2021.)
 |-  ( ( 5 ^
 2 )  = ; 2 5  /\  ( -u 3 ^ -u 2
 )  =  ( 1 
 /  9 ) )
 
Theoremex-fac 13111 Example for df-fac 10504. (Contributed by AV, 4-Sep-2021.)
 |-  ( ! `  5
 )  = ;; 1 2 0
 
Theoremex-bc 13112 Example for df-bc 10526. (Contributed by AV, 4-Sep-2021.)
 |-  ( 5  _C  3
 )  = ; 1 0
 
Theoremex-dvds 13113 Example for df-dvds 11530: 3 divides into 6. (Contributed by David A. Wheeler, 19-May-2015.)
 |-  3  ||  6
 
Theoremex-gcd 13114 Example for df-gcd 11672. (Contributed by AV, 5-Sep-2021.)
 |-  ( -u 6  gcd  9
 )  =  3
 
PART 11  SUPPLEMENTARY MATERIAL (USERS' MATHBOXES)
 
11.1  Mathboxes for user contributions
 
11.1.1  Mathbox guidelines
 
Theoremmathbox 13115 (This theorem is a dummy placeholder for these guidelines. The label of this theorem, "mathbox", is hard-coded into the Metamath program to identify the start of the mathbox section for web page generation.)

A "mathbox" is a user-contributed section that is maintained by its contributor independently from the main part of iset.mm.

For contributors:

By making a contribution, you agree to release it into the public domain, according to the statement at the beginning of iset.mm.

Guidelines:

Mathboxes in iset.mm follow the same practices as in set.mm, so refer to the mathbox guidelines there for more details.

(Contributed by NM, 20-Feb-2007.) (Revised by the Metamath team, 9-Sep-2023.) (New usage is discouraged.)

 |-  ph   =>    |-  ph
 
11.2  Mathbox for BJ
 
11.2.1  Propositional calculus
 
Theorembj-nnsn 13116 As far as implying a negated formula is concerned, a formula is equivalent to its double negation. (Contributed by BJ, 24-Nov-2023.)
 |-  (
 ( ph  ->  -.  ps ) 
 <->  ( -.  -.  ph  ->  -.  ps ) )
 
Theorembj-nnor 13117 Double negation of a disjunction in terms of implication. (Contributed by BJ, 9-Oct-2019.)
 |-  ( -.  -.  ( ph  \/  ps )  <->  ( -.  ph  ->  -.  -.  ps )
 )
 
Theorembj-nnim 13118 The double negation of an implication implies the implication with the consequent doubly negated. (Contributed by BJ, 24-Nov-2023.)
 |-  ( -.  -.  ( ph  ->  ps )  ->  ( ph  ->  -.  -.  ps )
 )
 
Theorembj-nnan 13119 The double negation of a conjunction implies the conjunction of the double negations. (Contributed by BJ, 24-Nov-2023.)
 |-  ( -.  -.  ( ph  /\  ps )  ->  ( -.  -.  ph 
 /\  -.  -.  ps )
 )
 
Theorembj-nnal 13120 The double negation of a universal quantification implies the universal quantification of the double negation. (Contributed by BJ, 24-Nov-2023.)
 |-  ( -.  -.  A. x ph  ->  A. x  -.  -.  ph )
 
Theorembj-nnclavius 13121 Clavius law with doubly negated consequent. (Contributed by BJ, 4-Dec-2023.)
 |-  (
 ( -.  ph  ->  ph )  ->  -.  -.  ph )
 
11.2.1.1  Stable formulas
 
Theorembj-trst 13122 A provable formula is stable. (Contributed by BJ, 24-Nov-2023.)
 |-  ( ph  -> STAB  ph )
 
Theorembj-fast 13123 A refutable formula is stable. (Contributed by BJ, 24-Nov-2023.)
 |-  ( -.  ph  -> STAB  ph )
 
Theorembj-nnbist 13124 If a formula is not refutable, then it is stable if and only if it is provable. By double-negation translation, if  ph is a classical tautology, then  -.  -.  ph is an intuitionistic tautology. Therefore, if  ph is a classical tautology, then  ph is intuitionistically equivalent to its stability (and to its decidability, see bj-nnbidc 13133). (Contributed by BJ, 24-Nov-2023.)
 |-  ( -.  -.  ph  ->  (STAB  ph  <->  ph ) )
 
Theorembj-stim 13125 A conjunction with a stable consequent is stable. See stabnot 819 for negation and bj-stan 13126 for conjunction. (Contributed by BJ, 24-Nov-2023.)
 |-  (STAB  ps  -> STAB  (
 ph  ->  ps ) )
 
Theorembj-stan 13126 The conjunction of two stable formulas is stable. See bj-stim 13125 for implication, stabnot 819 for negation, and bj-stal 13128 for universal quantification. (Contributed by BJ, 24-Nov-2023.)
 |-  (
 (STAB  ph  /\ STAB 
 ps )  -> STAB  ( ph  /\  ps ) )
 
Theorembj-stand 13127 The conjunction of two stable formulas is stable. Deduction form of bj-stan 13126. Its proof is shorter, so one could prove it first and then bj-stan 13126 from it, the usual way. (Contributed by BJ, 24-Nov-2023.) (Proof modification is discouraged.)
 |-  ( ph  -> STAB  ps )   &    |-  ( ph  -> STAB  ch )   =>    |-  ( ph  -> STAB 
 ( ps  /\  ch ) )
 
Theorembj-stal 13128 The universal quantification of stable formula is stable. See bj-stim 13125 for implication, stabnot 819 for negation, and bj-stan 13126 for conjunction. (Contributed by BJ, 24-Nov-2023.)
 |-  ( A. xSTAB 
 ph  -> STAB  A. x ph )
 
Theorembj-pm2.18st 13129 Clavius law for stable formulas. See pm2.18dc 841. (Contributed by BJ, 4-Dec-2023.)
 |-  (STAB  ph  ->  ( ( -.  ph  ->  ph )  ->  ph ) )
 
11.2.1.2  Decidable formulas
 
Theorembj-trdc 13130 A provable formula is decidable. (Contributed by BJ, 24-Nov-2023.)
 |-  ( ph  -> DECID  ph )
 
Theorembj-fadc 13131 A refutable formula is decidable. (Contributed by BJ, 24-Nov-2023.)
 |-  ( -.  ph  -> DECID  ph )
 
Theorembj-dcstab 13132 A decidable formula is stable. (Contributed by BJ, 24-Nov-2023.) (Proof modification is discouraged.)
 |-  (DECID  ph  -> STAB  ph )
 
Theorembj-nnbidc 13133 If a formula is not refutable, then it is decidable if and only if it is provable. See also comment of bj-nnbist 13124. (Contributed by BJ, 24-Nov-2023.)
 |-  ( -.  -.  ph  ->  (DECID  ph  <->  ph ) )
 
Theorembj-nndcALT 13134 Alternate proof of nndc 837. (Proof modification is discouraged.) (New usage is discouraged.) (Contributed by BJ, 9-Oct-2019.)
 |-  -.  -. DECID  ph
 
Theorembj-nnst 13135 Double negation of stability of a formula. Intuitionistic logic refutes unstability (but does not prove stability) of any formula. (Contributed by BJ, 9-Oct-2019.)
 |-  -.  -. STAB  ph
 
Theorembj-dcdc 13136 Decidability of a proposition is decidable if and only if that proposition is decidable. DECID is idempotent. (Contributed by BJ, 9-Oct-2019.)
 |-  (DECID DECID  ph  <-> DECID  ph )
 
Theorembj-stdc 13137 Decidability of a proposition is stable if and only if that proposition is decidable. In particular, the assumption that every formula is stable implies that every formula is decidable, hence classical logic. (Contributed by BJ, 9-Oct-2019.)
 |-  (STAB DECID  ph  <-> DECID  ph )
 
Theorembj-dcst 13138 Stability of a proposition is decidable if and only if that proposition is stable. (Contributed by BJ, 24-Nov-2023.)
 |-  (DECID STAB  ph  <-> STAB  ph )
 
Theorembj-stst 13139 Stability of a proposition is stable if and only if that proposition is stable. STAB is idempotent. (Contributed by BJ, 9-Oct-2019.)
 |-  (STAB STAB  ph  <-> STAB  ph )
 
11.2.2  Predicate calculus
 
Theorembj-ex 13140* Existential generalization. (Contributed by BJ, 8-Dec-2019.) Proof modification is discouraged because there are shorter proofs, but using less basic results (like exlimiv 1578 and 19.9ht 1621 or 19.23ht 1474). (Proof modification is discouraged.)
 |-  ( E. x ph  ->  ph )
 
Theorembj-hbalt 13141 Closed form of hbal 1454 (copied from set.mm). (Contributed by BJ, 2-May-2019.)
 |-  ( A. y ( ph  ->  A. x ph )  ->  ( A. y ph  ->  A. x A. y ph ) )
 
Theorembj-nfalt 13142 Closed form of nfal 1556 (copied from set.mm). (Contributed by BJ, 2-May-2019.) (Proof modification is discouraged.)
 |-  ( A. x F/ y ph  ->  F/ y A. x ph )
 
Theoremspimd 13143 Deduction form of spim 1717. (Contributed by BJ, 17-Oct-2019.)
 |-  ( ph  ->  F/ x ch )   &    |-  ( ph  ->  A. x ( x  =  y  ->  ( ps  ->  ch )
 ) )   =>    |-  ( ph  ->  ( A. x ps  ->  ch )
 )
 
Theorem2spim 13144* Double substitution, as in spim 1717. (Contributed by BJ, 17-Oct-2019.)
 |-  F/ x ch   &    |-  F/ z ch   &    |-  ( ( x  =  y  /\  z  =  t )  ->  ( ps  ->  ch ) )   =>    |-  ( A. z A. x ps  ->  ch )
 
Theoremch2var 13145* Implicit substitution of  y for  x and  t for  z into a theorem. (Contributed by BJ, 17-Oct-2019.)
 |-  F/ x ps   &    |-  F/ z ps   &    |-  ( ( x  =  y  /\  z  =  t )  ->  ( ph 
 <->  ps ) )   &    |-  ph   =>    |- 
 ps
 
Theoremch2varv 13146* Version of ch2var 13145 with non-freeness hypotheses replaced with disjoint variable conditions. (Contributed by BJ, 17-Oct-2019.)
 |-  (
 ( x  =  y 
 /\  z  =  t )  ->  ( ph  <->  ps ) )   &    |-  ph   =>    |- 
 ps
 
Theorembj-exlimmp 13147 Lemma for bj-vtoclgf 13154. (Contributed by BJ, 21-Nov-2019.) (Proof modification is discouraged.)
 |-  F/ x ps   &    |-  ( ch  ->  ph )   =>    |-  ( A. x ( ch  ->  ( ph  ->  ps ) )  ->  ( E. x ch  ->  ps ) )
 
Theorembj-exlimmpi 13148 Lemma for bj-vtoclgf 13154. (Contributed by BJ, 21-Nov-2019.) (Proof modification is discouraged.)
 |-  F/ x ps   &    |-  ( ch  ->  ph )   &    |-  ( ch  ->  (
 ph  ->  ps ) )   =>    |-  ( E. x ch  ->  ps )
 
Theorembj-sbimedh 13149 A strengthening of sbiedh 1761 (same proof). (Contributed by BJ, 16-Dec-2019.)
 |-  ( ph  ->  A. x ph )   &    |-  ( ph  ->  ( ch  ->  A. x ch ) )   &    |-  ( ph  ->  ( x  =  y  ->  ( ps 
 ->  ch ) ) )   =>    |-  ( ph  ->  ( [
 y  /  x ] ps  ->  ch ) )
 
Theorembj-sbimeh 13150 A strengthening of sbieh 1764 (same proof). (Contributed by BJ, 16-Dec-2019.)
 |-  ( ps  ->  A. x ps )   &    |-  ( x  =  y  ->  (
 ph  ->  ps ) )   =>    |-  ( [ y  /  x ] ph  ->  ps )
 
Theorembj-sbime 13151 A strengthening of sbie 1765 (same proof). (Contributed by BJ, 16-Dec-2019.)
 |-  F/ x ps   &    |-  ( x  =  y  ->  ( ph  ->  ps ) )   =>    |-  ( [ y  /  x ] ph  ->  ps )
 
11.2.3  Set theorey miscellaneous
 
Theorembj-el2oss1o 13152 Shorter proof of el2oss1o 13359 using more axioms. (Contributed by BJ, 21-Jan-2024.) (Proof modification is discouraged.) (New usage is discouraged.)
 |-  ( A  e.  2o  ->  A 
 C_  1o )
 
11.2.4  Extensionality

Various utility theorems using FOL and extensionality.

 
Theorembj-vtoclgft 13153 Weakening two hypotheses of vtoclgf 2747. (Contributed by BJ, 21-Nov-2019.)
 |-  F/_ x A   &    |- 
 F/ x ps   &    |-  ( x  =  A  ->  ph )   =>    |-  ( A. x ( x  =  A  ->  (
 ph  ->  ps ) )  ->  ( A  e.  V  ->  ps ) )
 
Theorembj-vtoclgf 13154 Weakening two hypotheses of vtoclgf 2747. (Contributed by BJ, 21-Nov-2019.)
 |-  F/_ x A   &    |- 
 F/ x ps   &    |-  ( x  =  A  ->  ph )   &    |-  ( x  =  A  ->  ( ph  ->  ps ) )   =>    |-  ( A  e.  V  ->  ps )
 
Theoremelabgf0 13155 Lemma for elabgf 2830. (Contributed by BJ, 21-Nov-2019.)
 |-  ( x  =  A  ->  ( A  e.  { x  |  ph }  <->  ph ) )
 
Theoremelabgft1 13156 One implication of elabgf 2830, in closed form. (Contributed by BJ, 21-Nov-2019.)
 |-  F/_ x A   &    |- 
 F/ x ps   =>    |-  ( A. x ( x  =  A  ->  ( ph  ->  ps )
 )  ->  ( A  e.  { x  |  ph } 
 ->  ps ) )
 
Theoremelabgf1 13157 One implication of elabgf 2830. (Contributed by BJ, 21-Nov-2019.)
 |-  F/_ x A   &    |- 
 F/ x ps   &    |-  ( x  =  A  ->  (
 ph  ->  ps ) )   =>    |-  ( A  e.  { x  |  ph }  ->  ps )
 
Theoremelabgf2 13158 One implication of elabgf 2830. (Contributed by BJ, 21-Nov-2019.)
 |-  F/_ x A   &    |- 
 F/ x ps   &    |-  ( x  =  A  ->  ( ps  ->  ph ) )   =>    |-  ( A  e.  B  ->  ( ps  ->  A  e.  { x  |  ph } ) )
 
Theoremelabf1 13159* One implication of elabf 2831. (Contributed by BJ, 21-Nov-2019.)
 |-  F/ x ps   &    |-  ( x  =  A  ->  ( ph  ->  ps ) )   =>    |-  ( A  e.  { x  |  ph }  ->  ps )
 
Theoremelabf2 13160* One implication of elabf 2831. (Contributed by BJ, 21-Nov-2019.)
 |-  F/ x ps   &    |-  A  e.  _V   &    |-  ( x  =  A  ->  ( ps  ->  ph ) )   =>    |-  ( ps  ->  A  e.  { x  |  ph } )
 
Theoremelab1 13161* One implication of elab 2832. (Contributed by BJ, 21-Nov-2019.)
 |-  ( x  =  A  ->  (
 ph  ->  ps ) )   =>    |-  ( A  e.  { x  |  ph }  ->  ps )
 
Theoremelab2a 13162* One implication of elab 2832. (Contributed by BJ, 21-Nov-2019.)
 |-  A  e.  _V   &    |-  ( x  =  A  ->  ( ps  -> 
 ph ) )   =>    |-  ( ps  ->  A  e.  { x  |  ph
 } )
 
Theoremelabg2 13163* One implication of elabg 2834. (Contributed by BJ, 21-Nov-2019.)
 |-  ( x  =  A  ->  ( ps  ->  ph ) )   =>    |-  ( A  e.  V  ->  ( ps  ->  A  e.  { x  |  ph } ) )
 
Theorembj-rspgt 13164 Restricted specialization, generalized. Weakens a hypothesis of rspccv 2790 and seems to have a shorter proof. (Contributed by BJ, 21-Nov-2019.)
 |-  F/_ x A   &    |-  F/_ x B   &    |-  F/ x ps   =>    |-  ( A. x ( x  =  A  ->  ( ph  ->  ps ) )  ->  ( A. x  e.  B  ph 
 ->  ( A  e.  B  ->  ps ) ) )
 
Theorembj-rspg 13165 Restricted specialization, generalized. Weakens a hypothesis of rspccv 2790 and seems to have a shorter proof. (Contributed by BJ, 21-Nov-2019.)
 |-  F/_ x A   &    |-  F/_ x B   &    |-  F/ x ps   &    |-  ( x  =  A  ->  (
 ph  ->  ps ) )   =>    |-  ( A. x  e.  B  ph  ->  ( A  e.  B  ->  ps )
 )
 
Theoremcbvrald 13166* Rule used to change bound variables, using implicit substitution. (Contributed by BJ, 22-Nov-2019.)
 |-  F/ x ph   &    |-  F/ y ph   &    |-  ( ph  ->  F/ y ps )   &    |-  ( ph  ->  F/ x ch )   &    |-  ( ph  ->  ( x  =  y  ->  ( ps  <->  ch ) ) )   =>    |-  ( ph  ->  (
 A. x  e.  A  ps 
 <-> 
 A. y  e.  A  ch ) )
 
Theorembj-intabssel 13167 Version of intss1 3794 using a class abstraction and explicit substitution. (Contributed by BJ, 29-Nov-2019.)
 |-  F/_ x A   =>    |-  ( A  e.  V  ->  ( [. A  /  x ]. ph  ->  |^| { x  |  ph }  C_  A ) )
 
Theorembj-intabssel1 13168 Version of intss1 3794 using a class abstraction and implicit substitution. Closed form of intmin3 3806. (Contributed by BJ, 29-Nov-2019.)
 |-  F/_ x A   &    |- 
 F/ x ps   &    |-  ( x  =  A  ->  ( ps  ->  ph ) )   =>    |-  ( A  e.  V  ->  ( ps  ->  |^| { x  |  ph }  C_  A ) )
 
Theorembj-elssuniab 13169 Version of elssuni 3772 using a class abstraction and explicit substitution. (Contributed by BJ, 29-Nov-2019.)
 |-  F/_ x A   =>    |-  ( A  e.  V  ->  ( [. A  /  x ]. ph  ->  A  C_  U.
 { x  |  ph } ) )
 
Theorembj-sseq 13170 If two converse inclusions are characterized each by a formula, then equality is characterized by the conjunction of these formulas. (Contributed by BJ, 30-Nov-2019.)
 |-  ( ph  ->  ( ps  <->  A  C_  B ) )   &    |-  ( ph  ->  ( ch  <->  B  C_  A ) )   =>    |-  ( ph  ->  (
 ( ps  /\  ch ) 
 <->  A  =  B ) )
 
11.2.5  Decidability of classes

The question of decidability is essential in intuitionistic logic. In intuitionistic set theories, it is natural to define decidability of a set (or class) as decidability of membership in it. One can parameterize this notion with another set (or class) since it is often important to assess decidability of membership in one class among elements of another class. Namely, one will say that "
A is decidable in  B " if  A. x  e.  BDECID  x  e.  A (see df-dcin 13172).

Note the similarity with the definition of a bounded class as a class for which membership in it is a bounded proposition (df-bdc 13210).

 
Syntaxwdcin 13171 Syntax for decidability of a class in another.
 wff  A DECIDin  B
 
Definitiondf-dcin 13172* Define decidability of a class in another. (Contributed by BJ, 19-Feb-2022.)
 |-  ( A DECIDin  B  <->  A. x  e.  B DECID  x  e.  A )
 
Theoremdecidi 13173 Property of being decidable in another class. (Contributed by BJ, 19-Feb-2022.)
 |-  ( A DECIDin  B  ->  ( X  e.  B  ->  ( X  e.  A  \/  -.  X  e.  A ) ) )
 
Theoremdecidr 13174* Sufficient condition for being decidable in another class. (Contributed by BJ, 19-Feb-2022.)
 |-  ( ph  ->  ( x  e.  B  ->  ( x  e.  A  \/  -.  x  e.  A ) ) )   =>    |-  ( ph  ->  A DECIDin  B )
 
Theoremdecidin 13175 If A is a decidable subclass of B (meaning: it is a subclass of B and it is decidable in B), and B is decidable in C, then A is decidable in C. (Contributed by BJ, 19-Feb-2022.)
 |-  ( ph  ->  A  C_  B )   &    |-  ( ph  ->  A DECIDin  B )   &    |-  ( ph  ->  B DECIDin  C )   =>    |-  ( ph  ->  A DECIDin  C )
 
Theoremuzdcinzz 13176 An upperset of integers is decidable in the integers. Reformulation of eluzdc 9431. (Contributed by Jim Kingdon, 18-Apr-2020.) (Revised by BJ, 19-Feb-2022.)
 |-  ( M  e.  ZZ  ->  (
 ZZ>= `  M ) DECIDin  ZZ )
 
Theoremsumdc2 13177* Alternate proof of sumdc 11159, without disjoint variable condition on  N ,  x (longer because the statement is taylored to the proof sumdc 11159). (Contributed by BJ, 19-Feb-2022.)
 |-  ( ph  ->  M  e.  ZZ )   &    |-  ( ph  ->  A  C_  ( ZZ>= `  M )
 )   &    |-  ( ph  ->  A. x  e.  ( ZZ>= `  M )DECID  x  e.  A )   &    |-  ( ph  ->  N  e.  ZZ )   =>    |-  ( ph  -> DECID  N  e.  A )
 
11.2.6  Disjoint union
 
Theoremdjucllem 13178* Lemma for djulcl 6944 and djurcl 6945. (Contributed by BJ, 4-Jul-2022.)
 |-  X  e.  _V   &    |-  F  =  ( x  e.  _V  |->  <. X ,  x >. )   =>    |-  ( A  e.  B  ->  ( ( F  |`  B ) `
  A )  e.  ( { X }  X.  B ) )
 
TheoremdjulclALT 13179 Shortening of djulcl 6944 using djucllem 13178. (Contributed by BJ, 4-Jul-2022.) (Proof modification is discouraged.) (New usage is discouraged.)
 |-  ( C  e.  A  ->  ( (inl  |`  A ) `  C )  e.  ( A B ) )
 
TheoremdjurclALT 13180 Shortening of djurcl 6945 using djucllem 13178. (Contributed by BJ, 4-Jul-2022.) (Proof modification is discouraged.) (New usage is discouraged.)
 |-  ( C  e.  B  ->  ( (inr  |`  B ) `  C )  e.  ( A B ) )
 
11.2.7  Constructive Zermelo--Fraenkel set theory (CZF): Bounded formulas and classes

This section develops constructive Zermelo--Fraenkel set theory (CZF) on top of intuitionistic logic. It is a constructive theory in the sense that its logic is intuitionistic and it is predicative. "Predicative" means that new sets can be constructed only from already constructed sets. In particular, the axiom of separation ax-sep 4054 is not predicative (because we cannot allow all formulas to define a subset) and is replaced in CZF by bounded separation ax-bdsep 13253. Because this axiom is weaker than full separation, the axiom of replacement or collection ax-coll 4051 of ZF and IZF has to be strengthened in CZF to the axiom of strong collection ax-strcoll 13351 (which is a theorem of IZF), and the axiom of infinity needs a more precise version, the von Neumann axiom of infinity ax-infvn 13310. Similarly, the axiom of powerset ax-pow 4106 is not predicative (checking whether a set is included in another requires to universally quantifier over that "not yet constructed" set) and is replaced in CZF by the axiom of fullness or the axiom of subset collection ax-sscoll 13356.

In an intuitionistic context, the axiom of regularity is stated in IZF as well as in CZF as the axiom of set induction ax-setind 4460. It is sometimes interesting to study the weakening of CZF where that axiom is replaced by bounded set induction ax-bdsetind 13337.

For more details on CZF, a useful set of notes is

Peter Aczel and Michael Rathjen, CST Book draft. (available at http://www1.maths.leeds.ac.uk/~rathjen/book.pdf 13337)

and an interesting article is

Michael Shulman, Comparing material and structural set theories, Annals of Pure and Applied Logic, Volume 170, Issue 4 (Apr. 2019), 465--504. (available at https://arxiv.org/abs/1808.05204 13337)

I also thank Michael Rathjen and Michael Shulman for useful hints in the formulation of some results.

 
11.2.7.1  Bounded formulas

The present definition of bounded formulas emerged from a discussion on GitHub between Jim Kingdon, Mario Carneiro and I, started 23-Sept-2019 (see https://github.com/metamath/set.mm/issues/1173 and links therein).

In order to state certain axiom schemes of Constructive Zermelo–Fraenkel (CZF) set theory, like the axiom scheme of bounded (or restricted, or Δ0) separation, it is necessary to distinguish certain formulas, called bounded (or restricted, or Δ0) formulas. The necessity of considering bounded formulas also arises in several theories of bounded arithmetic, both classical or intuitionistic, for instance to state the axiom scheme of Δ0-induction.

To formalize this in Metamath, there are several choices to make.

A first choice is to either create a new type for bounded formulas, or to create a predicate on formulas that indicates whether they are bounded. In the first case, one creates a new type "wff0" with a new set of metavariables (ph0 ...) and an axiom "$a wff ph0 " ensuring that bounded formulas are formulas, so that one can reuse existing theorems, and then axioms take the form "$a wff0 ( ph0 -> ps0 )", etc. In the second case, one introduces a predicate "BOUNDED " with the intended meaning that "BOUNDED  ph " is a formula meaning that  ph is a bounded formula. We choose the second option, since the first would complicate the grammar, risking to make it ambiguous. (TODO: elaborate.)

A second choice is to view "bounded" either as a syntactic or a semantic property. For instance,  A. x T. is not syntactically bounded since it has an unbounded universal quantifier, but it is semantically bounded since it is equivalent to T. which is bounded. We choose the second option, so that formulas using defined symbols can be proved bounded.

A third choice is in the form of the axioms, either in closed form or in inference form. One cannot state all the axioms in closed form, especially ax-bd0 13182. Indeed, if we posited it in closed form, then we could prove for instance  |-  ( ph  -> BOUNDED  ph ) and  |-  ( -.  ph  -> BOUNDED  ph ) which is problematic (with the law of excluded middle, this would entail that all formulas are bounded, but even without it, too many formulas could be proved bounded...). (TODO: elaborate.)

Having ax-bd0 13182 in inference form ensures that a formula can be proved bounded only if it is equivalent *for all values of the free variables* to a syntactically bounded one. The other axioms (ax-bdim 13183 through ax-bdsb 13191) can be written either in closed or inference form. The fact that ax-bd0 13182 is an inference is enough to ensure that the closed forms cannot be "exploited" to prove that some unbounded formulas are bounded. (TODO: check.) However, we state all the axioms in inference form to make it clear that we do not exploit any over-permissiveness.

Finally, note that our logic has no terms, only variables. Therefore, we cannot prove for instance that  x  e.  om is a bounded formula. However, since  om can be defined as "the  y such that PHI" a proof using the fact that  x  e.  om is bounded can be converted to a proof in iset.mm by replacing  om with  y everywhere and prepending the antecedent PHI, since  x  e.  y is bounded by ax-bdel 13190. For a similar method, see bj-omtrans 13325.

Note that one cannot add an axiom  |- BOUNDED  x  e.  A since by bdph 13219 it would imply that every formula is bounded.

 
Syntaxwbd 13181 Syntax for the predicate BOUNDED.
 wff BOUNDED  ph
 
Axiomax-bd0 13182 If two formulas are equivalent, then boundedness of one implies boundedness of the other. (Contributed by BJ, 3-Oct-2019.)
 |-  ( ph 
 <->  ps )   =>    |-  (BOUNDED  ph  -> BOUNDED  ps )
 
Axiomax-bdim 13183 An implication between two bounded formulas is bounded. (Contributed by BJ, 25-Sep-2019.)
 |- BOUNDED  ph   &    |- BOUNDED  ps   =>    |- BOUNDED  ( ph  ->  ps )
 
Axiomax-bdan 13184 The conjunction of two bounded formulas is bounded. (Contributed by BJ, 25-Sep-2019.)
 |- BOUNDED  ph   &    |- BOUNDED  ps   =>    |- BOUNDED  ( ph  /\  ps )
 
Axiomax-bdor 13185 The disjunction of two bounded formulas is bounded. (Contributed by BJ, 25-Sep-2019.)
 |- BOUNDED  ph   &    |- BOUNDED  ps   =>    |- BOUNDED  ( ph  \/  ps )
 
Axiomax-bdn 13186 The negation of a bounded formula is bounded. (Contributed by BJ, 25-Sep-2019.)
 |- BOUNDED  ph   =>    |- BOUNDED  -.  ph
 
Axiomax-bdal 13187* A bounded universal quantification of a bounded formula is bounded. Note the disjoint variable condition on  x ,  y. (Contributed by BJ, 25-Sep-2019.)
 |- BOUNDED  ph   =>    |- BOUNDED  A. x  e.  y  ph
 
Axiomax-bdex 13188* A bounded existential quantification of a bounded formula is bounded. Note the disjoint variable condition on  x ,  y. (Contributed by BJ, 25-Sep-2019.)
 |- BOUNDED  ph   =>    |- BOUNDED  E. x  e.  y  ph
 
Axiomax-bdeq 13189 An atomic formula is bounded (equality predicate). (Contributed by BJ, 3-Oct-2019.)
 |- BOUNDED  x  =  y
 
Axiomax-bdel 13190 An atomic formula is bounded (membership predicate). (Contributed by BJ, 3-Oct-2019.)
 |- BOUNDED  x  e.  y
 
Axiomax-bdsb 13191 A formula resulting from proper substitution in a bounded formula is bounded. This probably cannot be proved from the other axioms, since neither the definiens in df-sb 1737, nor probably any other equivalent formula, is syntactically bounded. (Contributed by BJ, 3-Oct-2019.)
 |- BOUNDED  ph   =>    |- BOUNDED  [
 y  /  x ] ph
 
Theorembdeq 13192 Equality property for the predicate BOUNDED. (Contributed by BJ, 3-Oct-2019.)
 |-  ( ph 
 <->  ps )   =>    |-  (BOUNDED  ph 
 <-> BOUNDED  ps )
 
Theorembd0 13193 A formula equivalent to a bounded one is bounded. See also bd0r 13194. (Contributed by BJ, 3-Oct-2019.)
 |- BOUNDED  ph   &    |-  ( ph  <->  ps )   =>    |- BOUNDED  ps
 
Theorembd0r 13194 A formula equivalent to a bounded one is bounded. Stated with a commuted (compared with bd0 13193) biconditional in the hypothesis, to work better with definitions (
ps is the definiendum that one wants to prove bounded). (Contributed by BJ, 3-Oct-2019.)
 |- BOUNDED  ph   &    |-  ( ps  <->  ph )   =>    |- BOUNDED  ps
 
Theorembdbi 13195 A biconditional between two bounded formulas is bounded. (Contributed by BJ, 3-Oct-2019.)
 |- BOUNDED  ph   &    |- BOUNDED  ps   =>    |- BOUNDED  ( ph 
 <->  ps )
 
Theorembdstab 13196 Stability of a bounded formula is bounded. (Contributed by BJ, 3-Oct-2019.)
 |- BOUNDED  ph   =>    |- BOUNDED STAB  ph
 
Theorembddc 13197 Decidability of a bounded formula is bounded. (Contributed by BJ, 3-Oct-2019.)
 |- BOUNDED  ph   =>    |- BOUNDED DECID  ph
 
Theorembd3or 13198 A disjunction of three bounded formulas is bounded. (Contributed by BJ, 3-Oct-2019.)
 |- BOUNDED  ph   &    |- BOUNDED  ps   &    |- BOUNDED  ch   =>    |- BOUNDED  ( ph  \/  ps  \/  ch )
 
Theorembd3an 13199 A conjunction of three bounded formulas is bounded. (Contributed by BJ, 3-Oct-2019.)
 |- BOUNDED  ph   &    |- BOUNDED  ps   &    |- BOUNDED  ch   =>    |- BOUNDED  ( ph  /\  ps  /\ 
 ch )
 
Theorembdth 13200 A truth (a (closed) theorem) is a bounded formula. (Contributed by BJ, 6-Oct-2019.)
 |-  ph   =>    |- BOUNDED  ph
    < Previous  Next >

Page List
Jump to page: Contents  1 1-100 2 101-200 3 201-300 4 301-400 5 401-500 6 501-600 7 601-700 8 701-800 9 801-900 10 901-1000 11 1001-1100 12 1101-1200 13 1201-1300 14 1301-1400 15 1401-1500 16 1501-1600 17 1601-1700 18 1701-1800 19 1801-1900 20 1901-2000 21 2001-2100 22 2101-2200 23 2201-2300 24 2301-2400 25 2401-2500 26 2501-2600 27 2601-2700 28 2701-2800 29 2801-2900 30 2901-3000 31 3001-3100 32 3101-3200 33 3201-3300 34 3301-3400 35 3401-3500 36 3501-3600 37 3601-3700 38 3701-3800 39 3801-3900 40 3901-4000 41 4001-4100 42 4101-4200 43 4201-4300 44 4301-4400 45 4401-4500 46 4501-4600 47 4601-4700 48 4701-4800 49 4801-4900 50 4901-5000 51 5001-5100 52 5101-5200 53 5201-5300 54 5301-5400 55 5401-5500 56 5501-5600 57 5601-5700 58 5701-5800 59 5801-5900 60 5901-6000 61 6001-6100 62 6101-6200 63 6201-6300 64 6301-6400 65 6401-6500 66 6501-6600 67 6601-6700 68 6701-6800 69 6801-6900 70 6901-7000 71 7001-7100 72 7101-7200 73 7201-7300 74 7301-7400 75 7401-7500 76 7501-7600 77 7601-7700 78 7701-7800 79 7801-7900 80 7901-8000 81 8001-8100 82 8101-8200 83 8201-8300 84 8301-8400 85 8401-8500 86 8501-8600 87 8601-8700 88 8701-8800 89 8801-8900 90 8901-9000 91 9001-9100 92 9101-9200 93 9201-9300 94 9301-9400 95 9401-9500 96 9501-9600 97 9601-9700 98 9701-9800 99 9801-9900 100 9901-10000 101 10001-10100 102 10101-10200 103 10201-10300 104 10301-10400 105 10401-10500 106 10501-10600 107 10601-10700 108 10701-10800 109 10801-10900 110 10901-11000 111 11001-11100 112 11101-11200 113 11201-11300 114 11301-11400 115 11401-11500 116 11501-11600 117 11601-11700 118 11701-11800 119 11801-11900 120 11901-12000 121 12001-12100 122 12101-12200 123 12201-12300 124 12301-12400 125 12401-12500 126 12501-12600 127 12601-12700 128 12701-12800 129 12801-12900 130 12901-13000 131 13001-13100 132 13101-13200 133 13201-13300 134 13301-13400 135 13401-13441
  Copyright terms: Public domain < Previous  Next >