- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 Haskell 的新手,我有以下代码:
second (x:y:xs) = y : second xs -- returns every second element of a list
second _ = []
xs = [1,2,3,4] ++ second xs
我希望 xs
被评估为 [1,2,3,4,2,4,4]
,因为那是固定点,即 [1,2,3,4,2,4,4] == [1,2,3,4]++ 秒 [1,2,3,4,2,4,4]
。
但是,当我尝试在 GHCi 中评估 xs
时,我得到了
Prelude> xs
[1,2,3,4,2,4,4
但它不会停止计算。
谁能解释为什么这不会停止,有没有一种简单的方法可以让计算停止并返回[1,2,3,4,2,4,4]
?
最佳答案
[1,2,3,4,2,4,4]++ []
是 ([1,2, 3,4]++) 。第二个
,但它不是最小的固定点。
即[1,2,3,4,2,4,4]++ undefined
,更小。它更小,因为它比第一个定义更少。
第一个定义更多,因为它的第 7 个尾部已定义,而第二个的第 7 个尾部是 undefined
。
这就是总体前景。但具体来说,我们可以一步一步地计算,命名所有中间值并扩展定义,我们会发现结果上的“get”点 catch 了最初更靠前的“put”点,但是“get”点比“put”快两倍。所以当他们见面时,那里还没有我们可以得到的东西。
因此计算被卡住了,等待一些东西出现在没有任何东西的地方,并且没有任何东西可以在那里放置任何东西。
避免这种情况的唯一方法是将 take 7
放在上面。
在不相关的注释中,我将该函数称为 seconds
,而不是 second
。
原来是这样的:
xs = [1,2,3,4] ++ second xs
a b c (_:a:p) = xs = [1,2,3,4]++second xs
↓ ↓ ↓ (_:b:q) = p = [ 3,4,2]++second p
= 1 2 3 4 2 4 4 (_:c:r) = q = [ 2,4]++second q
↓ ↓ ↓ ↓ r = [ 4]++second r
a b c
↑ ↑ ↑ ↑ r = drop 2 q = second q =
xs p q r = second (2:4:r) = 4:second r
head r
定义明确,是
r = drop 2 q = second q
= second (_:c:r)
= c:second r
head r = c = 4
tail r =
但是我们需要找到tail r
。它是 (:)
数据节点吗?是[]
吗?
= tail (c:second r)
= second r -- (1)
= second (c:second r)
= case (c:second r) of
(x:y:z) -> y:second z
[] -> []
= case (second r) of -- (2)
(y:z) -> y:second z
所以要找出 second r
( (1)
) 是什么,我们需要找出 what second r
( (2)
) 是。
我们被困住了。
关于haskell - 为什么这个定点计算不停止?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69418700/
当我在定点 Z3Py 中启用解释生成选项时,我收到包含以下消息的核心转储。 Error setting 'DL_GENERATE_EXPLANATIONS', reason: unknown opti
我正在开发一些代码,可以从 HW 获取浮点或定点数据。目前我们将其作为 float 。 底层API都是定点的。所以我们必须将数据作为定点传回。我们使用的算法是 Cholesky。我想知道为什么我们必须
我有一个关于在 MATLAB 中为 Texas Instruments TMS320C64xx DSP 编写算法的问题: 我在 MATLAB 中草率地实现了我的过滤器。我的目标是使用 MATLAB E
我需要将 float 转换为Q31定点,Q31表示1个符号位,0位表示整数部分,31位表示小数部分。这意味着 Q31 只能表示 [-1,0.9999] 范围内的数字。 根据定义,从浮点转换为定点时,会
我正在使用第 3 方定点 antilog() 函数来计算分贝 out_mag = 10^( in_db/20 ) 的幅度。 antilog() 采用 Q6.25 格式作为输入,并在输出时提供 Q16.
我想将一个定点数(Q31/int32 表示具有 31 个小数位的小数)除以另一个 Q31/int32。我想计算z = y/x,知道abs(x)>abs(y)。因此,z<1,因此可以表示为另一个Q31/
我是一名优秀的程序员,十分优秀!