Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Model EV Batteries #1533

Open
wants to merge 119 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 109 commits
Commits
Show all changes
119 commits
Select commit Hold shift + click to select a range
7b651b0
new arguments and method to write EV battery to xml
aspeake Oct 27, 2023
36492fb
custom schedule columns for EV batteries
aspeake Oct 27, 2023
08c8c5a
fix ev battery schedule generation, generalize for ev and non-ev batt…
aspeake Oct 30, 2023
3f94374
allow one EV and one non-EV battery in schema
aspeake Oct 30, 2023
744ad66
stub out defaults for EV batteries
aspeake Oct 30, 2023
4f1a37e
update how battery ids are assigned in xml
aspeake Oct 30, 2023
210c463
make ev_battery_preset argument optional
aspeake Oct 31, 2023
5c36fcb
Merge branch 'master' of https://github.com/NREL/OpenStudio-HPXML int…
shorowit Nov 2, 2023
01437d0
always require schedule when modeling ev batteries
aspeake Nov 9, 2023
8f33e3d
initial tests for ev batteries
aspeake Nov 9, 2023
52bc3ab
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Nov 9, 2023
9db3aeb
add missing ev battery schedule for tests
aspeake Nov 9, 2023
da8dc17
update log message tests for batteries
aspeake Nov 16, 2023
357ba18
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Nov 16, 2023
374aae8
fix test for battery log message
aspeake Nov 16, 2023
2a9b7bb
Latest results.
Nov 16, 2023
dd4d5cf
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Jan 11, 2024
61d39b6
Seperate EVs from batteries and leverage existing EV charger fields
aspeake Jan 23, 2024
22f00b2
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Jan 23, 2024
0056e2c
Merge branch 'ev_batteries' of https://github.com/NREL/OpenStudio-HPX…
aspeake Jan 23, 2024
f6b88a3
Refine inputs for EV battery and charger, update tests
aspeake Feb 5, 2024
1effbc8
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Feb 5, 2024
6fbd4f5
update unit tests for EVs and chargers; apply rubocop
aspeake Feb 28, 2024
bd3fbfe
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Feb 28, 2024
35e8be4
fix failing tests for ev batteries
aspeake Feb 29, 2024
cefa4e2
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Feb 29, 2024
e279ea4
Latest results.
Feb 29, 2024
b86a506
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Jun 6, 2024
3228c7a
Merge branch 'ev_batteries' of https://github.com/NREL/OpenStudio-HPX…
aspeake Jun 6, 2024
5d21e32
Update EV arguments for latest approach to argument handling
aspeake Jun 7, 2024
b1ef026
Generate an ELCD object for each EV battery
aspeake Jun 7, 2024
a413534
Update reporting measure to output EV energy
aspeake Jun 7, 2024
2432bfb
EMS program to adjust effective EV discharge power and offset that di…
aspeake Jun 7, 2024
9c31908
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Jun 25, 2024
0c8861c
Pull in latest Vehicles changes in HPXML schema, update HPXML classes…
aspeake Jun 25, 2024
891f609
Introduce miles/yr and hours/wk arguments for EVs, calculate the effe…
aspeake Jun 28, 2024
3291f9c
Write EV fraction charged at home to HPXML
aspeake Jun 28, 2024
2bfc0f7
Fix for EV discharge offset object when EV location is garage
aspeake Jul 1, 2024
b2d226a
Fix bug iniitalizing DBT sensor
aspeake Jul 12, 2024
d0a554f
Apply rubocop
aspeake Jul 12, 2024
ea3d06f
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Aug 13, 2024
7d04943
Pull in latest HPXML schema for EVs
aspeake Aug 13, 2024
a5a3fc7
Fix merge conflict
aspeake Aug 29, 2024
d591cad
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Aug 29, 2024
52d07dd
Fix unit tests for EV batteries
aspeake Aug 30, 2024
aaecf51
update in-line documentation for vehicles and batteries
aspeake Aug 30, 2024
14f026e
address unit test failures for EV batteries
aspeake Aug 30, 2024
ed8cc5b
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Aug 30, 2024
357509e
fixes for timeseries tests of EVs
aspeake Aug 30, 2024
1e89f06
Latest results.
Aug 31, 2024
50a8c47
prevent EVs modeled with a plug load and a battery at the same time
aspeake Sep 16, 2024
8cc6c93
Merge branch 'ev_batteries' of https://github.com/NREL/OpenStudio-HPX…
aspeake Sep 16, 2024
1198abd
pull in latest HPXML schema
aspeake Sep 16, 2024
9c373df
Merge branch 'master' of https://github.com/NREL/OpenStudio-HPXML int…
shorowit Oct 15, 2024
cbc7fa1
Bugfix.
shorowit Oct 15, 2024
59d5594
discard EMS for offsetting EV discharge energy and handle it directly…
aspeake Oct 17, 2024
385c67b
new reporting measure class to output vehicle-specific variables that…
aspeake Oct 17, 2024
486f01f
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Oct 17, 2024
32e567b
apply RuboCop
aspeake Oct 17, 2024
28e1849
fix bug for vehicles in the reporting measures
aspeake Oct 18, 2024
d17000e
Include reporting measure arguments to trigger vehicle outputs
aspeake Oct 21, 2024
18bf8fc
Latest results.
Oct 21, 2024
14718f5
refrain from using object id to check if a battery is for a vehicle
aspeake Oct 23, 2024
e032b3e
Merge branch 'ev_batteries' of https://github.com/NREL/OpenStudio-HPX…
aspeake Oct 23, 2024
962797a
simplify access to vehicle objects when applying to model; some cleanup
aspeake Oct 25, 2024
5d21764
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Oct 25, 2024
d7e8f28
Merge branch 'master' into ev_batteries
rajeee Oct 30, 2024
5101e71
Default schedules for EV batteries and EV plug loads
aspeake Nov 5, 2024
7452d70
Merge branch 'ev_batteries' of https://github.com/NREL/OpenStudio-HPX…
aspeake Nov 5, 2024
67401df
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Nov 5, 2024
532abc2
Pull in latest HPXML schema changes to vehicles
aspeake Nov 8, 2024
ff17916
Account for vehicles specified as EV batteries and as plug loads
aspeake Nov 8, 2024
caf8114
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Nov 21, 2024
8b29eab
New EMS variable to track unmet driving hours, report with Vehicle Ty…
aspeake Nov 26, 2024
d0bbdd4
Add check to avoid always trying to report unmet driving hours
aspeake Nov 26, 2024
5d3eeae
Always load EV discharge energy variable to adjust electricity meter.
aspeake Nov 27, 2024
1c20229
Merge branch 'master' of https://github.com/NREL/OpenStudio-HPXML int…
shorowit Dec 10, 2024
81fa928
Accommodate new output.
shorowit Dec 10, 2024
e461f26
Fixed CI failures?
shorowit Dec 11, 2024
dae014e
A little cleanup.
shorowit Dec 11, 2024
0c5982f
Fixed CI failure? And some code cleanup.
shorowit Dec 11, 2024
e0b8da9
Latest results.
Dec 11, 2024
4cdcad3
Add schematron rules for EVs; drop discharge power input for EVs.
aspeake Dec 16, 2024
859d4f5
Merge branch 'ev_batteries' of https://github.com/NREL/OpenStudio-HPX…
aspeake Dec 16, 2024
22344b0
Set EV rated power output during model generation using miles, hours…
aspeake Dec 17, 2024
71cdc88
Latest results.
Dec 17, 2024
d16f0d1
Drop vehicle type output and move unmet driving hours to UHT; add tes…
aspeake Dec 23, 2024
8c2772e
Merge branch 'ev_batteries' of https://github.com/NREL/OpenStudio-HPX…
aspeake Dec 23, 2024
f0976f0
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Dec 23, 2024
c27fde0
Latest results.
Dec 23, 2024
23edb30
Move logic to request EV discharge energy output; throw warning for u…
aspeake Dec 23, 2024
2c84e01
Merge branch 'ev_batteries' of https://github.com/NREL/OpenStudio-HPX…
aspeake Dec 23, 2024
b8c6ab5
Clarify argument descriptions for EV battery and EV plug load.
aspeake Dec 23, 2024
83d9148
Refactor calculation of effective and rated EV discharge power. Updat…
aspeake Dec 24, 2024
922cdea
Ensure only one EV ruleset charging or discharging schedule is genera…
aspeake Dec 26, 2024
9af936f
Latest results.
Dec 26, 2024
4776c31
Update docs and inline comments for EVs and chargers; remove roundtri…
aspeake Dec 31, 2024
2292c06
Merge branch 'ev_batteries' of https://github.com/NREL/OpenStudio-HPX…
aspeake Dec 31, 2024
d44ac99
Fix incorrect if statement in resilience reporting.
aspeake Dec 31, 2024
e444f74
New unit tests for EV and charger default values.
aspeake Jan 4, 2025
5e5e107
Test for multiple battery types, EV and home.
aspeake Jan 4, 2025
792f79e
Update schematron for BEVs and chargers.
aspeake Jan 5, 2025
35104b2
Remove unused sample xml.
aspeake Jan 5, 2025
4892769
Merge remote-tracking branch 'origin/master' into ev_batteries
aspeake Jan 5, 2025
0ff6acb
Update Changelog.
aspeake Jan 5, 2025
d9ffc48
Fix schematron check for EV charging location.
aspeake Jan 6, 2025
d8605a9
Latest results.
Jan 6, 2025
c6db1ac
Allow EV charger without an EV battery.
aspeake Jan 6, 2025
39492f3
Merge branch 'ev_batteries' of https://github.com/NREL/OpenStudio-HPX…
aspeake Jan 6, 2025
0bff0a9
Clean up measure and test code for EVs and chargers
aspeake Jan 6, 2025
5ed1495
Fix warning check in workflow tests.
aspeake Jan 6, 2025
5070b3d
Catch unmet driving hours warning in workflow tests.
aspeake Jan 7, 2025
f49ce9a
Address more warnings for workflow tests.
aspeake Jan 7, 2025
307dad0
Latest results.
Jan 7, 2025
42be417
Merge branch 'master' of https://github.com/NREL/OpenStudio-HPXML int…
shorowit Jan 10, 2025
9b24b18
Minor unrelated improvement to make sure all HPXMLs with garages get …
shorowit Jan 10, 2025
0414143
Latest results.
Jan 10, 2025
deb1c22
Update BuildResidentialHPXML measure args.
aspeake Jan 11, 2025
2349294
Merge branch 'ev_batteries' of https://github.com/NREL/OpenStudio-HPX…
aspeake Jan 11, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
126 changes: 125 additions & 1 deletion BuildResidentialHPXML/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4497,6 +4497,130 @@ The round trip efficiency of the lithium ion battery. If not provided, the OS-HP

