gpt4 book ai didi

haskell - 条件 QuickCheck 属性

转载 作者:行者123 更新时间:2023-12-04 00:08:52 24 4
gpt4 key购买 nike

我为一个函数编写了一个 QuickCheck 属性,该函数将两个排序的输入合并到一个排序的输出中:

prop_merge xs ys =
if (sorted xs && sorted ys) then (sorted (merge xs ys)) else True

也就是说,当输入被排序时,输出也被排序。也可以写成:
prop_merge xs ys = not(sorted xs && sorted ys) || (sorted (merge xs ys))

但我真的不喜欢这两个版本。 QuickCheck 中的“条件属性”是否有更好的语法?

最佳答案

您可以使用 ==> 运算符将 bool 条件附加到您的属性:

prop_merge xs ys = (sorted xs && sorted ys) ==> sorted (merge xs ys)

这不仅是一种更好的语法,而且允许 QuickCheck 区分测试成功的测试用例和不满足先决条件的测试用例。在后一种情况下,测试不计算在内,QuickCheck 会生成新的输入。

但是,在大多数输入不满足条件的情况下,这将导致您的测试运行得更慢,或者,如果丢弃了足够多的输入,QuickCheck 最终将放弃。由于随机列表不太可能被排序,因此上面的示例很可能会发生这种情况:
> quickCheck (prop_merge :: [Int] -> [Int] -> Property)
*** Gave up! Passed only 15 tests.

(请注意,使用标准 bool 运算符而不是使用 ==> 时,QuickCheck 将提升所有通过的测试,当大多数测试由于前置条件失败而无用时)

出于这个原因,通常最好只直接生成您需要的测试用例。对于简单的情况, Test.QuickCheck.Modifiers 模块包含几个有用的新类型,它们修改了输入的生成方式。例如, OrderedList 修饰符将仅生成排序列表,因此我们可以将您的属性简单地编写为:
prop_merge (Ordered xs) (Ordered ys) = sorted (merge xs ys)

关于haskell - 条件 QuickCheck 属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12884927/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com