基于 Ekman 方程求解大气边界层中的水平均匀流和高度相关的涡流粘度附matlab代码

简介: 基于 Ekman 方程求解大气边界层中的水平均匀流和高度相关的涡流粘度附matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法       神经网络预测       雷达通信      无线传感器        电力系统

信号处理              图像处理               路径规划       元胞自动机        无人机

⛄ 内容介绍

大气边界层中 Ekman 方程解的 Matlab 实现。假设流动是水平和均匀的。然而,可以模拟高度相关的涡流粘度。解决方案以一维形式提供。

EkmanAnalytic 函数为大气边界层中的恒定涡流粘度提供埃克曼方程的分析解。函数 solveEkman 用显式有限差分格式对 Ekman 方程进行数值求解,并允许使用高度相关的涡粘性。数值实现部分受到 [1] 的启发。

⛄ 部分代码

%% InputParser

p = inputParser();

p.CaseSensitive = false;

p.addOptional('Nmax',2e4);

p.addOptional('dt',[]);

p.addOptional('DT_save',100);

p.addOptional('Omega',7.29e-5);

p.addOptional('critConv',1e-6);

p.addOptional('method','Euler');

p.parse(varargin{:});

%%%%%%%%%%%%%%%%%%%%%%%%%%

Nmax = p.Results.Nmax ; % Maximal number of time steps (for convergence)

dt = p.Results.dt ; % time step for RK4

Omega = p.Results.Omega; % rate of angular rotation of the Earth (rad/s)

critConv= p.Results.critConv; % convergence criterion

DT_save= p.Results.DT_save; % Intermediate value are stored every DT step

method= p.Results.method;

%% Preallocation and Initial conditions

Nz = numel(z);

f = 2*Omega*sind(latitude);

dz = [0,diff(z)];

ut = zeros(Nmax,Nz);

vt = zeros(Nmax,Nz);

e = ones(Nz, 1);

A = spdiags( [e -2*e e], -1:1, Nz, Nz);


if isempty(dt)

   dt = 0.4*dz.^2/max(K);

end


if (dt>0.48*dz.^2/max(K)), warning('Time step may be too large.'); end


%% Initial conditions

u = Ug.*ones(1,Nz);

v = zeros(1,Nz);


%% Main loop

myFun = @(Y,A,F) A*Y + F;

count= 1;

for time_step=1:Nmax % time step

   %  update u,v a nd time at each step

   oldU = u;

   oldV = v;

   

   if strcmpi(method,'Euler')

       [u,v] = Euler(u,v,dt,Ug,K,f,A,dz);

   elseif strcmpi(method,'RK4')

       [u,v] = solve_with_RK4(myFun,u,v,Ug,K,f,A,dt,dz);

   end

   

   % Boundary conditions

   [u,v] = applyBC(u,v,Ug,Nz);

   

   % Store data very N step

   if mod(time_step,DT_save)==0

       ut(count,:)=u;

       vt(count,:)=v;

       count = count+1;

       if time_step>1 && time_step<Nmax

           % Check convergence

           maxDiffU = max(abs(u-oldU));

           maxDiffV = max(abs(v-oldV));

           if maxDiffU < critConv && maxDiffV< critConv

               ut = ut(1:count-1,:);

               vt = vt(1:count-1,:);

               t = [0:count-2].*mean(dt);

               fprintf('The algorithm has converged \n')

               return

           end

       elseif time_step==Nmax

           ut = ut(1:count-1,:);

           vt = vt(1:count-1,:);

           t = [0:count-2].*mean(dt);

           warning('The algorithm did not converge')

       else

           error('Unknown error')

       end

   end

   

