MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  df-clab Structured version   Visualization version   GIF version

Definition df-clab 2708
Description: Define class abstractions, that is, classes of the form {𝑦𝜑}, which is read "the class of sets 𝑦 such that 𝜑(𝑦)".

A few remarks are in order:

1. The axiomatic statement df-clab 2708 does not define the class abstraction {𝑦𝜑} itself, that is, it does not have the form {𝑦𝜑} = ... that a standard definition should have (for a good reason: equality itself has not yet been defined or axiomatized for class abstractions; it is defined later in df-cleq 2721). Instead, df-clab 2708 has the form (𝑥 ∈ {𝑦𝜑} ↔ ...), meaning that it only defines what it means for a setvar to be a member of a class abstraction. As a consequence, one can say that df-clab 2708 defines class abstractions if and only if a class abstraction is completely determined by which elements belong to it, which is the content of the axiom of extensionality ax-ext 2701. Therefore, df-clab 2708 can be considered a definition only in systems that can prove ax-ext 2701 (and the necessary first-order logic).

2. As in all definitions, the definiendum (the left-hand side of the biconditional) has no disjoint variable conditions. In particular, the setvar variables 𝑥 and 𝑦 need not be distinct, and the formula 𝜑 may depend on both 𝑥 and 𝑦. This is necessary, as with all definitions, since if there was for instance a disjoint variable condition on 𝑥, 𝑦, then one could not do anything with expressions like 𝑥 ∈ {𝑥𝜑} which are sometimes useful to shorten proofs (because of abid 2711). Most often, however, 𝑥 does not occur in {𝑦𝜑} and 𝑦 is free in 𝜑.

3. Remark 1 stresses that df-clab 2708 does not have the standard form of a definition for a class, but one could be led to think it has the standard form of a definition for a formula. However, it also fails that test since the membership predicate has already appeared earlier (outside of syntax e.g. in ax-8 2111). Indeed, the definiendum extends, or "overloads", the membership predicate from formulas of the form "setvar setvar" to formulas of the form "setvar class abstraction". This is possible because of wcel 2109 and cab 2707, and it can be called an "extension" of the membership predicate because of wel 2110, whose proof uses cv 1539. An a posteriori justification for cv 1539 is given by cvjust 2723, stating that every setvar can be written as a class abstraction (though conversely not every class abstraction is a set, as illustrated by Russell's paradox ru 3742).

4. Proof techniques. Because class variables can be substituted with compound expressions and setvar variables cannot, it is often useful to convert a theorem containing a free setvar variable to a more general version with a class variable. This is done with theorems such as vtoclg 3511 which is used, for example, to convert elirrv 9508 to elirr 9510.

5. Definition or axiom? The question arises with the three axiomatic statements introducing classes, df-clab 2708, df-cleq 2721, and df-clel 2803, to decide if they qualify as definitions or if they should be called axioms. Under the strict definition of "definition" (see conventions 30362), they are not definitions (see Remarks 1 and 3 above, and similarly for df-cleq 2721 and df-clel 2803). One could be less strict and decide to call "definition" every axiomatic statement which provides an eliminable and conservative extension of the considered axiom system. But the notion of conservativity may be given two different meanings in set.mm, due to the difference between the "scheme level" of set.mm and the "object level" of classical treatments. For a proof that these three axiomatic statements yield an eliminable and weakly (that is, object-level) conservative extension of FOL= plus ax-ext 2701, see Appendix of [Levy] p. 357.

6. References and history. The concept of class abstraction dates back to at least Frege, and is used by Whitehead and Russell. This definition is Definition 2.1 of [Quine] p. 16 and Axiom 4.3.1 of [Levy] p. 12. It is called the "axiom of class comprehension" by [Levy] p. 358, who treats the theory of classes as an extralogical extension to predicate logic and set theory axioms. He calls the construction {𝑦𝜑} a "class term". For a full description of how classes are introduced and how to recover the primitive language, see the books of Quine and Levy (and the comment of eqabb 2867 for a quick overview). For a general discussion of the theory of classes, see mmset.html#class 2867. (Contributed by NM, 26-May-1993.) (Revised by BJ, 19-Aug-2023.)

Assertion
Ref Expression
df-clab (𝑥 ∈ {𝑦𝜑} ↔ [𝑥 / 𝑦]𝜑)

Detailed syntax breakdown of Definition df-clab
StepHypRef Expression
1 vx . . . 4 setvar 𝑥
21cv 1539 . . 3 class 𝑥
3 wph . . . 4 wff 𝜑
4 vy . . . 4 setvar 𝑦
53, 4cab 2707 . . 3 class {𝑦𝜑}
62, 5wcel 2109 . 2 wff 𝑥 ∈ {𝑦𝜑}
73, 4, 1wsb 2065 . 2 wff [𝑥 / 𝑦]𝜑
86, 7wb 206 1 wff (𝑥 ∈ {𝑦𝜑} ↔ [𝑥 / 𝑦]𝜑)
Colors of variables: wff setvar class
This definition is referenced by:  eleq1ab  2709  abid  2711  vexwt  2712  vexw  2713  nfsab1  2715  hbab  2717  hbabg  2718  cvjust  2723  abbi  2794  abbib  2798  cbvabv  2799  cbvabw  2800  cbvab  2801  eqabbw  2802  eqabdv  2861  clelab  2873  nfaba1  2899  nfabdw  2913  nfabd  2914  rabrabi  3416  abv  3450  abvALT  3451  elab6g  3626  elabgw  3635  elrabi  3645  ralab  3655  dfsbcq2  3747  sbc8g  3752  sbcimdv  3813  sbcg  3817  csbied  3889  dfss2  3923  ss2abdv  4020  unabw  4260  unab  4261  inab  4262  difab  4263  notabw  4266  noel  4291  vn0  4298  eq0  4303  ab0w  4332  ab0orv  4336  eq0rdv  4360  csbab  4393  disj  4403  rzal  4462  ralf0  4467  exss  5410  iotaeq  6454  abrexex2g  7906  opabex3d  7907  opabex3rd  7908  opabex3  7909  axregs  35073  xpab  35698  in-ax8  36197  ss-ax8  36198  cbvabdavw  36229  eliminable1  36832  eliminable-velab  36838  bj-ab0  36881  bj-elabd2ALT  36898  bj-gabima  36913  bj-snsetex  36936  wl-df-clab  37477  wl-clabv  37568  wl-clabtv  37570  wl-clabt  37571  ss2ab1  42192  scottabf  44213
  Copyright terms: Public domain W3C validator