Sparkline in unicode: Difference between revisions

→‎{{header|Haskell}}: Tidied, obtained max and min values in one pass rather than two
(Add SenseTalk implementation)
(→‎{{header|Haskell}}: Tidied, obtained max and min values in one pass rather than two)
Line 1,073:
Or, stripping back a little:
{{Trans|Python}}
<lang haskell>import Data.List.SplitBifunctor (splitOneOfbimap)
import Data.List (findIndex)
import Data.List.Split (splitOneOf)
import Data.Maybe (maybe)
 
------------------------ SPARK LINE ----------------------
 
sparkLine :: [Float] -> String
sparkLine xs[] = ""
sparkLine xxs@(x : xs) =
maybe '█' ("▁▂▃▄▅▆▇" !!) . flip findIndex lbounds . flip (>) <$> xs
fmap
( maybe '█' ("▁▂▃▄▅▆▇" !!) . flip findIndex lbounds . flip (>) <$> xs
. flip findIndex lbounds
. (<)
)
xxs
where
(mn, mx) = foldr ((,)bimap . minimummin <*> maximummax) (x, x) xs
w = (mx - mn) / 8
lbounds = (mn +) . (w *) <$> [1 .. 7]
 
--------------------------- TEST -------------------------
parseFloats :: String -> [Float]
parseFloats = fmap read . filter (not . null) . splitOneOf " ,"
 
main :: IO ()
main =
mapM_ putStrLn $
sparkLine . parseFloats <$>
<$> [ "0, 1, 19, 20",
, "0, 999, 4000, 4999, 7000, 7999",
, "1 2 3 4 5 6 7 8 7 6 5 4 3 2 1",
, "1.5, 0.5 3.5, 2.5 5.5, 4.5 7.5, 6.5"
]
]</lang>
 
parseFloats :: String -> [Float]
parseFloats =
fmap read
. filter (not . null)
. splitOneOf " ,"</lang>
{{Out}}
<pre>▁▁██
9,655

edits