<br/>

**Electric Vehicle: Present**

Whether there is an electric vehicle battery present. If the `misc_plug_loads_vehicle_present` argument is true, this argument is superseded and vehicle charging will be modeled as a plug load only.

- **Name:** ``ev_battery_present``
- **Type:** ``Boolean``

- **Required:** ``false``

<br/>

**Electric Vehicle: Nominal Battery Capacity**

The nominal capacity of the EV battery. If not provided, the OS-HPXML default is used.

- **Name:** ``ev_battery_capacity``
- **Type:** ``Double``

- **Units:** ``kWh``

- **Required:** ``false``

<br/>

**Electric Vehicle: Usable Battery Capacity**

The usable capacity of the EV battery. If not provided, the OS-HPXML default is used.

- **Name:** ``ev_battery_usable_capacity``
- **Type:** ``Double``

- **Units:** ``kWh``

- **Required:** ``false``

<br/>

**Electric Vehicle: Energy Efficiency**

The efficiency of the EV. If not provided, the OS-HPXML default is used.

- **Name:** ``ev_energy_efficiency``
- **Type:** ``Double``

- **Units:** ``kWh/mile``

- **Required:** ``false``

<br/>

**Electric Vehicle: Miles Traveled**

The annual miles traveled by the EV.

- **Name:** ``ev_miles_per_year``
- **Type:** ``Double``

