Plotting a multivariable function, that also has a summation
9 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen

Good Afternoon everyone,
I am attempting to plot the funtion above in matlab, I have been trying with symsum, for loops & 3D plots but can't get it to work. Hopefully someone can help me!
Thank you
2 Kommentare
Akzeptierte Antwort
Torsten
am 10 Dez. 2022
Bearbeitet: Torsten
am 10 Dez. 2022
xstart = 0.0;
xend = 1.0;
nx = 100;
tstart = 0.0;
tend = 5.0;
nt = 100;
nsum = 31;
X = linspace(xstart,xend,nx);
T = linspace(tstart,tend,nt);
U = zeros(nx,nt);
for ix = 1:nx
x = X(ix);
for it = 1:nt
t = T(it);
for isum = 1:2:nsum
U(ix,it) = U(ix,it) + ?
end
end
end
U = U * 400/pi^3;
surf(X,T,U)
3 Kommentare
Torsten
am 11 Dez. 2022
Bearbeitet: Torsten
am 11 Dez. 2022
You have two dimensions in your equation: x in space and t in time.
Both dimensions are independent from each other.
So you need two loops to calculate values for U depending on a given value of x (this is the loop with ix) and a given value of t (this is the loop with it) simultaneously, thus for a pair (X(ix),T(it)).
The value U(ix,it) at X(ix) and T(it) is given by an infinite series. Thus you need a third loop over the number of elements of the series you want to account for. This is the loop with isum. If you feel better then, you can replace isum by n. For simplicity, I chose a fixed value for the number of elements of the series that are summed (31) (independent of x and t). Usually, this is done by evaluating the size of the series elements and a stopping criterion for each pair (X(ix),T(it)) separately.
Weitere Antworten (1)
Paul
am 11 Dez. 2022
Hi Ali,
Another approach that you might be interested in, which is less code but requires more memory, is to use an anonymous function
u = @(x,t,N) 400/pi^3*sum(sin(pi*reshape(1:2:N,1,1,[]).*x).*exp(-reshape(1:2:N,1,1,[]).^2.*pi^2.*0.003.*t)./reshape(1:2:N,1,1,[]).^3,3);
[X,T] = meshgrid(0:.1:1);
Nsum = 31; % uppler limit on the n-summation
surf(X,T,u(X,T,Nsum))
Memory could be reduced by loop-summing u over scalar values of n for a fixed set of values of X and T
U = 0*X;
for n = 1:2:31
U = U + u(X,T,n);
end
surf(X,T,U)
0 Kommentare
Siehe auch
Kategorien
Mehr zu Performance and Memory 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!

