{-# LANGUAGE DisambiguateRecordFields #-}
{-# LANGUAGE TypeFamilies #-}
module AtCoder.Extra.DynSegTree.Persistent
(
Raw.DynSegTree (..),
P.Index (..),
new,
buildWith,
recommendedCapacity,
newRoot,
newSeq,
write,
modify,
modifyM,
prod,
allProd,
resetInterval,
maxRight,
maxRightM,
clear,
)
where
import AtCoder.Extra.DynSegTree.Raw qualified as Raw
import AtCoder.Extra.Pool qualified as P
import Control.Monad.Primitive (PrimMonad, PrimState, stToPrim)
import Data.Vector.Unboxed qualified as VU
import GHC.Stack (HasCallStack)
import Prelude hiding (read)
{-# INLINE new #-}
new ::
(HasCallStack, PrimMonad m, Monoid a, VU.Unbox a) =>
Int ->
Int ->
Int ->
m (Raw.DynSegTree (PrimState m) a)
new :: forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
Int -> Int -> Int -> m (DynSegTree (PrimState m) a)
new Int
nDst Int
l Int
r = ST (PrimState m) (DynSegTree (PrimState m) a)
-> m (DynSegTree (PrimState m) a)
forall (m :: * -> *) a. PrimMonad m => ST (PrimState m) a -> m a
stToPrim (ST (PrimState m) (DynSegTree (PrimState m) a)
-> m (DynSegTree (PrimState m) a))
-> ST (PrimState m) (DynSegTree (PrimState m) a)
-> m (DynSegTree (PrimState m) a)
forall a b. (a -> b) -> a -> b
$ Bool
-> Int
-> Int
-> Int
-> (Int -> Int -> a)
-> ST (PrimState m) (DynSegTree (PrimState m) a)
forall a s.
(HasCallStack, Unbox a) =>
Bool
-> Int -> Int -> Int -> (Int -> Int -> a) -> ST s (DynSegTree s a)
Raw.newST Bool
True Int
nDst Int
l Int
r (\Int
_ Int
_ -> a
forall a. Monoid a => a
mempty)
{-# INLINE buildWith #-}
buildWith ::
(HasCallStack, PrimMonad m, Monoid a, VU.Unbox a) =>
Int ->
Int ->
Int ->
(Int -> Int -> a) ->
m (Raw.DynSegTree (PrimState m) a)
buildWith :: forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
Int
-> Int
-> Int
-> (Int -> Int -> a)
-> m (DynSegTree (PrimState m) a)
buildWith Int
nDst Int
l Int
r Int -> Int -> a
g = ST (PrimState m) (DynSegTree (PrimState m) a)
-> m (DynSegTree (PrimState m) a)
forall (m :: * -> *) a. PrimMonad m => ST (PrimState m) a -> m a
stToPrim (ST (PrimState m) (DynSegTree (PrimState m) a)
-> m (DynSegTree (PrimState m) a))
-> ST (PrimState m) (DynSegTree (PrimState m) a)
-> m (DynSegTree (PrimState m) a)
forall a b. (a -> b) -> a -> b
$ Bool
-> Int
-> Int
-> Int
-> (Int -> Int -> a)
-> ST (PrimState m) (DynSegTree (PrimState m) a)
forall a s.
(HasCallStack, Unbox a) =>
Bool
-> Int -> Int -> Int -> (Int -> Int -> a) -> ST s (DynSegTree s a)
Raw.newST Bool
True Int
nDst Int
l Int
r Int -> Int -> a
g
{-# INLINE recommendedCapacity #-}
recommendedCapacity :: Int -> Int -> Int
recommendedCapacity :: Int -> Int -> Int
recommendedCapacity Int
n Int
q = Int
2 Int -> Int -> Int
forall a. Num a => a -> a -> a
* Int
q Int -> Int -> Int
forall a. Num a => a -> a -> a
* (Int
2 Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Double -> Int
forall b. Integral b => Double -> b
forall a b. (RealFrac a, Integral b) => a -> b
ceiling (Double -> Double -> Double
forall a. Floating a => a -> a -> a
logBase Double
2 (Int -> Double
forall a b. (Integral a, Num b) => a -> b
fromIntegral Int
n) :: Double))
newRoot :: (HasCallStack, PrimMonad m, Monoid a, VU.Unbox a) => Raw.DynSegTree (PrimState m) a -> m P.Index
newRoot :: forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
DynSegTree (PrimState m) a -> m Index
newRoot DynSegTree (PrimState m) a
dst = ST (PrimState m) Index -> m Index
forall (m :: * -> *) a. PrimMonad m => ST (PrimState m) a -> m a
stToPrim (ST (PrimState m) Index -> m Index)
-> ST (PrimState m) Index -> m Index
forall a b. (a -> b) -> a -> b
$ DynSegTree (PrimState m) a -> ST (PrimState m) Index
forall a s.
(HasCallStack, Monoid a, Unbox a) =>
DynSegTree s a -> ST s Index
Raw.newRootST DynSegTree (PrimState m) a
dst
newSeq :: (HasCallStack, PrimMonad m, Monoid a, VU.Unbox a) => Raw.DynSegTree (PrimState m) a -> VU.Vector a -> m P.Index
newSeq :: forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
DynSegTree (PrimState m) a -> Vector a -> m Index
newSeq DynSegTree (PrimState m) a
dst Vector a
xs = ST (PrimState m) Index -> m Index
forall (m :: * -> *) a. PrimMonad m => ST (PrimState m) a -> m a
stToPrim (ST (PrimState m) Index -> m Index)
-> ST (PrimState m) Index -> m Index
forall a b. (a -> b) -> a -> b
$ DynSegTree (PrimState m) a -> Vector a -> ST (PrimState m) Index
forall a s.
(HasCallStack, Monoid a, Unbox a) =>
DynSegTree s a -> Vector a -> ST s Index
Raw.newSeqST DynSegTree (PrimState m) a
dst Vector a
xs
{-# INLINE write #-}
write :: (HasCallStack, PrimMonad m, Monoid a, VU.Unbox a) => Raw.DynSegTree (PrimState m) a -> P.Index -> Int -> a -> m P.Index
write :: forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
DynSegTree (PrimState m) a -> Index -> Int -> a -> m Index
write DynSegTree (PrimState m) a
dst Index
root Int
i a
x = ST (PrimState m) Index -> m Index
forall (m :: * -> *) a. PrimMonad m => ST (PrimState m) a -> m a
stToPrim (ST (PrimState m) Index -> m Index)
-> ST (PrimState m) Index -> m Index
forall a b. (a -> b) -> a -> b
$ do
DynSegTree (PrimState (ST (PrimState m))) a
-> Index
-> (a -> ST (PrimState m) a)
-> Int
-> ST (PrimState m) Index
forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
DynSegTree (PrimState m) a -> Index -> (a -> m a) -> Int -> m Index
Raw.modifyMST DynSegTree (PrimState m) a
DynSegTree (PrimState (ST (PrimState m))) a
dst Index
root (a -> ST (PrimState m) a
forall a. a -> ST (PrimState m) a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (a -> ST (PrimState m) a) -> (a -> a) -> a -> ST (PrimState m) a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> a -> a
forall a b. a -> b -> a
const a
x) Int
i
{-# INLINE modify #-}
modify :: (HasCallStack, PrimMonad m, Monoid a, VU.Unbox a) => Raw.DynSegTree (PrimState m) a -> P.Index -> (a -> a) -> Int -> m P.Index
modify :: forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
DynSegTree (PrimState m) a -> Index -> (a -> a) -> Int -> m Index
modify DynSegTree (PrimState m) a
dst Index
root a -> a
f Int
i = ST (PrimState m) Index -> m Index
forall (m :: * -> *) a. PrimMonad m => ST (PrimState m) a -> m a
stToPrim (ST (PrimState m) Index -> m Index)
-> ST (PrimState m) Index -> m Index
forall a b. (a -> b) -> a -> b
$ do
DynSegTree (PrimState (ST (PrimState m))) a
-> Index
-> (a -> ST (PrimState m) a)
-> Int
-> ST (PrimState m) Index
forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
DynSegTree (PrimState m) a -> Index -> (a -> m a) -> Int -> m Index
Raw.modifyMST DynSegTree (PrimState m) a
DynSegTree (PrimState (ST (PrimState m))) a
dst Index
root (a -> ST (PrimState m) a
forall a. a -> ST (PrimState m) a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (a -> ST (PrimState m) a) -> (a -> a) -> a -> ST (PrimState m) a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> a
f) Int
i
{-# INLINE modifyM #-}
modifyM :: (HasCallStack, PrimMonad m, Monoid a, VU.Unbox a) => Raw.DynSegTree (PrimState m) a -> P.Index -> (a -> m a) -> Int -> m P.Index
modifyM :: forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
DynSegTree (PrimState m) a -> Index -> (a -> m a) -> Int -> m Index
modifyM DynSegTree (PrimState m) a
dst Index
root a -> m a
f Int
i = do
DynSegTree (PrimState m) a -> Index -> (a -> m a) -> Int -> m Index
forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
DynSegTree (PrimState m) a -> Index -> (a -> m a) -> Int -> m Index
Raw.modifyMST DynSegTree (PrimState m) a
dst Index
root a -> m a
f Int
i
{-# INLINE prod #-}
prod :: (HasCallStack, PrimMonad m, Monoid a, VU.Unbox a) => Raw.DynSegTree (PrimState m) a -> P.Index -> Int -> Int -> m a
prod :: forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
DynSegTree (PrimState m) a -> Index -> Int -> Int -> m a
prod DynSegTree (PrimState m) a
dst Index
root Int
l Int
r = ST (PrimState m) a -> m a
forall (m :: * -> *) a. PrimMonad m => ST (PrimState m) a -> m a
stToPrim (ST (PrimState m) a -> m a) -> ST (PrimState m) a -> m a
forall a b. (a -> b) -> a -> b
$ do
DynSegTree (PrimState m) a
-> Index -> Int -> Int -> ST (PrimState m) a
forall a s.
(HasCallStack, Monoid a, Unbox a) =>
DynSegTree s a -> Index -> Int -> Int -> ST s a
Raw.prodST DynSegTree (PrimState m) a
dst Index
root Int
l Int
r
{-# INLINE allProd #-}
allProd :: (HasCallStack, PrimMonad m, Monoid a, VU.Unbox a) => Raw.DynSegTree (PrimState m) a -> P.Index -> m a
allProd :: forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
DynSegTree (PrimState m) a -> Index -> m a
allProd dst :: DynSegTree (PrimState m) a
dst@Raw.DynSegTree {Int
l0Dst :: Int
l0Dst :: forall s a. DynSegTree s a -> Int
l0Dst, Int
r0Dst :: Int
r0Dst :: forall s a. DynSegTree s a -> Int
r0Dst} Index
root = ST (PrimState m) a -> m a
forall (m :: * -> *) a. PrimMonad m => ST (PrimState m) a -> m a
stToPrim (ST (PrimState m) a -> m a) -> ST (PrimState m) a -> m a
forall a b. (a -> b) -> a -> b
$ do
DynSegTree (PrimState m) a
-> Index -> Int -> Int -> ST (PrimState m) a
forall a s.
(HasCallStack, Monoid a, Unbox a) =>
DynSegTree s a -> Index -> Int -> Int -> ST s a
Raw.prodST DynSegTree (PrimState m) a
dst Index
root Int
l0Dst Int
r0Dst
{-# INLINE resetInterval #-}
resetInterval :: (HasCallStack, PrimMonad m, Monoid a, VU.Unbox a) => Raw.DynSegTree (PrimState m) a -> P.Index -> Int -> Int -> m P.Index
resetInterval :: forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
DynSegTree (PrimState m) a -> Index -> Int -> Int -> m Index
resetInterval DynSegTree (PrimState m) a
dst Index
root Int
l Int
r = ST (PrimState m) Index -> m Index
forall (m :: * -> *) a. PrimMonad m => ST (PrimState m) a -> m a
stToPrim (ST (PrimState m) Index -> m Index)
-> ST (PrimState m) Index -> m Index
forall a b. (a -> b) -> a -> b
$ do
DynSegTree (PrimState m) a
-> Index -> Int -> Int -> ST (PrimState m) Index
forall a s.
(HasCallStack, Monoid a, Unbox a) =>
DynSegTree s a -> Index -> Int -> Int -> ST s Index
Raw.resetIntervalST DynSegTree (PrimState m) a
dst Index
root Int
l Int
r
{-# INLINE maxRight #-}
maxRight :: (HasCallStack, PrimMonad m, Monoid a, VU.Unbox a) => Raw.DynSegTree (PrimState m) a -> P.Index -> (a -> Bool) -> m Int
maxRight :: forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
DynSegTree (PrimState m) a -> Index -> (a -> Bool) -> m Int
maxRight DynSegTree (PrimState m) a
dst Index
root a -> Bool
f = do
DynSegTree (PrimState m) a -> Index -> (a -> m Bool) -> m Int
forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
DynSegTree (PrimState m) a -> Index -> (a -> m Bool) -> m Int
Raw.maxRightM DynSegTree (PrimState m) a
dst Index
root (Bool -> m Bool
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Bool -> m Bool) -> (a -> Bool) -> a -> m Bool
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> Bool
f)
{-# INLINE maxRightM #-}
maxRightM :: (HasCallStack, PrimMonad m, Monoid a, VU.Unbox a) => Raw.DynSegTree (PrimState m) a -> P.Index -> (a -> m Bool) -> m Int
maxRightM :: forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
DynSegTree (PrimState m) a -> Index -> (a -> m Bool) -> m Int
maxRightM DynSegTree (PrimState m) a
dst Index
root a -> m Bool
f = do
DynSegTree (PrimState m) a -> Index -> (a -> m Bool) -> m Int
forall (m :: * -> *) a.
(HasCallStack, PrimMonad m, Monoid a, Unbox a) =>
DynSegTree (PrimState m) a -> Index -> (a -> m Bool) -> m Int
Raw.maxRightM DynSegTree (PrimState m) a
dst Index
root a -> m Bool
f
{-# INLINE clear #-}
clear :: (PrimMonad m) => Raw.DynSegTree (PrimState m) a -> m ()
clear :: forall (m :: * -> *) a.
PrimMonad m =>
DynSegTree (PrimState m) a -> m ()
clear DynSegTree (PrimState m) a
dst = do
Pool (PrimState m) () -> m ()
forall (m :: * -> *) a. PrimMonad m => Pool (PrimState m) a -> m ()
P.clear (DynSegTree (PrimState m) a -> Pool (PrimState m) ()
forall s a. DynSegTree s a -> Pool s ()
Raw.poolDst DynSegTree (PrimState m) a
dst)