# frozen_string_literal: true # ******************************************************************************* # OpenStudio(R), Copyright (c) 2008-2020, Alliance for Sustainable Energy, LLC. # All rights reserved. # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are met: # # (1) Redistributions of source code must retain the above copyright notice, # this list of conditions and the following disclaimer. # # (2) Redistributions in binary form must reproduce the above copyright notice, # this list of conditions and the following disclaimer in the documentation # and/or other materials provided with the distribution. # # (3) Neither the name of the copyright holder nor the names of any contributors # may be used to endorse or promote products derived from this software without # specific prior written permission from the respective party. # # (4) Other than as required in clauses (1) and (2), distributions in any form # of modifications or other derivative works may not use the "OpenStudio" # trademark, "OS", "os", or any other confusingly similar designation without # specific prior written permission from Alliance for Sustainable Energy, LLC. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER(S) AND ANY CONTRIBUTORS # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, # THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE # ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER(S), ANY CONTRIBUTORS, THE # UNITED STATES GOVERNMENT, OR THE UNITED STATES DEPARTMENT OF ENERGY, NOR ANY OF # THEIR EMPLOYEES, BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, # EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT # OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, # STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. # ******************************************************************************* # see the URL below for information on how to write OpenStudio measures # http://nrel.github.io/OpenStudio-user-documentation/reference/measure_writing_guide/ require 'openstudio-standards' # load OpenStudio measure libraries from openstudio-extension gem require 'openstudio-extension' require 'openstudio/extension/core/os_lib_helper_methods' require 'openstudio/extension/core/os_lib_model_generation.rb' require_relative 'resources/Model.hvac' # DLM: should this be in openstudio-standards? dfg some tests fail without it # start the measure class CreateTypicalDEERBuildingFromModel < OpenStudio::Measure::ModelMeasure # resource file modules include OsLib_HelperMethods include OsLib_ModelGeneration # human readable name def name return 'Create Typical DEER Building from Model' end # human readable description def description return 'Takes a model with space and stub space types, and assigns constructions, schedules, internal loads, hvac, and other loads such as exterior lights and service water heating.' end # human readable description of modeling approach def modeler_description return 'It is important that the template argument chosen for this measure is in line with the buding types for the stub space types of the model passed in.' end # define the arguments that the user will input def arguments(model) args = OpenStudio::Measure::OSArgumentVector.new # see if building name contains any template values default_string = '90.1-2010' get_templates.each do |template_string| if model.getBuilding.name.to_s.include?(template_string) default_string = template_string next end end # Make argument for template template = OpenStudio::Measure::OSArgument.makeChoiceArgument('template', get_deer_templates, true) template.setDisplayName('Target Standard') template.setDefaultValue(default_string) args << template # Make argument for system type hvac_chs = OpenStudio::StringVector.new hvac_chs << 'Inferred' hvac_chs << 'Ideal Air Loads' hvac_chs << 'Baseboard electric' hvac_chs << 'Baseboard gas boiler' hvac_chs << 'Baseboard central air source heat pump' hvac_chs << 'Baseboard district hot water' hvac_chs << 'Direct evap coolers with baseboard electric' hvac_chs << 'Direct evap coolers with baseboard gas boiler' hvac_chs << 'Direct evap coolers with baseboard central air source heat pump' hvac_chs << 'Direct evap coolers with baseboard district hot water' hvac_chs << 'Direct evap coolers with forced air furnace' hvac_chs << 'Direct evap coolers with gas unit heaters' hvac_chs << 'Direct evap coolers with no heat' hvac_chs << 'DOAS with fan coil chiller with boiler' hvac_chs << 'DOAS with fan coil chiller with central air source heat pump' hvac_chs << 'DOAS with fan coil chiller with district hot water' hvac_chs << 'DOAS with fan coil chiller with baseboard electric' hvac_chs << 'DOAS with fan coil chiller with gas unit heaters' hvac_chs << 'DOAS with fan coil chiller with no heat' hvac_chs << 'DOAS with fan coil air-cooled chiller with boiler' hvac_chs << 'DOAS with fan coil air-cooled chiller with central air source heat pump' hvac_chs << 'DOAS with fan coil air-cooled chiller with district hot water' hvac_chs << 'DOAS with fan coil air-cooled chiller with baseboard electric' hvac_chs << 'DOAS with fan coil air-cooled chiller with gas unit heaters' hvac_chs << 'DOAS with fan coil air-cooled chiller with no heat' hvac_chs << 'DOAS with fan coil district chilled water with boiler' hvac_chs << 'DOAS with fan coil district chilled water with central air source heat pump' hvac_chs << 'DOAS with fan coil district chilled water with district hot water' hvac_chs << 'DOAS with fan coil district chilled water with baseboard electric' hvac_chs << 'DOAS with fan coil district chilled water with gas unit heaters' hvac_chs << 'DOAS with fan coil district chilled water with no heat' hvac_chs << 'DOAS with VRF' hvac_chs << 'DOAS with water source heat pumps fluid cooler with boiler' hvac_chs << 'DOAS with water source heat pumps cooling tower with boiler' hvac_chs << 'DOAS with water source heat pumps with ground source heat pump' hvac_chs << 'DOAS with water source heat pumps district chilled water with district hot water' hvac_chs << 'Fan coil chiller with boiler' hvac_chs << 'Fan coil chiller with central air source heat pump' hvac_chs << 'Fan coil chiller with district hot water' hvac_chs << 'Fan coil chiller with baseboard electric' hvac_chs << 'Fan coil chiller with gas unit heaters' hvac_chs << 'Fan coil chiller with no heat' hvac_chs << 'Fan coil air-cooled chiller with boiler' hvac_chs << 'Fan coil air-cooled chiller with central air source heat pump' hvac_chs << 'Fan coil air-cooled chiller with district hot water' hvac_chs << 'Fan coil air-cooled chiller with baseboard electric' hvac_chs << 'Fan coil air-cooled chiller with gas unit heaters' hvac_chs << 'Fan coil air-cooled chiller with no heat' hvac_chs << 'Fan coil district chilled water with boiler' hvac_chs << 'Fan coil district chilled water with central air source heat pump' hvac_chs << 'Fan coil district chilled water with district hot water' hvac_chs << 'Fan coil district chilled water with baseboard electric' hvac_chs << 'Fan coil district chilled water with gas unit heaters' hvac_chs << 'Fan coil district chilled water with no heat' hvac_chs << 'Forced air furnace' hvac_chs << 'Gas unit heaters' hvac_chs << 'PTAC with baseboard electric' hvac_chs << 'PTAC with baseboard gas boiler' hvac_chs << 'PTAC with baseboard district hot water' hvac_chs << 'PTAC with gas unit heaters' hvac_chs << 'PTAC with electric coil' hvac_chs << 'PTAC with gas coil' hvac_chs << 'PTAC with gas boiler' hvac_chs << 'PTAC with central air source heat pump' hvac_chs << 'PTAC with district hot water' hvac_chs << 'PTAC with no heat' hvac_chs << 'PTHP' hvac_chs << 'PSZ-AC with baseboard electric' hvac_chs << 'PSZ-AC with baseboard gas boiler' hvac_chs << 'PSZ-AC with baseboard district hot water' hvac_chs << 'PSZ-AC with gas unit heaters' hvac_chs << 'PSZ-AC with electric coil' hvac_chs << 'PSZ-AC with gas coil' hvac_chs << 'PSZ-AC with gas boiler' hvac_chs << 'PSZ-AC with central air source heat pump' hvac_chs << 'PSZ-AC with district hot water' hvac_chs << 'PSZ-AC with no heat' hvac_chs << 'PSZ-AC district chilled water with baseboard electric' hvac_chs << 'PSZ-AC district chilled water with baseboard gas boiler' hvac_chs << 'PSZ-AC district chilled water with baseboard district hot water' hvac_chs << 'PSZ-AC district chilled water with gas unit heaters' hvac_chs << 'PSZ-AC district chilled water with electric coil' hvac_chs << 'PSZ-AC district chilled water with gas coil' hvac_chs << 'PSZ-AC district chilled water with gas boiler' hvac_chs << 'PSZ-AC district chilled water with central air source heat pump' hvac_chs << 'PSZ-AC district chilled water with district hot water' hvac_chs << 'PSZ-AC district chilled water with no heat' hvac_chs << 'PSZ-HP' hvac_chs << 'PVAV with gas boiler reheat' hvac_chs << 'PVAV with central air source heat pump reheat' hvac_chs << 'PVAV with district hot water reheat' hvac_chs << 'PVAV with PFP boxes' hvac_chs << 'PVAV with gas heat with electric reheat' hvac_chs << 'Residential AC with baseboard electric' hvac_chs << 'Residential AC with baseboard gas boiler' hvac_chs << 'Residential AC with baseboard central air source heat pump' hvac_chs << 'Residential AC with baseboard district hot water' hvac_chs << 'Residential AC with residential forced air furnace' hvac_chs << 'Residential AC with no heat' hvac_chs << 'Residential heat pump' hvac_chs << 'Residential heat pump with no cooling' hvac_chs << 'Residential forced air furnace' hvac_chs << 'VAV chiller with gas boiler reheat' hvac_chs << 'VAV chiller with central air source heat pump reheat' hvac_chs << 'VAV chiller with district hot water reheat' hvac_chs << 'VAV chiller with PFP boxes' hvac_chs << 'VAV chiller with gas coil reheat' hvac_chs << 'VAV chiller with no reheat with baseboard electric' hvac_chs << 'VAV chiller with no reheat with gas unit heaters' hvac_chs << 'VAV chiller with no reheat with zone heat pump' hvac_chs << 'VAV air-cooled chiller with gas boiler reheat' hvac_chs << 'VAV air-cooled chiller with central air source heat pump reheat' hvac_chs << 'VAV air-cooled chiller with district hot water reheat' hvac_chs << 'VAV air-cooled chiller with PFP boxes' hvac_chs << 'VAV air-cooled chiller with gas coil reheat' hvac_chs << 'VAV air-cooled chiller with no reheat with baseboard electric' hvac_chs << 'VAV air-cooled chiller with no reheat with gas unit heaters' hvac_chs << 'VAV air-cooled chiller with no reheat with zone heat pump' hvac_chs << 'VAV district chilled water with gas boiler reheat' hvac_chs << 'VAV district chilled water with central air source heat pump reheat' hvac_chs << 'VAV district chilled water with district hot water reheat' hvac_chs << 'VAV district chilled water with PFP boxes' hvac_chs << 'VAV district chilled water with gas coil reheat' hvac_chs << 'VAV district chilled water with no reheat with baseboard electric' hvac_chs << 'VAV district chilled water with no reheat with gas unit heaters' hvac_chs << 'VAV district chilled water with no reheat with zone heat pump' hvac_chs << 'VRF' hvac_chs << 'Water source heat pumps fluid cooler with boiler' hvac_chs << 'Water source heat pumps cooling tower with boiler' hvac_chs << 'Water source heat pumps with ground source heat pump' hvac_chs << 'Water source heat pumps district chilled water with district hot water' hvac_chs << 'Window AC with baseboard electric' hvac_chs << 'Window AC with baseboard gas boiler' hvac_chs << 'Window AC with baseboard central air source heat pump' hvac_chs << 'Window AC with baseboard district hot water' hvac_chs << 'Window AC with forced air furnace' hvac_chs << 'Window AC with unit heaters' hvac_chs << 'Window AC with no heat' system_type = OpenStudio::Measure::OSArgument.makeChoiceArgument('system_type', hvac_chs, true) system_type.setDisplayName('HVAC System Type') system_type.setDefaultValue('Inferred') args << system_type # Make argument for HVAC delivery type hvac_type_chs = OpenStudio::StringVector.new hvac_type_chs << 'Forced Air' hvac_type_chs << 'Hydronic' hvac_delivery_type = OpenStudio::Measure::OSArgument.makeChoiceArgument('hvac_delivery_type', hvac_type_chs, true) hvac_delivery_type.setDisplayName('HVAC System Delivery Type') hvac_delivery_type.setDescription('How the HVAC system delivers heating or cooling to the zone.') hvac_delivery_type.setDefaultValue('Forced Air') args << hvac_delivery_type # Make argument for HVAC heating source htg_src_chs = OpenStudio::StringVector.new htg_src_chs << 'Electricity' htg_src_chs << 'NaturalGas' htg_src_chs << 'DistrictHeating' htg_src_chs << 'DistrictAmbient' htg_src = OpenStudio::Measure::OSArgument.makeChoiceArgument('htg_src', htg_src_chs, true) htg_src.setDisplayName('HVAC Heating Source') htg_src.setDescription('The primary source of heating used by HVAC systems in the model.') htg_src.setDefaultValue('NaturalGas') args << htg_src # Make argument for HVAC cooling source clg_src_chs = OpenStudio::StringVector.new clg_src_chs << 'Electricity' clg_src_chs << 'DistrictCooling' clg_src_chs << 'DistrictAmbient' clg_src = OpenStudio::Measure::OSArgument.makeChoiceArgument('clg_src', clg_src_chs, true) clg_src.setDisplayName('HVAC Cooling Source') clg_src.setDescription('The primary source of cooling used by HVAC systems in the model.') clg_src.setDefaultValue('Electricity') args << clg_src swh_src_chs = OpenStudio::StringVector.new swh_src_chs << 'Inferred' swh_src_chs << 'NaturalGas' swh_src_chs << 'Electricity' swh_src_chs << 'HeatPump' swh_src = OpenStudio::Measure::OSArgument.makeChoiceArgument('swh_src', swh_src_chs, true) swh_src.setDisplayName('Service Water Heating Source') swh_src.setDescription('The primary source of heating used by SWH systems in the model.') swh_src.setDefaultValue('Inferred') args << swh_src # # make argument for fuel type (not used yet) # fuel_type_cooking = OpenStudio::Measure::OSArgument::makeChoiceArgument("fuel_type_cooking", fuel_choices,true) # fuel_type_cooking.setDisplayName("Fuel Type for Cooking Loads") # fuel_type_cooking.setDefaultValue("Gas") # args << fuel_type_cooking # # # make argument for fuel type (not used yet) # fuel_type_laundry = OpenStudio::Measure::OSArgument::makeChoiceArgument("fuel_type_laundry", fuel_choices,true) # fuel_type_laundry.setDisplayName("Fuel Type for Laundry Dryer Loads") # fuel_type_laundry.setDefaultValue("Electric") # args << fuel_type_laundry # make argument for kitchen makeup kitchen_makeup_choices = OpenStudio::StringVector.new kitchen_makeup_choices << 'None' kitchen_makeup_choices << 'Largest Zone' kitchen_makeup_choices << 'Adjacent' kitchen_makeup = OpenStudio::Measure::OSArgument.makeChoiceArgument('kitchen_makeup', kitchen_makeup_choices, true) kitchen_makeup.setDisplayName('Kitchen Exhaust MakeUp Air Calculation Method') kitchen_makeup.setDescription('Determine logic to identify dining or cafe zones to provide makeup air to kitchen exhaust.') kitchen_makeup.setDefaultValue('Adjacent') args << kitchen_makeup # make argument for exterior_lighting_zone exterior_lighting_zone_choices = OpenStudio::StringVector.new exterior_lighting_zone_choices << '0 - Undeveloped Areas Parks' exterior_lighting_zone_choices << '1 - Developed Areas Parks' exterior_lighting_zone_choices << '2 - Neighborhood' exterior_lighting_zone_choices << '3 - All Other Areas' exterior_lighting_zone_choices << '4 - High Activity' exterior_lighting_zone = OpenStudio::Measure::OSArgument.makeChoiceArgument('exterior_lighting_zone', exterior_lighting_zone_choices, true) exterior_lighting_zone.setDisplayName('Exterior Lighting Zone') exterior_lighting_zone.setDescription('Identify the Exterior Lighting Zone for the Building Site.') exterior_lighting_zone.setDefaultValue('3 - All Other Areas') args << exterior_lighting_zone # make an argument for add_constructions add_constructions = OpenStudio::Measure::OSArgument.makeBoolArgument('add_constructions', true) add_constructions.setDisplayName('Add Constructions to Model') add_constructions.setDescription('Construction Set will be applied to entire building') add_constructions.setDefaultValue(true) args << add_constructions # make an argument for add_space_type_loads add_space_type_loads = OpenStudio::Measure::OSArgument.makeBoolArgument('add_space_type_loads', true) add_space_type_loads.setDisplayName('Add Space Type Loads to Model') add_space_type_loads.setDescription('Populate existing space types in model with internal loads.') add_space_type_loads.setDefaultValue(true) args << add_space_type_loads # make an argument for add_elevators add_elevators = OpenStudio::Measure::OSArgument.makeBoolArgument('add_elevators', true) add_elevators.setDisplayName('Add Elevators to Model') add_elevators.setDescription('Elevators will be add directly to space in model vs. being applied to a space type.') add_elevators.setDefaultValue(true) args << add_elevators # make an argument for add_internal_mass add_internal_mass = OpenStudio::Measure::OSArgument.makeBoolArgument('add_internal_mass', true) add_internal_mass.setDisplayName('Add Internal Mass to Model') add_internal_mass.setDescription('Adds internal mass to each space.') add_internal_mass.setDefaultValue(true) args << add_internal_mass # make an argument for add_exterior_lights add_exterior_lights = OpenStudio::Measure::OSArgument.makeBoolArgument('add_exterior_lights', true) add_exterior_lights.setDisplayName('Add Exterior Lights to Model') add_exterior_lights.setDescription('Multiple exterior lights objects will be added for different classes of lighting such as parking and facade.') add_exterior_lights.setDefaultValue(true) args << add_exterior_lights # make an argument for onsite_parking_fraction onsite_parking_fraction = OpenStudio::Measure::OSArgument.makeDoubleArgument('onsite_parking_fraction', true) onsite_parking_fraction.setDisplayName('Onsite Parking Fraction') onsite_parking_fraction.setDescription('If set to 0 no exterior lighting for parking will be added') onsite_parking_fraction.setDefaultValue(1.0) args << onsite_parking_fraction # make an argument for add_exhaust add_exhaust = OpenStudio::Measure::OSArgument.makeBoolArgument('add_exhaust', true) add_exhaust.setDisplayName('Add Exhaust Fans to Model') add_exhaust.setDescription('Depending upon building type exhaust fans can be in kitchens, restrooms or other space types') add_exhaust.setDefaultValue(true) args << add_exhaust # make an argument for add_swh add_swh = OpenStudio::Measure::OSArgument.makeBoolArgument('add_swh', true) add_swh.setDisplayName('Add Service Water Heating to Model') add_swh.setDescription('This will add both the supply and demand side of service water heating.') add_swh.setDefaultValue(true) args << add_swh # make an argument for add_thermostat add_thermostat = OpenStudio::Measure::OSArgument.makeBoolArgument('add_thermostat', true) add_thermostat.setDisplayName('Add Thermostats') add_thermostat.setDescription('Add Thermostat to model based on Space Type Standards information of spaces assigned to thermal zones.') add_thermostat.setDefaultValue(true) args << add_thermostat # make an argument for add_hvac add_hvac = OpenStudio::Measure::OSArgument.makeBoolArgument('add_hvac', true) add_hvac.setDisplayName('Add HVAC System to Model') add_hvac.setDescription('Add HVAC System to the model') add_hvac.setDefaultValue(true) args << add_hvac # make an argument for add_refrigeration add_refrigeration = OpenStudio::Measure::OSArgument.makeBoolArgument('add_refrigeration', true) add_refrigeration.setDisplayName('Add Refrigeration to Model') add_refrigeration.setDescription('Add refrigeration cases and walkins model') add_refrigeration.setDefaultValue(true) args << add_refrigeration # modify weekday hours of operation modify_wkdy_op_hrs = OpenStudio::Measure::OSArgument.makeBoolArgument('modify_wkdy_op_hrs', true) modify_wkdy_op_hrs.setDisplayName('Modify weekday hours of operation') modify_wkdy_op_hrs.setDescription('Modify the weekday hours of operation in the model.') modify_wkdy_op_hrs.setDefaultValue(false) args << modify_wkdy_op_hrs # weekday hours of operation start time wkdy_op_hrs_start_time = OpenStudio::Measure::OSArgument.makeDoubleArgument('wkdy_op_hrs_start_time', true) wkdy_op_hrs_start_time.setDisplayName('Weekday Operating Hours Start Time') wkdy_op_hrs_start_time.setDescription('Enter 24 hour values with fractional values converted to minutes. e.g. 17.25 = 5:15pm. Only used if Modify weekday hours of operation is true.') wkdy_op_hrs_start_time.setUnits('Hours') wkdy_op_hrs_start_time.setDefaultValue(8.0) args << wkdy_op_hrs_start_time # weekday hours of operation duration wkdy_op_hrs_duration = OpenStudio::Measure::OSArgument.makeDoubleArgument('wkdy_op_hrs_duration', true) wkdy_op_hrs_duration.setDisplayName('Weekday Operating Hours Duration') wkdy_op_hrs_duration.setDescription('Length of weekday operating hours. Enter 24 hour values with fractional values converted to minutes. e.g. 17.25 = 5:15pm. Only used if Modify weekday hours of operation is true.') wkdy_op_hrs_duration.setUnits('Hours') wkdy_op_hrs_duration.setDefaultValue(8.0) args << wkdy_op_hrs_duration # modify weekend hours of operation modify_wknd_op_hrs = OpenStudio::Measure::OSArgument.makeBoolArgument('modify_wknd_op_hrs', true) modify_wknd_op_hrs.setDisplayName('Modify weekend hours of operation') modify_wknd_op_hrs.setDescription('Modify the weekend hours of operation in the model.') modify_wknd_op_hrs.setDefaultValue(false) args << modify_wknd_op_hrs # weekend hours of operation start time wknd_op_hrs_start_time = OpenStudio::Measure::OSArgument.makeDoubleArgument('wknd_op_hrs_start_time', true) wknd_op_hrs_start_time.setDisplayName('Weekend Operating Hours Start Time') wknd_op_hrs_start_time.setDescription('Enter 24 hour values with fractional values converted to minutes. e.g. 17.25 = 5:15pm. Only used if Modify weekend hours of operation is true.') wknd_op_hrs_start_time.setUnits('Hours') wknd_op_hrs_start_time.setDefaultValue(8.0) args << wknd_op_hrs_start_time # weekend hours of operation duration wknd_op_hrs_duration = OpenStudio::Measure::OSArgument.makeDoubleArgument('wknd_op_hrs_duration', true) wknd_op_hrs_duration.setDisplayName('Weekend Operating Hours Duration') wknd_op_hrs_duration.setDescription('Length of weekend operating hours. Enter 24 hour values with fractional values converted to minutes. e.g. 17.25 = 5:15pm. Only used if Modify weekend hours of operation is true.') wknd_op_hrs_duration.setUnits('Hours') wknd_op_hrs_duration.setDefaultValue(8.0) args << wknd_op_hrs_duration # make an argument for unmet_hours_tolerance unmet_hours_tolerance = OpenStudio::Measure::OSArgument.makeDoubleArgument('unmet_hours_tolerance', true) unmet_hours_tolerance.setDisplayName('Unmet Hours Tolerance') unmet_hours_tolerance.setDescription('Set the thermostat setpoint tolerance for unmet hours in degrees Rankine') unmet_hours_tolerance.setDefaultValue(1.0) args << unmet_hours_tolerance # make an argument for remove_objects remove_objects = OpenStudio::Measure::OSArgument.makeBoolArgument('remove_objects', true) remove_objects.setDisplayName('Clean Model of non-geometry objects') remove_objects.setDescription('Only removes objects of type that are selected to be added.') remove_objects.setDefaultValue(true) args << remove_objects # make an argument for use_upstream_args use_upstream_args = OpenStudio::Measure::OSArgument.makeBoolArgument('use_upstream_args', true) use_upstream_args.setDisplayName('Use Upstream Argument Values') use_upstream_args.setDescription('When true this will look for arguments or registerValues in upstream measures that match arguments from this measure, and will use the value from the upstream measure in place of what is entered for this measure.') use_upstream_args.setDefaultValue(true) args << use_upstream_args # make force daylight savings on enable_dst = OpenStudio::Measure::OSArgument.makeBoolArgument('enable_dst', true) enable_dst.setDisplayName('Enable Daylight Savings') enable_dst.setDescription('By default this will force daylight savings to be enabled. Set to false if in a location where DST is not followed, or if needed for specific use case.') enable_dst.setDefaultValue(true) args << enable_dst return args end # define what happens when the measure is run def run(model, runner, user_arguments) super(model, runner, user_arguments) # method run from os_lib_model_generation.rb result = typical_building_from_model(model, runner, user_arguments) if result == false return false else return true end end end # register the measure to be used by the application CreateTypicalDEERBuildingFromModel.new.registerWithApplication