Project

General

Profile

« Previous | Next » 

Revision 5631506b

Added by Benoit Parmentier about 9 years ago

raster prediction stage modification of gam fusion script to take into acccount the existence of climatology layers

View differences:

climate/research/oregon/interpolation/GAM_fusion_analysis_raster_prediction_multisampling.R
12 12
   # gam_daily, kriging_daily,gwr_daily,gam_CAI,gam_fusion,kriging_fusion,gwr_fusion and other options added.
13 13
#For multiple time scale methods, the interpolation is done first at the monthly time scale then delta surfaces are added.
14 14
#AUTHOR: Benoit Parmentier                                                                        
15
#DATE: 11/03/2013                                                                                 
15
#CREATED ON: 04/01/2013  
16
#MODIFIED ON: 12/21/2015  
16 17
#PROJECT: NCEAS INPLANT: Environment and Organisms --TASK#568--     
17 18
#
18 19
# TO DO:
......
30 31
  #5)infile_covariates: raster covariate brick, tif file
31 32
  #6)covar_names: covar_names #remove at a later stage...
32 33
  #7)var: variable being interpolated-TMIN or TMAX
33
  #8)out_prefix
34
  #8)out_prefix: output suffix added to files
34 35
  #9)CRS_locs_WGS84
35 36
  #10)screen_data_training
36 37
  #
......
47 48
  #19)prop_minmax_month
48 49
  #20)dates_selected
49 50
  #
50
  #6 additional parameters for monthly climatology and more
51
  #13 additional parameters for monthly climatology and more
51 52
  #21)list_models: model formulas in character vector
52 53
  #22)lst_avg: LST climatology name in the brick of covariate--change later
53
  #23)n_path
54
  #24)out_path
54
  #23)in_path
55
  #24)out_path: path to directory containing daily data
56
  #25)out_path_clim: path to the directory containing climatology data
55 57
  #25)script_path: path to script
56 58
  #26)interpolation_method: c("gam_fusion","gam_CAI") #other otpions to be added later
57 59
  #27) use_clim_image
58 60
  #28) join_daily
59 61
  #29)list_models2: models' formulas as string vector for daily devation
60 62
  #30)interp_method2: intepolation method for daily devation step
63
  #31)num_cores: How many cores to use
64
  #32)max_mem: Max memory to use for predict step
65
  #33)reg_outline: shapefile with region outline used to create nc output file
61 66
  
62 67
  ###Loading R library and packages     
63 68
  
......
118 123
  interp_method2 <- list_param_raster_prediction$interp_method2
119 124
  
120 125
  lst_avg<-list_param_raster_prediction$lst_avg
121
  out_path<-list_param_raster_prediction$out_path
126
  out_path<-list_param_raster_prediction$out_path #daily prediction path
127
  out_path_clim <- list_param_raster_prediction$out_path_clim #clim prediction path
122 128
  script_path<-list_param_raster_prediction$script_path
123 129
  interpolation_method<-list_param_raster_prediction$interpolation_method
124 130
  screen_data_training <-list_param_raster_prediction$screen_data_training
125 131
  
126 132
  use_clim_image <- list_param_raster_prediction$use_clim_image # use predicted image as a base...rather than average Tmin at the station for delta
127 133
  join_daily <- list_param_raster_prediction$join_daily # join monthly and daily station before calucating delta
128
  
129
  setwd(out_path)
134

  
135
  #cores and memory usage options
136
  num_cores <- list_param_raster_prediction$num_cores
137
  max_mem<- as.numeric(list_param_raster_prediction$max_mem)
138
 
139
  #Get the region outline
140
  reg_outline<-list_param_raster_prediction$reg_outline
141

  
142
  #rasterOptions(maxmemory=max_mem,timer=TRUE,chunksize=1e+08)
143
  rasterOptions(timer=TRUE,chunksize=5e+05)  
144
  #rasterOptions(timer=TRUE)
145

  
146
  setwd(out_path) #note that this is now path to daily dir (with the name of the year...)
130 147
  
131 148
  ###################### START OF THE SCRIPT ########################
132 149
   
......
156 173
  cat("Starting script process time:",file=log_fname,sep="\n",append=TRUE)
157 174
  cat(as.character(time1),file=log_fname,sep="\n",append=TRUE)    
158 175
  
176
  ############### Make nc file from outline ############
177
  
