Merge from 89:270ab1db32db

Mon, 05 Dec 2016 13:26:38 +0200

author
Ioannis Binietoglou <binietoglou@noa.gr>
date
Mon, 05 Dec 2016 13:26:38 +0200
changeset 90
a36bbd265468
parent 89
8310b682c916 (diff)
parent 87
270ab1db32db (current diff)
child 91
45353331d6db

Merge from 89:270ab1db32db

--- a/.hgignore	Thu Nov 03 18:39:25 2016 +0200
+++ b/.hgignore	Mon Dec 05 13:26:38 2016 +0200
@@ -5,3 +5,5 @@
 re:~$
 
 re:^docs/aux_build/html/
+*.orig
+re:^\.idea/
--- a/docs/conf.py	Thu Nov 03 18:39:25 2016 +0200
+++ b/docs/conf.py	Mon Dec 05 13:26:38 2016 +0200
@@ -13,6 +13,13 @@
 
 import sys, os
 
+try:
+    import sphinx_bootstrap_theme
+    bootstrap_loaded = True
+except:
+    bootstrap_loaded = False
+    
+
 # If extensions (or modules to document with autodoc) are in another directory,
 # add these directories to sys.path here. If the directory is relative to the
 # documentation root, use os.path.abspath to make it absolute, like shown here.
@@ -41,7 +48,7 @@
 
 # General information about the project.
 project = u'Single Calculus Chain'
-copyright = u'2016, Ioannis Binietoglou'
+copyright = u"2016, Ioannis Binietoglou, Giuseppe D'Amico"
 
 # The version info for the project you're documenting, acts as replacement for
 # |version| and |release|, also used in various other places throughout the
@@ -91,7 +98,10 @@
 
 # The theme to use for HTML and HTML Help pages.  See the documentation for
 # a list of builtin themes.
-html_theme = 'default'
+if bootstrap_loaded:
+    html_theme = 'bootstrap'
+else:
+    html_theme = 'default'
 
 # 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
@@ -99,7 +109,8 @@
 #html_theme_options = {}
 
 # Add any paths that contain custom themes here, relative to this directory.
-#html_theme_path = []
+if bootstrap_loaded:
+    html_theme_path = sphinx_bootstrap_theme.get_html_theme_path()
 
 # The name for this set of Sphinx documents.  If None, it defaults to
 # "<project> v<release> documentation".
Binary file docs/files/NetCDF_input_file_v3.pdf has changed
--- a/docs/netcdf_file.rst	Thu Nov 03 18:39:25 2016 +0200
+++ b/docs/netcdf_file.rst	Mon Dec 05 13:26:38 2016 +0200
@@ -3,21 +3,23 @@
 The SCC netCDF file format
 ==========================
 
-A more detailed version of this document can be found in this :download:`pdf file <files/NetCDF_input_filev2.0.pdf>`.
+A more detailed version of this document can be found in this :download:`pdf file <files/NetCDF_input_file_v3.pdf>`.
 
 .. note::
 
    You can check the format of the files you create using the linked `script <https://bitbucket.org/iannis_b/scc-netcdf-checker>`_ .
 
-   
+
 Rationale
 ---------
 
-The Single Calculus Chain (SCC) is composed by two different modules:
+The Single Calculus Chain (SCC) is composed by three different modules:
+
+-  pre-processing module (*ELPP*)
 
--  pre-processing module ( scc\_preprocessing)
+-  optical processing module (*ELDA*)
 
--  optical processing module ( ELDA)
+-  depolarization calibrator module (*ELDEC*)
 
 To perfom aerosol optical retrievals the SCC needs not only the raw
 lidar data but also a certain number of parameters to use in both
@@ -33,51 +35,52 @@
 be found only in the SCC\_DB and other ones that can be found in both
 these locations. In the last case, if a particular parameter is needed,
 the SCC will search first in the input files and then in SCC\_DB. If the
-parameter is found in the input files the SCC will keep it without
+parameter is found in the input files, the SCC will keep it without
 looking into SCC\_DB.
 
-The input files have to be submitted to the SCC in NetCDF format. At the
+The input files have to be submitted to the SCC in NetCDF format. At 
 present the SCC can handle four different types of input files:
 
 1. Raw Lidar Data
+
 2. Sounding Data
+
 3. Overlap
+
 4. Lidar Ratio
 
-
-As already mentioned, the  Raw Lidar Data file contains not only the
+As already mentioned, the *Raw lidar data* file contains not only the
 raw lidar data but also other parameters to use to perform the
-pre-processing and optical processing. The  Sounding Data file
-contains the data coming from a correlative radiosounding and it is used
-by the SCC for molecular density calculation. The  Overlap file
-contains the measured overlap function. The  Lidar Ratio file contains
-a lidar ratio profile to use in elastic backscatter retrievals. The 
-Raw Lidar Data file is of course mandatory and the  Sounding Data, 
-Overlap and  Lidar Ratio files are optional. If  Sounding Data file
-is not submitted by the user, the molecular density will be calculated
-by the SCC using the “US Standard Atmosphere 1976”. If the  Overlap
-file is not submitted by the user, the SCC will get the full overlap
-height from SCC\_DB and it will produce optical results starting from
-this height. If  Lidar Ratio file is not submitted by the user, the
-SCC will consider a fixed value for lidar ratio got from SCC\_DB.
+pre-processing and optical processing. The *Sounding Data* file contains
+the data coming from a correlative radiosounding and it is used by the
+SCC for molecular density calculation. The *Overlap* file contains the
+measured overlap function. The *Lidar Ratio* file contains a lidar ratio
+profile to use in elastic backscatter retrievals. The *Raw Lidar Data*
+file is of course mandatory and the *Sounding Data*, *Overlap* and
+*Lidar Ratio* files are optional. If *Sounding Data* file is not
+submitted by the user, the molecular density will be calculated by the
+SCC using the "US Standard Atmosphere 1976". If the *Overlap* file is
+not submitted by the user, the SCC will get the full overlap height from
+SCC\_DB and it will produce optical results starting from this height.
+If *Lidar Ratio* file is not submitted by the user, the SCC will
+consider a fixed value for lidar ratio got from SCC\_DB.
 
 The user can decide to submit all these files or any number of them (of
-course the file  Raw Lidar Data is mandatory). For example the user
-can submit together with the  Raw Lidar Data file only the  Sounding
-Data file or only the  Overlap file.
+course the file *Raw Lidar Data* is mandatory). For example the user can
+submit together with the *Raw Lidar Data* file only the *Sounding Data*
+file or only the *Overlap* file.
 
-This document provides a detailed explanation about the structure of the
-NetCDF input files to use for SCC data submission. All Earlinet groups
-should read it carefully because they have to produce such kind of input
-files if they want to use the SCC for their standard lidar retrievals.
-Every comments or suggestions regarding this document can be sent to
-Giuseppe D’Amico by e-mail at ``damico@imaa.cnr.it``
+This document provides a detailed example about the structure of
+the NetCDF input files to use for SCC data submission. All Earlinet
+groups should read it carefully because they have to produce such kind
+of input files if they want to use the SCC for their standard lidar
+retrievals.
 
