{-# LANGUAGE AllowAmbiguousTypes #-}
{-# LANGUAGE ConstraintKinds #-}
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE PolyKinds #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeOperators #-}
{-# LANGUAGE UndecidableInstances #-}
{-# LANGUAGE UndecidableSuperClasses #-}
{-# OPTIONS_GHC -fwarn-incomplete-patterns #-}
module Frames.Aggregation.Maybe
(
RecordKeyMap
, combineKeyAggregations
, keyMap
, aggregateAllFold
, aggregateFold
, mergeDataFolds
)
where
import Frames.MapReduce.General ( RecGetFieldC(..)
, RCastC(..)
, IsoRec(..)
)
import qualified Frames.Aggregation.General as FA
import Frames.Aggregation.General ( RecordKeyMap )
import qualified Frames as F
import Frames ( (:.) )
import qualified Frames.Melt as F
import qualified Data.Vinyl as V
import Data.Vinyl ( ElField )
import qualified Data.Vinyl.TypeLevel as V
import qualified Control.Foldl as FL
import GHC.TypeLits ( Symbol )
import Data.Kind ( Type )
combineKeyAggregations
:: forall (a :: [(Symbol, Type)]) b a' b' record
. ( a F.⊆ (a V.++ b)
, b F.⊆ (a V.++ b)
, F.Disjoint a' b' ~ 'True
, RCastC a (a V.++ b) record Maybe
, RCastC b (a V.++ b) record Maybe
, IsoRec a' record Maybe
, IsoRec b' record Maybe
, IsoRec (a' V.++ b') record Maybe
)
=> RecordKeyMap record Maybe a a'
-> RecordKeyMap record Maybe b b'
-> RecordKeyMap record Maybe (a V.++ b) (a' V.++ b')
combineKeyAggregations = FA.combineKeyAggregations
keyMap
:: forall a b record
. ( V.KnownField a
, V.KnownField b
, RecGetFieldC a record Maybe '[a]
, IsoRec '[b] record Maybe
, Applicative Maybe
)
=> (V.Snd a -> V.Snd b)
-> RecordKeyMap record Maybe '[a] '[b]
keyMap = FA.keyMap
aggregateAllFold
:: forall (ak :: [(Symbol, Type)]) ak' d record
. ( (ak' V.++ d) F.⊆ ((ak V.++ d) V.++ ak')
, ak F.⊆ (ak V.++ d)
, ak' F.⊆ (ak' V.++ d)
, d F.⊆ (ak' V.++ d)
, Ord (record (Maybe :. ElField) ak')
, Ord (record (Maybe :. ElField) ak)
, RCastC (ak' V.++ d) ((ak V.++ d) V.++ ak') record Maybe
, RCastC ak (ak V.++ d) record Maybe
, RCastC ak' (ak' V.++ d) record Maybe
, RCastC d (ak' V.++ d) record Maybe
, IsoRec d record Maybe
, IsoRec (ak V.++ d) record Maybe
, IsoRec (ak' V.++ d) record Maybe
, IsoRec ak' record Maybe
, IsoRec ((ak V.++ d) V.++ ak') record Maybe
)
=> RecordKeyMap record Maybe ak ak'
-> (FL.Fold (record (Maybe :. ElField) d) (record (Maybe :. ElField) d))
-> FL.Fold
(record (Maybe :. ElField) (ak V.++ d))
[(record (Maybe :. ElField) (ak' V.++ d))]
aggregateAllFold = FA.aggregateAllFold
aggregateFold
:: forall (k :: [(Symbol, Type)]) ak ak' d record
. ( (ak' V.++ d) F.⊆ ((ak V.++ d) V.++ ak')
, ak F.⊆ (ak V.++ d)
, ak' F.⊆ (ak' V.++ d)
, d F.⊆ (ak' V.++ d)
, Ord (record (Maybe :. ElField) ak')
, Ord (record (Maybe :. ElField) ak)
, (k V.++ (ak' V.++ d)) ~ ((k V.++ ak') V.++ d)
, Ord (record (Maybe :. ElField) k)
, k F.⊆ ((k V.++ ak') V.++ d)
, k F.⊆ ((k V.++ ak) V.++ d)
, (ak V.++ d) F.⊆ ((k V.++ ak) V.++ d)
, RCastC ak (ak V.++ d) record Maybe
, RCastC ak' (ak' V.++ d) record Maybe
, RCastC d (ak' V.++ d) record Maybe
, RCastC k ((k V.++ ak) V.++ d) record Maybe
, RCastC (ak V.++ d) ((k V.++ ak) V.++ d) record Maybe
, RCastC (ak' V.++ d) ((ak V.++ d) V.++ ak') record Maybe
, IsoRec k record Maybe
, IsoRec d record Maybe
, IsoRec ((k V.++ ak') V.++ d) record Maybe
, IsoRec (ak V.++ d) record Maybe
, IsoRec (ak' V.++ d) record Maybe
, IsoRec ak' record Maybe
, IsoRec ((ak V.++ d) V.++ ak') record Maybe
)
=> RecordKeyMap record Maybe ak ak'
-> (FL.Fold (record (Maybe :. ElField) d) (record (Maybe :. ElField) d))
-> FL.Fold
(record (Maybe :. ElField) (k V.++ ak V.++ d))
[record (Maybe :. ElField) (k V.++ ak' V.++ d)]
aggregateFold = FA.aggregateFold @k
mergeDataFolds
:: forall (a :: (Symbol, Type)) b d record
. ( IsoRec '[b] record Maybe
, IsoRec '[a] record Maybe
, IsoRec '[a, b] record Maybe
)
=> FL.Fold (record (Maybe :. ElField) d) (record (Maybe :. ElField) '[a])
-> FL.Fold
(record (Maybe :. ElField) d)
(record (Maybe :. ElField) '[b])
-> FL.Fold
(record (Maybe :. ElField) d)
(record (Maybe :. ElField) '[a, b])
mergeDataFolds = FA.mergeDataFolds