end


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

   function [u,v] = Euler(u,v,dt,Ug,K,f,A,dz)

       

       % At each time step, compute the second derivative of u and v

       d2u = (A*u')'./dz.^2.*K;

       d2v = (A*v')'./dz.^2.*K;

       

       

       if numel(K)==1

           u = u + dt.*(d2u + f.*v) ;

           v = v + dt.*(d2v + f.*(Ug-u));

       else

           dK = [0,diff(K)];

           dU = [0,diff(u)];

           dV = [0,diff(v)];

           u = u + dt.*(d2u + f.*v + dK.*dU./dz.^2);

           v = v + dt.*(d2v + f.*(Ug-u)+ dK.*dV./dz.^2);

       end

   end

   function [u,v] = applyBC(u,v,Ug,Nz)

       % apply the upper boundary condition

       u(Nz) = Ug;

       v(Nz) = 0;

       

       % apply the no-slip lower boundary condition

       u(1) = 0;

       v(1) = 0;

   end

   function [u,v] = solve_with_RK4(Fun,u,v,Ug,K,f,A,dt,dz)

       

       

%         dt = repmat(w*(dz.^2)./K,2,1); % time step

       % At each time step, compute the second derivative of u and v

       d2u = K.*(A*u')'./dz.^2;

       d2v = K.*(A*v')'./dz.^2;

       

       if numel(K)==1

           F = [d2u; d2v + f.*Ug];

       else

           dK = [0,diff(K)];

           dU = [0,diff(u)];

           dV = [0,diff(v)];

           F = [d2u + dK.*dU./dz.^2; d2v + dK.*dV./dz.^2 + f.*Ug];

       end

       

       Y = [u;v];

       B = [0 f; -f 0];

       

       

       

       % Runge-Kutta of order 4

       k_1 = Fun(Y,B,F);

       k_2 = Fun(Y+0.5*dt.*k_1,B,F);

       k_3 = Fun(Y+0.5*dt.*k_2,B,F);

       k_4 = Fun(Y+k_3.*dt,B,F);

       % output

       Y = Y + (1/6)*(k_1+2*k_2+2*k_3+k_4).*dt;

       

       u = Y(1,:);

       v = Y(2,:);

%         dt = dt(1,:);

       

       

   end

end

⛄ 运行结果

⛄ 参考文献

[1] Berger, BW, & Grisogono, B. (1998)。斜压变涡粘性埃克曼层。边界层气象学,87(3),363-380。

[2] https://www.whoi.edu/science/PO/people/jprice/website/education_scripts.html

[3]伍荣生. 地形与Ekman边界层中的气流[J]. 气象学报, 1989, 47(2):10.

[4]宗金星. 非定常,水平非均匀的正压Ekman边界层的动力特征[J]. 气象科学, 1990, 10(3):14.

[5]刘敏. Ekman层风随高度分布方程的数值解法[C]// 中国地球物理学会第二十届年会论文集. 2004.

⛄ 完整代码

❤️部分理论引用网络文献,若有侵权联系博主删除
❤️ 关注我领取海量matlab电子书和数学建模资料


相关文章
|
4月前
|
安全
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
本文介绍了2023年高教社杯数学建模竞赛D题的圈养湖羊空间利用率问题,包括问题分析、数学模型建立和MATLAB代码实现,旨在优化养殖场的生产计划和空间利用效率。
224 6
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
|
4月前
|
存储 算法 搜索推荐
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
本文提供了2022年华为杯数学建模竞赛B题的详细方案和MATLAB代码实现,包括方形件组批优化问题和排样优化问题,以及相关数学模型的建立和求解方法。
140 3
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
|
4月前
|
数据采集 存储 移动开发
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
本文介绍了2023年五一杯数学建模竞赛B题的解题方法,详细阐述了如何通过数学建模和MATLAB编程来分析快递需求、预测运输数量、优化运输成本,并估计固定和非固定需求,提供了完整的建模方案和代码实现。
107 0
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
|
7月前
|
数据安全/隐私保护
耐震时程曲线,matlab代码,自定义反应谱与地震波,优化源代码,地震波耐震时程曲线
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
|
7月前
|
数据安全/隐私保护
地震波功率谱密度函数、功率谱密度曲线,反应谱转功率谱,matlab代码
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
基于混合整数规划的微网储能电池容量规划(matlab代码)
基于混合整数规划的微网储能电池容量规划(matlab代码)
|
7月前
|
算法 调度
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
|
7月前
|
Serverless
基于Logistic函数的负荷需求响应(matlab代码)
基于Logistic函数的负荷需求响应(matlab代码)
|
7月前
|
供应链 算法
基于分布式优化的多产消者非合作博弈能量共享(Matlab代码)
基于分布式优化的多产消者非合作博弈能量共享(Matlab代码)
|
7月前
|
算法 调度
基于多目标粒子群算法冷热电联供综合能源系统运行优化(matlab代码)
基于多目标粒子群算法冷热电联供综合能源系统运行优化(matlab代码)

热门文章

最新文章

下一篇
DataWorks