module Data.Vector.Algorithms.Quicksort.Predefined.BitonicIntST (bitonicSortIntST) where
import Control.Monad.ST
import Data.Int
import Data.Vector.Primitive qualified as P
import Data.Vector.Primitive.Mutable qualified as PM
import Data.Vector.Algorithms.FixedSort
{-# NOINLINE bitonicSortIntST #-}
bitonicSortIntST :: P.MVector s Int64 -> ST s ()
bitonicSortIntST :: forall s. MVector s Int64 -> ST s ()
bitonicSortIntST MVector s Int64
xs = Int -> MVector (PrimState (ST s)) Int64 -> ST s ()
forall (m :: * -> *) (v :: * -> * -> *) a.
(PrimMonad m, Ord a, MVector v a) =>
Int -> v (PrimState m) a -> m ()
bitonicSort (MVector s Int64 -> Int
forall a s. Prim a => MVector s a -> Int
PM.length MVector s Int64
xs) MVector s Int64
MVector (PrimState (ST s)) Int64
xs