Changeset 1708 in lmdz_wrf for trunk/tools/documentation


Ignore:
Timestamp:
Dec 11, 2017, 6:21:58 PM (7 years ago)
Author:
lfita
Message:

Updating installation procedure

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/tools/documentation/install.html

    r1556 r1708  
    6262     <LI>Now all the scripts are held in ${HOME}/PyNCplot. It might be desirable to set an environment variable to make life easier:
    6363      <DIV CLASS="codetxt">$ export pyHOME=${HOME}/PyNCplot</DIV>
    64       <LI>Finally one need to compile the Fortran modules using the same python to run the scripts. This is done using a standard `Makefile' and the tool <A CLASS="la" HREF="https://docs.scipy.org/doc/numpy-dev/f2py/" TARGET="_blank">f2py</A> to link Fortran compiled codes to python. There are different versions for different LMD/IPSL and French HPC machines. For a standard linux 64-bits machine (debain 7) there is one example as `Makefile.foudre'. Follow the instructions there in after linking the appropriated file:</LI>
    65       <DIV CLASS="codetxt">
    66       $ ln -s Makefile.[machine].[compiler] ./Makefile
    67       </DIV>
    68       <LI>In order to create a python 'library' from the fortran codes, one need to follow these steps (example for machine called `foudre')</LI>
    69       <OL>
    70         <LI>Preparing the fortran-python bridge of the `diagnostics' related module</LI>
     64      <LI>Finally one need to compile the Fortran modules using the same python to run the scripts. This is done using a standard `Makefile' and the tool <A CLASS="la" HREF="https://docs.scipy.org/doc/numpy-dev/f2py/" TARGET="_blank">f2py</A> to link Fortran compiled codes to python. There are different versions for different LMD/IPSL and French HPC machines. For a standard linux 64-bits machine (debain 9 with gcc compilers) there is one example as `Makefile.rayo'. Take one and specify a series of different variables specifically for the given machine
    7165          <DIV CLASS="codetxt">
    72             $ f2py -m module_ForDiag -h module_ForDiag.pyf module_generic.F90 module_ForDiagnosticsVars.F90 module_ForDiagnostics.F90 >& run_f2py_ForDiag_wrapper.log
     66            FC          = gfortran                                                      # Fortran compiler
     67            F2PY    = /usr/bin/f2py                                             # Path to the f2py tool
     68            NCLIBFOLD   = /usr/lib/x86_64-linux-gnu             # Path to netcdf libraries
     69            NCINCFOLD   = /usr/include                                  # Path to netcdf includes
    7370          </DIV>
    74         <LI>Creation of the binary objects of the Fortran codes</LI>
     71        <LI>Then one only needs to link the Makefile and compile</LI>
    7572          <DIV CLASS="codetxt">
    76             $ make
    77           </DIV>
    78         <LI>Creation of the fortran-python `diagnostics' related module</LI>
    79           <DIV CLASS="codetxt">
    80             $ f2py -m module_ForDiag -c --f90exec=/usr/bin/gfortran-4.7 module_ForDiag.pyf module_generic.F90 module_ForDiagnosticsVars.F90 module_ForDiagnostics.F90 >& run_f2py_ForDiag_compile.log
    81           </DIV>
    82         <LI>Preparing the fortran-python bridge of the `interpolation' related module</LI>
    83           <DIV CLASS="codetxt">
    84             $ f2py -m module_ForInt -h module_ForInt.pyf module_generic.F90 module_ForInterpolate.F90  >& run_f2py_ForInt_wrapper.log
    85           </DIV>
    86         <LI>Creation of the fortran-python `diagnostics' related module</LI>
    87           <DIV CLASS="codetxt">
    88             $ f2py -m module_ForInt -c --f90exec=/usr/bin/gfortran-4.7 module_ForInt.pyf module_generic.F90 module_ForInterpolate.F90  >& run_f2py_ForInt_compile.log
     73          $ ln -s Makefile.[machine].[compiler] ./Makefile<BR>
     74          $ make >& run_make.log
    8975          </DIV>
    9076        <LI>At the end one should have: </LI>
    91           <PRE><CODE>
    92           module_ForDiag.so
    93           module_ForInt.so
     77          <UL>
     78            <LI><PRE><CODE>DistriCorrection</CODE></PRE>: Complete fortran program to correct data by moving values within quantiles of the distribution</LI>
     79            <LI><PRE><CODE>interpolate</CODE></PRE>: Complete fortran program to interpolate data using nearest-neighbors and weighted distances</LI>
     80            <LI><PRE><CODE>module_ForDef.so</CODE></PRE>: python-callable package of fortran's definitions of variables</LI>
     81            <LI><PRE><CODE>module_ForDistriCorrect.so</CODE></PRE>: python-callable package of fortran's correction of the distribution by moving values within quantiles of the distribution</LI>
     82            <LI><PRE><CODE>module_ForSci.so</CODE></PRE>: python-callable package of fortran's scientific/mathematical all purpose functions</LI>
     83            <LI><PRE><CODE>module_ForDiag.so</CODE></PRE>: python-callable package of fortran's computation of meteorological diagnostics</LI>
     84            <LI><PRE><CODE>module_ForInt.so</CODE></PRE>: python-callable package of fortran's interpolation subroutines</LI>
     85            <LI><PRE><CODE>trajectories_overlap</CODE></PRE>: Complete fortran program to define enclosed regions on a given 2D field and compute their trajectories following a maximum-overlaping criteria</LI>
    9486          </CODE></PRE>
    9587        </OL>
Note: See TracChangeset for help on using the changeset viewer.