使用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
的映射才能得到结果?