-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsentinel_2_ndwi.sh
83 lines (59 loc) · 2.71 KB
/
sentinel_2_ndwi.sh
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
#! /usr/bin/bash
# $1 - A unique token identifying the product. GranuleId or ProductId should be fine.
export GDAL_CACHEMAX=128
S2_SEARCH_TOKEN=$1
S2_SCRIPT_DIR=$(dirname $0)
#TODO: Check for the index file and download if necessary.
#https://storage.googleapis.com/gcp-public-data-sentinel-2/index.csv.gz
S2_INDEX_LINE=$(gzip -d -c $S2_SCRIPT_DIR/index.csv.gz | grep -P -m1 $S2_SEARCH_TOKEN)
#echo 'Line='$S2_INDEX_LINE
echo $S2_INDEX_LINE
#Extract the WRS Path and Row from the scene name.
S2_GRANULE_ID=$(echo $S2_INDEX_LINE | grep -oP '^[^\,]+(?=\,)')
echo 'Granule='$S2_GRANULE_ID
S2_PRODUCT_ID=$(echo $S2_INDEX_LINE | grep -oP '^([^\,]*\,){1}\K[^\,]+(?=[\,]|$)')
echo 'Product='$S2_PRODUCT_ID
S2_MGRS_TILE=$(echo $S2_INDEX_LINE | grep -oP '^([^\,]*\,){3}\K[^\,]+(?=[\,]|$)')
echo 'Product='$S2_MGRS_TILE
S2_BASE_URL=$(echo $S2_INDEX_LINE | grep -oP '^([^\,]*\,){13}\K[^\,]+(?=[\,]|$)')
echo 'BaseUrl='$S2_BASE_URL
S2_URL_2=$(echo $S2_BASE_URL | grep -oP 'gs://\K.+')
echo 'Url2='$S2_URL_2
S2_PUBLIC_URL='/vsicurl/https://storage.googleapis.com/'$S2_URL_2'/GRANULE/'$S2_GRANULE_ID'/IMG_DATA'
echo 'PublicUrl='$S2_PUBLIC_URL
S2_IMAGE_BASE_OLD=$(echo $S2_GRANULE_ID | grep -oP '.*_(?=[[:alnum:]]{3}\.[[:digit:]]{2})')
echo 'ImageBaseOld='$S2_IMAGE_BASE
S2_SENSING_START_TIME=$(echo $S2_PRODUCT_ID | grep -oP 'MSIL1C_\K[[:alnum:]]+(?=_)')
S2_IMAGE_BASE_NEW='T'$S2_MGRS_TILE'_'$S2_SENSING_START_TIME'_'
echo 'ImageBaseNew='$S2_IMAGE_BASE_NEW
S2_IMAGE_BASE=$S2_IMAGE_BASE_OLD
if ["$S2_IMAGE_BASE" = ""]
then
S2_IMAGE_BASE=$S2_IMAGE_BASE_NEW
fi
echo 'ImageBase='$S2_IMAGE_BASE
S2_OUT_DIR="./"$S2_GRANULE_ID #Directory for the temporary files.
#TODO: Delete the output directory if it exists? GDAL might try to re-use stale aux.xml files.
mkdir $S2_OUT_DIR
S2_BAND1=$S2_PUBLIC_URL/$S2_IMAGE_BASE'B02.jp2'
S2_BAND2=$S2_PUBLIC_URL/$S2_IMAGE_BASE'B08.jp2'
echo "Band1="$S2_BAND1
echo "Band2"=$S2_BAND2
S2_BAND1_INTERMEDIATE=$S2_OUT_DIR"/"band1.tif
S2_BAND2_INTERMEDIATE=$S2_OUT_DIR"/"band2.tif
echo "Downloading bands..."
gdal_translate -ot Float64 $S2_BAND1 $S2_BAND1_INTERMEDIATE &
gdal_translate -ot Float64 $S2_BAND2 $S2_BAND2_INTERMEDIATE &
wait
echo "Download done."
###############
S2_NDWI_FILE=$S2_OUT_DIR/$S2_GRANULE_ID"_ndwi.tif"
gdal_calc.py -A $S2_BAND1_INTERMEDIATE -B $S2_BAND2_INTERMEDIATE --outfile=$S2_NDWI_FILE --type=Float64 --overwrite --calc='logical_and(A!=0,B!=0)*10000.0*(A-B)/(A+B)'
echo 'Calculating OTSU threshold...'
S2_THRESHOLD=$(python $S2_SCRIPT_DIR/otsu.py $S2_NDWI_FILE | grep -oP 'THRESHOLD:\K\-?[0-9\.]+')
echo 'Threshold:='$S2_THRESHOLD
S2_DETECTION_FILE=$S2_OUT_DIR/'detection.shp'
echo 'Extracting contours...'
gdal_contour -fl $S2_THRESHOLD $S2_NDWI_FILE $S2_DETECTION_FILE
echo 'Contours done'
#Remove temp directory?