- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
假设:
f[c_,x_]:= c x (1-x)
在[0,1]中固定一个区间(a,b)。 f的Poincare return(to the interval (a,b)) map是一个函数
R[c,x]=f^k[c,x],
其中 k 是第一个迭代使得a<f^k[c,x]<b
(此处f^k[c,x]
表示k
与其自身的f
次组合,即f[c,f[c,...f[c,x]...]]
)
所以,我想写一个函数(或模块)
R[f_,a_,b_,n_,x_]
它考虑 f 的前 n 次迭代并返回第一个落入区间f[c,x]
的迭代[a,b]
的值。
这是我尝试过的:
R[f_[x___ ], a_,b_, n_, x0_] :=
Module[{i, y=x0},
Catch[
For[i = 0, i <= n, i++,
If[a < f[{x}[[1]], y] < b,
Throw[f[{x}[[1]], y]], y = f[{x}[[1]], y]
]
]
]
]
代码不起作用,因为在写入f[{x}[[1]], y]
的地方,f
被理解为乘以数字{x}[[1]]
而不是上面定义的逻辑函数。
请注意,我正在寻找一段简单的代码,如果可能,请不要在您的答案中更改函数 R 的输入数量。
编辑:我想按如下方式调用 R。
R[f[3.5, t], 0.4, 0.7, 100, 0.2]
这应该在应用函数x0=0.2
后第一次落入区间(0.4,0.7)
时返回f[3.5,x]=3.5x(1-x)
的迭代值。 n
只是我们在放弃之前尝试的最大迭代次数。
最佳答案
您遇到的问题是您实际上并未从 Module
返回任何内容.要修复您的代码,如所写,我会使用
R[f_[x___], a_, b_, n_, x0_] :=
Module[{i, y = x0},
Catch[
For[i = 0, i <= n, i++, Print["i= ", i];
If[
a < f[{x}[[1]], y] < b,
y= f[{x}[[1]], y]; Throw[y],
y = f[{x}[[1]], y]
](*If*)
](*For*)
];(*Catch*)
y (* returns y *)
](*Module*)
然而,这可以更简洁地重写为
g[c_][x_] := c x(1 - x)
(* I used Q to differentiate it from R, above. *)
Q[f_, a_, b_, n_, x0_] :=
Module[{i},
(* -- FIXED THIS, See below. -- *)
NestWhile[f, f[x0], Not[a < # < b]&, 1, n]
](*Module*)
注意,我更改了f
的调用方式来自 f[c,x]
至 g[c][x]
.主要优势在于能够通过 g[c]
至 Q
而不是 f[c,t]
其中 t
是虚拟变量。然后像这样调用它
Q[g[3.5], 0.4, 0.7, 100, 0.2]
就像R
一样工作.
编辑:我在考虑扩展上面的代码时,发现了一个缺陷。我的条件是 a < f[#] < b&
这表示只有当下一次迭代的值(value)需求在边界内时,循环才会继续。相反,我们只想在当前迭代超出范围时继续,所以我将其更改为 Not[ a < # < b ]&
.
至于我正在考虑的更改,有时使用这样的计算能够查看完整的迭代列表会很好。为此,我们需要对上述代码进行一些小改动。
Clear[Q]
Options[Q] = {FullList -> False};
Q[f_, a_, b_, n_, x0_, opts : OptionsPattern[]] :=
Module[{i, nst},
nst = If[OptionValue[FullList],
NestWhileList, NestWhile];
nst[f, f[x0], Not[a < # < b] &, 1, n]
](*Module*)
其中介绍了Option
FullList
, 当设置为 True
, Q
将使用 NestWhileList
而不是 NestWhile
.
关于wolfram-mathematica - 逻辑映射 f_c(x)=cx(1-x) 的 Poincare 返回映射,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8217928/
我记得 WRI 的某个人在 official newsgroup 中说出于兼容性目的,Mathematica 7 仍然有一个来自 Mathematica 5 的老式 Mathematica 帮助浏览器
除非巫师先生在度假,否则很难击败这种似乎具有无所不在和无所不知的现象。我们如何使用 Mathematica 和 StackOverflow API 超越他? 最佳答案 这是 Sjoerd 解决方案的一
您好,我无法理解以下函数的输出。 ListPointPlot3D[Table[Sin[x^2 + y], {x, 0, 3, 0.15}, {y, 0, 3
我在图形中显示了一组点: alt text http://img69.imageshack.us/img69/874/plc1k1lrqynuyshgrdegvfy.jpg 我想知道是否有任何命令可以
让 S是具有唯一元素的向量,并且 s它的一个子集,也有独特的元素;例如,S={1,2,3,4,5,6}和 s={1,3,4,6} .现在给出另一个向量 c={7,8,9,7} ,如何创建矢量 C=[7
我想知道如果给定多个替换规则,mma 如何确定在发生碰撞时首先应用哪个规则。一个例子是: x^3 + x^2*s + x^3*s^2 + s x /. {x -> 0, x^_?OddQ -> 2}
在mathematica 中(我使用的是 mma 5.0(猜猜很老)),如果我将以下内容作为一行输入: Needs["Graphics`Master`"]; Animate[Plot[Sin[n x]
如果我有一个字母表,假设 sigma = {1,2,3,4,a,b,c,d,e,f,g} 并且想要生成所有长度为 n 的单词,有没有办法做到这一点? 我可以做 Flatten[Outer[Functi
生成参数列表的素数列表的最简单函数是什么?想出这样的函数并不难,比如: foo[n_] := Block[{A = {}, p = 2}, While[p All] 关于wol
在此示例中,将函数定义为“functionB”时,这是一个奇怪的结果。有人可以解释吗?我想绘制functionB[x]和functionB[Sqrt[x]],它们必须不同,但是此代码显示functio
如何在 Mathematica 中对列表进行数值微分而不先将其拟合为数学表达式(即使用 FindFit )? 具体来说,我想在列表中找到最大斜率的点。 我已经考虑使用 Differences并找到最大
我正在寻找 Mathematica 中原子对象的完整列表(其中 AtomQ 产生 True)。 我知道 Symbol String Integer Real Rational Complex Spar
最近发现了一些old post在 MathGroup 上使用未记录的命令行选项 -batchinput和 -batchoutput显示: If test.mma contains the follo
Mathematica 似乎缺少此功能,或者无论如何我都找不到它。 Series function 可以对多个变量进行连续扩展,但它似乎无法进行完整的多元扩展。 有谁知道如何做到这一点? 谢谢 最佳答
我有兴趣运行相同的函数,该函数以并行方式在多核上使用不同的参数值进行一些蒙特卡罗评估。我还想确保整个函数在同一个内核上运行,而函数内的计算不会跨内核分布。例如,假设我有一个函数(故意简化) f[a_,
我怎样才能从 Range[96] 中不重复地获得 48 个随机对的两个不同元素?即 96 个元素只使用一次。 当我尝试将元组/子集与 Select 结合使用时,我觉得必须有一种更直接的方法来实现这一点
我正在评估 Wolfram Mathematica 8 的大学类(class)项目。 我很难定义目标编程模型。 首先是因为我在数学方面真的很匮乏 :) 其次,因为我在 official documen
我开发了一些代码来从 LogNormalDistribution 和 StableDistribution 的乘积生成随机变量: LNStableRV[{\[Alpha]_, \[Beta]_, \[
我有一个想要优化的字符串验证函数。该字符串的长度为 2n,由 0 和 1 组成,例如 str="100001"。我想测试一下: 1) 字符串中奇数索引位置的 1 的数量(必须不少于 1)是否等于偶数索
请考虑: Function[subID, pointSO[subID] = RandomInteger[{1, 4}, {5, 2}]] /@ {"subA", "subB"}; M
我是一名优秀的程序员,十分优秀!