non associative with precedence 55
for @{ 'SnItem2 $I $T1 $T }.
-notation "hvbox( ⓑ { I } break term 55 T1 . break term 55 T )"
+notation "hvbox( ⓑ { a , I } break term 55 T1 . break term 55 T )"
non associative with precedence 55
- for @{ 'SnBind2 $I $T1 $T }.
+ for @{ 'SnBind2 $a $I $T1 $T }.
+
+notation "hvbox( + ⓑ { I } break term 55 T1 . break term 55 T )"
+ non associative with precedence 55
+ for @{ 'SnBind2Pos $I $T1 $T }.
+
+notation "hvbox( - ⓑ { I } break term 55 T1 . break term 55 T )"
+ non associative with precedence 55
+ for @{ 'SnBind2Neg $I $T1 $T }.
notation "hvbox( ⓕ { I } break term 55 T1 . break term 55 T )"
non associative with precedence 55
for @{ 'SnFlat2 $I $T1 $T }.
-notation "hvbox( ⓓ term 55 T1 . break term 55 T2 )"
+notation "hvbox( ⓓ { a } term 55 T1 . break term 55 T2 )"
+ non associative with precedence 55
+ for @{ 'SnAbbr $a $T1 $T2 }.
+
+notation "hvbox( + ⓓ term 55 T1 . break term 55 T2 )"
+ non associative with precedence 55
+ for @{ 'SnAbbrPos $T1 $T2 }.
+
+notation "hvbox( - ⓓ term 55 T1 . break term 55 T2 )"
+ non associative with precedence 55
+ for @{ 'SnAbbrNeg $T1 $T2 }.
+
+notation "hvbox( ⓛ { a } term 55 T1 . break term 55 T2 )"
+ non associative with precedence 55
+ for @{ 'SnAbst $a $T1 $T2 }.
+
+notation "hvbox( + ⓛ term 55 T1 . break term 55 T2 )"
non associative with precedence 55
- for @{ 'SnAbbr $T1 $T2 }.
+ for @{ 'SnAbstPos $T1 $T2 }.
-notation "hvbox( ⓛ term 55 T1 . break term 55 T2 )"
+notation "hvbox( - ⓛ term 55 T1 . break term 55 T2 )"
non associative with precedence 55
- for @{ 'SnAbst $T1 $T2 }.
+ for @{ 'SnAbstNeg $T1 $T2 }.
notation "hvbox( ⓐ term 55 T1 . break term 55 T2 )"
non associative with precedence 55
for @{ 'SnAppl $T1 $T2 }.
-notation "hvbox( â\93£ term 55 T1 . break term 55 T2 )"
+notation "hvbox( â\93\9d term 55 T1 . break term 55 T2 )"
non associative with precedence 55
for @{ 'SnCast $T1 $T2 }.
non associative with precedence 50
for @{ 'DxItem4 $T $I $T1 $T2 $T3 }.
-notation "hvbox( # [ x ] )"
+notation "hvbox( # { x } )"
non associative with precedence 90
for @{ 'Weight $x }.
-notation "hvbox( # [ x , break y ] )"
+notation "hvbox( # { x , break y } )"
non associative with precedence 90
for @{ 'Weight $x $y }.
(* Substitution *************************************************************)
-notation "hvbox( L ⊢ break 𝐑 [ d , break e ] break ⦃ T ⦄ )"
- non associative with precedence 45
- for @{ 'Reducible $L $d $e $T }.
-
-notation "hvbox( L ⊢ break 𝐈 [ d , break e ] break ⦃ T ⦄ )"
- non associative with precedence 45
- for @{ 'NotReducible $L $d $e $T }.
-
-notation "hvbox( L ⊢ break 𝐍 [ d , break e ] break ⦃ T ⦄ )"
- non associative with precedence 45
- for @{ 'Normal $L $d $e $T }.
-
notation "hvbox( ⇧ [ d , break e ] break term 46 T1 ≡ break term 46 T2 )"
non associative with precedence 45
for @{ 'RLift $d $e $T1 $T2 }.
non associative with precedence 45
for @{ 'SubEq $T1 $d $e $T2 }.
-notation "hvbox( â\89¼ [ d , break e ] break term 46 T2 )"
+notation "hvbox( â\89½ [ d , break e ] break term 46 T2 )"
non associative with precedence 45
- for @{ 'SubEqTop $d $e $T2 }.
+ for @{ 'SubEqBottom $d $e $T2 }.
notation "hvbox( ⇩ [ e ] break term 46 L1 ≡ break term 46 L2 )"
non associative with precedence 45
(* Unfold *******************************************************************)
-notation "hvbox( @ [ T1 ] break term 46 f ≡ break term 46 T2 )"
+notation "hvbox( @ ⦃ T1 , break f ⦄ ≡ break term 46 T2 )"
non associative with precedence 45
for @{ 'RAt $T1 $f $T2 }.
non associative with precedence 45
for @{ 'RDropStar $e $L1 $L2 }.
-notation "hvbox( T1 break ▶* [ d , break e ] break term 46 T2 )"
+notation "hvbox( T1 break ▶ * [ d , break e ] break term 46 T2 )"
non associative with precedence 45
for @{ 'PSubstStar $T1 $d $e $T2 }.
-notation "hvbox( L ⊢ break term 46 T1 break ▶* [ d , break e ] break term 46 T2 )"
+notation "hvbox( L ⊢ break term 46 T1 break ▶ * [ d , break e ] break term 46 T2 )"
non associative with precedence 45
for @{ 'PSubstStar $L $T1 $d $e $T2 }.
-notation "hvbox( L ⊢ break term 46 T1 break ▶▶* [ d , break e ] break term 46 T2 )"
+notation "hvbox( L ⊢ break term 46 T1 break ▶ ▶ * [ d , break e ] break term 46 T2 )"
non associative with precedence 45
for @{ 'PSubstStarAlt $L $T1 $d $e $T2 }.
-notation "hvbox( T1 break [ d , break e ] ≡ break term 46 T2 )"
+notation "hvbox( ▼ * [ d , break e ] break term 46 T1 ≡ break term 46 T2 )"
non associative with precedence 45
for @{ 'TSubst $T1 $d $e $T2 }.
-notation "hvbox( L ⊢ break term 46 T1 break [ d , break e ] ≡ break term 46 T2 )"
+notation "hvbox( L ⊢ break ▼ * [ d , break e ] break term 46 T1 ≡ break term 46 T2 )"
non associative with precedence 45
for @{ 'TSubst $L $T1 $d $e $T2 }.
-notation "hvbox( T1 break [ d , break e ] ≡ ≡ break term 46 T2 )"
+notation "hvbox( ▼ ▼ * [ d , break e ] break term 46 T1 ≡ break term 46 T2 )"
non associative with precedence 45
for @{ 'TSubstAlt $T1 $d $e $T2 }.
-notation "hvbox( L ⊢ break term 46 T1 break [ d , break e ] ≡ ≡ break term 46 T2 )"
+notation "hvbox( L ⊢ break ▼ ▼ * [ d , break e ] break term 46 T1 ≡ break term 46 T2 )"
non associative with precedence 45
for @{ 'TSubstAlt $L $T1 $d $e $T2 }.
non associative with precedence 45
for @{ 'CrSubEqA $T1 $T2 }.
-notation "hvbox( L ⊢ break term 46 T ÷ break term 46 A )"
+notation "hvbox( ⦃ h , break L ⦄ ⊢ break term 46 T ÷ break term 46 A )"
+ non associative with precedence 45
+ for @{ 'BinaryArity $h $L $T $A }.
+
+notation "hvbox( h ⊢ break term 46 L1 ÷ ⊑ break term 46 L2 )"
non associative with precedence 45
- for @{ 'BinaryArity $L $T $A }.
+ for @{ 'CrSubEqB $h $L1 $L2 }.
-notation "hvbox( T1 ÷ ⊑ break term 46 T2 )"
+notation "hvbox( ⦃ h , break L ⦄ ⊢ break term 46 T1 • break [ g , break l ] break term 46 T2 )"
non associative with precedence 45
- for @{ 'CrSubEqB $T1 $T2 }.
+ for @{ 'StaticType $h $g $l $L $T1 $T2 }.
-notation "hvbox( ⦃ h , break L ⦄ ⊢ break term 46 T1 • break term 46 T2 )"
+notation "hvbox( h ⊢ break term 46 L1 • ⊑ [ g ] break term 46 L2 )"
non associative with precedence 45
- for @{ 'StaticType $h $L $T1 $T2 }.
+ for @{ 'CrSubEqS $h $g $L1 $L2 }.
(* Unwind *******************************************************************)
-notation "hvbox( ⦃ h , break L ⦄ ⊢ break term 46 T1 •* break term 46 T2 )"
+notation "hvbox( L1 ⊢ ⧫ * break term 46 T ≡ break term 46 L2 )"
non associative with precedence 45
- for @{ 'StaticTypeStar $h $L $T1 $T2 }.
+ for @{ 'Unwind $L1 $T $L2 }.
(* Reducibility *************************************************************)
-notation "hvbox( 𝐑 ⦃ T ⦄ )"
- non associative with precedence 45
- for @{ 'Reducible $T }.
-
notation "hvbox( L ⊢ break 𝐑 ⦃ T ⦄ )"
non associative with precedence 45
for @{ 'Reducible $L $T }.
-notation "hvbox( 𝐈 ⦃ T ⦄ )"
- non associative with precedence 45
- for @{ 'NotReducible $T }.
-
notation "hvbox( L ⊢ break 𝐈 ⦃ T ⦄ )"
non associative with precedence 45
for @{ 'NotReducible $L $T }.
-notation "hvbox( 𝐍 ⦃ T ⦄ )"
- non associative with precedence 45
- for @{ 'Normal $T }.
-
notation "hvbox( L ⊢ break 𝐍 ⦃ T ⦄ )"
non associative with precedence 45
for @{ 'Normal $L $T }.
-notation "hvbox( 𝐖𝐇𝐑 ⦃ T ⦄ )"
+(* this might be removed *)
+notation "hvbox( 𝐇𝐑 ⦃ T ⦄ )"
non associative with precedence 45
- for @{ 'WHdReducible $T }.
+ for @{ 'HdReducible $T }.
-notation "hvbox( L ⊢ break 𝐖𝐇𝐑 ⦃ T ⦄ )"
+(* this might be removed *)
+notation "hvbox( L ⊢ break 𝐇𝐑 ⦃ T ⦄ )"
non associative with precedence 45
- for @{ 'WHdReducible $L $T }.
+ for @{ 'HdReducible $L $T }.
-notation "hvbox( 𝐖𝐇𝐈 ⦃ T ⦄ )"
+(* this might be removed *)
+notation "hvbox( 𝐇𝐈 ⦃ T ⦄ )"
non associative with precedence 45
- for @{ 'NotWHdReducible $T }.
+ for @{ 'NotHdReducible $T }.
-notation "hvbox( L ⊢ break 𝐖𝐇𝐈 ⦃ T ⦄ )"
+(* this might be removed *)
+notation "hvbox( L ⊢ break 𝐇𝐈 ⦃ T ⦄ )"
non associative with precedence 45
- for @{ 'NotWHdReducible $L $T }.
+ for @{ 'NotHdReducible $L $T }.
-notation "hvbox( 𝐖𝐇𝐍 ⦃ T ⦄ )"
+(* this might be removed *)
+notation "hvbox( 𝐇𝐍 ⦃ T ⦄ )"
non associative with precedence 45
- for @{ 'WHdNormal $T }.
+ for @{ 'HdNormal $T }.
-notation "hvbox( L ⊢ break 𝐖𝐇𝐍 ⦃ T ⦄ )"
+(* this might be removed *)
+notation "hvbox( L ⊢ break 𝐇𝐍 ⦃ T ⦄ )"
non associative with precedence 45
- for @{ 'WHdNormal $L $T }.
+ for @{ 'HdNormal $L $T }.
notation "hvbox( T1 ➡ break term 46 T2 )"
non associative with precedence 45
non associative with precedence 45
for @{ 'CPRed $L1 $L2 }.
+notation "hvbox( ⦃ L1 ⦄ ➡ break ⦃ L2 ⦄ )"
+ non associative with precedence 45
+ for @{ 'FocalizedPRed $L1 $L2 }.
+
+notation "hvbox( ⦃ L1, break T1 ⦄ ➡ break ⦃ L2 , break T2 ⦄ )"
+ non associative with precedence 45
+ for @{ 'FocalizedPRed $L1 $T1 $L2 $T2 }.
+
+notation "hvbox( ⦃ L1 ⦄ ➡ ➡ break ⦃ L2 ⦄ )"
+ non associative with precedence 45
+ for @{ 'FocalizedPRedAlt $L1 $L2 }.
+
+notation "hvbox( ⦃ h , break L ⦄ ⊢ break term 46 T1 ➸ break [ g ] break term 46 T2 )"
+ non associative with precedence 45
+ for @{ 'XPRed $h $g $L $T1 $T2 }.
+
(* Computation **************************************************************)
notation "hvbox( T1 ➡* break term 46 T2 )"
non associative with precedence 45
for @{ 'PRedStar $L $T1 $T2 }.
+notation "hvbox( T1 ➡➡* break term 46 T2 )"
+ non associative with precedence 45
+ for @{ 'PRedStarAlt $T1 $T2 }.
+
notation "hvbox( L1 ⊢ ➡* break term 46 L2 )"
non associative with precedence 45
for @{ 'CPRedStar $L1 $L2 }.
non associative with precedence 45
for @{ 'PEval $L $T1 $T2 }.
-notation "hvbox( â¬\87 * term 46 T )"
+notation "hvbox( â¬\8a * term 46 T )"
non associative with precedence 45
for @{ 'SN $T }.
-notation "hvbox( L ⊢ break ⬇ * term 46 T )"
+notation "hvbox( L ⊢ ⬊ * break term 46 T )"
non associative with precedence 45
for @{ 'SN $L $T }.
-notation "hvbox( L ⊢ break ⬇ ⬇ * term 46 T )"
+notation "hvbox( L ⊢ ⬊ ⬊ * break term 46 T )"
non associative with precedence 45
for @{ 'SNAlt $L $T }.
non associative with precedence 45
for @{ 'CrSubEq $T1 $R $T2 }.
+notation "hvbox( ⦃ h , break L ⦄ ⊢ break term 46 T1 ➸ * break [ g ] break term 46 T2 )"
+ non associative with precedence 45
+ for @{ 'XPRedStar $h $g $L $T1 $T2 }.
+
+notation "hvbox( ⦃ h , break L ⦄ ⊢ ➷ * break [ g ] break term 46 T2 )"
+ non associative with precedence 45
+ for @{ 'XSN $h $g $L $T }.
+
(* Conversion ***************************************************************)
notation "hvbox( L ⊢ break term 46 T1 ⬌ break term 46 T2 )"
(* Dynamic typing ***********************************************************)
+notation "hvbox( ⦃ h , break L ⦄ ⊩ break term 46 T : break [ g ] )"
+ non associative with precedence 45
+ for @{ 'NativeValid $h $g $L $T }.
+
notation "hvbox( ⦃ h , break L ⦄ ⊢ break term 46 T1 : break term 46 T2 )"
non associative with precedence 45
for @{ 'NativeType $h $L $T1 $T2 }.
-notation "hvbox( ⦃ h , break L ⦄ ⊢ break term 46 T1 :: break term 46 T2 )"
+notation "hvbox( ⦃ h , break L ⦄ ⊢ break term 46 T1 : : break term 46 T2 )"
non associative with precedence 45
for @{ 'NativeTypeAlt $h $L $T1 $T2 }.
-notation "hvbox( h ⊢ break term 46 L1 : ⊑ break term 46 L2 )"
+(* Higher order dynamic typing **********************************************)
+
+notation "hvbox( ⦃ h , break L ⦄ ⊢ break term 46 T1 : * break term 46 T2 )"
non associative with precedence 45
- for @{ 'CrSubEqN $h $L1 $L2 }.
+ for @{ 'NativeTypeStar $h $L $T1 $T2 }.