我需要帮助。我有很多变量,我在Graphics[]
命令中使用,它们依赖于一个变量(在我的例子中为H)。我想操纵我的图形,以便通过相应地改变H图形变化的值。但它并不像我想象的那么容易。
如果您对如何实现这一点有任何想法,我将不胜感激。
(*This variables are dependent on H that I want to change in
manipulate*)
R = 10;
\[Alpha] = ArcSin[H/R];
p = H/Tan[\[Alpha]];
n = 1.5;
\[Beta] = ArcSin[n Sin[\[Alpha]]];
\[Theta] = \[Beta] - \[Alpha];
l = H/Tan[\[Theta]];
(*This is the graphic I want to make manipulated*)
Graphics[{(*Incident ray*)Line[{{-2, H}, {p, H}}],(*Prism*)
Circle[{0, 0}, R, {0, Pi/2}],
Line[{{0, 0}, {0, 10}}],(*Refracted ray*)
Line[{{p, H}, {p + l, 0}}],(*Surface*)
Line[{{0, 0}, {p + l + 10, 0}}]}]
这是我的解决方案之一,但它确实非常混乱。我所做的只是手动插入这些值。有没有更合适的方法来实现这个目标:
R = 10;
n = 1.5;
Manipulate[
Graphics[{(*Incident ray*)
Line[{{-2, H}, {H/Tan[ArcSin[H/10]], H}}],(*Prism*)
Circle[{0, 0}, R, {0, Pi/2}],
Line[{{0, 0}, {0, 10}}],(*Refracted ray*)
Line[{{H/Tan[ArcSin[H/10]],
H}, {H/Tan[ArcSin[H/10]] +
H/Tan[ArcSin[n Sin[ArcSin[H/10]]] - ArcSin[H/10]],
0}}],(*Surface*)
Line[{{0,
0}, {H/Tan[ArcSin[H/10]] +
H/Tan[ArcSin[n Sin[ArcSin[H/10]]] - ArcSin[H/10]] + 10,
0}}]}], {H, 0.0001, 10, Appearance -> "Labeled"}]
还有如何使我的图形不断改变它的大小。我希望棱镜具有固定的尺寸和入射光线来改变它的位置(当H在上面的例子中得到> 6.66时/本解决方案)。
问题可能令人困惑,但如果你在Mathematica中尝试,你会看到我想要的东西。感谢您的任何建议。
答案 0 :(得分:7)
我认为你的解决方案一般都不错,马克已在他的回复中注意到了。我也很喜欢Mark的解决方案。仅仅为了实验,我也分享了我的想法。
1)为特定的Manipulate本地化变量总是一件好事,因此它们的值不会泄漏并干扰其他动态内容。如果您在笔记本中有额外的计算 - 它们可能会开始相互重置,这很重要。
2)在这种特殊情况下,如果你试图读取额外的变量,将表达式相互插入,你的方程变得复杂,很难看出为什么它们会失败一些。借助函数TrigExpand和FullSimplify的一些代数可能有助于澄清您的变量H具有取决于折射率值n的限制(见下文)。
3)如果我们知道点(2)我们也可以使变量n动态并且在控制定义中将值H连接到n(重置H的上限),所以它总是应该是H <10 / n。如果[..]也是必要的,那么控件就不会“粉红”。
4)如果你的公式依赖于R,我们也可以使R动态。但是我没有这个信息,所以我通过“虚拟”控件(ControlType - &gt; None)的概念对R进行了本地化 - 这对于Manipulate来说是非常有用的概念。
5)使用PlotRange和ImageSize来停止图形的抖动
6)让它美丽; - )
例如,如果您想要向Wolfram演示项目提交演示,这些要点非常重要。如果你只是在玩 - 我认为你和Mark的解决方案非常好。
谢谢, 维塔利
Manipulate[If[H >= 10/n, H = 10/n - .0001]; Graphics[{
{Red, Thick, Line[{{-2, H}, {Sqrt[100 - H^2], H}}]},
{Blue, Opacity[.5], Disk[{0, 0}, R, {0, Pi/2}]},
{Red, Thick, Line[{{Sqrt[100 - H^2], H},
{(100 n)/(Sqrt[100 - H^2] n - Sqrt[100 - H^2 n^2]), 0}}]}},
Axes -> True, PlotRange -> {{0, 30}, {0, 10}},
ImageSize -> {600, 200}], {{R, 10}, ControlType -> None},
{{n, 1.5, "Refraction"}, 1.001, 2, Appearance -> "Labeled"},
{{H, 3, "Length"}, 0.0001, 10/n - .0001, Appearance -> "Labeled"}]
答案 1 :(得分:5)
我认为您的第一批代码看起来很好并且很容易放入Manipulate
。我建议您使用PlotRange
中的Graphics
选项。
R = 10;
n = 1.5;
Manipulate[
\[Alpha] = ArcSin[H/R];
p = H/Tan[\[Alpha]];
\[Beta] = ArcSin[n Sin[\[Alpha]]];
\[Theta] = \[Beta] - \[Alpha];
l = H/Tan[\[Theta]];
Graphics[{
Line[{{-2, H}, {p, H}}],(*Prism*)
Circle[{0, 0}, R, {0, Pi/2}],
Line[{{0, 0}, {0, 10}}],(*Refracted ray*)
Line[{{p, H}, {p + l, 0}}],(*Surface*)
Line[{{0, 0}, {p + l + 10, 0}}]},
PlotRange -> {{-1,33},{-1,11}}],
{H,0.0001,6,Appearance->"Labeled"}]