首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用`Plots.jl`绘制三维空间中的二维曲面函数

用`Plots.jl`绘制三维空间中的二维曲面函数
EN

Stack Overflow用户
提问于 2016-11-17 08:52:08
回答 1查看 3K关注 0票数 4

在使用Plots.jl绘图时,我遇到了以下问题。我喜欢绘制罗森布罗克函数

代码语言:javascript
复制
rosenbrock(x) = (1.0 - x[1])^2 + 100.0 * (x[2] - x[1]^2)^2

作为表面,它需要一个2d Tuple{Float64,Float64}作为输入。

我能想到的是:

代码语言:javascript
复制
using Plots
gr()

rosenbrock(x) = (1.0 - x[1])^2 + 100.0 * (x[2] - x[1]^2)^2

ts = linspace(-1.0, 1.0, 100)
x = ts
y = map(rosenbrock, [(x, z) for (x,z) in zip(ts,ts)])
z = map(rosenbrock, [(x, y) for (x,y) in zip(ts,ts)])
# plot(x, x, z)
plot(x, y, z, st = [:surface, :contourf])

这就产生了这个情节:

我想我搞砸了一些尺寸,但我不知道我错了什么。

我需要嵌套yx映射的计算才能得到结果吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-11-17 09:53:29

在对我发现的Rosenbrock函数进行快速调查之后,如果我错了,请纠正我,但是您需要指定您不应该在z中嵌套的-vector,或者其他类似的东西,其他人尝试了与显示的这里相同的东西,但是使用了一些情节。

解决方案如下所示,由Patrick 完成

代码语言:javascript
复制
using Plots

function rosenbrock(x::Vector)
  return (1.0 - x[1])^2 + 100.0 * (x[2] - x[1]^2)^2
end

default(size=(600,600), fc=:heat)
x, y = -1.5:0.1:1.5, -1.5:0.1:1.5
z = Surface((x,y)->rosenbrock([x,y]), x, y)
surface(x,y,z, linealpha = 0.3)

这会导致

边注

我很高兴我搜索了这个,因为我一直在为朱莉娅寻找一个3D绘图仪,而不是PyPlot (因为为我的程序的用户设置可能有点麻烦),这个看起来甚至更好,图像可以旋转。

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40650340

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档