mirror of
https://github.com/ANL-CEEESA/UnitCommitment.jl.git
synced 2025-12-06 08:18:51 -06:00
42 lines
1.6 KiB
Julia
42 lines
1.6 KiB
Julia
# 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
|
|
|
|
basedir = @__DIR__
|
|
|
|
function parse_case14()
|
|
return JSON.parse(
|
|
GZip.gzopen("$basedir/../../instances/test/case14.json.gz"),
|
|
dicttype = () -> DefaultOrderedDict(nothing),
|
|
)
|
|
end
|
|
|
|
@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
|