[GRASS-SVN] r67582 - grass/branches/releasebranch_7_0/temporal/t.rast.aggregate.ds

svn_grass at osgeo.org svn_grass at osgeo.org
Thu Jan 14 15:20:43 PST 2016


Author: neteler
Date: 2016-01-14 15:20:43 -0800 (Thu, 14 Jan 2016)
New Revision: 67582

Modified:
   grass/branches/releasebranch_7_0/temporal/t.rast.aggregate.ds/t.rast.aggregate.ds.html
Log:
t.rast.aggregate.ds manual: example for MODIS 8-day aggregation (trunk, r67581; contributed by Vero Andreo)

Modified: grass/branches/releasebranch_7_0/temporal/t.rast.aggregate.ds/t.rast.aggregate.ds.html
===================================================================
--- grass/branches/releasebranch_7_0/temporal/t.rast.aggregate.ds/t.rast.aggregate.ds.html	2016-01-14 23:19:40 UTC (rev 67581)
+++ grass/branches/releasebranch_7_0/temporal/t.rast.aggregate.ds/t.rast.aggregate.ds.html	2016-01-14 23:20:43 UTC (rev 67582)
@@ -12,8 +12,10 @@
 It defines the temporal relations hips between intervals of the sampling 
 dataset and the input space time raster dataset.
 
-<h2>EXAMPLE</h2>
+<h2>EXAMPLES</h2>
 
+<h3>Precipitation aggregation</h3>
+
 In this example we create 7 raster maps that will be registered in a 
 single space time raster dataset named <em>precipitation_daily</em> 
 using a daily temporal granularity. The names of the raster maps are 
@@ -38,7 +40,7 @@
 MAPS="map_1 map_2 map_3 map_4 map_5 map_6 map_7"
 
 for map in ${MAPS} ; do
-    r.mapcalc --o expression="${map} = 1" 
+    r.mapcalc expression="${map} = 1" 
     echo ${map} >> map_list.txt 
 done
 
@@ -240,6 +242,114 @@
  +----------------------------------------------------------------------------+
 </pre></div>
 
+<h3>MODIS satellite sensor daily data aggregation to 8 days</h3>
+
+In this example the aggregation from daily data to eight days is shown.
+This "eight-day week" is used in some MODIS satellite sensor products.
+
+<div class="code"><pre>
+# NOTE: the example is written in shell language
+
+# create maps every 8 days as seed maps
+for year in `seq 2000 2001` ; do
+   for doy in `seq -w 1 8 365` ; do 
+      r.mapcalc -s expression="8day_${year}_${doy} = rand(0.0,40.0)"
+   done
+done
+
+# From de name of each map, we take year and doy, and convert it
+# to a YYYY-MM-DD date for start and end, and create a file with
+# mapnames, start date and end date
+
+g.list type=raster pattern=8day_20??_* > names_list
+
+for NAME in `cat names_list` ; do
+   
+   # Parse
+   YEAR=`echo $NAME | cut -d'_' -f2`
+   DOY=`echo $NAME | cut -d'_' -f3`
+   
+   # convert YYYY_DOY to YYYY-MM-DD
+   DOY=`echo "$DOY" | sed 's/^0*//'`
+   doy_end=0
+
+   if [ $DOY -le "353" ] ; then
+      doy_end=$(( $DOY + 8 ))
+   elif [ $DOY -eq "361" ] ; then 
+      if [ $[$YEAR % 4] -eq 0 ] && [ $[$YEAR % 100] -ne 0 ] || [ $[$YEAR % 400] -eq 0 ] ; then
+         doy_end=$(( $DOY + 6 ))
+      else
+	     doy_end=$(( $DOY + 5 ))
+      fi
+   fi
+
+   DATE_START=`date -d "${YEAR}-01-01 +$(( ${DOY} - 1 ))days" +%Y-%m-%d`
+   DATE_END=`date -d "${YEAR}-01-01 +$(( ${doy_end} -1 ))days" +%Y-%m-%d`
+   
+   # text file with mapnames, start date and end date
+   echo "$NAME|$DATE_START|$DATE_END" >> list_map_start_end_time.txt
+         
+done
+
+# check the list created. 
+cat list_map_start_end_time.txt
+8day_2000_001|2000-01-01|2000-01-09
+8day_2000_009|2000-01-09|2000-01-17
+...
+8day_2000_353|2000-12-18|2000-12-26
+8day_2000_361|2000-12-26|2001-01-01
+8day_2001_001|2001-01-01|2001-01-09
+8day_2001_009|2001-01-09|2001-01-17
+...
+8day_2001_345|2001-12-11|2001-12-19
+8day_2001_353|2001-12-19|2001-12-27
+8day_2001_361|2001-12-27|2002-01-01
+
+# all maps except for the last map in each year represent 8-days 
+# intervals. But the aggregation starts all over again every 
+# January 1st.
+
+# create 8-day MODIS-like strds
+t.create type=strds temporaltype=absolute \
+   output=8day_ts title="8 day time series" \
+   description="STRDS with MODIS like 8 day aggregation"
+ 
+# register maps
+t.register type=raster input=8day_ts \
+   file=list_map_start_end_time.txt
+
+# check
+t.info input=8day_ts
+t.rast.list input=8day_ts
+
+# finally, copy the aggregation to a daily time series
+t.rast.aggregate.ds -s input=daily_ts sample=8day_ts \
+   output=8day_agg basename=8day_agg \
+   method=average sampling=contains
+
+# add metadata
+t.support input=8day_agg \
+   title="8 day aggregated ts" \
+   description="8 day MODIS-like aggregated dataset"
+
+# check map list in newly created aggregated strds
+t.rast.list input=8day_agg
+name|mapset|start_time|end_time
+8day_agg_2000_01_01|modis|2000-01-01 00:00:00|2000-01-09 00:00:00
+8day_agg_2000_01_09|modis|2000-01-09 00:00:00|2000-01-17 00:00:00
+8day_agg_2000_01_17|modis|2000-01-17 00:00:00|2000-01-25 00:00:00
+...
+8day_agg_2000_12_18|modis|2000-12-18 00:00:00|2000-12-26 00:00:00
+8day_agg_2000_12_26|modis|2000-12-26 00:00:00|2001-01-01 00:00:00
+8day_agg_2001_01_01|modis|2001-01-01 00:00:00|2001-01-09 00:00:00
+...
+8day_agg_2001_12_11|modis|2001-12-11 00:00:00|2001-12-19 00:00:00
+8day_agg_2001_12_19|modis|2001-12-19 00:00:00|2001-12-27 00:00:00
+8day_agg_2001_12_27|modis|2001-12-27 00:00:00|2002-01-01 00:00:00
+</pre></div>
+
+
+
 <h2>SEE ALSO</h2>
 
 <em>



More information about the grass-commit mailing list