urbanopt-cli 0.8.2 → 0.9.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +5 -6
- data/CHANGELOG.md +21 -0
- data/CMakeLists.txt +7 -7
- data/Gemfile +3 -1
- data/README.md +9 -0
- data/example_files/Gemfile +23 -16
- data/example_files/Gemfile.lock +177 -0
- data/example_files/base_workflow_res.osw +57 -14
- data/example_files/class_project_coincident.json +1322 -0
- data/example_files/class_project_diverse.json +1322 -0
- data/example_files/disco/config.json +42 -0
- data/example_files/disco/cost_database.xlsx +0 -0
- data/example_files/disco/technical_catalog.json +12126 -0
- data/example_files/mappers/Baseline.rb +10 -7
- data/example_files/mappers/ChilledWaterStorage.rb +98 -0
- data/example_files/mappers/ClassProject.rb +110 -0
- data/example_files/mappers/CreateBar.rb +1 -0
- data/example_files/mappers/HighEfficiency.rb +13 -11
- data/example_files/mappers/PeakHoursMelsShedding.rb +72 -0
- data/example_files/mappers/PeakHoursThermostatAdjust.rb +78 -0
- data/example_files/mappers/ThermalStorage.rb +1 -0
- data/example_files/mappers/base_workflow.osw +55 -14
- data/example_files/mappers/class_project_workflow.osw +328 -0
- data/example_files/mappers/createbar_workflow.osw +16 -16
- data/example_files/measures/BuildResidentialModel/measure.rb +7 -1
- data/example_files/measures/BuildResidentialModel/measure.xml +1313 -706
- data/example_files/opendss/electrical_database.json +1446 -1446
- data/example_files/python_deps/dependencies.json +5 -0
- data/example_files/python_deps/install_python.ps1 +96 -0
- data/example_files/python_deps/install_python.sh +120 -0
- data/example_files/residential/clothes_dryer.tsv +11 -11
- data/example_files/residential/clothes_washer.tsv +3 -3
- data/example_files/residential/dishwasher.tsv +3 -3
- data/example_files/resources/hpxml-measures/.github/pull_request_template.md +0 -1
- data/example_files/resources/hpxml-measures/.github/workflows/config.yml +8 -21
- data/example_files/resources/hpxml-measures/.gitignore +2 -0
- data/example_files/resources/hpxml-measures/BuildResidentialHPXML/measure.rb +1272 -1094
- data/example_files/resources/hpxml-measures/BuildResidentialHPXML/measure.xml +978 -659
- data/example_files/resources/hpxml-measures/BuildResidentialHPXML/resources/geometry.rb +52 -74
- data/example_files/resources/hpxml-measures/BuildResidentialHPXML/tests/build_residential_hpxml_test.rb +77 -140
- data/example_files/resources/hpxml-measures/BuildResidentialScheduleFile/measure.rb +30 -27
- data/example_files/resources/hpxml-measures/BuildResidentialScheduleFile/measure.xml +32 -13
- data/example_files/resources/hpxml-measures/BuildResidentialScheduleFile/resources/schedules.rb +55 -51
- data/example_files/resources/hpxml-measures/BuildResidentialScheduleFile/tests/build_residential_schedule_file_test.rb +89 -16
- data/example_files/resources/hpxml-measures/Changelog.md +65 -0
- data/example_files/resources/hpxml-measures/Gemfile +2 -4
- data/example_files/resources/hpxml-measures/Gemfile.lock +2 -13
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/measure.rb +276 -300
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/measure.xml +221 -215
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/airflow.rb +215 -170
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/battery.rb +108 -16
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/constants.rb +24 -44
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/constructions.rb +564 -197
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/data/cambium/README.md +8 -8
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/energyplus.rb +1 -0
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/geometry.rb +7 -55
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/hotwater_appliances.rb +24 -19
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/hpxml.rb +541 -211
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/hpxml_defaults.rb +300 -172
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/hpxml_schema/HPXML.xsd +0 -2
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/hpxml_schema/HPXMLBaseElements.xsd +230 -141
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/hpxml_schema/HPXMLDataTypes.xsd +145 -137
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/hpxml_schematron/EPvalidator.xml +191 -97
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/hpxml_schematron/iso-schematron.xsd +391 -0
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/hvac.rb +194 -198
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/hvac_sizing.rb +140 -145
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/lighting.rb +11 -11
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/location.rb +33 -1
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/materials.rb +4 -4
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/meta_measure.rb +17 -9
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/misc_loads.rb +14 -12
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/output.rb +39 -17
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/psychrometrics.rb +1 -1
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/schedule_files/battery.csv +8761 -0
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/schedules.rb +114 -57
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/simcontrols.rb +1 -0
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/utility_bills.rb +148 -0
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/version.rb +2 -2
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/waterheater.rb +85 -127
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/weather.rb +26 -32
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/xmlhelper.rb +2 -14
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/xmlvalidator.rb +67 -0
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_airflow.rb +117 -56
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_battery.rb +141 -14
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_defaults.rb +453 -344
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_enclosure.rb +124 -20
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_generator.rb +1 -1
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_hotwater_appliance.rb +28 -32
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_hvac.rb +172 -79
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_hvac_sizing.rb +54 -8
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_lighting.rb +3 -3
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_location.rb +4 -4
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_miscloads.rb +7 -7
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_pv.rb +1 -1
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_schedules.rb +6 -9
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_simcontrols.rb +8 -8
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_validation.rb +213 -95
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_water_heater.rb +1 -10
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/tests/test_weather.rb +76 -0
- data/example_files/resources/hpxml-measures/README.md +2 -3
- data/example_files/resources/hpxml-measures/ReportSimulationOutput/measure.rb +585 -287
- data/example_files/resources/hpxml-measures/ReportSimulationOutput/measure.xml +304 -352
- data/example_files/resources/hpxml-measures/ReportSimulationOutput/tests/output_report_test.rb +404 -279
- data/example_files/resources/hpxml-measures/ReportUtilityBills/measure.rb +222 -501
- data/example_files/resources/hpxml-measures/ReportUtilityBills/measure.xml +137 -200
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/Sample Flat Rate Min Annual Charge.json +649 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/Sample Flat Rate Min Monthly Charge.json +649 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/Sample Flat Rate.json +647 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/Sample Real-Time Pricing Rate Min Annual Charge.json +8776 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/Sample Real-Time Pricing Rate Min Monthly Charge.json +8776 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/Sample Real-Time Pricing Rate.json +8774 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/Sample Tiered Rate Min Annual Charge.json +659 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/Sample Tiered Rate Min Monthly Charge.json +659 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/Sample Tiered Rate.json +657 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/Sample Tiered Time-of-Use Rate Min Annual Charge.json +670 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/Sample Tiered Time-of-Use Rate Min Monthly Charge.json +670 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/Sample Tiered Time-of-Use Rate.json +668 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/Sample Time-of-Use Rate Min Annual Charge.json +655 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/Sample Time-of-Use Rate Min Monthly Charge.json +655 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/Sample Time-of-Use Rate.json +653 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/detailed_rates/openei_rates.zip +0 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/{Data/UtilityRates → simple_rates}/Average_retail_price_of_electricity.csv +0 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/{Data/UtilityRates → simple_rates}/HouseholdConsumption.csv +0 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/{Data/UtilityRates → simple_rates}/NG_PRI_SUM_A_EPG0_PRS_DMCF_A.csv +0 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/{Data/UtilityRates → simple_rates}/PET_PRI_WFR_A_EPD2F_PRS_DPGAL_W.csv +0 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/{Data/UtilityRates → simple_rates}/PET_PRI_WFR_A_EPLLPA_PRS_DPGAL_W.csv +0 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/{Data/UtilityRates → simple_rates}/README.md +0 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/resources/util.rb +506 -25
- data/example_files/resources/hpxml-measures/ReportUtilityBills/tests/Contains Demand Charges.json +1312 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/tests/Invalid Fixed Charge Units.json +657 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/tests/Invalid Min Charge Units.json +659 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/tests/JacksonElectricMemberCorp-ResidentialSeniorCitizenLowIncomeAssistance.json +681 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/tests/Missing Required Fields.json +54 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/tests/data.csv +8761 -0
- data/example_files/resources/hpxml-measures/ReportUtilityBills/tests/utility_bills_test.rb +1006 -235
- data/example_files/resources/hpxml-measures/docs/source/conf.py +1 -1
- data/example_files/resources/hpxml-measures/docs/source/intro.rst +0 -1
- data/example_files/resources/hpxml-measures/docs/source/usage_instructions.rst +2 -2
- data/example_files/resources/hpxml-measures/docs/source/workflow_inputs.rst +461 -261
- data/example_files/resources/hpxml-measures/docs/source/workflow_outputs.rst +146 -152
- data/example_files/resources/hpxml-measures/tasks.rb +616 -802
- data/example_files/resources/hpxml-measures/workflow/real_homes/house001.xml +19 -11
- data/example_files/resources/hpxml-measures/workflow/real_homes/house002.xml +20 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house003.xml +12 -7
- data/example_files/resources/hpxml-measures/workflow/real_homes/house004.xml +12 -7
- data/example_files/resources/hpxml-measures/workflow/real_homes/house005.xml +19 -11
- data/example_files/resources/hpxml-measures/workflow/real_homes/house006.xml +12 -7
- data/example_files/resources/hpxml-measures/workflow/real_homes/house007.xml +20 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house008.xml +28 -16
- data/example_files/resources/hpxml-measures/workflow/real_homes/house009.xml +28 -17
- data/example_files/resources/hpxml-measures/workflow/real_homes/house010.xml +28 -16
- data/example_files/resources/hpxml-measures/workflow/real_homes/house011.xml +20 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house012.xml +20 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house013.xml +20 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house014.xml +20 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house015.xml +20 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house016.xml +22 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house017.xml +19 -11
- data/example_files/resources/hpxml-measures/workflow/real_homes/house018.xml +20 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house019.xml +13 -7
- data/example_files/resources/hpxml-measures/workflow/real_homes/house020.xml +12 -7
- data/example_files/resources/hpxml-measures/workflow/real_homes/house021.xml +31 -16
- data/example_files/resources/hpxml-measures/workflow/real_homes/house022.xml +22 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house023.xml +21 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house024.xml +37 -22
- data/example_files/resources/hpxml-measures/workflow/real_homes/house025.xml +24 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house026.xml +33 -21
- data/example_files/resources/hpxml-measures/workflow/real_homes/house027.xml +28 -16
- data/example_files/resources/hpxml-measures/workflow/real_homes/house028.xml +28 -16
- data/example_files/resources/hpxml-measures/workflow/real_homes/house029.xml +30 -17
- data/example_files/resources/hpxml-measures/workflow/real_homes/house030.xml +10 -7
- data/example_files/resources/hpxml-measures/workflow/real_homes/house031.xml +22 -11
- data/example_files/resources/hpxml-measures/workflow/real_homes/house032.xml +12 -7
- data/example_files/resources/hpxml-measures/workflow/real_homes/house033.xml +18 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house034.xml +25 -16
- data/example_files/resources/hpxml-measures/workflow/real_homes/house035.xml +22 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house036.xml +20 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house037.xml +26 -17
- data/example_files/resources/hpxml-measures/workflow/real_homes/house038.xml +19 -11
- data/example_files/resources/hpxml-measures/workflow/real_homes/house039.xml +25 -16
- data/example_files/resources/hpxml-measures/workflow/real_homes/house040.xml +20 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house041.xml +35 -21
- data/example_files/resources/hpxml-measures/workflow/real_homes/house042.xml +28 -17
- data/example_files/resources/hpxml-measures/workflow/real_homes/house043.xml +20 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house044.xml +35 -21
- data/example_files/resources/hpxml-measures/workflow/real_homes/house045.xml +20 -12
- data/example_files/resources/hpxml-measures/workflow/real_homes/house046.xml +20 -13
- data/example_files/resources/hpxml-measures/workflow/real_homes/house047.xml +12 -9
- data/example_files/resources/hpxml-measures/workflow/real_homes/house048.xml +25 -14
- data/example_files/resources/hpxml-measures/workflow/real_homes/house049.xml +10 -7
- data/example_files/resources/hpxml-measures/workflow/real_homes/house050.xml +20 -11
- data/example_files/resources/hpxml-measures/workflow/run_simulation.rb +91 -88
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-appliances-coal.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-appliances-dehumidifier-ief-portable.xml +546 -535
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-appliances-dehumidifier-ief-whole-home.xml +546 -535
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-appliances-dehumidifier-multiple.xml +555 -544
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-appliances-dehumidifier.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-appliances-gas.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-appliances-modified.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-appliances-none.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-appliances-oil-location-miami-fl.xml +580 -569
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-appliances-oil.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-appliances-propane-location-portland-or.xml +580 -569
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-appliances-propane.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-appliances-wood.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-atticroof-cathedral.xml +7 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-atticroof-conditioned.xml +17 -6
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-atticroof-flat.xml +7 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-atticroof-radiant-barrier.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-atticroof-unvented-insulated-roof.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-atticroof-vented.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-battery-scheduled.xml +600 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-battery.xml +598 -587
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-adjacent-to-multifamily-buffer-space.xml +494 -485
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-adjacent-to-multiple.xml +606 -593
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-adjacent-to-non-freezing-space.xml +494 -485
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-adjacent-to-other-heated-space.xml +494 -485
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-adjacent-to-other-housing-unit.xml +494 -485
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-calctype-operational.xml +480 -471
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-boiler-chiller-baseboard.xml +464 -457
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-boiler-chiller-fan-coil-ducted.xml +496 -487
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-boiler-chiller-fan-coil.xml +466 -459
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-boiler-chiller-water-loop-heat-pump.xml +518 -509
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-boiler-cooling-tower-water-loop-heat-pump.xml +513 -504
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-boiler-only-baseboard.xml +445 -438
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-boiler-only-fan-coil-ducted.xml +476 -467
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-boiler-only-fan-coil-eae.xml +443 -436
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-boiler-only-fan-coil.xml +446 -439
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-boiler-only-water-loop-heat-pump.xml +494 -485
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-chiller-only-baseboard.xml +445 -438
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-chiller-only-fan-coil-ducted.xml +476 -467
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-chiller-only-fan-coil.xml +446 -439
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-chiller-only-water-loop-heat-pump.xml +494 -485
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-cooling-tower-only-water-loop-heat-pump.xml +489 -480
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-generator.xml +499 -490
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-ground-loop-ground-to-air-heat-pump.xml +491 -482
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-laundry-room-multiple-water-heaters.xml +510 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-laundry-room.xml +495 -486
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-mechvent-multiple.xml +709 -695
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-mechvent-preconditioning.xml +528 -519
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-mechvent.xml +512 -503
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-pv.xml +504 -495
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-water-heater-recirc.xml +497 -488
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily-shared-water-heater.xml +490 -481
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-multifamily.xml +487 -478
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-single-family-attached-2stories.xml +639 -628
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-single-family-attached-atticroof-cathedral.xml +587 -580
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-bldgtype-single-family-attached.xml +639 -628
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-calctype-operational-misc-defaults.xml +539 -528
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-calctype-operational-misc-loads-large-uncommon.xml +644 -633
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-calctype-operational-misc-loads-large-uncommon2.xml +644 -633
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-calctype-operational.xml +575 -564
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-combi-tankless-outside.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-combi-tankless.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-desuperheater-2-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-desuperheater-gshp.xml +585 -574
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-desuperheater-hpwh.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-desuperheater-tankless.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-desuperheater-var-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-desuperheater.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-dwhr.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-indirect-detailed-setpoints.xml +536 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-indirect-dse.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-indirect-outside.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-indirect-standbyloss.xml +20 -8
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-indirect-with-solar-fraction.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-indirect.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-jacket-electric.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-jacket-gas.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-jacket-hpwh.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-jacket-indirect.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-low-flow-fixtures.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-multiple.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-none.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-recirc-demand.xml +19 -8
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-recirc-manual.xml +19 -8
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-recirc-nocontrol.xml +19 -8
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-recirc-temperature.xml +19 -8
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-recirc-timer.xml +19 -8
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-solar-direct-evacuated-tube.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-solar-direct-flat-plate.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-solar-direct-ics.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-solar-fraction.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-solar-indirect-flat-plate.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-solar-thermosyphon-flat-plate.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-coal.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-detailed-setpoints.xml +582 -571
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-elec-uef.xml +583 -572
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-gas-outside.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-gas-uef-fhr.xml +584 -573
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-gas-uef.xml +584 -573
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-gas.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-heat-pump-detailed-schedules.xml +583 -572
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-heat-pump-operating-mode-heat-pump-only.xml +585 -574
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-heat-pump-outside.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-heat-pump-uef.xml +582 -571
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-heat-pump-with-solar-fraction.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-heat-pump-with-solar.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-heat-pump.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-model-type-stratified-detailed-occupancy-stochastic.xml +586 -575
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-model-type-stratified.xml +585 -574
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-oil.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tank-wood.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tankless-detailed-setpoints.xml +580 -569
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tankless-electric-outside.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tankless-electric-uef.xml +580 -569
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tankless-electric.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tankless-gas-uef.xml +580 -569
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tankless-gas-with-solar-fraction.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tankless-gas-with-solar.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tankless-gas.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-dhw-tankless-propane.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-2stories-garage.xml +28 -11
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-2stories.xml +20 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-beds-1.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-beds-2.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-beds-4.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-beds-5.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-ceilingtypes.xml +607 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-floortypes.xml +550 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-garage.xml +27 -12
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-infil-ach-house-pressure.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-infil-cfm-house-pressure.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-infil-cfm50.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-infil-flue.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-infil-natural-ach.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-orientations.xml +589 -578
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-overhangs.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-rooftypes.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-skylights-physical-properties.xml +619 -608
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-skylights-shading.xml +620 -609
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-skylights-storms.xml +618 -607
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-skylights.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-split-level.xml +537 -526
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-split-surfaces.xml +90 -43
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-split-surfaces2.xml +2507 -2460
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-thermal-mass.xml +595 -584
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-walltypes.xml +19 -8
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-windows-natural-ventilation-availability.xml +584 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-windows-none.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-windows-physical-properties.xml +594 -583
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-windows-shading.xml +597 -586
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-enclosure-windows-storms.xml +598 -587
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-foundation-ambient.xml +27 -12
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-foundation-basement-garage.xml +671 -656
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-foundation-complex.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-foundation-conditioned-basement-slab-insulation.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/{base-foundation-conditioned-basement-wall-interior-insulation.xml → base-foundation-conditioned-basement-wall-insulation.xml} +585 -574
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-foundation-conditioned-crawlspace.xml +582 -571
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-foundation-multiple.xml +35 -16
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-foundation-slab.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-foundation-unconditioned-basement-above-grade.xml +27 -12
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-foundation-unconditioned-basement-assembly-r.xml +27 -12
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-foundation-unconditioned-basement-wall-insulation.xml +27 -12
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-foundation-unconditioned-basement.xml +27 -12
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-foundation-unvented-crawlspace.xml +27 -12
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-foundation-vented-crawlspace.xml +27 -12
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-foundation-walkout-basement.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-air-to-air-heat-pump-1-speed-backup-lockout-temperature.xml +586 -575
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-air-to-air-heat-pump-1-speed-cooling-only.xml +573 -562
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-air-to-air-heat-pump-1-speed-heating-only.xml +580 -569
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-air-to-air-heat-pump-1-speed-seer2-hspf2.xml +583 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-air-to-air-heat-pump-1-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-air-to-air-heat-pump-2-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-air-to-air-heat-pump-var-speed-backup-boiler-switchover-temperature.xml +600 -589
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-air-to-air-heat-pump-var-speed-backup-boiler.xml +599 -588
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-air-to-air-heat-pump-var-speed-backup-furnace.xml +629 -616
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-air-to-air-heat-pump-var-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-air-to-air-heat-pump-1-speed-cooling-only.xml +573 -562
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-air-to-air-heat-pump-1-speed-heating-only.xml +579 -568
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-air-to-air-heat-pump-1-speed-sizing-methodology-acca.xml +581 -570
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-air-to-air-heat-pump-1-speed-sizing-methodology-hers.xml +581 -570
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-air-to-air-heat-pump-1-speed-sizing-methodology-maxload-miami-fl.xml +582 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-air-to-air-heat-pump-1-speed-sizing-methodology-maxload.xml +581 -570
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-air-to-air-heat-pump-2-speed-sizing-methodology-acca.xml +581 -570
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-air-to-air-heat-pump-2-speed-sizing-methodology-hers.xml +581 -570
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-air-to-air-heat-pump-2-speed-sizing-methodology-maxload.xml +581 -570
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-air-to-air-heat-pump-var-speed-backup-boiler.xml +598 -587
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-air-to-air-heat-pump-var-speed-backup-furnace.xml +628 -615
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-air-to-air-heat-pump-var-speed-sizing-methodology-acca.xml +581 -570
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-air-to-air-heat-pump-var-speed-sizing-methodology-hers.xml +581 -570
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-air-to-air-heat-pump-var-speed-sizing-methodology-maxload.xml +581 -570
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-boiler-elec-only.xml +535 -526
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-boiler-gas-central-ac-1-speed.xml +589 -578
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-boiler-gas-only.xml +536 -527
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-central-ac-only-1-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-central-ac-only-2-speed.xml +565 -554
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-central-ac-only-var-speed.xml +565 -554
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-central-ac-plus-air-to-air-heat-pump-heating.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-dual-fuel-air-to-air-heat-pump-1-speed-sizing-methodology-acca.xml +582 -571
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-dual-fuel-air-to-air-heat-pump-1-speed-sizing-methodology-hers.xml +582 -571
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-dual-fuel-air-to-air-heat-pump-1-speed-sizing-methodology-maxload.xml +582 -571
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-dual-fuel-mini-split-heat-pump-ducted.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-elec-resistance-only.xml +526 -517
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-evap-cooler-furnace-gas.xml +573 -562
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-floor-furnace-propane-only.xml +529 -520
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-furnace-elec-only.xml +565 -554
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-furnace-gas-central-ac-2-speed.xml +580 -569
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-furnace-gas-central-ac-var-speed.xml +580 -569
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-furnace-gas-only.xml +565 -554
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-furnace-gas-room-ac.xml +578 -567
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-ground-to-air-heat-pump-cooling-only.xml +575 -564
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-ground-to-air-heat-pump-heating-only.xml +581 -570
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-ground-to-air-heat-pump-sizing-methodology-acca.xml +583 -572
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-ground-to-air-heat-pump-sizing-methodology-hers.xml +583 -572
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-ground-to-air-heat-pump-sizing-methodology-maxload.xml +583 -572
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-mini-split-air-conditioner-only-ducted.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-mini-split-heat-pump-ducted-cooling-only.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-mini-split-heat-pump-ducted-heating-only.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-mini-split-heat-pump-ducted-sizing-methodology-acca.xml +580 -569
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-mini-split-heat-pump-ducted-sizing-methodology-hers.xml +580 -569
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-mini-split-heat-pump-ducted-sizing-methodology-maxload.xml +580 -569
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-mini-split-heat-pump-ductless-backup-stove.xml +551 -542
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-ptac-with-heating.xml +532 -530
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-ptac.xml +525 -516
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-pthp-sizing-methodology-acca.xml +541 -532
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-pthp-sizing-methodology-hers.xml +541 -532
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-pthp-sizing-methodology-maxload.xml +541 -532
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-room-ac-only.xml +525 -516
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-room-ac-with-heating.xml +533 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-room-ac-with-reverse-cycle-sizing-methodology-acca.xml +542 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-room-ac-with-reverse-cycle-sizing-methodology-hers.xml +542 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-room-ac-with-reverse-cycle-sizing-methodology-maxload.xml +542 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-stove-oil-only.xml +529 -520
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize-wall-furnace-elec-only.xml +529 -520
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-autosize.xml +580 -569
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-boiler-coal-only.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-boiler-elec-only.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-boiler-gas-central-ac-1-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-boiler-gas-only.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-boiler-oil-only.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-boiler-propane-only.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-boiler-wood-only.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-central-ac-only-1-speed-seer2.xml +567 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-central-ac-only-1-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-central-ac-only-2-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-central-ac-only-var-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-central-ac-plus-air-to-air-heat-pump-heating.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-dse.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-dual-fuel-air-to-air-heat-pump-1-speed-electric.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-dual-fuel-air-to-air-heat-pump-1-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-dual-fuel-air-to-air-heat-pump-2-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-dual-fuel-air-to-air-heat-pump-var-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-dual-fuel-mini-split-heat-pump-ducted.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-ducts-area-fractions.xml +611 -598
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-ducts-area-multipliers.xml +589 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-ducts-leakage-cfm50.xml +582 -571
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-ducts-leakage-percent.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-elec-resistance-only.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-evap-cooler-furnace-gas.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-evap-cooler-only-ducted.xml +17 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-evap-cooler-only.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-fireplace-wood-only.xml +530 -521
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-fixed-heater-gas-only.xml +530 -521
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-floor-furnace-propane-only.xml +530 -521
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-furnace-coal-only.xml +566 -555
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-furnace-elec-central-ac-1-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-furnace-elec-only.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-furnace-gas-central-ac-2-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-furnace-gas-central-ac-var-speed.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-furnace-gas-only-detailed-setpoints.xml +566 -555
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-furnace-gas-only.xml +566 -555
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-furnace-gas-room-ac.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-furnace-oil-only.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-furnace-propane-only.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-furnace-wood-only.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-furnace-x3-dse.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-ground-to-air-heat-pump-cooling-only.xml +574 -563
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-ground-to-air-heat-pump-heating-only.xml +581 -570
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-ground-to-air-heat-pump.xml +583 -572
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-install-quality-air-to-air-heat-pump-1-speed.xml +587 -576
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-install-quality-air-to-air-heat-pump-2-speed.xml +587 -576
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-install-quality-air-to-air-heat-pump-var-speed.xml +587 -576
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-install-quality-furnace-gas-central-ac-1-speed.xml +591 -580
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-install-quality-furnace-gas-central-ac-2-speed.xml +591 -580
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-install-quality-furnace-gas-central-ac-var-speed.xml +591 -580
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-install-quality-furnace-gas-only.xml +570 -559
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-install-quality-ground-to-air-heat-pump.xml +586 -575
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-install-quality-mini-split-air-conditioner-only-ducted.xml +570 -559
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-install-quality-mini-split-heat-pump-ducted.xml +586 -575
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-mini-split-air-conditioner-only-ducted.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-mini-split-air-conditioner-only-ductless.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-mini-split-heat-pump-ducted-cooling-only.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-mini-split-heat-pump-ducted-heating-only.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-mini-split-heat-pump-ducted.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-mini-split-heat-pump-ductless-backup-stove.xml +552 -543
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-mini-split-heat-pump-ductless.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-multiple.xml +963 -938
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-none.xml +33 -69
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-portable-heater-gas-only.xml +530 -521
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-ptac-with-heating-electricity.xml +535 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/{base-hvac-ptac-with-heating.xml → base-hvac-ptac-with-heating-natural-gas.xml} +23 -21
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-ptac.xml +526 -517
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-pthp.xml +541 -532
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-room-ac-only-33percent.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-room-ac-only-ceer.xml +526 -517
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-room-ac-only-detailed-setpoints.xml +526 -517
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-room-ac-only.xml +16 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-room-ac-with-heating.xml +535 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-room-ac-with-reverse-cycle.xml +542 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-seasons.xml +594 -583
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-setpoints-daily-schedules.xml +586 -575
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-setpoints-daily-setbacks.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-setpoints.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-stove-oil-only.xml +530 -521
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-stove-wood-pellets-only.xml +530 -521
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-undersized-allow-increased-fixed-capacities.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-undersized.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-hvac-wall-furnace-elec-only.xml +530 -521
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-lighting-ceiling-fans.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-lighting-holiday.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-lighting-none.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-location-AMY-2012.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-location-baltimore-md.xml +27 -12
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-location-capetown-zaf.xml +591 -576
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-location-dallas-tx.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-location-duluth-mn.xml +27 -12
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-location-helena-mt.xml +582 -571
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-location-honolulu-hi.xml +537 -526
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-location-miami-fl.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-location-phoenix-az.xml +537 -526
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-location-portland-or.xml +601 -586
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-balanced.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-bath-kitchen-fans.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-cfis-airflow-fraction-zero.xml +601 -587
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-cfis-dse.xml +19 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-cfis-evap-cooler-only-ducted.xml +20 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-cfis-supplemental-fan-exhaust.xml +607 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-cfis-supplemental-fan-supply.xml +607 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-cfis.xml +21 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-erv-atre-asre.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-erv.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-exhaust-rated-flow-rate.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-exhaust.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-hrv-asre.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-hrv.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-multiple.xml +37 -19
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-supply.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-mechvent-whole-house-fan.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-additional-properties.xml +590 -579
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-bills-none.xml +578 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-bills-pv-detailed-only.xml +632 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-bills-pv-mixed.xml +614 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-bills-pv.xml +677 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-bills.xml +593 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-defaults.xml +27 -9
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-emissions.xml +676 -665
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-generators-battery-scheduled.xml +616 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-generators-battery.xml +615 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-generators.xml +598 -587
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-ground-conductivity.xml +586 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-loads-large-uncommon.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-loads-large-uncommon2.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-loads-none.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-neighbor-shading.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-shielding-of-home.xml +583 -572
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-misc-usage-multiplier.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-multiple-buildings.xml +1700 -1677
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-pv-battery-ah.xml +622 -611
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-pv-battery-garage.xml +697 -682
- data/example_files/resources/hpxml-measures/workflow/sample_files/{base-pv-battery-lifetime-model.xml → base-pv-battery-round-trip-efficiency.xml} +20 -11
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-pv-battery-scheduled.xml +624 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-pv-battery.xml +622 -611
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-pv-generators-battery-scheduled.xml +640 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-pv-generators-battery.xml +639 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-pv-generators.xml +623 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-pv.xml +606 -595
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-schedules-detailed-all-10-mins.xml +582 -571
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-schedules-detailed-occupancy-smooth.xml +583 -572
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-schedules-detailed-occupancy-stochastic-10-mins.xml +584 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-schedules-detailed-occupancy-stochastic-vacancy.xml +583 -572
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-schedules-detailed-occupancy-stochastic.xml +583 -572
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-schedules-detailed-setpoints-daily-schedules.xml +581 -570
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-schedules-detailed-setpoints-daily-setbacks.xml +581 -570
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-schedules-detailed-setpoints.xml +581 -570
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-schedules-simple.xml +636 -625
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-simcontrol-calendar-year-custom.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-simcontrol-daylight-saving-custom.xml +27 -14
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-simcontrol-daylight-saving-disabled.xml +21 -10
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-simcontrol-runperiod-1-month.xml +21 -10
- data/example_files/resources/hpxml-measures/workflow/sample_files/{base-dhw-tank-heat-pump-detailed-operating-modes.xml → base-simcontrol-temperature-capacitance-multiplier.xml} +25 -13
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-simcontrol-timestep-10-mins-occupancy-stochastic-10-mins.xml +584 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-simcontrol-timestep-10-mins-occupancy-stochastic-60-mins.xml +584 -0
- data/example_files/resources/hpxml-measures/workflow/sample_files/base-simcontrol-timestep-10-mins.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/sample_files/{base-dhw-tank-heat-pump-detailed-setpoints.xml → base-simcontrol-timestep-30-mins.xml} +25 -14
- data/example_files/resources/hpxml-measures/workflow/sample_files/base.xml +18 -7
- data/example_files/resources/hpxml-measures/workflow/template-build-and-run-hpxml-with-stochastic-occupancy.osw +18 -13
- data/example_files/resources/hpxml-measures/workflow/template-run-hpxml-with-stochastic-occupancy.osw +12 -7
- data/example_files/resources/hpxml-measures/workflow/template-run-hpxml.osw +8 -24
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L100AC.xml +366 -358
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L100AL.xml +369 -361
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L110AC.xml +369 -361
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L110AL.xml +369 -361
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L120AC.xml +369 -361
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L120AL.xml +369 -361
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L130AC.xml +369 -361
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L130AL.xml +369 -361
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L140AC.xml +311 -303
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L140AL.xml +311 -303
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L150AC.xml +327 -319
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L150AL.xml +327 -319
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L155AC.xml +332 -324
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L155AL.xml +332 -324
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L160AC.xml +341 -333
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L160AL.xml +341 -333
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L170AC.xml +369 -361
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L170AL.xml +369 -361
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L200AC.xml +369 -361
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L200AL.xml +369 -361
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L202AC.xml +369 -361
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L202AL.xml +369 -361
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L302XC.xml +383 -379
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L304XC.xml +383 -379
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L322XC.xml +538 -534
- data/example_files/resources/hpxml-measures/workflow/tests/ASHRAE_Standard_140/L324XC.xml +550 -546
- data/example_files/resources/hpxml-measures/workflow/tests/base_results/results.csv +444 -410
- data/example_files/resources/hpxml-measures/workflow/tests/base_results/results_ashrae_140.csv +8 -8
- data/example_files/resources/hpxml-measures/workflow/tests/base_results/results_bills.csv +444 -410
- data/example_files/resources/hpxml-measures/workflow/tests/compare.py +18 -4
- data/example_files/resources/hpxml-measures/workflow/tests/hpxml_translator_test.rb +133 -288
- data/example_files/scripts/convert_urbanopt_to_disco.py +130 -0
- data/example_files/scripts/default_control_changes.csv +8 -0
- data/example_files/scripts/default_voltage_regulators.csv +3 -0
- data/example_files/scripts/read_data.py +331 -0
- data/example_files/visualization/input_visualization_feature.html +172 -81
- data/example_files/visualization/input_visualization_scenario.html +178 -82
- data/example_files/xml_building/17/README.md +2 -2
- data/example_files/xml_building/17/unit 1.xml +40 -41
- data/example_files/xml_building/17/unit 2.xml +35 -36
- data/example_files/xml_building/17/unit 3.xml +35 -36
- data/example_files/xml_building/17/unit 4.xml +41 -42
- data/lib/uo_cli/version.rb +1 -1
- data/lib/uo_cli.rb +601 -101
- data/scripts/setup-env.bat +6 -7
- data/uo_cli.gemspec +6 -5
- metadata +121 -36
- data/example_files/residential/exhaust.tsv +0 -3
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/data/hvac_equipment_efficiency.csv +0 -493
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/data/water_heater_efficiency.csv +0 -157
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/hpxml_schematron/HPXMLvalidator.xml +0 -620
- data/example_files/resources/hpxml-measures/HPXMLtoOpenStudio/resources/validator.rb +0 -107
- data/example_files/resources/hpxml-measures/ReportHPXMLOutput/measure.rb +0 -450
- data/example_files/resources/hpxml-measures/ReportHPXMLOutput/measure.xml +0 -85
- data/example_files/resources/hpxml-measures/ReportHPXMLOutput/resources/constants.rb +0 -72
- data/example_files/resources/hpxml-measures/ReportHPXMLOutput/tests/hpxml_output_report_test.rb +0 -290
- data/example_files/resources/hpxml-measures/ReportUtilityBills/tests/PV_10kW.csv +0 -8761
- data/example_files/resources/hpxml-measures/ReportUtilityBills/tests/PV_1kW.csv +0 -8761
- data/example_files/resources/hpxml-measures/ReportUtilityBills/tests/PV_None.csv +0 -8761
- data/example_files/resources/hpxml-measures/workflow/tests/base_results/results_hvac_sizing.csv +0 -410
@@ -3,23 +3,15 @@
|
|
3
3
|
class Waterheater
|
4
4
|
def self.apply_tank(model, runner, loc_space, loc_schedule, water_heating_system, ec_adj, solar_thermal_system, eri_version, schedules_file)
|
5
5
|
solar_fraction = get_water_heater_solar_fraction(water_heating_system, solar_thermal_system)
|
6
|
-
|
7
|
-
|
8
|
-
default_set_temp_c = set_temp_c if !set_temp_c.nil?
|
9
|
-
loop = create_new_loop(model, Constants.ObjectNamePlantLoopDHW, default_set_temp_c)
|
10
|
-
|
11
|
-
new_pump = create_new_pump(model)
|
12
|
-
new_pump.addToNode(loop.supplyInletNode)
|
13
|
-
|
14
|
-
new_manager = create_new_schedule_manager(model, default_set_temp_c)
|
15
|
-
new_manager.addToNode(loop.supplyOutletNode)
|
6
|
+
t_set_c = get_t_set_c(water_heating_system.temperature, water_heating_system.water_heater_type)
|
7
|
+
loop = create_new_loop(model, Constants.ObjectNamePlantLoopDHW, t_set_c, eri_version)
|
16
8
|
|
17
9
|
act_vol = calc_storage_tank_actual_vol(water_heating_system.tank_volume, water_heating_system.fuel_type)
|
18
10
|
u, ua, eta_c = calc_tank_UA(act_vol, water_heating_system, solar_fraction)
|
19
11
|
new_heater = create_new_heater(name: Constants.ObjectNameWaterHeater,
|
20
12
|
water_heating_system: water_heating_system,
|
21
13
|
act_vol: act_vol,
|
22
|
-
t_set_c:
|
14
|
+
t_set_c: t_set_c,
|
23
15
|
loc_space: loc_space,
|
24
16
|
loc_schedule: loc_schedule,
|
25
17
|
model: model,
|
@@ -31,31 +23,23 @@ class Waterheater
|
|
31
23
|
loop.addSupplyBranchForComponent(new_heater)
|
32
24
|
|
33
25
|
add_ec_adj(model, new_heater, ec_adj, loc_space, water_heating_system)
|
34
|
-
add_desuperheater(model, runner, water_heating_system, new_heater, loc_space, loc_schedule, loop
|
26
|
+
add_desuperheater(model, runner, water_heating_system, new_heater, loc_space, loc_schedule, loop)
|
35
27
|
|
36
28
|
return loop
|
37
29
|
end
|
38
30
|
|
39
|
-
def self.apply_tankless(model, runner, loc_space, loc_schedule, water_heating_system, ec_adj,
|
31
|
+
def self.apply_tankless(model, runner, loc_space, loc_schedule, water_heating_system, ec_adj, solar_thermal_system, eri_version, schedules_file)
|
40
32
|
water_heating_system.heating_capacity = 100000000000.0
|
41
33
|
solar_fraction = get_water_heater_solar_fraction(water_heating_system, solar_thermal_system)
|
42
|
-
|
43
|
-
|
44
|
-
default_set_temp_c = set_temp_c if !set_temp_c.nil?
|
45
|
-
loop = create_new_loop(model, Constants.ObjectNamePlantLoopDHW, default_set_temp_c)
|
46
|
-
|
47
|
-
new_pump = create_new_pump(model)
|
48
|
-
new_pump.addToNode(loop.supplyInletNode)
|
49
|
-
|
50
|
-
new_manager = create_new_schedule_manager(model, default_set_temp_c)
|
51
|
-
new_manager.addToNode(loop.supplyOutletNode)
|
34
|
+
t_set_c = get_t_set_c(water_heating_system.temperature, water_heating_system.water_heater_type)
|
35
|
+
loop = create_new_loop(model, Constants.ObjectNamePlantLoopDHW, t_set_c, eri_version)
|
52
36
|
|
53
37
|
act_vol = 1.0
|
54
|
-
|
38
|
+
_u, ua, eta_c = calc_tank_UA(act_vol, water_heating_system, solar_fraction)
|
55
39
|
new_heater = create_new_heater(name: Constants.ObjectNameWaterHeater,
|
56
40
|
water_heating_system: water_heating_system,
|
57
41
|
act_vol: act_vol,
|
58
|
-
t_set_c:
|
42
|
+
t_set_c: t_set_c,
|
59
43
|
loc_space: loc_space,
|
60
44
|
loc_schedule: loc_schedule,
|
61
45
|
model: model,
|
@@ -67,7 +51,7 @@ class Waterheater
|
|
67
51
|
loop.addSupplyBranchForComponent(new_heater)
|
68
52
|
|
69
53
|
add_ec_adj(model, new_heater, ec_adj, loc_space, water_heating_system)
|
70
|
-
add_desuperheater(model, runner, water_heating_system, new_heater, loc_space, loc_schedule, loop
|
54
|
+
add_desuperheater(model, runner, water_heating_system, new_heater, loc_space, loc_schedule, loop)
|
71
55
|
|
72
56
|
return loop
|
73
57
|
end
|
@@ -75,16 +59,8 @@ class Waterheater
|
|
75
59
|
def self.apply_heatpump(model, runner, loc_space, loc_schedule, weather, water_heating_system, ec_adj, solar_thermal_system, living_zone, eri_version, schedules_file)
|
76
60
|
obj_name_hpwh = Constants.ObjectNameWaterHeater
|
77
61
|
solar_fraction = get_water_heater_solar_fraction(water_heating_system, solar_thermal_system)
|
78
|
-
|
79
|
-
|
80
|
-
default_set_temp_c = set_temp_c if !set_temp_c.nil?
|
81
|
-
loop = create_new_loop(model, Constants.ObjectNamePlantLoopDHW, default_set_temp_c)
|
82
|
-
|
83
|
-
new_pump = create_new_pump(model)
|
84
|
-
new_pump.addToNode(loop.supplyInletNode)
|
85
|
-
|
86
|
-
new_manager = create_new_schedule_manager(model, default_set_temp_c)
|
87
|
-
new_manager.addToNode(loop.supplyOutletNode)
|
62
|
+
t_set_c = get_t_set_c(water_heating_system.temperature, water_heating_system.water_heater_type)
|
63
|
+
loop = create_new_loop(model, Constants.ObjectNamePlantLoopDHW, t_set_c, eri_version)
|
88
64
|
|
89
65
|
h_tank = 0.0188 * water_heating_system.tank_volume + 0.0935 # Linear relationship that gets GE height at 50 gal and AO Smith height at 80 gal
|
90
66
|
|
@@ -97,11 +73,11 @@ class Waterheater
|
|
97
73
|
hpwh_rhamb.setName("#{obj_name_hpwh} RHamb act")
|
98
74
|
hpwh_rhamb.setValue(0.5)
|
99
75
|
|
76
|
+
# Note: These get overwritten by EMS later, see HPWH Control program
|
77
|
+
top_element_setpoint_schedule = OpenStudio::Model::ScheduleConstant.new(model)
|
78
|
+
top_element_setpoint_schedule.setName("#{obj_name_hpwh} TopElementSetpoint")
|
100
79
|
bottom_element_setpoint_schedule = OpenStudio::Model::ScheduleConstant.new(model)
|
101
80
|
bottom_element_setpoint_schedule.setName("#{obj_name_hpwh} BottomElementSetpoint")
|
102
|
-
bottom_element_setpoint_schedule.setValue(-60)
|
103
|
-
|
104
|
-
water_heater_offset = 9.0 # deg-C
|
105
81
|
|
106
82
|
setpoint_schedule = nil
|
107
83
|
if not schedules_file.nil?
|
@@ -114,28 +90,16 @@ class Waterheater
|
|
114
90
|
# Actuated schedule
|
115
91
|
control_setpoint_schedule = OpenStudio::Model::ScheduleConstant.new(model)
|
116
92
|
control_setpoint_schedule.setName("#{obj_name_hpwh} ControlSetpoint")
|
117
|
-
control_setpoint_schedule.setValue(default_set_temp_c)
|
118
|
-
|
119
|
-
# Note: This gets overwritten by EMS later, see HPWH Control program
|
120
|
-
top_element_setpoint_schedule = OpenStudio::Model::ScheduleConstant.new(model)
|
121
|
-
top_element_setpoint_schedule.setName("#{obj_name_hpwh} TopElementSetpoint")
|
122
|
-
top_element_setpoint_schedule.setValue(default_set_temp_c - water_heater_offset)
|
123
93
|
end
|
124
94
|
end
|
125
95
|
if setpoint_schedule.nil?
|
126
|
-
tset_C = UnitConversions.convert(water_heating_system.temperature, 'F', 'C')
|
127
|
-
|
128
96
|
setpoint_schedule = OpenStudio::Model::ScheduleConstant.new(model)
|
129
97
|
setpoint_schedule.setName("#{obj_name_hpwh} Setpoint")
|
130
|
-
setpoint_schedule.setValue(
|
98
|
+
setpoint_schedule.setValue(t_set_c)
|
131
99
|
|
132
100
|
control_setpoint_schedule = setpoint_schedule
|
133
|
-
|
134
|
-
top_element_setpoint_schedule = OpenStudio::Model::ScheduleConstant.new(model)
|
135
|
-
top_element_setpoint_schedule.setName("#{obj_name_hpwh} TopElementSetpoint")
|
136
|
-
top_element_setpoint_schedule.setValue(tset_C - water_heater_offset)
|
137
101
|
else
|
138
|
-
runner.registerWarning("Both '#{SchedulesFile::ColumnWaterHeaterSetpoint}' schedule file and setpoint temperature provided; the latter will be ignored.") if !
|
102
|
+
runner.registerWarning("Both '#{SchedulesFile::ColumnWaterHeaterSetpoint}' schedule file and setpoint temperature provided; the latter will be ignored.") if !t_set_c.nil?
|
139
103
|
end
|
140
104
|
|
141
105
|
airflow_rate = 181.0 # cfm
|
@@ -149,7 +113,7 @@ class Waterheater
|
|
149
113
|
tank = setup_hpwh_stratified_tank(model, water_heating_system, obj_name_hpwh, h_tank, solar_fraction, hpwh_tamb, bottom_element_setpoint_schedule, top_element_setpoint_schedule)
|
150
114
|
loop.addSupplyBranchForComponent(tank)
|
151
115
|
|
152
|
-
add_desuperheater(model, runner, water_heating_system, tank, loc_space, loc_schedule, loop
|
116
|
+
add_desuperheater(model, runner, water_heating_system, tank, loc_space, loc_schedule, loop)
|
153
117
|
|
154
118
|
# Fan:SystemModel
|
155
119
|
fan = setup_hpwh_fan(model, water_heating_system, obj_name_hpwh, airflow_rate)
|
@@ -159,7 +123,7 @@ class Waterheater
|
|
159
123
|
|
160
124
|
# Amb temp & RH sensors, temp sensor shared across programs
|
161
125
|
amb_temp_sensor, amb_rh_sensors = get_loc_temp_rh_sensors(model, obj_name_hpwh, loc_schedule, loc_space, living_zone)
|
162
|
-
hpwh_inlet_air_program = add_hpwh_inlet_air_and_zone_heat_gain_program(model, obj_name_hpwh, loc_space,
|
126
|
+
hpwh_inlet_air_program = add_hpwh_inlet_air_and_zone_heat_gain_program(model, obj_name_hpwh, loc_space, hpwh_tamb, hpwh_rhamb, tank, coil, fan, amb_temp_sensor, amb_rh_sensors)
|
163
127
|
|
164
128
|
# EMS for the HPWH control logic
|
165
129
|
op_mode = water_heating_system.operating_mode
|
@@ -188,7 +152,7 @@ class Waterheater
|
|
188
152
|
obj_name_combi = Constants.ObjectNameWaterHeater
|
189
153
|
|
190
154
|
if water_heating_system.water_heater_type == HPXML::WaterHeaterTypeCombiStorage
|
191
|
-
if water_heating_system.
|
155
|
+
if water_heating_system.standby_loss_value <= 0
|
192
156
|
fail 'A negative indirect water heater standby loss was calculated, double check water heater inputs.'
|
193
157
|
end
|
194
158
|
|
@@ -200,22 +164,14 @@ class Waterheater
|
|
200
164
|
act_vol = 1.0
|
201
165
|
end
|
202
166
|
|
203
|
-
|
204
|
-
|
205
|
-
default_set_temp_c = set_temp_c if !set_temp_c.nil?
|
206
|
-
loop = create_new_loop(model, Constants.ObjectNamePlantLoopDHW, default_set_temp_c)
|
207
|
-
|
208
|
-
new_pump = create_new_pump(model)
|
209
|
-
new_pump.addToNode(loop.supplyInletNode)
|
210
|
-
|
211
|
-
new_manager = create_new_schedule_manager(model, default_set_temp_c)
|
212
|
-
new_manager.addToNode(loop.supplyOutletNode)
|
167
|
+
t_set_c = get_t_set_c(water_heating_system.temperature, water_heating_system.water_heater_type)
|
168
|
+
loop = create_new_loop(model, Constants.ObjectNamePlantLoopDHW, t_set_c, eri_version)
|
213
169
|
|
214
170
|
# Create water heater
|
215
171
|
new_heater = create_new_heater(name: obj_name_combi,
|
216
172
|
water_heating_system: water_heating_system,
|
217
173
|
act_vol: act_vol,
|
218
|
-
t_set_c:
|
174
|
+
t_set_c: t_set_c,
|
219
175
|
loc_space: loc_space,
|
220
176
|
loc_schedule: loc_schedule,
|
221
177
|
model: model,
|
@@ -230,12 +186,8 @@ class Waterheater
|
|
230
186
|
new_heater.additionalProperties.setFeature('EnergyFactor', ef) # Used by reporting measure
|
231
187
|
|
232
188
|
# Create alternate setpoint schedule for source side flow request
|
233
|
-
alternate_stp_sch =
|
189
|
+
alternate_stp_sch = new_heater.setpointTemperatureSchedule.get.clone(model).to_Schedule.get
|
234
190
|
alternate_stp_sch.setName("#{obj_name_combi} Alt Spt")
|
235
|
-
alt_temp = get_set_temp_c(water_heating_system.temperature, water_heating_system.water_heater_type)
|
236
|
-
default_alt_temp = get_set_temp_c(Waterheater.get_default_hot_water_temperature(eri_version), water_heating_system.water_heater_type)
|
237
|
-
default_alt_temp = alt_temp if !alt_temp.nil?
|
238
|
-
alternate_stp_sch.setValue(default_alt_temp)
|
239
191
|
new_heater.setIndirectAlternateSetpointTemperatureSchedule(alternate_stp_sch)
|
240
192
|
|
241
193
|
# Create setpoint schedule to specify source side temperature
|
@@ -305,7 +257,11 @@ class Waterheater
|
|
305
257
|
tank_spt_sensor.setName("#{combi_sys_id} Setpoint Temperature")
|
306
258
|
tank_spt_sensor.setKeyName(water_heater.setpointTemperatureSchedule.get.name.to_s)
|
307
259
|
alt_spt_sch = water_heater.indirectAlternateSetpointTemperatureSchedule.get
|
308
|
-
|
260
|
+
if alt_spt_sch.to_ScheduleConstant.is_initialized
|
261
|
+
altsch_actuator = OpenStudio::Model::EnergyManagementSystemActuator.new(alt_spt_sch, *EPlus::EMSActuatorScheduleConstantValue)
|
262
|
+
else
|
263
|
+
altsch_actuator = OpenStudio::Model::EnergyManagementSystemActuator.new(alt_spt_sch, *EPlus::EMSActuatorScheduleFileValue)
|
264
|
+
end
|
309
265
|
altsch_actuator.setName("#{combi_sys_id} AltSchedOverride")
|
310
266
|
end
|
311
267
|
plant_loop.components.each do |c|
|
@@ -383,7 +339,7 @@ class Waterheater
|
|
383
339
|
combi_ctrl_program.addLine("Set #{altsch_actuator.name} = 100") # Set the alternate setpoint temperature to highest level to ensure maximum source side flow rate
|
384
340
|
combi_ctrl_program.addLine('Else')
|
385
341
|
combi_ctrl_program.addLine("Set #{pump_actuator.name} = 0")
|
386
|
-
combi_ctrl_program.addLine("Set #{altsch_actuator.name} =
|
342
|
+
combi_ctrl_program.addLine("Set #{altsch_actuator.name} = NULL")
|
387
343
|
combi_ctrl_program.addLine('EndIf')
|
388
344
|
|
389
345
|
# ProgramCallingManagers
|
@@ -605,7 +561,7 @@ class Waterheater
|
|
605
561
|
storage_tank.setHeaterFuelType(EPlus::FuelTypeElectricity)
|
606
562
|
storage_tank.setHeaterThermalEfficiency(1)
|
607
563
|
storage_tank.ambientTemperatureSchedule.get.remove
|
608
|
-
set_wh_ambient(loc_space, loc_schedule,
|
564
|
+
set_wh_ambient(loc_space, loc_schedule, storage_tank)
|
609
565
|
if fluid_type == Constants.FluidWater # Direct, make the storage tank a dummy tank with 0 tank losses
|
610
566
|
storage_tank.setUniformSkinLossCoefficientperUnitAreatoAmbientTemperature(0.0)
|
611
567
|
else
|
@@ -644,7 +600,7 @@ class Waterheater
|
|
644
600
|
availability_manager.setColdNode(storage_tank.demandOutletModelObject.get.to_Node.get)
|
645
601
|
availability_manager.setTemperatureDifferenceOnLimit(0)
|
646
602
|
availability_manager.setTemperatureDifferenceOffLimit(0)
|
647
|
-
plant_loop.
|
603
|
+
plant_loop.addAvailabilityManager(availability_manager)
|
648
604
|
|
649
605
|
# Add EMS code for SWH control (keeps the WH for the last hour if there's useful energy that can be delivered, E+ wouldn't always do this by default)
|
650
606
|
# Sensors
|
@@ -918,7 +874,7 @@ class Waterheater
|
|
918
874
|
return amb_temp_sensor, rh_sensors
|
919
875
|
end
|
920
876
|
|
921
|
-
def self.add_hpwh_inlet_air_and_zone_heat_gain_program(model, obj_name_hpwh, loc_space,
|
877
|
+
def self.add_hpwh_inlet_air_and_zone_heat_gain_program(model, obj_name_hpwh, loc_space, hpwh_tamb, hpwh_rhamb, tank, coil, fan, amb_temp_sensor, amb_rh_sensors)
|
922
878
|
# EMS Actuators: Inlet T & RH, sensible and latent gains to the space
|
923
879
|
tamb_act_actuator = OpenStudio::Model::EnergyManagementSystemActuator.new(hpwh_tamb, *EPlus::EMSActuatorScheduleConstantValue)
|
924
880
|
tamb_act_actuator.setName("#{obj_name_hpwh} Tamb act")
|
@@ -1024,12 +980,16 @@ class Waterheater
|
|
1024
980
|
runner.registerWarning("Both '#{SchedulesFile::ColumnWaterHeaterOperatingMode}' schedule file and operating mode provided; the latter will be ignored.") if !op_mode.nil?
|
1025
981
|
end
|
1026
982
|
|
983
|
+
t_offset = 9.0 # deg-C
|
984
|
+
min_temp_c = UnitConversions.convert(min_temp, 'F', 'C').round(2)
|
985
|
+
max_temp_c = UnitConversions.convert(max_temp, 'F', 'C').round(2)
|
986
|
+
|
1027
987
|
hpwh_ctrl_program = OpenStudio::Model::EnergyManagementSystemProgram.new(model)
|
1028
988
|
hpwh_ctrl_program.setName("#{obj_name_hpwh} Control")
|
1029
989
|
hpwh_ctrl_program.addLine("Set #{hpwhschedoverride_actuator.name} = #{t_set_sensor.name}")
|
1030
990
|
# If in HP only mode: still enable elements if ambient temperature is out of bounds, otherwise disable elements
|
1031
991
|
if op_mode == HPXML::WaterHeaterOperatingModeHeatPumpOnly
|
1032
|
-
hpwh_ctrl_program.addLine("If (#{amb_temp_sensor.name}<#{
|
992
|
+
hpwh_ctrl_program.addLine("If (#{amb_temp_sensor.name}<#{min_temp_c}) || (#{amb_temp_sensor.name}>#{max_temp_c})")
|
1033
993
|
hpwh_ctrl_program.addLine("Set #{leschedoverride_actuator.name} = #{t_set_sensor.name}")
|
1034
994
|
hpwh_ctrl_program.addLine("Set #{ueschedoverride_actuator.name} = #{t_set_sensor.name}")
|
1035
995
|
hpwh_ctrl_program.addLine('Else')
|
@@ -1038,11 +998,11 @@ class Waterheater
|
|
1038
998
|
hpwh_ctrl_program.addLine('EndIf')
|
1039
999
|
else
|
1040
1000
|
# First, check if ambient temperature is out of bounds for HP operation, if so enable lower element
|
1041
|
-
hpwh_ctrl_program.addLine("If (#{amb_temp_sensor.name}<#{
|
1001
|
+
hpwh_ctrl_program.addLine("If (#{amb_temp_sensor.name}<#{min_temp_c}) || (#{amb_temp_sensor.name}>#{max_temp_c})")
|
1042
1002
|
hpwh_ctrl_program.addLine("Set #{ueschedoverride_actuator.name} = #{t_set_sensor.name}")
|
1043
1003
|
hpwh_ctrl_program.addLine("Set #{leschedoverride_actuator.name} = #{t_set_sensor.name}")
|
1044
1004
|
hpwh_ctrl_program.addLine('Else')
|
1045
|
-
hpwh_ctrl_program.addLine("Set #{ueschedoverride_actuator.name} = #{t_set_sensor.name} -
|
1005
|
+
hpwh_ctrl_program.addLine("Set #{ueschedoverride_actuator.name} = #{t_set_sensor.name} - #{t_offset}")
|
1046
1006
|
hpwh_ctrl_program.addLine("Set #{leschedoverride_actuator.name} = 0")
|
1047
1007
|
hpwh_ctrl_program.addLine('EndIf')
|
1048
1008
|
# Scheduled operating mode: if in HP only mode, disable both elements (this will override prior logic)
|
@@ -1050,7 +1010,7 @@ class Waterheater
|
|
1050
1010
|
hpwh_ctrl_program.addLine("If #{op_mode_sensor.name} == 1")
|
1051
1011
|
hpwh_ctrl_program.addLine("Set #{ueschedoverride_actuator.name} = 0")
|
1052
1012
|
hpwh_ctrl_program.addLine('Else')
|
1053
|
-
hpwh_ctrl_program.addLine("Set #{ueschedoverride_actuator.name} = #{t_set_sensor.name} -
|
1013
|
+
hpwh_ctrl_program.addLine("Set #{ueschedoverride_actuator.name} = #{t_set_sensor.name} - #{t_offset}")
|
1054
1014
|
hpwh_ctrl_program.addLine('EndIf')
|
1055
1015
|
end
|
1056
1016
|
end
|
@@ -1094,7 +1054,7 @@ class Waterheater
|
|
1094
1054
|
fail "RelatedHVACSystem '#{water_heating_system.related_hvac_idref}' for water heating system '#{water_heating_system.id}' is not currently supported for desuperheaters."
|
1095
1055
|
end
|
1096
1056
|
|
1097
|
-
def self.add_desuperheater(model, runner, water_heating_system, tank, loc_space, loc_schedule, loop
|
1057
|
+
def self.add_desuperheater(model, runner, water_heating_system, tank, loc_space, loc_schedule, loop)
|
1098
1058
|
return unless water_heating_system.uses_desuperheater
|
1099
1059
|
|
1100
1060
|
desuperheater_clg_coil = get_desuperheatercoil(water_heating_system, model)
|
@@ -1107,7 +1067,12 @@ class Waterheater
|
|
1107
1067
|
assumed_ua = 6.0 # Btu/hr-F, tank ua calculated based on 1.0 standby_loss and 50gal nominal vol
|
1108
1068
|
storage_tank_name = "#{tank.name} storage tank"
|
1109
1069
|
# reduce tank setpoint to enable desuperheater setpoint at t_set
|
1110
|
-
|
1070
|
+
if water_heating_system.temperature.nil?
|
1071
|
+
fail "Detailed setpoints for water heating system '#{water_heating_system.id}' is not currently supported for desuperheaters."
|
1072
|
+
else
|
1073
|
+
tank_setpoint = get_t_set_c(water_heating_system.temperature - 5.0, HPXML::WaterHeaterTypeStorage)
|
1074
|
+
end
|
1075
|
+
|
1111
1076
|
storage_tank = create_new_heater(name: storage_tank_name,
|
1112
1077
|
act_vol: storage_vol_actual,
|
1113
1078
|
t_set_c: tank_setpoint,
|
@@ -1125,10 +1090,8 @@ class Waterheater
|
|
1125
1090
|
new_schedule = OpenStudio::Model::ScheduleConstant.new(model)
|
1126
1091
|
new_schedule.setName("#{desuperheater_name} setpoint schedule")
|
1127
1092
|
# Preheat tank desuperheater setpoint set to be the same as main water heater
|
1128
|
-
dsh_setpoint =
|
1129
|
-
|
1130
|
-
default_dsh_setpoint = dsh_setpoint if !dsh_setpoint.nil?
|
1131
|
-
new_schedule.setValue(default_dsh_setpoint)
|
1093
|
+
dsh_setpoint = get_t_set_c(water_heating_system.temperature, HPXML::WaterHeaterTypeStorage)
|
1094
|
+
new_schedule.setValue(dsh_setpoint)
|
1132
1095
|
|
1133
1096
|
# create a desuperheater object
|
1134
1097
|
desuperheater = OpenStudio::Model::CoilWaterHeatingDesuperheater.new(model, new_schedule)
|
@@ -1303,6 +1266,13 @@ class Waterheater
|
|
1303
1266
|
end
|
1304
1267
|
|
1305
1268
|
def self.calc_indirect_ua_with_standbyloss(act_vol, water_heating_system, a_side, solar_fraction)
|
1269
|
+
standby_loss_units = water_heating_system.standby_loss_units
|
1270
|
+
standby_loss_value = water_heating_system.standby_loss_value
|
1271
|
+
|
1272
|
+
if not [HPXML::UnitsDegFPerHour].include? standby_loss_units
|
1273
|
+
fail "Unexpected standby loss units '#{standby_loss_units}' for indirect water heater. Should be '#{HPXML::UnitsDegFPerHour}'."
|
1274
|
+
end
|
1275
|
+
|
1306
1276
|
# Test conditions
|
1307
1277
|
cp = 0.999 # Btu/lb-F
|
1308
1278
|
rho = 8.216 # lb/gal
|
@@ -1310,7 +1280,7 @@ class Waterheater
|
|
1310
1280
|
t_tank_avg = 135.0 # F, Test begins at 137-138F stop at 133F
|
1311
1281
|
|
1312
1282
|
# UA calculation
|
1313
|
-
q =
|
1283
|
+
q = standby_loss_value * cp * act_vol * rho # Btu/hr
|
1314
1284
|
ua = q / (t_tank_avg - t_amb) # Btu/hr-F
|
1315
1285
|
|
1316
1286
|
# jacket
|
@@ -1323,6 +1293,7 @@ class Waterheater
|
|
1323
1293
|
def self.get_default_num_bathrooms(num_beds)
|
1324
1294
|
# From BA HSP
|
1325
1295
|
num_baths = num_beds / 2.0 + 0.5
|
1296
|
+
return num_baths
|
1326
1297
|
end
|
1327
1298
|
|
1328
1299
|
def self.add_ec_adj(model, heater, ec_adj, loc_space, water_heating_system, combi_boiler = nil)
|
@@ -1430,7 +1401,8 @@ class Waterheater
|
|
1430
1401
|
end
|
1431
1402
|
end
|
1432
1403
|
|
1433
|
-
def self.get_default_location(hpxml,
|
1404
|
+
def self.get_default_location(hpxml, climate_zone_iecc)
|
1405
|
+
iecc_zone = (climate_zone_iecc.nil? ? nil : climate_zone_iecc.zone)
|
1434
1406
|
if ['1A', '1B', '1C', '2A', '2B', '2C', '3B', '3C'].include? iecc_zone
|
1435
1407
|
location_hierarchy = [HPXML::LocationGarage,
|
1436
1408
|
HPXML::LocationLivingSpace]
|
@@ -1584,7 +1556,6 @@ class Waterheater
|
|
1584
1556
|
if [HPXML::WaterHeaterTypeTankless, HPXML::WaterHeaterTypeCombiTankless].include? wh_type
|
1585
1557
|
ef = eta_c
|
1586
1558
|
else
|
1587
|
-
pi = Math::PI
|
1588
1559
|
volume_drawn = 64.3 # gal/day
|
1589
1560
|
density = 8.2938 # lb/gal
|
1590
1561
|
draw_mass = volume_drawn * density # lb
|
@@ -1615,10 +1586,10 @@ class Waterheater
|
|
1615
1586
|
return pump
|
1616
1587
|
end
|
1617
1588
|
|
1618
|
-
def self.create_new_schedule_manager(model,
|
1589
|
+
def self.create_new_schedule_manager(model, t_set_c)
|
1619
1590
|
new_schedule = OpenStudio::Model::ScheduleConstant.new(model)
|
1620
1591
|
new_schedule.setName('dhw temp')
|
1621
|
-
new_schedule.setValue(
|
1592
|
+
new_schedule.setValue(t_set_c)
|
1622
1593
|
OpenStudio::Model::SetpointManagerScheduled.new(model, new_schedule)
|
1623
1594
|
end
|
1624
1595
|
|
@@ -1713,7 +1684,7 @@ class Waterheater
|
|
1713
1684
|
new_heater.setName(name)
|
1714
1685
|
new_heater.setTankVolume(UnitConversions.convert(act_vol, 'gal', 'm^3'))
|
1715
1686
|
new_heater.setHeaterFuelType(EPlus.fuel_type(fuel)) unless fuel.nil?
|
1716
|
-
set_wh_ambient(loc_space, loc_schedule,
|
1687
|
+
set_wh_ambient(loc_space, loc_schedule, new_heater)
|
1717
1688
|
|
1718
1689
|
# FUTURE: These are always zero right now; develop smart defaults.
|
1719
1690
|
new_heater.setOnCycleParasiticFuelConsumptionRate(0.0)
|
@@ -1752,7 +1723,7 @@ class Waterheater
|
|
1752
1723
|
water_heater.setOffCycleLossFractiontoThermalZone(skinlossfrac)
|
1753
1724
|
end
|
1754
1725
|
|
1755
|
-
def self.set_wh_ambient(loc_space, loc_schedule,
|
1726
|
+
def self.set_wh_ambient(loc_space, loc_schedule, wh_obj)
|
1756
1727
|
if wh_obj.ambientTemperatureSchedule.is_initialized
|
1757
1728
|
wh_obj.ambientTemperatureSchedule.get.remove
|
1758
1729
|
end
|
@@ -1766,7 +1737,7 @@ class Waterheater
|
|
1766
1737
|
end
|
1767
1738
|
end
|
1768
1739
|
|
1769
|
-
def self.configure_mixed_tank_setpoint_schedule(new_heater, schedules_file,
|
1740
|
+
def self.configure_mixed_tank_setpoint_schedule(new_heater, schedules_file, t_set_c, model, runner)
|
1770
1741
|
new_schedule = nil
|
1771
1742
|
if not schedules_file.nil?
|
1772
1743
|
new_schedule = schedules_file.create_schedule_file(col_name: SchedulesFile::ColumnWaterHeaterSetpoint)
|
@@ -1774,9 +1745,9 @@ class Waterheater
|
|
1774
1745
|
if new_schedule.nil? # constant
|
1775
1746
|
new_schedule = OpenStudio::Model::ScheduleConstant.new(model)
|
1776
1747
|
new_schedule.setName('WH Setpoint Temp')
|
1777
|
-
new_schedule.setValue(
|
1748
|
+
new_schedule.setValue(t_set_c)
|
1778
1749
|
else
|
1779
|
-
runner.registerWarning("Both '#{SchedulesFile::ColumnWaterHeaterSetpoint}' schedule file and setpoint temperature provided; the latter will be ignored.") if !
|
1750
|
+
runner.registerWarning("Both '#{SchedulesFile::ColumnWaterHeaterSetpoint}' schedule file and setpoint temperature provided; the latter will be ignored.") if !t_set_c.nil?
|
1780
1751
|
end
|
1781
1752
|
if new_heater.setpointTemperatureSchedule.is_initialized
|
1782
1753
|
new_heater.setpointTemperatureSchedule.get.remove
|
@@ -1784,7 +1755,7 @@ class Waterheater
|
|
1784
1755
|
new_heater.setSetpointTemperatureSchedule(new_schedule)
|
1785
1756
|
end
|
1786
1757
|
|
1787
|
-
def self.configure_stratified_tank_setpoint_schedules(new_heater, schedules_file,
|
1758
|
+
def self.configure_stratified_tank_setpoint_schedules(new_heater, schedules_file, t_set_c, model, runner)
|
1788
1759
|
new_schedule = nil
|
1789
1760
|
if not schedules_file.nil?
|
1790
1761
|
new_schedule = schedules_file.create_schedule_file(col_name: SchedulesFile::ColumnWaterHeaterSetpoint)
|
@@ -1792,9 +1763,9 @@ class Waterheater
|
|
1792
1763
|
if new_schedule.nil? # constant
|
1793
1764
|
new_schedule = OpenStudio::Model::ScheduleConstant.new(model)
|
1794
1765
|
new_schedule.setName('WH Setpoint Temp')
|
1795
|
-
new_schedule.setValue(
|
1766
|
+
new_schedule.setValue(t_set_c)
|
1796
1767
|
else
|
1797
|
-
runner.registerWarning("Both '#{SchedulesFile::ColumnWaterHeaterSetpoint}' schedule file and setpoint temperature provided; the latter will be ignored.") if !
|
1768
|
+
runner.registerWarning("Both '#{SchedulesFile::ColumnWaterHeaterSetpoint}' schedule file and setpoint temperature provided; the latter will be ignored.") if !t_set_c.nil?
|
1798
1769
|
end
|
1799
1770
|
new_heater.heater1SetpointTemperatureSchedule.remove
|
1800
1771
|
new_heater.heater2SetpointTemperatureSchedule.remove
|
@@ -1802,17 +1773,22 @@ class Waterheater
|
|
1802
1773
|
new_heater.setHeater2SetpointTemperatureSchedule(new_schedule)
|
1803
1774
|
end
|
1804
1775
|
|
1805
|
-
def self.
|
1776
|
+
def self.get_t_set_c(t_set, wh_type)
|
1806
1777
|
return if t_set.nil?
|
1807
1778
|
|
1808
1779
|
return UnitConversions.convert(t_set, 'F', 'C') + deadband(wh_type) / 2.0 # Half the deadband to account for E+ deadband
|
1809
1780
|
end
|
1810
1781
|
|
1811
|
-
def self.create_new_loop(model, name,
|
1782
|
+
def self.create_new_loop(model, name, t_set_c, eri_version)
|
1812
1783
|
# Create a new plant loop for the water heater
|
1784
|
+
|
1785
|
+
if t_set_c.nil?
|
1786
|
+
t_set_c = UnitConversions.convert(get_default_hot_water_temperature(eri_version), 'F', 'C')
|
1787
|
+
end
|
1788
|
+
|
1813
1789
|
loop = OpenStudio::Model::PlantLoop.new(model)
|
1814
1790
|
loop.setName(name)
|
1815
|
-
loop.sizingPlant.setDesignLoopExitTemperature(
|
1791
|
+
loop.sizingPlant.setDesignLoopExitTemperature(t_set_c)
|
1816
1792
|
loop.sizingPlant.setLoopDesignTemperatureDifference(UnitConversions.convert(10.0, 'R', 'K'))
|
1817
1793
|
loop.setPlantLoopVolume(0.003) # ~1 gal
|
1818
1794
|
loop.setMaximumLoopFlowRate(0.01) # This size represents the physical limitations to flow due to losses in the piping system. We assume that the pipes are always adequately sized.
|
@@ -1823,6 +1799,12 @@ class Waterheater
|
|
1823
1799
|
loop.addSupplyBranchForComponent(bypass_pipe)
|
1824
1800
|
out_pipe.addToNode(loop.supplyOutletNode)
|
1825
1801
|
|
1802
|
+
new_pump = create_new_pump(model)
|
1803
|
+
new_pump.addToNode(loop.supplyInletNode)
|
1804
|
+
|
1805
|
+
new_manager = create_new_schedule_manager(model, t_set_c)
|
1806
|
+
new_manager.addToNode(loop.supplyOutletNode)
|
1807
|
+
|
1826
1808
|
return loop
|
1827
1809
|
end
|
1828
1810
|
|
@@ -1833,30 +1815,6 @@ class Waterheater
|
|
1833
1815
|
return solar_fraction.to_f
|
1834
1816
|
end
|
1835
1817
|
|
1836
|
-
def self.get_default_water_heater_efficiency_by_year_installed(year, fuel_type)
|
1837
|
-
fuel_primary_id = { EPlus::FuelTypeElectricity => 'electric',
|
1838
|
-
EPlus::FuelTypeNaturalGas => 'natural_gas',
|
1839
|
-
EPlus::FuelTypeOil => 'fuel_oil',
|
1840
|
-
EPlus::FuelTypeCoal => 'fuel_oil', # assumption
|
1841
|
-
EPlus::FuelTypeWoodCord => 'fuel_oil', # assumption
|
1842
|
-
EPlus::FuelTypeWoodPellets => 'fuel_oil', # assumption
|
1843
|
-
EPlus::FuelTypePropane => 'lpg' }[EPlus.fuel_type(fuel_type)]
|
1844
|
-
|
1845
|
-
value = nil
|
1846
|
-
lookup_year = 0
|
1847
|
-
CSV.foreach(File.join(File.dirname(__FILE__), 'data', 'water_heater_efficiency.csv'), headers: true) do |row|
|
1848
|
-
next unless row['fuel_primary_id'] == fuel_primary_id
|
1849
|
-
|
1850
|
-
row_year = Integer(row['year'])
|
1851
|
-
if (row_year - year).abs <= (lookup_year - year).abs
|
1852
|
-
lookup_year = row_year
|
1853
|
-
value = Float(row['value'])
|
1854
|
-
end
|
1855
|
-
end
|
1856
|
-
|
1857
|
-
return value
|
1858
|
-
end
|
1859
|
-
|
1860
1818
|
def self.get_usage_bin_from_first_hour_rating(fhr)
|
1861
1819
|
if fhr < 18.0
|
1862
1820
|
return HPXML::WaterHeaterUsageBinVerySmall
|
@@ -32,22 +32,15 @@ class WeatherProcess
|
|
32
32
|
return
|
33
33
|
end
|
34
34
|
|
35
|
-
|
36
|
-
@runner = runner
|
35
|
+
epw_path = get_epw_path(model)
|
37
36
|
|
38
|
-
|
39
|
-
|
40
|
-
if not File.exist?(@epw_path)
|
37
|
+
if not File.exist?(epw_path)
|
41
38
|
fail "Cannot find weather file at #{epw_path}."
|
42
39
|
end
|
43
40
|
|
44
|
-
|
45
|
-
|
46
|
-
process_epw
|
47
|
-
end
|
41
|
+
epw_file = OpenStudio::EpwFile.new(epw_path, true)
|
48
42
|
|
49
|
-
|
50
|
-
return @epw_path
|
43
|
+
process_epw(runner, epw_file)
|
51
44
|
end
|
52
45
|
|
53
46
|
def dump_to_csv(csv_path)
|
@@ -76,6 +69,7 @@ class WeatherProcess
|
|
76
69
|
end
|
77
70
|
|
78
71
|
def load_from_csv(csv_path)
|
72
|
+
require 'csv'
|
79
73
|
csv_data = CSV.read(csv_path, headers: false)
|
80
74
|
|
81
75
|
def to_datatype(data, dataclass)
|
@@ -106,7 +100,7 @@ class WeatherProcess
|
|
106
100
|
|
107
101
|
private
|
108
102
|
|
109
|
-
def
|
103
|
+
def get_epw_path(model)
|
110
104
|
if model.weatherFile.is_initialized
|
111
105
|
|
112
106
|
wf = model.weatherFile.get
|
@@ -125,23 +119,23 @@ class WeatherProcess
|
|
125
119
|
fail 'Model has not been assigned a weather file.'
|
126
120
|
end
|
127
121
|
|
128
|
-
def process_epw
|
122
|
+
def process_epw(runner, epw_file)
|
129
123
|
# Header info:
|
130
|
-
@header.City =
|
131
|
-
@header.State =
|
132
|
-
@header.Country =
|
133
|
-
@header.DataSource =
|
134
|
-
@header.Station =
|
135
|
-
@header.Latitude =
|
136
|
-
@header.Longitude =
|
137
|
-
@header.Timezone =
|
138
|
-
@header.Altitude = UnitConversions.convert(
|
124
|
+
@header.City = epw_file.city
|
125
|
+
@header.State = epw_file.stateProvinceRegion
|
126
|
+
@header.Country = epw_file.country
|
127
|
+
@header.DataSource = epw_file.dataSource
|
128
|
+
@header.Station = epw_file.wmoNumber
|
129
|
+
@header.Latitude = epw_file.latitude
|
130
|
+
@header.Longitude = epw_file.longitude
|
131
|
+
@header.Timezone = epw_file.timeZone
|
132
|
+
@header.Altitude = UnitConversions.convert(epw_file.elevation, 'm', 'ft')
|
139
133
|
@header.LocalPressure = Math::exp(-0.0000368 * @header.Altitude) # atm
|
140
|
-
@header.RecordsPerHour =
|
134
|
+
@header.RecordsPerHour = epw_file.recordsPerHour
|
141
135
|
|
142
|
-
epw_file_data =
|
136
|
+
epw_file_data = epw_file.data
|
143
137
|
|
144
|
-
epwHasDesignData = get_design_info_from_epw
|
138
|
+
epwHasDesignData = get_design_info_from_epw(epw_file)
|
145
139
|
|
146
140
|
# Timeseries data:
|
147
141
|
rowdata = []
|
@@ -208,14 +202,14 @@ class WeatherProcess
|
|
208
202
|
|
209
203
|
calc_annual_drybulbs(rowdata)
|
210
204
|
calc_monthly_drybulbs(rowdata)
|
211
|
-
calc_heat_cool_degree_days(
|
205
|
+
calc_heat_cool_degree_days(dailydbs)
|
212
206
|
calc_avg_monthly_highs_lows(dailyhighdbs, dailylowdbs)
|
213
207
|
calc_avg_windspeed(rowdata)
|
214
208
|
calc_ground_temperatures
|
215
209
|
@data.WSF = calc_ashrae_622_wsf(rowdata)
|
216
210
|
|
217
211
|
if not epwHasDesignData
|
218
|
-
|
212
|
+
runner.registerWarning('No design condition info found; calculating design conditions from EPW weather data.')
|
219
213
|
calc_design_info(rowdata)
|
220
214
|
@design.DailyTemperatureRange = @data.MonthlyAvgDailyHighDrybulbs[7] - @data.MonthlyAvgDailyLowDrybulbs[7]
|
221
215
|
end
|
@@ -248,7 +242,7 @@ class WeatherProcess
|
|
248
242
|
def calc_monthly_drybulbs(hd)
|
249
243
|
# Calculates and stores monthly average drybulbs
|
250
244
|
@data.MonthlyAvgDrybulbs = []
|
251
|
-
|
245
|
+
for month in 1..12
|
252
246
|
y = []
|
253
247
|
hd.each do |x|
|
254
248
|
if x['month'] == month
|
@@ -271,7 +265,7 @@ class WeatherProcess
|
|
271
265
|
@data.AnnualAvgWindspeed = avgws
|
272
266
|
end
|
273
267
|
|
274
|
-
def calc_heat_cool_degree_days(
|
268
|
+
def calc_heat_cool_degree_days(dailydbs)
|
275
269
|
# Calculates and stores heating/cooling degree days
|
276
270
|
@data.HDD65F = calc_degree_days(dailydbs, 65, true)
|
277
271
|
@data.HDD50F = calc_degree_days(dailydbs, 50, true)
|
@@ -404,8 +398,8 @@ class WeatherProcess
|
|
404
398
|
return wsf.round(2)
|
405
399
|
end
|
406
400
|
|
407
|
-
def get_design_info_from_epw
|
408
|
-
epw_design_conditions =
|
401
|
+
def get_design_info_from_epw(epw_file)
|
402
|
+
epw_design_conditions = epw_file.designConditions
|
409
403
|
epwHasDesignData = false
|
410
404
|
if epw_design_conditions.length > 0
|
411
405
|
epwHasDesignData = true
|
@@ -504,7 +498,7 @@ class WeatherProcess
|
|
504
498
|
bo = (data.MonthlyAvgDrybulbs.max - data.MonthlyAvgDrybulbs.min) * 0.5
|
505
499
|
|
506
500
|
@data.GroundMonthlyTemps = []
|
507
|
-
|
501
|
+
for i in 0..11
|
508
502
|
theta = amon[i] * 24.0
|
509
503
|
@data.GroundMonthlyTemps << UnitConversions.convert(data.AnnualAvgDrybulb - bo * Math::cos(2.0 * Math::PI / p * theta - po - phi) * gm + 460.0, 'R', 'F')
|
510
504
|
end
|