Safe Haskell | None |
---|---|
Language | GHC2021 |
Documentation
data BinaryHeap (f :: Type -> Type) s a Source #
BinaryHeap | |
|
type MinBinaryHeap s a = BinaryHeap Identity s a Source #
type MaxBinaryHeap s a = BinaryHeap Down s a Source #
newBinaryHeap :: (Unbox a, PrimMonad m) => (a -> f a) -> Int -> m (BinaryHeap f (PrimState m) a) Source #
newMinBinaryHeap :: (Unbox a, PrimMonad m) => Int -> m (MinBinaryHeap (PrimState m) a) Source #
newMaxBinaryHeap :: (Unbox a, PrimMonad m) => Int -> m (MaxBinaryHeap (PrimState m) a) Source #
getBinaryHeapSize :: forall m (f :: Type -> Type) a. PrimMonad m => BinaryHeap f (PrimState m) a -> m Int Source #
siftUpBy :: (Unbox a, PrimMonad m) => (a -> a -> Ordering) -> Int -> MVector (PrimState m) a -> m () Source #
siftDownBy :: (Unbox a, PrimMonad m) => (a -> a -> Ordering) -> Int -> MVector (PrimState m) a -> m () Source #
heapifyBy :: (Unbox a, PrimMonad m) => (a -> a -> Ordering) -> MVector (PrimState m) a -> m () Source #
class OrdVia (f :: Type -> Type) a where Source #
compareVia :: (a -> f a) -> a -> a -> Ordering Source #
buildBinaryHeapVia :: (OrdVia f a, Unbox a, PrimMonad m) => (a -> f a) -> Vector a -> m (BinaryHeap f (PrimState m) a) Source #
buildMinBinaryHeap :: (Ord a, Unbox a, PrimMonad m) => Vector a -> m (BinaryHeap Identity (PrimState m) a) Source #
buildMaxBinaryHeap :: (Ord a, Unbox a, PrimMonad m) => Vector a -> m (BinaryHeap Down (PrimState m) a) Source #
unsafeViewBH :: forall a m (f :: Type -> Type). (Unbox a, PrimMonad m) => BinaryHeap f (PrimState m) a -> m a Source #
viewBH :: forall a m (f :: Type -> Type). (Unbox a, PrimMonad m) => BinaryHeap f (PrimState m) a -> m (Maybe a) Source #
insertBH :: forall (f :: Type -> Type) a m. (OrdVia f a, Unbox a, PrimMonad m) => a -> BinaryHeap f (PrimState m) a -> m () Source #
unsafeDeleteBH :: forall (f :: Type -> Type) a m. (OrdVia f a, Unbox a, PrimMonad m) => BinaryHeap f (PrimState m) a -> m () Source #
modifyTopBH :: forall (f :: Type -> Type) a m. (OrdVia f a, Unbox a, PrimMonad m) => (a -> a) -> BinaryHeap f (PrimState m) a -> m () Source #
deleteFindTopBH :: forall (f :: Type -> Type) a m. (OrdVia f a, Unbox a, PrimMonad m) => BinaryHeap f (PrimState m) a -> m (Maybe a) Source #
clearBH :: forall m (f :: Type -> Type) a. PrimMonad m => BinaryHeap f (PrimState m) a -> m () Source #
freezeInternalVecBH :: forall a m (f :: Type -> Type). (Unbox a, PrimMonad m) => BinaryHeap f (PrimState m) a -> m (Vector a) Source #