Skip to content

Latest commit

 

History

History
60 lines (38 loc) · 2.11 KB

README.md

File metadata and controls

60 lines (38 loc) · 2.11 KB

espy

Python API for ESP-r

Please note that these modules are primarily designed for my own use, and functions may change inputs or names without warning or concern for maintaining compatibility with any scripts you may have.

Install procedure

git clone https://github.com/johnallison0/espy.git
cd espy
python setup.py install

Structure

ESPy is broken up into modules. Many of these echo names of ESP-r modules (e.g. bps, res, clm), that contain functions to automate functionality of these modules. Other modules contain various support facilities, as well as functions for interacting with ESP-r models without using the ESP-r interface.

For full namespace documentation, refer to the ./doc directory.

Usage

If the installation procedure above was followed, then ESPy modules should be included in Python code in the same manner as any other installed modules. A minimal workflow for a typical simulation and results extraction task might be the following:

import espy.bps import run_preset
from espy.res import time_series

run_preset('./cfg/model.cfg', 'annual')
time_series('./cfg/model.cfg', 'annual.res', [['all', 'Zone db T']], out_file='res.csv')

You would then have dry bulb temperature for all zones, in file res.csv. Alternatively, you could work with a DataFrame of the results:

import pandas as pd
from espy.res import time_series

res_df = time_series('./cfg/model.cfg', 'annual.res', [['all', 'Zone db T']])
res_df['Zone1_dbT'].to_csv('Zone1res.csv')

There are many other functions provided by ESPy. For full documentation, refer to the ./doc directory.

Prerequisites

The following Python modules are required. If not already present, these should be installed automatically during the install procedure detailed above.

datetime matplotlib numpy pandas vtk wand

To use the script gen_doc.py and generate code documentation, Doxygen is required: https://doxygen.nl/

To use the vtk model visulisation functionality in espy.plot, an OpenGL implementation is required. For Ubuntu users, we recommend looking into mesa: https://mesa3d.org/