Crop
Goal
Wrap the crop
step as a Common Workflow Language CommandLineTool and execute it with a CWL runner.
Lab
This step has a dedicated lab available at /workspace/mastering-app-package/practice-labs/CommandLineTools/crop.ipynb
How to wrap a step as a CWL CommandLineTool
The CWL document below shows the crop
step wrapped as a CWL CommandLineTool:
cwl-cli/crop.cwl | |
---|---|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 |
|
Let's break down the key components of this CWL document:
cwlVersion: v1.0
: Specifies the version of the CWL specification that this document follows.class: CommandLineTool
: Indicates that this CWL document defines a command-line tool.id: crop
: Provides a unique identifier for this tool, which can be used to reference it in workflows.requirements
: Specifies the requirements and dependencies of the tool. In this case, it defines the following:InlineJavascriptRequirement
: This requirement allows the use of inline JavaScript expressions in the tool.EnvVarRequirement
: It sets environment variables. In this case, it sets thePYTHONPATH
environment variable to "/app."ResourceRequirement
: Specifies resource requirements for running the tool, including the maximum number of CPU cores and maximum RAM.DockerRequirement
: This requirement specifies the Docker container to be used. It indicates that the tool should be executed in a Docker container with the imagelocalhost/crop:latest
.
baseCommand
: Defines the base command to be executed in the container. In this case, it's running a Python module called "app" with the commandpython -m app
.arguments
: This section is empty, meaning there are no additional command-line arguments specified here. The tool is expected to receive its arguments via the input parameters.inputs
: Describes the input parameters for the tool, including their types and how they are bound to command-line arguments. The tool expects the following inputs:item
: A string representing the input STAC item (image) to be processed, bound to the--input-item
argument.aoi
: A string representing the area of interest (AOI) as a bounding box, bound to the--aoi
argument.epsg
: A string representing the EPSG code for the coordinate system, bound to the--epsg
argument.band
: A string representing the name of the band to be extracted, bound to the--band
argument.
outputs
: Specifies the tool's output. It defines an output parameter namedcropped
, which is of typeFile
. The outputBinding section specifies that the tool is expected to produce one or more TIFF files (glob: '*.tif') as output.
Steps
Clean-up the /workspace/mastering-app-package/runs
folder:
rm -fr /workspace/mastering-app-package/runs/*
Run the CWL document using the cwltool
CWL runner to execute the crop
step with the green
band with:
export WORKSPACE=/workspace/mastering-app-package
export RUNTIME=${WORKSPACE}/runs
mkdir -p ${RUNTIME}
cd ${RUNTIME}
cwltool \
--podman \
--outdir ${WORKSPACE}/runs \
${WORKSPACE}/cwl-cli/crop.cwl \
--item "https://earth-search.aws.element84.com/v0/collections/sentinel-s2-l2a-cogs/items/S2B_10TFK_20210713_0_L2A" \
--aoi="-121.399,39.834,-120.74,40.472" \
--epsg "EPSG:4326" \
--band "green"
sh -x ${WORKSPACE}/scripts/cwl-cli-crop-green.sh
Run the CWL document using the cwltool
CWL runner to execute the crop
step with the nir
band with:
export WORKSPACE=/workspace/mastering-app-package
export RUNTIME=${WORKSPACE}/runs
mkdir -p ${RUNTIME}
cd ${RUNTIME}
cwltool \
--podman \
--outdir ${WORKSPACE}/runs \
${WORKSPACE}/cwl-cli/crop.cwl \
--item "https://earth-search.aws.element84.com/v0/collections/sentinel-s2-l2a-cogs/items/S2B_10TFK_20210713_0_L2A" \
--aoi="-121.399,39.834,-120.74,40.472" \
--epsg "EPSG:4326" \
--band "nir"
sh -x ${WORKSPACE}/scripts/cwl-cli-crop-nir.sh
Expected outcome
The folder /workspace/mastering-app-package/runs
contains:
(base) jovyan@coder-mrossi:~/runs$ tree .
.
├── crop_green.tif
└── crop_nir.tif
0 directories, 2 files
Extra
The CWL runner cwltool
allows you to do a YAML file with the parameters:
item: "https://earth-search.aws.element84.com/v0/collections/sentinel-s2-l2a-cogs/items/S2B_10TFK_20210713_0_L2A"
aoi: "-121.399,39.834,-120.74,40.472"
epsg: "EPSG:4326"
band: "green"
and run it with:
cwltool \
--podman \
--outdir /workspace/mastering-app-package/runs \
crop.cwl \
crop-params.yaml