diff --git a/docs/bibli.bib b/docs/bibli.bib
new file mode 100644
index 0000000..67fa9bc
--- /dev/null
+++ b/docs/bibli.bib
@@ -0,0 +1,63 @@
+@string{angl = {Ann.\ Glaciol.}}
+@string{arfm = {Annu.~Rev.~Fluid Mech.}}
+@string{bams = {Bull.~Am.~Met.~Soc.}}
+@string{blm = {Bound.~Layer~Meteorol.}}
+@string{climd = {Clim.~Dynamics}}
+@string{cch = {Clim.\ Change}}
+@string{cup = {Cambridge University Press}}
+@string{dao = {Dyn.~Atmos.~Oceans}}
+@string{dkrz = {Deutsches Klimarechenzentrum (DKRZ)}}
+@string{dnmi = {The Norwegian Meteorological Institute (DNMI)}}
+@string{dsr = {Deep Sea Res.}}
+@string{ecmwf = {ECMWF}}
+@string{eos = {Eos~Trans.\ AGU}}
+@string{esa = {European Space Agency (ESA)}}
+@string{esapub = {ESA Publications Division, ESTEC, Noordwijk (NL)}}
+@string{estec = {European Space Research and Technology Centre (ESTEC)}}
+@string{gaos = {Global Atmos.~Ocean System}}
+@string{grl = {Geophys.~Res.~Lett.}}
+@string{ieee = {IEEE Trans.~Geosci. Remote Sensing}}
+@string{ifremer = {IFREMER/CERSAT}}
+@string{igarss = {IEEE Press, Piscataway, N.J., USA}}
+@string{jam = {J.~Appl.~Meteor.}}
+@string{jaot = {J.~Atmos.~Ocean.~Technol.}}
+@string{jas = {J.~Atmos.~Sci.}}
+@string{jclim = {J.~Clim.}}
+@string{jcp = {J.~Comput.~Phys.}}
+@string{jfm = {J.~Fluid Mech.}}
+@string{jgr = {J.~Geophys.~Res.}}
+@string{ijrs = {Int.~J.~Remote Sensing}}
+@string{jms = {J.~Mar.~Sys.}}
+@string{jpo = {J.~Phys.~Oceanogr.}}
+@string{mpi = {MPI f\"ur Meteorologie}}
+@string{mcp = {Meth. Comput. Phys.}}
+@string{mwr = {Mon.~Wea.~Rev.}}
+@string{om = {Ocean Modelling}}
+@string{pf = {Physics of Fluids}}
+@string{pd = {Physica D.}}
+@string{ptrsl = {{Phil.~Trans.~R.~Soc.~Lond.}}}
+@string{rgsp = {{Rev.~Geophys.~Space~Phys.}}}
+@string{qjrms = {{Q.~J.~R.~Meteorol.~Soc.}}}
+@string{siscicom= {SIAM J.\ Sci.\ Comput.}}
+@string{tel = {Tellus}}
+
+@Article{for-eta:15,
+ author = {Forget, G. and Campin, J.-M. and Heimbach, P. and Hill, C. N. and Ponte, R. M and Wunsch, C.},
+ title = {{ECCO} version 4: an integrated framework for non-linear inverse modeling and global ocean state estimation},
+ journal = {Geoscientific Model Development},
+ volume = {8},
+ year = {2015},
+ number = {10},
+ pages = {3071--3104},
+ url = {http://www.geosci-model-dev.net/8/3071/2015/},
+ doi = {10.5194/gmd-8-3071-2015}
+}
+
+@Article{dspace-eccov4r2,
+ AUTHOR = {Forget, G. and Campin, J.-M. and Heimbach, P. and Hill, C. N. and Ponte, R. M and Wunsch, C.},
+ TITLE = {{ECCO} version 4: Second Release},
+ YEAR = {2016},
+ journal = {},
+ URL = {http://hdl.handle.net/1721.1/102062}
+}
+
diff --git a/docs/biblirefs.rst b/docs/biblirefs.rst
new file mode 100644
index 0000000..c14f447
--- /dev/null
+++ b/docs/biblirefs.rst
@@ -0,0 +1,10 @@
+.. _references:
+
+.. only:: html
+
+ References
+ **********
+
+.. bibliography:: bibli.bib
+ :all:
+
diff --git a/docs/conf.py b/docs/conf.py
index 426e17d..3ad36e9 100644
--- a/docs/conf.py
+++ b/docs/conf.py
@@ -30,7 +30,10 @@
# Add any Sphinx extension module names here, as strings. They can be
# extensions coming with Sphinx (named 'sphinx.ext.*') or your custom
# ones.
-extensions = []
+extensions = ['sphinx.ext.autodoc',
+ 'sphinx.ext.mathjax',
+ 'sphinx.ext.viewcode',
+ 'sphinxcontrib.bibtex']
# Add any paths that contain templates here, relative to this directory.
templates_path = ['_templates']
@@ -76,13 +79,30 @@
# If true, `todo` and `todoList` produce output, else they produce nothing.
todo_include_todos = False
+# number figures
+
+numfig_format = {'figure': 'Figure %s',
+ 'table': 'Table %s',
+ 'code-block': 'Code %s',
+ }
+
+numfig = True
+
+# number figures within section
+numfig_secnum_depth = 1
+
+#math_number_all = True
+
+numfig_format = {'figure': 'Figure %s', 'table': 'Table %s', 'code-block': 'Listing %s', 'section': 'Section %s'}
# -- Options for HTML output ----------------------------------------------
# The theme to use for HTML and HTML Help pages. See the documentation for
# a list of builtin themes.
#
-html_theme = 'alabaster'
+import sphinx_rtd_theme
+html_theme = "sphinx_rtd_theme"
+html_theme_path = [sphinx_rtd_theme.get_html_theme_path()]
# Theme options are theme-specific and customize the look and feel of a theme
# further. For a list of options available for each theme, see the
@@ -93,7 +113,9 @@
# Add any paths that contain custom static files (such as style sheets) here,
# relative to this directory. They are copied after the builtin static files,
# so a file named "default.css" will overwrite the builtin "default.css".
-html_static_path = ['_static']
+### gf: the following is commented to avoid warning
+### gf: see https://github.com/terasolunaorg/guideline/issues/1358
+# html_static_path = ['_static']
# Custom sidebar templates, must be a dictionary that maps document names
# to template names.
diff --git a/docs/figs/fig12-eccov4.pdf b/docs/figs/fig12-eccov4.pdf
new file mode 100644
index 0000000..a1df959
Binary files /dev/null and b/docs/figs/fig12-eccov4.pdf differ
diff --git a/docs/figs/plot_m_map.pdf b/docs/figs/plot_m_map.pdf
new file mode 100644
index 0000000..a03e6c1
Binary files /dev/null and b/docs/figs/plot_m_map.pdf differ
diff --git a/docs/figs/sphere_all.pdf b/docs/figs/sphere_all.pdf
new file mode 100644
index 0000000..300ed2c
Binary files /dev/null and b/docs/figs/sphere_all.pdf differ
diff --git a/docs/gcmfaces_demo_dirtree.rst b/docs/gcmfaces_demo_dirtree.rst
new file mode 100644
index 0000000..41c023f
--- /dev/null
+++ b/docs/gcmfaces_demo_dirtree.rst
@@ -0,0 +1,18 @@
+
+::
+
+ gcmfaces/ (Matlab / Octave toolbox)
+ MITprof/ (Matlab / Octave toolbox)
+ m_map/ (Matlab / Octave toolbox)
+ nctiles_grid/ (downloaded data)
+ release2_climatology/
+ nctiles_climatology/ (downloaded data)
+ mat/ (created by software)
+ tex/ (created by software)
+ release2/
+ nctiles_monthly/ (downloaded data)
+ nctiles_remotesensing/ (downloaded data)
+ profiles/ (downloaded data)
+ mat/ (created by software)
+ tex/ (created by software)
+
diff --git a/docs/index.rst b/docs/index.rst
index 7b63ea5..46d6b5d 100644
--- a/docs/index.rst
+++ b/docs/index.rst
@@ -3,14 +3,50 @@
You can adapt this file completely to your liking, but it should at least
contain the root `toctree` directive.
-Welcome to gcmfaces's documentation!
-====================================
+Welcome to gcmfaces' documentation!
+===================================
+
+.. A Generic Treatment Of Gridded Earth Variables In Matlab And Octave.
+
+Here, you will learn about the `gcmfaces` toolbox that provides a generic
+treatment of gridded Earth variables in Matlab and Octave.
+
+The `gcmfaces` toolbox handles gridded Earth variables as sets of connected
+arrays. This object-oriented approach allows users to
+write generic, compact analysis codes that readily become applicable
+to a wide variety of grids (e.g., those in :numref:`sphere_all`).
+`gcmfaces` notably allows for analysis of MITgcm output on any of its
+`familiar grids `__.
+It was originally developed as part the `ECCO version 4` framework along with
+the companion `MITprof` toolbox that handles unevenly
+distributed in-situ ocean observations :cite:`for-eta:15`.
+
+This user manual provides an installation guide for `gcmfaces` and `MITprof`
+(:numref:`install`), a documentation of the basic `gcmfaces` features
+(:numref:`features`), and an overview of higher-level `gcmfaces` functionalities
+for mapping, transport, etc. operations (:numref:`demo` and :numref:`standard`).
.. toctree::
- :maxdepth: 2
- :caption: Contents:
+ :maxdepth: 3
+ :caption: Contents
+ :numbered: 4
+
+ prep_install.rst
+ prep_basic.rst
+ prep_demo.rst
+ prep_diags.rst
+ biblirefs.rst
+
+Sample grids
+============
+.. figure:: figs/sphere_all.pdf
+ :width: 95%
+ :align: center
+ :alt: TBD
+ :name: sphere_all
+ Four approaches to gridding the Earth which are all commonly used in numerical models. Top left: lat-lon grid; mapping the Earth to a single rectangular array (`face`). Top right: cube-sphere grid; mapping the earth to the six faces of a cube. Bottom right: lat-lon-cap, `LLC`, grid (five faces). Bottom left: quadripolar grid (four faces). In this depiction, faces are color-coded, only grid line subsets are shown, and gaps are introduced between faces to highlight the defining characteristics of each grid.
Indices and tables
==================
diff --git a/docs/prep_basic.rst b/docs/prep_basic.rst
new file mode 100644
index 0000000..e0509d7
--- /dev/null
+++ b/docs/prep_basic.rst
@@ -0,0 +1,256 @@
+
+.. _features:
+
+Basic Features
+==============
+
+The core of `gcmfaces` lies in (1) its representation of connected arrays, or faces, as
+objects of the class defined in the ``@gcmfaces/`` directory (see :numref:`class`)
+and (2) its handling of C-Grid specifications via the `mygrid` global structure
+(:numref:`Cgrid`). Other basic features include functions that `exchange` data
+between faces (:numref:`exch`), or `overload` common operations (:numref:`overload`),
+as well as I/O routines (:numref:`formats`). These and other `gcmfaces` functions are generally
+documented through help sections that are readily accessible via the Matlab or Octave command window.
+
+.. _class:
+
+The gcmfaces Class
+------------------
+
+:numref:`sphere_all` illustrates four types of grids that are
+have been used in ocean general circulation models. Despite evident
+design differences, these grids can all be represented as sets of
+connected arrays, or faces, as shown in :numref:`plot_one_field_FACES`
+in the case of the LLC90 grid. `gcmfaces` simply takes advantage of this fact
+by defining a class for these objects, within ``@gcmfaces/``, that represents
+gridded earth variables generically as sets of connected arrays.
+
+Grid specifics, such as the number of faces and the size of each face,
+are embedded within the `gcmfaces` objects (see :ref:`gcmfaces_object`).
+Objects of the `gcmfaces` class can thus be manipulated simply through compact
+and generic expressions such as `a+b` that are robust to changes in grid
+design (:numref:`sphere_all`). The `gcmfaces` class inherits many of its
+basic operations from the `double` class as illustrated for the
+:ref:`plus_function` (see :numref:`overload` for details).
+
+.. figure:: figs/fig12-eccov4.pdf
+ :width: 85%
+ :align: center
+ :alt: Ocean topography on the LLC90 grid displayed face by face
+ :name: plot_one_field_FACES
+
+ Ocean topography on the LLC90 grid (:numref:`sphere_all`, bottom
+ right) displayed face by face (going from 1 to 5). This plot
+ generated using example_display(1) illustrates how gcmfaces organizes
+ data in memory (see :ref:`gcmfaces_object`). Within each face, grid point
+ indices increase from left to right and bottom to top.
+
+.. _gcmfaces_object:
+
+.. rubric:: Gcmfaces object structure
+
+An Earth variable on the LLC90 grid (:numref:`sphere_all`, bottom right) stored as a `gcmfaces`
+object called `fld` has the data structure depicted below. In this example, `fld` is a two dimensional field, and
+the five face arrays plotted in :numref:`plot_one_field_FACES` are denoted as f1 to f5.
+
+::
+
+ fld
+ nFaces: 5
+ f1: [90x270 double]
+ f2: [90x270 double]
+ f3: [90x90 double]
+ f4: [270x90 double]
+ f5: [270x90 double]
+
+.. _Cgrid:
+
+Handling C-Grids
+----------------
+
+In practice `gcmfaces` gets activated by adding, to the
+least, the ``@gcmfaces/`` directory to the Matlab path and then loading a
+grid to memory (:numref:`getting_started`). The default grid is LLC90,
+which can be loaded to memory by calling ``grid_load.m`` without any
+argument. :numref:`formats` and ``help grid_load;`` provide
+additional information regarding, respectively, and supported file
+formats and ``grid_load.m`` arguments. As an alternative to
+``grid_load.m``, `MITgcm` input grid files can be read ``grid_load_native.m``
+as shown `here `__
+(see README and ``demo_grids.m``).
+
+Both ``grid_load.m`` and ``grid_load_native.m`` store all C-grid variables
+at once in a global variable named `mygrid` (:numref:`mygrid`). `gcmfaces`
+functions then rely on `mygrid` that they get access to by calling
+``gcmfaces_global.m`` which also returns system information via `myenv`. If
+these global variables get deleted at some point, for example by a call to
+``clear all;``, user may need to rerun ``grid_load.m`` or ``grid_load_native.m``.
+In such situtations, any call to ``gcmfaces_global.m`` will generate a warning
+that `mygrid has not yet been loaded to memory`.
+
+.. table:: List of grid variables available via the mygrid global
+ variable. The naming convention is directly inherited from the `MITgcm`
+ naming convention [1]_.
+ :name: mygrid
+
+ +---------+---+----------------+------------------------------------------+
+ | XC | : | [1x1 gcmfaces] | longitude (tracer) |
+ +---------+---+----------------+------------------------------------------+
+ | YC | : | [1x1 gcmfaces] | latitude (tracer) |
+ +---------+---+----------------+------------------------------------------+
+ | RC | : | [50x1 double] | depth (tracer) |
+ +---------+---+----------------+------------------------------------------+
+ | XG | : | [1x1 gcmfaces] | longitude (vorticity) |
+ +---------+---+----------------+------------------------------------------+
+ | YG | : | [1x1 gcmfaces] | latitude (vorticity) |
+ +---------+---+----------------+------------------------------------------+
+ | RF | : | [51x1 double] | depth (velocity along 3rd dim) |
+ +---------+---+----------------+------------------------------------------+
+ | DXC | : | [1x1 gcmfaces] | grid spacing (tracer, 1st dim) |
+ +---------+---+----------------+------------------------------------------+
+ | DYC | : | [1x1 gcmfaces] | grid spacing (tracer, 2nd dim) |
+ +---------+---+----------------+------------------------------------------+
+ | DRC | : | [50x1 double] | grid spacing (tracer, 3nd dim) |
+ +---------+---+----------------+------------------------------------------+
+ | RAC | : | [1x1 gcmfaces] | grid cell area (tracer) |
+ +---------+---+----------------+------------------------------------------+
+ | DXG | : | [1x1 gcmfaces] | grid spacing (vorticity, 1st dim) |
+ +---------+---+----------------+------------------------------------------+
+ | DYG | : | [1x1 gcmfaces] | grid spacing (vorticity, 2nd dim) |
+ +---------+---+----------------+------------------------------------------+
+ | DRF | : | [50x1 double] | grid spacing (velocity, 3nd dim) |
+ +---------+---+----------------+------------------------------------------+
+ | RAZ | : | [1x1 gcmfaces] | grid cell area (vorticity) |
+ +---------+---+----------------+------------------------------------------+
+ | AngleCS | : | [1x1 gcmfaces] | grid orientation (tracer, cosine) |
+ +---------+---+----------------+------------------------------------------+
+ | AngleSN | : | [1x1 gcmfaces] | grid orientation (tracer, cosine) |
+ +---------+---+----------------+------------------------------------------+
+ | Depth | : | [1x1 gcmfaces] | ocean bottom depth (tracer) |
+ +---------+---+----------------+------------------------------------------+
+ | hFacC | : | [1x1 gcmfaces] | partial cell factor (tracer) |
+ +---------+---+----------------+------------------------------------------+
+ | hFacS | : | [1x1 gcmfaces] | partial cell factor (velocity, 2nd dim) |
+ +---------+---+----------------+------------------------------------------+
+ | hFacW | : | [1x1 gcmfaces] | partial cell factor (velocity, 1rst dim) |
+ +---------+---+----------------+------------------------------------------+
+
+The C-grid variable names listed in :numref:`mygrid` derive from the `MITgcm`
+naming convention [1]_. In brief, XC, YC, and RC denote longitude, latitude, and
+vertical position of tracer variable locations. DXC, DYC, DRC and RAC
+are the corresponding grid spacings, in m, and grid cell areas, in
+m\ :math:`^2`. A different set of such variables (XG, YG, RF, DXG, DYG,
+DRF, RAZ) corresponds to velocity and vorticity variables that are
+staggered in the C-grid approach [1]_.
+
+Indexing and vector orientation conventions also derive from
+`MITgcm` conventions [1]_. The indexing convention is illustrated in
+:numref:`plot_one_field_FACES`. For vector
+fields, the first component (U) is directed toward the right of the page
+and the second component (V) toward the top of the page. As compared
+with tracers, velocity variable locations are shifted by half a grid
+point to the left of the page (U components) or the bottom of the page
+(V components) following the C-grid approach [1]_.
+
+.. _exch:
+
+Exchange Functions
+------------------
+
+Many computations of interest (e.g., gradients and flow convergences)
+involve values from nearby grid points on neighboring faces. In
+practice rows and columns need to be appended at each face edge that are
+`exchanged` between neighboring faces – e.g., rows and columns from
+faces #2, #3, and #5 need to be appended at the face #1 edges in
+:numref:`plot_one_field_FACES`. Exchanges are
+operated by ``exch_T_N.m`` for tracer-type variables and by ``exch_UV_N.m`` for
+velocity-type variables. These are notably used to compute gradients
+(``calc_T_grad.m``) and flow convergences (``calc_UV_conv.m``).
+
+.. _overload:
+
+Overloaded Functions
+--------------------
+
+As in the case of the :ref:`plus_function`, common operations and functions
+are overloaded as part of the gcmfaces class definition
+within the ``@gcmfaces/`` directory:
+
+#. Logical operators: and, eq, ge, gt, isnan, le, lt, ne, not, or.
+
+#. Numerical operators: abs, angle, cat, cos, cumsum, diff, exp, imag,
+ log2, max, mean, median, min, minus, mrdivide, mtimes, nanmax,
+ nanmean, nanmedian, nanmin, nanstd, nansum, plus, power, rdivide,
+ real, sin, sqrt, std, sum, tan, times, uminus, uplus.
+
+#. Indexing operators: subsasgn, subsref, find, get, set, squeeze,
+ repmat.
+
+It may be worth highlighting ``@gcmfaces/subsasgn.m`` (subscripted
+assignment) and ``@gcmfaces/subsref.m`` (subscripted reference) since they
+overload some of the most commonly used Matlab functions. For example, if
+`fld` is of the `double` class then ``tmp2=fld(1);`` and ``fld(1)=1;`` call
+``subsref.m`` and ``subsasgn.m``, respectively. If `fld` instead is of the
+gcmfaces class then ``@gcmfaces/subsref.m`` behaves as follows:
+
+::
+
+ fld{n} returns the n^{th} face data (i.e., an array).
+ fld(:,:,n) returns the n^{th} vertical level (i.e., a gcmfaces object).
+
+and ``@gcmfaces/subsasgn.m`` behaves similarly but for assignments.
+
+.. _plus_function:
+
+.. rubric:: Overloaded + function
+
+::
+
+ function r = plus(p,q)
+ %overloaded gcmfaces `+' function :
+ % simply calls double `+' function for each face data
+ % if any of the two arguments is a gcmfaces object
+ if isa(p,'gcmfaces'); r=p; else; r=q; end;
+ for iFace=1:r.nFaces;
+ iF=num2str(iFace);
+ if isa(p,'gcmfaces')&isa(q,'gcmfaces');
+ eval(['r.f' iF '=p.f' iF '+q.f' iF ';']);
+ elseif isa(p,'gcmfaces')&isa(q,'double');
+ eval(['r.f' iF '=p.f' iF '+q;']);
+ elseif isa(p,'double')&isa(q,'gcmfaces');
+ eval(['r.f' iF '=p+q.f' iF ';']);
+ else;
+ error('gcmfaces plus: types are incompatible')
+ end;
+ end;
+
+.. _formats:
+
+Input / Output Files
+--------------------
+
+Objects of the `gcmfaces` class can readily be saved to file using
+Matlab’s proprietary I/O format (`.mat` files). Reloading them in a
+later Matlab session works seamlessly as long as the gcmfaces class
+has been defined by including ``@gcmfaces/`` to the Matlab path.
+
+Alternatively, gcmfaces variables can be written to files in the
+`nctiles` format :cite:`for-eta:15`. Illustrations in
+this user guide rely upon ECCO version 4 fields which are distributed in this
+format (see :numref:`data`; :ref:`gcmfaces_demo_dirtree` and :ref:`downloads`).
+The associated I/O functions provided in `gcmfaces` (``write2nctiles.m`` and
+``read_nctiles.m``) reformat data on the fly.
+
+Finally, `gcmfaces` can read MITgcm binary output in the `mds` format [2]_.
+The provided I/O functions (``rdmds2gcmfaces.m`` and ``read_bin.m``) rely on
+``convert2gcmfaces.m`` to convert `mds` output to `gcmfaces` objects on the fly.
+The reverse conversion occurs when ``convert2gcmfaces.m`` is called with a `gcmfaces`
+input argument. This approach provides a unified framework to analyze MITgcm output or
+prepare MITgcm input for `all known grids `__
+(see README and ``demo_grids.m``).
+
+.. [1]
+ For details, see sections 2.11 and 6.2.4 in http://mitgcm.org/public/r2_manual/latest/online_documents/manual.pdf
+
+.. [2]
+ For details, see section 7.3 in http://mitgcm.org/public/r2_manual/latest/online_documents/manual.pdf
diff --git a/docs/prep_demo.rst b/docs/prep_demo.rst
new file mode 100644
index 0000000..e11c310
--- /dev/null
+++ b/docs/prep_demo.rst
@@ -0,0 +1,41 @@
+.. _demo:
+
+Tutorial Examples
+=================
+
+To proceed with the tutorial examples, user is expected to have completed the software
+installation and data downloads from :numref:`install` (including
+``nctiles_climatology/`` and ``m_map/``). The full suite of tutorial examples
+can then be executed via ``gcmfaces_demo.m`` by opening Matlab and typing
+
+::
+
+ p = genpath('gcmfaces/'); addpath(p);
+ p = genpath('m_map/'); addpath(p);
+ gcmfaces_demo;
+
+As prompted by ``gcmfaces_demo.m``, specify the desired amount of explanatory
+text output. Various examples then proceed and display comments in
+the Matlab or Octave command window. The Matlab GUI and debugger can also
+be used to run each example line by line. This can be useful to learn more
+about the inner workings of `gcmfaces` functions.
+
+The first section in ``gcmfaces_demo.m`` illustrates I/O and plotting
+capabilities (``grid_load.m`` and ``example_display.m``). The second
+section focuses on data processing capabilities such
+as interpolation and smoothing.
+``example_interp.m`` interpolates fields to a lat-lon grid and vice versa.
+``example_smooth.m`` integrates a diffusion equation which involves tracer
+gradient and flux convergence computations. The final section in
+``gcmfaces_demo.m`` computes oceanic transports (``example_transports.m``).
+
+.. figure:: figs/plot_m_map.pdf
+ :width: 95%
+ :align: center
+ :alt: Ocean topography on the LLC90 grid displayed in geographical coordinates
+ :name: plot_one_field_M_MAP
+
+ Same as :numref:`plot_one_field_FACES` but
+ plotted in geographical coordinates using ``m_map_gcmfaces.m``. This plot
+ is generated by calling example_display(4).
+
diff --git a/docs/prep_diags.rst b/docs/prep_diags.rst
new file mode 100644
index 0000000..f44d970
--- /dev/null
+++ b/docs/prep_diags.rst
@@ -0,0 +1,78 @@
+
+.. _standard:
+
+Standard Analysis
+=================
+
+The `gcmfaces standard analysis` consists of an extensive set of
+physical diagnostics that are routinely computed to monitor and compare
+MITgcm simulations and ECCO state estimates :cite:`for-eta:15`, :cite:`dspace-eccov4r2`.
+The computational loop is operated by ``diags_driver.m`` which stores intermediate
+results in a dedicated directory (``mat/`` in :ref:`gcmfaces_demo_dirtree`). Afterwards,
+the display phase is operated via ``diags_display.m`` or
+``diags_driver_tex.m`` as explained below.
+
+In order to proceed, user should have completed the installation procedure in
+:numref:`install` and organized directories as shown in :ref:`gcmfaces_demo_dirtree`.
+They can then, for example, generate and display variance maps from the ECCO v4
+monthly mean climatology (12 monthly fields) by opening Matlab
+and executing ``diags_set_B.m`` as follows:
+
+::
+
+ %add paths:
+ p = genpath('gcmfaces/'); addpath(p);
+ p = genpath('MITprof/'); addpath(p);
+ p = genpath('m_map/'); addpath(p);
+
+ %set parameters:
+ dirModel='release2_climatology/';
+ dirMat=[dirModel 'mat/'];
+ setDiags='B';
+
+ %compute diagnostics:
+ diags_driver(dirModel,dirMat,'climatology',setDiags);
+
+ %display results:
+ diags_display(dirMat,setDiags);
+
+which should take :math:`\approx5` minutes. Each generated plot has a caption
+that indicates the quantity being displayed. Results of ``diags_driver.m``
+can, alternatively, be displayed via ``diags_driver_tex.m`` to save plots
+and create a compilable tex file. This process should take :math:`\approx`\ 10
+minutes:
+
+::
+
+ dirTex=[dirModel 'tex/']; nameTex='standardAnalysis';
+ diags_driver_tex(dirMat,{},dirTex,nameTex);
+
+Other diagnostic sets can be computed and displayed accordingly by
+modifying the `setDiags` specification: oceanic transports (`A`), mean
+and variance maps (`B`), sections and time series (`C`), and mixed layer
+depths (`MLD`). Each set of diagnostics (computation and display) is
+encoded in one routine named as `diags_set_XX.m` where `XX` stands for
+e.g., `A`, `B`, `C`, or `MLD`.
+
+These routines can be found in the ``gcmfaces_diags/`` subdirectory.
+Computing all four diagnostic sets from ECCO v4 r2 climatology takes
+:math:`\approx`\ 1/2 hour. Computing them from the 1992-2011 monthly
+time series (``nctiles_monthly/`` in :ref:`gcmfaces_demo_dirtree`)
+by typing
+
+::
+
+ dirModel='release2/'; dirMat=[dirModel 'mat/'];
+ diags_driver(dirModel,dirMat,[1992:2011]);
+
+takes :math:`\approx20` times longer and typically runs overnight.
+However, to speed up the process, computation can be distributed over
+multiple processors by splitting [1992:2011] into subsets.
+
+.. note::
+
+ The above ``diags_driver`` calls rely on default parameters that are
+ adequate for the :numref:`install` solution, but yours may differ.
+ Using the ``doInteractive`` option (see ``help diags_driver``) is
+ therefore the generally recommended method, since it gives you the
+ opportunity to review and, if needed, edit the relevant parameters.
diff --git a/docs/prep_install.rst b/docs/prep_install.rst
new file mode 100644
index 0000000..c417b69
--- /dev/null
+++ b/docs/prep_install.rst
@@ -0,0 +1,103 @@
+
+.. _install:
+
+Getting Started
+===============
+
+.. _soft:
+
+Install Software
+----------------
+
+Download the latest software version from `github `__ by typing
+
+::
+
+ git clone https://github.com/gaelforget/gcmfaces
+ git clone https://github.com/gaelforget/MITprof
+
+at the command line or using the github web browser interface. This method allows users to update the software later on and to manage their own, if any, code modifications. Archived frozen versions of the software, which can be cited in publications using permanent digital object identifiers, are also available via `zenodo `__. Additionally, `gcmfaces` relies on the `m_map` toolbox for geographic projections (:numref:`plot_one_field_M_MAP`), which can be downloaded from `this webpage `__ (e.g., `m_map1.4.tar.gz `__).
+
+Octave users will want to replace ``git clone ...faces`` with ``git clone -b octave ...faces`` in the above recipe. They will also need to install and load the Octave `statistics `__, `io `__, and `netcdf `__ packages.
+
+.. note::
+
+ `MITprof` is not generally needed by `gcmfaces`, but is used in :numref:`demo` and :numref:`standard`.
+
+.. _data:
+
+Obtain Input Data
+-----------------
+
+The `gcmfaces` toolbox allows users to seamlessly deal with various gridding
+approaches (e.g., all grids distributed via `this FTP server
+`__)
+using compact and generic codes as explained in this user guide. Once a
+grid has been loaded to memory (see below and :numref:`Cgrid`), `gcmfaces` can be used
+to analyze ocean model solutions and state estimates on that grid
+(:numref:`demo` and :numref:`standard`).
+
+
+To get started in :numref:`getting_started` and :numref:`features`, it
+suffices to download ``nctiles_grid/`` (145M) either from `this ftp
+server `__
+or from `this permanent archive `__.
+:numref:`demo` and :numref:`standard` use ``nctiles_climatology/`` (10G)
+to illustrate higher-level functionalities. One download method, from the
+command line, is shown in :ref:`downloads`. Commands reported afterwards assume
+that downloaded contents are organized as shown in :ref:`gcmfaces_demo_dirtree`.
+
+The other input data sets shown in :ref:`gcmfaces_demo_dirtree` (inside of ``release2/``)
+are not be needed unless user wants to reproduce the full set of plots in :cite:`dspace-eccov4r2`.
+The contents of ``profiles/`` (7G) and ``nctiles_remotesensing/`` (27G) allow for model-data
+comparisons, while ``nctiles_monthly/`` (170G) contains monthly
+time series of ocean variables over 1992-2011. These can be used
+to reproduce the plots in :cite:`dspace-eccov4r2` via a few
+function calls as explained at the end of :numref:`standard`.
+
+.. _downloads:
+
+.. rubric:: Demo Directory Downloads
+
+::
+
+ setenv FTPv4r2 'ftp://mit.ecco-group.org/ecco_for_las/version_4/release2/'
+ #export FTPv4r2='ftp://mit.ecco-group.org/ecco_for_las/version_4/release2/'
+ wget --recursive {$FTPv4r2}/nctiles_grid
+ wget --recursive {$FTPv4r2}/nctiles_climatology
+ #wget --recursive {$FTPv4r2}/nctiles_monthly
+ #wget --recursive {$FTPv4r2}/nctiles_remotesensing
+ #wget --recursive {$FTPv4r2}/profiles
+
+.. _gcmfaces_demo_dirtree:
+
+.. rubric:: Demo Directories Organization
+
+.. include:: gcmfaces_demo_dirtree.rst
+
+.. _getting_started:
+
+Activate gcmfaces
+-----------------
+
+Once ``gcmfaces/`` and ``nctiles_grid/`` have been placed in a
+common directory as shown in :ref:`gcmfaces_demo_dirtree`,
+open Matlab or Octave from within that directory and type:
+
+::
+
+ %add gcmfaces and MITprof directories to Matlab path:
+ p = genpath('gcmfaces/'); addpath(p);
+ %p = genpath('MITprof/'); addpath(p);
+
+ %load all grid variables from nctiles_grid/ into mygrid:
+ grid_load;
+
+ %make mygrid accessible in current workspace:
+ gcmfaces_global;
+
+ %display list of grid variables:
+ disp(mygrid);
+
+ %display one gcmfaces variable:
+ disp(mygrid.XC);
diff --git a/docs/requirements.txt b/docs/requirements.txt
new file mode 100644
index 0000000..ef36add
--- /dev/null
+++ b/docs/requirements.txt
@@ -0,0 +1 @@
+sphinxcontrib-bibtex