2. Reading and running IDF files¶
archetypal is packed up with some built-in workflows to read, edit and run EnergyPlus files.
2.1. Reading¶
To read an IDF file, simply call IDF
with the path name. For example:
>>> from archetypal import IDF
>>> idf = IDF("in.idf) # in.idf must in the current directory.
You can also load on of the example files by name.
>>> from archetypal import IDF
>>> idf = IDF.from_example_files("AdultEducationCenter.idf")
You can optionally pass the weather file path as well:
>>> weather = eplus_dir / "WeatherData" / "USA_IL_Chicago-OHare.Intl.AP.725300_TMY3.epw" # Weather file path
>>> idf = IDF(eplus_file, epw=weather) # IDF load
2.2. Editing¶
Editing IDF files is based on the eppy package. The IDF
object exposes the
EnergyPlus objects that make up the IDF file. These objects can be edited and new objects can be created. See the eppy
documentation for more information on how to edit IDF files.
Hint
Pre-sets
EnergyPlus outputs can be quickly defined using the Outputs
class. This class and its
methods handle adding predefined or custom outputs to an IDF model. An Outputs
is
instantiated by default in an IDF
model. It accessed with the
outputs
attribute. For example, the idf object created above can be modified by
adding a basic set of outputs:
>>> idf.outputs.add_basics().apply()
One can specify custom outputs by calling add_custom()
with a list of dict
of the form fieldname:value and then apply()
. These outputs will be
appended to the IDF model only if apply()
is called. See
Outputs
for more details on all possible methods.
2.3. Running¶
To run an IDF
model, simply call the simulate()
function
on the IDF object. In both cases, users can also specify run options as well as output options.
For the same IDF object above:
>>> idf.simulate(epw=weather)
Hint
Caching system.
When running EnergyPlus simulations, a caching system is activated to reduce the number of calls to the
EnergyPlus executable or to reduce time spent on I/O operations such as in sql
and
htm()
which parse the simulation results. This caching system will save
simulation results in a folder identified by a unique identifier. This identifier is based on the content of the IDF
file, as well as EnergyPlus simulate options. This system works by invalidating any dependant attributes when
independent attributes change.