-This document is available for downloading at ``www.earlinetasos.org``
-
-In table tab:rawdata is reported a list of dimensions, variables and
-global attributes that can be used in the NetCDF  Raw Lidar Data input
-file. For each of them it is indicated:
+Additionaly, the linked :download:`pdf file <files/NetCDF_input_file_v3.pdf>` contains
+tables with all mandatory and optional variables for the netcdf files
+accepted by the SCC. Table 1 contains a list of dimensions, variables and
+global attributes that can be used in the NetCDF *Raw Lidar Data*
+input file. For each of them it is indicated:
 
 -  The name. For the multidimensional variables also the corresponding
    dimensions are reported
@@ -89,26 +92,26 @@
 -  If it is mandatory or optional
 
 As already mentioned, the SCC can get some parameters looking first in
-the  Raw Lidar Data input file and then into SCC\_DB. This means that
+the *Raw Lidar Data* input file and then into SCC\_DB. This means that
 to use the parameters stored in SCC\_DB the optional variables or
-optional global attributes must not appear within  Raw Lidar Data
-file. This is the suggested and recommended way to use the SCC. Please
-include optional parameters in the  Raw Lidar Data only as an
-exception.
+optional global attributes must not appear within *Raw Lidar Data* file.
+This is the suggested and recommended way to use the SCC. Please include
+optional parameters in the *Raw Lidar Data* only as an exception.
 
-In table tab:sounding, tab:overlap and tab:lr are reported all the
-information about the structure of  Sounding Data,  Overlap and 
-Lidar Ratio input files respectively.
+Tables 2, 3, and 4 report all the
+information about the structure of *Sounding Data*, *Overlap* and *Lidar
+Ratio* input files respectively.
+
 
 Example
 -------
 
-Let’s now consider an example of  Raw Lidar Data input file. Suppose
+Let's now consider an example of *Raw Lidar Data* input file. Suppose
 we want to generate NetCDF input file corresponding to a measurement
 with the following properties:
 
 +----------------------+-------------------------------------------+
-| Start Date           | :math:`30^{th}` January 2009              |
+| Start Date           | 30\ :sup:`th` January 2009                |
 +----------------------+-------------------------------------------+
 | Start Time UT        | 00:00:01                                  |
 +----------------------+-------------------------------------------+
@@ -121,10 +124,11 @@
 | Pointing angle       | 5 degrees with respect to the zenith      |
 +----------------------+-------------------------------------------+
 
+
 Moreover suppose that this measurement is composed by the following
 lidar channels:
 
-1. 1064 lidar channel
+#. 1064 lidar channel
 
    +------------------------------+-------------------------------+
    | Emission wavelength=1064nm   | Detection wavelength=1064nm   |
@@ -136,31 +140,31 @@
    | Range resolution=7.5m        | Polarization state=total      |
    +------------------------------+-------------------------------+
 
-2. 532 cross lidar channel
+#. 532 cross lidar channel
 
-   +-----------------------------+---------------------------------+
-   | Emission wavelength=532nm   | Detection wavelength=532nm      |
-   +-----------------------------+---------------------------------+
-   | Time resolution=60s         | Number of laser shots=3000      |
-   +-----------------------------+---------------------------------+
-   | Number of bins=5000         | Detection mode=photoncounting   |
-   +-----------------------------+---------------------------------+
-   | Range resolution=15m        | Polarization state=cross        |
-   +-----------------------------+---------------------------------+
+   +-----------------------------+------------------------------------------+
+   | Emission wavelength=532nm   | Detection wavelength=532nm               |
+   +-----------------------------+------------------------------------------+
+   | Time resolution=60s         | Number of laser shots=3000               |
+   +-----------------------------+------------------------------------------+
+   | Number of bins=5000         | Detection mode=photoncounting            |
+   +-----------------------------+------------------------------------------+
+   | Range resolution=15m        | Polarization state=cross (transmitted)   |
+   +-----------------------------+------------------------------------------+
 
-3. 532 parallel lidar channel
+#. 532 parallel lidar channel
 
-   +-----------------------------+---------------------------------+
-   | Emission wavelength=532nm   | Detection wavelength=532nm      |
-   +-----------------------------+---------------------------------+
-   | Time resolution=60s         | Number of laser shots=3000      |
-   +-----------------------------+---------------------------------+
-   | Number of bins=5000         | Detection mode=photoncounting   |
-   +-----------------------------+---------------------------------+
-   | Range resolution=15m        | Polarization state=parallel     |
-   +-----------------------------+---------------------------------+
+   +-----------------------------+-------------------------------------------+
+   | Emission wavelength=532nm   | Detection wavelength=532nm                |
+   +-----------------------------+-------------------------------------------+
+   | Time resolution=60s         | Number of laser shots=3000                |
+   +-----------------------------+-------------------------------------------+
+   | Number of bins=5000         | Detection mode=photoncounting             |
+   +-----------------------------+-------------------------------------------+
+   | Range resolution=15m        | Polarization state=parallel (reflected)   |
+   +-----------------------------+-------------------------------------------+
 
-4. 607 :math:`N_2` vibrational Raman channel
+#. | 607 :math:`N_2` vibrational Raman channel
 
    +-----------------------------+---------------------------------+
    | Emission wavelength=532nm   | Detection wavelength=607nm      |
@@ -169,17 +173,18 @@
    +-----------------------------+---------------------------------+
    | Number of bins=5000         | Detection mode=photoncounting   |
    +-----------------------------+---------------------------------+
-   | Range resolution=15m                                          |
+   | Range resolution=15m        |                                 |
    +-----------------------------+---------------------------------+
 
-Finally let’s assume we have also performed dark measurements before the
+Finally let's assume we have also performed dark measurements before the
 lidar measurements from the 23:50:01 UT up to 23:53:01 UT of
-29:math:`^\mathrmth` January 2009.
+29\ :sup:`th` January 2009.
+
 
 Dimensions
 ~~~~~~~~~~
 
-Looking at table tab:rawdata we have to fix the following dimensions:
+Looking at table 1 of the pdf file we have to fix the following dimensions:
 
 ::
 
@@ -191,7 +196,6 @@
     time_bck
 
 The dimension ``time`` is unlimited so we don’t have to fix it.
-
 We have 4 lidar channels so:
 
 ::
@@ -234,21 +238,22 @@
 
     time_bck=6
 
+
 Variables
 ~~~~~~~~~
 
 In this section it will be explained how to fill all the possible
-variables either mandatory or optional of  Raw Lidar Data input file.
+variables either mandatory or optional of *Raw Lidar Data* input file.
 
-Raw_Data_Start_Time(time, nb_of_time_scales)
-   This 2 dimensional mandatory array has to contain the acquisition
-   start time (in seconds from the time given by the global attribute
-   ``RawData_Start_Time_UT``) of each lidar profile. In this example we
-   have two different time scales: one is characterized by steps of 30
-   seconds (the 1064nm is acquired with this time scale) the other by
-   steps of 60 seconds (532cross, 532parallel and 607nm). Moreover the
-   measurement start time is 00:00:01 UT and the measurement stop time
-   is 00:05:01 UT. In this case we have to define:
+-  | ``Raw_Data_Start_Time(time, nb_of_time_scales)``
+   | This 2 dimensional mandatory array has to contain the acquisition
+     start time (in seconds from the time given by the global attribute
+     ``RawData_Start_Time_UT``) of each lidar profile. In this example
+     we have two different time scales: one is characterized by steps of
+     30 seconds (the 1064nm is acquired with this time scale) the other
+     by steps of 60 seconds (532cross, 532parallel and 607nm). Moreover
+     the measurement start time is 00:00:01 UT and the measurement stop
+     time is 00:05:01 UT. In this case we have to define:
 
    ::
 
