from functools import partial
import hypothesis as h
import hypothesis.strategies as hs
import hypothesis.extra.numpy as hnp
import numpy as np
floats_notnull = partial(hs.floats, allow_nan=False, allow_infinity=False)
complex_notnull = partial(hs.complex_numbers, allow_nan=False, allow_infinity=False)
data_strategy_real = hnp.arrays(
np.float64,
hs.tuples(hs.integers(min_value=2, max_value=50),
hs.integers(min_value=2, max_value=5)),
floats_notnull()
)
data_strategy_complex = hnp.arrays(
np.complex64,
hs.tuples(hs.integers(min_value=2, max_value=50), hs.just(1)),
complex_notnull()
)
data_strategy = hs.one_of(data_strategy_real, data_strategy_complex)
如果您运行data_strategy.example()
几次,您会注意到结果中的某些值具有无限的实部或虚部。我的意图是明确禁止无限或 NaN 部分。
我究竟做错了什么?
更新:如果我使用
data_strategy = hs.lists(complex_notnull, min_size=2, max_size=50)
并将其转换为我的测试中的数组,问题似乎消失了。复数是否溢出?我没有收到关于假设溢出的通常弃用警告。
如果我使用
data_strategy = data_strategy_real
没有inf
出现。