*=*=*=*= writestd.html =*=*=*=*
SUBROUTINE writestd

SUBROUTINE writestd


      SUBROUTINE writestd(champ,icount)

c=======================================================================
c
c   Auteurs:   Jan Polcher, Frederic Hourdin
c   --------
c
c   Objet:
c   ------
c
c Subroutine qui ecrit les fichiers dans le format de transfert
c vers le LMD.
c format etabli par :
c   Zhao-Xin Li, Frederic Hourdin, Emmanuelle Cohen-Solal,
c   Jan Polcher .
c Il peut etre utilise pour sortire  des evolutions
c temporelles, des champs 2D (iim,jjm ou jjm,llm) ou des champs 3D.
c le character # place devant le format determine la fin de la
c description du champ et permet eventulellement de rajouter
c des informations (avant le #).
c le programme de lecture lit , dans la description, les variables
c qu'il connait et saute apres jusquau #. A partir de la
c il commence a lire le champ dans le format specifie.
c
c-----------------------------------------------------------------------
c
c   Interface:
c   ----------
c
c   ARGUMENTS
c   ---------
c
c champ: REAL (icount)
c        champ contenant les valeurs et de longeur icount
c icount: INTEGER
c        nombre d'element dans le champ
c
c   COMMON:
c   -------
c
c=======================================================================
c  INCLUDE '/usr/local/lmdgraph/libio/lmdstd.h'
c
c     INTEGER bandmax
c     PARAMETER(bandmax=24)
c
c     COMMON/lmdstdch/gtitre,gunites,gformat,gfichier,glistfich(100),
c    $                gentete,gdatedep,gdatefin
c
c     CHARACTER*100 gtitre    !du champ
c     CHARACTER*20  gunites   !unites du champ
c     CHARACTER*20  gformat   !formats FORTRAN ou zxliN (N=1,2,3) ou ''
c     CHARACTER*100 gfichier  !nom du fichier contenant le champ
c     CHARACTER*100 gentete   !nom generique (exemple desript. du RUN)
c     CHARACTER*8   gdatedep  !date de depart de la moy. ou evol. temp.
c     CHARACTER*8   gdatefin  !date de fin '' si une seule datefin
c     CHARACTER*20  glistfich !liste de champs a sortir
c
c     COMMON/lmdstdnu/ gminimum,gmaximum,
c    $                 gdeltajour(bandmax),gdeltapas(bandmax),
c    $                 gnbetats(bandmax),gnbfich
c
c     REAL    gminimum        ! \    min et max
c     REAL    gmaximum        ! /    du champ
c     INTEGER gnbfich         ! nombre de fichier a sortir
c pour les evolutions temporelles:
c     INTEGER gnbetats        ! nombre d'etats par bande
c     INTEGER gdeltapas       ! nombre de pas de temps entre 2 sorties
c     REAL    gdeltajour      ! ecart en jour des sorties sur bandes
c
c=======================================================================
c-----------------------------------------------------------------------
c   Declarations:
c   -------------

      IMPLICIT NONE
#include "lmdstd.h"

c   Arguments:
c   ----------

      INTEGER icount
      REAL champ(icount)

c   Local:
c   ------

      INTEGER i,imin,imax
      LOGICAL check, writeornot
      INTEGER lnblnk,ismin,ismax
      EXTERNAL lnblnk,ismin,ismax, isitor, to36

      INTEGER indexfil
      COMMON/indexfil/indexfil

c-----------------------------------------------------------------------
c   verification que le champ est dans la liste predefinie:
c   -------------------------------------------------------

      check = .FALSE.

      IF (gnbfich .EQ. 0) THEN
        writeornot = .TRUE.
      ELSE
        CALL isitor(gfichier,writeornot,gnbfich, glistfich)
      ENDIF

      IF (check) THEN
        WRITE(*,*) 'MYWRITE:: writeornot=',writeornot
      ENDIF

c-----------------------------------------------------------------------
      IF (writeornot) THEN
c-----------------------------------------------------------------------

      imin = ismin(icount,champ,1)
      imax = ismax(icount,champ,1)
      IF (check) THEN
        WRITE(*,*) gentete(1:lnblnk(gentete))
        WRITE(*,*) gtitre(1:lnblnk(gtitre))
        WRITE(*,*) gdatedep
        WRITE(*,*) gdatefin
        WRITE(*,*) gunites(1:lnblnk(gunites))
        WRITE(*,*) gdeltapas, gnbetats
        WRITE(*,*) gdeltajour
        WRITE(*,*) champ(imin),champ(imax)
        WRITE(*,*) gformat(1:lnblnk(gformat))
        WRITE(*,*) icount
      ENDIF
      WRITE(*,*) gtitre(1:lnblnk(gtitre)),'min,max:',
     &  champ(imin),champ(imax),'  ',gunites(1:lnblnk(gunites))

c-----------------------------------------------------------------------
c   creation eventuelle d'un nom pour le fichier d'ecriture du champ:
c   -----------------------------------------------------------------

      IF(lnblnk(gfichier).LT.1.OR.lnblnk(gfichier).GE.100) THEN
         gfichier(1:5)='champ'
         IF(indexfil.LT.1) indexfil=49
         gfichier(6:6)=char(indexfil)
       indexfil=indexfil+1
       PRINT*,'nom du fichier  ',gfichier
      ENDIF

c-----------------------------------------------------------------------
c   ecriture sur le fichier de sorties:
c   -----------------------------------

      OPEN (unit=55, file=gfichier(1:lnblnk(gfichier)))
      WRITE(55,'(a)') gentete(1:lnblnk(gentete))
      WRITE(55,'(a)') gtitre(1:lnblnk(gtitre))
      WRITE(55,'(a)') gdatedep
      WRITE(55,'(a)') gdatefin
      WRITE(55,'(a)') gunites(1:lnblnk(gunites))
      WRITE(55,*) gdeltapas, gnbetats
      WRITE(55,*) gdeltajour
      WRITE(55,*) champ(imin),champ(imax)
      WRITE(55,'(a)') '#'//gformat(1:lnblnk(gformat))
      WRITE(55,*) icount

      IF (check) THEN
        WRITE(*,'('//gformat(1:lnblnk(gformat))//')') champ(1)
      ENDIF

      IF (lnblnk(gformat).LE.1.OR.lnblnk(gformat).GE.20) THEN
         DO 2230 i=1,icount
            WRITE(55,*) champ(i)
2230     CONTINUE
      ELSE
         IF (gformat(1:lnblnk(gformat)) .EQ. 'zxli1') THEN
            CALL to36 (champ,icount,champ(imin),champ(imax),55, 1)
         ELSE
            IF (gformat(1:lnblnk(gformat)) .EQ. 'zxli2') THEN
               CALL to36(champ,icount,champ(imin),champ(imax),55,2)
            ELSE
               IF (gformat(1:lnblnk(gformat)) .EQ. 'zxli3') THEN
                  CALL to36(champ,icount,champ(imin),champ(imax),55,3)
               ELSE
                  WRITE(55,'('//gformat(1:lnblnk(gformat))//')')
     &            (champ(i),i=1,icount)
               ENDIF
            ENDIF
         ENDIF
      ENDIF

      CLOSE (unit=55)

      gfichier=' '

c-----------------------------------------------------------------------
c   si on ecrit pas le champ (writeornot.EQ..f.):
c   ---------------------------------------------

      ELSE
        WRITE(*,*) 'FILE    ',gfichier,'WAS NOT WRITEN'
      ENDIF

      RETURN
      END