@@ -269,9 +274,9 @@
    we have a time scale index of 0 for the time scale with steps of 60
    seconds and a time scale index of 1 for the other one.
 
-Raw_Data_Stop_Time(time, nb_of_time_scales)
-   The same as previous item but for the data acquisition stop time.
-   Following a similar procedure we have to define:
+-  | ``Raw_Data_Stop_Time(time, nb_of_time_scales)``
+   | The same as previous item but for the data acquisition stop time.
+     Following a similar procedure we have to define:
 
    ::
 
@@ -287,34 +292,34 @@
          _, 270,
          _, 300 ;
 
-Raw_Lidar_Data(time, channels, points)
-   This 3 dimensional mandatory array has to be filled with the
-   time-series of raw lidar data. The photoncounting profiles have to
-   submitted in counts (so as integers) while the analog ones in mV. The
-   order the user chooses to fill this array defines the correspondence
-   between channel index and lidar data.
-   
-   For example if we fill this array in such way that:
+-  | ``Raw_Lidar_Data(time, channels, points)``
+   | This 3 dimensional mandatory array has to be filled with the
+     time-series of raw lidar data. The photoncounting profiles have to
+     submitted in counts (so as integers) while the analog ones in mV.
+     The order the user chooses to fill this array defines the
+     correspondence between channel index and lidar data.
+   | For example if we fill this array in such way that:
 
