- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我面临着为生成器编写收缩函数的问题,该函数取决于另一个生成器输出的值。基本上是以下形式的生成器:
do
a <- genA
b <- f a
pure $! g a b
哪里genA :: Gen a
, f :: a -> Gen b
g :: a -> b -> c
。为了便于论证,假设 g = (,)
。那么问题是给定一对 (a, b)
,缩小a
可能会破坏 a
之间存在的关系, f
和b
。
举个例子,请考虑以下具有缓存长度的列表:
data List =
List
{ llength :: Int
, list :: [Int]
} deriving (Eq, Show)
arbitrary
可以轻松定义函数:
instance Arbitrary List where
arbitrary = do
n <- choose (0, 10)
xs <- vector n
pure $! List { llength = n, list = xs }
但是缩小 List n xs
形式的元素需要了解 n
之间的关系和xs
.
在前面的示例中,这不是问题,因为 n
之间的关系和xs
很容易确定,但是对于我正在努力确定这种关系的问题来说并不是微不足道的。
类似 hedgehog
的库该功能集成收缩将解决这个特定问题(尽管 not always ),但是我想知道 QuickCheck
中是否有原则性的方法来解决这个问题.
Here是一个示例,显示了 hedgehog
如何找到列表长度小于 5 的属性的最小反例(它始终给出 List 5 [ 0 , 0 , 0 , 0 , 0 ]
作为反例)。和here这是我(认为我)目前如何解决这个问题的一个例子,基本上是通过模拟集成收缩。
此外,请注意 hedgehog
的单子(monad)接口(interface)的行为is probably not what you want most of the time .
最佳答案
没有什么 Elixir 。据我所知,集成收缩是通用解决方案的最先进技术,并且有您提到的注意事项。它内置于 Hedgehog 中,但该方法也与 QuickCheck 100% 兼容,后者只是在缩小问题上采取中立立场,因为甚至没有接近一刀切的解决方案。
Libraries like hedgehog that feature integrated shrinking would solve this particular problem (albeit not always), however I'm wondering if there is a principled way to solve this in QuickCheck.
这个问题表明 Hedgehog 和 QuickCheck 之间存在某种方法论上的二分法,但事实并非如此。他们遵循不同的设计理念,但完全不反对。
集成收缩(即在同一单子(monad)中混合生成和收缩)处于通用性和便利性的最佳点;它内置于 Hedgehog 中,但也可以在 QuickCheck 之上构建等效的东西。没有根本性的障碍,只是与简单地使用 Hedgehog 中已有的内容相比,不值得付出努力。
QuickCheck 的组织方式不同,具有单独的生成器 Gen a
和收缩器 a -> [a]
。如果您想生成一棵值树并将其用于收缩(这就是集成收缩的工作原理),您可以自由地继续执行。关键是,选择是你自己做出的,而不是含蓄地为你做的;作为交换,您可以从正交概念(生成和缩小)的两个简单抽象开始,而不是通过一个将这两个概念联系在一起的更复杂的抽象。实际上,差异是表面的,并且很容易显式地分解或合并回这些抽象。
关于haskell - QuickCheck 中的相关收缩,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59466970/
我正在处理 Real WorldHaskell其中一个 第4章的练习是实现一个foldr基于版本的concat .我认为这将是一个很好的测试候选者 QuickCheck 因为有一个现有的实现来验证我的
我要延期 QuickCheck在测试失败时给我更好的信息(而不仅仅是种子)。例如,我希望能够按照以下方式创建内容: eqTest :: Eq a => a -> a -> TestResult eqT
有没有人确切地知道如何使用 QuickCheck 在 Haskell 中定义生成器,以便仅选择一次所选元素? 我已经意识到我可能需要一个“Gen(Maybe Positive)”生成器,但这当然会产生
我有以下要使用快速检查测试的属性: prop_zip xs ys = length xs == length ys ==> unzip (zip xs ys) == (xs,ys) 尽管根据
我有一个具有以下类型签名的函数 rndListIndex :: Double -> Double -> Double -> Double rndListIndex maxIdx r1 r2 = … 第
鉴于以下情况: test :: (Int -> Int) -> Int -> Bool test _ _ = True 编译源码后,我尝试运行quickCheck test : > quickChec
为什么没有QuickCheck功能类似于 hedgehog的 success ?特别是我想知道如何翻译如下属性: prop_specialPair :: Property prop_specialPa
我有一个如下所示的 QuickCheck 属性: prop42 :: Foo -> Bool prop42 foo = fn1 foo == fn2 foo 如果此属性失败,它将打印出 foo曾是。但
所以我有这个 quickCheck 命题逻辑生成器: instance Arbitrary Form where arbitrary = genForm genForm = sized genF
背景 为了好玩,我正在尝试编写一个用于快速检查的属性,以测试 cryptography with RSA 背后的基本思想。 . 选择两个不同的素数,p和 q . 让 N = p*q e是某个数字rel
我有一组对字符串进行编码/解码的简单演示程序,并希望为它们生成一些 quickCheck 测试,但将测试限制为仅可打印的字符串。由于生成和拒绝的测试用例太多,使用 guard 太慢并且失败,所以我想为
我有两个生成器,gen_n 和 gen_arr: gen_n :: Gen Int gen_n = suchThat arbitrary (\i -> i >= 0 && i i >= 0 && i
我面临着为生成器编写收缩函数的问题,该函数取决于另一个生成器输出的值。基本上是以下形式的生成器: do a Gen b g :: a -> b -> c 。为了便于论证,假设 g = (,) 。
我有一个数据类型定义: data Point = Point {x :: Int, h :: Int} | EmptyPoint 在我的属性测试中,我想将测试限制为仅针对 Point 构造函数案例。例
propertyForStringsFromMyCharPool :: String -> Bool -- implementation main = T.quickCheck propertyFor
我有一个类型类 Atomic,它定义了将某些类型与包装器值 (Atom) 相互转换的函数。我想定义一个 QuickCheck 属性,它声明:“对于 Atomic 的所有实例,可以安全地存储和检索任何值
tl;dr:如果您的数据类型允许太多嵌套,您如何编写不会爆炸的 Arbitrary 实例?您如何保证这些实例产生您的数据结构的真正随机样本? 我想生成随机树结构,然后在用我的库代码破坏这些结构后测试它
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题吗? 更新问题,以便 editing this post 提供事实和引用来回答它. 关闭 7 年前。 Improve
我正在尝试为身份编写一个 QuickCheck 测试 f $ y = f y 我最初的计划是编写一个返回函数和整数的任意生成器,签名为 Gen (Int -> Int, Int) 并且在 prop_D
我正在使用 Test.QuickCheck 生成随机数独谜题。 data Sudoku = Sudoku { getSudoku :: [[Maybe Int]] } deriving (Show,
我是一名优秀的程序员,十分优秀!