Undifined function or variable x
    5 Ansichten (letzte 30 Tage)
  
       Ältere Kommentare anzeigen
    
    Dawid Brits
 am 15 Okt. 2019
  
    
    
    
    
    Bearbeitet: Walter Roberson
      
      
 am 15 Okt. 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 Kommentare
  Stephen23
      
      
 am 15 Okt. 2019
				
      Bearbeitet: Stephen23
      
      
 am 15 Okt. 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.
Akzeptierte Antwort
  Walter Roberson
      
      
 am 15 Okt. 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 Kommentare
  Walter Roberson
      
      
 am 15 Okt. 2019
				
      Bearbeitet: Walter Roberson
      
      
 am 15 Okt. 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
Weitere Antworten (0)
Siehe auch
Kategorien
				Mehr zu Pole and Zero Locations finden Sie in Help Center und File Exchange
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!