-   +-------------------------------------+------------------------------------------------------------+
-   | Raw_Lidar_Data(time,0,points        | :math:`\rightarrow` is the time-series of 1064 nm          |
-   +-------------------------------------+------------------------------------------------------------+
-   | Raw_Lidar_Data(time,1,points        | :math:`\rightarrow` is the time-series of 532 cross        |
-   +-------------------------------------+------------------------------------------------------------+
-   | Raw_Lidar_Data(time,2,points        | :math:`\rightarrow` is the time-series of 532 parallel     |
-   +-------------------------------------+------------------------------------------------------------+
-   | Raw_Lidar_Data(time,3,points        | :math:`\rightarrow` is the time-series of 607 nm           |
-   +-------------------------------------+------------------------------------------------------------+
+   +-------------------------------------+---------------------------------------+
+   | ``Raw_Lidar_Data(time,0,points)``   |  is the time-series of 1064 nm        |
+   +-------------------------------------+---------------------------------------+
+   | ``Raw_Lidar_Data(time,1,points)``   |  is the time-series of 532 cross      |
+   +-------------------------------------+---------------------------------------+
+   | ``Raw_Lidar_Data(time,2,points)``   |  is the time-series of 532 parallel   |
+   +-------------------------------------+---------------------------------------+
+   | ``Raw_Lidar_Data(time,3,points)``   |  is the time-series of 607 nm         |
+   +-------------------------------------+---------------------------------------+
 
-   from now on the channel index 0 is associated to the 1064 channel, 
-   1 to the 532 cross, 2 to the 532 parallel and 3 to the 607nm.
+   | 
+   | from now on the channel index 0 is associated to the 1064 channel,
+     1 to the 532 cross, 2 to the 532 parallel and 3 to the 607nm.
 
-Raw_Bck_Start_Time(time_bck, nb_of_time_scales)
-   This 2 dimensional optional array has to contain the acquisition
-   start time (in seconds from the time given by the global attribute
-   ``RawBck_Start_Time_UT``) of each dark measurements profile.
-   Following the same procedure used for the variable
-   ``Raw_Data_Start_Time`` we have to define:
+-  | ``Raw_Bck_Start_Time(time_bck, nb_of_time_scales)``
+   | This 2 dimensional optional array has to contain the acquisition
+     start time (in seconds from the time given by the global attribute
+     ``RawBck_Start_Time_UT``) of each dark measurements profile.
+     Following the same procedure used for the variable
+     ``Raw_Data_Start_Time`` we have to define:
 
    ::
 
@@ -326,9 +331,9 @@
          _, 120,
          _, 150;
 
-Raw_Bck_Stop_Time(time_bck, nb_of_time_scales)
-   The same as previous item but for the dark acquisition stop time.
-   Following a similar procedure we have to define:
+-  | ``Raw_Bck_Stop_Time(time_bck, nb_of_time_scales)``
+   | The same as previous item but for the dark acquisition stop time.
+     Following a similar procedure we have to define:
 
    ::
 
@@ -339,86 +344,86 @@
          _, 120,
          _, 150,
          _, 180 ;
-         
 
-Background_Profile(time_bck, channels, points)
-   This 3 dimensional optional array has to be filled with the
-   time-series of the dark measurements data. The photoncounting
-   profiles have to submitted in counts (so as integers) while the
-   analog ones in mV. The user has to fill this array following the same
-   order used in filling the array ``Raw_Lidar_Data``:
+-  | ``Background_Profile(time_bck, channels, points)``
+   | This 3 dimensional optional array has to be filled with the
+     time-series of the dark measurements data. The photoncounting
+     profiles have to submitted in counts (so as integers) while the
+     analog ones in mV. The user has to fill this array following the
+     same order used in filling the array ``Raw_Lidar_Data``:
 
-   +---------------------------------------------+----------------------------------------------------------+
-   | Background_Profile(time_bck,0,points        | :math:`\rightarrow` dark time-series at 1064 nm          |
-   +---------------------------------------------+----------------------------------------------------------+
-   | Background_Profile(time_bck,1,points        | :math:`\rightarrow` dark time-series at 532 cross        |
-   +---------------------------------------------+----------------------------------------------------------+
-   | Background_Profile(time_bck,2,points        | :math:`\rightarrow` dark time-series at 532 parallel     |
-   +---------------------------------------------+----------------------------------------------------------+
-   | Background_Profile(time_bck,3,points        | :math:`\rightarrow` dark time-series at 607 nm           |
-   +---------------------------------------------+----------------------------------------------------------+
-   
+   +---------------------------------------------+-------------------------------------+
+   | ``Background_Profile(time_bck,0,points)``   |  dark time-series at 1064 nm        |
+   +---------------------------------------------+-------------------------------------+
+   | ``Background_Profile(time_bck,1,points)``   |  dark time-series at 532 cross      |
+   +---------------------------------------------+-------------------------------------+
+   | ``Background_Profile(time_bck,2,points)``   |  dark time-series at 532 parallel   |
+   +---------------------------------------------+-------------------------------------+
+   | ``Background_Profile(time_bck,3,points)``   |  dark time-series at 607 nm         |
+   +---------------------------------------------+-------------------------------------+
+
+   | 
 
-channel_ID(channels)
-   This mandatory array provides the link between the channel index
-   within the  Raw Lidar Data input file and the channel ID in
-   SCC\_DB. To fill this variable the user has to know which channel IDs
-   in SCC\_DB correspond to his lidar channels. For this purpose the
-   SCC, in its final version will provide to the user a special tool to
-   get these channel IDs through a Web interface. At the moment this
-   interface is not yet available and these channel IDs will be
-   communicated directly to the user by the NA5 people.
-   
-   Anyway to continue the example let’s suppose that the four lidar
-   channels taken into account are mapped into SCC\_DB with the
-   following channel IDs:
+-  | ``channel_ID(channels)``
+   | This mandatory array provides the link between the channel index
+     within the *Raw Lidar Data* input file and the channel ID in
+     SCC\_DB. To fill this variable the user has to know which channel
+     IDs in SCC\_DB correspond to his lidar channels. For this purpose
+     the SCC, in its final version will provide to the user a special
+     tool to get these channel IDs through a Web interface. At the
+     moment this interface is not yet available and these channel IDs
+     will be communicated directly to the user by the NA5 people.
+   | Anyway to continue the example let’s suppose that the four lidar
+     channels taken into account are mapped into SCC\_DB with the
+     following channel IDs:
 
-   +----------------+--------------------------------------+
-   | 1064 nm        | :math:`\rightarrow` channel ID=7     |
-   +----------------+--------------------------------------+
-   | 532 cross      | :math:`\rightarrow` channel ID=5     |
-   +----------------+--------------------------------------+
-   | 532 parallel   | :math:`\rightarrow` channel ID=6     |
-   +----------------+--------------------------------------+
-   | 607 nm         | :math:`\rightarrow` channel ID=8     |
-   +----------------+--------------------------------------+
+   +----------------+-----------------+
+   | 1064 nm        |  channel ID=7   |
+   +----------------+-----------------+
+   | 532 cross      |  channel ID=5   |
+   +----------------+-----------------+
+   | 532 parallel   |  channel ID=6   |
+   +----------------+-----------------+
+   | 607 nm         |  channel ID=8   |
+   +----------------+-----------------+
 
-    In this case we have to define:
+   | 
+   | In this case we have to define:
 
    ::
 
        channel_ID = 7, 5, 6, 8 ;
 
-id_timescale(channels)
-   This mandatory array is introduced to determine which time scale is
-   used for the acquisition of each lidar channel. In particular this
-   array defines the link between the channel index and the time scale
-   index. In our example we have two different time scales. Filling the
-   arrays ``Raw_Data_Start_Time`` and ``Raw_Data_Stop_Time`` we have
-   defined a time scale index of 0 for the time scale with steps of 60
-   seconds and a time scale index of 1 for the other one with steps of
-   30 seconds. In this way this array has to be set as:
+-  | ``id_timescale(channels)``
+   | This mandatory array is introduced to determine which time scale is
+     used for the acquisition of each lidar channel. In particular this
+     array defines the link between the channel index and the time scale
+     index. In our example we have two different time scales. Filling
+     the arrays ``Raw_Data_Start_Time`` and ``Raw_Data_Stop_Time`` we
+     have defined a time scale index of 0 for the time scale with steps
+     of 60 seconds and a time scale index of 1 for the other one with
+     steps of 30 seconds. In this way this array has to be set as:
 
    ::
 
        id_timescale = 1, 0, 0, 0 ;
 
-Laser_Pointing_Angle(scan_angles
-   This mandatory array contains all the scan angles used in the
-   measurement. In our example we have only one scan angle of 5 degrees
-   with respect to the zenith, so we have to define:
+-  | ``Laser_Pointing_Angle(scan_angles)``
+   | This mandatory array contains all the scan angles used in the
+     measurement. In our example we have only one scan angle of 5
+     degrees with respect to the zenith, so we have to define:
 
    ::
 
        Laser_Pointing_Angle = 5 ;
 
-Laser_Pointing_Angle_of_Profiles(time, nb_of_time_scales)
-   This mandatory array is introduced to determine which scan angle is
-   used for the acquisition of each lidar profile. In particular this
-   array defines the link between the time and time scales indexes and
-   the scan angle index. In our example we have a single scan angle that
-   has to correspond to the scan angle index 0. So this array has to be
-   defined as:
+-  | ``Laser_Pointing_Angle_of_Profiles(time, nb_of_time_scales)``
+   | This mandatory array is introduced to determine which scan angle is
+     used for the acquisition of each lidar profile. In particular this
+     array defines the link between the time and time scales indexes and
+     the scan angle index. In our example we have a single scan angle
+     that has to correspond to the scan angle index 0. So this array has
+     to be defined as:
 
    ::
 
@@ -434,12 +439,12 @@
          _, 0,
          _, 0 ;
 
-Laser_Shots(time, channels)
-   This mandatory array stores the laser shots accumulated at each time
-   for each channel. In our example the number of laser shots
-   accumulated is 1500 for the 1064nm channels and 3000 for all the
-   other channels. Moreover the laser shots do not change with the time.
-   So we have to define this array as:
+-  | ``Laser_Shots(time, channels)``
+   | This mandatory array stores the laser shots accumulated at each
+     time for each channel. In our example the number of laser shots
+     accumulated is 1500 for the 1064nm channels and 3000 for all the
+     other channels. Moreover the laser shots do not change with the
+     time. So we have to define this array as:
 
    ::
 
@@ -455,158 +460,222 @@
          1500, _, _, _, 
          1500, _, _, _ ;
 
-Emitted_Wavelength(channels)
-   This optional array defines the link between the channel index and
-   the emission wavelength for each lidar channel. The wavelength has to
-   be expressed in nm. This information can be also taken from SCC\_DB.
-   In our example we have:
+-  | ``Emitted_Wavelength(channels)``
+   | This optional array defines the link between the channel index and
+     the emission wavelength for each lidar channel. The wavelength has
+     to be expressed in nm. This information can be also taken from
+     SCC\_DB. In our example we have:
 
    ::
 
        Emitted_Wavelength = 1064, 532, 532, 532 ;
 
-Detected_Wavelength(channels)
-   This optional array defines the link between the channel index and
-   the detected wavelength for each lidar channel. Here detected
-   wavelength means the value of center of interferential filter
-   expressed in nm. This information can be also taken from SCC\_DB. In
-   our example we have:
+-  | ``Detected_Wavelength(channels)``
+   | This optional array defines the link between the channel index and
+     the detected wavelength for each lidar channel. Here detected
+     wavelength means the value of center of interferential filter
+     expressed in nm. This information can be also taken from SCC\_DB.
+     In our example we have:
 
    ::
 
        Detected_Wavelength = 1064, 532, 532, 607 ;
 
-Raw_Data_Range_Resolution(channels)
-   This optional array defines the link between the channel index and
-   the raw range resolution for each channel. If the scan angle is
-   different from zero this quantity is different from the vertical
-   resolution. More precisely if :math:`\alpha` is the scan angle used
-   and :math:`\Delta z` is the range resolution the vertical
-   resolution is calculated as :math:`\Delta
-   z'=\Delta z \cos\alpha`. This array has to be filled with
-   :math:`\Delta z` and not with :math:`\Delta z'`. The unit is
-   meters. This information can be also taken from SCC\_DB. In our
-   example we have:
+-  | ``Raw_Data_Range_Resolution(channels)``
+   | This optional array defines the link between the channel index and
+     the raw range resolution for each channel. If the scan angle is
+     different from zero this quantity is different from the vertical
+     resolution. More precisely if :math:`\alpha` is the scan angle used
+     and :math:`\Delta z` is the range resolution the vertical
+     resolution is calculated as :math:`\Delta
+      z'=\Delta z \cos\alpha`. This array has to be filled with
+     :math:`\Delta z` and not with :math:`\Delta z'`. The unit is
+     meters. This information can be also taken from SCC\_DB. In our
+     example we have:
 
    ::
 
        Raw_Data_Range_Resolution = 7.5, 15.0, 15.0, 15.0 ;
 
-ID_Range(channels)
-   This optional array defines if a particular channel is configured as
-   high, low or ultranear range channel. In particular a value 0
-   indicates a low range channel, a value 1 a high range channel and a
-   value of 2 an ultranear range channel. If for a particular channel
-   you don’t separate between high and low range channel, please set the
-   corresponding value to 1. This information can be also taken from
-   SCC\_DB. In our case we have to set:
-
-   ::
-
-       ID_Range = 1, 1, 1, 1 ;
-
-Scattering_Mechanism(channels)
-   This optional array defines the scattering mechanism involved in
-   each lidar channel. In particular the following values are adopted:
+-  | ``Scattering_Mechanism(channels)``
+   | This optional array defines the scattering mechanism involved in
+     each lidar channel. In particular the following values are adopted:
 
-   +------+---------------------------------------------------------------------------------------------+
-   | 0    | :math:`\rightarrow` Total elastic backscatter                                               |
-   +------+---------------------------------------------------------------------------------------------+
-   | 1    | :math:`\rightarrow` :math:`N_2` vibrational Raman backscatter                               |
-   +------+---------------------------------------------------------------------------------------------+
-   | 2    | :math:`\rightarrow` Cross polarization elastic backscatter                                  |
-   +------+---------------------------------------------------------------------------------------------+
-   | 3    | :math:`\rightarrow` Parallel polarization elastic backscatter                               |
-   +------+---------------------------------------------------------------------------------------------+
-   | 4    | :math:`\rightarrow` :math:`H_2O` vibrational Raman backscatter                              |
-   +------+---------------------------------------------------------------------------------------------+
-   | 5    | :math:`\rightarrow` Rotational Raman Stokes line close to elastic line                      |
-   +------+---------------------------------------------------------------------------------------------+
-   | 6    | :math:`\rightarrow` Rotational Raman Stokes line far from elastic line                      |
-   +------+---------------------------------------------------------------------------------------------+
-   | 7    | :math:`\rightarrow` Rotational Raman anti-Stokes line close to elastic line                 |
-   +------+---------------------------------------------------------------------------------------------+
-   | 8    | :math:`\rightarrow` Rotational Raman anti-Stokes line far from elastic line                 |
-   +------+---------------------------------------------------------------------------------------------+
-   | 9    | :math:`\rightarrow` Rotational Raman Stokes and anti-Stokes lines close to elastic line     |
-   +------+---------------------------------------------------------------------------------------------+
-   | 10   | :math:`\rightarrow` Rotational Raman Stokes and anti-Stokes lines far from elastic line     |
-   +------+---------------------------------------------------------------------------------------------+
+   +-----+---------------------------------------------------+
+   | 0   |  Total elastic backscatter                        |
+   +-----+---------------------------------------------------+
+   | 1   |  N\ :math:`_2` vibrational Raman backscatter      |
+   +-----+---------------------------------------------------+
+   | 2   |  Cross polarization elastic backscatter           |
+   +-----+---------------------------------------------------+
+   | 3   |  Parallel polarization elastic backscatter        |
+   +-----+---------------------------------------------------+
+   | 4   |  H\ :math:`_2`\ O vibrational Raman backscatter   |
+   +-----+---------------------------------------------------+
+   | 5   |  Rotational Raman low quantum number              |
+   +-----+---------------------------------------------------+
+   | 6   |  Rotational Raman high quantum number             |
+   +-----+---------------------------------------------------+
 
-   This information can be also taken from SCC\_DB. In our example we have:
+   | 
+   | This information can be also taken from SCC\_DB. In our example we
+     have:
 
    ::
 
         Scattering_Mechanism = 0, 2, 3, 1 ;
 
-Acquisition_Mode(channels)
-   This optional array defines the acquisition mode (analog or
-   photoncounting) involved in each lidar channel. In particular a value
-   of 0 means analog mode and 1 photoncounting mode. This information
-   can be also taken from SCC\_DB. In our example we have:
+-  | ``Signal_Type(channels)``
+   | This optional array defines the type of signal involved in each
+     lidar channel. In particular the following values are adopted:
+
+   +------+--------------------------------------------------------------+
+   | 0    |  Total elastic                                               |
+   +------+--------------------------------------------------------------+
+   | 1    |  Total elastic near range                                    |
+   +------+--------------------------------------------------------------+
+   | 2    |  Total elastic far range                                     |
+   +------+--------------------------------------------------------------+
+   | 3    |  N\ :math:`_2` vibrational Raman                             |
+   +------+--------------------------------------------------------------+
+   | 4    |  N\ :math:`_2` vibrational Raman near range                  |
+   +------+--------------------------------------------------------------+
+   | 5    |  N\ :math:`_2` vibrational Raman far range                   |
+   +------+--------------------------------------------------------------+
+   | 6    |  Elastic polarization reflected                              |
+   +------+--------------------------------------------------------------+
+   | 7    |  Elastic polarization transmitted                            |
+   +------+--------------------------------------------------------------+
+   | 8    |  Rotational Raman line close to elastic line                 |
+   +------+--------------------------------------------------------------+
+   | 9    |  Rotational Raman line far from elastic line                 |
+   +------+--------------------------------------------------------------+
+   | 10   |  Elastic polarization reflected near range                   |
+   +------+--------------------------------------------------------------+
+   | 11   |  Elastic polarization reflected far range                    |
+   +------+--------------------------------------------------------------+
+   | 12   |  Elastic polarization transmitted near range                 |
+   +------+--------------------------------------------------------------+
+   | 13   |  Elastic polarization transmitted far range                  |
+   +------+--------------------------------------------------------------+
+   | 14   |  H\ :math:`_2`\ O vibrational Raman backscatter              |
+   +------+--------------------------------------------------------------+
+   | 15   |  Rotational Raman line far from elastic line near range      |
+   +------+--------------------------------------------------------------+
+   | 16   |  Rotational Raman line far from elastic line far range       |
+   +------+--------------------------------------------------------------+
+   | 17   |  Rotational Raman line close to elastic line near range      |
+   +------+--------------------------------------------------------------+
+   | 18   |  Rotational Raman line close to elastic line far range       |
+   +------+--------------------------------------------------------------+
+   | 19   |  H\ :math:`_2`\ O vibrational Raman backscatter near range   |
+   +------+--------------------------------------------------------------+
+   | 20   |  H\ :math:`_2`\ O vibrational Raman backscatter far range    |
+   +------+--------------------------------------------------------------+
+   | 21   |  Total elastic ultra near range                              |
+   +------+--------------------------------------------------------------+
+   | 22   |  +45 rotated elastic polarization transmitted                |
+   +------+--------------------------------------------------------------+
+   | 23   |  +45 rotated elastic polarization reflected                  |
+   +------+--------------------------------------------------------------+
+   | 24   |  -45 rotated elastic polarization transmitted                |
+   +------+--------------------------------------------------------------+
+   | 25   |  -45 rotated elastic polarization reflected                  |
+   +------+--------------------------------------------------------------+
+   | 26   |  +45 rotated elastic polarization transmitted near range     |
+   +------+--------------------------------------------------------------+
+   | 27   |  +45 rotated elastic polarization transmitted far range      |
+   +------+--------------------------------------------------------------+
+   | 28   |  +45 rotated elastic polarization reflected near range       |
+   +------+--------------------------------------------------------------+
+   | 29   |  +45 rotated elastic polarization reflected far range        |
+   +------+--------------------------------------------------------------+
+   | 30   |  -45 rotated elastic polarization transmitted near range     |
+   +------+--------------------------------------------------------------+
+   | 31   |  -45 rotated elastic polarization transmitted far range      |
+   +------+--------------------------------------------------------------+
+   | 32   |  -45 rotated elastic polarization reflected near range       |
+   +------+--------------------------------------------------------------+
+   | 33   |  -45 rotated elastic polarization reflected far range        |
+   +------+--------------------------------------------------------------+
+
+   | 
+   | This information can be also taken from SCC\_DB. In our example we
+     have:
+
+   ::
+
+        Signal_Type = 0, 7, 6, 3 ;
+
+-  | ``Acquisition_Mode(channels)``
+   | This optional array defines the acquisition mode (analog or
+     photoncounting) involved in each lidar channel. In particular a
+     value of 0 means analog mode and 1 photoncounting mode. This
+     information can be also taken from SCC\_DB. In our example we have:
 
    ::
 
         Acquisition_Mode = 0, 1, 1, 1 ;
 
-Laser_Repetition_Rate(channels)
-   This optional array defines the repetition rate in Hz used to
-   acquire each lidar channel. This information can be also taken from
-   SCC\_DB. In our example we are supposing we have only one laser with
-   a repetition rate of 50 Hz so we have to set:
+-  | ``Laser_Repetition_Rate(channels)``
+   | This optional array defines the repetition rate in Hz used to
+     acquire each lidar channel. This information can be also taken from
+     SCC\_DB. In our example we are supposing we have only one laser
+     with a repetition rate of 50 Hz so we have to set:
 
    ::
 
        Laser_Repetition_Rate = 50, 50, 50, 50 ;
 
-Dead_Time(channels)
-   This optional array defines the dead time in ns associated to each
-   lidar channel. The SCC will use the values given by this array to
-   correct the photoncounting signals for dead time. Of course for
-   analog signals no dead time correction will be applied (for analog
-   channels the corresponding dead time values have to be set to
-   undefined value). This information can be also taken from SCC\_DB. In
-   our example the 1064 nm channel is acquired in analog mode so the
-   corresponding dead time value has to be undefined. If we suppose a
-   dead time of 10 ns for all other channels we have to set:
+-  | ``Dead_Time(channels)``
+   | This optional array defines the dead time in ns associated to each
+     lidar channel. The SCC will use the values given by this array to
+     correct the photoncounting signals for dead time. Of course for
+     analog signals no dead time correction will be applied (for analog
+     channels the corresponding dead time values have to be set to
+     undefined value). This information can be also taken from SCC\_DB.
+     In our example the 1064 nm channel is acquired in analog mode so
+     the corresponding dead time value has to be undefined. If we
+     suppose a dead time of 10 ns for all other channels we have to set:
 
    ::
 
         Dead_Time = _, 10, 10, 10 ;
 
-Dead_Time_Corr_Type(channels
-   This optional array defines which kind of dead time correction has
-   to be applied on each photoncounting channel. The SCC will correct
-   the data supposing a not-paralyzable channel if a value of 0 is found
-   while a paralyzable channel is supposed if a value of 1 is found. Of
-   course for analog signals no dead time correction will be applied and
-   so the corresponding values have to be set to undefined value. This
-   information can be also taken from SCC\_DB. In our example the 1064
-   nm channel is acquired in analog mode so the corresponding has to be
-   undefined. If we want to consider all the photoncounting signals as
-   not-paralyzable ones: we have to set:
+-  | ``Dead_Time_Corr_Type(channels)``
+   | This optional array defines which kind of dead time correction has
+     to be applied on each photoncounting channel. The SCC will correct
+     the data supposing a not-paralyzable channel if a value of 0 is
+     found while a paralyzable channel is supposed if a value of 1 is
+     found. Of course for analog signals no dead time correction will be
+     applied and so the corresponding values have to be set to undefined
+     value. This information can be also taken from SCC\_DB. In our
+     example the 1064 nm channel is acquired in analog mode so the
+     corresponding has to be undefined. If we want to consider all the
+     photoncounting signals as not-paralyzable ones: we have to set:
 
    ::
 
         Dead_Time_Corr_Type = _, 0, 0, 0 ;
 
-Trigger_Delay(channels)
-   This optional array defines the delay (in ns) of the middle of the
-   first rangebin with respect to the output laser pulse for each lidar
-   channel. The SCC will use the values given by this array to correct
-   for trigger delay. This information can be also taken from SCC\_DB.
-   Let’s suppose that in our example all the photoncounting channels are
-   not affected by this delay and only the analog channel at 1064nm is
-   acquired with a delay of 50ns. In this case we have to set:
+-  | ``Trigger_Delay(channels)``
+   | This optional array defines the delay (in ns) of the middle of the
+     first rangebin with respect to the output laser pulse for each
+     lidar channel. The SCC will use the values given by this array to
+     correct for trigger delay. This information can be also taken from
+     SCC\_DB. Let’s suppose that in our example all the photoncounting
+     channels are not affected by this delay and only the analog channel
+     at 1064nm is acquired with a delay of 50ns. In this case we have to
+     set:
 
    ::
 
        Trigger_Delay = 50, 0, 0, 0 ;
 
-Background_Mode(channels
-   This optional array defines how the atmospheric background has to be
-   subtracted from the lidar channel. Two options are available for the
-   calculation of atmospheric background:
+-  | ``Background_Mode(channels)``
+   | This optional array defines how the atmospheric background has to
+     be subtracted from the lidar channel. Two options are available for
+     the calculation of atmospheric background:
 
    #. Average in the far field of lidar channel. In this case the value
       of this variable has to be 1
@@ -622,39 +691,40 @@
 
        Background_Mode = 0, 1, 1, 1 ;
 
-Background_Low(channels)
-   This mandatory array defines the minimum altitude (in meters) to
-   consider in calculating the atmospheric background for each channel.
-   In case pre-trigger mode is used the corresponding value has to be
-   set to the rangebin to be used as lower limit (within pre-trigger
-   region) for background calculation. In our example, if we want to
-   calculate the background between 30000 and 50000 meters for all
-   photoncounting channels and we want to use the first 500 pre-trigger
-   bins for the background calculation for the 1064nm channel we have to
-   set:
+-  | ``Background_Low(channels)``
+   | This mandatory array defines the minimum altitude (in meters) to
+     consider in calculating the atmospheric background for each
+     channel. In case pre-trigger mode is used the corresponding value
+     has to be set to the rangebin to be used as lower limit (within
+     pre-trigger region) for background calculation. In our example, if
+     we want to calculate the background between 30000 and 50000 meters
+     for all photoncounting channels and we want to use the first 500
+     pre-trigger bins for the background calculation for the 1064nm
+     channel we have to set:
 
    ::
 
         Background_Low= 0, 30000, 30000, 30000 ;
 
-Background_High(channels)
-   This mandatory array defines the maximum altitude (in meters) to
-   consider in calculating the atmospheric background for each channel.
-   In case pre-trigger mode is used the corresponding value has to be
-   set to the rangebin to be used as upper limit (within pre-trigger
-   region) for background calculation. In our example, if we want to
-   calculate the background between 30000 and 50000 meters for all
-   photoncounting channels and we want to use the first 500 pre-trigger
-   bins for the background calculation for the 1064nm channel we have to
-   set:
+-  | ``Background_High(channels)``
+   | This mandatory array defines the maximum altitude (in meters) to
+     consider in calculating the atmospheric background for each
+     channel. In case pre-trigger mode is used the corresponding value
+     has to be set to the rangebin to be used as upper limit (within
+     pre-trigger region) for background calculation. In our example, if
+     we want to calculate the background between 30000 and 50000 meters
+     for all photoncounting channels and we want to use the first 500
+     pre-trigger bins for the background calculation for the 1064nm
+     channel we have to set:
 
    ::
 
        Background_High = 500, 50000, 50000, 50000 ;
 
-Molecular_Calc
-   This mandatory variable defines the way used by SCC to calculate the
-   molecular density profile. At the moment two options are available:
+-  | ``Molecular_Calc``
+   | This mandatory variable defines the way used by SCC to calculate
+     the molecular density profile. At the moment two options are
+     available:
 
    #. US Standard Atmosphere 1976. In this case the value of this
       variable has to be 0
@@ -665,59 +735,35 @@
    measured pressure and temperature at lidar station level. Indeed if
    we decide to use the option 2. a radiosounding file has to be
    submitted separately in NetCDF format (the structure of this file is
-   summarized in table tab:sounding). Let’s suppose we want to use the
+   summarized in table 2 of the pdf file). Let’s suppose we want to use the
    option 1. so:
 
    ::
 
        Molecular_Calc = 0 ;
 
-Pressure_at_Lidar_Station
-   Because we have chosen the US Standard Atmosphere for calculation of
-   the molecular density profile we have to give the pressure in hPa at
-   lidar station level:
+-  | ``Pressure_at_Lidar_Station``
+   | Because we have chosen the US Standard Atmosphere for calculation
+     of the molecular density profile we have to give the pressure in
+     hPa at lidar station level:
 
    ::
 
        Pressure_at_Lidar_Station = 1010 ;
 
-Temperature_at_Lidar_Station
-   Because we have chosen the US Standard Atmosphere for calculation of
-   the molecular density profile we have to give the temperature in C at
-   lidar station level:
+-  | ``Temperature_at_Lidar_Station``
+   | Because we have chosen the US Standard Atmosphere for calculation
+     of the molecular density profile we have to give the temperature in
+     C at lidar station level:
 
    ::
 
        Temperature_at_Lidar_Station = 19.8 ;
 
-Depolarization_Factor(channels)
-   This array is required only for lidar systems that use the two
-   depolarization channels for the backscatter retrieval. It represents
-   the factor :math:`f` to calculate the total backscatter signal
-   :math:`S_t` combining its cross :math:`S_c` and parallel
-   :math:`S_p` components: :math:`S_t=S_p+fS_c`. This factor is
-   mandatory only for systems acquiring :math:`S_c` and :math:`S_p`
-   and not :math:`S_t`. For systems acquiring :math:`S_c`,
-   :math:`S_p` and :math:`S_t` this factor is optional and it will
-   be used only for depolarizaton ratio calculation. Moreover only the
-   values of the array corresponding to cross polarization channels will
-   be considered; all other values will be not taken into account and
-   should be set to undefined value. In our example for the wavelength
-   532nm we have only the cross and the parallel components and not the
-   total one. So we have to give the value of this factor only in
-   correspondence of the 532nm cross polarization channel that
-   corresponds to the channel index 1. Suppose that this factor is 0.88.
-   Moreover, because we don’t have any other depolarization channels we
-   have also to set all other values of the array to undefined value.
-
-   ::
-
-       Depolarization_Factor = _,0.88,_,_ ;
-
-LR_Input(channels)
-   This array is required only for lidar channels for which elastic
-   backscatter retrieval has to be performed. It defines the lidar ratio
-   to be used within this retrieval. Two options are available:
+-  | ``LR_Input(channels)``
+   | This array is required only for lidar channels for which elastic
+     backscatter retrieval has to be performed. It defines the lidar
+     ratio to be used within this retrieval. Two options are available:
 
    #. The user can submit a lidar ratio profile. In this case the value
       of this variable has to be 0.
@@ -727,7 +773,7 @@
 
    If we decide to use the option 1. a lidar ratio file has to be
    submitted separately in NetCDF format (the structure of this file is
-   summarized in table tab:lr). If we decide to use the option 2. the
+   summarized in table ). If we decide to use the option 2. the
    fixed value of lidar ratio will be taken from SCC\_DB. In our example
    we have to give a value of this array only for the 1064nm lidar
    channel because for the 532nm we will be able to retrieve a Raman
@@ -738,85 +784,87 @@
 
        LR_Input = 1,_,_,_ ;
 
-DAQ_Range(channels)
-   This array is required only if one or more lidar signals are
-   acquired in analog mode. It gives the analog scale in mV used to
-   acquire the analog signals. In our example we have only the 1064nm
-   channel acquired in analog mode. If we have used a 100mV analog scale
-   to acquire this channel we have to set:
+-  | ``DAQ_Range(channels)``
+   | This array is required only if one or more lidar signals are
+     acquired in analog mode. It gives the analog scale in mV used to
+     acquire the analog signals. In our example we have only the 1064nm
+     channel acquired in analog mode. If we have used a 100mV analog
+     scale to acquire this channel we have to set:
 
    ::
 
        DAQ_Range = 100,_,_,_ ;
 
+
 Global attributes
 ~~~~~~~~~~~~~~~~~
 
-Measurement_ID
-   This mandatory global attribute defines the measurement ID
-   corresponding to the actual lidar measurement. It is a string
-   composed by 12 characters. The first 8 characters give the start date
-   of measurement in the format YYYYMMDD. The next 2 characters give the
-   Earlinet call-sign of the station. The last 2 characters are used to
-   distinguish between different time-series within the same date. In
-   our example we have to set:
+-  | ``Measurement_ID``
+   | This mandatory global attribute defines the measurement ID
+     corresponding to the actual lidar measurement. It is a string
+     composed by 12 characters. The first 8 characters give the start
+     date of measurement in the format YYYYMMDD. The next 2 characters
+     give the Earlinet call-sign of the station. The last 2 characters
+     are used to distinguish between different time-series within the
+     same date. In our example we have to set:
 
    ::
 
         Measurement_ID= "20090130cc00" ;
 
-RawData_Start_Date
-   This mandatory global attribute defines the start date of lidar
-   measurements in the format YYYYMMDD. In our case we have:
+-  | ``RawData_Start_Date``
+   | This mandatory global attribute defines the start date of lidar
+     measurements in the format YYYYMMDD. In our case we have:
 
    ::
 
         RawData_Start_Date = "20090130" ;
 
-RawData_Start_Time_UT
-   This mandatory global attribute defines the UT start time of lidar
-   measurements in the format HHMMSS. In our case we have:
+-  | ``RawData_Start_Time_UT``
+   | This mandatory global attribute defines the UT start time of lidar
+     measurements in the format HHMMSS. In our case we have:
 
    ::
 
         RawData_Start_Time_UT = "000001" ;
 
-RawData_Stop_Time_UT``
-   This mandatory global attribute defines the UT stop time of lidar
-   measurements in the format HHMMSS. In our case we have:
+-  | ``RawData_Stop_Time_UT``
+   | This mandatory global attribute defines the UT stop time of lidar
+     measurements in the format HHMMSS. In our case we have:
 
    ::
 
         RawData_Stop_Time_UT = "000501" ;
 
-RawBck_Start_Date
-   This optional global attribute defines the start date of dark
-   measurements in the format YYYYMMDD. In our case we have:
+-  | ``RawBck_Start_Date``
+   | This optional global attribute defines the start date of dark
+     measurements in the format YYYYMMDD. In our case we have:
 
    ::
 
         RawBck_Start_Date = "20090129" ;
 
-RawBck_Start_Time_UT
-   This optional global attribute defines the UT start time of dark
-   measurements in the format HHMMSS. In our case we have:
+-  | ``RawBck_Start_Time_UT``
+   | This optional global attribute defines the UT start time of dark
+     measurements in the format HHMMSS. In our case we have:
 
    ::
 
         RawBck_Start_Time_UT = "235001" ;
 
-RawBck_Stop_Time_UT
-   This optional global attribute defines the UT stop time of dark
-   measurements in the format HHMMSS. In our case we have:
+-  | ``RawBck_Stop_Time_UT``
+   | This optional global attribute defines the UT stop time of dark
+     measurements in the format HHMMSS. In our case we have:
 
    ::
 
         RawBck_Stop_Time_UT = "235301" ;
 
+
 Example of file (CDL format)
-----------------------------
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 
-To summarize we have the following NetCDF  Raw Lidar Data file (in CDL
+To summarize we have the following NetCDF *Raw Lidar Data* file (in CDL
 format):
 
 ::
@@ -832,8 +880,7 @@
             int channel_ID(channels) ;
             int Laser_Repetition_Rate(channels) ;
             double Laser_Pointing_Angle(scan_angles) ;
-            int ID_Range(channels) ;
-            int Scattering_Mechanism(channels) ;
+            int Signal_Type(channels);
             double Emitted_Wavelength(channels) ;
             double Detected_Wavelength(channels) ;
             double Raw_Data_Range_Resolution(channels) ;
@@ -876,9 +923,7 @@
 
      Laser_Pointing_Angle = 5 ;
 
-     ID_Range = 1, 1, 1, 1 ;
-
-     Scattering_Mechanism = 0, 2, 3, 1 ;
+     Signal_Type = 0, 7, 6, 3 ;
 
      Emitted_Wavelength = 1064, 532, 532, 532 ;
 
@@ -985,11 +1030,19 @@
 
      Background_Profile = ...
 
-Please keep in mind that in case you submit a file like the previous one
-all the parameters present in it will be used by the SCC even if you
-have different values for the same parameters within the SCC\_DB. If you
-want to use the values already stored in SCC\_DB (this should be the
-usual way to use SCC) the  Raw Lidar Data input file has to be
+The name of the input file should have the following format:
+
+::
+
+    Measurement_ID.nc
+
+| so in the example the filename should be 20090130cc00.nc.
+  
+Please keep in mind that in case you submit a file like the previous
+one all the parameters present in it will be used by the SCC even if
+you have different values for the same parameters within the SCC\_DB.
+If you want to use the values already stored in SCC\_DB (this should
+be the usual way to use SCC) the *Raw Lidar Data* input file has to be
 modified as follows:
 
 ::
@@ -1126,10 +1179,10 @@
      Background_Profile = ... 
 
 This example file contains the minimum collection of mandatory
-information that has to be found within the  Raw Lidar Data input
-file. If it is really necessary, the user can decide to add to these
-mandatory parameters any number of additional parameters considered in
-the previous example.
+information that has to be found within the *Raw Lidar Data* input file.
+If it is really necessary, the user can decide to add to these mandatory
+parameters any number of additional parameters considered in the
+previous example.
 
 Finally, suppose we want to make the following changes with respect to
 the previous example:
@@ -1144,25 +1197,25 @@
 
 In this case we have to generate the following NetCDF additional files:
 
-rs_20090130cc00.nc
-    The name of  Sounding Data file has to be computed as follows:
-    ``"rs_"``+``Measurement_ID``
-    The structure of this file is summarized in table tab:sounding.
+-  | ``rs_20090130cc00.nc``
+   | The name of *Sounding Data* file has to be computed as follows:
+   | ``"rs_"``\ +\ ``Measurement_ID``
+   | The structure of this file is summarized in table 2 of the pdf.
 
-ov_20090130cc00.nc
-    The name of  Overlap file has to be computed as follows:
-    ``"ov_"``+``Measurement_ID``
-    The structure of this file is summarized in table tab:overlap.
+-  | ``ov_20090130cc00.nc``
+   | The name of *Overlap* file has to be computed as follows:
+   | ``"ov_"``\ +\ ``Measurement_ID``
+   | The structure of this file is summarized in table 3 of the pdf.
 
-lr_20090130cc00.nc
-    The name of  Lidar Ratio file has to be computed as follows:
-    ``"lr_"``+``Measurement_ID``
-    The structure of this file is summarized in table tab:lr.
+-  | ``lr_20090130cc00.nc``
+   | The name of *Lidar Ratio* file has to be computed as follows:
+   | ``"lr_"``\ +\ ``Measurement_ID``
+   | The structure of this file is summarized in table 4 of the pdf.
 
-Moreover we need to apply the following changes to the  Raw Lidar Data
+Moreover we need to apply the following changes to the *Raw Lidar Data*
 input file:
 
-1. Change the value of the variable ``Molecular_Calc`` as follows:
+#. Change the value of the variable ``Molecular_Calc`` as follows:
 
    ::
 
@@ -1171,26 +1224,27 @@
    Of course the variables ``Pressure_at_Lidar_Station`` and
    ``Temperature_at_Lidar_Station`` are not necessary anymore.
 
-2. Change the values of the array ``LR_Input`` as follows:
+#. Change the values of the array ``LR_Input`` as follows:
 
    ::
 
        LR_Input = 0,_,_,_ ;
 
-3. Add the global attribute ``Sounding_File_Name``
+#. Add the global attribute ``Sounding_File_Name``
 
    ::
 
        Sounding_File_Name = "rs_20090130cc00.nc" ;
 
-5. Add the global attribute ``LR_File_Name``
+#. Add the global attribute ``LR_File_Name``
 
    ::
 
        LR_File_Name = "lr_20090130cc00.nc" ;
 
-6. Add the global attribute ``Overlap_File_Name``
+#. Add the global attribute ``Overlap_File_Name``
 
    ::
 
        Overlap_File_Name = "ov_20090130cc00.nc" ;
+

mercurial