以下は、2147483647が素数であるため、Trueを返します。なぜこのハスケルは、拡張されたときにあいまいなタイプについて文句を言うのですか?
length [f | f <- [2..(floor(sqrt 2147483647))], 2147483647 `mod` f == 0 ] == 0
なぜ私は以下のように拡張しようとしないのですか?
Prelude> [n | n <- [2..], length [f | f <- [2..(floor(sqrt n))], n `mod` f == 0 ] == 0 ]
<interactive>:1:39:
Ambiguous type variable `t' in the constraints:
`RealFrac t' arising from a use of `floor' at <interactive>:1:39-51
`Integral t' arising from a use of `mod' at <interactive>:1:56-64
`Floating t' arising from a use of `sqrt' at <interactive>:1:45-50
Probable fix: add a type signature that fixes these type variable(s)
私は理解できませんが、なぜRealFracは床の使用から生じるのですか?私はフロアがRealFracsを取ってIntegralsを生産したと思った?さらに、上の例では不平を言っていませんでした。
Prelude> :t floor
floor :: (RealFrac a, Integral b) => a -> b
ハスケルのデフォルトのメカニズムは、一般的にそのようなあいまいさを処理します。例えば、「Floating」のインスタンスは、通常は「Double」にデフォルト設定されます。問題のエラーは、デフォルトのタイプのすべての可能な選択肢を除外する制約が原因です。 –