【发布时间】:2017-03-31 17:25:42
【问题描述】:
我在使用Plots.jl 绘图时遇到以下问题。我喜欢绘制 Rosenbrock 函数
rosenbrock(x) = (1.0 - x[1])^2 + 100.0 * (x[2] - x[1]^2)^2
作为表面,期望 2d Tuple{Float64,Float64} 作为输入。
我能想到的是:
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])
我想我搞砸了一些维度,但我不明白我做错了什么。
我是否必须嵌套 y 和 x 的映射计算才能得到结果?
【问题讨论】:
-
我建议你试着把你的问题表述得更清楚一点,我不知道你在做什么,我也不知道问题是什么
-
@isebarn 我已经更新了这个问题。我喜欢将函数绘制为一个曲面,但我不知道该怎么做。
标签: optimization plot julia surface plots.jl