Skip to content

Commit

Permalink
Merge branch 'main' into rh/add_2t_physical_model
Browse files Browse the repository at this point in the history
  • Loading branch information
rodrigomha authored Nov 4, 2024
2 parents 071b893 + ec2c559 commit 697bb2d
Show file tree
Hide file tree
Showing 5 changed files with 45 additions and 17 deletions.
2 changes: 1 addition & 1 deletion Project.toml
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ DataFrames = "1"
DataStructures = "~0.18"
Dates = "1"
DocStringExtensions = "0.8, 0.9.2"
InfrastructureSystems = "^2.2"
InfrastructureSystems = "^2.3"
InteractiveUtils = "1"
JSON3 = "1"
LinearAlgebra = "1"
Expand Down
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ The `PowerSystems.jl` package provides a rigorous data model using Julia structu
- Dynamic Generators Models
- Dynamic Inverter Models

For a more exhaustive list, check the [Documentation](https://nrel-sienna.github.io/PowerSystems.jl/stable).
For information on using the package and a more extensive list of device data enabled, see the [stable documentation](https://nrel-sienna.github.io/PowerSystems.jl/stable/). Use the [in-development documentation](https://nrel-sienna.github.io/PowerSystems.jl/dev/) for the version of the documentation which contains the unreleased features.

## Parsing capabilities in PowerSystems

Expand Down
2 changes: 1 addition & 1 deletion docs/make.jl
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ pages = OrderedDict(
"Reference" =>
Any["Public API" => "api/public.md",
"Glossary and Acronyms" => "api/glossary.md",
"Type Hierarchy" => "api/type_tree.md",
"Type Tree" => "api/type_tree.md",
"`ValueCurve` Options" => "api/valuecurve_options.md",
"Specifying the category of..." => "api/enumerated_types.md",
"Citation" => "api/citation.md",
Expand Down
2 changes: 1 addition & 1 deletion docs/src/api/type_tree.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# Type Hierarchy
# Type Tree

Here is the complete `PowerSystems.jl` type hierarchy:

Expand Down
54 changes: 41 additions & 13 deletions src/base.jl
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,7 @@ System(; kwargs...)
`"DEVICE_BASE"`, or `"NATURAL_UNITS"`)
By default, time series data is stored in an HDF5 file in the tmp file system to prevent
large datasets from overwhelming system memory (see [Data Storage](@ref)).
large datasets from overwhelming system memory (see [Data Storage](@ref)).
**If the system's time series
data will be larger than the amount of tmp space available**, use the
`time_series_directory` parameter to change its location.
Expand Down Expand Up @@ -1080,22 +1080,25 @@ function get_component(::Type{T}, sys::System, name::AbstractString) where {T <:
end

"""
Returns an iterator of components. T can be concrete or abstract.
Return an iterator of components of a given `Type` from a [`System`](@ref).
`T` can be a concrete or abstract [`Component`](@ref) type from the [Type Tree](@ref).
Call collect on the result if an array is desired.
# Examples
```julia
iter = PowerSystems.get_components(ThermalStandard, sys)
iter = PowerSystems.get_components(Generator, sys)
iter = PowerSystems.get_components(x -> PowerSystems.get_available(x), Generator, sys)
thermal_gens = get_components(ThermalStandard, sys) do gen
get_available(gen)
end
generators = collect(PowerSystems.get_components(Generator, sys))
iter = get_components(ThermalStandard, sys)
iter = get_components(Generator, sys)
generators = collect(get_components(Generator, sys))
```
See also: [`iterate_components`](@ref)
See also: [`iterate_components`](@ref), [`get_components` with a filter](@ref get_components(
filter_func::Function,
::Type{T},
sys::System;
subsystem_name = nothing,
) where {T <: Component}),
[`get_available_components`](@ref), [`get_buses`](@ref)
"""
function get_components(
::Type{T},
Expand All @@ -1105,6 +1108,27 @@ function get_components(
return IS.get_components(T, sys.data; subsystem_name = subsystem_name)
end

"""
Return an iterator of components of a given `Type` from a [`System`](@ref), using an
additional filter
`T` can be a concrete or abstract [`Component`](@ref) type from the [Type Tree](@ref).
Call collect on the result if an array is desired.
# Examples
```julia
iter_coal = get_components(x -> get_fuel(x) == ThermalFuels.COAL, Generator, sys)
pv_gens =
collect(get_components(x -> get_prime_mover_type(x) == PrimeMovers.PVe, Generator, sys))
```
See also: [`get_components`](@ref get_components(
::Type{T},
sys::System;
subsystem_name = nothing,
) where {T <: Component}), [`get_available_components`](@ref),
[`get_buses`](@ref)
"""
function get_components(
filter_func::Function,
::Type{T},
Expand Down Expand Up @@ -1161,7 +1185,11 @@ function get_components_by_name(
end

"""
Gets components availability. Requires type T to have the method get_available implemented.
Returns iterator of available components in a [`System`](@ref).
`T` can be a concrete or abstract [`Component`](@ref) type from the [Type Tree](@ref)
and must have the method `get_available` implemented.
Call collect on the result if an array is desired.
"""
function get_available_components(::Type{T}, sys::System) where {T <: Component}
return get_components(get_available, T, sys)
Expand Down Expand Up @@ -1297,7 +1325,7 @@ function _get_buses(data::IS.SystemData, aggregator::T) where {T <: AggregationT
buses = Vector{ACBus}()
for bus in IS.get_components(ACBus, data)
_aggregator = accessor_func(bus)
if IS.get_uuid(_aggregator) == IS.get_uuid(aggregator)
if !isnothing(_aggregator) && IS.get_uuid(_aggregator) == IS.get_uuid(aggregator)
push!(buses, bus)
end
end
Expand Down

0 comments on commit 697bb2d

Please sign in to comment.