Created
          April 8, 2018 23:31 
        
      - 
      
- 
        Save cdepillabout/58d1edebdae0035f8d940701b9fceb15 to your computer and use it in GitHub Desktop. 
    This file changes the plusMinusEq law to use Refl (:~:) instead of Dict.
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | {-# LANGUAGE AllowAmbiguousTypes #-} | |
| {-# LANGUAGE ConstraintKinds #-} | |
| {-# LANGUAGE DataKinds #-} | |
| {-# LANGUAGE FlexibleContexts #-} | |
| {-# LANGUAGE FlexibleInstances #-} | |
| {-# LANGUAGE GADTs #-} | |
| {-# LANGUAGE GeneralizedNewtypeDeriving #-} | |
| {-# LANGUAGE InstanceSigs #-} | |
| {-# LANGUAGE KindSignatures #-} | |
| {-# LANGUAGE PolyKinds #-} | |
| {-# LANGUAGE RankNTypes #-} | |
| {-# LANGUAGE ScopedTypeVariables #-} | |
| {-# LANGUAGE StandaloneDeriving #-} | |
| {-# LANGUAGE TypeApplications #-} | |
| {-# LANGUAGE TypeFamilies #-} | |
| {-# LANGUAGE TypeOperators #-} | |
| {-# LANGUAGE TypeInType #-} | |
| module VectStuff5 where | |
| import Data.Constraint (Dict(Dict)) | |
| import Data.Kind (Type) | |
| import Data.Proxy (Proxy(Proxy)) | |
| import Data.Type.Equality | |
| import GHC.TypeLits | |
| (type (+), type (-), KnownNat, Nat, SomeNat(SomeNat), | |
| natVal, sameNat, someNatVal) | |
| import Unsafe.Coerce (unsafeCoerce) | |
| data Vect :: Nat -> Type -> Type where | |
| VNil :: Vect 0 a | |
| VCons :: a -> Vect n a -> Vect (n + 1) a | |
| deriving instance Show a => Show (Vect n a) | |
| plusMinusEq :: forall n m. n :~: ((n - m) + m) | |
| plusMinusEq = unsafeCoerce Refl | |
| unsafeKnownNat :: forall n. KnownNat n => Dict (KnownNat (n - 1)) | |
| unsafeKnownNat = | |
| let int = natVal (Proxy @n) - 1 | |
| in | |
| case someNatVal int of | |
| Nothing -> error "error" | |
| Just (SomeNat (Proxy :: Proxy x)) -> | |
| unsafeCoerce (Dict :: Dict (KnownNat x)) int | |
| replicateVec :: forall n a. KnownNat n => a -> Vect n a | |
| replicateVec a = | |
| case sameNat (Proxy @n) (Proxy @0) of | |
| Just Refl -> VNil | |
| Nothing -> | |
| case plusMinusEq @n @1 of | |
| Refl -> | |
| case unsafeKnownNat @n of | |
| Dict -> VCons a $ replicateVec @(n - 1) a | 
This can be loaded into GHCI with the following command:
$ stack --resolver nightly-2018-03-18 ghci --package constraints
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment
  
            
This is as suggested in https://stackoverflow.com/questions/49709113/replicate-function-for-a-length-indexed-list-using-ghc-typelits-and-singletons/49710029?noredirect=1#comment86456465_49710029.