Ignore:
Timestamp:
11/22/16 02:31:19 (8 years ago)
Author:
bdef
Message:

CHG: uniformization fix

File:
1 edited

Legend:

Unmodified
Added
Removed
  • issm/trunk-jpl/test/NightlyRun/test1205.py

    r21060 r21408  
    11#Test Name: EISMINTRoundIceSheetStaticSIA
    2 import numpy
     2import numpy as np
    33from model import *
     4from socket import gethostname
    45from roundmesh import *
    56from setmask import *
     
    78from setflowequation import *
    89from solve import *
    9 from MatlabFuncs import *
     10
    1011
    1112"""
     
    2829vx_obs=constant/2.*md.mesh.x*(md.geometry.thickness)**-1
    2930vy_obs=constant/2.*md.mesh.y*(md.geometry.thickness)**-1
    30 vel_obs=numpy.sqrt((md.inversion.vx_obs)**2+(md.inversion.vy_obs)**2)
     31vel_obs=np.sqrt((md.inversion.vx_obs)**2+(md.inversion.vy_obs)**2)
    3132
    3233#We extrude the model to have a 3d model
    33 md.extrude(numlayers,1.);
     34md.extrude(numlayers,1.)
    3435md=setflowequation(md,'SIA','all')
    3536
    3637#Spc the nodes on the bed
    37 pos=numpy.nonzero(md.mesh.vertexonbase)
     38pos=np.where(md.mesh.vertexonbase)
    3839md.stressbalance.spcvx[pos]=0.
    3940md.stressbalance.spcvy[pos]=0.
     
    4142
    4243#Now we can solve the problem
    43 md.cluster=generic('name',oshostname(),'np',8)
     44md.cluster=generic('name',gethostname(),'np',8)
    4445md=solve(md,'Stressbalance')
    4546
     
    4748vx=md.results.StressbalanceSolution.Vx
    4849vy=md.results.StressbalanceSolution.Vy
    49 vel=numpy.zeros((md.mesh.numberofvertices2d,1))
     50vel=np.zeros((md.mesh.numberofvertices2d))
    5051
    5152for i in xrange(0,md.mesh.numberofvertices2d):
    5253        node_vel=0.
    5354        for j in xrange(0,md.mesh.numberoflayers-1):
    54                 node_vel=node_vel+1./(2.*(md.mesh.numberoflayers-1))*\
    55                         (numpy.sqrt(vx[i+(j+1)*md.mesh.numberofvertices2d,0]**2+vy[i+(j+1)*md.mesh.numberofvertices2d,0]**2)+\
    56                         numpy.sqrt(vx[i+j*md.mesh.numberofvertices2d,0]**2+vy[i+j*md.mesh.numberofvertices2d,0]**2))
    57         vel[i,0]=node_vel
     55                node_vel=node_vel+1./(2.*(md.mesh.numberoflayers-1))*(np.sqrt(vx[i+(j+1)*md.mesh.numberofvertices2d,0]**2+vy[i+(j+1)*md.mesh.numberofvertices2d,0]**2)+np.sqrt(vx[i+j*md.mesh.numberofvertices2d,0]**2+vy[i+j*md.mesh.numberofvertices2d,0]**2))
     56        vel[i]=node_vel
    5857
    5958#Plot of the velocity from the exact and calculated solutions
     
    6261#subplot(2,2,1)
    6362#p=patch('Faces',md.mesh.elements2d,'Vertices',[md.mesh.x2d md.mesh.y2d],'FaceVertexCData',...
    64 #vel,'FaceColor','interp','EdgeColor','none');
     63#vel,'FaceColor','interp','EdgeColor','none')
    6564#title('Modelled velocity','FontSize',14,'FontWeight','bold')
    66 #colorbar;
    67 #caxis([0 200]);
     65#colorbar
     66#caxis([0 200])
    6867   
    6968#subplot(2,2,2)
    7069#p=patch('Faces',md.mesh.elements2d,'Vertices',[md.mesh.x2d md.mesh.y2d],'FaceVertexCData',...
    71 #vel_obs,'FaceColor','interp','EdgeColor','none');
     70#vel_obs,'FaceColor','interp','EdgeColor','none')
    7271#title('Analytical velocity','FontSize',14,'FontWeight','bold')
    73 #colorbar;
    74 #caxis([0 200]);
     72#colorbar
     73#caxis([0 200])
    7574
    7675#subplot(2,2,3)
    77 #hold on;
    78 #plot(sqrt((md.mesh.x(1:md.mesh.numberofvertices2d)).^2+(md.mesh.y(1:md.mesh.numberofvertices2d)).^2),vel,'r.');
    79 #plot(sqrt((md.mesh.x2d).^2+(md.mesh.y2d).^2),vel_obs,'b.');
    80 #title('Analytical vs calculated velocity','FontSize',14,'FontWeight','bold');
    81 #xlabel('distance to the center of the icesheet [m]','FontSize',14,'FontWeight','bold');
    82 #ylabel('velocity [m/yr]','FontSize',14,'FontWeight','bold');
    83 #legend('calculated velocity','exact velocity');
    84 #axis([0 750000 0 200]);
    85 #hold off;
     76#hold on
     77#plot(sqrt((md.mesh.x(1:md.mesh.numberofvertices2d)).^2+(md.mesh.y(1:md.mesh.numberofvertices2d)).^2),vel,'r.')
     78#plot(sqrt((md.mesh.x2d).^2+(md.mesh.y2d).^2),vel_obs,'b.')
     79#title('Analytical vs calculated velocity','FontSize',14,'FontWeight','bold')
     80#xlabel('distance to the center of the icesheet [m]','FontSize',14,'FontWeight','bold')
     81#ylabel('velocity [m/yr]','FontSize',14,'FontWeight','bold')
     82#legend('calculated velocity','exact velocity')
     83#axis([0 750000 0 200])
     84#hold off
    8685
    8786#subplot(2,2,4)
    8887#p=patch('Faces',md.mesh.elements2d,'Vertices',[md.mesh.x2d md.mesh.y2d],'FaceVertexCData',...
    89 #abs(vel-vel_obs)./vel_obs*100,'FaceColor','interp','EdgeColor','none');
     88#abs(vel-vel_obs)./vel_obs*100,'FaceColor','interp','EdgeColor','none')
    9089#title('Relative misfit [%]','FontSize',14,'FontWeight','bold')
    91 #colorbar;
    92 #caxis([0 100]);
     90#colorbar
     91#caxis([0 100])
    9392
    9493if printingflag:
    9594        pass
    9695#       set(gcf,'Color','w')
    97 #       printmodel('SIAstatic','png','margin','on','marginsize',25,'frame','off','resolution',0.7,'hardcopy','off');
    98 #       system(['mv SIAstatic.png ' ISSM_DIR '/website/doc_pdf/validation/Images/EISMINT/IceSheet']);
     96#       printmodel('SIAstatic','png','margin','on','marginsize',25,'frame','off','resolution',0.7,'hardcopy','off')
     97#       system(['mv SIAstatic.png ' ISSM_DIR '/website/doc_pdf/validation/Images/EISMINT/IceSheet'])
    9998
    10099#Fields and tolerances to track changes
    101 field_names     =[ \
    102         'Vx','Vy','Vel', \
    103 ]
    104 field_tolerances=[ \
    105         1e-13,1e-13,1e-13, \
    106 ]
    107 field_values=[ \
    108         vx,vy,vel, \
    109 ]
     100field_names     =['Vx','Vy','Vel']
     101field_tolerances=[1e-13,1e-13,1e-13]
     102field_values=[vx,vy,vel]
Note: See TracChangeset for help on using the changeset viewer.