178

  
159 179
  ############### READING INPUTS: DAILY STATION DATA AND OTHER DATASETS  #################
180
  #Takes too long to read shapefiles. Let's try using saveRDS(object,*.rds) and readRDS()
181
  infile_daily_rds <-sub(".shp",".rds",infile_daily)
182

  
183
  if (file.exists(infile_daily_rds) == TRUE){
184
     ghcn<-readRDS(infile_daily_rds)
185
     CRS_interp<-proj4string(ghcn)
186
  }else{
187
    ghcn<-readOGR(dsn=dirname(infile_daily),layer=sub(".shp","",basename(infile_daily)))
188
    CRS_interp<-proj4string(ghcn)                       #Storing projection information (ellipsoid, datum,etc.)
189
    saveRDS(ghcn,infile_daily_rds)
190
  }
191

  
192
  infile_locs_rds<-sub(".shp",".rds",infile_locs)
193
  if (file.exists(infile_locs_rds) == TRUE){
194
    stat_loc<-readRDS(infile_locs_rds) 
195
  }else{
196
    stat_loc<-readOGR(dsn=dirname(infile_locs),layer=sub(".shp","",basename(infile_locs)))
197
    saveRDS(stat_loc,infile_locs_rds)
198
  }
160 199
  
161
  ghcn<-readOGR(dsn=dirname(infile_daily),layer=sub(".shp","",basename(infile_daily)))
162
  CRS_interp<-proj4string(ghcn)                       #Storing projection information (ellipsoid, datum,etc.)
163
  stat_loc<-readOGR(dsn=dirname(infile_locs),layer=sub(".shp","",basename(infile_locs)))
164
  #dates2 <-readLines(file.path(in_path,dates_selected)) #dates to be predicted, now read directly from the file
200
  #dates2 <-readLines(file.path(in_path,dates_selected)) #dates to be predicted, now read directly from the file  
165 201
  
166 202
  #Should clean this up, reduce the number of if
