|
|
|
|
|
by takemikazuchi
4174 days ago
|
|
This is a bit of tangent, but I looked up Idris since I'd never heard of it. I'm currently learning Haskell and they look really similar. What differentiates the two? What can you do in one that you can't do in the other? |
|
But fundamentally Idris is theoretically more advanced than Haskell. The core differences are
1. Idris functions can be proven to terminate (if you choose).
2. In Idris, types are first class values, and you can have dependent functions: functions whose return type depends on their input value.
An example of something you can do in Idris and not* in Haskell, in Idris you can define a vector type Vect n a, which is the type of vectors of length n with values in type a. You can also define Fin n, the set of integers less than n. Then you can define a function index : Fin n -> (Vect n a) -> a which takes an integer less than n, a vector of length n with element of type a, and returns an element of type a. This function is guaranteed to return a value, because the index is guaranteed to be in the correct range.
*For some meaning of "not": you can probably do this in some way in Haskell.