HTML documentation here.
UVMHS uses lots of unicode symbols. It's strongly encouraged to use a fully featured unicode input mode when editing or using UVMHS. Most people who use UVMHS use the input mode here.
Here is a cross-reference table between common datatypes and their equivalents in both standard Haskell and UVMHS:
Datatype | UVMHS | Standard Haskell |
---|---|---|
bool |
𝔹 |
Bool |
char |
ℂ |
Char |
nat (unbounded) |
ℕ |
Natural |
int (unbounded) |
ℤ |
Integer |
nat 64-bit |
ℕ64 |
Word64 |
int 64-bit |
ℤ64 |
Int64 |
nat 32-bit |
ℕ32 |
Word32 |
int 32-bit |
ℤ32 |
Int32 |
string |
𝕊 |
String = [Char] |
list |
𝐿 a |
[a] |
iterator |
𝐼 a |
[a] |
pair |
a ∧ b |
(a,b) |
tagged union |
a ∨ b |
Either a b |
optional |
𝑂 a |
Maybe a |
dictionary |
k ⇰ a |
Map k a |
set |
𝑃 a |
Set a |
vector |
𝕍 a |
Vector a |
In addition to datatypes, UVMHS uses its own basis of standard type classes upon which the rest of the library builds.
UVMHS Primitive Type Class Functions |
---|
single ∷ (Single a t) ⇒ a → t |
iter ∷ (ToIter a t) ⇒ t → 𝐼 a |
(⋕?) ∷ (Lookup k v t) ⇒ t → k → 𝑂 v |
(⋕) ∷ (Access k v t) ⇒ t → k → v |
UVMHS Type Class Function |
---|
zero ∷ (Zero a) ⇒ a |
(+) ∷ (Plus a) ⇒ a → a → a |
(-) ∷ (Minus a) ⇒ a → a → a |
one ∷ (One a) ⇒ a |
(×) ∷ (Times a) ⇒ a → a → a |
(/) ∷ (Divide a) ⇒ a → a → a |
(⌿) ∷ (DivMod a) ⇒ a → a → a |
(÷) ∷ (DivMod a) ⇒ a → a → a |
(^^) ∷ (Pon a) ⇒ a → a → a |
(^) ∷ (Pow a) ⇒ a → a → a |
root ∷ (Root a) ⇒ a → a |
log ∷ (Log a) ⇒ a → a |
efn ∷ (Efn a) ⇒ a → a |
sin ∷ (Sin a) ⇒ a → a |
cos ∷ (Cos a) ⇒ a → a |
UVMHS Type Class Function |
---|
null ∷ (Null a) ⇒ a |
(⧺) ∷ (Append a) ⇒ a → a → a |
bot ∷ (Bot a) ⇒ a |
(⊔) ∷ (Join a) ⇒ a → a → a |
top ∷ (Top a) ⇒ a |
(⊓) ∷ (Meet a) ⇒ a → a → a |
(⊑) ∷ (POrd a) ⇒ a → a → 𝔹 |
UVMHS Type Class Function |
---|
map ∷ (Functor t) ⇒ t a → t b |
return ∷ (Return m) ⇒ a → m a |
(≫=) ∷ (Bind m) ⇒ m a → (a → m b) → m b |
mapM ∷ (FunctorM t,Monad m) ⇒ (a → m b) → t a → m (t b) |