167 203
  if (dates_selected==""){
......
180 216
  names(s_raster)<-covar_names               #Assigning names to the raster layers: making sure it is included in the extraction
181 217
    
182 218
  #Reading monthly data
183
  dst<-readOGR(dsn=dirname(infile_monthly),layer=sub(".shp","",basename(infile_monthly)))
184
    
219
  infile_monthly_rds<-sub(".shp",".rds",infile_monthly)
220
  if (file.exists(infile_monthly_rds) == TRUE) {
221
     dst<-readRDS(infile_monthly_rds)
222
  }else{
223
   dst<-readOGR(dsn=dirname(infile_monthly),layer=sub(".shp","",basename(infile_monthly)))
224
   saveRDS(dst,infile_monthly_rds) 
225
  }
226

  
185 227
  #construct date based on input end_year !!!
186 228
  day_tmp <- rep("15",length=nrow(dst))
187 229
  year_tmp <- rep(as.character(end_year),length=nrow(dst))
......
210 252
  
211 253
  sampling_month_obj <- sampling_training_testing(list_param_sampling)
212 254
  
255
  #save(sampling_month_obj,file="/nobackupp4/aguzman4/climateLayers/output10Deg/reg1/35.0_-115.0/test.RData")
256

  
213 257
  ########### PREDICT FOR MONTHLY SCALE  ##################
214
  
215 258
  #First predict at the monthly time scale: climatology
216 259
  cat("Predictions at monthly scale:",file=log_fname,sep="\n", append=TRUE)
217 260
  cat(paste("Local Date and Time: ",as.character(Sys.time()),sep=""),
218 261
      file=log_fname,sep="\n")
219 262
  t1<-proc.time()
220 263
  j=12
264
  
265
  ###Changes 12/21/2015
221 266
  #browser() #Missing out_path for gam_fusion list param!!!
222 267
  #if (interpolation_method=="gam_fusion"){
223 268
  if (interpolation_method %in% c("gam_fusion","kriging_fusion","gwr_fusion")){
224
    list_param_runClim_KGFusion<-list(j,s_raster,covar_names,lst_avg,list_models,dst,sampling_month_obj,var,y_var_name, out_prefix,out_path)
225
    names(list_param_runClim_KGFusion)<-c("list_index","covar_rast","covar_names","lst_avg","list_models","dst","sampling_month_obj","var","y_var_name","out_prefix","out_path")
226
    #debug(runClim_KGFusion)
227
    #test<-runClim_KGFusion(1,list_param=list_param_runClim_KGFusion)
228
    clim_method_mod_obj<-mclapply(1:length(sampling_month_obj$ghcn_data), list_param=list_param_runClim_KGFusion, runClim_KGFusion,mc.preschedule=FALSE,mc.cores = 11) #This is the end bracket from mclapply(...) statement
229
    save(clim_method_mod_obj,file= file.path(out_path,paste(interpolation_method,"_mod_",y_var_name,out_prefix,".RData",sep="")))
230
    #Use function to extract list
269
    clim_method_mod_obj_file <- file.path(out_path_clim,paste(interpolation_method,"_mod_",y_var_name,out_prefix,".RData",sep=""))
270
    if(!file.exists(clim_method_mod_obj_file)){
271
      list_param_runClim_KGFusion<-list(j,s_raster,covar_names,lst_avg,list_models,dst,sampling_month_obj,var,y_var_name, out_prefix,out_path)
272
      names(list_param_runClim_KGFusion)<-c("list_index","covar_rast","covar_names","lst_avg","list_models","dst","sampling_month_obj","var","y_var_name","out_prefix","out_path")
273
      #debug(runClim_KGFusion)
274
      #test<-runClim_KGFusion(1,list_param=list_param_runClim_KGFusion)
275
      clim_method_mod_obj<-mclapply(1:length(sampling_month_obj$ghcn_data), list_param=list_param_runClim_KGFusion, runClim_KGFusion,mc.preschedule=FALSE,mc.cores = num_cores) #This is the end bracket from mclapply(...) statement
276
    
277
      save(clim_method_mod_obj,file= file.path(out_path,paste(interpolation_method,"_mod_",y_var_name,out_prefix,".RData",sep="")))
278
      #Use function to extract list
279
    }else{
280
      clim_method_mod_obj <- load_obj(clim_method_mod_obj_file) #load the existing file
281
    }
282
    #Get relevant data
231 283
    list_tmp<-vector("list",length(clim_method_mod_obj))
284

  
232 285
    for (i in 1:length(clim_method_mod_obj)){
233 286
      tmp<-clim_method_mod_obj[[i]]$clim
234 287
      list_tmp[[i]]<-tmp
235 288
    }
289
    
236 290
    clim_yearlist<-list_tmp
237 291
  }
238 292
  
239 293
  if (interpolation_method %in% c("gam_CAI","kriging_CAI", "gwr_CAI")){
240
    list_param_runClim_KGCAI<-list(j,s_raster,covar_names,lst_avg,list_models,dst,sampling_month_obj,var,y_var_name, out_prefix,out_path)
241
    names(list_param_runClim_KGCAI)<-c("list_index","covar_rast","covar_names","lst_avg","list_models","dst","sampling_month_obj","var","y_var_name","out_prefix","out_path")
242
    clim_method_mod_obj<-mclapply(1:length(sampling_month_obj$ghcn_data), list_param=list_param_runClim_KGCAI, runClim_KGCAI,mc.preschedule=FALSE,mc.cores = 11) #This is the end bracket from mclapply(...) statement
243
    #test<-runClim_KGCAI(1,list_param=list_param_runClim_KGCAI)
244
    save(clim_method_mod_obj,file= file.path(out_path,paste(interpolation_method,"_mod_",y_var_name,out_prefix,".RData",sep="")))
294
    clim_method_mod_obj_file <- file.path(out_path_clim,paste(interpolation_method,"_mod_",y_var_name,out_prefix,".RData",sep=""))
295
    if(!file.exists(clim_method_mod_obj_file)){
296
      num_cores2 = as.integer(num_cores) + 2
297
      list_param_runClim_KGCAI<-list(j,s_raster,covar_names,lst_avg,list_models,dst,sampling_month_obj,var,y_var_name, out_prefix,out_path)
298
      names(list_param_runClim_KGCAI)<-c("list_index","covar_rast","covar_names","lst_avg","list_models","dst","sampling_month_obj","var","y_var_name","out_prefix","out_path")
299
      clim_method_mod_obj<-mclapply(1:length(sampling_month_obj$ghcn_data), list_param=list_param_runClim_KGCAI, runClim_KGCAI,mc.preschedule=FALSE,mc.cores = num_cores2) #This is the end bracket from mclapply(...) statement
300
      #test<-runClim_KGCAI(1,list_param=list_param_runClim_KGCAI)
301

  
302
      save(clim_method_mod_obj,file= file.path(out_path,paste(interpolation_method,"_mod_",y_var_name,out_prefix,".RData",sep="")))
303
    }else{
304
      clim_method_mod_obj <- load_obj(clim_method_mod_obj_file) #load the existing file
305
    }
306
    #Now get relevant data
245 307
    list_tmp<-vector("list",length(clim_method_mod_obj))
246 308
    for (i in 1:length(clim_method_mod_obj)){
247 309
      tmp<-clim_method_mod_obj[[i]]$clim
......
251 313
  }
252 314
  t2<-proc.time()-t1
253 315
  cat(as.character(t2),file=log_fname,sep="\n", append=TRUE)
316
  
317
  #Getting rid of raster temp files
318
  removeTmpFiles(h=0)
319
  
254 320

  
255 321
  ################## PREDICT AT DAILY TIME SCALE #################
256 322
  #Predict at daily time scale from single time scale or multiple time scale methods: 2 methods availabe now
257
  
258 323
  #put together list of clim models per month...
259 324
  #rast_clim_yearlist<-list_tmp
260 325
  
261 326
  #Second predict at the daily time scale: delta
262 327
  
263 328
  #method_mod_obj<-mclapply(1:1, runGAMFusion,mc.preschedule=FALSE,mc.cores = 1) #This is the end bracket from mclapply(...) statement
329

  
330
  #Set raster options for daily steps
331
  #rasterOptions(timer=TRUE,chunksize=1e+05)
332
  #This is for high station count areas
333
  rasterOptions(timer=TRUE,chunksize=1e+04)
334
  #rasterOptions(timer=TRUE,chunksize=1e+03)
335

  
264 336
  cat("Predictions at the daily scale:",file=log_fname,sep="\n", append=TRUE)
265 337
  t1<-proc.time()
266 338
  cat(paste("Local Date and Time: ",as.character(Sys.time()),sep=""),
......
289 361
    #test <- run_prediction_daily_deviation(1,list_param=list_param_run_prediction_daily_deviation) #This is the end bracket from mclapply(...) statement
290 362
    #test <- mclapply(1:9,list_param=list_param_run_prediction_daily_deviation,run_prediction_daily_deviation,mc.preschedule=FALSE,mc.cores = 9) #This is the end bracket from mclapply(...) statement
291 363
    
292
    method_mod_obj<-mclapply(1:nrow(daily_dev_sampling_dat),list_param=list_param_run_prediction_daily_deviation,run_prediction_daily_deviation,mc.preschedule=FALSE,mc.cores = 9) #This is the end bracket from mclapply(...) statement
364
    method_mod_obj<-mclapply(1:nrow(daily_dev_sampling_dat),list_param=list_param_run_prediction_daily_deviation,run_prediction_daily_deviation,mc.preschedule=FALSE,mc.cores = num_cores) #This is the end bracket from mclapply(...) statement
293 365
    save(method_mod_obj,file= file.path(out_path,paste("method_mod_obj_",interpolation_method,"_",y_var_name,out_prefix,".RData",sep="")))
294 366
    
295 367
  }
296 368
  
369
  removeTmpFiles(h=0)
370

  
297 371
  #TODO : Same call for all functions!!! Replace by one "if" for all daily single time scale methods...
298 372
  if (interpolation_method=="gam_daily"){
299 373
    #input a list:note that ghcn.subsets is not sampling_obj$data_day_ghcn
......
302 376
    names(list_param_run_prediction_gam_daily)<-c("list_index","covar_rast","covar_names","lst_avg","list_models","dst","screen_data_training","var","y_var_name","sampling_obj","interpolation_method","out_prefix","out_path")
303 377
    #test <- runGAM_day_fun(1,list_param_run_prediction_gam_daily)
304 378
    
305
    method_mod_obj<-mclapply(1:length(sampling_obj$ghcn_data),list_param=list_param_run_prediction_gam_daily,runGAM_day_fun,mc.preschedule=FALSE,mc.cores = 11) #This is the end bracket from mclapply(...) statement
379
    method_mod_obj<-mclapply(1:length(sampling_obj$ghcn_data),list_param=list_param_run_prediction_gam_daily,runGAM_day_fun,mc.preschedule=FALSE,mc.cores = num_cores) #This is the end bracket from mclapply(...) statement
306 380
    #method_mod_obj<-mclapply(1:22,list_param=list_param_run_prediction_gam_daily,runGAM_day_fun,mc.preschedule=FALSE,mc.cores = 11) #This is the end bracket from mclapply(...) statement
307 381
    
308 382
    save(method_mod_obj,file= file.path(out_path,paste("method_mod_obj_",interpolation_method,"_",y_var_name,out_prefix,".RData",sep="")))
......
315 389
    list_param_run_prediction_kriging_daily <-list(i,s_raster,covar_names,lst_avg,list_models,dst,var,y_var_name, sampling_obj,interpolation_method,out_prefix,out_path)
316 390
    names(list_param_run_prediction_kriging_daily)<-c("list_index","covar_rast","covar_names","lst_avg","list_models","dst","var","y_var_name","sampling_obj","interpolation_method","out_prefix","out_path")
317 391
    #test <- runKriging_day_fun(1,list_param_run_prediction_kriging_daily)
318
    method_mod_obj<-mclapply(1:length(sampling_obj$ghcn_data),list_param=list_param_run_prediction_kriging_daily,runKriging_day_fun,mc.preschedule=FALSE,mc.cores = 11) #This is the end bracket from mclapply(...) statement
392
    method_mod_obj<-mclapply(1:length(sampling_obj$ghcn_data),list_param=list_param_run_prediction_kriging_daily,runKriging_day_fun,mc.preschedule=FALSE,mc.cores = num_cores) #This is the end bracket from mclapply(...) statement
319 393
    #method_mod_obj<-mclapply(1:18,list_param=list_param_run_prediction_kriging_daily,runKriging_day_fun,mc.preschedule=FALSE,mc.cores = 9) #This is the end bracket from mclapply(...) statement
320 394
    
321 395
    save(method_mod_obj,file= file.path(out_path,paste("method_mod_obj_",interpolation_method,"_",y_var_name,out_prefix,".RData",sep="")))
......
328 402
    list_param_run_prediction_gwr_daily <-list(i,s_raster,covar_names,lst_avg,list_models,dst,var,y_var_name, sampling_obj,interpolation_method,out_prefix,out_path)
329 403
    names(list_param_run_prediction_gwr_daily)<-c("list_index","covar_rast","covar_names","lst_avg","list_models","dst","var","y_var_name","sampling_obj","interpolation_method","out_prefix","out_path")
330 404
    #test <- run_interp_day_fun(1,list_param_run_prediction_gwr_daily)
331
    method_mod_obj<-mclapply(1:length(sampling_obj$ghcn_data),list_param=list_param_run_prediction_gwr_daily,run_interp_day_fun,mc.preschedule=FALSE,mc.cores = 11) #This is the end bracket from mclapply(...) statement
405
    method_mod_obj<-mclapply(1:length(sampling_obj$ghcn_data),list_param=list_param_run_prediction_gwr_daily,run_interp_day_fun,mc.preschedule=FALSE,mc.cores = num_cores) #This is the end bracket from mclapply(...) statement
332 406
    #method_mod_obj<-mclapply(1:22,list_param=list_param_run_prediction_gwr_daily,run_interp_day_fun,mc.preschedule=FALSE,mc.cores = 11) #This is the end bracket from mclapply(...) statement
333 407
    #method_mod_obj<-mclapply(1:18,list_param=list_param_run_prediction_kriging_daily,runKriging_day_fun,mc.preschedule=FALSE,mc.cores = 9) #This is the end bracket from mclapply(...) statement
334 408
    
......
341 415
  
342 416
  ############### NOW RUN VALIDATION #########################
343 417
  #SIMPLIFY THIS PART: one call
344
      
345 418
  cat("Validation step:",file=log_fname,sep="\n", append=TRUE)
346 419
  t1<-proc.time()
347 420
  cat(paste("Local Date and Time: ",as.character(Sys.time()),sep=""),
......
361 434
    #debug(calculate_accuracy_metrics)
362 435
    #test_val2 <-calculate_accuracy_metrics(1,list_param_validation)
363 436
  
364
    validation_mod_obj <-mclapply(1:length(method_mod_obj), list_param=list_param_validation, calculate_accuracy_metrics,mc.preschedule=FALSE,mc.cores = 9) 
437
    validation_mod_obj <-mclapply(1:length(method_mod_obj), list_param=list_param_validation, calculate_accuracy_metrics,mc.preschedule=FALSE,mc.cores = num_cores) 
365 438
    save(validation_mod_obj,file= file.path(out_path,paste(interpolation_method,"_validation_mod_obj_",y_var_name,out_prefix,".RData",sep="")))
366 439
    t2<-proc.time()-t1
367 440
    cat(as.character(t2),file=log_fname,sep="\n", append=TRUE)
368 441
  }
369 442
    
370 443
  ### Run monthly validation if multi-time scale methods and add information to daily...
371
  
372 444
  if (interpolation_method %in% c("gam_CAI","kriging_CAI","gwr_CAI","gam_fusion","kriging_fusion","gwr_fusion")){
373 445
    multi_time_scale <- TRUE
374 446
    i<-1
......
385 457
    #debug(calculate_accuracy_metrics)
386 458
    #test_val2 <-calculate_accuracy_metrics(1,list_param_validation)
387 459
    
388
    validation_mod_obj <-mclapply(1:length(method_mod_obj), list_param=list_param_validation, calculate_accuracy_metrics,mc.preschedule=FALSE,mc.cores = 9) 
460
    validation_mod_obj <-mclapply(1:length(method_mod_obj), list_param=list_param_validation, calculate_accuracy_metrics,mc.preschedule=FALSE,mc.cores = num_cores) 
389 461
    save(validation_mod_obj,file= file.path(out_path,paste(interpolation_method,"_validation_mod_obj_",y_var_name,out_prefix,".RData",sep="")))
390 462
    
391 463
    ### monthly time scale
......
403 475
    #debug(calculate_accuracy_metrics)    
404 476
    #test_val2 <-calculate_accuracy_metrics(1,list_param_validation_month)
405 477
    
406
    validation_mod_month_obj <- mclapply(1:length(clim_method_mod_obj), list_param=list_param_validation_month, calculate_accuracy_metrics,mc.preschedule=FALSE,mc.cores = 6) 
478
    validation_mod_month_obj <- mclapply(1:length(clim_method_mod_obj), list_param=list_param_validation_month, calculate_accuracy_metrics,mc.preschedule=FALSE,mc.cores = num_cores) 
407 479
    #test_val<-calculate_accuracy_metrics(1,list_param_validation)
408 480
    save(validation_mod_month_obj,file= file.path(out_path,paste(interpolation_method,"_validation_mod_month_obj_",y_var_name,out_prefix,".RData",sep="")))
409 481
  
......
417 489
    tb_month_diagnostic_s$method_interp <- interpolation_method #add type of interpolation...out_prefix too??
418 490
    
419 491
  }
492

  
493
  #Cleaning raster temp files
494
  removeTmpFiles(h=0)
495

  
420 496
  #################### ASSESSMENT OF PREDICTIONS: PLOTS OF ACCURACY METRICS ###########
421
  
422 497
  ##Create data.frame with validation and fit metrics for a full year/full numbe of runs
423 498
  tb_diagnostic_v<-extract_from_list_obj(validation_mod_obj,"metrics_v") 
424 499
  #tb_diagnostic_v contains accuracy metrics for models sample and proportion for every run...if full year then 365 rows maximum
......
448 523
  
449 524
  ################### PREPARE RETURN OBJECT ###############
450 525
  #Will add more information to be returned
451
  
452 526
  if (interpolation_method %in% c("gam_CAI","kriging_CAI","gwr_CAI","gam_fusion","kriging_fusion","gwr_fusion")){
453 527
    raster_prediction_obj<-list(clim_method_mod_obj,method_mod_obj,validation_mod_obj,validation_mod_month_obj, tb_diagnostic_v,
454 528
                                tb_diagnostic_s,tb_month_diagnostic_v,tb_month_diagnostic_s,summary_metrics_v,summary_month_metrics_v)
......
467 541
    save(raster_prediction_obj,file= file.path(out_path,paste("raster_prediction_obj_",interpolation_method,"_", y_var_name,out_prefix,".RData",sep="")))
468 542
    
469 543
  }
470
  
544

  
471 545
  return(raster_prediction_obj)
472 546
}
473 547

  
474 548
####################################################################
475
######################## END OF SCRIPT/FUNCTION #####################
549
######################## END OF SCRIPT/FUNCTION #####################

Also available in: Unified diff