公告:本站正式转型为非交互式静态网站!
转型:本站将通过笔记和博客的形式继续为大家服务,关于 Mathematica 问答服务请移步至QQ群:365716997
联系:如有问题请联系QQ群管理员,或发送邮件至:lixuan.xyz@qq.com。
感谢:最后非常感谢大家多年来的支持与帮助!
参考《互联网跟帖评论服务管理规定》《中华人民共和国网络安全法》《网络信息内容生态治理规定》《互联网用户账号信息管理规定》

—— 2022-11-27

欢迎来到 Mathematica 问答社区

提问时请贴上文本代码

语法高亮:在编辑器中点击

被禁止的话题:广告破解

请阅读:《提问的智慧》

备用域名:mma.ooo

支持LaTex数学公式
行内公式标识符:\$ 或“$\backslash ($”+“$\backslash )$”,
行间公式标识符:\$\$ 或 “$\backslash [$”+“$\backslash ]$”

社区建议QQ群:365716997

分类

–5 投票
5.2k 浏览
ContourPlot[
 E^(Sin[x] + Cos[y]) == Sin[E^(x + y)], {x, -10, 10}, {y, -10, 10}, 
 MaxRecursion -> 0, PlotPoints -> 1500]

事实上,别的绘图软件很容易绘出如下效果

用下面的代码的话,为什么左下方多出一部分矩形,并且右上方矩形成型效果很差

Clear["`*"];
data = Compile[{}, 
    With[{y = Range[-10, 10, .01]}, 
     Abs@Table[Clip[E^(Sin[x] + Cos[y]) - Sin[E^(x + y)]], {x, y}]]][];
ArrayPlot[data, ColorFunction -> (Hue[.2, .7, 1 - #] &), 
 DataReversed -> {True, False}]

 

问题关闭原因: 问题暂时告一段落吧
分类:绘图 | 用户: mma-2-2-2 (1.3k 分)
已关闭 用户:mma-2-2-2
-1。我四个链接放出来不是让你抄的。
data = Table[
   With[{a = Interval[{x, x + .025}], b = Interval[{y, y + .025}]},
    IntervalMemberQ[E^(Sin[a] + Cos[b]) - Sin[E^(a + b)],
     0]], {x, -10, 10, .025}, {y, -10, 10, .025}];
ArrayPlot[Boole@Reverse[data, 1]]
这段代码效果十分满意,可是问题中那段代码多出的矩形部分和右上方矩形成形效果差的问题实在不知道该怎么调整,我只会调整左右顺序。

2 个回答

+2 投票
 
已采纳

这类图在Mathematica里的简单高效的画法几乎可以说是有定论的。明明是公开的讨论却总是无法传承也是搞得我心塞:

http://tieba.baidu.com/p/2776245919?pid=43465289339&cid=0#43465289339

http://tieba.baidu.com/p/2504432886?pid=36525064381&cid=36526175919#36526175919

http://tieba.baidu.com/p/3517568789

http://tieba.baidu.com/p/2578898520

 

----

算了,贴个通用解法,想抄就抄吧:

Clear[equationPlot, gradEquationPlot, approxEquationPlot]
equationPlot[type___][expr : Except[{__}], rest__] := equationPlot[type][{expr}, rest];
equationPlot[type___][eqn : {HoldPattern@Equal[_, _] ..}, rest__] := 
  equationPlot[type][Subtract @@@ eqn, rest];

findZero["grad"] := Abs@Differences[# // UnitStep, {0, 1}] &;
findZero["approx", limit_: 1/100] := 
  Function[(1 - UnitStep[-limit - #]) (1 - UnitStep[-limit + #])];

equationPlot[type : "grad" | "approx" : "approx", limit___][
   expr_, {x_, xl_, xr_}, {y_, yl_, yr_}, step_: 1/100, prec_: MachinePrecision] := 
  With[{rx = Range[xl, xr, N[step, prec]], ry = Range[yl, yr, N[step, prec]], 
    rcolor = Range@Length@expr}, 
   ContourPlot[False, {x, xl, xr}, {y, yl, yr}]~Show~
    ArrayPlot[rcolor findZero[type, limit][
        Function[{x, y}, expr][#, ry] & /@ rx // Transpose] // Total, 
     DataReversed -> True, DataRange -> {{xl, xr}, {yl, yr}}, 
     ColorRules -> (# -> ColorData[1][#] & /@ rcolor)]];

gradEquationPlot = equationPlot["grad"];
approxEquationPlot = equationPlot["approx"];

 

equationPlot["approx", 1/10][

 E^(Sin[x] + Cos[y]) == Sin[E^(x + y)], {x, -10, 10}, {y, -10, 10}, 1/100] gradEquationPlot[E^(Sin[x] + Cos[y]) == Sin[E^(x + y)], {x, -10, 10}, {y, -10, 10}]
用户: xzczd (2.2k 分)
修改于 用户:xzczd
如果在你的审美里,强振荡的部分在图象里必须得糊成一团黑才叫效果好,那我也没什么好说的。
不再讨论了,谢谢大家的无私帮助
因为这个地方本来就是这么稠密的,你画不出来还有理了?
而且再说你的函数:
equationPlot["approx", 1/10][
 Abs[x + y] + .0001, {x, -10, 10}, {y, -10, 10}, 1/100]
gradEquationPlot[Abs[x + y], {x, -10, 10}, {y, -10, 10}]
第一个不该画出来的画出来(这里当然可以改小approx,但是复杂函数能这么容易看出来approx?),第二个该画出来的没画,这已经不是效果差不差的问题了。
稠密的振荡和一马平川的0也是不一样的,把它们画成一样就有理了?上面已经说了,见仁见智的问题。至于你新举的两个例子,如果你这回要拿我在形容自己的代码时用了“通用”两个字说事儿那我也依旧没什么好说的,这里只补充一句"approx"被选为默认方法就是为了多少能规避一点上述问题。最后,Interval方法的优化极限大概是:
With[{step = .05},
  With[{x = Range[-10, 10, step]},
   ArrayPlot[Boole@IntervalMemberQ[E^(Sin[#1] + Cos[x]) - Sin[E^(#1 + x)], 0] &@
       Interval@{#, # + step} & /@ x, DataReversed -> True]]] // AbsoluteTiming

最后的最后,需要指出的是,Interval方法在这个方程上表现得好,其实也是歪打正着,具体原因请参看Interval的自带帮助的“可能存在的问题”。限于精力,本条评论发出后我不会再参与本话题的讨论,其他参与者们请随意。
我说的Interval是指算法,而不局限于mma的Interval函数,事实上我是先用python实现的,没怎么优化过,大概也就比你上边所谓的“优化极限大概”快二三十倍吧,也就是比你上边那个所谓的“通用绘图”再快个10倍,不单性能更高,而且不会有你所谓的“可能存在的问题”中的问题,mma完全可以自己实现更加高性能和可靠的区间算数,我这里直接用了interval一方面是为了更清楚的表示算法,一方面也是因为这里用起来正好没问题。
+1 投票

此类图建议使用这个软件绘制:GrafEq,软件的核心算法也是公开的:
http://www.dgp.toronto.edu/people/mooncake/papers/SIGGRAPH2001_Tupper.pdf

顾森的博客上有简要的介绍,官方网站中不但有详细介绍,还有大量非常漂亮的图片及其对应的函数。


由于绘图算法不同,要想用Mma中内置函数实现,计算成本是很高的。
如果有精力,可以参考上面的算法,写一个绘图函数。

用户: 野鹤 (5.1k 分)
...