我正在尝试在不同的行上打印autocorrelation结果的不同组成部分:
import Data.Vector as V
import Statistics.Autocorrelation
import Data.Typeable
sampleA = [1.0, 2.0, 3.0, 4.0, 1.0, 2.0, 3.0, 4]
main = do
let res = autocorrelation $ V.fromList sampleA
putStr "Type of result of autocorrelation test: "
print $ typeOf res
print res
-- Prelude.mapM_ print res -- not working; 输出为:
Type of result of autocorrelation test: ((Vector Double),(Vector Double),(Vector Double))
([1.0,2.5e-2,-0.45,-0.325,0.5,0.125,-0.15],[1.0,-1.3255000000000001,-1.4039375473415425,-1.442999810318651,-1.5311377955236107,-1.5364636906417393,-1.544097864842309],[1.0,1.0755000000000001,1.1539375473415425,1.192999810318651,1.2811377955236107,1.2864636906417393,1.294097864842309])但是,如果我取消对最后一行的注释,我会得到错误:
• No instance for (Foldable ((,,) (Vector Double) (Vector Double)))
arising from a use of ‘Prelude.mapM_’
• In a stmt of a 'do' block: Prelude.mapM_ print res
In the expression:
do { let res = autocorrelation $ fromList sampleA;
putStr "Type of result of autocorrelation test: ";
print $ typeOf res;
print res;
.... }
In an equation for ‘main’:
main
= do { let res = ...;
putStr "Type of result of autocorrelation test: ";
print $ typeOf res;
.... }如何在单独的行上打印结果的所有部分?谢谢你的帮助。
发布于 2019-09-14 09:51:14
最简单的事情就是模式匹配。
main = do
let (a,b,c) = autocorrelation $ V.fromList sampleA
print a
print b
print c发布于 2019-09-14 11:55:43
如果你真的不想自己进行模式匹配,你可以使用the fixed-vector package来帮助你。请注意,它有自己的mapM_,您必须使用它:
import Data.Vector as V
import qualified Data.Vector.Fixed as F
import Statistics.Autocorrelation
import Data.Typeable
sampleA = [1.0, 2.0, 3.0, 4.0, 1.0, 2.0, 3.0, 4]
main = do
let res = autocorrelation $ V.fromList sampleA
putStr "Type of result of autocorrelation test: "
print $ typeOf res
print res
F.mapM_ print res或者,您可以创建一个newtype并将您的元组放在其中:
{-# LANGUAGE DeriveFoldable #-}
import Data.Vector as V
import Statistics.Autocorrelation
import Data.Typeable
newtype Triple a = Triple (a, a, a) deriving(Foldable)
sampleA = [1.0, 2.0, 3.0, 4.0, 1.0, 2.0, 3.0, 4]
main = do
let res = autocorrelation $ V.fromList sampleA
putStr "Type of result of autocorrelation test: "
print $ typeOf res
print res
Prelude.mapM_ print $ Triple reshttps://stackoverflow.com/questions/57931873
复制相似问题