海洋数值模型 利用简单的差分简化海洋方程

先根据一些方程画出流场分布

再模拟一滴墨水的运动

% 并非我想要的三维,我想要的是先有每个位置(二维)的波高/密度等值,然后模拟下一个时刻波高大小
%而受到一些流速等影响,但不用我考虑,只要离散化,知道和上一时刻哪些位置的波高有关,并知道系数即可
%此题研究的是单个点? 知道流场 ,研究单个点位置变化  此时fi表示的是位置?
%事实上,此题研究的就是类似波高的量,此题研究的也是每个点,而为了描述示踪剂的位置,
%可以将变量理解为“浓度”,而不同位置的浓度大小与流场的关系这里不用研究,反正可以随时间扩散
%若研究单一质点,扩散后还需要将原位置的值清零,太麻烦也不准确
clc;
clear all;
close all;

F=1;
b=5*10^3;
p=0.05;
q=0.95;
A=2*10^-4;
B=1.3*10^-3;
PI=3.1415926;
k=10^-2;
dx=100;
dy=100;
dt=3600;
f(1:101,1:51,1)=0.0;
for x=1:101
 for y=1:51
 u(x,y)=F*(PI/b)*cos(PI*(y-1)*dy/b)*(p*exp(A*(x-1)*dx)+q*exp(-B*(x-1)*dx)-1);
 v(x,y)=-F*sin(PI*(y-1)*dy/b)*(p*A*exp(A*(x-1)*dx)-q*B*exp(-B*(x-1)*dx));
 end
end
xi=0:100:10000;
yi=0:100:5000;
figure
[yi,xi]=meshgrid(yi,xi);
quiver(xi,yi,u,v,2)
axis([0 10000 0 5000])
xlabel('X(km)');
ylabel('Y(km)');
title('Current Field')
colormap('jet')
colorbar
for x=1:101
 for y=1:51
     for t=1:8760
 S(x,y,t)=0.0;
     end
 end
end
S(31,11,1)=1.0; 
t1=0;
for t=1:8760 
 for x=2:100
 for y=2:50
 if(u(x,y)>=0 && v(x,y)>=0)
 advection=-u(x,y)*(f(x,y,t)-f(x-1,y,t))/dx*dt ...
 -v(x,y)*(f(x,y,t)-f(x,y-1,t))/dy*dt; 
 end
 if(u(x,y)>0 && v(x,y)<0)
 advection=-u(x,y)*(f(x,y,t)-f(x-1,y,t))/dx*dt ...
 -v(x,y)*(f(x,y+1,t)-f(x,y,t))/dy*dt; 
 end
 if(u(x,y)<0 && v(x,y)>0)
 advection=-u(x,y)*(f(x+1,y,t)-f(x,y,t))/dx*dt ...
 -v(x,y)*(f(x,y,t)-f(x,y-1,t))/dy*dt; 
 end
 if(u(x,y)<0 && v(x,y)<0)
 advection=-u(x,y)*(f(x+1,y,t)-f(x,y,t))/dx*dt ...
 -v(x,y)*(f(x,y+1,t)-f(x,y,t))/dy*dt; 
 end
 diffusion=k*(f(x+1,y,t)-2*f(x,y,t)+f(x-1,y,t))/(dx^2)*dt ...
 +k*(f(x,y+1,t)-2*f(x,y,t)+f(x,y-1,t))/(dy^2)*dt; 
 
 f(x,y,t+1)=f(x,y,t)+advection+diffusion+S(x,y,t)*dt/3600; 
 end
 end
 f(1,:,t+1)=0;
 f(101,:,t+1)=0;
 f(:,1,t+1)=0;
 f(:,51,t+1)=0;
 
 if (mod(t,24)==0) 
 t1=t1+1;
 ff(:,:,t1)=f(:,:,t+1);
 end
end
figure
xi=0:100:10000;
yi=0:100:5000;

[yi,xi]=meshgrid(yi,xi);
for k =1:360
fi=ff(:,:,k); 

contour(xi,yi,fi,20)
colormap('jet')
colorbar
xlabel('X(km)');
ylabel('Y(km)');
title('Upwind Scheme Case 1 Days=60'); 
pause (0.3)
end

你可能感兴趣的:(海洋数值模式,matlab,matlab)