Project

General

Profile

Actions

Application Descriptor File

Purpose

The application descriptor file contains the definition of the application in terms of:
  • job templates including:
    • streaming executable
    • default parameters
    • job default configuration
  • workflow including the workflow nodes defined with
    • the source for the inputs (e.g. a previous node, a catalogue series, a local file)
    • their parameter values to override the default parameters (defined in the job template above)

Type

The application descriptor is an XML file available in $_CIOP_APPLICATION_PATH/application.xml

Note: the value $_CIOP_APPLICATION_PATH is /application

Format

The application descriptor file structure is available below:

Level Tag name Descendants Tag Contents Cardinality Attribute name Attribute value
> application All - 1..1 - -
1 jobTemplates jobTemplate - 1..1 - -
2 jobTemplate streamingExecutable, defaultParameters, defaultJobconf - 1..* id job template name
3 streamingExecutable none path to streaming executable 1..1 - -
3 defaultParameters parameter - 0..1 - -
4 parameter - parameter default value 0..* id parameter name
3 defaultJobconf - - 0..1 - -
4 property - property value 0..* id property value
1 workflow workflowVersion,node - 1..1 id workflow name
2 workflowVersion - workflow version 1..1 - -
2 node job, sources, parameters - 1..* id node name
3 job - - 1..1 id job template name
3 sources source - 1..1 - -
4 source - source value 1..* refid file:urls, wf:node, cas:serie
3 parameters parameter - 0..* - -
4 parameter - parameter value (overrides the parameter default value) 0..* id parameter name

Tip: check your application descriptor file with the ciop-appcheck utility described here: ciop-appcheck

Application descriptor values and properties

source refid values

Local inputs - local files will use the file:// protocol and are defined in the workflow as follows:

<workflow id="somename">                            
    <workflowVersion>1.0</workflowVersion>
    <node id="somenodeid">
        <job id="ceda-collect"></job>
        <sources>
            <source refid="file:urls" >/application/input.urls</source>
        </sources>
    </node>
</workflow>

and the file input.urls contains the references to the local files:

[ user@sb ~] cat /application/input.urls
file:///tmp/somefile1
file:///tmp/somefile2
file:///tmp/somefile3

Then the job executable can use ciop-copy to copy the files if needed.

while read inputfile
do
    echo $inputfile | ciop-copy -o ./ - 
done 

Values

Passing values to a job follows the same approach as above.

<workflow id="somename">                            
    <workflowVersion>1.0</workflowVersion>
    <node id="somenodeid">
        <job id="ceda-collect"></job>
        <sources>
            <source refid="file:urls" >/application/inputparams</source>
        </sources>
    </node>
</workflow>

and the file inputparams contains the list of values:

[ user@sb ~] cat /application/inputparams
-10,-10,10,10
10,10,20,20

In the example above, the executable manages the parameters (bounding boxes) with:

while read bbox
do
    echo "processing bounding box $bbox" 
done 

Products available in the sandbox internal catalogue

During the sandbox definition and creation you may have selected a list of EO products, the references to these products are available in the sandbox internal catalogue.
The workflow is defined as follows:

<workflow id="some_workflow">
    <workflowVersion>1.0</workflowVersion>
    <node id="some_node">                        
    <job id="some_job_template"></job>                    
    <sources>
        <source refid="cas:serie">ATS_TOA_1P</source>
    </sources>
    <parameters>                            
        <parameter id="some_parameter">some_value</parameter>
    </parameters>
    </node>

As an example, the job executable would contain the lines below to copy the catalogue products locally:

while read product
do
    echo $product | ciop-copy -o ./ -
done

outputs from a previous node

The methods above are used for the first job of the workflow. The remaining nodes need to refer the precedent job(s) results:

<workflow id="somename">                            
    <workflowVersion>1.0</workflowVersion>
    <node id="some_node_1">
        <job id="some_job_template_1"></job>
        <sources>
            <source refid="file:urls">/application/inputparams</source>
        </sources>
    </node>
    <node id="some_node_2">
        <job id="some_job_template_2"></job>
        <sources>
            <source refid="wf:node">some_node_1</source>
        </sources>
    </node>
</workflow>

Job configuration

At job template level, the default properties below can be defined:

Property Value Description
ciop.job.max.tasks integer sets the maximum number of jobs (>0)
mapred.task.timeout integer number of milliseconds of walltime for the execution of a job without reporting via ciop-log

Example

The example below is taken from the BEAM Arithm tutorial available here: Beam Arithm

<?xml version="1.0" encoding="UTF-8"?>
<application id="beam_arithm">
    <jobTemplates>
        <!-- BEAM BandMaths operator job template  -->
        <jobTemplate id="expression">
            <streamingExecutable>/application/expression/run</streamingExecutable>
            <defaultParameters>                        
                <parameter id="expression">l1_flags.INVALID?0:radiance_13>15?0:100+radiance_9-(radiance_8+(radiance_10-radiance_8)*27.524/72.570)</parameter>
            </defaultParameters>
        </jobTemplate>
        <!-- BEAM Level 3 processor job template  -->
        <jobTemplate id="binning">
            <streamingExecutable>/application/binning/run</streamingExecutable>
            <defaultParameters>                        
                <parameter id="cellsize">9.28</parameter>
                <parameter id="bandname">out</parameter>
                <parameter id="bitmask">l1_flags.INVALID?0:radiance_13>15?0:100+radiance_9-(radiance_8+(radiance_10-radiance_8)*27.524/72.570)</parameter>
                <parameter id="bbox">-180,-90,180,90</parameter>
                <parameter id="algorithm">Minimum/Maximum</parameter>
                <parameter id="outputname">binned</parameter>
                <parameter id="resampling">binning</parameter>
                <parameter id="palette">#MCI_Palette
color0=0,0,0
color1=0,0,154
color2=54,99,250
color3=110,201,136
color4=166,245,8
color5=222,224,0
color6=234,136,0
color7=245,47,0
color8=255,255,255
numPoints=9
sample0=98.19878118960284
sample1=98.64947122314665
sample2=99.10016125669047
sample3=99.5508512902343
sample4=100.0015413237781
sample5=100.4522313573219
sample6=100.90292139086574
sample7=101.35361142440956
sample8=101.80430145795337</parameter>
                <parameter id="band">1</parameter>
                <parameter id="tailor">true</parameter>
            </defaultParameters>
            <defaultJobconf>
                    <property id="ciop.job.max.tasks">1</property>
                </defaultJobconf>
        </jobTemplate>
    </jobTemplates>
    <workflow id="beam_arithm">                            
        <workflowVersion>1.0</workflowVersion>
        <node id="node_expression">                
            <job id="expression"></job>            
            <sources>
                <!-- <source refid="file:urls">/home/fbrito/meris</source>  -->
                <source refid="cas:serie">MER_RR__1P</source>
            </sources>
            <parameters>                    
            </parameters>
        </node>
        <node id="node_binning">                
            <job id="binning"></job>            
            <sources>
                <source refid="wf:node">node_expression</source>                
            </sources>
            <parameters>
                <parameter id="bitmask"/>        
            </parameters>
        </node>
    </workflow>
</application>

Updated by Herve Caumont over 11 years ago ยท 2 revisions