- **Units:** ``miles``

- **Required:** ``false``

<br/>

**Electric Vehicle: Hours Driven per Week**

The weekly hours traveled by the EV.

- **Name:** ``ev_hours_per_week``
- **Type:** ``Double``

- **Units:** ``hours``

- **Required:** ``false``

<br/>

**Electric Vehicle: Fraction Charged at Home**

The fraction charging energy provided by the at-home charger.

- **Name:** ``ev_fraction_charged_home``
- **Type:** ``Double``

- **Required:** ``false``

<br/>

**Electric Vehicle Charger: Present**

Whether there is an electric vehicle charger present.

- **Name:** ``ev_charger_present``
- **Type:** ``Boolean``

- **Required:** ``false``

<br/>

**Electric Vehicle Charger: Rated Charger Power Output**

The rated power output of the EV charger. If not provided, the OS-HPXML default is used.

- **Name:** ``ev_charger_power``
- **Type:** ``Double``

- **Units:** ``W``

- **Required:** ``false``

<br/>

**Electric Vehicle Charger: Location**

The space type for the EV charger. If not provided, the OS-HPXML default is used.

- **Name:** ``ev_charger_location``
- **Type:** ``Choice``

- **Required:** ``false``

- **Choices:** `garage`, `outside`

<br/>

