/[MITgcm]/MITgcm_contrib/enderton/Diagnostics/DiagUtility/cubeCalcAngle.m
ViewVC logotype

Contents of /MITgcm_contrib/enderton/Diagnostics/DiagUtility/cubeCalcAngle.m

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph


Revision 1.1 - (show annotations) (download)
Mon Sep 12 15:37:44 2005 UTC (19 years, 10 months ago) by enderton
Branch: MAIN
CVS Tags: HEAD
Error occurred while calculating annotation data.
Functions (based on some from JMC) to calculate angle and make rotations from cube C-grid to u-east and v-north on the cube.

1 function [AngleCS,AngleSN] = cubeCalcAngle(YG,RAC,dxG,dyG);
2 % [AngleCS,AngleSN] = cubeCalcAngle(YG,RAC,dxG,dyG);
3 %
4 % Determine rotation angle, alpha (returned as cos(alpha) and sin(alpha)),
5 % to convert cube sphere C-grid vectors to east-west and north-south
6 % components.
7 %
8 % e.g.
9 %
10 % >> XG=rdmds('XG');
11 % >> YG=rdmds('YG');
12 % >> RAC=rdmds('RAC');
13 % >> dxG=rdmds('dxG');
14 % >> dyG=rdmds('dyG');
15 % >> [AngleCS,AngleSN] = cubeCalcAngle(YG,RAC,dxG,dyG);
16 %
17 % >> u=rdmds('uVeltave.0000513360');
18 % >> v=rdmds('vVeltave.0000513360');
19 % >> [uE,vN] = rotate_csCg_EN(u,v,AngleCS,AngleSN,XG,YG);
20
21 nc=size(RAC,2);
22 deg2rad=pi/180;
23 r_earth=sqrt(sum(sum(RAC))./(4.*pi));
24
25 [yZ6]=split_Z_cub(YG);
26
27 % Build purely zonal flow from a stream function, psi = r_earth * latitude.
28 psi=-r_earth.*yZ6.*deg2rad;
29 uZ=psi([1:nc],[1:nc],:)-psi([1:nc],[2:nc+1],:);
30 vZ=psi([2:nc+1],[1:nc],:)-psi([1:nc],[1:nc],:);
31 uZ=reshape(permute(uZ,[1 3 2]),[6.*nc nc])./dyG;
32 vZ=reshape(permute(vZ,[1 3 2]),[6.*nc nc])./dxG;
33
34 % Put constructed zonal wind at cell center.
35 [uu,vv]=split_UV_cub(uZ,vZ);
36 u=(uu(1:nc,:,:)+uu(2:nc+1,:,:))/2;
37 v=(vv(:,1:nc,:)+vv(:,2:nc+1,:))/2;
38 uZc=reshape(permute(u,[1 3 2]),[6.*nc nc]);
39 vZc=reshape(permute(v,[1 3 2]),[6.*nc nc]);
40
41 % Calculate angles.
42 norm=sqrt(uZc.*uZc+vZc.*vZc);
43 AngleCS = uZc./norm;
44 AngleSN = -vZc./norm;

  ViewVC Help
Powered by ViewVC 1.1.22