You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
44 lines
1.8 KiB
44 lines
1.8 KiB
# UnitCommitment.jl: Optimization Package for Security-Constrained Unit Commitment
|
|
# Copyright (C) 2020, UChicago Argonne, LLC. All rights reserved.
|
|
# Released under the modified BSD license. See COPYING.md for more details.
|
|
|
|
using UnitCommitment, JSON, GZip, DataStructures
|
|
|
|
function parse_case14()
|
|
return JSON.parse(
|
|
GZip.gzopen("../instances/test/case14.json.gz"),
|
|
dicttype = () -> DefaultOrderedDict(nothing),
|
|
)
|
|
end
|
|
|
|
@testset "Validation" begin
|
|
@testset "repair!" begin
|
|
@testset "Cost curve should be convex" begin
|
|
json = parse_case14()
|
|
json["Generators"]["g1"]["Production cost curve (MW)"] =
|
|
[100, 150, 200]
|
|
json["Generators"]["g1"]["Production cost curve (\$)"] =
|
|
[10, 25, 30]
|
|
instance = UnitCommitment._from_json(json, repair = false)
|
|
@test UnitCommitment.repair!(instance) == 4
|
|
end
|
|
|
|
@testset "Startup limit must be greater than Pmin" begin
|
|
json = parse_case14()
|
|
json["Generators"]["g1"]["Production cost curve (MW)"] = [100, 150]
|
|
json["Generators"]["g1"]["Production cost curve (\$)"] = [100, 150]
|
|
json["Generators"]["g1"]["Startup limit (MW)"] = 80
|
|
instance = UnitCommitment._from_json(json, repair = false)
|
|
@test UnitCommitment.repair!(instance) == 1
|
|
end
|
|
|
|
@testset "Startup costs and delays must be increasing" begin
|
|
json = parse_case14()
|
|
json["Generators"]["g1"]["Startup costs (\$)"] = [300, 200, 100]
|
|
json["Generators"]["g1"]["Startup delays (h)"] = [8, 4, 2]
|
|
instance = UnitCommitment._from_json(json, repair = false)
|
|
@test UnitCommitment.repair!(instance) == 4
|
|
end
|
|
end
|
|
end
|