**Battery: Number of Bedrooms Served**

Number of bedrooms served by the lithium ion battery. Only needed if single-family attached or apartment unit and it is a shared battery serving multiple dwelling units. Used to apportion battery charging/discharging to the unit of a SFA/MF building.
Expand Down Expand Up @@ -5517,7 +5641,7 @@ Multiplier on the well pump energy usage that can reflect, e.g., high/low usage

**Misc Plug Loads: Vehicle Present**

Whether there is an electric vehicle.
Whether there is an electric vehicle. Specifying this argument will model EV charging as a plug load and take precendence over the `ev_battery_present` argument.

- **Name:** ``misc_plug_loads_vehicle_present``
- **Type:** ``Boolean``
Expand Down
102 changes: 101 additions & 1 deletion BuildResidentialHPXML/measure.rb
Original file line number Diff line number Diff line change
Expand Up @@ -2676,6 +2676,68 @@ def arguments(model) # rubocop:disable Lint/UnusedMethodArgument
arg.setUnits('Frac')
args << arg

arg = OpenStudio::Measure::OSArgument::makeBoolArgument('ev_battery_present', false)
arg.setDisplayName('Electric Vehicle: Present')
arg.setDescription('Whether there is an electric vehicle battery present. If the `misc_plug_loads_vehicle_present` argument is true, this argument is superseded and vehicle charging will be modeled as a plug load only.')
arg.setDefaultValue(false)
args << arg

