{-# LANGUAGE DataKinds #-}
{-# LANGUAGE ExistentialQuantification #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE NoStarIsType #-}
{-# LANGUAGE PolyKinds #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeOperators #-}
{-# LANGUAGE UndecidableInstances #-}
module Math.Tensor.Safe.Proofs
(
saneTailRProof
, singITailRProof
,
saneMergeRProof
, proofMergeLT
, proofMergeGT
, proofMergeIxNotEQ
, proofMergeIxLT
, proofMergeIxGT
,
saneContractProof
, singletonContractProof
, contractTailDiffVProof
, contractTailSameVNoConProof
, contractTailSameVNoCovProof
, contractTailSameVDiffIProof
, contractTailSameVSameIProof
) where
import Math.Tensor.Safe.TH
import Data.Constraint
( Dict (Dict)
, (:-) (Sub)
)
import Unsafe.Coerce (unsafeCoerce)
import Data.Singletons.Prelude
( Sing, SingI
, PEq ((==))
, Symbol
, Fst, Snd, Compare
)
{-# INLINE saneTailRProof #-}
saneTailRProof :: forall (r :: Rank).Sing r -> (Sane r ~ 'True) :- (Sane (TailR r) ~ 'True)
saneTailRProof :: Sing r -> (Sane r ~ 'True) :- (Sane (TailR r) ~ 'True)
saneTailRProof Sing r
_ = ((Sane r ~ 'True) => Dict (Sane (TailR r) ~ 'True))
-> (Sane r ~ 'True) :- (Sane (TailR r) ~ 'True)
forall (a :: Constraint) (b :: Constraint). (a => Dict b) -> a :- b
Sub (Sane r ~ 'True) => Dict (Sane (TailR r) ~ 'True)
axiom
where
axiom :: Sane r ~ 'True => Dict (Sane (TailR r) ~ 'True)
axiom :: Dict (Sane (TailR r) ~ 'True)
axiom = Dict (Any ~ Any) -> Dict (Sane (TailR r) ~ 'True)
forall a b. a -> b
unsafeCoerce (forall (a :: Constraint). a => Dict a
forall k (a :: k). Dict (a ~ a)
Dict :: Dict (a ~ a))
{-# INLINE singITailRProof #-}
singITailRProof :: forall (r :: Rank).Sing r -> SingI r :- SingI (TailR r)
singITailRProof :: Sing r -> SingI r :- SingI (TailR r)
singITailRProof Sing r
_ = (SingI r => Dict (SingI (TailR r))) -> SingI r :- SingI (TailR r)
forall (a :: Constraint) (b :: Constraint). (a => Dict b) -> a :- b
Sub SingI r => Dict (SingI (TailR r))
axiom
where
axiom :: SingI r => Dict (SingI (TailR r))
axiom :: Dict (SingI (TailR r))
axiom = Dict (Any ~ Any) -> Dict (SingI (TailR r))
forall a b. a -> b
unsafeCoerce (forall (a :: Constraint). a => Dict a
forall k (a :: k). Dict (a ~ a)
Dict :: Dict (a ~ a))
{-# INLINE saneMergeRProof #-}
saneMergeRProof :: forall (r :: Rank) (r' :: Rank) (r'' :: Rank).
Sing r -> Sing r' ->
(Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'') :- (Sane r'' ~ 'True)
saneMergeRProof :: Sing r
-> Sing r'
-> (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'')
:- (Sane r'' ~ 'True)
saneMergeRProof Sing r
_ Sing r'
_ = ((Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'') =>
Dict (Sane r'' ~ 'True))
-> (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'')
:- (Sane r'' ~ 'True)
forall (a :: Constraint) (b :: Constraint). (a => Dict b) -> a :- b
Sub (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'') =>
Dict (Sane r'' ~ 'True)
(Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'') =>
Dict (Sane r'' ~ 'True)
axiom
where
axiom :: (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'') =>
Dict (Sane r'' ~ 'True)
axiom :: Dict (Sane r'' ~ 'True)
axiom = Dict (Any ~ Any) -> Dict (Sane r'' ~ 'True)
forall a b. a -> b
unsafeCoerce (forall (a :: Constraint). a => Dict a
forall k (a :: k). Dict (a ~ a)
Dict :: Dict (a ~ a))
{-# INLINE proofMergeLT #-}
proofMergeLT :: forall (r :: Rank) (r' :: Rank) (r'' :: Rank).
Sing r -> Sing r' ->
(Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'LT)
:- (MergeR (TailR r) r' ~ 'Just (TailR r''))
proofMergeLT :: Sing r
-> Sing r'
-> (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'LT)
:- (MergeR (TailR r) r' ~ 'Just (TailR r''))
proofMergeLT Sing r
_ Sing r'
_ = ((Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare_6989586621679117768 (Fst (HeadR r)) (Fst (HeadR r'))
~ 'LT) =>
Dict (MergeR (TailR r) r' ~ 'Just (TailR r'')))
-> (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare_6989586621679117768 (Fst (HeadR r)) (Fst (HeadR r')) ~ 'LT)
:- (MergeR (TailR r) r' ~ 'Just (TailR r''))
forall (a :: Constraint) (b :: Constraint). (a => Dict b) -> a :- b
Sub (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'LT) =>
Dict (MergeR (TailR r) r' ~ 'Just (TailR r''))
(Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare_6989586621679117768 (Fst (HeadR r)) (Fst (HeadR r'))
~ 'LT) =>
Dict (MergeR (TailR r) r' ~ 'Just (TailR r''))
axiom
where
axiom :: (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'LT)
=> Dict (MergeR (TailR r) r' ~ 'Just (TailR r''))
axiom :: Dict (MergeR (TailR r) r' ~ 'Just (TailR r''))
axiom = Dict (Any ~ Any) -> Dict (MergeR (TailR r) r' ~ 'Just (TailR r''))
forall a b. a -> b
unsafeCoerce (forall (a :: Constraint). a => Dict a
forall k (a :: k). Dict (a ~ a)
Dict :: Dict (a ~ a))
{-# INLINE proofMergeIxNotEQ #-}
proofMergeIxNotEQ :: forall (r :: Rank) (r' :: Rank) (r'' :: Rank).
Sing r -> Sing r' ->
(Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ)
:- ((IxCompare (Snd (HeadR r)) (Snd (HeadR r')) == 'EQ) ~ 'False)
proofMergeIxNotEQ :: Sing r
-> Sing r'
-> (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ)
:- ((IxCompare (Snd (HeadR r)) (Snd (HeadR r')) == 'EQ) ~ 'False)
proofMergeIxNotEQ Sing r
_ Sing r'
_ = ((Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare_6989586621679117768 (Fst (HeadR r)) (Fst (HeadR r'))
~ 'EQ) =>
Dict
(Equals_6989586621679820485
(IxCompare (Snd (HeadR r)) (Snd (HeadR r'))) 'EQ
~ 'False))
-> (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare_6989586621679117768 (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ)
:- (Equals_6989586621679820485
(IxCompare (Snd (HeadR r)) (Snd (HeadR r'))) 'EQ
~ 'False)
forall (a :: Constraint) (b :: Constraint). (a => Dict b) -> a :- b
Sub (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ) =>
Dict ((IxCompare (Snd (HeadR r)) (Snd (HeadR r')) == 'EQ) ~ 'False)
(Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare_6989586621679117768 (Fst (HeadR r)) (Fst (HeadR r'))
~ 'EQ) =>
Dict
(Equals_6989586621679820485
(IxCompare (Snd (HeadR r)) (Snd (HeadR r'))) 'EQ
~ 'False)
axiom
where
axiom :: (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ)
=> Dict ((IxCompare (Snd (HeadR r)) (Snd (HeadR r')) == 'EQ) ~ 'False)
axiom :: Dict ((IxCompare (Snd (HeadR r)) (Snd (HeadR r')) == 'EQ) ~ 'False)
axiom = Dict (Any ~ Any)
-> Dict
(Equals_6989586621679820485
(IxCompare (Snd (HeadR r)) (Snd (HeadR r'))) 'EQ
~ 'False)
forall a b. a -> b
unsafeCoerce (forall (a :: Constraint). a => Dict a
forall k (a :: k). Dict (a ~ a)
Dict :: Dict (a ~ a))
{-# INLINE proofMergeIxLT #-}
proofMergeIxLT :: forall (r :: Rank) (r' :: Rank) (r'' :: Rank).
Sing r -> Sing r' ->
(Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ,
IxCompare (Snd (HeadR r)) (Snd (HeadR r')) ~ 'LT)
:- (MergeR (TailR r) r' ~ 'Just (TailR r''))
proofMergeIxLT :: Sing r
-> Sing r'
-> (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ,
IxCompare (Snd (HeadR r)) (Snd (HeadR r')) ~ 'LT)
:- (MergeR (TailR r) r' ~ 'Just (TailR r''))
proofMergeIxLT Sing r
_ Sing r'
_ = ((Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare_6989586621679117768 (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ,
IxCompare (Snd (HeadR r)) (Snd (HeadR r')) ~ 'LT) =>
Dict (MergeR (TailR r) r' ~ 'Just (TailR r'')))
-> (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare_6989586621679117768 (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ,
IxCompare (Snd (HeadR r)) (Snd (HeadR r')) ~ 'LT)
:- (MergeR (TailR r) r' ~ 'Just (TailR r''))
forall (a :: Constraint) (b :: Constraint). (a => Dict b) -> a :- b
Sub (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ,
IxCompare (Snd (HeadR r)) (Snd (HeadR r')) ~ 'LT) =>
Dict (MergeR (TailR r) r' ~ 'Just (TailR r''))
(Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare_6989586621679117768 (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ,
IxCompare (Snd (HeadR r)) (Snd (HeadR r')) ~ 'LT) =>
Dict (MergeR (TailR r) r' ~ 'Just (TailR r''))
axiom
where
axiom :: (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ,
IxCompare (Snd (HeadR r)) (Snd (HeadR r')) ~ 'LT)
=> Dict (MergeR (TailR r) r' ~ 'Just (TailR r''))
axiom :: Dict (MergeR (TailR r) r' ~ 'Just (TailR r''))
axiom = Dict (Any ~ Any) -> Dict (MergeR (TailR r) r' ~ 'Just (TailR r''))
forall a b. a -> b
unsafeCoerce (forall (a :: Constraint). a => Dict a
forall k (a :: k). Dict (a ~ a)
Dict :: Dict (a ~ a))
{-# INLINE proofMergeGT #-}
proofMergeGT :: forall (r :: Rank) (r' :: Rank) (r'' :: Rank).
Sing r -> Sing r' ->
(Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'GT)
:- (MergeR r (TailR r') ~ 'Just (TailR r''))
proofMergeGT :: Sing r
-> Sing r'
-> (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'GT)
:- (MergeR r (TailR r') ~ 'Just (TailR r''))
proofMergeGT Sing r
_ Sing r'
_ = ((Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare_6989586621679117768 (Fst (HeadR r)) (Fst (HeadR r'))
~ 'GT) =>
Dict (MergeR r (TailR r') ~ 'Just (TailR r'')))
-> (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare_6989586621679117768 (Fst (HeadR r)) (Fst (HeadR r')) ~ 'GT)
:- (MergeR r (TailR r') ~ 'Just (TailR r''))
forall (a :: Constraint) (b :: Constraint). (a => Dict b) -> a :- b
Sub (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'GT) =>
Dict (MergeR r (TailR r') ~ 'Just (TailR r''))
(Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare_6989586621679117768 (Fst (HeadR r)) (Fst (HeadR r'))
~ 'GT) =>
Dict (MergeR r (TailR r') ~ 'Just (TailR r''))
axiom
where
axiom :: (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'GT)
=> Dict (MergeR r (TailR r') ~ 'Just (TailR r''))
axiom :: Dict (MergeR r (TailR r') ~ 'Just (TailR r''))
axiom = Dict (Any ~ Any) -> Dict (MergeR r (TailR r') ~ 'Just (TailR r''))
forall a b. a -> b
unsafeCoerce (forall (a :: Constraint). a => Dict a
forall k (a :: k). Dict (a ~ a)
Dict :: Dict (a ~ a))
{-# INLINE proofMergeIxGT #-}
proofMergeIxGT :: forall (r :: Rank) (r' :: Rank) (r'' :: Rank).
Sing r -> Sing r' ->
(Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ,
IxCompare (Snd (HeadR r)) (Snd (HeadR r')) ~ 'GT)
:- (MergeR r (TailR r') ~ 'Just (TailR r''))
proofMergeIxGT :: Sing r
-> Sing r'
-> (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ,
IxCompare (Snd (HeadR r)) (Snd (HeadR r')) ~ 'GT)
:- (MergeR r (TailR r') ~ 'Just (TailR r''))
proofMergeIxGT Sing r
_ Sing r'
_ = ((Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare_6989586621679117768 (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ,
IxCompare (Snd (HeadR r)) (Snd (HeadR r')) ~ 'GT) =>
Dict (MergeR r (TailR r') ~ 'Just (TailR r'')))
-> (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare_6989586621679117768 (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ,
IxCompare (Snd (HeadR r)) (Snd (HeadR r')) ~ 'GT)
:- (MergeR r (TailR r') ~ 'Just (TailR r''))
forall (a :: Constraint) (b :: Constraint). (a => Dict b) -> a :- b
Sub (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ,
IxCompare (Snd (HeadR r)) (Snd (HeadR r')) ~ 'GT) =>
Dict (MergeR r (TailR r') ~ 'Just (TailR r''))
(Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare_6989586621679117768 (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ,
IxCompare (Snd (HeadR r)) (Snd (HeadR r')) ~ 'GT) =>
Dict (MergeR r (TailR r') ~ 'Just (TailR r''))
axiom
where
axiom :: (Sane r ~ 'True, Sane r' ~ 'True, MergeR r r' ~ 'Just r'',
Compare (Fst (HeadR r)) (Fst (HeadR r')) ~ 'EQ,
IxCompare (Snd (HeadR r)) (Snd (HeadR r')) ~ 'GT)
=> Dict (MergeR r (TailR r') ~ 'Just (TailR r''))
axiom :: Dict (MergeR r (TailR r') ~ 'Just (TailR r''))
axiom = Dict (Any ~ Any) -> Dict (MergeR r (TailR r') ~ 'Just (TailR r''))
forall a b. a -> b
unsafeCoerce (forall (a :: Constraint). a => Dict a
forall k (a :: k). Dict (a ~ a)
Dict :: Dict (a ~ a))
{-# INLINE saneContractProof #-}
saneContractProof :: forall (r :: Rank).Sing r -> (Sane r ~ 'True) :- (Sane (ContractR r) ~ 'True)
saneContractProof :: Sing r -> (Sane r ~ 'True) :- (Sane (ContractR r) ~ 'True)
saneContractProof Sing r
_ = ((Sane r ~ 'True) => Dict (Sane (ContractR r) ~ 'True))
-> (Sane r ~ 'True) :- (Sane (ContractR r) ~ 'True)
forall (a :: Constraint) (b :: Constraint). (a => Dict b) -> a :- b
Sub (Sane r ~ 'True) => Dict (Sane (ContractR r) ~ 'True)
axiom
where
axiom :: Sane r ~ 'True => Dict (Sane (ContractR r) ~ 'True)
axiom :: Dict (Sane (ContractR r) ~ 'True)
axiom = Dict (Any ~ Any) -> Dict (Sane (ContractR r) ~ 'True)
forall a b. a -> b
unsafeCoerce (forall (a :: Constraint). a => Dict a
forall k (a :: k). Dict (a ~ a)
Dict :: Dict (a ~ a))
{-# INLINE singletonContractProof #-}
singletonContractProof :: forall (r :: Rank).
Sing r -> (TailR r ~ '[]) :- (ContractR r ~ r)
singletonContractProof :: Sing r -> (TailR r ~ '[]) :- (ContractR r ~ r)
singletonContractProof Sing r
_ = ((TailR r ~ '[]) => Dict (ContractR r ~ r))
-> (TailR r ~ '[]) :- (ContractR r ~ r)
forall (a :: Constraint) (b :: Constraint). (a => Dict b) -> a :- b
Sub (TailR r ~ '[]) => Dict (ContractR r ~ r)
axiom
where
axiom :: TailR r ~ '[] => Dict (ContractR r ~ r)
axiom :: Dict (ContractR r ~ r)
axiom = Dict (Any ~ Any) -> Dict (ContractR r ~ r)
forall a b. a -> b
unsafeCoerce (forall (a :: Constraint). a => Dict a
forall k (a :: k). Dict (a ~ a)
Dict :: Dict (a ~ a))
{-# INLINE contractTailDiffVProof #-}
contractTailDiffVProof :: forall (r :: Rank) (t :: Rank) (t' :: Rank).
Sing r ->
(t ~ TailR r, t' ~ TailR t, (Fst (HeadR r) == Fst (HeadR t)) ~ 'False)
:- (TailR (ContractR r) ~ ContractR t)
contractTailDiffVProof :: Sing r
-> (t ~ TailR r, t' ~ TailR t,
(Fst (HeadR r) == Fst (HeadR t)) ~ 'False)
:- (TailR (ContractR r) ~ ContractR t)
contractTailDiffVProof Sing r
_ = ((t ~ TailR r, t' ~ TailR t,
Equals_6989586621679117889 (Fst (HeadR r)) (Fst (HeadR t))
~ 'False) =>
Dict (TailR (ContractR r) ~ ContractR t))
-> (t ~ TailR r, t' ~ TailR t,
Equals_6989586621679117889 (Fst (HeadR r)) (Fst (HeadR t))
~ 'False)
:- (TailR (ContractR r) ~ ContractR t)
forall (a :: Constraint) (b :: Constraint). (a => Dict b) -> a :- b
Sub (t ~ TailR r, t' ~ TailR t,
(Fst (HeadR r) == Fst (HeadR t)) ~ 'False) =>
Dict (TailR (ContractR r) ~ ContractR t)
(t ~ TailR r, t' ~ TailR t,
Equals_6989586621679117889 (Fst (HeadR r)) (Fst (HeadR t))
~ 'False) =>
Dict (TailR (ContractR r) ~ ContractR t)
axiom
where
axiom :: (t ~ TailR r, t' ~ TailR t, (Fst (HeadR r) == Fst (HeadR t)) ~ 'False)
=> Dict (TailR (ContractR r) ~ ContractR t)
axiom :: Dict (TailR (ContractR r) ~ ContractR t)
axiom = Dict (Any ~ Any) -> Dict (TailR (ContractR r) ~ ContractR t)
forall a b. a -> b
unsafeCoerce (forall (a :: Constraint). a => Dict a
forall k (a :: k). Dict (a ~ a)
Dict :: Dict (a ~ a))
{-# INLINE contractTailSameVNoConProof #-}
contractTailSameVNoConProof :: forall (r :: Rank) (t :: Rank) (t' :: Rank) (i :: Symbol).
Sing r ->
(t ~ TailR r, t' ~ TailR t, (Fst (HeadR r) == Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICov i)
:- (TailR (ContractR r) ~ ContractR t)
contractTailSameVNoConProof :: Sing r
-> (t ~ TailR r, t' ~ TailR t,
(Fst (HeadR r) == Fst (HeadR t)) ~ 'True, Snd (HeadR r) ~ 'ICov i)
:- (TailR (ContractR r) ~ ContractR t)
contractTailSameVNoConProof Sing r
_ = ((t ~ TailR r, t' ~ TailR t,
Equals_6989586621679117889 (Fst (HeadR r)) (Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICov i) =>
Dict (TailR (ContractR r) ~ ContractR t))
-> (t ~ TailR r, t' ~ TailR t,
Equals_6989586621679117889 (Fst (HeadR r)) (Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICov i)
:- (TailR (ContractR r) ~ ContractR t)
forall (a :: Constraint) (b :: Constraint). (a => Dict b) -> a :- b
Sub (t ~ TailR r, t' ~ TailR t,
(Fst (HeadR r) == Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICov i) =>
Dict (TailR (ContractR r) ~ ContractR t)
(t ~ TailR r, t' ~ TailR t,
Equals_6989586621679117889 (Fst (HeadR r)) (Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICov i) =>
Dict (TailR (ContractR r) ~ ContractR t)
axiom
where
axiom :: (t ~ TailR r, t' ~ TailR t, (Fst (HeadR r) == Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICov i)
=> Dict (TailR (ContractR r) ~ ContractR t)
axiom :: Dict (TailR (ContractR r) ~ ContractR t)
axiom = Dict (Any ~ Any) -> Dict (TailR (ContractR r) ~ ContractR t)
forall a b. a -> b
unsafeCoerce (forall (a :: Constraint). a => Dict a
forall k (a :: k). Dict (a ~ a)
Dict :: Dict (a ~ a))
{-# INLINE contractTailSameVNoCovProof #-}
contractTailSameVNoCovProof :: forall (r :: Rank) (t :: Rank) (t' :: Rank) (i :: Symbol).
Sing r ->
(t ~ TailR r, t' ~ TailR t, (Fst (HeadR r) == Fst (HeadR t)) ~ 'True,
Snd (HeadR t) ~ 'ICon i)
:- (TailR (ContractR r) ~ ContractR t)
contractTailSameVNoCovProof :: Sing r
-> (t ~ TailR r, t' ~ TailR t,
(Fst (HeadR r) == Fst (HeadR t)) ~ 'True, Snd (HeadR t) ~ 'ICon i)
:- (TailR (ContractR r) ~ ContractR t)
contractTailSameVNoCovProof Sing r
_ = ((t ~ TailR r, t' ~ TailR t,
Equals_6989586621679117889 (Fst (HeadR r)) (Fst (HeadR t)) ~ 'True,
Snd (HeadR t) ~ 'ICon i) =>
Dict (TailR (ContractR r) ~ ContractR t))
-> (t ~ TailR r, t' ~ TailR t,
Equals_6989586621679117889 (Fst (HeadR r)) (Fst (HeadR t)) ~ 'True,
Snd (HeadR t) ~ 'ICon i)
:- (TailR (ContractR r) ~ ContractR t)
forall (a :: Constraint) (b :: Constraint). (a => Dict b) -> a :- b
Sub (t ~ TailR r, t' ~ TailR t,
(Fst (HeadR r) == Fst (HeadR t)) ~ 'True,
Snd (HeadR t) ~ 'ICon i) =>
Dict (TailR (ContractR r) ~ ContractR t)
(t ~ TailR r, t' ~ TailR t,
Equals_6989586621679117889 (Fst (HeadR r)) (Fst (HeadR t)) ~ 'True,
Snd (HeadR t) ~ 'ICon i) =>
Dict (TailR (ContractR r) ~ ContractR t)
axiom
where
axiom :: (t ~ TailR r, t' ~ TailR t, (Fst (HeadR r) == Fst (HeadR t)) ~ 'True,
Snd (HeadR t) ~ 'ICon i)
=> Dict (TailR (ContractR r) ~ ContractR t)
axiom :: Dict (TailR (ContractR r) ~ ContractR t)
axiom = Dict (Any ~ Any) -> Dict (TailR (ContractR r) ~ ContractR t)
forall a b. a -> b
unsafeCoerce (forall (a :: Constraint). a => Dict a
forall k (a :: k). Dict (a ~ a)
Dict :: Dict (a ~ a))
{-# INLINE contractTailSameVDiffIProof #-}
contractTailSameVDiffIProof :: forall (r :: Rank) (t :: Rank) (t' :: Rank) (i :: Symbol) (j :: Symbol).
Sing r ->
(t ~ TailR r, t' ~ TailR t, (Fst (HeadR r) == Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICon i, Snd (HeadR t) ~ 'ICov j, (i == j) ~ 'False)
:- (TailR (ContractR r) ~ ContractR t)
contractTailSameVDiffIProof :: Sing r
-> (t ~ TailR r, t' ~ TailR t,
(Fst (HeadR r) == Fst (HeadR t)) ~ 'True, Snd (HeadR r) ~ 'ICon i,
Snd (HeadR t) ~ 'ICov j, (i == j) ~ 'False)
:- (TailR (ContractR r) ~ ContractR t)
contractTailSameVDiffIProof Sing r
_ = ((t ~ TailR r, t' ~ TailR t,
Equals_6989586621679117889 (Fst (HeadR r)) (Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICon i, Snd (HeadR t) ~ 'ICov j,
DefaultEq i j ~ 'False) =>
Dict (TailR (ContractR r) ~ ContractR t))
-> (t ~ TailR r, t' ~ TailR t,
Equals_6989586621679117889 (Fst (HeadR r)) (Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICon i, Snd (HeadR t) ~ 'ICov j,
DefaultEq i j ~ 'False)
:- (TailR (ContractR r) ~ ContractR t)
forall (a :: Constraint) (b :: Constraint). (a => Dict b) -> a :- b
Sub (t ~ TailR r, t' ~ TailR t,
(Fst (HeadR r) == Fst (HeadR t)) ~ 'True, Snd (HeadR r) ~ 'ICon i,
Snd (HeadR t) ~ 'ICov j, (i == j) ~ 'False) =>
Dict (TailR (ContractR r) ~ ContractR t)
(t ~ TailR r, t' ~ TailR t,
Equals_6989586621679117889 (Fst (HeadR r)) (Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICon i, Snd (HeadR t) ~ 'ICov j,
DefaultEq i j ~ 'False) =>
Dict (TailR (ContractR r) ~ ContractR t)
axiom
where
axiom :: (t ~ TailR r, t' ~ TailR t, (Fst (HeadR r) == Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICon i, Snd (HeadR t) ~ 'ICov j, (i == j) ~ 'False)
=> Dict (TailR (ContractR r) ~ ContractR t)
axiom :: Dict (TailR (ContractR r) ~ ContractR t)
axiom = Dict (Any ~ Any) -> Dict (TailR (ContractR r) ~ ContractR t)
forall a b. a -> b
unsafeCoerce (forall (a :: Constraint). a => Dict a
forall k (a :: k). Dict (a ~ a)
Dict :: Dict (a ~ a))
{-# INLINE contractTailSameVSameIProof #-}
contractTailSameVSameIProof :: forall (r :: Rank) (t :: Rank) (t' :: Rank) (i :: Symbol) (j :: Symbol).
Sing r ->
(t ~ TailR r, t' ~ TailR t, (Fst (HeadR r) == Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICon i, Snd (HeadR t) ~ 'ICov j, (i == j) ~ 'True)
:- (ContractR t' ~ ContractR r)
contractTailSameVSameIProof :: Sing r
-> (t ~ TailR r, t' ~ TailR t,
(Fst (HeadR r) == Fst (HeadR t)) ~ 'True, Snd (HeadR r) ~ 'ICon i,
Snd (HeadR t) ~ 'ICov j, (i == j) ~ 'True)
:- (ContractR t' ~ ContractR r)
contractTailSameVSameIProof Sing r
_ = ((t ~ TailR r, t' ~ TailR t,
Equals_6989586621679117889 (Fst (HeadR r)) (Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICon i, Snd (HeadR t) ~ 'ICov j,
DefaultEq i j ~ 'True) =>
Dict (ContractR t' ~ ContractR r))
-> (t ~ TailR r, t' ~ TailR t,
Equals_6989586621679117889 (Fst (HeadR r)) (Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICon i, Snd (HeadR t) ~ 'ICov j,
DefaultEq i j ~ 'True)
:- (ContractR t' ~ ContractR r)
forall (a :: Constraint) (b :: Constraint). (a => Dict b) -> a :- b
Sub (t ~ TailR r, t' ~ TailR t,
(Fst (HeadR r) == Fst (HeadR t)) ~ 'True, Snd (HeadR r) ~ 'ICon i,
Snd (HeadR t) ~ 'ICov j, (i == j) ~ 'True) =>
Dict (ContractR t' ~ ContractR r)
(t ~ TailR r, t' ~ TailR t,
Equals_6989586621679117889 (Fst (HeadR r)) (Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICon i, Snd (HeadR t) ~ 'ICov j,
DefaultEq i j ~ 'True) =>
Dict (ContractR t' ~ ContractR r)
axiom
where
axiom :: (t ~ TailR r, t' ~ TailR t, (Fst (HeadR r) == Fst (HeadR t)) ~ 'True,
Snd (HeadR r) ~ 'ICon i, Snd (HeadR t) ~ 'ICov j, (i == j) ~ 'True)
=> Dict (ContractR t' ~ ContractR r)
axiom :: Dict (ContractR t' ~ ContractR r)
axiom = Dict (Any ~ Any) -> Dict (ContractR t' ~ ContractR r)
forall a b. a -> b
unsafeCoerce (forall (a :: Constraint). a => Dict a
forall k (a :: k). Dict (a ~ a)
Dict :: Dict (a ~ a))