The Energy Trading System (ETS) is a website <http://ets.aeso.ca> made available by the Alberta Electric System Operator (AESO) <http://www.aeso.ca> for energy trading and public information purposes. The ets module makes access to many of the reporting functions easier. This is useful for the contruction of market models and various heuristic “expert” trading systems.
The pyaeso.ets module defines the following functions:
Returns a file-like object attached to the ETS pool price report webservice. Note that the webservice limits the number of days that can be queried to 721 days (as of 2009-11-12).
| Parameters: | 
 | 
|---|---|
| Return type: | file-like object as returned by urlopen. | 
Usage example:
>>> # 3rd Party Libraries
>>> from pyaeso import ets
>>>
>>> end_date = datetime.date.today()
>>> start_date = end_date - datetime.timedelta(1)
>>>
>>> f = ets.urlopen_pool_price(start_date, end_date)
>>> print f.read()
>>> f.close()
Note
The raw ETS pool price report can be accessed at <http://ets.aeso.ca/ets_web/ip/Market/Reports/HistoricalPoolPriceReportServlet>.
Downloads market equilibrium data from ETS and writes it to the file object f_out. Unlike urlopen_pool_price there is no restriction on the amount of data that can be requested. Internally an iterator is used to query data in 721 day blocks before it is written to f_out.
Usage example:
>>> # 3rd Party Libraries
>>> from pyaeso import ets
>>>
>>> end_date = datetime.date.today()
>>> start_date = end_date - datetime.timedelta(1)
>>>
>>> f = open('pool_price_report.csv', 'w')
>>> ets.dump_pool_price(f, start_date, end_date)
>>> f.close()
Yields QpPoint objects as extracted from the open CSV file-object f.
Usage example:
>>> # Standard library imports
>>> from StringIO import StringIO
>>> import datetime
>>>
>>> # 3rd Party Libraries
>>> from pyaeso import ets
>>>
>>> end_date = datetime.date.today()
>>> start_date = end_date - datetime.timedelta(1)
>>>
>>> f = StringIO()
>>> ets.dump_pool_price(f, start_date, end_date)
>>> f.seek(0)
>>> data = list(ets.parse_pool_price_file(f))
>>> f.close()
>>>
>>> print "Yesterday's market clearing price/demand points."
>>> for d in data:
...   ab_time = d.t.astimezone(ets.ALBERTA_TZ)
...   print '{0} ${1} {2}MW'.format(ab_time, d.price, d.demand)
Returns a file-like object containing data returned by the ETS asset list webservice.
| Return type: | file-like object as returned by urlopen. | 
|---|
New in version 0.2.
Usage example:
>>> # 3rd Party Libraries
>>> from pyaeso import ets
>>>
>>> f = ets.urlopen_asset_list()
>>> print f.read()
>>> f.close()
Note
The raw ETS asset list report can be accessed at <http://ets.aeso.ca/ets_web/ip/Market/Reports/AssetListReportServlet>.
Downloads asset list report and writes it to file-object f.
New in version 0.2.
Usage example:
>>> # 3rd Party Libraries
>>> from pyaeso import ets
>>>
>>> f = open('asset_list_report.csv', 'w')
>>> ets.dump_asset_list(f)
>>> f.close()
Yields Asset objects extracted from the open file-object f.
New in version 0.2.
Usage example:
>>> # 3rd Party Libraries
>>> from pyaeso import ets
>>>
>>>
>>> f = ets.urlopen_asset_list()
>>> assets = list(ets.parse_asset_list_file(f))
>>> f.close()
Returns a file-like object attached to the ETS marginal pool price report. The report is limited by AESO to returning 31 days of information (2010-02-09). The report will include data for start_date but not for end_date. The earliest date for which marginal price information is available is 1999-10-01 (2010-02-10). start_date must be before end_date.
| Parameters: | 
 | 
