diff --git a/MNH/fast_terms.f90 b/MNH/fast_terms.f90
new file mode 100644
index 0000000000000000000000000000000000000000..5e4dbc6a2dea55acd859981d06b22f45ffb82b80
--- /dev/null
+++ b/MNH/fast_terms.f90
@@ -0,0 +1,455 @@
+!MNH_LIC Copyright 1994-2014 CNRS, Meteo-France and Universite Paul Sabatier
+!MNH_LIC This is part of the Meso-NH software governed by the CeCILL-C licence
+!MNH_LIC version 1. See LICENSE, CeCILL-C_V1-en.txt and CeCILL-C_V1-fr.txt  
+!MNH_LIC for details. version 1.
+!-----------------------------------------------------------------
+!--------------- special set of characters for RCS information
+!-----------------------------------------------------------------
+! $Source: /home/cvsroot/MNH-VX-Y-Z/src/MNH/fast_terms.f90,v $ $Revision: 1.2.4.1.18.4 $ $Date: 2014/03/21 09:11:36 $
+!-----------------------------------------------------------------
+!-----------------------------------------------------------------
+!     ######################
+      MODULE MODI_FAST_TERMS
+!     ######################
+!
+INTERFACE
+!
+      SUBROUTINE FAST_TERMS( KRR, KMI, HFMFILE, HLUOUT, HRAD,           &
+                             HTURBDIM, HSCONV, HMF_CLOUD,               &
+                             OCLOSE_OUT, OSUBG_COND, PTSTEP,            &
+                             PRHODJ, PSIGS, PPABST,                     &
+                             PCF_MF,PRC_MF,                             &
+                             PRVT, PRCT, PRVS, PRCS, PRRS,              &
+                             PTHS, PSRCS, PCLDFR )
+         !
+INTEGER,                  INTENT(IN)    :: KRR      ! Number of moist variables
+INTEGER,                  INTENT(IN)    :: KMI      ! Model index 
+CHARACTER(LEN=*),         INTENT(IN)    :: HFMFILE  ! Name of the output FM-file
+CHARACTER(LEN=*),         INTENT(IN)    :: HLUOUT   ! Output-listing name for
+                                                    ! model n
+CHARACTER*4,              INTENT(IN)    :: HTURBDIM ! Dimensionality of the
+                                                    ! turbulence scheme
+CHARACTER(LEN=4),         INTENT(IN)    :: HSCONV   ! Shallow convection scheme
+CHARACTER(LEN=4),         INTENT(IN)    :: HMF_CLOUD! Type of statistical cloud
+CHARACTER*4,              INTENT(IN)    :: HRAD     ! Radiation scheme name
+LOGICAL,                  INTENT(IN)    :: OCLOSE_OUT ! Conditional closure of 
+                                                    ! the OUTPUT FM-file
+LOGICAL,                  INTENT(IN)    :: OSUBG_COND ! Switch for Subgrid 
+                                                    ! Condensation
+REAL,                     INTENT(IN)    :: PTSTEP   ! Time step          
+!
+REAL, DIMENSION(:,:,:),   INTENT(IN)   ::  PRHODJ  ! Dry density * Jacobian
+REAL, DIMENSION(:,:,:),   INTENT(IN)    :: PSIGS   ! Sigma_s at time t
+REAL, DIMENSION(:,:,:),   INTENT(IN)   ::  PPABST  ! Absolute Pressure at t     
+!
+REAL, DIMENSION(:,:,:),   INTENT(IN)   ::  PRVT    ! Water vapor m.r. at t
+REAL, DIMENSION(:,:,:),   INTENT(IN)   ::  PRCT    ! Cloud water m.r. at t
+!
+REAL, DIMENSION(:,:,:),   INTENT(INOUT)       :: PRVS  ! Water vapor m.r. source
+REAL, DIMENSION(:,:,:),   INTENT(INOUT)       :: PRCS  ! Cloud water m.r. source
+REAL, DIMENSION(:,:,:), OPTIONAL,  INTENT(IN) :: PRRS  ! Rain  water m.r. source
+!
+!
+REAL, DIMENSION(:,:,:),     INTENT(IN)    :: PCF_MF! Convective Mass Flux Cloud fraction 
+REAL, DIMENSION(:,:,:),     INTENT(IN)    :: PRC_MF! Convective Mass Flux liquid mixing ratio
+!
+REAL, DIMENSION(:,:,:),   INTENT(INOUT) :: PTHS    ! Theta source
+REAL, DIMENSION(:,:,:),   INTENT(OUT)   :: PSRCS   ! Second-order flux
+                                                   ! s'rc'/2Sigma_s2 at time t+1
+                                                   ! multiplied by Lambda_3
+REAL, DIMENSION(:,:,:),   INTENT(OUT)   :: PCLDFR  ! Cloud fraction          
+!
+END SUBROUTINE FAST_TERMS
+!
+END INTERFACE
+!
+END MODULE MODI_FAST_TERMS
+!
+!     ##########################################################################
+      SUBROUTINE FAST_TERMS( KRR, KMI, HFMFILE, HLUOUT, HRAD,           &
+                             HTURBDIM, HSCONV, HMF_CLOUD,               &
+                             OCLOSE_OUT, OSUBG_COND, PTSTEP,            &
+                             PRHODJ, PSIGS, PPABST,                     &
+                             PCF_MF,PRC_MF,                             &                   
+                             PRVT, PRCT, PRVS, PRCS, PRRS,              &
+                             PTHS, PSRCS, PCLDFR )
+!     ##########################################################################
+!
+!!****  *FAST_TERMS* -  compute the fast  microphysical sources 
+!!
+!!    PURPOSE
+!!    -------
+!!    The purpose of this routine is to compute the fast microphysical sources
+!!    through a saturation ajustement procedure.
+!!
+!!
+!!**  METHOD
+!!    ------
+!!    Langlois, Tellus, 1973 for the cloudless version.
+!!    When cloud water is taken into account, refer to book 1 of the
+!!    documentation.
+!!
+!!     
+!!
+!!    EXTERNAL
+!!    --------
+!!      None
+!!     
+!!
+!!    IMPLICIT ARGUMENTS
+!!    ------------------
+!!      Module MODD_CST
+!!         XP00               ! Reference pressure
+!!         XMD,XMV            ! Molar mass of dry air and molar mass of vapor
+!!         XRD,XRV            ! Gaz constant for dry air, gaz constant for vapor
+!!         XCPD,XCPV          ! Cpd (dry air), Cpv (vapor)
+!!         XCL                ! Cl (liquid)
+!!         XTT                ! Triple point temperature
+!!         XLVTT              ! Vaporization heat constant
+!!         XALPW,XBETAW,XGAMW ! Constants for saturation vapor 
+!!                            !  pressure  function 
+!!      Module  MODD_CONF 
+!!         CCONF
+!!      Module MODD_BUDGET:
+!!         NBUMOD 
+!!         CBUTYPE
+!!         NBUPROCCTR 
+!!         LBU_RTH    
+!!         LBU_RRV  
+!!         LBU_RRC  
+!!
+!!    REFERENCE
+!!    ---------
+!!
+!!      Book 1 and Book2 of documentation ( routine FAST_TERMS )
+!!      Langlois, Tellus, 1973
+!!    AUTHOR
+!!    ------
+!!      E. Richard       * Laboratoire d'Aerologie*
+!!   
+!!
+!!    MODIFICATIONS
+!!    -------------
+!!      Original    20/12/94 
+!!      Modifications: March 1, 1995 (J.M. Carriere) 
+!!                                  Introduction of cloud water with order 1
+!!                                  formulation
+!!      Modifications: June 8, 1995 ( J.Stein )
+!!                                  Cleaning 
+!!      Modifications: August 30, 1995 ( J.Stein )
+!!                                  add Lambda3 for the subgrid condensation
+!!   
+!!                     October 16, 1995 (J. Stein)     change the budget calls 
+!!                     March   16, 1996 (J. Stein)     store the cloud fraction
+!!                     April   03, 1996 (J. Stein)     displace the nebulosity
+!!                                      computation in the all and nothing case
+!!                     April   15, 1996 (J. Stein)     displace the lambda 3 
+!!                         multiplication and change the nebulosity threshold
+!!                     September 16, 1996  (J. Stein)  bug in the SG cond for
+!!                                                     the M computation
+!!                     October 10, 1996 (J. Stein)     reformulate the Subgrid
+!!                                                     condensation scheme
+!!                     October 8,  1996 (Cuxart,Sanchez) Cloud frac. LES diag (XNA)
+!!                     December 6, 1996 (J.-P. Pinty)  correction of Delta_2
+!!                     November 5, 1996 (J. Stein) remove Rnp<0 values
+!!                     November 13 1996 (V. Masson) add prints in test above
+!!                     November 6, 2002 (V. Masson) update the budget calls
+!!                     November 6, 2002 (S. Malardel,J.Pergaud) Cloud Fract + Rc of 
+!!                                                              Mass flux convection
+!!                                                              Scheme
+!!      J.Escobar 21/03/2013: for HALOK comment all NHALO=1 test
+!-------------------------------------------------------------------------------
+!
+!*       0.    DECLARATIONS
+!              ------------
+!
+USE MODD_PARAMETERS
+USE MODD_CST
+USE MODD_CONF
+USE MODD_BUDGET
+!
+USE MODI_CONDENS
+USE MODI_BUDGET
+USE MODE_FM
+USE MODE_FMWRIT
+!
+IMPLICIT NONE
+!
+!*       0.1   Declarations of dummy arguments :
+!
+!
+INTEGER,                  INTENT(IN)    :: KRR      ! Number of moist variables
+INTEGER,                  INTENT(IN)    :: KMI      ! Model index 
+CHARACTER(LEN=*),         INTENT(IN)    :: HFMFILE  ! Name of the output FM-file
+CHARACTER(LEN=*),         INTENT(IN)    :: HLUOUT   ! Output-listing name for
+                                                    ! model n
+CHARACTER*4,              INTENT(IN)    :: HTURBDIM ! Dimensionality of the
+                                                    ! turbulence scheme
+CHARACTER(LEN=4),         INTENT(IN)    :: HSCONV   ! Shallow convection scheme
+CHARACTER(LEN=4),         INTENT(IN)    :: HMF_CLOUD! Type of statistical cloud
+CHARACTER*4,              INTENT(IN)    :: HRAD     ! Radiation scheme name
+LOGICAL,                  INTENT(IN)    :: OCLOSE_OUT ! Conditional closure of 
+                                                    ! the OUTPUT FM-file
+LOGICAL,                  INTENT(IN)    :: OSUBG_COND ! Switch for Subgrid 
+                                                    ! Condensation
+REAL,                     INTENT(IN)    :: PTSTEP   ! Time step          
+!
+REAL, DIMENSION(:,:,:),   INTENT(IN)   ::  PRHODJ  ! Dry density * Jacobian
+REAL, DIMENSION(:,:,:),   INTENT(IN)    :: PSIGS   ! Sigma_s at time t
+REAL, DIMENSION(:,:,:),   INTENT(IN)   ::  PPABST  ! Absolute Pressure at t     
+!
+REAL, DIMENSION(:,:,:),   INTENT(IN)   ::  PRVT    ! Water vapor m.r. at t
+REAL, DIMENSION(:,:,:),   INTENT(IN)   ::  PRCT    ! Cloud water m.r. at t
+!
+REAL, DIMENSION(:,:,:),   INTENT(INOUT)       :: PRVS  ! Water vapor m.r. source
+REAL, DIMENSION(:,:,:),   INTENT(INOUT)       :: PRCS  ! Cloud water m.r. source
+REAL, DIMENSION(:,:,:), OPTIONAL,  INTENT(IN) :: PRRS  ! Rain  water m.r. source
+!!
+REAL, DIMENSION(:,:,:),     INTENT(IN)    :: PCF_MF! Convective Mass Flux Cloud fraction 
+REAL, DIMENSION(:,:,:),     INTENT(IN)    :: PRC_MF! Convective Mass Flux liquid mixing ratio
+!
+REAL, DIMENSION(:,:,:),   INTENT(INOUT) :: PTHS    ! Theta source
+REAL, DIMENSION(:,:,:),   INTENT(OUT)   :: PSRCS   ! Second-order flux
+                                                   ! s'rc'/2Sigma_s2 at time t+1
+                                                   ! multiplied by Lambda_3
+REAL, DIMENSION(:,:,:),   INTENT(OUT)   :: PCLDFR  ! Cloud fraction          
+!
+!
+!
+!*       0.2   Declarations of local variables :
+!
+!
+REAL  :: ZEPS  ! Mv/Md
+REAL  :: ZTL,ZTHETA,ZRVS
+REAL, DIMENSION(SIZE(PRHODJ,1),SIZE(PRHODJ,2),SIZE(PRHODJ,3)) &
+                         :: ZEXNS,&      ! guess of the Exner function at t+1
+                            ZT,   &      ! guess of the temperature at t+1
+                            ZCPH, &      ! guess of the CPh for the mixing
+                            ZLV,  &      ! guess of the Lv at t+1
+                            ZW1,ZW2,ZW3  ! Work arrays for intermediate
+                                         ! fields
+!
+INTEGER             :: IRESP      ! Return code of FM routines
+INTEGER             :: ILENG      ! Length of comment string in LFIFM file
+INTEGER             :: IGRID      ! C-grid indicator in LFIFM file
+INTEGER             :: ILENCH     ! Length of comment string in LFIFM file
+INTEGER             :: IKB        ! K index value of the first inner mass point
+INTEGER             :: IKE        ! K index value of the last inner mass point
+INTEGER             :: IIB,IJB    ! Horz index values of the first inner mass points
+INTEGER             :: IIE,IJE    ! Horz index values of the last inner mass points
+INTEGER             :: IPLAN      ! Number of horz inner points
+INTEGER             :: JK         ! Var for vertical DO loops
+INTEGER             :: JITER,ITERMAX  ! iterative loop for first order adjustment
+INTEGER             :: ILUOUT     ! Logical unit of output listing 
+CHARACTER (LEN=100) :: YCOMMENT   ! Comment string in LFIFM file
+CHARACTER (LEN=16)  :: YRECFM     ! Name of the desired field in LFIFM file
+!-------------------------------------------------------------------------------
+!
+!*       1.     PRELIMINARIES
+!               -------------
+!
+CALL FMLOOK_ll(HLUOUT,HLUOUT,ILUOUT,IRESP)
+!!$IIB = 1 + JPHEXT
+!!$IIE = SIZE(PRHODJ,1) - JPHEXT
+!!$IJB = 1 + JPHEXT
+!!$IJE = SIZE(PRHODJ,2) - JPHEXT
+CALL GET_INDICE_ll (IIB,IJB,IIE,IJE)
+IPLAN = (SIZE(PRHODJ,1)-2*JPHEXT)*(SIZE(PRHODJ,2)-2*JPHEXT)
+IKB = 1 + JPVEXT
+IKE = SIZE(PRHODJ,3) - JPVEXT
+ZEPS= XMV / XMD
+!
+IF (OSUBG_COND) THEN
+  ITERMAX=2
+ELSE
+  ITERMAX=1
+END IF
+!
+!
+!-------------------------------------------------------------------------------
+!
+!*       2.     COMPUTE QUANTITIES WITH THE GUESS OF THE FUTURE INSTANT
+!               -------------------------------------------------------
+!
+!*       2.1    remove negative non-precipitating negative water
+!               ------------------------------------------------
+!
+IF( NVERB>5) THEN
+  IF (ANY(PRCS(:,:,:)+PRVS(:,:,:) < 0.) ) THEN
+    WRITE(ILUOUT,*) 'FAST_TERMS:  negative values of total water (reset to zero)'
+    WRITE(ILUOUT,*) '  location of minimum:', MINLOC(PRCS(:,:,:)+PRVS(:,:,:))
+    WRITE(ILUOUT,*) '  value of minimum   :', MINVAL(PRCS(:,:,:)+PRVS(:,:,:))
+  END IF
+END IF
+!
+WHERE ( PRCS(:,:,:)+PRVS(:,:,:) < 0.)
+  PRVS(:,:,:) = -  PRCS(:,:,:)
+END WHERE
+!
+!*       2.2    estimate the Exner function at t+1
+!
+ZEXNS(:,:,:) = ( PPABST(:,:,:)  / XP00 ) ** (XRD/XCPD)  
+!
+!    beginning of the iterative loop
+!
+DO JITER =1,ITERMAX
+!
+!*       2.3    compute the intermediate temperature at t+1, T*
+!  
+  ZT(:,:,:) = ( PTHS(:,:,:) * PTSTEP ) * ZEXNS(:,:,:)
+!
+!*       2.4    compute the latent heat of vaporization Lv(T*) at t+1
+!
+  ZLV(:,:,:) = XLVTT + ( XCPV - XCL ) * ( ZT(:,:,:) -XTT )
+!
+!*       2.5    compute the specific heat for moist air (Cph) at t+1
+!
+  IF     ( KRR == 3 ) THEN 
+    ZCPH(:,:,:) =  XCPD + XCPV *PTSTEP*   PRVS(:,:,:)       &
+                        + XCL  *PTSTEP* ( PRCS(:,:,:) + PRRS(:,:,:) )
+  ELSE IF( KRR == 2 ) THEN
+    ZCPH(:,:,:) =  XCPD + XCPV *PTSTEP*   PRVS(:,:,:)       &
+                        + XCL  *PTSTEP*   PRCS(:,:,:)  
+  END IF
+!
+!*       2.6    compute the saturation vapor pressure at t+1
+!
+  ZW1(:,:,:) = EXP( XALPW - XBETAW/ZT(:,:,:) - XGAMW*ALOG( ZT(:,:,:) ) )
+!
+!*       2.7    compute the saturation mixing ratio at t+1
+!
+  ZW2(:,:,:) =  ZW1(:,:,:) * ZEPS /              &
+                (  PPABST(:,:,:) - ZW1(:,:,:) )   
+!
+!*       2.8    compute the saturation mixing ratio derivative (rvs')
+!
+  ZW1(:,:,:) = ( XBETAW / ZT(:,:,:)  - XGAMW ) / ZT(:,:,:)   & 
+               * ZW2(:,:,:) * ( 1. + ZW2(:,:,:) / ZEPS )
+!
+!*       2.9    compute  Cph + Lv * rvs'
+!
+  ZW3(:,:,:) = ZCPH(:,:,:) + ZLV(:,:,:) * ZW1(:,:,:)
+!
+!
+!-------------------------------------------------------------------------------
+!
+!*       3.     FIRST ORDER SUBGRID CONDENSATION SCHEME
+!               ---------------------------------------
+!
+  IF ( OSUBG_COND ) THEN
+!
+!*       3.1    compute  Q1              
+!
+    ZW2(:,:,:) = ( ( PRVS(:,:,:)*PTSTEP - ZW2(:,:,:) ) * ZCPH(:,:,:) / ZW3(:,:,:) &
+                  + PRCS(:,:,:)*PTSTEP                                            &
+                 ) / ( 2. * PSIGS(:,:,:) )
+
+!
+!*       3.2    compute s'rc'/2Sigma_s2, Rc and the nebolisity
+!
+    CALL CONDENS(HTURBDIM, ZW2,ZW1,ZW3,PSRCS) ! ZW1 = Cloud fraction 
+                                              ! PSRC = s'rc'/(2 Sigma_s**2) 
+                                              ! ZW3 = Rc / (2 Sigma_s)
+    ZW3(:,:,:) = 2. * PSIGS(:,:,:) * ZW3(:,:,:)    ! Rc 
+!
+!    multiply PSRCS by the lambda3 coefficient
+!
+    IF ( HTURBDIM == '1DIM'.AND.JITER==ITERMAX ) THEN
+      PSRCS(:,:,:) = PSRCS(:,:,:) * MIN( 3. , MAX(1.,1.-ZW2(:,:,:)) )
+    END IF       ! in the 3D case lamda_3 = 1.
+!
+!*       3.3    compute the variation of mixing ratio
+!
+                                                      !         Rc - Rc*
+    ZW3(:,:,:) = (ZW3(:,:,:)/PTSTEP) - PRCS(:,:,:)       ! Pcon = ----------
+                                                      !         2 Delta t
+  ELSE
+!
+!
+!*       4.     SECOND ORDER ALL OR NOTHING CONDENSATION SCHEME
+!               -----------------------------------------------
+!
+!*       4.1    compute Delta 2
+!
+    ZW1(:,:,:) = (ZW1(:,:,:) * ZLV(:,:,:) / ZW3(:,:,:) ) *                     &
+          ( ((-2.*XBETAW+XGAMW*ZT(:,:,:)) / (XBETAW-XGAMW*ZT(:,:,:))           &
+               + (XBETAW/ZT(:,:,:)-XGAMW)*(1.0+2.0*ZW2(:,:,:)/ZEPS))/ZT(:,:,:) )
+!
+!*       4.2    compute Delta 1
+!
+    ZW2(:,:,:) = ZLV(:,:,:) / ZW3(:,:,:) * ( ZW2(:,:,:) - PRVS(:,:,:)*PTSTEP )
+!
+!*       4.3    compute the variation of mixing ratio
+!
+    ZW3(:,:,:) = - ZW2(:,:,:) * ( 1 + 0.5 * ZW2(:,:,:) * ZW1(:,:,:) )  &
+                 * ZCPH(:,:,:) / ZLV(:,:,:) / PTSTEP
+!
+!  end of the IF structure on the all or nothing or statistical condensation
+!  scheme
+!
+  END IF
+!
+!
+!*       5.     COMPUTE THE SOURCES AND STORES THE CLOUD FRACTION
+!               -------------------------------------------------
+!
+!
+!*       5.1    compute the sources 
+! 
+  ZW3(:,:,:) = MAX ( ZW3(:,:,:), -PRCS(:,:,:) )  
+  WHERE (ZW3(:,:,:) > 0.0)
+    ZW3(:,:,:) = MIN ( ZW3(:,:,:),  PRVS(:,:,:) )
+  END WHERE
+  PRCS(:,:,:) = PRCS(:,:,:) + ZW3(:,:,:)
+  PRVS(:,:,:) = PRVS(:,:,:) - ZW3(:,:,:) 
+  PTHS(:,:,:) = PTHS(:,:,:) + ZW3(:,:,:) * ZLV(:,:,:) / ZCPH(:,:,:)     &
+                                         / ZEXNS(:,:,:)
+!
+!  end of the iterative loop
+!
+END DO
+!
+!*       5.2    compute the cloud fraction PCLDFR
+!
+IF ( .NOT. OSUBG_COND ) THEN
+  WHERE (PRCS(:,:,:) > 1.E-12 / PTSTEP)
+    ZW1(:,:,:)  = 1.
+  ELSEWHERE
+    ZW1(:,:,:)  = 0. 
+  ENDWHERE 
+  IF ( SIZE(PSRCS,3) /= 0 ) THEN
+    PSRCS(:,:,:) = ZW1(:,:,:) 
+  END IF
+ELSE 
+  IF ( HRAD /= 'NONE' ) THEN
+    PCLDFR(:,:,:) = ZW1(:,:,:)
+  END IF
+!
+  IF (HSCONV == 'EDKF' .AND. HMF_CLOUD == 'DIRE') THEN
+    PCLDFR(:,:,:) = MIN(1.,(ZW1(:,:,:)+ PCF_MF(:,:,:)))
+    PRCS(:,:,:) = PRCS(:,:,:)+PRC_MF(:,:,:)/PTSTEP
+    PRVS(:,:,:) = PRVS(:,:,:)-PRC_MF(:,:,:)/PTSTEP
+    PTHS(:,:,:) = PTHS(:,:,:) + PRC_MF * ZLV(:,:,:) / ZCPH(:,:,:)     &
+                                       / ZEXNS(:,:,:) /PTSTEP
+  END IF
+ENDIF
+!
+!
+!
+!        6.  Horizontal mean Cloud fraction (for LES uses)
+!            ---------------------------------------------
+!
+
+!
+!*       7.  STORE THE BUDGET TERMS
+!            ----------------------
+!
+!
+IF (LBUDGET_RV) CALL BUDGET (PRVS(:,:,:) * PRHODJ(:,:,:),6,'COND_BU_RRV')
+IF (LBUDGET_RC) CALL BUDGET (PRCS(:,:,:) * PRHODJ(:,:,:),7,'COND_BU_RRC')
+IF (LBUDGET_TH) CALL BUDGET (PTHS(:,:,:) * PRHODJ(:,:,:),4,'COND_BU_RTH')
+!
+!------------------------------------------------------------------------------
+!
+!
+END SUBROUTINE FAST_TERMS