Undifined function or variable x
2 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
Dawid Brits
le 15 Oct 2019
Modifié(e) : Walter Roberson
le 15 Oct 2019
I am trying to create a matlab function that graphs a particular function in 3D, however I keep getting the error undifined variable or not enough input arguments, Here is my code.
R1 = 2;
R2 = 1;
s1 = [-2;2];
s2 = [3;-1];
n1 = 2;
n2 = 1;
%for values of x and y between -5 and 5
landscape(-5:5, -5:5);
function M = landscape(x, y)
M = H1 + H2;
function h1 = H1(x, y, R1, s1, n1)
h1 = (1/(1+(R1/sqrt((x-s1(1))^2+(y-s1(2))^2))^n1));
end
function h2 = H2(x, y, R2, s2, n2)
h2 = (1/(1+(R2/sqrt((x-s2(1))^2+(y-s2(2))^2))^n2));
end
surf(M)
contour(M)
end
%Thanks
2 commentaires
Stephen23
le 15 Oct 2019
Modifié(e) : Stephen23
le 15 Oct 2019
You defined two nested functions H1 and H2, each with five input arguments:
function h1 = H1(x, y, R1, s1, n1)
then you call those functions withput any input arguments at all:
M = H1 + H2;
The variables R1, s1, n1 are not defined inside landscape.
Réponse acceptée
Walter Roberson
le 15 Oct 2019
function better_homes_and_gardens
R1 = 2;
R2 = 1;
s1 = [-2;2];
s2 = [3;-1];
n1 = 2;
n2 = 1;
%for values of x and y between -5 and 5
landscape(-5:5, -5:5);
function M = landscape(x, y)
M = H1(x, y, R1, s1, n1) + H2(x, y, R2, s2, n2);
function h1 = H1(x, y, R1, s1, n1)
h1 = (1./(1+(R1/sqrt((x-s1(1)).^2+(y-s1(2)).^2)).^n1));
end
function h2 = H2(x, y, R2, s2, n2)
h2 = (1./(1+(R2/sqrt((x-s2(1)).^2+(y-s2(2)).^2)).^n2));
end
surf(M)
contour(M)
end
end
4 commentaires
Walter Roberson
le 15 Oct 2019
Modifié(e) : Walter Roberson
le 15 Oct 2019
function better_homes_and_gardens
R1 = 2;
R2 = 1;
s1 = [-2;2];
s2 = [3;-1];
n1 = 2;
n2 = 1;
%for values of x and y between -5 and 5
landscape(-5:5, -5:5);
function M = landscape(x, y)
M = H1(x, y, R1, s1, n1) + H2(x, y, R2, s2, n2);
function h1 = H1(x, y, R1, s1, n1)
h1 = (1./(1+(R1./sqrt((x-s1(1)).^2+(y(:)-s1(2)).^2)).^n1));
end
function h2 = H2(x, y, R2, s2, n2)
h2 = (1./(1+(R2./sqrt((x-s2(1)).^2+(y(:)-s2(2)).^2)).^n2));
end
surfc(M)
end
end
Plus de réponses (0)
Voir également
Catégories
En savoir plus sur Pole and Zero Locations dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!