|---|---|
| Return type: | file-like object as returned by urlopen. | 
New in version 0.4.
Usage example:
>>> # Standard library imports
>>> from datetime import date
>>> from datetime import timedelta
>>>
>>> # 3rd Party Libraries
>>> from pyaeso.ets import urlopen_marginal_pool_price
>>>
>>> start_date = datetime.date(2010, 1, 1)
>>> end_date = datetime.date(2010, 1, 31) + datetime.timedelta(1)
>>> # If you want to include all days in january, must add 24 hours.
>>> # Remember that there will be no information returned for
>>> # *end_date* itself, only for dates prior to it!
>>>
>>> f = urlopen_marginal_pool_price(start_date, end_date)
>>> text = f.read()
Downloads market marginal pool price data from ETS and writes it to file object dst. Unlike urlopen_marginal_pool_price there is no limit on the amount of data that can be requested. Internally an iterator is used to query data in 31 day blocks before it is written to dst. Output is included for start_date but excludes data for end_date.
| Parameters: | 
 | 
|---|
New in version 0.4.
Usage example:
>>> # Standard library imports
>>> from datetime import date
>>> from datetime import timedelta
>>> from StringIO import StringIO
>>>
>>> # 3rd Party Libraries
>>> from pyaeso.ets import dump_marginal_pool_price
>>>
>>> start_date = datetime.date(2010, 1, 1)
>>> end_date = datetime.date(2010, 1, 31) + datetime.timedelta(1)
>>> # Remember, no data will be returned on end_date itself!
>>>
>>> f = StringIO()
>>> dump_marginal_pool_price(f)
>>> text = f.getvalue()
Yields a PPoint object for each price point in marginal pool price data report file-object f. As always, times are UTC.
New in version 0.4.
Usage example:
>>> # Standard library imports
>>> from datetime import date
>>> from datetime import timedelta
>>> from StringIO import StringIO
>>>
>>> # 3rd Party Libraries
>>> from pyaeso.ets import dump_marginal_pool_price, parse_marginal_pool_price_file
>>> from pyaeso import ets
>>>
>>> start_date = datetime.date(2010, 1, 1)
>>> end_date = datetime.date(2010, 1, 31) + datetime.timedelta(1)
>>> # Remember, no data will be returned on end_date itself!
>>>
>>> f = StringIO()
>>> dump_marginal_pool_price(f)
>>> f.seek(0)
>>>
>>> points = list(parse_marginal_pool_price_file(f))
>>>
>>> for pp in points:
...   # PPoint objects are iterable and can be unpacked!
...   time, price = pp
...   print time.astimezone(ets.ALBERTA_TZ), '$' + str(price)
...   # *time* is in UTC, so it must be converted to Alberta
...   # timezone before display.
Represents the market equilibrium at a given point in time.
UTC localized time at which price and demand are valid. Normally this time should be localized to Alberta Mountain Standard Time before being displayed to the user. (@type datetime.datetime)
Usage Example:
# QpPoint object *qp* as yielded by parse_pool_price_file method
qp.t.astimezone(ets.ALBERTA_TZ)`
Power price in CDN$/MW (@type Decimal).
Power demand in megawatts (MW) (@type Decimal).
An enumeration of asset status’.
New in version 0.2.
New in version 0.2.
(@type str)
(@type str)
A value from AssetStatus enumeration.
(@type str)
(@type str)
A price at a given point in time.
Since PPoint objects will iterate over their properties t, and price, they can be unpacked as in the example. Also of note is that the time, t, attribute is normally stored in UTC and is normally converted to Alberta’s timezone before display.
New in version 0.4.
Usage example:
>>> from datetime import datetime
>>> from pyaeso import ets
>>>
>>> point = PPoint(datetime(2010, 2, 12, 10, 36), 4.56)
>>> t, price = point
>>> t.astimezone(ets.ALBERTA_TZ)
This is a UTC time and so normally must be converted to Alberta’s timezone before display.
(@type datetime.datetime).
(@type Decimal).