energyplus-ruleset-model


Nameenergyplus-ruleset-model JSON
Version 0.6 PyPI version JSON
download
home_pagehttps://github.com/JasonGlazer/createRulesetProjectDescription
SummaryA Python tool for generating RPDs.
upload_time2024-11-26 17:14:33
maintainerNone
docs_urlNone
authorJason Glazer
requires_python>=3.7
licenseModifiedBSD
keywords energyplus
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage
            # Creating ASHRAE Standard 229 Ruleset Project Description Files for EnergyPlus 

[![Test/Package Status](https://github.com/JasonGlazer/createRulesetProjectDescription/actions/workflows/flake8.yml/badge.svg)](https://github.com/JasonGlazer/createRulesetProjectDescription/actions/workflows/flake8.yml)
[![Build Package and Run Tests](https://github.com/JasonGlazer/createRulesetProjectDescription/actions/workflows/build_and_test.yml/badge.svg?branch=main)](https://github.com/JasonGlazer/createRulesetProjectDescription/actions/workflows/build_and_test.yml)

An EnergyPlus utility that creates a Ruleset Project Description (RPD) file based on output (and some input) from a simulation. 

## Background

The RPD file is based on a schema being developed as part of the writing of ASHRAE Standard 229P:

Title:

 - Protocols for Evaluating Ruleset Implementation in Building Performance Modeling Software

Purpose:

 - This standard establishes tests and acceptance criteria for implementation of rulesets (e.g., modeling rules) and related reporting in building performance modeling software.

Scope:

 - This standard applies to building performance modeling software that implements rulesets.
 - This standard applies to rulesets associated with new or existing buildings and their systems, system controls, their sites, and other aspects of buildings described by the ruleset implementation being evaluated.

The development of the RPD schema to support the standard is going on here:

https://github.com/open229/ruleset-model-description-schema

## Overview

The utility is intended to be used at a command line prompt:

```
  createRulesetProjectDescription in.epJSON
```

where in.epJSON is the name of the EnergyPlus input file with the file path, in the epJSON format. 

EnergyPlus version 24.2.0 or newer is required to use the utility.

An [overview video](https://youtu.be/p1vHqsraR8g) is also available.

## Command Line Options

To create an RPD file using the same name as the .epJSON file but with the .rpd extension, call 

```
  createRulesetProjectDescription filename.epJSON
```

Since many compliance parameters are needed, to create an JSON file with the correct fields for each corresponding EnergyPlus object call with the --create_empty_cp or -c parameter

```
  createRulesetProjectDescription --create_empty_cp filename.epJSON
```

That will create a file named filename.comp-param-empty.json that is like an RPD file but only contains compliance parameters. The user should then rename the file to filename.comp-param.json and edit the file with the correct compliance parameters in each field. When that is complete the command with --add_cp or -a will merge the compliance parameters provided by the user with the data elements populated from EnergyPlus. Here is an example:

```
  createRulesetProjectDescription --add_cp filename.epJSON
```

For help with the command line options use the parameter -h or --help without a filename.

```
  createRulesetProjectDescription --help
```

## epJSON Format

To create an epJSON file from an EnergyPlus IDF file, use ConvertInputFormat.exe that comes with EnergyPlus. 

To convert files, at the command prompt type:

```
 ConvertInputFormat in.idf
```

Where in.idf is the name of the EnergyPlus input file with the file path, in the IDF format. The utility will convert the file into a file with the same name
but with the extension .epJSON in the JSON format. 

For additional help with ConvertInputFormat at the command prompt in the directory with the EnergyPlus application, type:

```
 ConvertInputFormat --help
```

## Required Input File Changes

The EnergyPlus input file has some added requirements to be used with the createRulesetProjectDescription utility.

 - many tabular output reports are used, so the Output:Table:SummaryReports should be set to AllSummary, AllSummaryMonthly, or AllSummaryMonthlyAndSizingPeriod:

``` 
  Output:Table:SummaryReports,
    AllSummaryMonthly;    !- Report 1 Name
``` 

Additional warning messages may appear when including the monthly predefined reports.

 - the JSON output format is used, so that should be enabled for both time series and tabular output:

```    
  Output:JSON,
    TimeSeriesAndTabular,    !- Option Type
    Yes,                     !- Output JSON
    No,                      !- Output CBOR
    No;                      !- Output MessagePack
```

This will create filename_out.json files when EnergyPlus is run at the command line. 

Note: This utility was designed to work with files produced using EnergyPlus at the command line. Some file renaming might be necessary if using EP-Launch. 
If using EP-Launch, the eplusout.json and eplusout_hourly.json files may be found in the EPTEMP directory without the specific file name.

 - SI units should be used so

``` 
   OutputControl:Table:Style,
    HTML,            !- Column Separator
    None;            !- Unit Conversion
```
 - hourly output for each schedule needs to be created using the following
 
```
   Output:Variable,
    *,
    schedule value,
    hourly;
```

This will create filenameout_hourly.json files when EnergyPlus is run at the command line. If using EP-Launch, this files may be found in the EPTEMP directory without the specific file name.

 - add output schedules reports
 
```
  Output:Schedules,
    Hourly;
```

This produces a summary report in the EIO file and the Initialization Summary related to schedules. While it is not currently used by the script it probably will be used 
in the future.


 - add space type tags by using the Space input object

```
  Space,
    core_space,              !- Name
    Core_ZN,                 !- Zone Name
    autocalculate,           !- Ceiling Height
    autocalculate,           !- Volume
    autocalculate,           !- Floor Area {m2}
    OFFICE_OPEN_PLAN,        !- Space Type
    OFFICE_BUILDINGS_OFFICE_SPACE, !- Tag 1
    OFFICE;                  !- Tag 2
```

The fields should be completed as described below:

 - the Space Type field should be set to the appropriate option for lighting_space_type see LightingSpaceOptions2019ASHRAE901TG37 for the list of options.
 - the Tag 1 field should be set to the the appropriate option for ventilations_space_type see VentilationSpaceOptions2019ASHRAE901 for the list of options.
 - the Tag 2 field should be set to the the appropriate option for service_water_heating_space_type see ServiceWaterHeatingSpaceOptions2019ASHRAE901 for the list of options.

These enumerated lists are found here:

https://github.com/open229/ruleset-model-description-schema/blob/master/docs229/Enumerations2019ASHRAE901.schema.md

If you have not been using the Space input object before, set the numeric inputs to 'autocalculate'.

It is usually easier to make these changes prior to converting the file into the epJSON format.

## Weather File

When selecting the EPW weather file, make sure the STAT file is present in the same directory. This file is needed to fully populate the Climatic Data Summary tabular 
report, which is used to identify the ASHRAE climate zone.

## Output

The resulting Ruleset Project Description file will be created in the same directory as the epJSON file with the same name and the file extension .rpd

The Ruleset Project Description file is not complete but can be used to test many aspects of the building model transformation due to the ruleset. 
The data groups that are partially populated include:

 - RulesetProjectDescription
 - RulesetModelDescription
 - Building
 - BuildingSegment
 - Zone
 - Space
 - Infiltration
 - Surface
 - Construction
 - Material
 - Subsurface
 - InteriorLighting
 - MiscellaneousEquipment
 - Schedule
 - Calendar
 - Weather
 - HeatingVentilatingAirConditioningSystem
 - HeatingSystem
 - CoolingSystem
 - FanSystem
 - Fan
 - Terminal
 - FluidLoop
 - FluidLoopDesignAndControl
 - Pump
 - Boiler
 - Chiller
 - HeatRejection
 - ExteriorLighting


Please note that all data groups listed above still have some data elements that are not implemented and, in many cases, many data elements that are not implemented. The ones that 
were implemented often because they were easy to implement and not necessarily based on the need for the data element. 

Data groups that have not started to be implemented are:

 - SurfaceOpticalProperties
 - Transformer
 - Elevator
 - AirEconomizer
 - AirEnergyRecovery
 - FanOutputValidationPoint
 - PumpOutputValidationPoint
 - BoilerOutputValidationPoint
 - ChillerCapacityValidationPoint
 - ChillerPowerValidationPoint
 - ExternalFluidSource
 - ServiceWaterHeatingDistributionSystem
 - ServiceWaterPiping
 - SolarThermal
 - ServiceWaterHeatingEquipment
 - ServiceWaterHeaterValidationPoint
 - HeatPumpWaterHeaterCapacityValidationPoint
 - HeatPumpWaterHeaterPowerValidationPoint
 - Tank
 - ServiceWaterHeatingUse
 - RefrigeratedCase

If the the ASHRAE229_extra.schema.yaml with extra EnergyPlus tags are included in the energyplus_rpd folder, then an energyplus_implementation_report.txt file is generated which provides additional details. An example of the extra tags is shown here:

https://github.com/open229/ruleset-model-description-schema/blob/EPtags/schema-source/ASHRAE229_extra.schema.yaml


            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/JasonGlazer/createRulesetProjectDescription",
    "name": "energyplus-ruleset-model",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.7",
    "maintainer_email": null,
    "keywords": "energyplus",
    "author": "Jason Glazer",
    "author_email": null,
    "download_url": "https://files.pythonhosted.org/packages/e3/2c/e5356c788e4063e1c9771c62f951a0237db68165d6031e14f1c171140d0b/energyplus_ruleset_model-0.6.tar.gz",
    "platform": null,
    "description": "# Creating ASHRAE Standard 229 Ruleset Project Description Files for EnergyPlus \n\n[![Test/Package Status](https://github.com/JasonGlazer/createRulesetProjectDescription/actions/workflows/flake8.yml/badge.svg)](https://github.com/JasonGlazer/createRulesetProjectDescription/actions/workflows/flake8.yml)\n[![Build Package and Run Tests](https://github.com/JasonGlazer/createRulesetProjectDescription/actions/workflows/build_and_test.yml/badge.svg?branch=main)](https://github.com/JasonGlazer/createRulesetProjectDescription/actions/workflows/build_and_test.yml)\n\nAn EnergyPlus utility that creates a Ruleset Project Description (RPD) file based on output (and some input) from a simulation. \n\n## Background\n\nThe RPD file is based on a schema being developed as part of the writing of ASHRAE Standard 229P:\n\nTitle:\n\n - Protocols for Evaluating Ruleset Implementation in Building Performance Modeling Software\n\nPurpose:\n\n - This standard establishes tests and acceptance criteria for implementation of rulesets (e.g., modeling rules) and related reporting in building performance modeling software.\n\nScope:\n\n - This standard applies to building performance modeling software that implements rulesets.\n - This standard applies to rulesets associated with new or existing buildings and their systems, system controls, their sites, and other aspects of buildings described by the ruleset implementation being evaluated.\n\nThe development of the RPD schema to support the standard is going on here:\n\nhttps://github.com/open229/ruleset-model-description-schema\n\n## Overview\n\nThe utility is intended to be used at a command line prompt:\n\n```\n  createRulesetProjectDescription in.epJSON\n```\n\nwhere in.epJSON is the name of the EnergyPlus input file with the file path, in the epJSON format. \n\nEnergyPlus version 24.2.0 or newer is required to use the utility.\n\nAn [overview video](https://youtu.be/p1vHqsraR8g) is also available.\n\n## Command Line Options\n\nTo create an RPD file using the same name as the .epJSON file but with the .rpd extension, call \n\n```\n  createRulesetProjectDescription filename.epJSON\n```\n\nSince many compliance parameters are needed, to create an JSON file with the correct fields for each corresponding EnergyPlus object call with the --create_empty_cp or -c parameter\n\n```\n  createRulesetProjectDescription --create_empty_cp filename.epJSON\n```\n\nThat will create a file named filename.comp-param-empty.json that is like an RPD file but only contains compliance parameters. The user should then rename the file to filename.comp-param.json and edit the file with the correct compliance parameters in each field. When that is complete the command with --add_cp or -a will merge the compliance parameters provided by the user with the data elements populated from EnergyPlus. Here is an example:\n\n```\n  createRulesetProjectDescription --add_cp filename.epJSON\n```\n\nFor help with the command line options use the parameter -h or --help without a filename.\n\n```\n  createRulesetProjectDescription --help\n```\n\n## epJSON Format\n\nTo create an epJSON file from an EnergyPlus IDF file, use ConvertInputFormat.exe that comes with EnergyPlus. \n\nTo convert files, at the command prompt type:\n\n```\n ConvertInputFormat in.idf\n```\n\nWhere in.idf is the name of the EnergyPlus input file with the file path, in the IDF format. The utility will convert the file into a file with the same name\nbut with the extension .epJSON in the JSON format. \n\nFor additional help with ConvertInputFormat at the command prompt in the directory with the EnergyPlus application, type:\n\n```\n ConvertInputFormat --help\n```\n\n## Required Input File Changes\n\nThe EnergyPlus input file has some added requirements to be used with the createRulesetProjectDescription utility.\n\n - many tabular output reports are used, so the Output:Table:SummaryReports should be set to AllSummary, AllSummaryMonthly, or AllSummaryMonthlyAndSizingPeriod:\n\n``` \n  Output:Table:SummaryReports,\n    AllSummaryMonthly;    !- Report 1 Name\n``` \n\nAdditional warning messages may appear when including the monthly predefined reports.\n\n - the JSON output format is used, so that should be enabled for both time series and tabular output:\n\n```    \n  Output:JSON,\n    TimeSeriesAndTabular,    !- Option Type\n    Yes,                     !- Output JSON\n    No,                      !- Output CBOR\n    No;                      !- Output MessagePack\n```\n\nThis will create filename_out.json files when EnergyPlus is run at the command line. \n\nNote: This utility was designed to work with files produced using EnergyPlus at the command line. Some file renaming might be necessary if using EP-Launch. \nIf using EP-Launch, the eplusout.json and eplusout_hourly.json files may be found in the EPTEMP directory without the specific file name.\n\n - SI units should be used so\n\n``` \n   OutputControl:Table:Style,\n    HTML,            !- Column Separator\n    None;            !- Unit Conversion\n```\n - hourly output for each schedule needs to be created using the following\n \n```\n   Output:Variable,\n    *,\n    schedule value,\n    hourly;\n```\n\nThis will create filenameout_hourly.json files when EnergyPlus is run at the command line. If using EP-Launch, this files may be found in the EPTEMP directory without the specific file name.\n\n - add output schedules reports\n \n```\n  Output:Schedules,\n    Hourly;\n```\n\nThis produces a summary report in the EIO file and the Initialization Summary related to schedules. While it is not currently used by the script it probably will be used \nin the future.\n\n\n - add space type tags by using the Space input object\n\n```\n  Space,\n    core_space,              !- Name\n    Core_ZN,                 !- Zone Name\n    autocalculate,           !- Ceiling Height\n    autocalculate,           !- Volume\n    autocalculate,           !- Floor Area {m2}\n    OFFICE_OPEN_PLAN,        !- Space Type\n    OFFICE_BUILDINGS_OFFICE_SPACE, !- Tag 1\n    OFFICE;                  !- Tag 2\n```\n\nThe fields should be completed as described below:\n\n - the Space Type field should be set to the appropriate option for lighting_space_type see LightingSpaceOptions2019ASHRAE901TG37 for the list of options.\n - the Tag 1 field should be set to the the appropriate option for ventilations_space_type see VentilationSpaceOptions2019ASHRAE901 for the list of options.\n - the Tag 2 field should be set to the the appropriate option for service_water_heating_space_type see ServiceWaterHeatingSpaceOptions2019ASHRAE901 for the list of options.\n\nThese enumerated lists are found here:\n\nhttps://github.com/open229/ruleset-model-description-schema/blob/master/docs229/Enumerations2019ASHRAE901.schema.md\n\nIf you have not been using the Space input object before, set the numeric inputs to 'autocalculate'.\n\nIt is usually easier to make these changes prior to converting the file into the epJSON format.\n\n## Weather File\n\nWhen selecting the EPW weather file, make sure the STAT file is present in the same directory. This file is needed to fully populate the Climatic Data Summary tabular \nreport, which is used to identify the ASHRAE climate zone.\n\n## Output\n\nThe resulting Ruleset Project Description file will be created in the same directory as the epJSON file with the same name and the file extension .rpd\n\nThe Ruleset Project Description file is not complete but can be used to test many aspects of the building model transformation due to the ruleset. \nThe data groups that are partially populated include:\n\n - RulesetProjectDescription\n - RulesetModelDescription\n - Building\n - BuildingSegment\n - Zone\n - Space\n - Infiltration\n - Surface\n - Construction\n - Material\n - Subsurface\n - InteriorLighting\n - MiscellaneousEquipment\n - Schedule\n - Calendar\n - Weather\n - HeatingVentilatingAirConditioningSystem\n - HeatingSystem\n - CoolingSystem\n - FanSystem\n - Fan\n - Terminal\n - FluidLoop\n - FluidLoopDesignAndControl\n - Pump\n - Boiler\n - Chiller\n - HeatRejection\n - ExteriorLighting\n\n\nPlease note that all data groups listed above still have some data elements that are not implemented and, in many cases, many data elements that are not implemented. The ones that \nwere implemented often because they were easy to implement and not necessarily based on the need for the data element. \n\nData groups that have not started to be implemented are:\n\n - SurfaceOpticalProperties\n - Transformer\n - Elevator\n - AirEconomizer\n - AirEnergyRecovery\n - FanOutputValidationPoint\n - PumpOutputValidationPoint\n - BoilerOutputValidationPoint\n - ChillerCapacityValidationPoint\n - ChillerPowerValidationPoint\n - ExternalFluidSource\n - ServiceWaterHeatingDistributionSystem\n - ServiceWaterPiping\n - SolarThermal\n - ServiceWaterHeatingEquipment\n - ServiceWaterHeaterValidationPoint\n - HeatPumpWaterHeaterCapacityValidationPoint\n - HeatPumpWaterHeaterPowerValidationPoint\n - Tank\n - ServiceWaterHeatingUse\n - RefrigeratedCase\n\nIf the the ASHRAE229_extra.schema.yaml with extra EnergyPlus tags are included in the energyplus_rpd folder, then an energyplus_implementation_report.txt file is generated which provides additional details. An example of the extra tags is shown here:\n\nhttps://github.com/open229/ruleset-model-description-schema/blob/EPtags/schema-source/ASHRAE229_extra.schema.yaml\n\n",
    "bugtrack_url": null,
    "license": "ModifiedBSD",
    "summary": "A Python tool for generating RPDs.",
    "version": "0.6",
    "project_urls": {
        "Homepage": "https://github.com/JasonGlazer/createRulesetProjectDescription"
    },
    "split_keywords": [
        "energyplus"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "d3884d2ce17656dab891da12b5689a0b7088ce438a59fca6dc4f7a2f4ad88885",
                "md5": "082a666adcb39f1b30872acc0cfb5dda",
                "sha256": "e67ab5c5ee118d8355d4e81fc2a984bf64d27344a8767a47b64e474d14fca5c3"
            },
            "downloads": -1,
            "filename": "energyplus_ruleset_model-0.6-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "082a666adcb39f1b30872acc0cfb5dda",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.7",
            "size": 31898,
            "upload_time": "2024-11-26T17:14:31",
            "upload_time_iso_8601": "2024-11-26T17:14:31.225394Z",
            "url": "https://files.pythonhosted.org/packages/d3/88/4d2ce17656dab891da12b5689a0b7088ce438a59fca6dc4f7a2f4ad88885/energyplus_ruleset_model-0.6-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "e32ce5356c788e4063e1c9771c62f951a0237db68165d6031e14f1c171140d0b",
                "md5": "d0c60b68391b7f18a602c5ec0ba86bff",
                "sha256": "333f202341b328b761127d2ecdec7104f3ed7ac9665707060a1bd83214a82791"
            },
            "downloads": -1,
            "filename": "energyplus_ruleset_model-0.6.tar.gz",
            "has_sig": false,
            "md5_digest": "d0c60b68391b7f18a602c5ec0ba86bff",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.7",
            "size": 32441,
            "upload_time": "2024-11-26T17:14:33",
            "upload_time_iso_8601": "2024-11-26T17:14:33.094973Z",
            "url": "https://files.pythonhosted.org/packages/e3/2c/e5356c788e4063e1c9771c62f951a0237db68165d6031e14f1c171140d0b/energyplus_ruleset_model-0.6.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-11-26 17:14:33",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "JasonGlazer",
    "github_project": "createRulesetProjectDescription",
    "travis_ci": false,
    "coveralls": true,
    "github_actions": true,
    "requirements": [],
    "lcname": "energyplus-ruleset-model"
}
        
Elapsed time: 0.37259s