-
Notifications
You must be signed in to change notification settings - Fork 1
/
02_Two_Echelon_UCC.R
92 lines (66 loc) · 3.65 KB
/
02_Two_Echelon_UCC.R
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
84
85
86
87
88
89
90
91
92
#Rscript C:/LEAD_MODELS/NEW/2echelon-main/02_Two_Echelon_UCC.R C:/LEAD_MODELS/NEW/2echelon-main/ 40.4161737 -3.7087409
#--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
#Description:
# Script for executing scenarios.json:
# direct shipments from the branch in San Fernando to the consumers using a non-electric vehicle defined in args[3]
# it creates the inputs and the dependencies for wrapping function that connects to the next model (COPERT)
# args[1] = the location of the folder that contains the scripts, the INPUT, OUTPUT, SHAPEFILES folder to run the scenario
# args[2] = latitude
# args[3] = longitude
#
#---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
#reading the parameters from the console
args= commandArgs(trailingOnly = TRUE)
if (length(args)==0) {
#stop("One arguments need to be supplied", call.=FALSE)
path_in = "C:/LEAD_MODELS/NEW/2echelon-main"
latitude = 40.4161737
longitude= -3.7087409
} else if (length(args)==3) {
# # default output file
print("hola")
path_in =args[1]
latitude = args[2]
longitude=args[3]
}
#sourcing the libraries
setwd(path_in)
source("TwoEchelonModel_script.R")
source("TwoEchelonModel_IO.R")
source("Shapefile_to_Zone.R")
#predefined parameters
two_echelon_output_filename="output_two_echelon.json" #name of the output file with the results and all the information of the scenario
config = read_config(path_in)
facility1 = read_facility(path_in,1, config[3])
vehicle1 = read_vehicle(path_in,1,config[5])
facility2 = read_facility(path_in,2,config[4])
facility2 = read_facility(path_in,2,config[4])
facility2[3] = latitude
facility2[4] = longitude
print(facility2)
vehicle2 = read_vehicle(path_in,2,config[6])
zone1=read_deliveryZone(path_in,1,T,facility2)
zone2 = read_deliveryZone(path_in,2,T,NULL)
#browser()
solutionFirstLeg = calculateSolutionLeg(zone1,vehicle1, facility1, config,1)
solutionSecondLeg = calculateSolutionLeg(zone2, vehicle2, facility2, config,2)
output=c(solutionFirstLeg, solutionSecondLeg)
dfOutput = data.frame('echelon'=1:2,
'zone_name'=c(zone1[1],zone2[1]),
'zone_avg_size'=c(zone1[2],zone2[2]),
'zone_area_km2'=c(zone1[3],zone2[3]),
'zone_total_services'=c(zone1[6],zone2[6]),
'zone_latitude'=c(zone1[4],zone2[4]),
'zone_longitude'=c(zone1[5],zone2[5]),
'facility_name' = c(facility1[1],facility2[1]),
'facility_handling_time' = c(facility1[2],facility2[2]),
'facility_latitude'=c(facility1[3],facility2[3]),
'facility_longitude'=c(facility1[4],facility2[4]),
'vehicle_name'= c(vehicle1[1],vehicle2[1]),
'vehicle_capacity'= c(vehicle1[2],vehicle2[2]),
'vehicle_velocity_km.s'= c(vehicle1[3],vehicle2[3]),
'vehicle_velocity_stop_time'= c(vehicle1[4],vehicle2[4]),
'total_distance_km' = c(output[1],output[4]),
'total_time_hours' = c(output[2],output[5]),
'number_vehicles' = c(output[3], output[6]))
write_outputJSON(path_in,dfOutput,two_echelon_output_filename)