2022-04-28 17:29:24 +02:00
|
|
|
#!/usr/bin/env julia
|
|
|
|
# -*- coding: UTF-8 -*-
|
|
|
|
# __julia-version__ = 1.7.2
|
|
|
|
# __author__ = "Max Kannenberg"
|
|
|
|
# __copyright__ = "2020-2022"
|
|
|
|
# __license__ = "ISC"
|
|
|
|
|
2022-05-04 16:34:17 +02:00
|
|
|
function createOutput(train::Dict, settings::Settings, path::Path, movingSection::Dict, drivingCourse::Vector{Dict})
|
2022-04-28 17:29:24 +02:00
|
|
|
if settings.outputDetail == :running_time
|
|
|
|
output = movingSection[:t] # TODO: or use drivingCourse[end][:t]
|
|
|
|
|
|
|
|
elseif settings.outputDetail == :points_of_interest
|
|
|
|
# add points of interest
|
2022-05-04 16:34:17 +02:00
|
|
|
if !isempty(path.poi)
|
|
|
|
|
|
|
|
# for elem in 1:length(driving_course)
|
|
|
|
# end
|
|
|
|
|
|
|
|
output = Dict[]
|
2022-04-28 17:29:24 +02:00
|
|
|
POI = 1
|
|
|
|
i = 1
|
2022-05-04 16:34:17 +02:00
|
|
|
while POI <= length(path.poi) && i <= drivingCourse[end][:i]
|
|
|
|
if path.poi[POI][:station] == drivingCourse[i][:s]
|
2022-04-28 17:29:24 +02:00
|
|
|
push!(output, drivingCourse[i])
|
|
|
|
POI = POI+1
|
|
|
|
end
|
|
|
|
i = i+1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
elseif settings.outputDetail == :driving_course
|
|
|
|
output = drivingCourse
|
|
|
|
|
|
|
|
elseif settings.outputDetail == :everything
|
|
|
|
output = Dict{Symbol,Any}()
|
|
|
|
merge!(output, Dict(:train => train, :path => path, :settings => settings))
|
|
|
|
|
|
|
|
|
|
|
|
# add moving section and driving courses
|
|
|
|
if settings[:operationModeMinimumRunningTime] == true
|
|
|
|
merge!(output, Dict(:movingSectionMinimumRunningTime => movingSection,
|
|
|
|
:drivingCourseMinimumRunningTime => drivingCourse))
|
|
|
|
elseif settings[:operationModeMinimumEnergyConsumption] == true
|
|
|
|
merge!(output, Dict(:movingSectionMinimumEnergyConsumption => movingSection,
|
|
|
|
:drivingCourseMinimumEnergyConsumption => drivingCourse))
|
|
|
|
end
|
|
|
|
|
|
|
|
# add points of interest
|
2022-05-04 16:34:17 +02:00
|
|
|
if !isempty(path.poi)
|
2022-04-28 17:29:24 +02:00
|
|
|
pointsOfInterest = Vector{Dict}()
|
|
|
|
POI = 1
|
|
|
|
i = 1
|
2022-05-04 16:34:17 +02:00
|
|
|
while POI <= length(path.poi) && i <= drivingCourse[end][:i]
|
|
|
|
if path.poi[POI] == drivingCourse[i][:s]
|
2022-04-28 17:29:24 +02:00
|
|
|
push!(pointsOfInterest, drivingCourse[i])
|
|
|
|
POI = POI+1
|
|
|
|
end
|
|
|
|
i = i+1
|
|
|
|
end
|
|
|
|
|
|
|
|
if settings[:operationModeMinimumRunningTime] == true
|
|
|
|
merge!(output, Dict(:pointsOfInterestMinimumRunningTime => pointsOfInterest))
|
|
|
|
elseif settings[:operationModeMinimumEnergyConsumption] == true
|
|
|
|
merge!(output, Dict(:pointsOfInterestMinimumEnergyConsumption => pointsOfInterest))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
else
|
|
|
|
output = nothing
|
|
|
|
end
|
|
|
|
return output
|
|
|
|
end
|
|
|
|
|
|
|
|
#=
|
2022-05-04 16:34:17 +02:00
|
|
|
function createOutputDict(train::Dict, settings::Settings, path::Path, movingSection::Dict, drivingCourse::Vector{Dict})
|
2022-04-28 17:29:24 +02:00
|
|
|
outputDict = Dict{Symbol,Any}()
|
|
|
|
merge!(outputDict, Dict(:train => train, :path => path, :settings => settings))
|
|
|
|
|
|
|
|
|
|
|
|
# add moving section and driving courses
|
|
|
|
if settings[:operationModeMinimumRunningTime] == true
|
|
|
|
merge!(outputDict, Dict(:movingSectionMinimumRunningTime => movingSection,
|
|
|
|
:drivingCourseMinimumRunningTime => drivingCourse))
|
|
|
|
elseif settings[:operationModeMinimumEnergyConsumption] == true
|
|
|
|
merge!(outputDict, Dict(:movingSectionMinimumEnergyConsumption => movingSection,
|
|
|
|
:drivingCourseMinimumEnergyConsumption => drivingCourse))
|
|
|
|
end
|
|
|
|
|
|
|
|
# add points of interest
|
2022-05-04 16:34:17 +02:00
|
|
|
if !isempty(path.poi)
|
2022-04-28 17:29:24 +02:00
|
|
|
pointsOfInterest = Vector{Dict}()
|
|
|
|
POI = 1
|
|
|
|
i = 1
|
2022-05-04 16:34:17 +02:00
|
|
|
while POI <= length(path.poi) && i <= drivingCourse[end][:i]
|
|
|
|
if path.poi[POI] == drivingCourse[i][:s]
|
2022-04-28 17:29:24 +02:00
|
|
|
push!(pointsOfInterest, drivingCourse[i])
|
|
|
|
POI = POI+1
|
|
|
|
end
|
|
|
|
i = i+1
|
|
|
|
end
|
|
|
|
|
|
|
|
if settings[:operationModeMinimumRunningTime] == true
|
|
|
|
merge!(outputDict, Dict(:pointsOfInterestMinimumRunningTime => pointsOfInterest))
|
|
|
|
elseif settings[:operationModeMinimumEnergyConsumption] == true
|
|
|
|
merge!(outputDict, Dict(:pointsOfInterestMinimumEnergyConsumption => pointsOfInterest))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
return outputDict
|
|
|
|
end # function createOutputDict
|
|
|
|
=#
|