ILE Home Intuitionistic Logic Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  ILE Home  >  Th. List  >  ispsmet GIF version

Theorem ispsmet 14962
Description: Express the predicate "𝐷 is a pseudometric". (Contributed by Thierry Arnoux, 7-Feb-2018.)
Assertion
Ref Expression
ispsmet (𝑋𝑉 → (𝐷 ∈ (PsMet‘𝑋) ↔ (𝐷:(𝑋 × 𝑋)⟶ℝ* ∧ ∀𝑥𝑋 ((𝑥𝐷𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝐷𝑦) ≤ ((𝑧𝐷𝑥) +𝑒 (𝑧𝐷𝑦))))))
Distinct variable groups:   𝑥,𝑦,𝑧,𝑋   𝑥,𝐷,𝑦,𝑧
Allowed substitution hints:   𝑉(𝑥,𝑦,𝑧)

Proof of Theorem ispsmet
Dummy variables 𝑢 𝑑 𝑓 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 df-psmet 14472 . . . . 5 PsMet = (𝑢 ∈ V ↦ {𝑑 ∈ (ℝ*𝑚 (𝑢 × 𝑢)) ∣ ∀𝑥𝑢 ((𝑥𝑑𝑥) = 0 ∧ ∀𝑦𝑢𝑧𝑢 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦)))})
2 id 19 . . . . . . . 8 (𝑢 = 𝑋𝑢 = 𝑋)
32sqxpeqd 4722 . . . . . . 7 (𝑢 = 𝑋 → (𝑢 × 𝑢) = (𝑋 × 𝑋))
43oveq2d 5990 . . . . . 6 (𝑢 = 𝑋 → (ℝ*𝑚 (𝑢 × 𝑢)) = (ℝ*𝑚 (𝑋 × 𝑋)))
5 raleq 2708 . . . . . . . . 9 (𝑢 = 𝑋 → (∀𝑧𝑢 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦)) ↔ ∀𝑧𝑋 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦))))
65raleqbi1dv 2720 . . . . . . . 8 (𝑢 = 𝑋 → (∀𝑦𝑢𝑧𝑢 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦)) ↔ ∀𝑦𝑋𝑧𝑋 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦))))
76anbi2d 464 . . . . . . 7 (𝑢 = 𝑋 → (((𝑥𝑑𝑥) = 0 ∧ ∀𝑦𝑢𝑧𝑢 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦))) ↔ ((𝑥𝑑𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦)))))
87raleqbi1dv 2720 . . . . . 6 (𝑢 = 𝑋 → (∀𝑥𝑢 ((𝑥𝑑𝑥) = 0 ∧ ∀𝑦𝑢𝑧𝑢 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦))) ↔ ∀𝑥𝑋 ((𝑥𝑑𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦)))))
94, 8rabeqbidv 2774 . . . . 5 (𝑢 = 𝑋 → {𝑑 ∈ (ℝ*𝑚 (𝑢 × 𝑢)) ∣ ∀𝑥𝑢 ((𝑥𝑑𝑥) = 0 ∧ ∀𝑦𝑢𝑧𝑢 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦)))} = {𝑑 ∈ (ℝ*𝑚 (𝑋 × 𝑋)) ∣ ∀𝑥𝑋 ((𝑥𝑑𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦)))})
10 elex 2791 . . . . 5 (𝑋𝑉𝑋 ∈ V)
11 xrex 10020 . . . . . . . 8 * ∈ V
12 sqxpexg 4812 . . . . . . . 8 (𝑋𝑉 → (𝑋 × 𝑋) ∈ V)
13 mapvalg 6775 . . . . . . . 8 ((ℝ* ∈ V ∧ (𝑋 × 𝑋) ∈ V) → (ℝ*𝑚 (𝑋 × 𝑋)) = {𝑓𝑓:(𝑋 × 𝑋)⟶ℝ*})
1411, 12, 13sylancr 414 . . . . . . 7 (𝑋𝑉 → (ℝ*𝑚 (𝑋 × 𝑋)) = {𝑓𝑓:(𝑋 × 𝑋)⟶ℝ*})
15 mapex 6771 . . . . . . . 8 (((𝑋 × 𝑋) ∈ V ∧ ℝ* ∈ V) → {𝑓𝑓:(𝑋 × 𝑋)⟶ℝ*} ∈ V)
1612, 11, 15sylancl 413 . . . . . . 7 (𝑋𝑉 → {𝑓𝑓:(𝑋 × 𝑋)⟶ℝ*} ∈ V)
1714, 16eqeltrd 2286 . . . . . 6 (𝑋𝑉 → (ℝ*𝑚 (𝑋 × 𝑋)) ∈ V)
18 rabexg 4206 . . . . . 6 ((ℝ*𝑚 (𝑋 × 𝑋)) ∈ V → {𝑑 ∈ (ℝ*𝑚 (𝑋 × 𝑋)) ∣ ∀𝑥𝑋 ((𝑥𝑑𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦)))} ∈ V)
1917, 18syl 14 . . . . 5 (𝑋𝑉 → {𝑑 ∈ (ℝ*𝑚 (𝑋 × 𝑋)) ∣ ∀𝑥𝑋 ((𝑥𝑑𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦)))} ∈ V)
201, 9, 10, 19fvmptd3 5701 . . . 4 (𝑋𝑉 → (PsMet‘𝑋) = {𝑑 ∈ (ℝ*𝑚 (𝑋 × 𝑋)) ∣ ∀𝑥𝑋 ((𝑥𝑑𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦)))})
2120eleq2d 2279 . . 3 (𝑋𝑉 → (𝐷 ∈ (PsMet‘𝑋) ↔ 𝐷 ∈ {𝑑 ∈ (ℝ*𝑚 (𝑋 × 𝑋)) ∣ ∀𝑥𝑋 ((𝑥𝑑𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦)))}))
22 oveq 5980 . . . . . . 7 (𝑑 = 𝐷 → (𝑥𝑑𝑥) = (𝑥𝐷𝑥))
2322eqeq1d 2218 . . . . . 6 (𝑑 = 𝐷 → ((𝑥𝑑𝑥) = 0 ↔ (𝑥𝐷𝑥) = 0))
24 oveq 5980 . . . . . . . 8 (𝑑 = 𝐷 → (𝑥𝑑𝑦) = (𝑥𝐷𝑦))
25 oveq 5980 . . . . . . . . 9 (𝑑 = 𝐷 → (𝑧𝑑𝑥) = (𝑧𝐷𝑥))
26 oveq 5980 . . . . . . . . 9 (𝑑 = 𝐷 → (𝑧𝑑𝑦) = (𝑧𝐷𝑦))
2725, 26oveq12d 5992 . . . . . . . 8 (𝑑 = 𝐷 → ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦)) = ((𝑧𝐷𝑥) +𝑒 (𝑧𝐷𝑦)))
2824, 27breq12d 4075 . . . . . . 7 (𝑑 = 𝐷 → ((𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦)) ↔ (𝑥𝐷𝑦) ≤ ((𝑧𝐷𝑥) +𝑒 (𝑧𝐷𝑦))))
29282ralbidv 2534 . . . . . 6 (𝑑 = 𝐷 → (∀𝑦𝑋𝑧𝑋 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦)) ↔ ∀𝑦𝑋𝑧𝑋 (𝑥𝐷𝑦) ≤ ((𝑧𝐷𝑥) +𝑒 (𝑧𝐷𝑦))))
3023, 29anbi12d 473 . . . . 5 (𝑑 = 𝐷 → (((𝑥𝑑𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦))) ↔ ((𝑥𝐷𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝐷𝑦) ≤ ((𝑧𝐷𝑥) +𝑒 (𝑧𝐷𝑦)))))
3130ralbidv 2510 . . . 4 (𝑑 = 𝐷 → (∀𝑥𝑋 ((𝑥𝑑𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦))) ↔ ∀𝑥𝑋 ((𝑥𝐷𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝐷𝑦) ≤ ((𝑧𝐷𝑥) +𝑒 (𝑧𝐷𝑦)))))
3231elrab 2939 . . 3 (𝐷 ∈ {𝑑 ∈ (ℝ*𝑚 (𝑋 × 𝑋)) ∣ ∀𝑥𝑋 ((𝑥𝑑𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝑑𝑦) ≤ ((𝑧𝑑𝑥) +𝑒 (𝑧𝑑𝑦)))} ↔ (𝐷 ∈ (ℝ*𝑚 (𝑋 × 𝑋)) ∧ ∀𝑥𝑋 ((𝑥𝐷𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝐷𝑦) ≤ ((𝑧𝐷𝑥) +𝑒 (𝑧𝐷𝑦)))))
3321, 32bitrdi 196 . 2 (𝑋𝑉 → (𝐷 ∈ (PsMet‘𝑋) ↔ (𝐷 ∈ (ℝ*𝑚 (𝑋 × 𝑋)) ∧ ∀𝑥𝑋 ((𝑥𝐷𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝐷𝑦) ≤ ((𝑧𝐷𝑥) +𝑒 (𝑧𝐷𝑦))))))
34 elmapg 6778 . . . 4 ((ℝ* ∈ V ∧ (𝑋 × 𝑋) ∈ V) → (𝐷 ∈ (ℝ*𝑚 (𝑋 × 𝑋)) ↔ 𝐷:(𝑋 × 𝑋)⟶ℝ*))
3511, 12, 34sylancr 414 . . 3 (𝑋𝑉 → (𝐷 ∈ (ℝ*𝑚 (𝑋 × 𝑋)) ↔ 𝐷:(𝑋 × 𝑋)⟶ℝ*))
3635anbi1d 465 . 2 (𝑋𝑉 → ((𝐷 ∈ (ℝ*𝑚 (𝑋 × 𝑋)) ∧ ∀𝑥𝑋 ((𝑥𝐷𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝐷𝑦) ≤ ((𝑧𝐷𝑥) +𝑒 (𝑧𝐷𝑦)))) ↔ (𝐷:(𝑋 × 𝑋)⟶ℝ* ∧ ∀𝑥𝑋 ((𝑥𝐷𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝐷𝑦) ≤ ((𝑧𝐷𝑥) +𝑒 (𝑧𝐷𝑦))))))
3733, 36bitrd 188 1 (𝑋𝑉 → (𝐷 ∈ (PsMet‘𝑋) ↔ (𝐷:(𝑋 × 𝑋)⟶ℝ* ∧ ∀𝑥𝑋 ((𝑥𝐷𝑥) = 0 ∧ ∀𝑦𝑋𝑧𝑋 (𝑥𝐷𝑦) ≤ ((𝑧𝐷𝑥) +𝑒 (𝑧𝐷𝑦))))))
Colors of variables: wff set class
Syntax hints:  wi 4  wa 104  wb 105   = wceq 1375  wcel 2180  {cab 2195  wral 2488  {crab 2492  Vcvv 2779   class class class wbr 4062   × cxp 4694  wf 5290  cfv 5294  (class class class)co 5974  𝑚 cmap 6765  0cc0 7967  *cxr 8148  cle 8150   +𝑒 cxad 9934  PsMetcpsmet 14464
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-ia1 106  ax-ia2 107  ax-ia3 108  ax-in1 617  ax-in2 618  ax-io 713  ax-5 1473  ax-7 1474  ax-gen 1475  ax-ie1 1519  ax-ie2 1520  ax-8 1530  ax-10 1531  ax-11 1532  ax-i12 1533  ax-bndl 1535  ax-4 1536  ax-17 1552  ax-i9 1556  ax-ial 1560  ax-i5r 1561  ax-13 2182  ax-14 2183  ax-ext 2191  ax-sep 4181  ax-pow 4237  ax-pr 4272  ax-un 4501  ax-setind 4606  ax-cnex 8058  ax-resscn 8059
This theorem depends on definitions:  df-bi 117  df-3an 985  df-tru 1378  df-fal 1381  df-nf 1487  df-sb 1789  df-eu 2060  df-mo 2061  df-clab 2196  df-cleq 2202  df-clel 2205  df-nfc 2341  df-ne 2381  df-ral 2493  df-rex 2494  df-rab 2497  df-v 2781  df-sbc 3009  df-csb 3105  df-dif 3179  df-un 3181  df-in 3183  df-ss 3190  df-pw 3631  df-sn 3652  df-pr 3653  df-op 3655  df-uni 3868  df-br 4063  df-opab 4125  df-mpt 4126  df-id 4361  df-xp 4702  df-rel 4703  df-cnv 4704  df-co 4705  df-dm 4706  df-rn 4707  df-iota 5254  df-fun 5296  df-fn 5297  df-f 5298  df-fv 5302  df-ov 5977  df-oprab 5978  df-mpo 5979  df-map 6767  df-pnf 8151  df-mnf 8152  df-xr 8153  df-psmet 14472
This theorem is referenced by:  psmetdmdm  14963  psmetf  14964  psmet0  14966  psmettri2  14967  psmetres2  14972  xmetpsmet  15008
  Copyright terms: Public domain W3C validator