! $Id: traceurpole.f90 5195 2024-09-16 13:18:00Z fairhead $ SUBROUTINE traceurpole(q, masse) USE lmdz_comdissip, ONLY: coefdis, tetavel, tetatemp, gamdissip, niterdis USE lmdz_comgeom2 USE lmdz_dimensions, ONLY: iim, jjm, llm, ndm USE lmdz_paramet IMPLICIT NONE ! Arguments INTEGER :: iq REAL :: masse(iip1, jjp1, llm) REAL :: q(iip1, jjp1, llm) ! Locals INTEGER :: i, j, l REAL :: sommemassen(llm) REAL :: sommemqn(llm) REAL :: sommemasses(llm) REAL :: sommemqs(llm) REAL :: qpolen(llm), qpoles(llm) ! 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 ! 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 ! 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 SUBROUTINE traceurpole