Solving the 3D wave equation
This scripts solves the 3D wave equation using the FFT. It also illustrates how to create nice 3D graphics.
Contents
close all;clear;
Create the grid
N=64; z=linspace(-1,1,N+1); z=z(1:end-1); [xx,yy,zz]=meshgrid(z,z,z);
Parameters.
dt=0.001; L=2; dk=2*pi/L;
Wavenumbers
ksvec(1)=0; ksvec(N/2+1)=0; for ii=2:(N/2) ksvec(ii)=ii-1; ksvec(N/2+ii)=-N/2 + ii -1; end ksvec=ksvec*dk; [k,l,m]=meshgrid(ksvec,ksvec,ksvec); k2=k.*k; l2=l.*l; m2=m.*m;
Create the operators
lap=-(k2+l2+m2); myop=dt*dt*lap;
Create the ICs
r=sqrt(xx.*xx+yy.*yy+4*zz.*zz); u0 = exp(-((r-.4)/.1).^2); u=u0; um1=u0;
Time parameters
numsteps=100; numouts=10; t=0;
Plot ICs
figure(1) clf hold on p=patch(isosurface(xx,yy,zz,u,0.05)); set(p,'FaceColor','blue','EdgeColor','none','facealpha',.3) daspect([1 1 1]) view(3); camlight, lighting phong sl = slice(xx,yy,zz,u,0,[],[]); minc = max(min(u(:)),-1); maxc = min(max(u(:)),1); cbot = -abs(max(abs(minc),abs(maxc))); ctop = -cbot; caxis([cbot ctop]); colormap hot;grid on %colorbar set(sl,'edgecolor','none','facecolor','interp','ambientstrength',1,... 'diffusestrength',0,'specularstrength',0,'facealpha',0.6); mystr=['time = ' num2str(t)]; title(mystr); axis([-1 1 -1 1 -1 1]) drawnow
data:image/s3,"s3://crabby-images/b43c7/b43c7333773a7eea615f0dbb132d02fced995aff" alt=""
Main Loop
for ii=1:numouts
for jj=1:numsteps
Step time.
t=t+dt;
FFT in y.
uf=fft(u);
FFT in x.
uf=fft(uf,[],2);
FFT in z.
uf=fft(uf,[],3);
Make the laplacian piece.
uf=myop.*uf;
iFFT in y.
uf=ifft(uf);
iFFT in x.
uf=ifft(uf,[],2);
iFFT in z.
uf=ifft(uf,[],3);
Knock off the small imaginary parts.
uf=real(uf);
Take a leapfrog step forward.
up1=-um1+2*u+uf; um1=u; u=up1;
end
Step plot
figure(1) clf hold on p=patch(isosurface(xx,yy,zz,u,0.05)); set(p,'FaceColor','blue','EdgeColor','none','facealpha',.3) daspect([1 1 1]) view(3); camlight, lighting phong sl = slice(xx,yy,zz,u,0,[],[]); minc = max(min(u(:)),-1); maxc = min(max(u(:)),1); cbot = -abs(max(abs(minc),abs(maxc))); ctop = -cbot; caxis([cbot ctop]); colormap hot;grid on %colorbar set(sl,'edgecolor','none','facecolor','interp','ambientstrength',1,... 'diffusestrength',0,'specularstrength',0,'facealpha',0.6); mystr=['time = ' num2str(t)]; title(mystr); axis([-1 1 -1 1 -1 1]) drawnow
data:image/s3,"s3://crabby-images/6b745/6b745ce44636dcf6ee0ab6011242339766b6d690" alt=""
data:image/s3,"s3://crabby-images/fa36e/fa36e12a80d5af24e898cbdbc7f830a446d5a7ae" alt=""
data:image/s3,"s3://crabby-images/7d229/7d2294963d6c66cc2dbbb811c5727f6f36909663" alt=""
data:image/s3,"s3://crabby-images/c70d7/c70d709813201f5bf0f3dc2a13451e3e020a512d" alt=""
data:image/s3,"s3://crabby-images/2d132/2d1326afc6814015b55f6ec1b869c5be4f498d86" alt=""
data:image/s3,"s3://crabby-images/069bc/069bc58aa2d1cff3a12b5b5f1e24c739e82f2449" alt=""
data:image/s3,"s3://crabby-images/41235/4123558320a24ab746f1f7e351731840c2bd4220" alt=""
data:image/s3,"s3://crabby-images/5ee98/5ee982650df2e436620dedd5d485e3c365a3918f" alt=""
data:image/s3,"s3://crabby-images/9e2b3/9e2b34d2d5857ecb848dc5b4295055d9532021b4" alt=""
data:image/s3,"s3://crabby-images/22aad/22aad0b2ea9b3e6ed8955ec19df5090486e181b6" alt=""
end