! ! $Id: traceurpole.F 1403 2010-07-01 09:02:53Z aslmd $ ! subroutine traceurpole(q,masse) USE control_mod implicit none #include "dimensions.h" c#include "paramr2.h" #include "paramet.h" #include "comconst.h" #include "comdissip.h" #include "comvert.h" #include "comgeom2.h" #include "logic.h" #include "temps.h" #include "ener.h" #include "description.h" c Arguments integer iq real masse(iip1,jjp1,llm) real q(iip1,jjp1,llm) c Locals integer i,j,l real sommemassen(llm) real sommemqn(llm) real sommemasses(llm) real sommemqs(llm) real qpolen(llm),qpoles(llm) c On impose une seule valeur au pôle Sud j=jjm+1=jjp1 sommemasses=0 sommemqs=0 do l=1,llm do i=1,iip1 sommemasses(l)=sommemasses(l)+masse(i,jjp1,l) sommemqs(l)=sommemqs(l)+masse(i,jjp1,l)*q(i,jjp1,l) enddo qpoles(l)=sommemqs(l)/sommemasses(l) enddo c On impose une seule valeur du traceur au pôle Nord j=1 sommemassen=0 sommemqn=0 do l=1,llm do i=1,iip1 sommemassen(l)=sommemassen(l)+masse(i,1,l) sommemqn(l)=sommemqn(l)+masse(i,1,l)*q(i,1,l) enddo qpolen(l)=sommemqn(l)/sommemassen(l) enddo c On force le traceur ŕ prendre cette valeur aux pôles do l=1,llm do i=1,iip1 q(i,1,l)=qpolen(l) q(i,jjp1,l)=qpoles(l) enddo enddo return end