arg = OpenStudio::Measure::OSArgument::makeDoubleArgument('ev_battery_capacity', false)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Could you generalize this to better match the generic Vehicle element in HPXML? I.e.:

  • Replace "Electric Vehicle: Present" with "Vehicle: Type" where you can choose EV, ICE, etc., or "none". Default to "none".
  • Change all the display names from "Electric Vehicle: Foo" to be "Vehicle: Foo" and, for those arguments that only apply for certain vehicle types, say so in the description. (You'll find lots of examples of this in the code.) You may have to update the set_electric_vehicle() method a bit too use the vehicle type argument.
  • Change all descriptions to refer to "vehicle" instead of "EV".
  • Change all the arguments from ev_battery_foo to vehicle_foo.

This would allow someone to create an HPXML with other vehicle types too. Hopefully not too much work...

arg.setDisplayName('Electric Vehicle: Nominal Battery Capacity')
arg.setDescription('The nominal capacity of the EV battery. If not provided, the OS-HPXML default is used.')
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Anytime you say "the OS-HPXML default is used", please include a link to the documentation. You'll find lots of examples where we do this.

arg.setUnits('kWh')
args << arg

arg = OpenStudio::Measure::OSArgument::makeDoubleArgument('ev_battery_usable_capacity', false)
arg.setDisplayName('Electric Vehicle: Usable Battery Capacity')
arg.setDescription('The usable capacity of the EV battery. If not provided, the OS-HPXML default is used.')
arg.setUnits('kWh')
args << arg

arg = OpenStudio::Measure::OSArgument::makeDoubleArgument('ev_energy_efficiency', false)
arg.setDisplayName('Electric Vehicle: Energy Efficiency')
arg.setDescription('The efficiency of the EV. If not provided, the OS-HPXML default is used.')
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There is no "Energy Efficiency" element in the HPXML. Please use the same names that are used in the schema, otherwise it is confusing. Seems like it is "Combined Fuel Economy"?

Also, we should probably split this argument in two: the units (choice enumeration, it's fine if only "kWh/mile" is supported today) and the value. You can find examples of this in other arguments in the measure.

arg.setUnits('kWh/mile')
args << arg

arg = OpenStudio::Measure::OSArgument::makeDoubleArgument('ev_miles_per_year', false)
arg.setDisplayName('Electric Vehicle: Miles Traveled')
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Match HPXML schema... I assume "Miles Driven Per Year"?

arg.setDescription('The annual miles traveled by the EV.')
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Doesn't this (and some of the others, please double-check) have an OS-HPXML default? "If not provided, the OS-HPXML default is used."

arg.setUnits('miles')
args << arg
Copy link
Collaborator Author

@aspeake aspeake Jan 6, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Used to calculate the effective discharge power in vehicles.rb (power = kwh/mile * annl_miles / driving hours)


arg = OpenStudio::Measure::OSArgument::makeDoubleArgument('ev_hours_per_week', false)
arg.setDisplayName('Electric Vehicle: Hours Driven per Week')
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Match the schema... "Hours Driven Per Week".

arg.setDescription('The weekly hours traveled by the EV.')
arg.setUnits('hours')
args << arg
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not currently used, but will be needed in schedule generation PR


arg = OpenStudio::Measure::OSArgument::makeDoubleArgument('ev_fraction_charged_home', false)
arg.setDisplayName('Electric Vehicle: Fraction Charged at Home')
arg.setDescription('The fraction charging energy provided by the at-home charger.')
args << arg
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not sure if this argument belongs here. It will be used in ResStockArguments to scale the miles/year, which influences the schedule. I liked that it persists into the HPXML to give context to the miles/year, but the fraction is not used directly in OS-HPXML.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't follow. Why wouldn't OS-HPXML use this?This should affect how much charging is done at home, no?


arg = OpenStudio::Measure::OSArgument::makeBoolArgument('ev_charger_present', false)
arg.setDisplayName('Electric Vehicle Charger: Present')
arg.setDescription('Whether there is an electric vehicle charger present.')
arg.setDefaultValue(false)
args << arg

arg = OpenStudio::Measure::OSArgument::makeDoubleArgument('ev_charger_power', false)
arg.setDisplayName('Electric Vehicle Charger: Rated Charger Power Output')
arg.setDescription('The rated power output of the EV charger. If not provided, the OS-HPXML default is used.')
arg.setUnits('W')
args << arg

ev_charger_location_choices = OpenStudio::StringVector.new
ev_charger_location_choices << HPXML::LocationGarage
ev_charger_location_choices << HPXML::LocationOutside

arg = OpenStudio::Measure::OSArgument::makeChoiceArgument('ev_charger_location', ev_charger_location_choices, false)
arg.setDisplayName('Electric Vehicle Charger: Location')
arg.setDescription('The space type for the EV charger. If not provided, the OS-HPXML default is used.')
args << arg

arg = OpenStudio::Measure::OSArgument::makeIntegerArgument('battery_num_bedrooms_served', false)
arg.setDisplayName('Battery: Number of Bedrooms Served')
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks like this home battery argument got split from the rest. Please move it up.

arg.setDescription("Number of bedrooms served by the lithium ion battery. Only needed if #{HPXML::ResidentialTypeSFA} or #{HPXML::ResidentialTypeApartment} and it is a shared battery serving multiple dwelling units. Used to apportion battery charging/discharging to the unit of a SFA/MF building.")
Expand Down Expand Up @@ -3210,7 +3272,7 @@ def arguments(model) # rubocop:disable Lint/UnusedMethodArgument

arg = OpenStudio::Measure::OSArgument::makeBoolArgument('misc_plug_loads_vehicle_present', true)
arg.setDisplayName('Misc Plug Loads: Vehicle Present')
arg.setDescription('Whether there is an electric vehicle.')
arg.setDescription('Whether there is an electric vehicle. Specifying this argument will model EV charging as a plug load and take precendence over the `ev_battery_present` argument.')
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No need to do this. The BuildResidentialHPXML measure should simply write an HPXML file with both. Then the HPXMLtoOpenStudio measure downstream will give a warning and handle it.

arg.setDefaultValue(false)
args << arg

Expand Down Expand Up @@ -3941,6 +4003,7 @@ def self.create(runner, model, args, epw_path, hpxml_path, existing_hpxml_path)
set_solar_thermal(hpxml_bldg, args, weather)
set_pv_systems(hpxml_bldg, args, weather)
set_battery(hpxml_bldg, args)
set_electric_vehicle(hpxml_bldg, args)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Rename to set_vehicle

set_lighting(hpxml_bldg, args)
set_dehumidifier(hpxml_bldg, args)
set_clothes_washer(hpxml_bldg, args)
Expand Down Expand Up @@ -6877,6 +6940,43 @@ def self.set_battery(hpxml_bldg, args)
number_of_bedrooms_served: number_of_bedrooms_served)
end

# Set the electric vehicle and electric vehicle charger properties, including:
# - nominal and usable capacity
# - driving efficiency
# - miles driven per year
# - hours driven per week
# - fraction charged at home
# - EV charger reference
# - EV charger location
# - EV charger charging power
#
# @param hpxml_bldg [HPXML::Building] HPXML Building object representing an individual dwelling unit
# @param args [Hash] Map of :argument_name => value
# @return [nil]
def self.set_electric_vehicle(hpxml_bldg, args)
return unless args[:ev_battery_present] || args[:ev_charger_present]

charger_id = nil
if args[:ev_charger_present]
charger_id = "EVCharger#{hpxml_bldg.ev_chargers.size + 1}"
hpxml_bldg.ev_chargers.add(id: charger_id,
location: args[:ev_charger_location],
charging_power: args[:ev_charger_power])
end

if args[:ev_battery_present]
ev_ct = hpxml_bldg.vehicles.count { |vehicle| vehicle.vehicle_type == HPXML::VehicleTypeBEV }
hpxml_bldg.vehicles.add(id: "ElectricVehicle#{ev_ct + 1}",
nominal_capacity_kwh: args[:ev_battery_capacity],
usable_capacity_kwh: args[:ev_battery_usable_capacity],
energy_efficiency: args[:ev_energy_efficiency],
miles_per_year: args[:ev_miles_per_year],
hours_per_week: args[:ev_hours_per_week],
fraction_charged_home: args[:ev_fraction_charged_home],
ev_charger_idref: charger_id)
end
end

# Set the lighting properties, including:
# - interior/exterior/garage fraction of lamps that are LFL/CFL/LED
# - interior/exterior/garage usage multipliers
Expand Down
Loading