========
eppy3000
========
.. image:: https://img.shields.io/pypi/v/eppy3000.svg
:target: https://pypi.python.org/pypi/eppy3000
.. image:: https://img.shields.io/travis/pyenergyplus/eppy3000.svg
:target: https://travis-ci.org/pyenergyplus/eppy3000
.. image:: https://readthedocs.org/projects/eppy3000/badge/?version=latest
:target: https://eppy3000.readthedocs.io/en/latest/?badge=latest
:alt: Documentation Status
E+ scripting using epJSON file format
* Free software: Mozilla Public License, v. 2.0
* Documentation: https://eppy3000.readthedocs.io.
* Home Page: https://github.com/pyenergyplus/eppy3000
Features - so far :-)
---------------------
* Open and read an epJSON file with *some* `eppy <https://github.com/santoshphilip/eppy>`_ functionality.
* Right now the `eppy <https://github.com/santoshphilip/eppy>`_ functionality is only partial
Background
----------
E+ has been moving from the IDD/IDF text format to a JSON format. `Eppy <https://github.com/santoshphilip/eppy>`_ reads the old IDD/IDF format. There is a need to have `eppy <https://github.com/santoshphilip/eppy>`_ read the JSON format and/or have a new package that will read the JSON format.
Whats in a name
---------------
Why is this package called eppy3000 ?
It is a play on the word python3000. Guido van van Rossum said about python in 2007 *"The first time I came up with the idea of Python 3000 was probably at a Python conference in the year 2000. The name was a take on Windows 2000. ...<snip>... The idea was that Python 3000 would be the first Python release to give up backwards compatibility in favor of making it the best language going forward."*
Eppy3000 will also break backward compatibility with eppy. Also eppy3000 will be written only for python3. Eppy3000 and eppy will continue to remain the best scripting language for modelling :-)
So what is eppy3000
-------------------
This project is an attempt to read JSON file formats and work like eppy. There is some value in trying to do this from scratch. The dot syntax that makes the original eppy useful can be recreated with a couple of lines in eppy3000. It took a lot of deep hacking to make the dot syntax work in the original eppy. Eppy3000 reads the JSON format as a dictionary. The package `Munch <https://github.com/Infinidat/munch>`_ (what was `Bunch <https://github.com/dsc/bunch>`_) allows the use of dot format syntax with a dictionary. The code is as simple as::
as_json = json.load(open(fname, 'r'))
for_dot_syntax = DefaultMunch.fromDict(as_json)
At this point eppy3000 is an exploration to find out what is possible. The API in eppy3000 will not be stable as we explore the possibilities. So, don't use it as production code yet :-)
What about eppy
---------------
Eppy will be continue to be developed and maintained. A major task will be to make eppy read the new JSON formats. Initial investigations shows that it is not too hard to develop this functionality. Internally eppy will continue to use the old format. Hopefully this will make the JSON reading functionality trivially easy. At the moment, E+ maintains a one to one mapping between the old IDD/IDF format and the new JSON format. This mapping is embedded in the file Energy+.schema.epJSON, pointing to an easy compatibility strategy.
In the long term, this may not be a viable strategy, as E+ may totally abandon the IDD/IDF file format breaking the link between JSON and IDD/IDF. Discussion thread at `unmethours <https://unmethours.com/question/36062/hvac-templates-to-be-discontinued/>`_ seems to indicate that this is about 5 yers in the future.
Future possibilites
-------------------
A number of possibilites came up in discussions at Simbuild 2018 in Chicago. The biggest takeaway was that the code base for the JSON format and the dot syntax can lead to a universal translator between modelling file formats. The thinking here is that if there exists a schema.JSON for two modelling file structures, the possibility of translating between the two exists.
Of course *the proof is in the pudding*. So we are going to write some quick and dirty translators between E+ and DOE2.1E (or EQuest) as well as between the older idds and the new epJSON. Lets see how that goes.
Credits
-------
This package was created with Cookiecutter_ and the `audreyr/cookiecutter-pypackage`_ project template.
.. _Cookiecutter: https://github.com/audreyr/cookiecutter
.. _`audreyr/cookiecutter-pypackage`: https://github.com/audreyr/cookiecutter-pypackage
=======
History
=======
Releases
--------
Release 0.1.13 (2021-03-16)
----------------------------
2021-03-16
~~~~~~~~~~
Fixed #76
:Problem: Need easier conversion from IDF to epJSON
:Solution: ``idffile2epjfile`` will convert a single file and ``idffolder2epjfolder`` will do batch conversion
Date: Mon Jan 18 21:53:40 PST 2021
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
fixed issue #73
:Problem: Would be nice to have an html viewer for epj
:Solution: pytested eppy3000.epjviewer with sphinx user documentation
Date: Tue Jan 12 14:18:37 PST 2021
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
fixed issue #69
:Problem: no EPJ.run() function
:Solution: EPJ.run() function implemented
Release 0.1.4 (2020-07-09)
---------------------------
Date: Tue Jul 7 08:09:26 2020 -0700
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Fixed issue #48
:Problem: No Tutorial for eppy3000
:Solution: tutorial for eppy3000
+ This tutorial is based on eppy tutorial
+ Identifies the gaps in the eppy3000 tagged by TODO in the tutorial
+ open issues on these TODOs and resolve
Release 0.1.3 (2020-07-04)
--------------------------
Date: Wed May 13 14:20:34 2020 -0700
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
fixed issue # 45
Problem: setup.py not including folders `oldeppy` and `experimental`
Solution: setup.py updated and tested
Release 0.1.2 (2020-05-12)
--------------------------
Date: Tue May 12 08:11:39 2020 -0700
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
fixed issue #41
Problem: function to get an array of xyz points from the surfaces
Solution: function in eppy300.experimental.listfields.surf2list()
Date: Mon May 11 08:15:50 2020 -0700
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
fixed issue #34
Problem: need an easy to use converter between
epj (epyy300 format) and idf (eppy format)
Solution: functions idf2epj() epj2idf() do this.
epj.saveas(filename) and idf.saveas(filename)
will save it to disk
Date: Mon May 11 15:35:54 2020 -0700
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
fixed issue #39
**Problem:** need a place to put experimental functions
**Solution:** created an experimental folder in eppy3000
Date: Mon May 11 08:15:50 2020 -0700
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
fixed issue #34
Problem: need an easy to use converter between
epj (epyy300 format) and idf (eppy format)
Solution: functions idf2epj() epj2idf() do this.
epj.saveas(filename) and idf.saveas(filename)
will save it to disk
Sun May 10 09:26:32 2020 -0700
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
fixed issue #36
Problem: modelbuilder.EPJ need savecopy() to fix issue #34
Solution: coded EPJ.savecopy and EPJ.jsonstr()
Release 0.1.1 (2019-06-06)
--------------------------
2019-06-06
~~~~~~~~~~
- functions to read and write IDF files
- issue #20
0.1.0 (2018-10-15)
------------------
* First release on PyPI.
Raw data
{
"_id": null,
"home_page": "https://github.com/pyenergyplus/eppy3000",
"name": "eppy3000",
"maintainer": "",
"docs_url": null,
"requires_python": "",
"maintainer_email": "",
"keywords": "eppy3000",
"author": "Santosh Philip",
"author_email": "santosh@noemail.com",
"download_url": "https://files.pythonhosted.org/packages/ab/53/278a38dd74990fbc15d466d77b6ee242ab11413efba0f68cfd20508e3049/eppy3000-0.1.15.tar.gz",
"platform": null,
"description": "========\neppy3000\n========\n\n\n.. image:: https://img.shields.io/pypi/v/eppy3000.svg\n :target: https://pypi.python.org/pypi/eppy3000\n\n.. image:: https://img.shields.io/travis/pyenergyplus/eppy3000.svg\n :target: https://travis-ci.org/pyenergyplus/eppy3000\n\n.. image:: https://readthedocs.org/projects/eppy3000/badge/?version=latest\n :target: https://eppy3000.readthedocs.io/en/latest/?badge=latest\n :alt: Documentation Status\n\n\n\n\nE+ scripting using epJSON file format\n\n\n* Free software: Mozilla Public License, v. 2.0\n* Documentation: https://eppy3000.readthedocs.io.\n* Home Page: https://github.com/pyenergyplus/eppy3000\n\n\nFeatures - so far :-)\n---------------------\n\n* Open and read an epJSON file with *some* `eppy <https://github.com/santoshphilip/eppy>`_ functionality.\n* Right now the `eppy <https://github.com/santoshphilip/eppy>`_ functionality is only partial\n\n\nBackground\n----------\n\nE+ has been moving from the IDD/IDF text format to a JSON format. `Eppy <https://github.com/santoshphilip/eppy>`_ reads the old IDD/IDF format. There is a need to have `eppy <https://github.com/santoshphilip/eppy>`_ read the JSON format and/or have a new package that will read the JSON format.\n\nWhats in a name\n---------------\n\nWhy is this package called eppy3000 ?\n\nIt is a play on the word python3000. Guido van van Rossum said about python in 2007 *\"The first time I came up with the idea of Python 3000 was probably at a Python conference in the year 2000. The name was a take on Windows 2000. ...<snip>... The idea was that Python 3000 would be the first Python release to give up backwards compatibility in favor of making it the best language going forward.\"*\n\nEppy3000 will also break backward compatibility with eppy. Also eppy3000 will be written only for python3. Eppy3000 and eppy will continue to remain the best scripting language for modelling :-)\n\n\nSo what is eppy3000\n-------------------\n\nThis project is an attempt to read JSON file formats and work like eppy. There is some value in trying to do this from scratch. The dot syntax that makes the original eppy useful can be recreated with a couple of lines in eppy3000. It took a lot of deep hacking to make the dot syntax work in the original eppy. Eppy3000 reads the JSON format as a dictionary. The package `Munch <https://github.com/Infinidat/munch>`_ (what was `Bunch <https://github.com/dsc/bunch>`_) allows the use of dot format syntax with a dictionary. The code is as simple as::\n\n as_json = json.load(open(fname, 'r'))\n for_dot_syntax = DefaultMunch.fromDict(as_json)\n\nAt this point eppy3000 is an exploration to find out what is possible. The API in eppy3000 will not be stable as we explore the possibilities. So, don't use it as production code yet :-)\n\n\nWhat about eppy\n---------------\n\nEppy will be continue to be developed and maintained. A major task will be to make eppy read the new JSON formats. Initial investigations shows that it is not too hard to develop this functionality. Internally eppy will continue to use the old format. Hopefully this will make the JSON reading functionality trivially easy. At the moment, E+ maintains a one to one mapping between the old IDD/IDF format and the new JSON format. This mapping is embedded in the file Energy+.schema.epJSON, pointing to an easy compatibility strategy.\n\nIn the long term, this may not be a viable strategy, as E+ may totally abandon the IDD/IDF file format breaking the link between JSON and IDD/IDF. Discussion thread at `unmethours <https://unmethours.com/question/36062/hvac-templates-to-be-discontinued/>`_ seems to indicate that this is about 5 yers in the future.\n\n\nFuture possibilites\n-------------------\n\nA number of possibilites came up in discussions at Simbuild 2018 in Chicago. The biggest takeaway was that the code base for the JSON format and the dot syntax can lead to a universal translator between modelling file formats. The thinking here is that if there exists a schema.JSON for two modelling file structures, the possibility of translating between the two exists.\n\nOf course *the proof is in the pudding*. So we are going to write some quick and dirty translators between E+ and DOE2.1E (or EQuest) as well as between the older idds and the new epJSON. Lets see how that goes.\n\n\nCredits\n-------\n\nThis package was created with Cookiecutter_ and the `audreyr/cookiecutter-pypackage`_ project template.\n\n.. _Cookiecutter: https://github.com/audreyr/cookiecutter\n.. _`audreyr/cookiecutter-pypackage`: https://github.com/audreyr/cookiecutter-pypackage\n\n\n=======\nHistory\n=======\n\nReleases\n--------\n\n\nRelease 0.1.13 (2021-03-16)\n----------------------------\n\n2021-03-16\n~~~~~~~~~~\n\nFixed #76\n\n:Problem: Need easier conversion from IDF to epJSON\n:Solution: ``idffile2epjfile`` will convert a single file and ``idffolder2epjfolder`` will do batch conversion\n\nDate: Mon Jan 18 21:53:40 PST 2021\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\nfixed issue #73\n\n:Problem: Would be nice to have an html viewer for epj\n:Solution: pytested eppy3000.epjviewer with sphinx user documentation\n\nDate: Tue Jan 12 14:18:37 PST 2021\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\nfixed issue #69\n\n:Problem: no EPJ.run() function\n:Solution: EPJ.run() function implemented\n\n\nRelease 0.1.4 (2020-07-09)\n---------------------------\n\n\nDate: Tue Jul 7 08:09:26 2020 -0700\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\nFixed issue #48\n\n:Problem: No Tutorial for eppy3000\n:Solution: tutorial for eppy3000\n\n+ This tutorial is based on eppy tutorial\n+ Identifies the gaps in the eppy3000 tagged by TODO in the tutorial\n+ open issues on these TODOs and resolve\n\n\nRelease 0.1.3 (2020-07-04)\n--------------------------\n\nDate: Wed May 13 14:20:34 2020 -0700\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\n fixed issue # 45\n \n Problem: setup.py not including folders `oldeppy` and `experimental`\n Solution: setup.py updated and tested\n\n\n\nRelease 0.1.2 (2020-05-12)\n--------------------------\n\nDate: Tue May 12 08:11:39 2020 -0700\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\n fixed issue #41\n \n Problem: function to get an array of xyz points from the surfaces\n Solution: function in eppy300.experimental.listfields.surf2list()\n\n\nDate: Mon May 11 08:15:50 2020 -0700\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\n fixed issue #34\n \n Problem: need an easy to use converter between\n epj (epyy300 format) and idf (eppy format)\n \n Solution: functions idf2epj() epj2idf() do this.\n epj.saveas(filename) and idf.saveas(filename)\n will save it to disk\n\n\n\nDate: Mon May 11 15:35:54 2020 -0700\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\n fixed issue #39\n\n **Problem:** need a place to put experimental functions\n **Solution:** created an experimental folder in eppy3000\n\n\nDate: Mon May 11 08:15:50 2020 -0700\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\n fixed issue #34\n \n Problem: need an easy to use converter between\n epj (epyy300 format) and idf (eppy format)\n \n Solution: functions idf2epj() epj2idf() do this.\n epj.saveas(filename) and idf.saveas(filename)\n will save it to disk\n\n\n\nSun May 10 09:26:32 2020 -0700\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\n fixed issue #36\n\n Problem: modelbuilder.EPJ need savecopy() to fix issue #34\n Solution: coded EPJ.savecopy and EPJ.jsonstr()\n\n\n\n\n\nRelease 0.1.1 (2019-06-06)\n--------------------------\n\n2019-06-06\n~~~~~~~~~~\n\n- functions to read and write IDF files\n - issue #20\n\n0.1.0 (2018-10-15)\n------------------\n\n* First release on PyPI.\n",
"bugtrack_url": null,
"license": "Mozilla Public License, v. 2.0",
"summary": "E+ scripting using epJSON file format",
"version": "0.1.15",
"split_keywords": [
"eppy3000"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "ec915692e93f28c04fd338159d985c477d3c28cadf87a6f9e9986d304d8893ee",
"md5": "6417eccb16d2516cd54de2307dcd7d5b",
"sha256": "03857c0a3b537eb1e48a1b212fc67c0d86c0ee510fbcde70bbafd88af675640e"
},
"downloads": -1,
"filename": "eppy3000-0.1.15-py2.py3-none-any.whl",
"has_sig": false,
"md5_digest": "6417eccb16d2516cd54de2307dcd7d5b",
"packagetype": "bdist_wheel",
"python_version": "py2.py3",
"requires_python": null,
"size": 38440,
"upload_time": "2023-04-22T14:33:22",
"upload_time_iso_8601": "2023-04-22T14:33:22.335461Z",
"url": "https://files.pythonhosted.org/packages/ec/91/5692e93f28c04fd338159d985c477d3c28cadf87a6f9e9986d304d8893ee/eppy3000-0.1.15-py2.py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "ab53278a38dd74990fbc15d466d77b6ee242ab11413efba0f68cfd20508e3049",
"md5": "1a030d403008f0f73b246255174943f1",
"sha256": "9f2ef8a2cc660ea6f6ef3782868393e71a02d2afe43bfe4b658f78070f0e20db"
},
"downloads": -1,
"filename": "eppy3000-0.1.15.tar.gz",
"has_sig": false,
"md5_digest": "1a030d403008f0f73b246255174943f1",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 588609,
"upload_time": "2023-04-22T14:33:30",
"upload_time_iso_8601": "2023-04-22T14:33:30.038720Z",
"url": "https://files.pythonhosted.org/packages/ab/53/278a38dd74990fbc15d466d77b6ee242ab11413efba0f68cfd20508e3049/eppy3000-0.1.15.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-04-22 14:33:30",
"github": true,
"gitlab": false,
"bitbucket": false,
"github_user": "pyenergyplus",
"github_project": "eppy3000",
"travis_ci": true,
"coveralls": false,
"github_actions": false,
"requirements": [],
"tox": true,
"lcname": "eppy3000"
}