3d plot error

4 visualizzazioni (ultimi 30 giorni)
www
www il 20 Gen 2017
Commentato: Star Strider il 20 Gen 2017
Hi All!
I have 3 functions and I need to plot them individually on a plot window. However, I kept getting the error 'Z must be a matrix, not a scalar or vector.' Even though I have change my function into 2d (dependent on x and y only). It still doesnt work.
f1(x,y,z) = 8*x.^3+36*y.^3+z.^2-36; f2(x,y,z) = 4x.^2-y.^2-21*z; f3(x,y,z) = 4x.^2-2y.^2+10z.^2;
xxx = linspace(-3,3); yyy = linspace (-3,3);
a = sym(f1); b= sym(f2); c= sym(f3); s = subs(a,'z',1); t = subs(b,'z',1); u = subs(c,'z',1);
[x,y] = meshgrid(xxx,yyy); mesh(x,y,s); hold on mesh(x,y,t); hold on mesh(x,y,u);
Thanks in advance!
  2 Commenti
John Chilleri
John Chilleri il 20 Gen 2017
Modificato: John Chilleri il 20 Gen 2017
To reproduce the error, run:
f1 = @(x,y,z) 8*x.^3+36*y.^3+z.^2-36;
f2 = @(x,y,z) 4*x.^2-y.^2-21*z;
f3 = @(x,y,z) 4*x.^2-2*y.^2+10*z.^2;
xxx = linspace(-3,3);
yyy = linspace (-3,3);
a = sym(f1);
b= sym(f2);
c= sym(f3);
s = subs(a,'z',1);
t = subs(b,'z',1);
u = subs(c,'z',1);
[x,y] = meshgrid(xxx,yyy);
mesh(x,y,s);
hold on mesh(x,y,t);
hold on mesh(x,y,u);
When you give mesh(x,y,s), s is just a symbolic function. I'm guessing you need to say:
[x,y] = meshgrid(xxx,yyy);
s = subs(s,'y',y);
s = subs(s,'x',x);
mesh(x,y,s)
but it's taking a while to run so I can't confirm if this is correct. It feels like this produces an s that is far too large.
www
www il 20 Gen 2017
I'm still getting the same error :/

Accedi per commentare.

Risposta accettata

Star Strider
Star Strider il 20 Gen 2017
You were missing some multiplication operators in your functions. (MATLAB does not recognise implicit multiplication.) I also created your functions as anonymous functions (see Function Basics (link) for details), and then did the plots. The Symbolic Math Toolbox is not always the best option unless you want to specifically do symbolic calculations. Here, it is not necessary.
The Code:
f1 = @(x,y,z) 8*x.^3+36*y.^3+z.^2-36;
f2 = @(x,y,z) 4*x.^2-y.^2-21*z;
f3 = @(x,y,z) 4*x.^2-2*y.^2+10*z.^2;
xxx = linspace(-3,3);
yyy = linspace (-3,3);
[x,y] = meshgrid(xxx,yyy);
z = 1;
figure(1)
mesh(x,y,f1(x,y,z))
hold on
mesh(x,y,f2(x,y,z))
mesh(x,y,f3(x,y,z))
hold off
grid on
  4 Commenti
www
www il 20 Gen 2017
Modificato: www il 20 Gen 2017
You are truly a saver! I'll never forget to donate to polar bear conservation project. :)
Star Strider
Star Strider il 20 Gen 2017
Thank you!
With accelerating global warming, we need all the help we can get!

Accedi per commentare.

Più risposte (0)

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by