Revision b765ab2b
Added by Benoit Parmentier about 9 years ago
climate/research/oregon/interpolation/global_run_scalingup_mosaicing_function.R | ||
---|---|---|
4 | 4 |
#Different options to explore mosaicing are tested. This script only contains functions. |
5 | 5 |
#AUTHOR: Benoit Parmentier |
6 | 6 |
#CREATED ON: 04/14/2015 |
7 |
#MODIFIED ON: 11/12/2015
|
|
7 |
#MODIFIED ON: 12/02/2015
|
|
8 | 8 |
#Version: 1 |
9 | 9 |
#PROJECT: Environmental Layers project |
10 | 10 |
#COMMENTS: first commit of function script to test mosaicing using 1500x4500km and other tiles |
... | ... | |
99 | 99 |
#metric_name: accuracy metric selected to be mapped, RMSE, MAE etc. |
100 | 100 |
#pred_mod_name: model selected, such as mod1, mod_kr etc. |
101 | 101 |
#y_var_name: variable being modeled e.g."dailyTmax", dailyTmin, precip |
102 |
#interpolation_method <- list_param$interpolation_method #c("gam_CAI") #PARAM3
|
|
102 |
#interpolation_method: names of the interpolation/modeling method
|
|
103 | 103 |
#date_processed: day being processed , e.g. 19920101 |
104 |
#num_cores : number of cores used in the parallelization |
|
104 | 105 |
#NA_flag_val: value used as flag in the raster |
105 | 106 |
#file_format: e.g. tif., .rst |
106 | 107 |
#out_dir_str: output directory |
107 |
#out_suffix_str: <- list_param$out_suffix
|
|
108 |
#out_suffix_str: output suffix
|
|
108 | 109 |
#Outputs: |
109 | 110 |
#raster list of weights and product of wegihts and inuts |
110 | 111 |
#TODO: |
... | ... | |
113 | 114 |
# |
114 | 115 |
############ |
115 | 116 |
|
117 |
#Functions |
|
118 |
create_raster_df_centroids_fun <- function(j,list_param){ |
|
119 |
#This function generates raster images from metrics values from a data.frame. |
|
120 |
#The raster layer is assigned a unique value from the pixel at every location. |
|
121 |
#Input Parameters: |
|
122 |
# #lf: list of raster files |
|
123 |
#df_centroids: data.frame table #fitting or validation table with all days |
|
124 |
#metric_name: accuracy metric selected to be mapped, RMSE, MAE etc. |
|
125 |
#date_processed: day being processed , e.g. 19920101 |
|
126 |
#num_cores : number of cores used in the parallelization |
|
127 |
#NA_flag_val: value used as flag in the raster |
|
128 |
#file_format: e.g. tif., .rst |
|
129 |
#out_dir_str: output directory |
|
130 |
#out_suffix_str: output suffix |
|
131 |
#Outputs: |
|
132 |
|
|
133 |
#### PARSE arguments |
|
134 |
|
|
135 |
df_centroids <- list_param$df_centroids |
|
136 |
metric_name <- list_param$metric_name |
|
137 |
#interpolation_method <- list_param$interpolation_method #c("gam_CAI") #PARAM3 |
|
138 |
#date_processed <- list_param$metric_name |
|
139 |
#num_cores <- list_param$num_cores |
|
140 |
NA_flag_val <- list_param$NA_flag_val |
|
141 |
file_format <- list_param$file_format |
|
142 |
out_dir_str <- list_param$out_dir |
|
143 |
out_suffix_str <- list_param$out_suffix |
|
144 |
|
|
145 |
####### START SCRIPT ##### |
|
146 |
|
|
147 |
inFilename <- df_centroids$files[j] |
|
148 |
r1 <- raster(inFilename) |
|
149 |
r1[] <- df_centroids[[metric_name]][j] #improve this |
|
150 |
#set1f <- function(x){rep(NA, x)} |
|
151 |
#r_init <- init(r_in, fun=set1f) |
|
152 |
lf_tmp <- gsub(file_format,"",lf) |
|
153 |
|
|
154 |
extension_str <- extension(inFilename) |
|
155 |
raster_name_tmp <- gsub(extension_str,"",basename(inFilename)) |
|
156 |
outFilename <- file.path(out_dir,paste(raster_name_tmp,"_",metric_name,"_",out_suffix,file_format,sep="")) #for use in function later... |
|
157 |
|
|
158 |
writeRaster(r1, NAflag=NA_flag_val,filename=outFilename,overwrite=TRUE) |
|
159 |
#list_raster_name[[j]] <- outFilename |
|
160 |
return(outFilename) |
|
161 |
} |
|
162 |
|
|
163 |
####### PARSE ARGUMENTS |
|
164 |
|
|
116 | 165 |
lf <- list_param$lf[[i]] #list of files to mosaic |
117 | 166 |
tb <- list_param$tb #fitting or validation table with all days |
118 | 167 |
metric_name <- list_param$metric_name #RMSE, MAE etc. |
... | ... | |
120 | 169 |
y_var_name <- list_param$y_var_name #"dailyTmax" #PARAM2 |
121 | 170 |
interpolation_method <- list_param$interpolation_method #c("gam_CAI") #PARAM3 |
122 | 171 |
date_processed <- list_param$days_to_process[i] |
172 |
num_cores <- list_param$num_cores #number of cores used |
|
123 | 173 |
NA_flag_val <- list_param$NA_flag_val |
124 | 174 |
#NAflag,file_format,out_suffix etc... |
125 | 175 |
file_format <- list_param$file_format |
... | ... | |
128 | 178 |
|
129 | 179 |
####### START SCRIPT ##### |
130 | 180 |
|
131 |
#r_in <- raster(lf[i]) #input image |
|
132 |
|
|
133 |
#date_processed <- day_to_mosaic[i] |
|
134 |
#lf_to_mosaic <-list.files(path=file.path(in_dir_tiles), |
|
135 |
# pattern=paste(".*.",date_processed,".*.tif$",sep=""),full.names=T) #choosing date 2...20100901 |
|
136 |
|
|
137 | 181 |
lf_tmp <- gsub(file_format,"",lf) |
138 | 182 |
tx<-strsplit(as.character(lf_tmp),"_") |
139 | 183 |
#deal with the fact that we have number "1" attached to the out_suffix (centroids of tiles) |
... | ... | |
156 | 200 |
tb_date$tile_coord <- as.character(tb_date$tile_coord) |
157 | 201 |
df_centroids <- merge(df_centroids,tb_date,by="tile_coord") |
158 | 202 |
|
159 |
#r1 <- raster(lf[i]) |
|
160 |
|
|
161 |
#function(j,df_centroids,metric_name,date_processed,interpolation,) |
|
162 |
#loop over files, make this a function later, works for now |
|
163 | 203 |
#use mclapply |
164 |
list_raster_name <- vector("list",length=length(lf)) |
|
165 |
|
|
166 |
for(j in 1:length(lf)){ |
|
167 |
|
|
168 |
inFilename <- df_centroids$files[j] |
|
169 |
r1 <- raster(inFilename) |
|
170 |
r1[] <- df_centroids[[metric_name]][j] #improve this |
|
171 |
#set1f <- function(x){rep(NA, x)} |
|
172 |
#r_init <- init(r_in, fun=set1f) |
|
173 |
lf_tmp <- gsub(file_format,"",lf) |
|
174 |
|
|
175 |
extension_str <- extension(inFilename) |
|
176 |
raster_name_tmp <- gsub(extension_str,"",basename(inFilename)) |
|
177 |
outFilename <- file.path(out_dir,paste(raster_name_tmp,"_",metric_name,"_",out_suffix,file_format,sep="")) #for use in function later... |
|
178 |
|
|
179 |
#raster_name <- file.path(out_dir_str,paste(raster_name_tmp,"_",out_suffix,file_format,sep=""))#output file |
|
204 |
#list_raster_name <- vector("list",length=length(lf)) |
|
205 |
list_param_raster_df_centroids <- list(df_centroids,metric_name,NA_flag_val,file_format,out_dir,out_suffix) |
|
206 |
names(list_param_raster_df_centroids) <- c("df_centroids","metric_name","NA_flag_val","file_format","out_dir","out_suffix") |
|
180 | 207 |
|
181 |
#raster_name_tmp <- paste("r_",metric_name,"_",interpolation_method,"_",date_processed,"_",out_suffix_str,sep="") |
|
182 |
#raster_name <- file.path(out_dir_str,raster_name_tmp) |
|
183 |
writeRaster(r1, NAflag=NA_flag_val,filename=outFilename,overwrite=TRUE) |
|
184 |
list_raster_name[[j]] <- outFilename |
|
185 |
} |
|
208 |
#undebug(create_raster_df_centroids_fun) |
|
209 |
#test_lf <- lapply(1,FUN=create_raster_df_centroids_fun,list_param=list_param_raster_df_centroids) |
|
186 | 210 |
|
211 |
list_raster_name <- mclapply(1:length(lf),FUN=create_raster_df_centroids_fun,list_param=list_param_raster_df_centroids,mc.preschedule=FALSE,mc.cores = num_cores) |
|
212 |
|
|
187 | 213 |
raster_created_obj <- list(list_raster_name,df_centroids) |
188 | 214 |
names(raster_created_obj) <- c("list_raster_name","df_centroids") |
189 | 215 |
return(raster_created_obj) |
190 |
|
|
191 | 216 |
} |
192 | 217 |
|
193 | 218 |
#### end of function |
... | ... | |
381 | 406 |
rast_list<-file.path(out_path,raster_name) |
382 | 407 |
|
383 | 408 |
## The Raster and rgdal packages write temporary files on the disk when memory is an issue. This can potential build up |
384 |
## in long loops and can fill up hard drives resulting in errors. The following sections removes these files |
|
385 |
## as they are created in the loop. This code section can be transformed into a "clean-up function later on |
|
386 |
## Start remove |
|
387 |
#tempfiles<-list.files(tempdir(),full.names=T) #GDAL transient files are not removed |
|
388 |
#files_to_remove<-grep(out_suffix,tempfiles,value=T) #list files to remove |
|
389 |
#if(length(files_to_remove)>0){ |
|
390 |
# file.remove(files_to_remove) |
|
391 |
#} |
|
392 |
#now remove temp files from raster package located in rasterTmpDir |
|
409 |
|
|
393 | 410 |
removeTmpFiles(h=0) #did not work if h is not set to 0 |
394 | 411 |
## end of remove section |
395 | 412 |
|
... | ... | |
771 | 788 |
paste("-A ", r_prod_sum_raster_name,sep=""), |
772 | 789 |
paste("-B ", r_weights_sum_raster_name,sep=""), |
773 | 790 |
paste("--outfile=",r_m_weighted_mean_raster_name,sep=""), |
791 |
paste("NoDataValue=",NA_flag_val,sep=""), |
|
774 | 792 |
"--calc='A/B'","--overwrite",sep=" ") #division by zero is problematic... |
775 | 793 |
system(cmd_str) |
776 |
|
|
794 |
cmd_mosaic_logfile <- file.path(out_dir,paste("cmd_mosaic_",out_suffix,".txt",sep="")) |
|
795 |
writeLines(cmd_str1,con=cmd_mosaic_logfile) #weights files to mosaic |
|
796 |
#writeLines(cmd_str2,con=file.path(out_dir,paste("cmd_mosaic_",out_suffix,".txt",sep=""))) #weights files to mosaic |
|
797 |
cat(cmd_str2, file=cmd_mosaic_logfile, append=TRUE, sep = "\n") |
|
798 |
|
|
777 | 799 |
#cmd_str <- "/nobackupp6/aguzman4/climateLayers/sharedModules/bin/gdal_calc.py -A r_prod_weights_sum_m_use_edge_weights_weighted_mean_gam_CAI_dailyTmax_19920101_reg4_run10_1500x4500_global_analyses_pred_1992_10052015.tif -B r_weights_sum_m_use_edge_weights_weighted_mean_gam_CAI_dailyTmax_19920101_reg4_run10_1500x4500_global_analyses_pred_1992_10052015.tif --outfile='test2.tif' --calc='A/B' --overwrite" |
778 | 800 |
|
779 | 801 |
#writeRaster(r_m_weighted_mean, NAflag=NA_flag_val,filename=raster_name,overwrite=TRUE) |
... | ... | |
993 | 1015 |
} |
994 | 1016 |
|
995 | 1017 |
#Use this instead of daily mosaic plot function |
1018 |
#Add NAvalue flag!! |
|
996 | 1019 |
plot_screen_raster_val<-function(i,list_param){ |
997 | 1020 |
##USAGE### |
998 | 1021 |
#Screen raster list and produced plot as png. |
Also available in: Unified diff
mosaicing function adding function to produce accuracy metric surface from tile RMSE