aboutsummaryrefslogtreecommitdiff
path: root/src/Data/Array/Nested/Ranked.hs
diff options
context:
space:
mode:
authorMikolaj Konarski <mikolaj.konarski@funktory.com>2025-12-02 13:16:33 +0100
committerMikolaj Konarski <mikolaj.konarski@funktory.com>2025-12-02 13:16:33 +0100
commit9f47aa6a2bcd772388a5d5150ca7254e4eb95bc2 (patch)
tree4c3a1b8a7b1a734e83f161f2b1be58ce4470cfa3 /src/Data/Array/Nested/Ranked.hs
parentba5a31c976f80421464af1af8d6ab1e2a154cd83 (diff)
Generalize mgeneratePrim to potentially avoid @fmap fromIntegral@
Diffstat (limited to 'src/Data/Array/Nested/Ranked.hs')
-rw-r--r--src/Data/Array/Nested/Ranked.hs4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/Data/Array/Nested/Ranked.hs b/src/Data/Array/Nested/Ranked.hs
index 9504247..37925fb 100644
--- a/src/Data/Array/Nested/Ranked.hs
+++ b/src/Data/Array/Nested/Ranked.hs
@@ -71,7 +71,9 @@ rgenerate sh f
-- TODO: this would be shorter and faster written with rfromVector,
-- but unfortunately we don't have ixrFromLinear
-rgeneratePrim :: forall n a. PrimElt a => IShR n -> (IIxR n -> a) -> Ranked n a
+{-# INLINE rgeneratePrim #-}
+rgeneratePrim :: forall n a i. (PrimElt a, Num i)
+ => IShR n -> (IxR n i -> a) -> Ranked n a
rgeneratePrim sh f
| sn@SNat <- shrRank sh
, Dict <- lemKnownReplicate sn